UNPKG

3.14 MBSource Map (JSON)View Raw
1{"version":3,"sources":["webpack://[name]/webpack/universalModuleDefinition","webpack://[name]/./node_modules/_@babel_polyfill@7.12.1@@babel/polyfill/lib/noConflict.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/regenerator/index.js","webpack://[name]/./node_modules/_@webgpu_types@0.0.31@@webgpu/types/dist/constants.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/es6/index.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/fn/array/flat-map.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/fn/array/includes.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/fn/object/entries.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/fn/object/get-own-property-descriptors.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/fn/object/values.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/fn/promise/finally.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/fn/string/pad-end.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/fn/string/pad-start.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/fn/string/trim-end.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/fn/string/trim-start.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/fn/symbol/async-iterator.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/fn/global.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_a-function.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_an-object.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_core.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_ctx.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_descriptors.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_dom-create.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_export.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_fails.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_global.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_has.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_hide.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_ie8-dom-define.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_is-object.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_object-dp.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_property-desc.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/_to-primitive.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/library/modules/es7.global.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_a-function.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_a-number-value.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_add-to-unscopables.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_advance-string-index.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_an-instance.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_an-object.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_array-copy-within.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_array-fill.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_array-includes.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_array-methods.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_array-reduce.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_array-species-constructor.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_array-species-create.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_bind.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_classof.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_cof.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_collection-strong.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_collection-weak.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_collection.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_core.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_create-property.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_ctx.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_date-to-iso-string.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_date-to-primitive.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_defined.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_descriptors.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_dom-create.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_enum-bug-keys.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_enum-keys.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_export.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_fails-is-regexp.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_fails.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_fix-re-wks.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_flags.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_flatten-into-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_for-of.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_function-to-string.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_global.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_has.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_hide.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_html.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_ie8-dom-define.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_inherit-if-required.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_invoke.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_iobject.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_is-array-iter.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_is-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_is-integer.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_is-object.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_is-regexp.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_iter-call.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_iter-create.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_iter-define.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_iter-detect.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_iter-step.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_iterators.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_library.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_math-expm1.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_math-fround.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_math-log1p.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_math-sign.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_meta.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_microtask.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_new-promise-capability.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-assign.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-create.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-dp.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-dps.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-gopd.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-gopn-ext.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-gopn.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-gops.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-gpo.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-keys-internal.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-keys.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-pie.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-sap.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_object-to-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_own-keys.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_parse-float.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_parse-int.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_perform.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_promise-resolve.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_property-desc.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_redefine-all.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_redefine.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_regexp-exec-abstract.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_regexp-exec.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_same-value.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_set-proto.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_set-species.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_set-to-string-tag.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_shared-key.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_shared.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_species-constructor.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_strict-method.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_string-at.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_string-context.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_string-html.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_string-pad.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_string-repeat.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_string-trim.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_string-ws.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_task.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_to-absolute-index.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_to-index.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_to-integer.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_to-iobject.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_to-length.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_to-object.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_to-primitive.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_typed-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_typed-buffer.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_typed.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_uid.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_user-agent.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_validate-collection.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_wks-define.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_wks-ext.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/_wks.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/core.get-iterator-method.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.copy-within.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.every.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.fill.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.filter.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.find-index.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.find.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.for-each.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.from.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.index-of.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.is-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.iterator.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.join.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.last-index-of.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.map.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.of.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.reduce-right.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.reduce.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.slice.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.some.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.sort.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.array.species.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.date.now.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.date.to-iso-string.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.date.to-json.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.date.to-primitive.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.date.to-string.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.function.bind.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.function.has-instance.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.function.name.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.map.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.acosh.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.asinh.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.atanh.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.cbrt.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.clz32.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.cosh.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.expm1.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.fround.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.hypot.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.imul.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.log10.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.log1p.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.log2.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.sign.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.sinh.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.tanh.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.math.trunc.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.number.constructor.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.number.epsilon.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.number.is-finite.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.number.is-integer.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.number.is-nan.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.number.is-safe-integer.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.number.max-safe-integer.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.number.min-safe-integer.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.number.parse-float.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.number.parse-int.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.number.to-fixed.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.number.to-precision.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.assign.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.create.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.define-properties.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.define-property.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.freeze.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.get-own-property-descriptor.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.get-own-property-names.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.get-prototype-of.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.is-extensible.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.is-frozen.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.is-sealed.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.is.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.keys.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.prevent-extensions.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.seal.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.set-prototype-of.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.object.to-string.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.parse-float.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.parse-int.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.promise.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.apply.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.construct.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.define-property.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.delete-property.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.enumerate.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.get-own-property-descriptor.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.get-prototype-of.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.get.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.has.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.is-extensible.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.own-keys.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.prevent-extensions.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.set-prototype-of.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.reflect.set.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.regexp.constructor.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.regexp.exec.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.regexp.flags.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.regexp.match.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.regexp.replace.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.regexp.search.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.regexp.split.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.regexp.to-string.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.set.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.anchor.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.big.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.blink.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.bold.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.code-point-at.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.ends-with.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.fixed.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.fontcolor.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.fontsize.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.from-code-point.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.includes.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.italics.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.iterator.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.link.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.raw.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.repeat.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.small.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.starts-with.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.strike.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.sub.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.sup.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.string.trim.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.symbol.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.typed.array-buffer.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.typed.data-view.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.typed.float32-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.typed.float64-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.typed.int16-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.typed.int32-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.typed.int8-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.typed.uint16-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.typed.uint32-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.typed.uint8-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.typed.uint8-clamped-array.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.weak-map.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es6.weak-set.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es7.array.flat-map.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es7.array.includes.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es7.object.entries.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es7.object.get-own-property-descriptors.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es7.object.values.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es7.promise.finally.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es7.string.pad-end.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es7.string.pad-start.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es7.string.trim-left.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es7.string.trim-right.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/es7.symbol.async-iterator.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/web.dom.iterable.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/web.immediate.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/modules/web.timers.js","webpack://[name]/./node_modules/_core-js@2.6.12@core-js/web/index.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/index.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/acyclic.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/add-border-segments.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/coordinate-system.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/data/list.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/debug.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/graphlib.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/greedy-fas.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/layout.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/lodash.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/nesting-graph.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/normalize.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/order/add-subgraph-constraints.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/order/barycenter.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/order/build-layer-graph.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/order/cross-count.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/order/index.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/order/init-order.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/order/resolve-conflicts.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/order/sort-subgraph.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/order/sort.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/parent-dummy-chains.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/position/bk.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/position/index.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/rank/feasible-tree.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/rank/index.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/rank/network-simplex.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/rank/util.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/util.js","webpack://[name]/./node_modules/_dagre@0.8.5@dagre/lib/version.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/add.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/ceil.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/clone.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/copy.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/create.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/cross.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/dist.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/distance.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/div.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/divide.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/dot.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/epsilon.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/equals.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/exactEquals.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/floor.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/forEach.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/fromValues.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/index.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/inverse.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/len.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/length.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/lerp.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/limit.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/max.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/min.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/mul.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/multiply.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/negate.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/normalize.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/random.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/rotate.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/round.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/scale.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/scaleAndAdd.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/set.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/sqrDist.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/sqrLen.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/squaredDistance.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/squaredLength.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/sub.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/subtract.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/transformMat2.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/transformMat2d.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/transformMat3.js","webpack://[name]/./node_modules/_gl-vec2@1.3.0@gl-vec2/transformMat4.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/index.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/components.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/dfs.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/dijkstra-all.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/dijkstra.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/find-cycles.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/floyd-warshall.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/index.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/is-acyclic.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/postorder.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/preorder.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/prim.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/tarjan.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/alg/topsort.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/data/priority-queue.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/graph.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/index.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/json.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/lodash.js","webpack://[name]/./node_modules/_graphlib@2.1.8@graphlib/lib/version.js","webpack://[name]/./node_modules/_inversify-inject-decorators@3.1.0@inversify-inject-decorators/lib/decorators.js","webpack://[name]/./node_modules/_inversify-inject-decorators@3.1.0@inversify-inject-decorators/lib/index.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/annotation/decorator_utils.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/annotation/inject.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/annotation/injectable.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/annotation/multi_inject.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/annotation/named.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/annotation/optional.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/annotation/post_construct.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/annotation/tagged.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/annotation/target_name.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/annotation/unmanaged.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/bindings/binding.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/bindings/binding_count.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/constants/error_msgs.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/constants/literal_types.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/constants/metadata_keys.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/container/container.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/container/container_module.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/container/container_snapshot.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/container/lookup.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/inversify.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/planning/context.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/planning/metadata.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/planning/metadata_reader.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/planning/plan.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/planning/planner.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/planning/queryable_string.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/planning/reflection_utils.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/planning/request.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/planning/target.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/resolution/instantiation.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/resolution/resolver.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/syntax/binding_in_syntax.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/syntax/binding_in_when_on_syntax.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/syntax/binding_on_syntax.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/syntax/binding_to_syntax.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/syntax/binding_when_on_syntax.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/syntax/binding_when_syntax.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/syntax/constraint_helpers.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/utils/binding_utils.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/utils/exceptions.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/utils/id.js","webpack://[name]/./node_modules/_inversify@5.0.5@inversify/lib/utils/serialization.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_DataView.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_Hash.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_ListCache.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_Map.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_MapCache.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_Promise.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_Set.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_SetCache.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_Stack.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_Symbol.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_Uint8Array.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_WeakMap.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_apply.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_arrayEach.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_arrayFilter.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_arrayIncludes.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_arrayIncludesWith.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_arrayLikeKeys.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_arrayMap.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_arrayPush.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_arrayReduce.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_arraySome.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_asciiSize.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_assignMergeValue.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_assignValue.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_assocIndexOf.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseAssign.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseAssignIn.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseAssignValue.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseClone.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseCreate.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseEach.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseExtremum.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseFilter.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseFindIndex.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseFlatten.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseFor.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseForOwn.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseGet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseGetAllKeys.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseGetTag.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseGt.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseHas.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseHasIn.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseIndexOf.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseIsArguments.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseIsEqual.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseIsEqualDeep.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseIsMap.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseIsMatch.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseIsNaN.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseIsNative.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseIsSet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseIsTypedArray.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseIteratee.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseKeys.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseKeysIn.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseLt.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseMap.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseMatches.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseMatchesProperty.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseMerge.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseMergeDeep.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseOrderBy.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_basePick.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_basePickBy.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseProperty.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_basePropertyDeep.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseRange.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseReduce.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseRest.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseSet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseSetToString.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseSortBy.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseTimes.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseToString.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseTrim.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseUnary.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseUniq.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseValues.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_baseZipObject.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_cacheHas.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_castFunction.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_castPath.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_cloneArrayBuffer.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_cloneBuffer.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_cloneDataView.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_cloneRegExp.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_cloneSymbol.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_cloneTypedArray.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_compareAscending.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_compareMultiple.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_copyArray.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_copyObject.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_copySymbols.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_copySymbolsIn.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_coreJsData.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_createAssigner.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_createBaseEach.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_createBaseFor.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_createFind.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_createRange.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_createSet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_defineProperty.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_equalArrays.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_equalByTag.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_equalObjects.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_flatRest.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_freeGlobal.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_getAllKeys.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_getAllKeysIn.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_getMapData.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_getMatchData.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_getNative.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_getPrototype.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_getRawTag.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_getSymbols.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_getSymbolsIn.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_getTag.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_getValue.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_hasPath.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_hasUnicode.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_hashClear.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_hashDelete.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_hashGet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_hashHas.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_hashSet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_initCloneArray.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_initCloneByTag.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_initCloneObject.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_isFlattenable.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_isIndex.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_isIterateeCall.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_isKey.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_isKeyable.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_isMasked.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_isPrototype.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_isStrictComparable.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_listCacheClear.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_listCacheDelete.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_listCacheGet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_listCacheHas.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_listCacheSet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_mapCacheClear.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_mapCacheDelete.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_mapCacheGet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_mapCacheHas.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_mapCacheSet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_mapToArray.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_matchesStrictComparable.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_memoizeCapped.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_nativeCreate.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_nativeKeys.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_nativeKeysIn.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_nodeUtil.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_objectToString.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_overArg.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_overRest.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_root.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_safeGet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_setCacheAdd.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_setCacheHas.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_setToArray.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_setToString.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_shortOut.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_stackClear.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_stackDelete.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_stackGet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_stackHas.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_stackSet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_strictIndexOf.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_stringSize.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_stringToPath.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_toKey.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_toSource.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_trimmedEndIndex.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/_unicodeSize.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/clone.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/cloneDeep.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/constant.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/defaults.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/each.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/eq.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/filter.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/find.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/findIndex.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/flatten.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/forEach.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/forIn.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/get.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/has.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/hasIn.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/identity.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isArguments.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isArray.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isArrayLike.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isArrayLikeObject.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isBuffer.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isEmpty.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isFunction.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isLength.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isMap.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isObject.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isObjectLike.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isPlainObject.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isSet.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isString.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isSymbol.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isTypedArray.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/isUndefined.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/keys.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/keysIn.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/last.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/map.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/mapValues.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/max.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/memoize.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/merge.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/min.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/minBy.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/noop.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/now.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/pick.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/property.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/range.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/reduce.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/size.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/sortBy.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/stubArray.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/stubFalse.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/toFinite.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/toInteger.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/toNumber.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/toPlainObject.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/toString.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/transform.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/union.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/uniqueId.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/values.js","webpack://[name]/./node_modules/_lodash@4.17.21@lodash/zipObject.js","webpack://[name]/./node_modules/_polyline-miter-util@1.0.1@polyline-miter-util/index.js","webpack://[name]/./node_modules/_reflect-metadata@0.1.13@reflect-metadata/Reflect.js","webpack://[name]/./node_modules/_regenerator-runtime@0.13.7@regenerator-runtime/runtime.js","webpack://[name]/./node_modules/_regl@1.7.0@regl/dist/regl.js","webpack://[name]/webpack/bootstrap","webpack://[name]/webpack/runtime/compat get default export","webpack://[name]/webpack/runtime/define property getters","webpack://[name]/webpack/runtime/global","webpack://[name]/webpack/runtime/hasOwnProperty shorthand","webpack://[name]/webpack/runtime/make namespace object","webpack://[name]/webpack/runtime/node module decorator","webpack://[name]/./node_modules/_@babel_polyfill@7.12.1@@babel/polyfill/lib/index.js","webpack://[name]/./src/layout/base.ts","webpack://[name]/./src/util/string.ts","webpack://[name]/./src/util/array.ts","webpack://[name]/./src/util/number.ts","webpack://[name]/./src/util/math.ts","webpack://[name]/./src/util/object.ts","webpack://[name]/./src/util/function.ts","webpack://[name]/./src/registy/index.ts","webpack://[name]/./src/layout/grid.ts","webpack://[name]/./src/layout/random.ts","webpack://[name]/./src/layout/gForce.ts","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/add.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/quad.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/x.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/y.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/quadtree.js","webpack://[name]/./node_modules/_d3-force@2.1.1@d3-force/src/constant.js","webpack://[name]/./node_modules/_d3-force@2.1.1@d3-force/src/jiggle.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/cover.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/data.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/extent.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/find.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/remove.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/root.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/size.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/visit.js","webpack://[name]/./node_modules/_d3-quadtree@2.0.0@d3-quadtree/src/visitAfter.js","webpack://[name]/./node_modules/_d3-dispatch@2.0.0@d3-dispatch/src/dispatch.js","webpack://[name]/./node_modules/_d3-timer@2.0.0@d3-timer/src/timer.js","webpack://[name]/./node_modules/_d3-force@2.1.1@d3-force/src/lcg.js","webpack://[name]/./node_modules/_d3-force@2.1.1@d3-force/src/simulation.js","webpack://[name]/./node_modules/_d3-force@2.1.1@d3-force/src/manyBody.js","webpack://[name]/./node_modules/_d3-force@2.1.1@d3-force/src/link.js","webpack://[name]/./node_modules/_d3-force@2.1.1@d3-force/src/collide.js","webpack://[name]/./node_modules/_d3-force@2.1.1@d3-force/src/x.js","webpack://[name]/./node_modules/_d3-force@2.1.1@d3-force/src/y.js","webpack://[name]/./src/layout/constants.ts","webpack://[name]/./src/layout/force/force.ts","webpack://[name]/./src/layout/force/force-in-a-box.ts","webpack://[name]/./node_modules/_d3-force@2.1.1@d3-force/src/center.js","webpack://[name]/./src/layout/circular.ts","webpack://[name]/./src/layout/dagre.ts","webpack://[name]/./node_modules/_is-any-array@0.1.1@is-any-array/src/index.js","webpack://[name]/./node_modules/_ml-array-max@1.2.2@ml-array-max/lib-es6/index.js","webpack://[name]/./node_modules/_ml-array-min@1.2.1@ml-array-min/lib-es6/index.js","webpack://[name]/./node_modules/_ml-array-rescale@1.3.4@ml-array-rescale/lib-es6/index.js","webpack://[name]/./node_modules/_ml-matrix@6.6.0@ml-matrix/src/inspect.js","webpack://[name]/./node_modules/_ml-matrix@6.6.0@ml-matrix/src/util.js","webpack://[name]/./node_modules/_ml-matrix@6.6.0@ml-matrix/src/matrix.js","webpack://[name]/./node_modules/_ml-matrix@6.6.0@ml-matrix/src/stat.js","webpack://[name]/./node_modules/_ml-matrix@6.6.0@ml-matrix/src/mathOperations.js","webpack://[name]/./node_modules/_ml-matrix@6.6.0@ml-matrix/src/wrap/WrapperMatrix2D.js","webpack://[name]/./node_modules/_ml-matrix@6.6.0@ml-matrix/src/dc/util.js","webpack://[name]/./node_modules/_ml-matrix@6.6.0@ml-matrix/src/dc/svd.js","webpack://[name]/./src/layout/radial/mds.ts","webpack://[name]/./src/layout/radial/radialNonoverlapForce.ts","webpack://[name]/./src/layout/radial/radial.ts","webpack://[name]/./src/layout/concentric.ts","webpack://[name]/./src/layout/mds.ts","webpack://[name]/./src/layout/fruchterman.ts","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/initializerDefineProperty.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/classCallCheck.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/createClass.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/applyDecoratedDescriptor.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/asyncToGenerator.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/Entity.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/ComponentManager.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/arrayLikeToArray.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/unsupportedIterableToArray.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/slicedToArray.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/arrayWithHoles.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/iterableToArrayLimit.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/nonIterableRest.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/identifier.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/framegraph/FrameGraphHandle.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/framegraph/FrameGraphPass.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/framegraph/PassNode.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/setPrototypeOf.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/inherits.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/typeof.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/assertThisInitialized.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/possibleConstructorReturn.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/getPrototypeOf.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/framegraph/ResourceEntry.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/framegraph/System.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/framegraph/VirtualResource.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/framegraph/ResourceNode.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/defineProperty.js","webpack://[name]/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/common.js","webpack://[name]/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/vec4.js","webpack://[name]/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/mat3.js","webpack://[name]/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/vec3.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/utils/is-typedarray.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/geometry/GeometryComponent.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/renderer/gl.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/geometry/System.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/material/MaterialComponent.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/material/System.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/mesh/CullableComponent.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/shape/AABB.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/mesh/MeshComponent.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/shape/Frustum.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/shape/Plane.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/mesh/System.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/renderer/passes/RenderPass.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/utils/math.js","webpack://[name]/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/mat4.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/renderer/passes/PixelPickingPass.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/renderer/passes/CopyPass.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/renderer/System.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/scenegraph/HierarchyComponent.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/scenegraph/System.js","webpack://[name]/./node_modules/_gl-matrix@3.3.0@gl-matrix/esm/quat.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/scenegraph/TransformComponent.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/framegraph/ResourcePool.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/scenegraph/NameComponent.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/services/config/ConfigService.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/services/interactor/IteractorService.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/services/shader-module/ShaderModuleService.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/utils/shader-module.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/utils/uniq.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/inversify.config.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/utils/aabb.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/utils/isSafari.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/components/renderer/IMultiPassRenderer.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/index.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/utils/is-number.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/utils/math.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/shape/BoundingSphere.js","webpack://[name]/./node_modules/_@antv_g-webgpu-core@0.5.5@@antv/g-webgpu-core/es/shape/Ray.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/camera/Landmark.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/camera/Camera.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/geometry/index.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/utils/canvas.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/utils/is-type.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/utils/is-typedarray.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/Kernel.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/material/index.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/renderable/Renderable.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgl/constants.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/utils/is-array.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgl/ReglAttribute.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgl/ReglBuffer.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/toConsumableArray.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/arrayWithoutHoles.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/iterableToArray.js","webpack://[name]/./node_modules/_@babel_runtime@7.13.9@@babel/runtime/helpers/esm/nonIterableSpread.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/utils/is-typedarray.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgl/ReglComputeModel.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgl/ReglElements.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgl/ReglFramebuffer.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/utils/uniform.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/utils/is-object.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgl/ReglModel.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgl/index.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgpu/glslang.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgl/ReglTexture2D.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/utils/dom.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgpu/WebGPUAttribute.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgpu/constants.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgpu/WebGPUBuffer.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgpu/WebGPUComputeModel.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/utils/is-number.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgpu/WebGPUElements.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgpu/WebGPUFramebuffer.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgpu/WebGPUModel.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgpu/index.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/geometry/Box.js","webpack://[name]/./node_modules/_@antv_g-webgpu-engine@0.5.5@@antv/g-webgpu-engine/es/webgpu/WebGPUTexture2D.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/geometry/Merged.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/geometry/Plane.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/utils/typedarray.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/geometry/Sphere.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/material/basic/index.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/renderable/grid/index.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/renderable/line/index.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/utils/polyline-normals.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/renderable/point/index.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/Renderer.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/utils/picking.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/Scene.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/texture/Cache.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/texture/Texture2D.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/View.js","webpack://[name]/./node_modules/_@antv_g-webgpu@0.5.5@@antv/g-webgpu/es/World.js","webpack://[name]/./src/util/gpu.ts","webpack://[name]/./src/layout/gpu/fruchterman.ts","webpack://[name]/./src/layout/gpu/fruchtermanShader.ts","webpack://[name]/./src/layout/gpu/gForce.ts","webpack://[name]/./src/layout/gpu/gForceShader.ts","webpack://[name]/./src/layout/comboForce.ts","webpack://[name]/./src/layout/forceAtlas2/body.ts","webpack://[name]/./src/layout/forceAtlas2/quad.ts","webpack://[name]/./src/layout/forceAtlas2/quadTree.ts","webpack://[name]/./src/layout/forceAtlas2/index.ts","webpack://[name]/./src/layout/layout.ts"],"names":["root","factory","exports","module","define","amd","self","MapMode","TextureUsage","ShaderStage","ColorWrite","BufferUsage","CompilationMessageType","TextureAspect","VertexFormat","TextureViewDimension","TextureComponentType","TextureFormat","TextureDimension","StoreOp","StencilOperation","PrimitiveTopology","InputStepMode","IndexFormat","FrontFace","FilterMode","CullMode","CompareFunction","BlendOperation","BlendFactor","BindingType","AddressMode","it","TypeError","isObject","core","version","__e","aFunction","fn","that","length","undefined","a","call","b","c","apply","arguments","Object","defineProperty","get","document","is","createElement","global","ctx","hide","has","$export","type","name","source","key","own","out","IS_FORCED","F","IS_GLOBAL","G","IS_STATIC","S","IS_PROTO","P","IS_BIND","B","IS_WRAP","W","expProto","target","C","this","Function","virtual","R","U","exec","e","window","Math","__g","hasOwnProperty","dP","createDesc","object","value","f","anObject","IE8_DOM_DEFINE","toPrimitive","O","Attributes","bitmap","enumerable","configurable","writable","val","toString","valueOf","cof","msg","UNSCOPABLES","ArrayProto","Array","prototype","at","index","unicode","Constructor","forbiddenField","toObject","toAbsoluteIndex","toLength","copyWithin","start","len","to","from","end","count","min","inc","aLen","endPos","toIObject","IS_INCLUDES","$this","el","fromIndex","IObject","asc","TYPE","$create","IS_MAP","IS_FILTER","IS_SOME","IS_EVERY","IS_FIND_INDEX","NO_HOLES","create","callbackfn","res","result","push","memo","isRight","i","isArray","SPECIES","original","constructor","speciesConstructor","invoke","arraySlice","slice","factories","construct","args","n","join","bind","partArgs","bound","concat","TAG","ARG","T","tryGet","callee","redefineAll","anInstance","forOf","$iterDefine","step","setSpecies","DESCRIPTORS","fastKey","validate","SIZE","getEntry","entry","_i","_f","k","getConstructor","wrapper","NAME","ADDER","iterable","_t","_l","clear","data","r","p","next","prev","forEach","v","def","setStrong","iterated","kind","_k","getWeak","createArrayMethod","$has","arrayFind","arrayFindIndex","id","uncaughtFrozenStore","UncaughtFrozenStore","findUncaughtFrozen","store","set","splice","ufstore","redefine","meta","fails","$iterDetect","setToStringTag","inheritIfRequired","methods","common","IS_WEAK","Base","proto","fixMethod","KEY","entries","instance","HASNT_CHAINING","THROWS_ON_PRIMITIVES","ACCEPT_ITERABLES","iter","BUGGY_ZERO","$instance","NEED","$defineProperty","getTime","Date","$toISOString","toISOString","lz","num","NaN","isFinite","RangeError","d","y","getUTCFullYear","m","getUTCMilliseconds","s","abs","getUTCMonth","getUTCDate","getUTCHours","getUTCMinutes","getUTCSeconds","NUMBER","hint","split","getKeys","gOPS","pIE","getSymbols","symbols","isEnum","exp","MATCH","re","defined","wks","regexpExec","REPLACE_SUPPORTS_NAMED_GROUPS","groups","replace","SPLIT_WORKS_WITH_OVERWRITTEN_EXEC","originalExec","SYMBOL","DELEGATES_TO_SYMBOL","DELEGATES_TO_EXEC","execCalled","nativeRegExpMethod","fns","nativeMethod","regexp","str","arg2","forceStringMethod","done","strfn","rxfn","String","RegExp","string","arg","ignoreCase","multiline","sticky","IS_CONCAT_SPREADABLE","flattenIntoArray","sourceLen","depth","mapper","thisArg","element","spreadable","targetIndex","sourceIndex","mapFn","isArrayIter","getIterFn","BREAK","RETURN","ITERATOR","iterator","iterFn","documentElement","setPrototypeOf","un","propertyIsEnumerable","Iterators","floor","isRegExp","ret","descriptor","IteratorPrototype","LIBRARY","$iterCreate","getPrototypeOf","BUGGY","keys","KEYS","VALUES","returnThis","DEFAULT","IS_SET","FORCED","getMethod","DEF_VALUES","VALUES_BUG","$native","$default","$entries","$anyNative","values","SAFE_CLOSING","riter","skipClosing","safe","arr","$expm1","expm1","x","sign","pow","EPSILON","EPSILON32","MAX32","MIN32","fround","$abs","$sign","Infinity","log1p","log","META","setDesc","isExtensible","FREEZE","preventExtensions","setMeta","w","onFreeze","macrotask","Observer","MutationObserver","WebKitMutationObserver","process","Promise","isNode","head","last","notify","flush","parent","domain","exit","enter","nextTick","navigator","standalone","resolve","promise","then","toggle","node","createTextNode","observe","characterData","task","PromiseCapability","reject","$$resolve","$$reject","$assign","assign","A","Symbol","K","j","dPs","enumBugKeys","IE_PROTO","Empty","createDict","iframeDocument","iframe","style","display","src","contentWindow","open","write","lt","close","Properties","defineProperties","gOPD","getOwnPropertyDescriptor","gOPN","windowNames","getOwnPropertyNames","getWindowNames","$keys","hiddenKeys","getOwnPropertySymbols","ObjectProto","arrayIndexOf","names","isEntries","Reflect","ownKeys","$parseFloat","$trim","charAt","$parseInt","ws","hex","radix","test","newPromiseCapability","promiseCapability","SRC","$toString","TO_STRING","TPL","isFunction","classof","builtinExec","re1","re2","regexpFlags","nativeExec","nativeReplace","patchedExec","UPDATES_LAST_INDEX_WRONG","NPCG_INCLUDED","lastIndex","reCopy","match","check","buggy","__proto__","tag","stat","shared","uid","SHARED","mode","copyright","D","method","toInteger","pos","l","charCodeAt","searchString","quot","createHTML","attribute","p1","toLowerCase","repeat","maxLength","fillString","left","stringLength","fillStr","intMaxLength","fillLen","stringFiller","ceil","spaces","space","ltrim","rtrim","exporter","ALIAS","FORCE","trim","defer","channel","port","html","cel","setTask","setImmediate","clearTask","clearImmediate","MessageChannel","Dispatch","counter","queue","run","listener","event","now","port2","port1","onmessage","postMessage","addEventListener","importScripts","appendChild","removeChild","setTimeout","max","number","isNaN","$typed","$buffer","propertyDesc","toIndex","createArrayIncludes","ArrayIterators","arrayFill","arrayCopyWithin","$DP","$GOPD","Uint8Array","ARRAY_BUFFER","SHARED_BUFFER","BYTES_PER_ELEMENT","$ArrayBuffer","ArrayBuffer","$DataView","DataView","arrayForEach","arrayFilter","arraySome","arrayEvery","arrayIncludes","arrayValues","arrayKeys","arrayEntries","arrayLastIndexOf","lastIndexOf","arrayReduce","reduce","arrayReduceRight","reduceRight","arrayJoin","arraySort","sort","arrayToString","arrayToLocaleString","toLocaleString","TYPED_CONSTRUCTOR","DEF_CONSTRUCTOR","ALL_CONSTRUCTORS","CONSTR","TYPED_ARRAY","TYPED","VIEW","WRONG_LENGTH","$map","allocate","LITTLE_ENDIAN","Uint16Array","buffer","FORCED_SET","toOffset","BYTES","offset","speciesFromList","list","fromList","addGetter","internal","_d","$from","mapfn","mapping","$of","TO_LOCALE_BUG","$toLocaleString","every","fill","filter","find","predicate","findIndex","indexOf","searchElement","includes","separator","map","reverse","middle","some","comparefn","subarray","begin","$begin","byteOffset","$slice","$set","arrayLike","$iterators","isTAIndex","$getDesc","$setDesc","desc","$TypedArrayPrototype$","CLAMPED","GETTER","SETTER","TypedArray","TAC","ABV","TypedArrayPrototype","addElement","o","getter","round","setter","$offset","$length","byteLength","klass","$len","$nativeIterator","CORRECT_ITER_NAME","$iterator","of","DATA_VIEW","WRONG_INDEX","BaseBuffer","LN2","BUFFER","BYTE_LENGTH","BYTE_OFFSET","$BUFFER","$LENGTH","$OFFSET","packIEEE754","mLen","nBytes","eLen","eMax","eBias","rt","unpackIEEE754","nBits","unpackI32","bytes","packI8","packI16","packI32","packF64","packF32","view","isLittleEndian","intIndex","_b","pack","conversion","ArrayBufferProto","$setInt8","setInt8","getInt8","setUint8","bufferLength","getUint8","getInt16","getUint16","getInt32","getUint32","getFloat32","getFloat64","setInt16","setUint16","setInt32","setUint32","setFloat32","setFloat64","Typed","TypedArrayConstructors","px","random","userAgent","wksExt","$Symbol","USE_SYMBOL","$every","$filter","$find","forced","$forEach","STRICT","createProperty","$indexOf","NEGATIVE_ZERO","addToUnscopables","Arguments","$reduce","upTo","size","cloned","$some","$sort","toJSON","pv","TO_PRIMITIVE","DateProto","INVALID_DATE","HAS_INSTANCE","FunctionProto","FProto","nameRE","strong","MAP","sqrt","$acosh","acosh","Number","MAX_VALUE","$asinh","asinh","$atanh","atanh","cbrt","clz32","LOG2E","cosh","hypot","value1","value2","div","sum","larg","$imul","imul","UINT16","xn","yn","xl","yl","log10","LOG10E","log2","sinh","E","tanh","trunc","$Number","BROKEN_COF","TRIM","toNumber","argument","third","maxCode","first","code","digits","parseInt","_isFinite","isInteger","isSafeInteger","MAX_SAFE_INTEGER","MIN_SAFE_INTEGER","parseFloat","aNumberValue","$toFixed","toFixed","ERROR","ZERO","multiply","c2","divide","numToString","t","acc","fractionDigits","z","x2","$fails","$toPrecision","toPrecision","precision","$freeze","$getOwnPropertyDescriptor","$getPrototypeOf","$isExtensible","$isFrozen","$isSealed","$preventExtensions","$seal","Internal","newGenericPromiseCapability","OwnPromiseCapability","Wrapper","microtask","newPromiseCapabilityModule","perform","promiseResolve","PROMISE","versions","v8","$Promise","empty","USE_NATIVE","FakePromise","PromiseRejectionEvent","isThenable","isReject","_n","chain","_c","_v","ok","_s","reaction","exited","handler","fail","_h","onHandleUnhandled","onUnhandled","console","unhandled","isUnhandled","emit","onunhandledrejection","reason","error","_a","onrejectionhandled","$reject","_w","$resolve","executor","err","onFulfilled","onRejected","capability","all","remaining","$index","alreadyCalled","race","rApply","fApply","thisArgument","argumentsList","L","rConstruct","NEW_TARGET_BUG","ARGS_BUG","Target","newTarget","$args","propertyKey","attributes","deleteProperty","Enumerate","enumerate","getProto","receiver","setProto","V","existingDescriptor","ownDesc","$flags","$RegExp","CORRECT_NEW","tiRE","piRE","fiU","proxy","flags","advanceStringIndex","regExpExec","$match","maybeCallNative","rx","fullUnicode","matchStr","SUBSTITUTION_SYMBOLS","SUBSTITUTION_SYMBOLS_NO_NAMED","REPLACE","$replace","searchValue","replaceValue","functionalReplace","results","accumulatedResult","nextSourcePosition","matched","position","captures","namedCaptures","replacerArgs","replacement","getSubstitution","tailPos","ch","capture","sameValue","SEARCH","$search","previousLastIndex","callRegExpExec","$min","$push","MAX_UINT32","SUPPORTS_Y","SPLIT","$split","internalSplit","limit","lastLength","output","lastLastIndex","splitLimit","separatorCopy","splitter","unicodeMatching","lim","q","add","$at","codePointAt","context","ENDS_WITH","$endsWith","endsWith","endPosition","search","color","fromCharCode","$fromCodePoint","fromCodePoint","INCLUDES","point","url","raw","callSite","tpl","STARTS_WITH","$startsWith","startsWith","wksDefine","enumKeys","_create","gOPNExt","$GOPS","$JSON","JSON","_stringify","stringify","HIDDEN","SymbolRegistry","AllSymbols","OPSymbols","QObject","findChild","setSymbolDesc","protoDesc","wrap","sym","isSymbol","$defineProperties","$propertyIsEnumerable","$getOwnPropertyNames","$getOwnPropertySymbols","IS_OP","es6Symbols","wellKnownSymbols","keyFor","useSetter","useSimple","FAILS_ON_PRIMITIVES","replacer","$replacer","$isView","isView","fin","viewS","viewT","init","InternalMap","each","weak","NATIVE_WEAK_MAP","IS_IE11","ActiveXObject","WEAK_MAP","$WeakMap","WEAK_SET","arraySpeciesCreate","flatMap","$includes","getOwnPropertyDescriptors","getDesc","$values","onFinally","$pad","WEBKIT_BUG","padEnd","padStart","TO_STRING_TAG","ArrayValues","DOMIterables","CSSRuleList","CSSStyleDeclaration","CSSValueList","ClientRectList","DOMRectList","DOMStringList","DOMTokenList","DataTransferItemList","FileList","HTMLAllCollection","HTMLCollection","HTMLFormElement","HTMLSelectElement","MediaList","MimeTypeArray","NamedNodeMap","NodeList","PaintRequestList","Plugin","PluginArray","SVGLengthList","SVGNumberList","SVGPathSegList","SVGPointList","SVGStringList","SVGTransformList","SourceBufferList","StyleSheetList","TextTrackCueList","TextTrackList","TouchList","collections","explicit","Collection","$task","MSIE","time","boundArgs","setInterval","graphlib","layout","debug","util","notime","_","greedyFAS","g","fas","graph","acyclicer","edge","weight","weightFn","stack","visited","nodes","dfs","outEdges","dfsFAS","label","removeEdge","forwardName","reversed","setEdge","uniqueId","undo","edges","addBorderNode","prop","prefix","sg","sgNode","rank","width","height","borderType","curr","addDummyNode","setParent","children","borderLeft","borderRight","minRank","maxRank","swapWidthHeight","swapWidthHeightOne","attrs","reverseYOne","swapXYOne","adjust","rankDir","rankdir","points","reverseY","swapXY","List","sentinel","_next","_prev","_sentinel","unlink","filterOutLinks","dequeue","enqueue","strs","Graph","debugOrdering","layerMatrix","buildLayerMatrix","h","compound","multigraph","setGraph","setNode","layer","layerV","u","nodeCount","state","fasGraph","maxIn","maxOut","prevWeight","edgeWeight","buckets","range","zeroIdx","assignBucket","buildState","DEFAULT_WEIGHT_FN","sources","sinks","removeNode","doGreedyFAS","flatten","constant","collectPredecessors","inEdges","uEntry","wEntry","acyclic","normalize","normalizeRanks","parentDummyChains","removeEmptyRanks","nestingGraph","addBorderSegments","coordinateSystem","order","opts","debugTiming","layoutGraph","inputGraph","canonicalize","merge","graphDefaults","selectNumberAttrs","graphNumAttrs","pick","graphAttrs","defaults","nodeNumAttrs","nodeDefaults","edgeDefaults","edgeNumAttrs","edgeAttrs","buildLayoutGraph","ranksep","minlen","labelpos","labeloffset","makeSpaceForEdgeLabels","selfEdges","removeSelfEdges","asNonCompoundGraph","injectEdgeLabelProxies","cleanup","borderTop","borderBottom","assignRankMinMax","dummy","labelRank","removeEdgeLabelProxies","layers","orderShift","selfEdge","insertSelfEdges","selfNode","dx","dy","positionSelfEdges","removeBorderNodes","fixupEdgeLabelCoords","minX","POSITIVE_INFINITY","maxX","minY","maxY","graphLabel","marginX","marginx","marginY","marginy","getExtremes","translateGraph","p2","nodeV","nodeW","unshift","intersectRect","assignNodeIntersects","reversePointsForReversedEdges","runLayout","inputLabel","layoutLabel","updateInputGraph","edgesep","nodesep","obj","mapValues","newAttrs","lodash","cloneDeep","forIn","isUndefined","minBy","sortBy","zipObject","nodeSep","depths","top","bottom","child","childNode","childTop","childBottom","thisWeight","nestingEdge","treeDepths","nestingRoot","sumWeights","nodeRankFactor","dummyChains","vRank","wRank","edgeLabel","edgeObj","normalizeEdge","origLabel","successors","cg","vs","rootPrev","prevChild","movable","inV","nodeU","barycenter","relationship","hasNode","createRootNode","setDefaultNodeLabel","twoLayerCrossCount","northLayer","southLayer","southPos","southEntries","firstIndex","treeSize","tree","cc","weightSum","layering","initOrder","crossCount","sortSubgraph","buildLayerGraph","addSubgraphConstraints","buildLayerGraphs","ranks","sweepLayerGraphs","layerGraphs","biasRight","lg","sorted","assignOrder","downLayerGraphs","upLayerGraphs","best","bestCC","lastBest","simpleNodes","orderedVs","mappedEntries","tmp","indegree","entryV","entryW","sourceSet","handleIn","vEntry","merged","handleOut","pop","doResolveConflicts","resolveConflicts","bl","br","subgraphs","barycenters","subgraphResult","other","expandSubgraphs","predecessors","blPred","brPred","consumeUnsortable","unsortable","bias","parts","partition","sortable","lhs","rhs","vsIndex","postorderNums","low","postorder","pathData","lca","vPath","wPath","path","findPath","pathIdx","pathV","ascending","findType1Conflicts","conflicts","prevLayer","k0","scanPos","prevLayerLength","lastNode","findOtherInnerSegmentNode","k1","scanNode","uLabel","uPos","addConflict","findType2Conflicts","scan","south","southEnd","prevNorthBorder","nextNorthBorder","uNode","north","nextNorthPos","prevNorthPos","southLookahead","conflictsV","hasConflict","verticalAlignment","neighborFn","align","prevIdx","mp","il","horizontalCompaction","reverseSep","xs","blockG","blockGraph","sepFn","edgeSep","delta","vLabel","wLabel","sep","vRoot","uRoot","prevMax","buildBlockGraph","iterate","setXsFunc","nextNodesFunc","elem","findSmallestWidthAlignment","xss","NEGATIVE_INFINITY","halfWidth","alignCoordinates","alignTo","alignToVals","alignToMin","alignToMax","vert","horiz","alignment","xsVals","balance","ul","ignore","positionX","adjustedLayering","inner","smallestWidth","rankSep","prevY","maxHeight","positionY","slack","tightTree","nodeEdges","edgeV","findMinSlackEdge","shiftRanks","directed","longestPath","feasibleTree","networkSimplex","ranker","networkSimplexRanker","tightTreeRanker","longestPathRanker","initRank","preorder","simplify","initLowLimValues","initCutValues","leaveEdge","exchangeEdges","enterEdge","cutvalue","calcCutValue","assignCutValue","childIsTail","graphEdge","cutValue","isOutEdge","pointsToHead","otherWeight","hasEdge","otherCutValue","dfsAssignLowLim","nextLim","neighbors","tailLabel","flip","candidates","isDescendant","flipped","updateRanks","rootLabel","simplified","simpleLabel","isMultigraph","successorWeights","weightMap","sucs","predecessorWeights","preds","rect","sx","sy","Error","collection","Float32Array","a0","a1","b0","b1","stride","vec","clone","fromValues","copy","equals","exactEquals","subtract","sub","mul","inverse","rotate","scale","scaleAndAdd","distance","dist","squaredDistance","sqrDist","squaredLength","sqrLen","negate","dot","cross","lerp","transformMat2","transformMat2d","transformMat3","transformMat4","ax","ay","mSq","PI","cos","sin","angle","lib","json","alg","cmpt","cmpts","doDfs","navigation","isDirected","dijkstra","weightFunc","edgeFunc","transform","PriorityQueue","edgeFn","pq","updateNeighbors","predecessor","decrease","removeMin","runDijkstra","DEFAULT_WEIGHT_FUNC","tarjan","rowK","rowI","ik","kj","ij","altDistance","runFloydWarshall","components","dijkstraAll","findCycles","floydWarshall","isAcyclic","prim","topsort","CycleException","parents","pri","priority","onStack","lowlink","visit","_arr","_keyIndices","keyIndices","_decrease","_swap","_heapify","largest","origArrI","origArrJ","GRAPH_NODE","_isDirected","_isMultigraph","_isCompound","_label","_defaultNodeLabelFn","_defaultEdgeLabelFn","_nodes","_parent","_children","_in","_preds","_out","_sucs","_edgeObjs","_edgeLabels","incrementOrInitEntry","decrementOrRemoveEntry","edgeArgsToId","v_","w_","edgeArgsToObj","edgeObjToId","_nodeCount","_edgeCount","isCompound","newDefault","isEmpty","setNodes","_removeFromParentsChildList","ancestor","predsV","sucsV","union","isLeaf","filterNodes","findParent","setDefaultEdgeLabel","edgeCount","setPath","valueSpecified","arg0","freeze","outV","writeNodes","nodeValue","writeEdges","edgeValue","options","read","INJECTION","for","_proxyGetter","doCache","hasMetadata","defineMetadata","getMetadata","newVal","makePropertyInjectDecorator","container","serviceIdentifier","makePropertyInjectNamedDecorator","named","getNamed","makePropertyInjectTaggedDecorator","propertyName","getTagged","makePropertyMultiInjectDecorator","getAll","decorators_1","lazyInject","lazyInjectNamed","lazyInjectTagged","lazyMultiInject","tagProperty","tagParameter","decorate","ERROR_MSGS","METADATA_KEY","_tagParameterOrProperty","metadataKey","annotationTarget","metadata","parameterIndex","paramsOrPropertiesMetadata","isParameterDecorator","INVALID_DECORATOR_OPERATION","hasOwnMetadata","paramOrPropertyMetadata","paramOrPropertyMetadata_1","DUPLICATED_METADATA","_decorate","decorators","_param","paramIndex","decorator","TAGGED","TAGGED_PROP","inject","LazyServiceIdentifer","error_msgs_1","metadata_1","decorator_utils_1","cb","_cb","unwrap","targetKey","UNDEFINED_INJECT_ANNOTATION","Metadata","INJECT_TAG","injectable","ERRORS_MSGS","PARAM_TYPES","DUPLICATED_INJECTABLE_DECORATOR","types","DESIGN_PARAM_TYPES","multiInject","MULTI_INJECT_TAG","NAMED_TAG","optional","OPTIONAL_TAG","postConstruct","POST_CONSTRUCT","MULTIPLE_POST_CONSTRUCT_METHODS","tagged","metadataValue","targetName","NAME_TAG","unmanaged","UNMANAGED_TAG","Binding","literal_types_1","id_1","scope","activated","BindingTypeEnum","Invalid","constraint","request","implementationType","cache","provider","onActivation","dynamicValue","BindingCount","MultipleBindingsAvailable","NoBindingsAvailable","OnlyOneBindingAvailable","STACK_OVERFLOW","CIRCULAR_DEPENDENCY_IN_FACTORY","POST_CONSTRUCT_ERROR","CONTAINER_OPTIONS_INVALID_SKIP_BASE_CHECK","CONTAINER_OPTIONS_INVALID_AUTO_BIND_INJECTABLE","CONTAINER_OPTIONS_INVALID_DEFAULT_SCOPE","CONTAINER_OPTIONS_MUST_BE_AN_OBJECT","ARGUMENTS_LENGTH_MISMATCH","INVALID_TO_SELF_VALUE","INVALID_FUNCTION_BINDING","INVALID_MIDDLEWARE_RETURN","NO_MORE_SNAPSHOTS_AVAILABLE","INVALID_BINDING_TYPE","NOT_IMPLEMENTED","CIRCULAR_DEPENDENCY","MISSING_INJECT_ANNOTATION","MISSING_INJECTABLE_ANNOTATION","NOT_REGISTERED","CANNOT_UNBIND","AMBIGUOUS_MATCH","KEY_NOT_FOUND","NULL_ARGUMENT","TargetTypeEnum","BindingScopeEnum","Request","Singleton","Transient","ConstantValue","DynamicValue","Factory","Instance","Provider","ClassProperty","ConstructorArgument","Variable","__awaiter","_arguments","generator","fulfilled","rejected","__generator","body","sent","trys","ops","verb","op","Container","binding_1","metadata_reader_1","planner_1","resolver_1","binding_to_syntax_1","serialization_1","container_snapshot_1","lookup_1","containerOptions","defaultScope","autoBindInjectable","skipBaseClassChecks","_bindingDictionary","Lookup","_snapshots","_middleware","_metadataReader","MetadataReader","container1","container2","bindingDictionary","getBindingDictionary","bindingDictionary1","bindingDictionary2","copyDictionary","origin","destination","traverse","binding","load","modules","getHelpers","_getContainerModuleHelpersFactory","modules_1","currentModule","containerModuleHelpers","registry","bindFunction","unbindFunction","isboundFunction","rebindFunction","loadAsync","modules_2","unload","_this","conditionFactory","expected","item","moduleId","condition","removeByCondition","BindingToSyntax","rebind","unbind","remove","getServiceIdentifierAsString","unbindAll","isBound","hasKey","isBoundNamed","isBoundTagged","bindings","request_1","createMockRequest","snapshot","ContainerSnapshot","restore","middleware","createChild","applyMiddleware","middlewares","initial","_planAndResolve","applyCustomMetadataReader","metadataReader","_get","getAllTagged","getAllNamed","constructorFunction","tempContainer","toSelf","setModuleId","bindingToSyntax","_binding","getRebindFunction","_rebind","mId","_bind","_isBound","_unbind","avoidConstraints","isMultiInject","targetType","defaultArgs","contextInterceptor","plan","AsyncContainerModule","ContainerModule","_map","Map","getMap","delete","updatedEntries","func","container_1","injectable_1","named_1","inject_1","Context","addPlan","setCurrentRequest","currentRequest","getConstructorMetadata","constructorFunc","compilerGeneratedMetadata","userGeneratedMetadata","getPropertiesMetadata","Plan","parentContext","rootRequest","binding_count_1","exceptions_1","context_1","plan_1","reflection_utils_1","target_1","cntnr","_getActiveBindings","parentRequest","activeBindings","getBindings","isOptional","serviceIdentifierString","listMetadataForTarget","listRegisteredBindingsForServiceIdentifier","_validateActiveBindingCount","_createSubRequests","childRequest","thePlan","addChildRequest","subChildRequest","dependencies","getDependencies","baseClassDependencyCount","getBaseClassDependencyCount","getFunctionName","dependency","injectMetadata","tagMetadata","_createTarget","isStackOverflowExeption","circularDependencyToException","QueryableString","reverseString","reverseSearchString","contains","compareString","__spreadArrays","jl","getTargets","constructorName","isBaseClass","serviceIdentifiers","constructorArgsMetadata","constructorTargets","iterations","targets","getConstructorArgsAsTarget","getConstructorArgsAsTargets","propertyTargets","getClassPropsAsTargets","targetMetadata","formatTargetMetadata","isManaged","classPropsMetadata","keys_1","baseConstructor","baseTargets","targetMetadataMap","unmanagedCount","dependencyCount","childRequests","requestScope","queryable_string_1","namedOrTagged","metadataItem","hasTag","matchesArray","matchesTag","isNamed","isTagged","getNamedTag","getCustomTags","matchesNamedTag","resolveInstance","constr","resolveRequest","Func","injections","propertyInjectionsRequests","propertyInjections","injection","_injectProperties","message","_postConstruct","instantiation_1","invokeFactory","factoryType","_resolveRequest","targetIsAnArray","targetParentIsNotAnArray","isSingleton","isRequestSingleton","BindingInSyntax","binding_when_on_syntax_1","inRequestScope","BindingWhenOnSyntax","inSingletonScope","inTransientScope","BindingInWhenOnSyntax","binding_in_syntax_1","binding_on_syntax_1","binding_when_syntax_1","_bindingWhenSyntax","BindingWhenSyntax","_bindingOnSyntax","BindingOnSyntax","_bindingInSyntax","when","whenTargetNamed","whenTargetIsDefault","whenTargetTagged","whenInjectedInto","whenParentNamed","whenParentTagged","whenAnyAncestorIs","whenNoAncestorIs","whenAnyAncestorNamed","whenAnyAncestorTagged","whenNoAncestorNamed","whenNoAncestorTagged","whenAnyAncestorMatches","whenNoAncestorMatches","binding_in_when_on_syntax_1","toConstantValue","toDynamicValue","toConstructor","toFactory","toFunction","bindingWhenOnSyntax","toAutoFactory","toProvider","toService","service","constraint_helpers_1","namedConstraint","taggedConstraint","typeConstraint","traverseAncerstors","metaData","multiBindToService","idCounter","alreadyDependencyChain","name_1","registeredBindingsList","registeredBindings","services","_createStringArr","req","dependencyChainToString","m_1","namedTag","otherTags","getNative","hashClear","hashDelete","hashGet","hashHas","hashSet","Hash","listCacheClear","listCacheDelete","listCacheGet","listCacheHas","listCacheSet","ListCache","mapCacheClear","mapCacheDelete","mapCacheGet","mapCacheHas","mapCacheSet","MapCache","Set","setCacheAdd","setCacheHas","SetCache","__data__","stackClear","stackDelete","stackGet","stackHas","stackSet","Stack","WeakMap","array","iteratee","resIndex","baseIndexOf","comparator","baseTimes","isArguments","isBuffer","isIndex","isTypedArray","inherited","isArr","isArg","isBuff","isType","skipIndexes","accumulator","initAccum","asciiSize","baseProperty","baseAssignValue","eq","objValue","copyObject","keysIn","arrayEach","assignValue","baseAssign","baseAssignIn","cloneBuffer","copyArray","copySymbols","copySymbolsIn","getAllKeys","getAllKeysIn","getTag","initCloneArray","initCloneByTag","initCloneObject","isMap","isSet","argsTag","funcTag","objectTag","cloneableTags","baseClone","bitmask","customizer","isDeep","isFlat","isFull","isFunc","stacked","subValue","props","objectCreate","baseCreate","baseForOwn","baseEach","createBaseEach","current","computed","fromRight","arrayPush","isFlattenable","baseFlatten","isStrict","baseFor","createBaseFor","castPath","toKey","keysFunc","symbolsFunc","getRawTag","objectToString","symToStringTag","toStringTag","baseFindIndex","baseIsNaN","strictIndexOf","baseGetTag","isObjectLike","baseIsEqualDeep","baseIsEqual","equalArrays","equalByTag","equalObjects","arrayTag","equalFunc","objIsArr","othIsArr","objTag","othTag","objIsObj","othIsObj","isSameTag","objIsWrapped","othIsWrapped","objUnwrapped","othUnwrapped","matchData","noCustomizer","srcValue","COMPARE_PARTIAL_FLAG","isMasked","toSource","reIsHostCtor","funcProto","objectProto","funcToString","reIsNative","isLength","typedArrayTags","baseMatches","baseMatchesProperty","identity","property","isPrototype","nativeKeys","nativeKeysIn","isProto","isArrayLike","baseIsMatch","getMatchData","matchesStrictComparable","hasIn","isKey","isStrictComparable","assignMergeValue","baseMergeDeep","safeGet","baseMerge","srcIndex","newValue","cloneTypedArray","isArrayLikeObject","isPlainObject","toPlainObject","mergeFunc","isCommon","isTyped","arrayMap","baseGet","baseIteratee","baseMap","baseSortBy","baseUnary","compareMultiple","iteratees","orders","basePickBy","paths","baseSet","nativeCeil","nativeMax","eachFunc","overRest","setToString","nested","baseSetToString","comparer","symbolProto","symbolToString","baseToString","trimmedEndIndex","reTrimStart","arrayIncludesWith","cacheHas","createSet","setToArray","seen","outer","seenIndex","assignFunc","valsLength","stringToPath","arrayBuffer","freeExports","nodeType","freeModule","Buffer","allocUnsafe","cloneArrayBuffer","dataView","reFlags","symbolValueOf","symbol","typedArray","valIsDefined","valIsNull","valIsReflexive","valIsSymbol","othIsDefined","othIsNull","othIsReflexive","othIsSymbol","compareAscending","objCriteria","criteria","othCriteria","ordersLength","isNew","getSymbolsIn","coreJsData","baseRest","isIterateeCall","assigner","guard","findIndexFunc","baseRange","toFinite","noop","isPartial","arrLength","othLength","arrStacked","othStacked","arrValue","othValue","compared","othIndex","mapToArray","convert","objProps","objLength","objStacked","skipCtor","objCtor","othCtor","freeGlobal","baseGetAllKeys","isKeyable","baseIsNative","getValue","getPrototype","overArg","nativeObjectToString","isOwn","unmasked","stubArray","nativeGetSymbols","mapTag","promiseTag","setTag","weakMapTag","dataViewTag","dataViewCtorString","mapCtorString","promiseCtorString","setCtorString","weakMapCtorString","Ctor","ctorString","hasFunc","reHasUnicode","nativeCreate","input","cloneDataView","cloneRegExp","cloneSymbol","spreadableSymbol","isConcatSpreadable","reIsUint","reIsDeepProp","reIsPlainProp","maskSrcKey","assocIndexOf","getMapData","memoize","freeProcess","nodeUtil","require","otherArgs","freeSelf","shortOut","nativeNow","lastCalled","stamp","pairs","LARGE_ARRAY_SIZE","hasUnicode","unicodeSize","memoizeCapped","rePropName","reEscapeChar","quote","subString","reWhitespace","rsCombo","rsFitz","rsNonAstral","rsRegional","rsSurrPair","reOptMod","rsModifier","rsOptVar","rsSeq","rsSymbol","reUnicode","CLONE_DEEP_FLAG","propsIndex","propsLength","baseFilter","createFind","castFunction","defaultValue","baseHas","hasPath","baseHasIn","baseIsArguments","stubFalse","baseKeys","baseIsMap","nodeIsMap","objectCtorString","baseIsSet","nodeIsSet","baseIsTypedArray","nodeIsTypedArray","arrayLikeKeys","baseKeysIn","baseExtremum","baseGt","resolver","memoized","Cache","createAssigner","baseLt","basePick","flatRest","basePropertyDeep","createRange","baseReduce","isString","stringSize","baseOrderBy","remainder","baseTrim","reIsBadHex","reIsBinary","reIsOctal","freeParseInt","isBinary","isArrLike","baseUniq","arrays","baseValues","baseZipObject","tangent","miter","lineA","lineB","halfThick","dir","makeExporter","previous","hasOwn","supportsSymbol","toPrimitiveSymbol","iteratorSymbol","supportsCreate","supportsProto","downLevel","HashMap","MakeDictionary","functionPrototype","usePolyfill","env","_Map","cacheSentinel","arraySentinel","MapIterator","selector","_index","_keys","_values","_selector","throw","return","_cacheKey","_cacheIndex","_find","getKey","insert","CreateMapPolyfill","_Set","rootKey","CreateUniqueKey","_key","table","GetOrCreateWeakMapTable","CreateUUID","FillRandomBytes","crypto","getRandomValues","msCrypto","byte","CreateWeakMapPolyfill","GetOrCreateMetadataMap","Create","IsUndefined","metadataMap","OrdinaryHasMetadata","MetadataKey","OrdinaryHasOwnMetadata","OrdinaryGetPrototypeOf","IsNull","OrdinaryGetMetadata","OrdinaryGetOwnMetadata","OrdinaryDefineOwnMetadata","MetadataValue","OrdinaryMetadataKeys","OrdinaryOwnMetadataKeys","parentKeys","ownKeys_1","parentKeys_1","GetMethod","IsCallable","IsObject","GetIterator","IteratorStep","nextValue","IteratorClose","Type","ToPrimitive","PreferredType","exoticToPrim","toString_1","toString_2","OrdinaryToPrimitive","ToPropertyKey","ToString","IsArray","IsConstructor","prototypeProto","__","decorated","DecorateConstructor","DecorateProperty","IsPropertyKey","runtime","Op","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","innerFn","outerFn","tryLocsList","protoGenerator","Generator","_invoke","GenStateSuspendedStart","GenStateExecuting","GenStateCompleted","doneResult","delegate","delegateResult","maybeInvokeDelegate","ContinueSentinel","_sent","dispatchException","abrupt","record","tryCatch","GenStateSuspendedYield","makeInvokeMethod","GeneratorFunction","GeneratorFunctionPrototype","NativeIteratorPrototype","Gp","defineIteratorMethods","AsyncIterator","PromiseImpl","__await","unwrapped","previousPromise","callInvokeWithMethodAndArg","info","resultName","nextLoc","pushTryEntry","locs","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","reset","iteratorMethod","displayName","isGeneratorFunction","genFun","ctor","mark","awrap","async","skipTempReset","stop","rootRecord","rval","exception","handle","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","thrown","delegateYield","regeneratorRuntime","accidentalStrictMode","Uint32Array","Int8Array","Int16Array","Int32Array","Float64Array","Uint8ClampedArray","extend","base","endl","raise","pred","encolon","standardTypeEh","checkOneOf","constructorKeys","leftPad","ShaderFile","lines","hasErrors","ShaderLine","line","errors","ShaderError","fileNumber","lineNumber","file","guessCommand","pat","pat2","guessCallSite","parseSource","command","files","unknown","0","lineNumberInfo","nameInfo","atob","saveCommandRef","_commandRef","commandRaise","checkCommandType","GL_CLAMP_TO_EDGE","TYPE_SIZE","pixelSize","channels","isPow2","check$1","block","parameter","param","possibilities","commandParameter","commandType","nni","oneOf","shaderError","gl","shader","getShaderParameter","COMPILE_STATUS","errLog","getShaderInfoLog","typeName","FRAGMENT_SHADER","errMsg","parseErrorLog","annotateFiles","strings","styles","token","tokenPat","chrome","linkError","program","fragShader","vertShader","getProgramParameter","LINK_STATUS","getProgramInfoLog","fragParse","header","saveDrawInfo","uniforms","stringStore","addProps","dict","_fragId","static","frag","_vertId","uniformSet","_uniformSet","dynamic","attributeSet","_attributeSet","_hasCount","framebufferFormat","attachment","texFormats","rbFormats","texture","_texture","internalformat","renderbuffer","_renderbuffer","format","texture2D","mipData","limits","maxTextureSize","wrapS","wrapT","mipmask","minFilter","extensions","magFilter","genMipmaps","mipimages","images","mw","mh","img","compressed","rowSize","unpackAlignment","textureCube","faces","face","mipmaps","VARIABLE_COUNTER","DynamicVariable","escapeStr","splitParts","firstChar","lastChar","substr","subparts","toAccessorString","isDynamic","_reglType","unbox","accessor","raf","requestAnimationFrame","cancel","cancelAnimationFrame","clearTimeout","clock","performance","parseExtensions","getElement","querySelector","parseArgs","args_","canvas","contextAttributes","optionalExtensions","pixelRatio","devicePixelRatio","profile","onDone","onDestroy","nodeName","getBoundingClientRect","drawArrays","drawElements","isWebGLContext","resizeObserver","resize","innerWidth","innerHeight","bounds","right","border","margin","padding","ResizeObserver","disconnect","removeEventListener","createCanvas","premultipliedAlpha","getContext","createContext","loop","shift","createPool","bufferPool","alloc","sz","nextPow16","bin","free","buf","allocType","freeType","pool","zero","GL_TEXTURE_2D","GL_RGBA","GL_FLOAT$1","GL_FRAMEBUFFER","isNDArrayLike","shape","flattenUtils","array_","out_","nx","flatten1D","ny","ptr","row","flatten2D","flatten3D","flattenRec","nz","ptr_","col","level","arrayTypes","glTypes","int8","int16","int32","uint8","uint16","uint32","float","float32","usageTypes","stream","arrayFlatten","arrayShape","GL_UNSIGNED_BYTE$3","GL_FLOAT$3","DTYPES_SIZES","typedArrayCode","inp","transpose","shapeX","shapeY","strideX","strideY","primTypes","triangles","triangle","GL_UNSIGNED_BYTE$4","GL_UNSIGNED_SHORT$2","GL_UNSIGNED_INT$2","GL_ELEMENT_ARRAY_BUFFER","FLOAT","INT","convertToHalfFloat","ushorts","sgn","frac","isPow2$1","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_RGB5_A1","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_UNSIGNED_BYTE$5","GL_UNSIGNED_SHORT$3","GL_UNSIGNED_INT$3","GL_FLOAT$4","GL_CLAMP_TO_EDGE$1","GL_NEAREST$1","GL_NEAREST_MIPMAP_NEAREST$1","GL_LINEAR_MIPMAP_LINEAR$1","GL_DONT_CARE","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","isRectArray","classString","isCanvasElement","isOffscreenCanvas","isPixelData","className","typedArrayCode$1","preConvert","image","postConvert","getTextureSize","isMipmap","isCube","total","createTextureSet","reglPoll","contextState","stats","config","mipmapHint","wrapModes","magFilters","minFilters","colorSpace","textureTypes","textureFormats","compressedTextureFormats","ext_srgb","srgb","srgba","oes_texture_float","oes_texture_half_float","webgl_depth_texture","webgl_compressed_texture_s3tc","webgl_compressed_texture_atc","webgl_compressed_texture_pvrtc","webgl_compressed_texture_etc1","supportedCompressedFormats","getParameter","supportedFormats","textureFormatsInvert","textureTypesInvert","magFiltersInvert","minFiltersInvert","wrapModesInvert","colorFormats","glenum","TexFlags","premultiplyAlpha","flipY","copyFlags","parseFlags","hasChannels","radius","hasFormat","formatStr","setFlags","pixelStorei","TexImage","xOffset","yOffset","needsFree","needsCopy","parseImage","viewW","viewportWidth","viewH","viewportHeight","converted","convertData","shapeC","strideC","transposeData","isBitmap","isImageElement","naturalWidth","naturalHeight","isVideoElement","videoWidth","videoHeight","dd","allocData","setImage","miplevel","texImage2D","compressedTexImage2D","copyTexImage2D","setSubImage","texSubImage2D","compressedTexSubImage2D","copyTexSubImage2D","imagePool","allocImage","freeImage","MipMap","parseMipMapFromShape","mipmap","parseMipMapFromObject","imgData","setMipMap","mipPool","allocMipMap","freeMipMap","TexInfo","anisotropic","parseTexInfo","mag","optWrapS","optWrapT","maxAnisotropic","hasMipMap","setTexInfo","texParameteri","ext_texture_filter_anisotropic","generateMipmap","textureCount","textureSet","numTexUnits","maxTextureUnits","textureUnits","REGLTexture","refCount","createTexture","unit","bindCount","texInfo","tempBind","activeTexture","bindTexture","tempRestore","destroy","deleteTexture","params","pixels","decRef","getTotalTextureSize","create2D","reglTexture2D","subimage","x_","y_","level_","imageData","h_","createCube","a2","a3","a4","a5","cubeCount","reglTextureCube","faceInput","npotTextureCube","radius_","getTexture","tex","refresh","GL_RENDERBUFFER","GL_RGBA4$1","FORMAT_SIZES","getRenderbufferSize","GL_FRAMEBUFFER$1","GL_RENDERBUFFER$1","GL_TEXTURE_2D$2","GL_TEXTURE_CUBE_MAP_POSITIVE_X$2","colorTextureFormatEnums","textureFormatChannels","textureTypeSizes","colorRenderbufferFormatEnums","statusCode","AttributeRecord","normalized","divisor","GL_UNSIGNED_BYTE$7","GL_FLOAT$7","wrapReadPixels","framebufferState","glAttributes","readPixelsImpl","preserveDrawingBuffer","colorAttachments","readFloat","framebufferWidth","framebufferHeight","readPixels","setFBO","framebuffer","readPixelsFBO","CUTE_COMPONENTS","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_DRAWINGBUFFER_WIDTH","S_DRAWINGBUFFER","S_DRAWINGBUFFER_HEIGHT","NESTED_OPTIONS","GL_ARRAY_BUFFER$2","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_FRONT","GL_BACK","GL_CCW","GL_KEEP","blendFuncs","invalidBlendCombinations","compareFuncs","stencilOps","shaderType","orientationType","isBufferArgs","sortState","Declaration","thisDep","contextDep","propDep","append","isStatic","decl","createStaticDecl","createDynamicDecl","dyn","numArgs","subDyn","subArgs","SCOPE_DECL","reglCore","bufferState","elementState","textureState","uniformState","attributeState","shaderState","drawState","timer","Record","blendEquations","ext_blend_minmax","extInstancing","angle_instanced_arrays","extDrawBuffers","webgl_draw_buffers","currentState","dirty","nextState","GL_STATE_NAMES","GL_FLAGS","GL_VARIABLES","propName","stateFlag","sname","cap","stateVariable","drawingBufferWidth","drawingBufferHeight","sharedState","draw","elements","vao","sharedConstants","backBuffer","drawBuffer","maxDrawbuffers","drawCallCounter","createREGLEnvironment","varCounter","linkedNames","linkedValues","vars","entryToString","exitToString","save","globalBlock","procedures","link","proc","bodyToString","cond","thenBlock","elseBlock","thenToString","elseToString","else","elseClause","compile","createEnvironment","batchId","CHECK","commandStr","assert","nextVars","currentVars","variable","constants","argList","ref","attribCache","scopeAttribs","scopeAttrib","parseArguments","staticOptions","dynamicOptions","KEY_NAMES","checkKeys","attribLocations","staticAttributes","sAttributes","parseAttribLocations","getFramebuffer","FRAMEBUFFER","CONTEXT","FRAMEBUFFER_FUNC","FRAMEBUFFER_STATE","parseFramebuffer","viewportAndScissor","parseBox","box","BOX_W","BOX_H","dynBox","BOX","BOX_X","BOX_Y","viewport","prevViewport","VIEWPORT","scissor_box","parseViewportScissor","getElements","ELEMENTS","IS_BUFFER_ARGS","ELEMENT_STATE","elementDefn","elementStream","ifte","parseElements","parseParam","isOffset","OFFSET","dynValue","primitive","dynPrimitive","PRIM_TYPES","parsePrimitive","dynCount","MISSING","DYNAMIC","parseVertCount","instances","parseDraw","STATE","parseStatic","parseDynamic","COMPARE_FUNCS","srcRGB","srcAlpha","dstRGB","dst","dstAlpha","BLEND_FUNCS","suffix","INVALID_BLEND_COMBINATIONS","SRC_RGB","SRC_ALPHA","rgb","alpha","BLEND_EQUATIONS","RGB","ALPHA","checkProp","cmp","mask","zfail","zpass","STENCIL_OPS","factor","units","lineWidthDims","sampleValue","sampleInvert","invert","parseGLState","parseShader","progVar","fragId","SHADER_STATE","progDef","parseProgram","copyBox","defn","scopeVAO","drawVAO","useVAO","profileEnable","enable","parseProfile","staticUniforms","dynamicUniforms","UNIFORMS","reglType","parseUniforms","getVAO","createVAO","vaoRef","parseVAO","staticBindings","attr","dynamicAttributes","attributeDefs","getBuffer","VALID_KEYS","dtype","isStream","VALUE","BUFFER_STATE","defaultRecord","emitReadRecord","parseAttributes","staticContext","dynamicContext","parseContext","emitContext","contextEnter","emitPollFramebuffer","skipCheck","EXT_DRAW_BUFFERS","GL","NEXT","DRAW_BUFFERS","BACK_BUFFER","emitPollState","CURRENT_VARS","NEXT_VARS","CURRENT_STATE","NEXT_STATE","CURRENT","emitSetOptions","flag","injectExtensions","instancing","emitProfile","useScope","incrementCounter","CPU_START","QUERY_COUNTER","USE_PROFILE","STATS","TIMER","profileArg","perfCounter","emitProfileStart","emitProfileEnd","scopeProfile","emitAttributes","ATTRIBUTE","LOCATION","BINDING","CONST_COMPONENTS","COMMON_KEYS","emitBuffer","DIVISOR","emitConstant","emitBindAttribute","typeLength","emitUniforms","infix","uniform","TEX_VALUE","MAT_VALUE","dim","emitCheck","checkType","checkVector","checkTexture","unroll","TEX","matSize","STORAGE","emitDraw","DRAW_STATE","drawOptions","contextDynamic","emitElements","emitValue","INSTANCES","EXT_INSTANCING","PRIMITIVE","COUNT","emitCount","ELEMENT_TYPE","elementsStatic","emitInstancing","emitRegular","createBody","emitBody","parentEnv","emitDrawBody","emitBatchDynamicShaderBody","emitBatchBody","BATCH_ID","PROPS","isInnerDefn","isOuterDefn","needsContext","needsFramebuffer","progCache","PROGRAM","PROG_ID","CACHED_PROC","splatObject","isDynamicObject","globals","objectRef","deps","procs","poll","INSTANCING","oes_vertex_array_object","maxAttributes","drawCache","emitDrawProc","saveShader","opt","emitScopeProc","batch","progDefn","batchCache","emitBatchProc","createTimer","ext_disjoint_timer_query","queryPool","freeQuery","query","pendingQueries","PendingStats","startQueryIndex","endQueryIndex","pendingStatsPool","freePendingStats","pendingStats","pushScopeStats","ps","timeSum","queryPtr","beginQuery","createQueryEXT","beginQueryEXT","endQuery","endQueryEXT","update","queryTime","getQueryObjectEXT","startPtr","endPtr","gpuTime","getNumPendingQueries","deleteQueryEXT","CONTEXT_LOST_EVENT","CONTEXT_RESTORED_EVENT","haystack","needle","getContextAttributes","contextLost","isContextLost","extensionState","tryLoadExtension","name_","ext","getExtension","createExtensionCache","stringIds","stringValues","stats$$1","vaoCount","bufferCount","elementsCount","framebufferCount","shaderCount","renderbufferCount","START_TIME","WIDTH","HEIGHT","tick","maxColorAttachments","readFloatTexture","fbo","createFramebuffer","bindFramebuffer","framebufferTexture2D","checkFramebufferStatus","clearColor","getError","deleteFramebuffer","appVersion","cubeTexture","colorBits","depthBits","stencilBits","subpixelBits","pointSizeDims","maxViewportDims","maxCombinedTextureUnits","maxCubeMapSize","maxRenderbufferSize","maxVertexUniforms","maxVertexTextureUnits","maxVaryingVectors","maxFragmentUniforms","glsl","renderer","vendor","wrapLimits","destroyBuffer","bufferSet","REGLBuffer","createBuffer","usage","dimension","persistentData","bindBuffer","streamPool","initBufferFromTypedArray","bufferData","initBufferFromData","persist","flatData","typedData","deleteBuffer","getTotalBufferSize","deferInit","persistent","reglBuffer","setSubData","bufferSubData","_buffer","subdata","offset_","createStream","destroyStream","stream$$1","_initBuffer","wrapBufferState","NUM_ATTRIBUTES","attributeBindings","vaoSet","currentVAO","targetVAO","extVAO","_attr","REGLVAO","updateVAO","bufUpdated","nattributes","spec","rec","buffers","_vao","disableVertexAttribArray","setVAO","bindVertexArrayOES","bindAttrs","exti","extInstanced","enableVertexAttribArray","vertexAttribPointer","offfset","vertexAttribDivisorANGLE","vertexAttrib4f","extension","createVertexArrayOES","deleteVertexArrayOES","wrapAttributeState","elementSet","elementCount","elementTypes","REGLElementBuffer","primType","vertCount","oes_element_index_uint","initElements","predictedType","destroyElements","reglElements","_elements","wrapElementsState","fragShaders","vertShaders","ActiveInfo","location","insertActiveInfo","getShader","createShader","shaderSource","compileShader","programCache","programList","PROGRAM_COUNTER","REGLProgram","vertId","uniformsCount","attributesCount","linkProgram","attributeLocations","createProgram","attachShader","bindAttribLocation","numUniforms","getActiveUniform","getUniformLocation","numAttributes","getActiveAttrib","getAttribLocation","getMaxUniformsCount","getMaxAttributesCount","deleteShader","deleteProgram","prevProgram","idx","wrapShaderState","renderbufferState","formatTypes","ext_color_buffer_half_float","webgl_color_buffer_float","formatTypesInvert","renderbufferSet","REGLRenderbuffer","rb","bindRenderbuffer","deleteRenderbuffer","getTotalRenderbufferSize","createRenderbuffer","reglRenderbuffer","renderbufferStorage","wrapRenderbuffers","cur","colorTextureFormats","colorRenderbufferFormats","colorTypes","FramebufferAttachment","incRefAndCheckShape","tw","th","attach","framebufferRenderbuffer","parseAttachment","allocAttachment","isTexture","unwrapAttachment","resizeAttachment","framebufferSet","REGLFramebuffer","depthAttachment","stencilAttachment","depthStencilAttachment","decFBORefs","updateFramebuffer","status","createFBO","reglFramebuffer","needsDepth","needsStencil","colorBuffer","colorTexture","colorFormat","colorType","colorCount","depthBuffer","stencilBuffer","depthStencilBuffer","depthStencilTexture","colors","depthTexture","stencil","depthStencil","commonColorAttachmentSize","colorAttachmentSize","_framebuffer","use","reglFramebufferCube","colorCubes","cubeMapParams","cube","fb","wrapFBOState","rafCallbacks","lossCallbacks","restoreCallbacks","destroyCallbacks","activeRAF","handleRAF","startRAF","stopRAF","handleContextLoss","preventDefault","handleContextRestored","compileProcedure","separateDynamic","useArrays","staticItems","dynamicItems","option","opBack","opFront","flattenNestedOptions","cpuTime","compiled","EMPTY_ARRAY","reserve","clearImpl","clearFlags","clearDepth","clearStencil","frame","pendingCancel","pollViewport","scissorBox","regl","framebuffer_reglType","framebufferCube","on","callback","callbacks","hasExtension","_gl","_refresh","__webpack_module_cache__","__webpack_require__","loaded","__webpack_modules__","__esModule","definition","globalThis","nmd","_global","_babelPolyfill","warn","combos","positions","destroyed","onLayoutEnd","execute","reloadData","executeWithWorker","getDefaultCfg","updateCfg","cfg","getType","camelizeRE","toUpperCase","getDegree","nodeIdxMap","degrees","adjMatrix","getAdjMatrix","matrix","nodeMap","sIndex","tIndex","traverseUp","traverseTreeUp","registerLayout","layoutOverride","defaultCfg","GLayout","unRegisterLayout","getLayoutByName","preventOverlap","preventOverlapPadding","condense","nodeSize","cellWidth","cellHeight","cellUsed","id2manPos","rows","cols","layoutNodes","degree","n1","n2","oRows","oCols","columns","cells","splits","sm","small","large","nodew","nodeh","rcPos","used","getPos","moveToNextCell","center","proccessToFunc","defaultV","maxIteration","edgeStrength","nodeStrength","coulombDisScale","damping","maxSpeed","minMovement","interval","linkDistance","gravity","enableTick","timeInterval","clearInterval","nodeSizeFunc","nodeSpacing","getMass","accArray","velArray","calRepulsive","calAttractive","calGravity","stepInterval","updateVelocity","previousPos","updatePosition","movement","vx","vy","ni","massi","nj","vecX","vecY","vecLength","nVecLength","direX","direY","massj","paramOverlap","sourceNode","targetNode","sourceIdx","targetIdx","massSource","massTarget","defaultGravity","nodeLength","getCenter","customCenterOpt","vLength","param2","fx","fy","distX","distY","xm","ym","xp","yp","_root","leaf","x0","_x0","y0","_y0","x1","_x1","y1","_y1","_x","_y","defaultX","defaultY","quadtree","Quadtree","addAll","leaf_copy","treeProto","cover","xz","yz","extent","y2","x3","y3","quads","d2","retainer","removeAll","visitAfter","dispatch","parseTypenames","typenames","typename","taskHead","taskTail","timeout","clockLast","clockNow","clockSkew","setFrame","clearNow","Timer","_call","_time","delay","restart","wake","timerFlush","t0","t2","t1","sleep","nap","poke","initialAngle","simulation","alphaMin","alphaDecay","alphaTarget","velocityDecay","forces","stepper","lcg","force","initializeNodes","initializeForce","initialize","randomSource","closest","strengths","strength","distanceMin2","distanceMax2","theta2","accumulate","quad","jiggle","_random","distanceMin","distanceMax","theta","nodeById","nodeId","links","distances","initializeStrength","initializeDistance","radii","xi","yi","ri","ri2","prepare","rj","LAYOUT_MESSAGE","clusterNodeStrength","clusterEdgeStrength","clusterEdgeDistance","clusterNodeSize","clusterFociStrength","collideStrength","workerEnabled","ticking","forceSimulation","clustering","expectKeys","clusterForce","edgeForce","overlapProcess","nodeForce","templateForce","groupBy","cluster","forceNodeSize","forceCharge","forceLinkDistance","forceLinkStrength","nodesMap","centerX","centerY","foci","none","templateNodes","template","enableGrouping","getFocisFromTemplate","gnodes","glinks","dNodes","clustersCounts","clustersLinks","net","sumforceNodeSize","tmpCount","computeClustersNodeCounts","dClusterLinks","clusterLinks","sourceID","targetID","getLinkKey","computeClustersLinkCounts","initializeWithForce","genNodesMap","getFocis","forceInABox","isInWorker","totalTicks","totalTicksFloat","getSimulationTicks","currentTick","nodeSpacingFunc","WorkerGlobalScope","compareDegree","aDegree","bDegree","startRadius","endRadius","startAngle","endAngle","clockwise","divisions","ordering","angleRatio","angleStep","astep","topologyOrdering","degreeOrdering","divN","cnodes","orderedCNodes","resNodes","pickFlags","sourceChildren","targetChildren","initHierarchy","cnode","connect","foundChild","childIdx","ii","orderedNodes","controlPoints","sortByCombo","nodesepFunc","ranksepFunc","horisep","getFunc","vertisep","coord","comboMap","verti","hori","comboId","combo","parentId","isAnyArray","_options$fromIndex","_options$toIndex","maxValue","minValue","currentMin","currentMax","_options$min","autoMinMax","_options$max","indent","indentData","inspectMatrixWithOptions","maxRows","maxColumns","maxNumSize","maxI","maxJ","formatNumber","inspectData","numStr","precise","exponential","toExponential","eIndex","checkRowIndex","checkColumnIndex","checkRowVector","vector","to1DArray","checkColumnVector","checkRowIndices","rowIndices","checkColumnIndices","columnIndices","checkRange","startRow","endRow","startColumn","endColumn","checkNumber","newArray","checkNonEmpty","AbstractMatrix","newRows","newColumns","newData","newMatrix","Matrix","column","zeros","matrix1","matrix2","checkMatrix","isMatrix","to2DArray","isSquare","previousColumn","isEchelonForm","checked","isReducedEchelonForm","iMax","swapRows","echelonForm","maxRow","pivot","setSubMatrix","mulS","rowVector","getRow","row1","row2","temp","columnVector","getColumn","column1","column2","diag","vector2","vector1","Bcolj","a11","b11","a12","b12","a21","b21","a22","b22","m1","m2","m3","m4","m5","c00","c01","c10","c11","a00","a01","a02","a10","a20","b00","b01","b02","b10","b20","m6","m7","m8","m9","m12","m13","m14","m15","m16","m17","m18","c02","c12","c20","c21","c22","r1","c1","r2","embed","mat","resultat","blockMult","mmul","halfRows","halfCols","subMatrix","setRow","setColumn","compareFunction","compareNumbers","indices","checkIndices","rowIndex","columnIndex","trace","by","sumByRow","sumByColumn","sumAll","productByRow","productByColumn","productAll","unbiased","mean","variance","sum1","sum2","varianceByRow","varianceByColumn","varianceAll","centerByRow","centerByColumn","centerAll","getScaleByRow","scaleByRow","getScaleByColumn","scaleByColumn","divider","getScaleAll","scaleAll","rand","randomInt","randInt","diagonal","eye","neg","tensorProduct","kroneckerProduct","nRows","nColumns","super","arrayData","newRow","addS","addM","subS","subM","subtractS","subtractM","mulM","multiplyS","multiplyM","divS","divM","divideS","divideM","mod","modS","modM","modulus","modulusS","modulusM","and","andS","andM","or","orS","orM","xor","xorS","xorM","leftShift","leftShiftS","leftShiftM","signPropagatingRightShift","signPropagatingRightShiftS","signPropagatingRightShiftM","rightShift","rightShiftS","rightShiftM","zeroFillRightShift","zeroFillRightShiftS","zeroFillRightShiftM","not","acos","asin","atan","tan","powS","powM","installMathOperations","WrapperMatrix2D","hypotenuse","SingularValueDecomposition","computeLeftSingularVectors","computeRightSingularVectors","autoTranspose","wantu","Boolean","wantv","swapped","aux","nu","work","si","nct","nrt","mrc","pp","eps","kase","MIN_VALUE","ks","cs","sn","sp","spm1","epm1","sk","ek","Y","threshold","scols","Ls","rightSingularVectors","VL","vrows","urows","VLU","solve","vcols","X","ucols","tol","M","rowMeans","colMeans","totalMean","subRowVector","subColumnVector","diagonalMatrix","leftSingularVectors","disp","focusID","speed","strictRadial","maxDisplace","getRepulsion","updatePositions","vecx","vecy","di","vpx","vpy","diLength","tdispLength","distLength","limitedDist","nfDis","getEDistance","focusNode","unitRadius","maxPreventOverlapIteration","sortStrength","found","focusIndex","getIndexById","maxDistance","maxToFocus","handleInfinity","focusNodeD","semiWidth","semiHeight","maxRadius","maxD","eIdealD","eIdealDisMatrix","eIdealDistances","getWeightMatrix","weights","nonoverlapForceParams","nonoverlapForce","eIdealDis","oneIteration","vparam","originDis","reciODis","xMolecule","yMolecule","denominator","edis","reciEdis","idealDis","reciR","linkDis","iValue","jValue","minus","minNodeSpacing","equidistant","sweep","maxLevelDiff","maxNodeSize","counterclockwise","indexMap","maxValueNode","levels","currentLevel","diff","minDist","firstLvlHasMulti","rStep","dTheta","dcos","dsin","rMin","rDelta","rr","ratio","scaledD","scaledDistances","runMDS","eigenValues","clusterGravity","area","k2","clusterMap","cx","cy","displacements","applyCalculate","gravityForce","vecLengthSqr","uIndex","vIndex","_initializerDefineProperty","initializer","_defineProperties","protoProps","staticProps","_applyDecoratedDescriptor","asyncGeneratorStep","gen","_throw","_asyncToGenerator","entitySequence","Component","ComponentManager","clazz","entities","lookup","_forEachAsync","entity","component","componentIndex","entity2","_i2","destIndex","srcComponent","srcEntity","direction","_i3","componentIdx","_i4","_Object$keys","_entity","entityInNum","_i5","getCount","_component","getComponent","_i6","_i7","_Object$keys2","_entity2","_callee","_i8","_Object$keys3","_entity3","_context","_i9","_Object$keys4","_entity4","_arrayLikeToArray","arr2","_unsupportedIterableToArray","minLen","_slicedToArray","_e","IDENTIFIER","HierarchyComponentManager","TransformComponentManager","NameComponentManager","SceneGraphSystem","FrameGraphSystem","ResourcePool","ResourceHandleComponentManager","PassNodeComponentManager","RendererSystem","RenderPass","RenderPassFactory","Renderable","MeshSystem","MeshComponentManager","CullableComponentManager","Geometry","GeometrySystem","GeometryComponentManager","Material","MaterialSystem","MaterialComponentManager","ForwardRenderPath","ComputeSystem","ComputeComponentManager","ComputeStrategy","Systems","World","RenderEngine","WebGPUEngine","WebGLEngine","ShaderModuleService","ConfigService","InteractorService","IEventEmitter","Light","FrameGraphHandle","FrameGraphPass","tearDown","PassNode","hasSideEffect","devirtualize","reads","writes","fg","getResourceNode","resource","imported","createResourceNode","writer","_setPrototypeOf","_inherits","subClass","superClass","_assertThisInitialized","ReferenceError","_possibleConstructorReturn","_getPrototypeOf","_dec","_dec2","_class","_class2","_descriptor","ResourceEntry","_VirtualResource","VirtualResource","Derived","hasNativeReflectConstruct","_super","sham","Proxy","_isNativeReflectConstruct","Super","NewTarget","_len","refs","discardStart","discardEnd","ResourceNode","readerCount","_createForOfIteratorHelper","allowArrayLike","normalCompletion","didErr","_e2","passNodes","resourceNodes","frameGraphPasses","_executePassNodes","_execute","views","executePassNodes","pass","setup","frameGraphPass","passNode","_step","_iterator","_pass","_step2","_iterator2","pNode","_step3","_iterator3","_step4","_iterator4","_pass2","_step6","_iterator6","_resource2","pResource","_step7","_iterator7","_resource3","_pResource","_step5","_iterator5","_resource","pFirst","pLast","_callee2","_iterator8","_step8","_step8$value","_iterator9","_step9","_iterator10","_step10","_iterator11","_step11","_iterator12","_step12","_context2","preExecuteDevirtualize","engine","preExecuteDestroy","postExecuteDevirtualize","postExecuteDestroy","_x2","resourceEntry","resourceNode","fgh","addPass","_callee3","_context3","_defineProperty","ARRAY_TYPE","az","enumerableOnly","_objectSpread","_dec3","_descriptor2","GeometryComponent","_Component","indicesBuffer","vertexCount","maxInstancedCount","aabb","bufferGetter","existed","a03","a13","a23","a30","a31","a32","a33","b03","b04","b05","b06","b07","b08","b09","det","positionAttribute","_ref","normalAttribute","_ref2","normalMatrix","normal","geometry","_attribute$buffer","subData","createElements","UNSIGNED_INT","STATIC_DRAW","_dec4","_descriptor3","MaterialComponent","vertexShaderGLSL","fragmentShaderGLSL","defines","cull","BACK","blend","_this2","setUniform","existedUniform","Strategy","material","vertexShader","fragmentShader","supportWebGPU","moduleName","shaderModule","registerModule","fs","materialModule","getModule","uniformName","CullableComponent","strategy","Standard","visibilityPlaneMask","visible","AABB","halfExtents","tc","tcx","tcy","tcz","thx","thy","thz","tminx","tmaxx","tminy","tmaxy","tminz","tmaxz","oc","ocx","ocy","ocz","oh","ohx","ohy","ohz","ominx","omaxx","ominy","omaxy","ominz","omaxz","aMax","getMax","aMin","getMin","bMax","bMin","plane","pnVertexFlag","Mask","MeshComponent","aabbDirty","model","Plane","updatePNVertexFlag","invLen","d0","distanceToPoint","intersects","_dec5","_dec6","_descriptor4","_descriptor5","Frustum","planes","vpMatrix","_vpMatrix","m0","m10","m11","_dec7","_dec8","_dec9","_dec10","_dec11","_descriptor6","_descriptor7","_descriptor8","_descriptor9","_class3","scene","camera","hierarchyComponent","cullableComponent","geometryComponent","meshTransform","worldTransform","_geometryComponent$aa","transformedCenter","rotationScale","transformedHalfExtents","parentCullableComponent","getScene","getCamera","getEntities","mesh","getComponentByEntity","hierarchy","cullable","parentID","computeVisibilityWithPlaneMask","INDETERMINATE","getFrustum","OUTSIDE","parentPlaneMask","INSIDE","_planes$k","getNegativeFarPoint","getPositiveFarPoint","b2","b3","getTranslation","getScaling","m21","m22","m23","m31","m32","m33","scaling","is1","is2","is3","sm11","sm12","sm13","sm21","sm22","sm23","sm31","sm32","sm33","z2","xx","yx","yy","zx","zy","zz","wx","wy","wz","modelCache","createRenderTarget","RENDER_ATTACHMENT","SAMPLED","COPY_SRC","resourcePool","getOrCreateResource","initView","getCanvas","setScissor","getClearColor","useFramebuffer","renderView","_x3","_initView","_initMesh","viewMatrix","getViewTransform","viewProjectionMatrix","getPerspective","extractFromVPMatrix","_view$getViewport","getViewport","meshEntity","renderMesh","modelViewMatrix","_view$getViewport2","projectionMatrix","modelMatrix","cameraPosition","getPosition","u_viewport","modelCacheKey","_this$engine","createModel","createAttribute","modelInitializationOptions","arrayStride","stepMode","scissor","_x4","_x5","initMesh","_x6","PixelPickingPass","pickingFBO","highlightEnabled","highlightColor","alreadyInRendering","_loop","renderPass","renderPassFactory","meshes","pickedColors","pickedFeatureIdx","xInDevicePixel","yInDevicePixel","_color","highlightPickedFeature","enabled","CopyPass","getPass","a_Position","shaderLocation","u_Texture","_this$renderPassFacto","setupRenderPass","executeRenderPass","_this$renderPassFacto2","setupCopyPass","executeCopyPass","tearDownCopyPass","copyPass","frameGraphSystem","present","clean","HierarchyComponent","runTransformUpdateSystem","runHierarchyUpdateSystem","isDirty","isLocalDirty","setMeshAABBDirty","updateTransform","parentComponent","transformChild","transformParent","updateTransformWithParent","isChildAlreadyInLocalSpace","detach","parentCandidateEntity","getEntity","moveItem","matrixTransform","applyTransform","removeKeepSorted","_this$hierarchy$getCo","setAxisAngle","axis","rad","aw","bx","bz","bw","invDot","fromEuler","halfToRad","cz","TransformComponent","transformed","quatX","quatY","quatZ","aS","aR","aT","bS","bR","bT","tr","parentInvertMatrix","parentInvertRotation","invParentRot","dirtyFlag","localDirtyFlag","localPosition","localRotation","localScale","localTransform","rotation","getLocalTransform","rotateRollPitchYaw","setDirty","omega","cosom","sinom","scale0","scale1","translate","translation","setPosition","translateLocal","qx","qy","qz","qw","uuvx","uvz","uvy","uuvy","uvx","uuvz","w2","setLocalDirty","quaternion","rot","getRotation","parentRot","rotateLocal","setRotation","DIRTY","xy","getWorldTransform","_resource$descriptor","createTexture2D","CLAMP_TO_EDGE","IInteractorEvent","NameComponent","uniformRegExp","extractUniforms","content","defaultValues","arrayLength","getUniformLengthByType","precisionRegExp","includeRegExp","moduleCache","rawContentCache","moduleParams","_moduleParams$vs","_moduleParams$fs","declaredUniforms","_extractUniforms","extractedVS","vsUniforms","_extractUniforms2","extractedFS","fsUniforms","rawVS","rawFS","_this$processModule","processModule","vsIncludeList","includeList","_this$processModule2","fsIncludeList","compiledFs","rawContent","strMatch","includeName","txt","createWorldContainer","worldContainer","generateAABBFromVertices","setMinMax","PassType","AST_TOKEN_TYPES","AST_NODE_TYPES","STORAGE_CLASS","isSafari","CAMERA_TYPE","CAMERA_TRACKING_MODE","CAMERA_PROJECTION_MODE","Landmark","up","forward","focalPoint","distanceVector","dollyingStep","azimuth","elevation","roll","relAzimuth","relElevation","relRoll","DEG_2_RAD","RAD_2_DEG","Camera","minDistance","rotateWorld","fov","near","far","aspect","rright","zoom","perspective","following","EXPLORING","trackingMode","projectionMode","PERSPECTIVE","frustum","landmarks","landmarkAnimationID","setType","interactor","setWorldRotation","_getAngles","TRACKING","setTrackingMode","_update","setPerspective","fullWidth","fullHeight","offsetX","offsetY","setOrthographic","fovy","nf","ORTHOGRAPHIC","scaleW","scaleH","lr","bt","_setPosition","setFocalPoint","CINEMATIC","atan2","z0","z1","eyex","eyey","eyez","upx","upy","upz","centerx","centery","centerz","_getAxes","_getDistance","setAzimuth","setElevation","rl","setRoll","computeMatrix","ORBITING","_getPosition","_getFocalPoint","rotX","rotY","rotZ","rotQ","rotMatrix","tx","ty","coords","updatedDistance","landmark","duration","retrieve","timeStart","destPosition","destFocalPoint","getFocalPoint","destRoll","getRoll","animate","timestamp","interRoll","elapsed","interFocalPoint","interPosition","ProjectionMode","onEntityCreated","SPHERE","PLANE","MERGED","_primitiveMap","_usageMap","_dataTypeMap","_formatMap","_mipmapMap","_filterMap","_wrapModeMap","_colorSpaceMap","_depthFuncMap","_blendEquationMap","_blendFuncMap","_stencilFuncMap","_stencilOpMap","_cullFaceMap","Kernel","compiledBundle","initPromise","_compile","_getOutput","_this$configService$g","configService","engineOptions","swapChainFormat","antialiasing","bundle","parse","isNumberLikeData","existedDefine","existedBinding","isReferer","storageClass","Uniform","updateUniform","updateBuffer","setBinding","iteration","_args","beginFrame","confirmInput","endFrame","readData","useWGSL","WGSL","GLSL450","GLSL100","shaders","valuePlaceHolder","StorageBuffer","sizePerElement","FloatArray","Vector4FloatArray","createComputeModel","BASIC","meshComponent","transformComponent","onAttributeChanged","childEntity","parentRenderable","sceneGraphSystem","detachChildren","convertAttributeName2UniformName","attributeName","POINT","LINE","GRID","ReglAttribute","primitiveMap","POINTS","LINES","LINE_LOOP","LINE_STRIP","TRIANGLES","TRIANGLE_FAN","TRIANGLE_STRIP","usageMap","DYNAMIC_DRAW","STREAM_DRAW","dataTypeMap","BYTE","UNSIGNED_BYTE","UNSIGNED_SHORT","formatMap","LUMINANCE","LUMINANCE_ALPHA","RGBA","RGBA4","RGB5_A1","RGB565","DEPTH_COMPONENT","DEPTH_STENCIL","mipmapMap","DONT_CARE","NICEST","FASTEST","filterMap","NEAREST","LINEAR","LINEAR_MIPMAP_LINEAR","NEAREST_MIPMAP_LINEAR","LINEAR_MIPMAP_NEAREST","NEAREST_MIPMAP_NEAREST","wrapModeMap","REPEAT","MIRRORED_REPEAT","colorSpaceMap","NONE","BROWSER_DEFAULT_WEBGL","depthFuncMap","NEVER","ALWAYS","LESS","LEQUAL","GREATER","GEQUAL","EQUAL","NOTEQUAL","blendEquationMap","FUNC_ADD","MIN_EXT","MAX_EXT","FUNC_SUBTRACT","FUNC_REVERSE_SUBTRACT","blendFuncMap","ONE","SRC_COLOR","ONE_MINUS_SRC_COLOR","ONE_MINUS_SRC_ALPHA","DST_COLOR","ONE_MINUS_DST_COLOR","DST_ALPHA","ONE_MINUS_DST_ALPHA","CONSTANT_COLOR","ONE_MINUS_CONSTANT_COLOR","CONSTANT_ALPHA","ONE_MINUS_CONSTANT_ALPHA","SRC_ALPHA_SATURATE","stencilFuncMap","stencilOpMap","KEEP","INVERT","INCR","DECR","INCR_WRAP","DECR_WRAP","cullFaceMap","FRONT","ReglBuffer","reGl","_toConsumableArray","textureId","ReglComputeModel","texFBO","computeCommand","textureCache","outputTextureName","swapOutputTextureName","compiledPingpong","dynamicPingpong","calcDataTexture","_this$textureCache$na","textureWidth","isOutput","needPingpong","_this$getOuputDataTex","getOuputDataTexture","texelCount","u_OutputTextureSize","u_OutputTexelCount","textureSize","drawParams","a_TexCoord","_readData","swap","_this$getOuputDataTex2","originalDataLength","elementsPerTexel","_this$getOuputDataTex3","typedArrayConstructor","formattedPixels","_this3","inputName","inputModel","bufferName","_this$calcDataTexture","paddingData","createSwapOutputDataTexture","outputTextureUniformName","cloneDataTexture","paddingTexelCount","ReglElements","ReglFramebuffer","framebufferOptions","extractedUniforms","extractUniformsRecursively","uniformValue","childName","glslang","ReglModel","drawCommand","reglUniforms","reglAttributes","defineStmts","generateDefines","initDepthDrawParams","initBlendDrawParams","initStencilDrawParams","initCullDrawParams","reglDrawProps","equation","_blend$color","_ref3","_stencil$mask","_stencil$func","_stencil$opFront","_stencil$opBack","_ref4","_cull$face","ReglTexture2D","_options$type","_options$flipY","_options$format","_options$mipmap","_options$wrapS","_options$wrapT","_options$aniso","aniso","_options$alignment","_options$premultiplyA","_options$mag","_options$colorSpace","textureOptions","$canvas","inited","drawCommands","_options$framebuffer","reglClearOptions","SCISSOR_TEST","disable","readPixelsOptions","getGLContext","_init","_callee4","_context4","antialias","loadScriptAsync","scriptUrl","scriptId","onSuccess","onError","getElementsByTagName","script","setAttribute","onload","onerror","loadScript","WebGPUAttribute","_options","WebGPUBuffer","verticesBufferDescriptor","device","destBuffer","destOffset","srcArrayBuffer","getQueue","defaultQueue","writeBuffer","WebGPUComputeModel","uniformGPUBufferLayout","uniformBuffer","vertexBuffers","outputBuffer","bindGroupEntries","bindGroup","computePipeline","_compileComputePipelineStageDescriptor","_yield$this$compileCo","computeStage","bufferBindingIndex","mergedUniformData","compileComputePipelineStageDescriptor","_uniform$data","originDataLength","gpuBuffer","refer","createComputePipeline","createBindGroup","getBindGroupLayout","byteCount","gpuReadBuffer","encoder","arraybuffer","GPUBufferUsage","COPY_DST","MAP_READ","createCommandEncoder","copyBufferToBuffer","submit","mapAsync","getMappedRange","unmap","_this$engine$currentC","currentComputePass","setPipeline","setBindGroup","inputBuffer","_context$output","shaderVersion","compileRawShaderToSpirV","compileGLSL","computeCode","computeShader","compileShaderToSpirV","createShaderModule","isWHLSL","entryPoint","WebGPUElements","indexCount","WebGPUFramebuffer","_this$colorTexture","_this$depthTexture","_this$colorTexture2","_this$depthTexture2","_this$colorTexture3","_this$depthTexture3","getCullMode","getDepthStencilStateDescriptor","stencilFrontBack","compare","depthFailOp","failOp","passOp","depthWriteEnabled","depthCompare","stencilFront","stencilBack","stencilReadMask","stencilWriteMask","getColorStateDescriptors","alphaBlend","srcFactor","dstFactor","operation","colorBlend","writeMask","concatenate","resultConstructor","totalLength","_arrays","_arrays2","WebGPUModel","pipelineLayout","renderPipeline","uniformsBindGroupLayout","uniformBindGroup","attributeCache","indexBuffer","_compilePipelineStageDescriptor","_this$options","_yield$this$compilePi","vertexStage","fragmentStage","vertexState","compilePipelineStageDescriptor","buildUniformBindGroup","_attribute$get","ats","sampleCount","mainPassSampleCount","primitiveTopology","rasterizationState","getDefaultRasterizationStateDescriptor","cullMode","depthStencilState","colorStates","createRenderPipeline","getCurrentRenderPass","bindGroupBindings","_this2$uniformGPUBuff","_this2$uniformGPUBuff2","_offset","textureOrFramebuffer","sampler","createView","setIndexBuffer","setVertexBuffer","drawIndexed","vertexCode","fragmentCode","createPipelineStageDescriptor","frontFace","depthBias","depthBiasSlopeScale","depthBiasClamp","hasUniform","visibility","createBindGroupLayout","createPipelineLayout","bindGroupLayouts","WebGPUTexture2D","_this$options$format","_this$options$wrapS","_this$options$wrapT","_this$options$aniso","_this$options$mag","_this$options$min","mipLevelCount","createSampler","addressModeU","addressModeV","addressModeW","maxAnisotropy","adapter","swapChain","mainTexture","mainColorAttachments","mainTextureExtends","mainDepthAttachment","uploadEncoder","renderEncoder","computeEncoder","renderTargetEncoder","commandBuffers","currentRenderPass","mainRenderPass","currentRenderTargetViewDescriptor","bundleEncoder","tempBuffers","currentRenderTarget","uploadEncoderDescriptor","renderEncoderDescriptor","renderTargetEncoderDescriptor","computeEncoderDescriptor","pipelines","computePipelines","defaultSampleCount","clearDepthValue","clearStencilValue","transientViewport","cachedViewport","supportCompute","startComputePass","endRenderTargetRenderPass","startRenderTargetRenderPass","loadValue","depthLoadValue","stencilLoadValue","endMainRenderPass","startMainRenderPass","unbindFramebuffer","arrayLayerCount","setViewport","_initGlslang","initGlslang","initContextAndSwapChain","initMainAttachments","endComputePass","_navigator","_navigator$gpu","gpu","requestAdapter","requestDevice","configureSwapChain","mainTextureDescriptor","createDefaultView","storeOp","getCurrentTexture","depthTextureDescriptor","depthStoreOp","stencilStoreOp","beginComputePass","resolveTarget","beginRenderPass","renderTarget","_renderTarget$get$col","_renderTarget$get$dep","colorTextureView","gpuTexture","depthStencilTextureView","endPass","resetCachedViewport","primitiveUv1Padding","Box","_Geometry","_this$config","_this$config$widthSeg","widthSegments","_this$config$heightSe","heightSegments","_this$config$depthSeg","depthSegments","_this$config$halfExte","hs","ds","_halfExtents","hey","hez","corners","faceAxes","faceNormals","normals","uvs","uvs1","vcounter","generateFace","side","uSegments","vSegments","temp1","temp2","temp3","Merged","_this$config$geometri","geometries","mergedComponent","mergedAttributes","mergedIndices","indexOffset","_this$config$lengthSe","lengthSegments","Sphere","_this$config$radius","_this$config$latitude","latitudeBands","_this$config$longitud","longitudeBands","lat","sinTheta","cosTheta","lon","phi","sinPhi","_lat","_lon","second","Basic","_Material","shaderModuleService","_this$shaderModuleSer","setDefines","USE_UV","USE_MAP","uvTransform","Grid","_Renderable","getMeshComponent","materialSystem","createShaderMaterial","setMaterial","geometrySystem","createBufferGeometry","setGeometry","setCull","setDepth","setAttributes","gridColor","gridSize","setIndex","extrusions","addNext","Line","_getNormals","closed","_lastFlip","_started","_normal","attrPos","attrIndex","attrCounters","miterLen","bevel","dashArray","dashOffset","dashRatio","thickness","attrNormal","attrMiter","norm","pointShapes","Point","u_device_pixel_ratio","buildAttributes","createInstancedBufferGeometry","instancedOffsets","instancedColors","instancedSizes","instancedShapes","instancedPickingColors","_attributes$instanced","_attributes$instanced2","_attributes$instanced3","_attributes$instanced4","featureIdx","buildAttribute","Renderer","rendering","pendings","_render","systems","system","registerBuiltinModules","_args2","pending","Scene","renderable","addEntity","removeEntity","TextureCache","Texture2D","_load","Image","crossOrigin","View","rendererSystem","_getEngine","setConfig","setEntity","precompiledBundle","kernel","setBundle","engineClazz","world","setContainer","arrayToTextureData","valueArrays","dataArray","attributeNum","itemNum","valueArray","clusterField","attributeNames","items","attributteStringMap","attributeArray","clusterCount","numParticles","nodeDict","mapIdPos","maxEdgePerVetex","dests","dest","buildTextureData","nodesEdgesArray","clusterCenters","kernelFruchterman","createKernel","setDispatch","u_Data","u_K","u_K2","u_Gravity","u_ClusterGravity","u_Speed","u_MaxDisplace","u_Clustering","u_Center","u_AttributeArray","u_ClusterCenters","MAX_EDGE_PER_VERTEX","VERTEX_COUNT","kernelCluster","u_NodeAttributes","CLUSTER_COUNT","getOutput","finalParticleData","vertexEdgeData","attrs1","attrs2","buildTextureDataWithTwoEdgeAttr","masses","nodeStrengths","centerXs","centerYs","centerGravities","fxs","fys","nodeGravity","customCenter","nodeAttributeArray1","nodeAttributeArray2","initPreviousData","kernelGForce","u_damping","u_maxSpeed","u_minMovement","u_coulombDisScale","u_factor","u_NodeAttributeArray1","u_NodeAttributeArray2","u_AveMovement","u_interval","kernelAveMovement","comboGravity","preventNodeOverlap","preventComboOverlap","nodeCollideStrength","comboCollideStrength","comboSpacing","comboPadding","optimizeRangeFactor","onTick","depthAttractiveForceScale","depthRepulsiveForceScale","comboTrees","oriComboMap","previousLayouted","comboTree","initVals","initPos","applyComboCenterForce","meanCenter","centerOffset","mapped","getComboMap","comboSpacingFunc","comboPaddingFunc","linkDistanceFunc","edgeStrengthFunc","nodeStrengthFunc","ctree","treeChildren","treeNode","itemType","oriCombo","virtualNodeId","vnode","childCombo","gravityScale","comboX","comboY","vecMap","vl2","vl","updateComboSizes","comboNonOverlapping","nodeMinX","nodeMinY","nodeMaxX","nodeMaxY","minSize","cv","cu","rv","ru","ru2","rv2","vnodes","sqrtl","ll","vn","vindex","uindex","depthDiff","depthParam","rj2","rratio","ry","mass","distanceTo","bo","setPos","resetForce","addForce","nenwMass","Body","xmid","ymid","massCenter","getLength","halfLen","NW","Quad","NE","SW","SE","_isExternal","QuadTree","_putBody","updateForce","kr","kg","dissuadeHubs","barnesHut","ksmax","tao","prune","sizes","nodeNum","nodeWidth","nodeHeight","getWidth","getHeight","maxSize","updateNodesByForces","nonLoopEdges","esize","idMap","edgeEndsIdMap","Es","node1","node2","sIdx","tIdx","preForces","bodies","getAttrForces","getOptRepGraForces","getRepGraForces","updatePos","prevoIter","eucliDis","Fa1","Fa2","krPrime","Fr","Fg","minx","maxx","miny","maxy","quadTree","swgns","trans","swgG","traG","minusNorm","addNorm","preSG","absForce","dnx","dny","layoutClass","layoutInstance","Layouts","propKey"],"mappings":"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AAe,MAAI,GAAK,S,gBCzQpC,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,MACR,EAAQ,OACR,EAAQ,OACR,EAAQ,MACR,EAAQ,OACR,EAAQ,OACR,EAAQ,MACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,MACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,MACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,MACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,MACR,EAAQ,OACR,EAAQ,MACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,MACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,MACR,EAAQ,OACR,EAAQ,MACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,MACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,KACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,OACR,EAAQ,O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","file":"layout.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"layout\"] = factory();\n\telse\n\t\troot[\"layout\"] = factory();\n})(self, function() {\nreturn ","\"use strict\";\n\nrequire(\"core-js/es6\");\n\nrequire(\"core-js/fn/array/includes\");\n\nrequire(\"core-js/fn/array/flat-map\");\n\nrequire(\"core-js/fn/string/pad-start\");\n\nrequire(\"core-js/fn/string/pad-end\");\n\nrequire(\"core-js/fn/string/trim-start\");\n\nrequire(\"core-js/fn/string/trim-end\");\n\nrequire(\"core-js/fn/symbol/async-iterator\");\n\nrequire(\"core-js/fn/object/get-own-property-descriptors\");\n\nrequire(\"core-js/fn/object/values\");\n\nrequire(\"core-js/fn/object/entries\");\n\nrequire(\"core-js/fn/promise/finally\");\n\nrequire(\"core-js/web\");\n\nrequire(\"regenerator-runtime/runtime\");","module.exports = require(\"regenerator-runtime\");\n","\"use strict\";\n// https://github.com/gpuweb/gpuweb/blob/01b20b4ad93fabae1e8e0d7752515f69708d33e0/spec/index.bs\nObject.defineProperty(exports, \"__esModule\", { value: true });\n// tslint:disable:variable-name\n// String enums\nvar ExtensionName;\n(function (ExtensionName) {\n ExtensionName[\"TextureCompressionBC\"] = \"texture-compression-bc\";\n})(ExtensionName = exports.ExtensionName || (exports.ExtensionName = {}));\nvar AddressMode;\n(function (AddressMode) {\n AddressMode[\"ClampToEdge\"] = \"clamp-to-edge\";\n AddressMode[\"Repeat\"] = \"repeat\";\n AddressMode[\"MirrorRepeat\"] = \"mirror-repeat\";\n})(AddressMode = exports.AddressMode || (exports.AddressMode = {}));\nvar BindingType;\n(function (BindingType) {\n BindingType[\"UniformBuffer\"] = \"uniform-buffer\";\n BindingType[\"StorageBuffer\"] = \"storage-buffer\";\n BindingType[\"ReadonlyStorageBuffer\"] = \"readonly-storage-buffer\";\n BindingType[\"Sampler\"] = \"sampler\";\n BindingType[\"ComparisonSampler\"] = \"comparison-sampler\";\n BindingType[\"SampledTexture\"] = \"sampled-texture\";\n BindingType[\"ReadonlyStorageTexture\"] = \"readonly-storage-texture\";\n BindingType[\"WriteonlyStorageTexture\"] = \"writeonly-storage-texture\";\n})(BindingType = exports.BindingType || (exports.BindingType = {}));\nvar BlendFactor;\n(function (BlendFactor) {\n BlendFactor[\"Zero\"] = \"zero\";\n BlendFactor[\"One\"] = \"one\";\n BlendFactor[\"SrcColor\"] = \"src-color\";\n BlendFactor[\"OneMinusSrcColor\"] = \"one-minus-src-color\";\n BlendFactor[\"SrcAlpha\"] = \"src-alpha\";\n BlendFactor[\"OneMinusSrcAlpha\"] = \"one-minus-src-alpha\";\n BlendFactor[\"DstColor\"] = \"dst-color\";\n BlendFactor[\"OneMinusDstColor\"] = \"one-minus-dst-color\";\n BlendFactor[\"DstAlpha\"] = \"dst-alpha\";\n BlendFactor[\"OneMinusDstAlpha\"] = \"one-minus-dst-alpha\";\n BlendFactor[\"SrcAlphaSaturated\"] = \"src-alpha-saturated\";\n BlendFactor[\"BlendColor\"] = \"blend-color\";\n BlendFactor[\"OneMinusBlendColor\"] = \"one-minus-blend-color\";\n})(BlendFactor = exports.BlendFactor || (exports.BlendFactor = {}));\nvar BlendOperation;\n(function (BlendOperation) {\n BlendOperation[\"Add\"] = \"add\";\n BlendOperation[\"Subtract\"] = \"subtract\";\n BlendOperation[\"ReverseSubtract\"] = \"reverse-subtract\";\n BlendOperation[\"Min\"] = \"min\";\n BlendOperation[\"Max\"] = \"max\";\n})(BlendOperation = exports.BlendOperation || (exports.BlendOperation = {}));\nvar CompareFunction;\n(function (CompareFunction) {\n CompareFunction[\"Never\"] = \"never\";\n CompareFunction[\"Less\"] = \"less\";\n CompareFunction[\"Equal\"] = \"equal\";\n CompareFunction[\"LessEqual\"] = \"less-equal\";\n CompareFunction[\"Greater\"] = \"greater\";\n CompareFunction[\"NotEqual\"] = \"not-equal\";\n CompareFunction[\"GreaterEqual\"] = \"greater-equal\";\n CompareFunction[\"Always\"] = \"always\";\n})(CompareFunction = exports.CompareFunction || (exports.CompareFunction = {}));\nvar CullMode;\n(function (CullMode) {\n CullMode[\"None\"] = \"none\";\n CullMode[\"Front\"] = \"front\";\n CullMode[\"Back\"] = \"back\";\n})(CullMode = exports.CullMode || (exports.CullMode = {}));\nvar FilterMode;\n(function (FilterMode) {\n FilterMode[\"Nearest\"] = \"nearest\";\n FilterMode[\"Linear\"] = \"linear\";\n})(FilterMode = exports.FilterMode || (exports.FilterMode = {}));\nvar FrontFace;\n(function (FrontFace) {\n FrontFace[\"CCW\"] = \"ccw\";\n FrontFace[\"CW\"] = \"cw\";\n})(FrontFace = exports.FrontFace || (exports.FrontFace = {}));\nvar IndexFormat;\n(function (IndexFormat) {\n IndexFormat[\"Uint16\"] = \"uint16\";\n IndexFormat[\"Uint32\"] = \"uint32\";\n})(IndexFormat = exports.IndexFormat || (exports.IndexFormat = {}));\nvar InputStepMode;\n(function (InputStepMode) {\n InputStepMode[\"Vertex\"] = \"vertex\";\n InputStepMode[\"Instance\"] = \"instance\";\n})(InputStepMode = exports.InputStepMode || (exports.InputStepMode = {}));\nvar LoadOp;\n(function (LoadOp) {\n LoadOp[\"Load\"] = \"load\";\n})(LoadOp = exports.LoadOp || (exports.LoadOp = {}));\nvar PrimitiveTopology;\n(function (PrimitiveTopology) {\n PrimitiveTopology[\"PointList\"] = \"point-list\";\n PrimitiveTopology[\"LineList\"] = \"line-list\";\n PrimitiveTopology[\"LineStrip\"] = \"line-strip\";\n PrimitiveTopology[\"TriangleList\"] = \"triangle-list\";\n PrimitiveTopology[\"TriangleStrip\"] = \"triangle-strip\";\n})(PrimitiveTopology = exports.PrimitiveTopology || (exports.PrimitiveTopology = {}));\nvar StencilOperation;\n(function (StencilOperation) {\n StencilOperation[\"Keep\"] = \"keep\";\n StencilOperation[\"Zero\"] = \"zero\";\n StencilOperation[\"Replace\"] = \"replace\";\n StencilOperation[\"Invert\"] = \"invert\";\n StencilOperation[\"IncrementClamp\"] = \"increment-clamp\";\n StencilOperation[\"DecrementClamp\"] = \"decrement-clamp\";\n StencilOperation[\"IncrementWrap\"] = \"increment-wrap\";\n StencilOperation[\"DecrementWrap\"] = \"decrement-wrap\";\n})(StencilOperation = exports.StencilOperation || (exports.StencilOperation = {}));\nvar StoreOp;\n(function (StoreOp) {\n StoreOp[\"Store\"] = \"store\";\n StoreOp[\"Clear\"] = \"clear\";\n})(StoreOp = exports.StoreOp || (exports.StoreOp = {}));\nvar TextureDimension;\n(function (TextureDimension) {\n TextureDimension[\"E1d\"] = \"1d\";\n TextureDimension[\"E2d\"] = \"2d\";\n TextureDimension[\"E3d\"] = \"3d\";\n})(TextureDimension = exports.TextureDimension || (exports.TextureDimension = {}));\nvar TextureFormat;\n(function (TextureFormat) {\n TextureFormat[\"R8Unorm\"] = \"r8unorm\";\n TextureFormat[\"R8Snorm\"] = \"r8snorm\";\n TextureFormat[\"R8Uint\"] = \"r8uint\";\n TextureFormat[\"R8Sint\"] = \"r8sint\";\n TextureFormat[\"R16Uint\"] = \"r16uint\";\n TextureFormat[\"R16Sint\"] = \"r16sint\";\n TextureFormat[\"R16Float\"] = \"r16float\";\n TextureFormat[\"RG8Unorm\"] = \"rg8unorm\";\n TextureFormat[\"RG8Snorm\"] = \"rg8snorm\";\n TextureFormat[\"RG8Uint\"] = \"rg8uint\";\n TextureFormat[\"RG8Sint\"] = \"rg8sint\";\n TextureFormat[\"R32Uint\"] = \"r32uint\";\n TextureFormat[\"R32Sint\"] = \"r32sint\";\n TextureFormat[\"R32Float\"] = \"r32float\";\n TextureFormat[\"RG16Uint\"] = \"rg16uint\";\n TextureFormat[\"RG16Sint\"] = \"rg16sint\";\n TextureFormat[\"RG16Float\"] = \"rg16float\";\n TextureFormat[\"RGBA8Unorm\"] = \"rgba8unorm\";\n TextureFormat[\"RGBA8UnormSRGB\"] = \"rgba8unorm-srgb\";\n TextureFormat[\"RGBA8Snorm\"] = \"rgba8snorm\";\n TextureFormat[\"RGBA8Uint\"] = \"rgba8uint\";\n TextureFormat[\"RGBA8Sint\"] = \"rgba8sint\";\n TextureFormat[\"BGRA8Unorm\"] = \"bgra8unorm\";\n TextureFormat[\"BGRA8UnormSRGB\"] = \"bgra8unorm-srgb\";\n TextureFormat[\"RGB10A2Unorm\"] = \"rgb10a2unorm\";\n TextureFormat[\"RG11B10Float\"] = \"rg11b10float\";\n TextureFormat[\"RG32Uint\"] = \"rg32uint\";\n TextureFormat[\"RG32Sint\"] = \"rg32sint\";\n TextureFormat[\"RG32Float\"] = \"rg32float\";\n TextureFormat[\"RGBA16Uint\"] = \"rgba16uint\";\n TextureFormat[\"RGBA16Sint\"] = \"rgba16sint\";\n TextureFormat[\"RGBA16Float\"] = \"rgba16float\";\n TextureFormat[\"RGBA32Uint\"] = \"rgba32uint\";\n TextureFormat[\"RGBA32Sint\"] = \"rgba32sint\";\n TextureFormat[\"RGBA32Float\"] = \"rgba32float\";\n TextureFormat[\"Depth32Float\"] = \"depth32float\";\n TextureFormat[\"Depth24Plus\"] = \"depth24plus\";\n TextureFormat[\"Depth24PlusStencil8\"] = \"depth24plus-stencil8\";\n})(TextureFormat = exports.TextureFormat || (exports.TextureFormat = {}));\nvar TextureComponentType;\n(function (TextureComponentType) {\n TextureComponentType[\"Float\"] = \"float\";\n TextureComponentType[\"Sint\"] = \"sint\";\n TextureComponentType[\"Uint\"] = \"uint\";\n})(TextureComponentType = exports.TextureComponentType || (exports.TextureComponentType = {}));\nvar TextureViewDimension;\n(function (TextureViewDimension) {\n TextureViewDimension[\"E1d\"] = \"1d\";\n TextureViewDimension[\"E2d\"] = \"2d\";\n TextureViewDimension[\"E2dArray\"] = \"2d-array\";\n TextureViewDimension[\"Cube\"] = \"cube\";\n TextureViewDimension[\"CubeArray\"] = \"cube-array\";\n TextureViewDimension[\"E3d\"] = \"3d\";\n})(TextureViewDimension = exports.TextureViewDimension || (exports.TextureViewDimension = {}));\nvar VertexFormat;\n(function (VertexFormat) {\n VertexFormat[\"Uchar2\"] = \"uchar2\";\n VertexFormat[\"Uchar4\"] = \"uchar4\";\n VertexFormat[\"Char2\"] = \"char2\";\n VertexFormat[\"Char4\"] = \"char4\";\n VertexFormat[\"Uchar2Norm\"] = \"uchar2norm\";\n VertexFormat[\"Uchar4Norm\"] = \"uchar4norm\";\n VertexFormat[\"Char2Norm\"] = \"char2norm\";\n VertexFormat[\"Char4Norm\"] = \"char4norm\";\n VertexFormat[\"Ushort2\"] = \"ushort2\";\n VertexFormat[\"Ushort4\"] = \"ushort4\";\n VertexFormat[\"Short2\"] = \"short2\";\n VertexFormat[\"Short4\"] = \"short4\";\n VertexFormat[\"Ushort2Norm\"] = \"ushort2norm\";\n VertexFormat[\"Ushort4Norm\"] = \"ushort4norm\";\n VertexFormat[\"Short2Norm\"] = \"short2norm\";\n VertexFormat[\"Short4Norm\"] = \"short4norm\";\n VertexFormat[\"Half2\"] = \"half2\";\n VertexFormat[\"Half4\"] = \"half4\";\n VertexFormat[\"Float\"] = \"float\";\n VertexFormat[\"Float2\"] = \"float2\";\n VertexFormat[\"Float3\"] = \"float3\";\n VertexFormat[\"Float4\"] = \"float4\";\n VertexFormat[\"Uint\"] = \"uint\";\n VertexFormat[\"Uint2\"] = \"uint2\";\n VertexFormat[\"Uint3\"] = \"uint3\";\n VertexFormat[\"Uint4\"] = \"uint4\";\n VertexFormat[\"Int\"] = \"int\";\n VertexFormat[\"Int2\"] = \"int2\";\n VertexFormat[\"Int3\"] = \"int3\";\n VertexFormat[\"Int4\"] = \"int4\";\n})(VertexFormat = exports.VertexFormat || (exports.VertexFormat = {}));\nvar TextureAspect;\n(function (TextureAspect) {\n TextureAspect[\"All\"] = \"all\";\n TextureAspect[\"StencilOnly\"] = \"stencil-only\";\n TextureAspect[\"DepthOnly\"] = \"depth-only\";\n})(TextureAspect = exports.TextureAspect || (exports.TextureAspect = {}));\nvar CompilationMessageType;\n(function (CompilationMessageType) {\n CompilationMessageType[\"Error\"] = \"error\";\n CompilationMessageType[\"Warning\"] = \"warning\";\n CompilationMessageType[\"Info\"] = \"info\";\n})(CompilationMessageType = exports.CompilationMessageType || (exports.CompilationMessageType = {}));\nvar QueryType;\n(function (QueryType) {\n QueryType[\"Occlusion\"] = \"occlusion\";\n})(QueryType = exports.QueryType || (exports.QueryType = {}));\n// Bit fields\nvar BufferUsage;\n(function (BufferUsage) {\n BufferUsage[BufferUsage[\"MapRead\"] = 1] = \"MapRead\";\n BufferUsage[BufferUsage[\"MapWrite\"] = 2] = \"MapWrite\";\n BufferUsage[BufferUsage[\"CopySrc\"] = 4] = \"CopySrc\";\n BufferUsage[BufferUsage[\"CopyDst\"] = 8] = \"CopyDst\";\n BufferUsage[BufferUsage[\"Index\"] = 16] = \"Index\";\n BufferUsage[BufferUsage[\"Vertex\"] = 32] = \"Vertex\";\n BufferUsage[BufferUsage[\"Uniform\"] = 64] = \"Uniform\";\n BufferUsage[BufferUsage[\"Storage\"] = 128] = \"Storage\";\n BufferUsage[BufferUsage[\"Indirect\"] = 256] = \"Indirect\";\n BufferUsage[BufferUsage[\"QueryResolve\"] = 512] = \"QueryResolve\";\n})(BufferUsage = exports.BufferUsage || (exports.BufferUsage = {}));\nvar ColorWrite;\n(function (ColorWrite) {\n ColorWrite[ColorWrite[\"Red\"] = 1] = \"Red\";\n ColorWrite[ColorWrite[\"Green\"] = 2] = \"Green\";\n ColorWrite[ColorWrite[\"Blue\"] = 4] = \"Blue\";\n ColorWrite[ColorWrite[\"Alpha\"] = 8] = \"Alpha\";\n ColorWrite[ColorWrite[\"All\"] = 15] = \"All\";\n})(ColorWrite = exports.ColorWrite || (exports.ColorWrite = {}));\nvar ShaderStage;\n(function (ShaderStage) {\n ShaderStage[ShaderStage[\"Vertex\"] = 1] = \"Vertex\";\n ShaderStage[ShaderStage[\"Fragment\"] = 2] = \"Fragment\";\n ShaderStage[ShaderStage[\"Compute\"] = 4] = \"Compute\";\n})(ShaderStage = exports.ShaderStage || (exports.ShaderStage = {}));\nvar TextureUsage;\n(function (TextureUsage) {\n TextureUsage[TextureUsage[\"CopySrc\"] = 1] = \"CopySrc\";\n TextureUsage[TextureUsage[\"CopyDst\"] = 2] = \"CopyDst\";\n TextureUsage[TextureUsage[\"Sampled\"] = 4] = \"Sampled\";\n TextureUsage[TextureUsage[\"Storage\"] = 8] = \"Storage\";\n TextureUsage[TextureUsage[\"OutputAttachment\"] = 16] = \"OutputAttachment\";\n})(TextureUsage = exports.TextureUsage || (exports.TextureUsage = {}));\nvar MapMode;\n(function (MapMode) {\n MapMode[MapMode[\"Read\"] = 1] = \"Read\";\n MapMode[MapMode[\"Write\"] = 2] = \"Write\";\n})(MapMode = exports.MapMode || (exports.MapMode = {}));\n","require('../modules/es6.symbol');\nrequire('../modules/es6.object.create');\nrequire('../modules/es6.object.define-property');\nrequire('../modules/es6.object.define-properties');\nrequire('../modules/es6.object.get-own-property-descriptor');\nrequire('../modules/es6.object.get-prototype-of');\nrequire('../modules/es6.object.keys');\nrequire('../modules/es6.object.get-own-property-names');\nrequire('../modules/es6.object.freeze');\nrequire('../modules/es6.object.seal');\nrequire('../modules/es6.object.prevent-extensions');\nrequire('../modules/es6.object.is-frozen');\nrequire('../modules/es6.object.is-sealed');\nrequire('../modules/es6.object.is-extensible');\nrequire('../modules/es6.object.assign');\nrequire('../modules/es6.object.is');\nrequire('../modules/es6.object.set-prototype-of');\nrequire('../modules/es6.object.to-string');\nrequire('../modules/es6.function.bind');\nrequire('../modules/es6.function.name');\nrequire('../modules/es6.function.has-instance');\nrequire('../modules/es6.parse-int');\nrequire('../modules/es6.parse-float');\nrequire('../modules/es6.number.constructor');\nrequire('../modules/es6.number.to-fixed');\nrequire('../modules/es6.number.to-precision');\nrequire('../modules/es6.number.epsilon');\nrequire('../modules/es6.number.is-finite');\nrequire('../modules/es6.number.is-integer');\nrequire('../modules/es6.number.is-nan');\nrequire('../modules/es6.number.is-safe-integer');\nrequire('../modules/es6.number.max-safe-integer');\nrequire('../modules/es6.number.min-safe-integer');\nrequire('../modules/es6.number.parse-float');\nrequire('../modules/es6.number.parse-int');\nrequire('../modules/es6.math.acosh');\nrequire('../modules/es6.math.asinh');\nrequire('../modules/es6.math.atanh');\nrequire('../modules/es6.math.cbrt');\nrequire('../modules/es6.math.clz32');\nrequire('../modules/es6.math.cosh');\nrequire('../modules/es6.math.expm1');\nrequire('../modules/es6.math.fround');\nrequire('../modules/es6.math.hypot');\nrequire('../modules/es6.math.imul');\nrequire('../modules/es6.math.log10');\nrequire('../modules/es6.math.log1p');\nrequire('../modules/es6.math.log2');\nrequire('../modules/es6.math.sign');\nrequire('../modules/es6.math.sinh');\nrequire('../modules/es6.math.tanh');\nrequire('../modules/es6.math.trunc');\nrequire('../modules/es6.string.from-code-point');\nrequire('../modules/es6.string.raw');\nrequire('../modules/es6.string.trim');\nrequire('../modules/es6.string.iterator');\nrequire('../modules/es6.string.code-point-at');\nrequire('../modules/es6.string.ends-with');\nrequire('../modules/es6.string.includes');\nrequire('../modules/es6.string.repeat');\nrequire('../modules/es6.string.starts-with');\nrequire('../modules/es6.string.anchor');\nrequire('../modules/es6.string.big');\nrequire('../modules/es6.string.blink');\nrequire('../modules/es6.string.bold');\nrequire('../modules/es6.string.fixed');\nrequire('../modules/es6.string.fontcolor');\nrequire('../modules/es6.string.fontsize');\nrequire('../modules/es6.string.italics');\nrequire('../modules/es6.string.link');\nrequire('../modules/es6.string.small');\nrequire('../modules/es6.string.strike');\nrequire('../modules/es6.string.sub');\nrequire('../modules/es6.string.sup');\nrequire('../modules/es6.date.now');\nrequire('../modules/es6.date.to-json');\nrequire('../modules/es6.date.to-iso-string');\nrequire('../modules/es6.date.to-string');\nrequire('../modules/es6.date.to-primitive');\nrequire('../modules/es6.array.is-array');\nrequire('../modules/es6.array.from');\nrequire('../modules/es6.array.of');\nrequire('../modules/es6.array.join');\nrequire('../modules/es6.array.slice');\nrequire('../modules/es6.array.sort');\nrequire('../modules/es6.array.for-each');\nrequire('../modules/es6.array.map');\nrequire('../modules/es6.array.filter');\nrequire('../modules/es6.array.some');\nrequire('../modules/es6.array.every');\nrequire('../modules/es6.array.reduce');\nrequire('../modules/es6.array.reduce-right');\nrequire('../modules/es6.array.index-of');\nrequire('../modules/es6.array.last-index-of');\nrequire('../modules/es6.array.copy-within');\nrequire('../modules/es6.array.fill');\nrequire('../modules/es6.array.find');\nrequire('../modules/es6.array.find-index');\nrequire('../modules/es6.array.species');\nrequire('../modules/es6.array.iterator');\nrequire('../modules/es6.regexp.constructor');\nrequire('../modules/es6.regexp.exec');\nrequire('../modules/es6.regexp.to-string');\nrequire('../modules/es6.regexp.flags');\nrequire('../modules/es6.regexp.match');\nrequire('../modules/es6.regexp.replace');\nrequire('../modules/es6.regexp.search');\nrequire('../modules/es6.regexp.split');\nrequire('../modules/es6.promise');\nrequire('../modules/es6.map');\nrequire('../modules/es6.set');\nrequire('../modules/es6.weak-map');\nrequire('../modules/es6.weak-set');\nrequire('../modules/es6.typed.array-buffer');\nrequire('../modules/es6.typed.data-view');\nrequire('../modules/es6.typed.int8-array');\nrequire('../modules/es6.typed.uint8-array');\nrequire('../modules/es6.typed.uint8-clamped-array');\nrequire('../modules/es6.typed.int16-array');\nrequire('../modules/es6.typed.uint16-array');\nrequire('../modules/es6.typed.int32-array');\nrequire('../modules/es6.typed.uint32-array');\nrequire('../modules/es6.typed.float32-array');\nrequire('../modules/es6.typed.float64-array');\nrequire('../modules/es6.reflect.apply');\nrequire('../modules/es6.reflect.construct');\nrequire('../modules/es6.reflect.define-property');\nrequire('../modules/es6.reflect.delete-property');\nrequire('../modules/es6.reflect.enumerate');\nrequire('../modules/es6.reflect.get');\nrequire('../modules/es6.reflect.get-own-property-descriptor');\nrequire('../modules/es6.reflect.get-prototype-of');\nrequire('../modules/es6.reflect.has');\nrequire('../modules/es6.reflect.is-extensible');\nrequire('../modules/es6.reflect.own-keys');\nrequire('../modules/es6.reflect.prevent-extensions');\nrequire('../modules/es6.reflect.set');\nrequire('../modules/es6.reflect.set-prototype-of');\nmodule.exports = require('../modules/_core');\n","require('../../modules/es7.array.flat-map');\nmodule.exports = require('../../modules/_core').Array.flatMap;\n","require('../../modules/es7.array.includes');\nmodule.exports = require('../../modules/_core').Array.includes;\n","require('../../modules/es7.object.entries');\nmodule.exports = require('../../modules/_core').Object.entries;\n","require('../../modules/es7.object.get-own-property-descriptors');\nmodule.exports = require('../../modules/_core').Object.getOwnPropertyDescriptors;\n","require('../../modules/es7.object.values');\nmodule.exports = require('../../modules/_core').Object.values;\n","'use strict';\nrequire('../../modules/es6.promise');\nrequire('../../modules/es7.promise.finally');\nmodule.exports = require('../../modules/_core').Promise['finally'];\n","require('../../modules/es7.string.pad-end');\nmodule.exports = require('../../modules/_core').String.padEnd;\n","require('../../modules/es7.string.pad-start');\nmodule.exports = require('../../modules/_core').String.padStart;\n","require('../../modules/es7.string.trim-right');\nmodule.exports = require('../../modules/_core').String.trimRight;\n","require('../../modules/es7.string.trim-left');\nmodule.exports = require('../../modules/_core').String.trimLeft;\n","require('../../modules/es7.symbol.async-iterator');\nmodule.exports = require('../../modules/_wks-ext').f('asyncIterator');\n","require('../modules/es7.global');\nmodule.exports = require('../modules/_core').global;\n","module.exports = function (it) {\n if (typeof it != 'function') throw TypeError(it + ' is not a function!');\n return it;\n};\n","var isObject = require('./_is-object');\nmodule.exports = function (it) {\n if (!isObject(it)) throw TypeError(it + ' is not an object!');\n return it;\n};\n","var core = module.exports = { version: '2.6.12' };\nif (typeof __e == 'number') __e = core; // eslint-disable-line no-undef\n","// optional / simple context binding\nvar aFunction = require('./_a-function');\nmodule.exports = function (fn, that, length) {\n aFunction(fn);\n if (that === undefined) return fn;\n switch (length) {\n case 1: return function (a) {\n return fn.call(that, a);\n };\n case 2: return function (a, b) {\n return fn.call(that, a, b);\n };\n case 3: return function (a, b, c) {\n return fn.call(that, a, b, c);\n };\n }\n return function (/* ...args */) {\n return fn.apply(that, arguments);\n };\n};\n","// Thank's IE8 for his funny defineProperty\nmodule.exports = !require('./_fails')(function () {\n return Object.defineProperty({}, 'a', { get: function () { return 7; } }).a != 7;\n});\n","var isObject = require('./_is-object');\nvar document = require('./_global').document;\n// typeof document.createElement is 'object' in old IE\nvar is = isObject(document) && isObject(document.createElement);\nmodule.exports = function (it) {\n return is ? document.createElement(it) : {};\n};\n","var global = require('./_global');\nvar core = require('./_core');\nvar ctx = require('./_ctx');\nvar hide = require('./_hide');\nvar has = require('./_has');\nvar PROTOTYPE = 'prototype';\n\nvar $export = function (type, name, source) {\n var IS_FORCED = type & $export.F;\n var IS_GLOBAL = type & $export.G;\n var IS_STATIC = type & $export.S;\n var IS_PROTO = type & $export.P;\n var IS_BIND = type & $export.B;\n var IS_WRAP = type & $export.W;\n var exports = IS_GLOBAL ? core : core[name] || (core[name] = {});\n var expProto = exports[PROTOTYPE];\n var target = IS_GLOBAL ? global : IS_STATIC ? global[name] : (global[name] || {})[PROTOTYPE];\n var key, own, out;\n if (IS_GLOBAL) source = name;\n for (key in source) {\n // contains in native\n own = !IS_FORCED && target && target[key] !== undefined;\n if (own && has(exports, key)) continue;\n // export native or passed\n out = own ? target[key] : source[key];\n // prevent global pollution for namespaces\n exports[key] = IS_GLOBAL && typeof target[key] != 'function' ? source[key]\n // bind timers to global for call from export context\n : IS_BIND && own ? ctx(out, global)\n // wrap global constructors for prevent change them in library\n : IS_WRAP && target[key] == out ? (function (C) {\n var F = function (a, b, c) {\n if (this instanceof C) {\n switch (arguments.length) {\n case 0: return new C();\n case 1: return new C(a);\n case 2: return new C(a, b);\n } return new C(a, b, c);\n } return C.apply(this, arguments);\n };\n F[PROTOTYPE] = C[PROTOTYPE];\n return F;\n // make static versions for prototype methods\n })(out) : IS_PROTO && typeof out == 'function' ? ctx(Function.call, out) : out;\n // export proto methods to core.%CONSTRUCTOR%.methods.%NAME%\n if (IS_PROTO) {\n (exports.virtual || (exports.virtual = {}))[key] = out;\n // export proto methods to core.%CONSTRUCTOR%.prototype.%NAME%\n if (type & $export.R && expProto && !expProto[key]) hide(expProto, key, out);\n }\n }\n};\n// type bitmap\n$export.F = 1; // forced\n$export.G = 2; // global\n$export.S = 4; // static\n$export.P = 8; // proto\n$export.B = 16; // bind\n$export.W = 32; // wrap\n$export.U = 64; // safe\n$export.R = 128; // real proto method for `library`\nmodule.exports = $export;\n","module.exports = function (exec) {\n try {\n return !!exec();\n } catch (e) {\n return true;\n }\n};\n","// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nvar global = module.exports = typeof window != 'undefined' && window.Math == Math\n ? window : typeof self != 'undefined' && self.Math == Math ? self\n // eslint-disable-next-line no-new-func\n : Function('return this')();\nif (typeof __g == 'number') __g = global; // eslint-disable-line no-undef\n","var hasOwnProperty = {}.hasOwnProperty;\nmodule.exports = function (it, key) {\n return hasOwnProperty.call(it, key);\n};\n","var dP = require('./_object-dp');\nvar createDesc = require('./_property-desc');\nmodule.exports = require('./_descriptors') ? function (object, key, value) {\n return dP.f(object, key, createDesc(1, value));\n} : function (object, key, value) {\n object[key] = value;\n return object;\n};\n","module.exports = !require('./_descriptors') && !require('./_fails')(function () {\n return Object.defineProperty(require('./_dom-create')('div'), 'a', { get: function () { return 7; } }).a != 7;\n});\n","module.exports = function (it) {\n return typeof it === 'object' ? it !== null : typeof it === 'function';\n};\n","var anObject = require('./_an-object');\nvar IE8_DOM_DEFINE = require('./_ie8-dom-define');\nvar toPrimitive = require('./_to-primitive');\nvar dP = Object.defineProperty;\n\nexports.f = require('./_descriptors') ? Object.defineProperty : function defineProperty(O, P, Attributes) {\n anObject(O);\n P = toPrimitive(P, true);\n anObject(Attributes);\n if (IE8_DOM_DEFINE) try {\n return dP(O, P, Attributes);\n } catch (e) { /* empty */ }\n if ('get' in Attributes || 'set' in Attributes) throw TypeError('Accessors not supported!');\n if ('value' in Attributes) O[P] = Attributes.value;\n return O;\n};\n","module.exports = function (bitmap, value) {\n return {\n enumerable: !(bitmap & 1),\n configurable: !(bitmap & 2),\n writable: !(bitmap & 4),\n value: value\n };\n};\n","// 7.1.1 ToPrimitive(input [, PreferredType])\nvar isObject = require('./_is-object');\n// instead of the ES6 spec version, we didn't implement @@toPrimitive case\n// and the second argument - flag - preferred type is a string\nmodule.exports = function (it, S) {\n if (!isObject(it)) return it;\n var fn, val;\n if (S && typeof (fn = it.toString) == 'function' && !isObject(val = fn.call(it))) return val;\n if (typeof (fn = it.valueOf) == 'function' && !isObject(val = fn.call(it))) return val;\n if (!S && typeof (fn = it.toString) == 'function' && !isObject(val = fn.call(it))) return val;\n throw TypeError(\"Can't convert object to primitive value\");\n};\n","// https://github.com/tc39/proposal-global\nvar $export = require('./_export');\n\n$export($export.G, { global: require('./_global') });\n","module.exports = function (it) {\n if (typeof it != 'function') throw TypeError(it + ' is not a function!');\n return it;\n};\n","var cof = require('./_cof');\nmodule.exports = function (it, msg) {\n if (typeof it != 'number' && cof(it) != 'Number') throw TypeError(msg);\n return +it;\n};\n","// 22.1.3.31 Array.prototype[@@unscopables]\nvar UNSCOPABLES = require('./_wks')('unscopables');\nvar ArrayProto = Array.prototype;\nif (ArrayProto[UNSCOPABLES] == undefined) require('./_hide')(ArrayProto, UNSCOPABLES, {});\nmodule.exports = function (key) {\n ArrayProto[UNSCOPABLES][key] = true;\n};\n","'use strict';\nvar at = require('./_string-at')(true);\n\n // `AdvanceStringIndex` abstract operation\n// https://tc39.github.io/ecma262/#sec-advancestringindex\nmodule.exports = function (S, index, unicode) {\n return index + (unicode ? at(S, index).length : 1);\n};\n","module.exports = function (it, Constructor, name, forbiddenField) {\n if (!(it instanceof Constructor) || (forbiddenField !== undefined && forbiddenField in it)) {\n throw TypeError(name + ': incorrect invocation!');\n } return it;\n};\n","var isObject = require('./_is-object');\nmodule.exports = function (it) {\n if (!isObject(it)) throw TypeError(it + ' is not an object!');\n return it;\n};\n","// 22.1.3.3 Array.prototype.copyWithin(target, start, end = this.length)\n'use strict';\nvar toObject = require('./_to-object');\nvar toAbsoluteIndex = require('./_to-absolute-index');\nvar toLength = require('./_to-length');\n\nmodule.exports = [].copyWithin || function copyWithin(target /* = 0 */, start /* = 0, end = @length */) {\n var O = toObject(this);\n var len = toLength(O.length);\n var to = toAbsoluteIndex(target, len);\n var from = toAbsoluteIndex(start, len);\n var end = arguments.length > 2 ? arguments[2] : undefined;\n var count = Math.min((end === undefined ? len : toAbsoluteIndex(end, len)) - from, len - to);\n var inc = 1;\n if (from < to && to < from + count) {\n inc = -1;\n from += count - 1;\n to += count - 1;\n }\n while (count-- > 0) {\n if (from in O) O[to] = O[from];\n else delete O[to];\n to += inc;\n from += inc;\n } return O;\n};\n","// 22.1.3.6 Array.prototype.fill(value, start = 0, end = this.length)\n'use strict';\nvar toObject = require('./_to-object');\nvar toAbsoluteIndex = require('./_to-absolute-index');\nvar toLength = require('./_to-length');\nmodule.exports = function fill(value /* , start = 0, end = @length */) {\n var O = toObject(this);\n var length = toLength(O.length);\n var aLen = arguments.length;\n var index = toAbsoluteIndex(aLen > 1 ? arguments[1] : undefined, length);\n var end = aLen > 2 ? arguments[2] : undefined;\n var endPos = end === undefined ? length : toAbsoluteIndex(end, length);\n while (endPos > index) O[index++] = value;\n return O;\n};\n","// false -> Array#indexOf\n// true -> Array#includes\nvar toIObject = require('./_to-iobject');\nvar toLength = require('./_to-length');\nvar toAbsoluteIndex = require('./_to-absolute-index');\nmodule.exports = function (IS_INCLUDES) {\n return function ($this, el, fromIndex) {\n var O = toIObject($this);\n var length = toLength(O.length);\n var index = toAbsoluteIndex(fromIndex, length);\n var value;\n // Array#includes uses SameValueZero equality algorithm\n // eslint-disable-next-line no-self-compare\n if (IS_INCLUDES && el != el) while (length > index) {\n value = O[index++];\n // eslint-disable-next-line no-self-compare\n if (value != value) return true;\n // Array#indexOf ignores holes, Array#includes - not\n } else for (;length > index; index++) if (IS_INCLUDES || index in O) {\n if (O[index] === el) return IS_INCLUDES || index || 0;\n } return !IS_INCLUDES && -1;\n };\n};\n","// 0 -> Array#forEach\n// 1 -> Array#map\n// 2 -> Array#filter\n// 3 -> Array#some\n// 4 -> Array#every\n// 5 -> Array#find\n// 6 -> Array#findIndex\nvar ctx = require('./_ctx');\nvar IObject = require('./_iobject');\nvar toObject = require('./_to-object');\nvar toLength = require('./_to-length');\nvar asc = require('./_array-species-create');\nmodule.exports = function (TYPE, $create) {\n var IS_MAP = TYPE == 1;\n var IS_FILTER = TYPE == 2;\n var IS_SOME = TYPE == 3;\n var IS_EVERY = TYPE == 4;\n var IS_FIND_INDEX = TYPE == 6;\n var NO_HOLES = TYPE == 5 || IS_FIND_INDEX;\n var create = $create || asc;\n return function ($this, callbackfn, that) {\n var O = toObject($this);\n var self = IObject(O);\n var f = ctx(callbackfn, that, 3);\n var length = toLength(self.length);\n var index = 0;\n var result = IS_MAP ? create($this, length) : IS_FILTER ? create($this, 0) : undefined;\n var val, res;\n for (;length > index; index++) if (NO_HOLES || index in self) {\n val = self[index];\n res = f(val, index, O);\n if (TYPE) {\n if (IS_MAP) result[index] = res; // map\n else if (res) switch (TYPE) {\n case 3: return true; // some\n case 5: return val; // find\n case 6: return index; // findIndex\n case 2: result.push(val); // filter\n } else if (IS_EVERY) return false; // every\n }\n }\n return IS_FIND_INDEX ? -1 : IS_SOME || IS_EVERY ? IS_EVERY : result;\n };\n};\n","var aFunction = require('./_a-function');\nvar toObject = require('./_to-object');\nvar IObject = require('./_iobject');\nvar toLength = require('./_to-length');\n\nmodule.exports = function (that, callbackfn, aLen, memo, isRight) {\n aFunction(callbackfn);\n var O = toObject(that);\n var self = IObject(O);\n var length = toLength(O.length);\n var index = isRight ? length - 1 : 0;\n var i = isRight ? -1 : 1;\n if (aLen < 2) for (;;) {\n if (index in self) {\n memo = self[index];\n index += i;\n break;\n }\n index += i;\n if (isRight ? index < 0 : length <= index) {\n throw TypeError('Reduce of empty array with no initial value');\n }\n }\n for (;isRight ? index >= 0 : length > index; index += i) if (index in self) {\n memo = callbackfn(memo, self[index], index, O);\n }\n return memo;\n};\n","var isObject = require('./_is-object');\nvar isArray = require('./_is-array');\nvar SPECIES = require('./_wks')('species');\n\nmodule.exports = function (original) {\n var C;\n if (isArray(original)) {\n C = original.constructor;\n // cross-realm fallback\n if (typeof C == 'function' && (C === Array || isArray(C.prototype))) C = undefined;\n if (isObject(C)) {\n C = C[SPECIES];\n if (C === null) C = undefined;\n }\n } return C === undefined ? Array : C;\n};\n","// 9.4.2.3 ArraySpeciesCreate(originalArray, length)\nvar speciesConstructor = require('./_array-species-constructor');\n\nmodule.exports = function (original, length) {\n return new (speciesConstructor(original))(length);\n};\n","'use strict';\nvar aFunction = require('./_a-function');\nvar isObject = require('./_is-object');\nvar invoke = require('./_invoke');\nvar arraySlice = [].slice;\nvar factories = {};\n\nvar construct = function (F, len, args) {\n if (!(len in factories)) {\n for (var n = [], i = 0; i < len; i++) n[i] = 'a[' + i + ']';\n // eslint-disable-next-line no-new-func\n factories[len] = Function('F,a', 'return new F(' + n.join(',') + ')');\n } return factories[len](F, args);\n};\n\nmodule.exports = Function.bind || function bind(that /* , ...args */) {\n var fn = aFunction(this);\n var partArgs = arraySlice.call(arguments, 1);\n var bound = function (/* args... */) {\n var args = partArgs.concat(arraySlice.call(arguments));\n return this instanceof bound ? construct(fn, args.length, args) : invoke(fn, args, that);\n };\n if (isObject(fn.prototype)) bound.prototype = fn.prototype;\n return bound;\n};\n","// getting tag from 19.1.3.6 Object.prototype.toString()\nvar cof = require('./_cof');\nvar TAG = require('./_wks')('toStringTag');\n// ES3 wrong here\nvar ARG = cof(function () { return arguments; }()) == 'Arguments';\n\n// fallback for IE11 Script Access Denied error\nvar tryGet = function (it, key) {\n try {\n return it[key];\n } catch (e) { /* empty */ }\n};\n\nmodule.exports = function (it) {\n var O, T, B;\n return it === undefined ? 'Undefined' : it === null ? 'Null'\n // @@toStringTag case\n : typeof (T = tryGet(O = Object(it), TAG)) == 'string' ? T\n // builtinTag case\n : ARG ? cof(O)\n // ES3 arguments fallback\n : (B = cof(O)) == 'Object' && typeof O.callee == 'function' ? 'Arguments' : B;\n};\n","var toString = {}.toString;\n\nmodule.exports = function (it) {\n return toString.call(it).slice(8, -1);\n};\n","'use strict';\nvar dP = require('./_object-dp').f;\nvar create = require('./_object-create');\nvar redefineAll = require('./_redefine-all');\nvar ctx = require('./_ctx');\nvar anInstance = require('./_an-instance');\nvar forOf = require('./_for-of');\nvar $iterDefine = require('./_iter-define');\nvar step = require('./_iter-step');\nvar setSpecies = require('./_set-species');\nvar DESCRIPTORS = require('./_descriptors');\nvar fastKey = require('./_meta').fastKey;\nvar validate = require('./_validate-collection');\nvar SIZE = DESCRIPTORS ? '_s' : 'size';\n\nvar getEntry = function (that, key) {\n // fast case\n var index = fastKey(key);\n var entry;\n if (index !== 'F') return that._i[index];\n // frozen object case\n for (entry = that._f; entry; entry = entry.n) {\n if (entry.k == key) return entry;\n }\n};\n\nmodule.exports = {\n getConstructor: function (wrapper, NAME, IS_MAP, ADDER) {\n var C = wrapper(function (that, iterable) {\n anInstance(that, C, NAME, '_i');\n that._t = NAME; // collection type\n that._i = create(null); // index\n that._f = undefined; // first entry\n that._l = undefined; // last entry\n that[SIZE] = 0; // size\n if (iterable != undefined) forOf(iterable, IS_MAP, that[ADDER], that);\n });\n redefineAll(C.prototype, {\n // 23.1.3.1 Map.prototype.clear()\n // 23.2.3.2 Set.prototype.clear()\n clear: function clear() {\n for (var that = validate(this, NAME), data = that._i, entry = that._f; entry; entry = entry.n) {\n entry.r = true;\n if (entry.p) entry.p = entry.p.n = undefined;\n delete data[entry.i];\n }\n that._f = that._l = undefined;\n that[SIZE] = 0;\n },\n // 23.1.3.3 Map.prototype.delete(key)\n // 23.2.3.4 Set.prototype.delete(value)\n 'delete': function (key) {\n var that = validate(this, NAME);\n var entry = getEntry(that, key);\n if (entry) {\n var next = entry.n;\n var prev = entry.p;\n delete that._i[entry.i];\n entry.r = true;\n if (prev) prev.n = next;\n if (next) next.p = prev;\n if (that._f == entry) that._f = next;\n if (that._l == entry) that._l = prev;\n that[SIZE]--;\n } return !!entry;\n },\n // 23.2.3.6 Set.prototype.forEach(callbackfn, thisArg = undefined)\n // 23.1.3.5 Map.prototype.forEach(callbackfn, thisArg = undefined)\n forEach: function forEach(callbackfn /* , that = undefined */) {\n validate(this, NAME);\n var f = ctx(callbackfn, arguments.length > 1 ? arguments[1] : undefined, 3);\n var entry;\n while (entry = entry ? entry.n : this._f) {\n f(entry.v, entry.k, this);\n // revert to the last existing entry\n while (entry && entry.r) entry = entry.p;\n }\n },\n // 23.1.3.7 Map.prototype.has(key)\n // 23.2.3.7 Set.prototype.has(value)\n has: function has(key) {\n return !!getEntry(validate(this, NAME), key);\n }\n });\n if (DESCRIPTORS) dP(C.prototype, 'size', {\n get: function () {\n return validate(this, NAME)[SIZE];\n }\n });\n return C;\n },\n def: function (that, key, value) {\n var entry = getEntry(that, key);\n var prev, index;\n // change existing entry\n if (entry) {\n entry.v = value;\n // create new entry\n } else {\n that._l = entry = {\n i: index = fastKey(key, true), // <- index\n k: key, // <- key\n v: value, // <- value\n p: prev = that._l, // <- previous entry\n n: undefined, // <- next entry\n r: false // <- removed\n };\n if (!that._f) that._f = entry;\n if (prev) prev.n = entry;\n that[SIZE]++;\n // add to index\n if (index !== 'F') that._i[index] = entry;\n } return that;\n },\n getEntry: getEntry,\n setStrong: function (C, NAME, IS_MAP) {\n // add .keys, .values, .entries, [@@iterator]\n // 23.1.3.4, 23.1.3.8, 23.1.3.11, 23.1.3.12, 23.2.3.5, 23.2.3.8, 23.2.3.10, 23.2.3.11\n $iterDefine(C, NAME, function (iterated, kind) {\n this._t = validate(iterated, NAME); // target\n this._k = kind; // kind\n this._l = undefined; // previous\n }, function () {\n var that = this;\n var kind = that._k;\n var entry = that._l;\n // revert to the last existing entry\n while (entry && entry.r) entry = entry.p;\n // get next entry\n if (!that._t || !(that._l = entry = entry ? entry.n : that._t._f)) {\n // or finish the iteration\n that._t = undefined;\n return step(1);\n }\n // return step by kind\n if (kind == 'keys') return step(0, entry.k);\n if (kind == 'values') return step(0, entry.v);\n return step(0, [entry.k, entry.v]);\n }, IS_MAP ? 'entries' : 'values', !IS_MAP, true);\n\n // add [@@species], 23.1.2.2, 23.2.2.2\n setSpecies(NAME);\n }\n};\n","'use strict';\nvar redefineAll = require('./_redefine-all');\nvar getWeak = require('./_meta').getWeak;\nvar anObject = require('./_an-object');\nvar isObject = require('./_is-object');\nvar anInstance = require('./_an-instance');\nvar forOf = require('./_for-of');\nvar createArrayMethod = require('./_array-methods');\nvar $has = require('./_has');\nvar validate = require('./_validate-collection');\nvar arrayFind = createArrayMethod(5);\nvar arrayFindIndex = createArrayMethod(6);\nvar id = 0;\n\n// fallback for uncaught frozen keys\nvar uncaughtFrozenStore = function (that) {\n return that._l || (that._l = new UncaughtFrozenStore());\n};\nvar UncaughtFrozenStore = function () {\n this.a = [];\n};\nvar findUncaughtFrozen = function (store, key) {\n return arrayFind(store.a, function (it) {\n return it[0] === key;\n });\n};\nUncaughtFrozenStore.prototype = {\n get: function (key) {\n var entry = findUncaughtFrozen(this, key);\n if (entry) return entry[1];\n },\n has: function (key) {\n return !!findUncaughtFrozen(this, key);\n },\n set: function (key, value) {\n var entry = findUncaughtFrozen(this, key);\n if (entry) entry[1] = value;\n else this.a.push([key, value]);\n },\n 'delete': function (key) {\n var index = arrayFindIndex(this.a, function (it) {\n return it[0] === key;\n });\n if (~index) this.a.splice(index, 1);\n return !!~index;\n }\n};\n\nmodule.exports = {\n getConstructor: function (wrapper, NAME, IS_MAP, ADDER) {\n var C = wrapper(function (that, iterable) {\n anInstance(that, C, NAME, '_i');\n that._t = NAME; // collection type\n that._i = id++; // collection id\n that._l = undefined; // leak store for uncaught frozen objects\n if (iterable != undefined) forOf(iterable, IS_MAP, that[ADDER], that);\n });\n redefineAll(C.prototype, {\n // 23.3.3.2 WeakMap.prototype.delete(key)\n // 23.4.3.3 WeakSet.prototype.delete(value)\n 'delete': function (key) {\n if (!isObject(key)) return false;\n var data = getWeak(key);\n if (data === true) return uncaughtFrozenStore(validate(this, NAME))['delete'](key);\n return data && $has(data, this._i) && delete data[this._i];\n },\n // 23.3.3.4 WeakMap.prototype.has(key)\n // 23.4.3.4 WeakSet.prototype.has(value)\n has: function has(key) {\n if (!isObject(key)) return false;\n var data = getWeak(key);\n if (data === true) return uncaughtFrozenStore(validate(this, NAME)).has(key);\n return data && $has(data, this._i);\n }\n });\n return C;\n },\n def: function (that, key, value) {\n var data = getWeak(anObject(key), true);\n if (data === true) uncaughtFrozenStore(that).set(key, value);\n else data[that._i] = value;\n return that;\n },\n ufstore: uncaughtFrozenStore\n};\n","'use strict';\nvar global = require('./_global');\nvar $export = require('./_export');\nvar redefine = require('./_redefine');\nvar redefineAll = require('./_redefine-all');\nvar meta = require('./_meta');\nvar forOf = require('./_for-of');\nvar anInstance = require('./_an-instance');\nvar isObject = require('./_is-object');\nvar fails = require('./_fails');\nvar $iterDetect = require('./_iter-detect');\nvar setToStringTag = require('./_set-to-string-tag');\nvar inheritIfRequired = require('./_inherit-if-required');\n\nmodule.exports = function (NAME, wrapper, methods, common, IS_MAP, IS_WEAK) {\n var Base = global[NAME];\n var C = Base;\n var ADDER = IS_MAP ? 'set' : 'add';\n var proto = C && C.prototype;\n var O = {};\n var fixMethod = function (KEY) {\n var fn = proto[KEY];\n redefine(proto, KEY,\n KEY == 'delete' ? function (a) {\n return IS_WEAK && !isObject(a) ? false : fn.call(this, a === 0 ? 0 : a);\n } : KEY == 'has' ? function has(a) {\n return IS_WEAK && !isObject(a) ? false : fn.call(this, a === 0 ? 0 : a);\n } : KEY == 'get' ? function get(a) {\n return IS_WEAK && !isObject(a) ? undefined : fn.call(this, a === 0 ? 0 : a);\n } : KEY == 'add' ? function add(a) { fn.call(this, a === 0 ? 0 : a); return this; }\n : function set(a, b) { fn.call(this, a === 0 ? 0 : a, b); return this; }\n );\n };\n if (typeof C != 'function' || !(IS_WEAK || proto.forEach && !fails(function () {\n new C().entries().next();\n }))) {\n // create collection constructor\n C = common.getConstructor(wrapper, NAME, IS_MAP, ADDER);\n redefineAll(C.prototype, methods);\n meta.NEED = true;\n } else {\n var instance = new C();\n // early implementations not supports chaining\n var HASNT_CHAINING = instance[ADDER](IS_WEAK ? {} : -0, 1) != instance;\n // V8 ~ Chromium 40- weak-collections throws on primitives, but should return false\n var THROWS_ON_PRIMITIVES = fails(function () { instance.has(1); });\n // most early implementations doesn't supports iterables, most modern - not close it correctly\n var ACCEPT_ITERABLES = $iterDetect(function (iter) { new C(iter); }); // eslint-disable-line no-new\n // for early implementations -0 and +0 not the same\n var BUGGY_ZERO = !IS_WEAK && fails(function () {\n // V8 ~ Chromium 42- fails only with 5+ elements\n var $instance = new C();\n var index = 5;\n while (index--) $instance[ADDER](index, index);\n return !$instance.has(-0);\n });\n if (!ACCEPT_ITERABLES) {\n C = wrapper(function (target, iterable) {\n anInstance(target, C, NAME);\n var that = inheritIfRequired(new Base(), target, C);\n if (iterable != undefined) forOf(iterable, IS_MAP, that[ADDER], that);\n return that;\n });\n C.prototype = proto;\n proto.constructor = C;\n }\n if (THROWS_ON_PRIMITIVES || BUGGY_ZERO) {\n fixMethod('delete');\n fixMethod('has');\n IS_MAP && fixMethod('get');\n }\n if (BUGGY_ZERO || HASNT_CHAINING) fixMethod(ADDER);\n // weak collections should not contains .clear method\n if (IS_WEAK && proto.clear) delete proto.clear;\n }\n\n setToStringTag(C, NAME);\n\n O[NAME] = C;\n $export($export.G + $export.W + $export.F * (C != Base), O);\n\n if (!IS_WEAK) common.setStrong(C, NAME, IS_MAP);\n\n return C;\n};\n","var core = module.exports = { version: '2.6.12' };\nif (typeof __e == 'number') __e = core; // eslint-disable-line no-undef\n","'use strict';\nvar $defineProperty = require('./_object-dp');\nvar createDesc = require('./_property-desc');\n\nmodule.exports = function (object, index, value) {\n if (index in object) $defineProperty.f(object, index, createDesc(0, value));\n else object[index] = value;\n};\n","// optional / simple context binding\nvar aFunction = require('./_a-function');\nmodule.exports = function (fn, that, length) {\n aFunction(fn);\n if (that === undefined) return fn;\n switch (length) {\n case 1: return function (a) {\n return fn.call(that, a);\n };\n case 2: return function (a, b) {\n return fn.call(that, a, b);\n };\n case 3: return function (a, b, c) {\n return fn.call(that, a, b, c);\n };\n }\n return function (/* ...args */) {\n return fn.apply(that, arguments);\n };\n};\n","'use strict';\n// 20.3.4.36 / 15.9.5.43 Date.prototype.toISOString()\nvar fails = require('./_fails');\nvar getTime = Date.prototype.getTime;\nvar $toISOString = Date.prototype.toISOString;\n\nvar lz = function (num) {\n return num > 9 ? num : '0' + num;\n};\n\n// PhantomJS / old WebKit has a broken implementations\nmodule.exports = (fails(function () {\n return $toISOString.call(new Date(-5e13 - 1)) != '0385-07-25T07:06:39.999Z';\n}) || !fails(function () {\n $toISOString.call(new Date(NaN));\n})) ? function toISOString() {\n if (!isFinite(getTime.call(this))) throw RangeError('Invalid time value');\n var d = this;\n var y = d.getUTCFullYear();\n var m = d.getUTCMilliseconds();\n var s = y < 0 ? '-' : y > 9999 ? '+' : '';\n return s + ('00000' + Math.abs(y)).slice(s ? -6 : -4) +\n '-' + lz(d.getUTCMonth() + 1) + '-' + lz(d.getUTCDate()) +\n 'T' + lz(d.getUTCHours()) + ':' + lz(d.getUTCMinutes()) +\n ':' + lz(d.getUTCSeconds()) + '.' + (m > 99 ? m : '0' + lz(m)) + 'Z';\n} : $toISOString;\n","'use strict';\nvar anObject = require('./_an-object');\nvar toPrimitive = require('./_to-primitive');\nvar NUMBER = 'number';\n\nmodule.exports = function (hint) {\n if (hint !== 'string' && hint !== NUMBER && hint !== 'default') throw TypeError('Incorrect hint');\n return toPrimitive(anObject(this), hint != NUMBER);\n};\n","// 7.2.1 RequireObjectCoercible(argument)\nmodule.exports = function (it) {\n if (it == undefined) throw TypeError(\"Can't call method on \" + it);\n return it;\n};\n","// Thank's IE8 for his funny defineProperty\nmodule.exports = !require('./_fails')(function () {\n return Object.defineProperty({}, 'a', { get: function () { return 7; } }).a != 7;\n});\n","var isObject = require('./_is-object');\nvar document = require('./_global').document;\n// typeof document.createElement is 'object' in old IE\nvar is = isObject(document) && isObject(document.createElement);\nmodule.exports = function (it) {\n return is ? document.createElement(it) : {};\n};\n","// IE 8- don't enum bug keys\nmodule.exports = (\n 'constructor,hasOwnProperty,isPrototypeOf,propertyIsEnumerable,toLocaleString,toString,valueOf'\n).split(',');\n","// all enumerable object keys, includes symbols\nvar getKeys = require('./_object-keys');\nvar gOPS = require('./_object-gops');\nvar pIE = require('./_object-pie');\nmodule.exports = function (it) {\n var result = getKeys(it);\n var getSymbols = gOPS.f;\n if (getSymbols) {\n var symbols = getSymbols(it);\n var isEnum = pIE.f;\n var i = 0;\n var key;\n while (symbols.length > i) if (isEnum.call(it, key = symbols[i++])) result.push(key);\n } return result;\n};\n","var global = require('./_global');\nvar core = require('./_core');\nvar hide = require('./_hide');\nvar redefine = require('./_redefine');\nvar ctx = require('./_ctx');\nvar PROTOTYPE = 'prototype';\n\nvar $export = function (type, name, source) {\n var IS_FORCED = type & $export.F;\n var IS_GLOBAL = type & $export.G;\n var IS_STATIC = type & $export.S;\n var IS_PROTO = type & $export.P;\n var IS_BIND = type & $export.B;\n var target = IS_GLOBAL ? global : IS_STATIC ? global[name] || (global[name] = {}) : (global[name] || {})[PROTOTYPE];\n var exports = IS_GLOBAL ? core : core[name] || (core[name] = {});\n var expProto = exports[PROTOTYPE] || (exports[PROTOTYPE] = {});\n var key, own, out, exp;\n if (IS_GLOBAL) source = name;\n for (key in source) {\n // contains in native\n own = !IS_FORCED && target && target[key] !== undefined;\n // export native or passed\n out = (own ? target : source)[key];\n // bind timers to global for call from export context\n exp = IS_BIND && own ? ctx(out, global) : IS_PROTO && typeof out == 'function' ? ctx(Function.call, out) : out;\n // extend global\n if (target) redefine(target, key, out, type & $export.U);\n // export\n if (exports[key] != out) hide(exports, key, exp);\n if (IS_PROTO && expProto[key] != out) expProto[key] = out;\n }\n};\nglobal.core = core;\n// type bitmap\n$export.F = 1; // forced\n$export.G = 2; // global\n$export.S = 4; // static\n$export.P = 8; // proto\n$export.B = 16; // bind\n$export.W = 32; // wrap\n$export.U = 64; // safe\n$export.R = 128; // real proto method for `library`\nmodule.exports = $export;\n","var MATCH = require('./_wks')('match');\nmodule.exports = function (KEY) {\n var re = /./;\n try {\n '/./'[KEY](re);\n } catch (e) {\n try {\n re[MATCH] = false;\n return !'/./'[KEY](re);\n } catch (f) { /* empty */ }\n } return true;\n};\n","module.exports = function (exec) {\n try {\n return !!exec();\n } catch (e) {\n return true;\n }\n};\n","'use strict';\nrequire('./es6.regexp.exec');\nvar redefine = require('./_redefine');\nvar hide = require('./_hide');\nvar fails = require('./_fails');\nvar defined = require('./_defined');\nvar wks = require('./_wks');\nvar regexpExec = require('./_regexp-exec');\n\nvar SPECIES = wks('species');\n\nvar REPLACE_SUPPORTS_NAMED_GROUPS = !fails(function () {\n // #replace needs built-in support for named groups.\n // #match works fine because it just return the exec results, even if it has\n // a \"grops\" property.\n var re = /./;\n re.exec = function () {\n var result = [];\n result.groups = { a: '7' };\n return result;\n };\n return ''.replace(re, '$<a>') !== '7';\n});\n\nvar SPLIT_WORKS_WITH_OVERWRITTEN_EXEC = (function () {\n // Chrome 51 has a buggy \"split\" implementation when RegExp#exec !== nativeExec\n var re = /(?:)/;\n var originalExec = re.exec;\n re.exec = function () { return originalExec.apply(this, arguments); };\n var result = 'ab'.split(re);\n return result.length === 2 && result[0] === 'a' && result[1] === 'b';\n})();\n\nmodule.exports = function (KEY, length, exec) {\n var SYMBOL = wks(KEY);\n\n var DELEGATES_TO_SYMBOL = !fails(function () {\n // String methods call symbol-named RegEp methods\n var O = {};\n O[SYMBOL] = function () { return 7; };\n return ''[KEY](O) != 7;\n });\n\n var DELEGATES_TO_EXEC = DELEGATES_TO_SYMBOL ? !fails(function () {\n // Symbol-named RegExp methods call .exec\n var execCalled = false;\n var re = /a/;\n re.exec = function () { execCalled = true; return null; };\n if (KEY === 'split') {\n // RegExp[@@split] doesn't call the regex's exec method, but first creates\n // a new one. We need to return the patched regex when creating the new one.\n re.constructor = {};\n re.constructor[SPECIES] = function () { return re; };\n }\n re[SYMBOL]('');\n return !execCalled;\n }) : undefined;\n\n if (\n !DELEGATES_TO_SYMBOL ||\n !DELEGATES_TO_EXEC ||\n (KEY === 'replace' && !REPLACE_SUPPORTS_NAMED_GROUPS) ||\n (KEY === 'split' && !SPLIT_WORKS_WITH_OVERWRITTEN_EXEC)\n ) {\n var nativeRegExpMethod = /./[SYMBOL];\n var fns = exec(\n defined,\n SYMBOL,\n ''[KEY],\n function maybeCallNative(nativeMethod, regexp, str, arg2, forceStringMethod) {\n if (regexp.exec === regexpExec) {\n if (DELEGATES_TO_SYMBOL && !forceStringMethod) {\n // The native String method already delegates to @@method (this\n // polyfilled function), leasing to infinite recursion.\n // We avoid it by directly calling the native @@method method.\n return { done: true, value: nativeRegExpMethod.call(regexp, str, arg2) };\n }\n return { done: true, value: nativeMethod.call(str, regexp, arg2) };\n }\n return { done: false };\n }\n );\n var strfn = fns[0];\n var rxfn = fns[1];\n\n redefine(String.prototype, KEY, strfn);\n hide(RegExp.prototype, SYMBOL, length == 2\n // 21.2.5.8 RegExp.prototype[@@replace](string, replaceValue)\n // 21.2.5.11 RegExp.prototype[@@split](string, limit)\n ? function (string, arg) { return rxfn.call(string, this, arg); }\n // 21.2.5.6 RegExp.prototype[@@match](string)\n // 21.2.5.9 RegExp.prototype[@@search](string)\n : function (string) { return rxfn.call(string, this); }\n );\n }\n};\n","'use strict';\n// 21.2.5.3 get RegExp.prototype.flags\nvar anObject = require('./_an-object');\nmodule.exports = function () {\n var that = anObject(this);\n var result = '';\n if (that.global) result += 'g';\n if (that.ignoreCase) result += 'i';\n if (that.multiline) result += 'm';\n if (that.unicode) result += 'u';\n if (that.sticky) result += 'y';\n return result;\n};\n","'use strict';\n// https://tc39.github.io/proposal-flatMap/#sec-FlattenIntoArray\nvar isArray = require('./_is-array');\nvar isObject = require('./_is-object');\nvar toLength = require('./_to-length');\nvar ctx = require('./_ctx');\nvar IS_CONCAT_SPREADABLE = require('./_wks')('isConcatSpreadable');\n\nfunction flattenIntoArray(target, original, source, sourceLen, start, depth, mapper, thisArg) {\n var targetIndex = start;\n var sourceIndex = 0;\n var mapFn = mapper ? ctx(mapper, thisArg, 3) : false;\n var element, spreadable;\n\n while (sourceIndex < sourceLen) {\n if (sourceIndex in source) {\n element = mapFn ? mapFn(source[sourceIndex], sourceIndex, original) : source[sourceIndex];\n\n spreadable = false;\n if (isObject(element)) {\n spreadable = element[IS_CONCAT_SPREADABLE];\n spreadable = spreadable !== undefined ? !!spreadable : isArray(element);\n }\n\n if (spreadable && depth > 0) {\n targetIndex = flattenIntoArray(target, original, element, toLength(element.length), targetIndex, depth - 1) - 1;\n } else {\n if (targetIndex >= 0x1fffffffffffff) throw TypeError();\n target[targetIndex] = element;\n }\n\n targetIndex++;\n }\n sourceIndex++;\n }\n return targetIndex;\n}\n\nmodule.exports = flattenIntoArray;\n","var ctx = require('./_ctx');\nvar call = require('./_iter-call');\nvar isArrayIter = require('./_is-array-iter');\nvar anObject = require('./_an-object');\nvar toLength = require('./_to-length');\nvar getIterFn = require('./core.get-iterator-method');\nvar BREAK = {};\nvar RETURN = {};\nvar exports = module.exports = function (iterable, entries, fn, that, ITERATOR) {\n var iterFn = ITERATOR ? function () { return iterable; } : getIterFn(iterable);\n var f = ctx(fn, that, entries ? 2 : 1);\n var index = 0;\n var length, step, iterator, result;\n if (typeof iterFn != 'function') throw TypeError(iterable + ' is not iterable!');\n // fast case for arrays with default iterator\n if (isArrayIter(iterFn)) for (length = toLength(iterable.length); length > index; index++) {\n result = entries ? f(anObject(step = iterable[index])[0], step[1]) : f(iterable[index]);\n if (result === BREAK || result === RETURN) return result;\n } else for (iterator = iterFn.call(iterable); !(step = iterator.next()).done;) {\n result = call(iterator, f, step.value, entries);\n if (result === BREAK || result === RETURN) return result;\n }\n};\nexports.BREAK = BREAK;\nexports.RETURN = RETURN;\n","module.exports = require('./_shared')('native-function-to-string', Function.toString);\n","// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nvar global = module.exports = typeof window != 'undefined' && window.Math == Math\n ? window : typeof self != 'undefined' && self.Math == Math ? self\n // eslint-disable-next-line no-new-func\n : Function('return this')();\nif (typeof __g == 'number') __g = global; // eslint-disable-line no-undef\n","var hasOwnProperty = {}.hasOwnProperty;\nmodule.exports = function (it, key) {\n return hasOwnProperty.call(it, key);\n};\n","var dP = require('./_object-dp');\nvar createDesc = require('./_property-desc');\nmodule.exports = require('./_descriptors') ? function (object, key, value) {\n return dP.f(object, key, createDesc(1, value));\n} : function (object, key, value) {\n object[key] = value;\n return object;\n};\n","var document = require('./_global').document;\nmodule.exports = document && document.documentElement;\n","module.exports = !require('./_descriptors') && !require('./_fails')(function () {\n return Object.defineProperty(require('./_dom-create')('div'), 'a', { get: function () { return 7; } }).a != 7;\n});\n","var isObject = require('./_is-object');\nvar setPrototypeOf = require('./_set-proto').set;\nmodule.exports = function (that, target, C) {\n var S = target.constructor;\n var P;\n if (S !== C && typeof S == 'function' && (P = S.prototype) !== C.prototype && isObject(P) && setPrototypeOf) {\n setPrototypeOf(that, P);\n } return that;\n};\n","// fast apply, http://jsperf.lnkit.com/fast-apply/5\nmodule.exports = function (fn, args, that) {\n var un = that === undefined;\n switch (args.length) {\n case 0: return un ? fn()\n : fn.call(that);\n case 1: return un ? fn(args[0])\n : fn.call(that, args[0]);\n case 2: return un ? fn(args[0], args[1])\n : fn.call(that, args[0], args[1]);\n case 3: return un ? fn(args[0], args[1], args[2])\n : fn.call(that, args[0], args[1], args[2]);\n case 4: return un ? fn(args[0], args[1], args[2], args[3])\n : fn.call(that, args[0], args[1], args[2], args[3]);\n } return fn.apply(that, args);\n};\n","// fallback for non-array-like ES3 and non-enumerable old V8 strings\nvar cof = require('./_cof');\n// eslint-disable-next-line no-prototype-builtins\nmodule.exports = Object('z').propertyIsEnumerable(0) ? Object : function (it) {\n return cof(it) == 'String' ? it.split('') : Object(it);\n};\n","// check on default Array iterator\nvar Iterators = require('./_iterators');\nvar ITERATOR = require('./_wks')('iterator');\nvar ArrayProto = Array.prototype;\n\nmodule.exports = function (it) {\n return it !== undefined && (Iterators.Array === it || ArrayProto[ITERATOR] === it);\n};\n","// 7.2.2 IsArray(argument)\nvar cof = require('./_cof');\nmodule.exports = Array.isArray || function isArray(arg) {\n return cof(arg) == 'Array';\n};\n","// 20.1.2.3 Number.isInteger(number)\nvar isObject = require('./_is-object');\nvar floor = Math.floor;\nmodule.exports = function isInteger(it) {\n return !isObject(it) && isFinite(it) && floor(it) === it;\n};\n","module.exports = function (it) {\n return typeof it === 'object' ? it !== null : typeof it === 'function';\n};\n","// 7.2.8 IsRegExp(argument)\nvar isObject = require('./_is-object');\nvar cof = require('./_cof');\nvar MATCH = require('./_wks')('match');\nmodule.exports = function (it) {\n var isRegExp;\n return isObject(it) && ((isRegExp = it[MATCH]) !== undefined ? !!isRegExp : cof(it) == 'RegExp');\n};\n","// call something on iterator step with safe closing on error\nvar anObject = require('./_an-object');\nmodule.exports = function (iterator, fn, value, entries) {\n try {\n return entries ? fn(anObject(value)[0], value[1]) : fn(value);\n // 7.4.6 IteratorClose(iterator, completion)\n } catch (e) {\n var ret = iterator['return'];\n if (ret !== undefined) anObject(ret.call(iterator));\n throw e;\n }\n};\n","'use strict';\nvar create = require('./_object-create');\nvar descriptor = require('./_property-desc');\nvar setToStringTag = require('./_set-to-string-tag');\nvar IteratorPrototype = {};\n\n// 25.1.2.1.1 %IteratorPrototype%[@@iterator]()\nrequire('./_hide')(IteratorPrototype, require('./_wks')('iterator'), function () { return this; });\n\nmodule.exports = function (Constructor, NAME, next) {\n Constructor.prototype = create(IteratorPrototype, { next: descriptor(1, next) });\n setToStringTag(Constructor, NAME + ' Iterator');\n};\n","'use strict';\nvar LIBRARY = require('./_library');\nvar $export = require('./_export');\nvar redefine = require('./_redefine');\nvar hide = require('./_hide');\nvar Iterators = require('./_iterators');\nvar $iterCreate = require('./_iter-create');\nvar setToStringTag = require('./_set-to-string-tag');\nvar getPrototypeOf = require('./_object-gpo');\nvar ITERATOR = require('./_wks')('iterator');\nvar BUGGY = !([].keys && 'next' in [].keys()); // Safari has buggy iterators w/o `next`\nvar FF_ITERATOR = '@@iterator';\nvar KEYS = 'keys';\nvar VALUES = 'values';\n\nvar returnThis = function () { return this; };\n\nmodule.exports = function (Base, NAME, Constructor, next, DEFAULT, IS_SET, FORCED) {\n $iterCreate(Constructor, NAME, next);\n var getMethod = function (kind) {\n if (!BUGGY && kind in proto) return proto[kind];\n switch (kind) {\n case KEYS: return function keys() { return new Constructor(this, kind); };\n case VALUES: return function values() { return new Constructor(this, kind); };\n } return function entries() { return new Constructor(this, kind); };\n };\n var TAG = NAME + ' Iterator';\n var DEF_VALUES = DEFAULT == VALUES;\n var VALUES_BUG = false;\n var proto = Base.prototype;\n var $native = proto[ITERATOR] || proto[FF_ITERATOR] || DEFAULT && proto[DEFAULT];\n var $default = $native || getMethod(DEFAULT);\n var $entries = DEFAULT ? !DEF_VALUES ? $default : getMethod('entries') : undefined;\n var $anyNative = NAME == 'Array' ? proto.entries || $native : $native;\n var methods, key, IteratorPrototype;\n // Fix native\n if ($anyNative) {\n IteratorPrototype = getPrototypeOf($anyNative.call(new Base()));\n if (IteratorPrototype !== Object.prototype && IteratorPrototype.next) {\n // Set @@toStringTag to native iterators\n setToStringTag(IteratorPrototype, TAG, true);\n // fix for some old engines\n if (!LIBRARY && typeof IteratorPrototype[ITERATOR] != 'function') hide(IteratorPrototype, ITERATOR, returnThis);\n }\n }\n // fix Array#{values, @@iterator}.name in V8 / FF\n if (DEF_VALUES && $native && $native.name !== VALUES) {\n VALUES_BUG = true;\n $default = function values() { return $native.call(this); };\n }\n // Define iterator\n if ((!LIBRARY || FORCED) && (BUGGY || VALUES_BUG || !proto[ITERATOR])) {\n hide(proto, ITERATOR, $default);\n }\n // Plug for library\n Iterators[NAME] = $default;\n Iterators[TAG] = returnThis;\n if (DEFAULT) {\n methods = {\n values: DEF_VALUES ? $default : getMethod(VALUES),\n keys: IS_SET ? $default : getMethod(KEYS),\n entries: $entries\n };\n if (FORCED) for (key in methods) {\n if (!(key in proto)) redefine(proto, key, methods[key]);\n } else $export($export.P + $export.F * (BUGGY || VALUES_BUG), NAME, methods);\n }\n return methods;\n};\n","var ITERATOR = require('./_wks')('iterator');\nvar SAFE_CLOSING = false;\n\ntry {\n var riter = [7][ITERATOR]();\n riter['return'] = function () { SAFE_CLOSING = true; };\n // eslint-disable-next-line no-throw-literal\n Array.from(riter, function () { throw 2; });\n} catch (e) { /* empty */ }\n\nmodule.exports = function (exec, skipClosing) {\n if (!skipClosing && !SAFE_CLOSING) return false;\n var safe = false;\n try {\n var arr = [7];\n var iter = arr[ITERATOR]();\n iter.next = function () { return { done: safe = true }; };\n arr[ITERATOR] = function () { return iter; };\n exec(arr);\n } catch (e) { /* empty */ }\n return safe;\n};\n","module.exports = function (done, value) {\n return { value: value, done: !!done };\n};\n","module.exports = {};\n","module.exports = false;\n","// 20.2.2.14 Math.expm1(x)\nvar $expm1 = Math.expm1;\nmodule.exports = (!$expm1\n // Old FF bug\n || $expm1(10) > 22025.465794806719 || $expm1(10) < 22025.4657948067165168\n // Tor Browser bug\n || $expm1(-2e-17) != -2e-17\n) ? function expm1(x) {\n return (x = +x) == 0 ? x : x > -1e-6 && x < 1e-6 ? x + x * x / 2 : Math.exp(x) - 1;\n} : $expm1;\n","// 20.2.2.16 Math.fround(x)\nvar sign = require('./_math-sign');\nvar pow = Math.pow;\nvar EPSILON = pow(2, -52);\nvar EPSILON32 = pow(2, -23);\nvar MAX32 = pow(2, 127) * (2 - EPSILON32);\nvar MIN32 = pow(2, -126);\n\nvar roundTiesToEven = function (n) {\n return n + 1 / EPSILON - 1 / EPSILON;\n};\n\nmodule.exports = Math.fround || function fround(x) {\n var $abs = Math.abs(x);\n var $sign = sign(x);\n var a, result;\n if ($abs < MIN32) return $sign * roundTiesToEven($abs / MIN32 / EPSILON32) * MIN32 * EPSILON32;\n a = (1 + EPSILON32 / EPSILON) * $abs;\n result = a - (a - $abs);\n // eslint-disable-next-line no-self-compare\n if (result > MAX32 || result != result) return $sign * Infinity;\n return $sign * result;\n};\n","// 20.2.2.20 Math.log1p(x)\nmodule.exports = Math.log1p || function log1p(x) {\n return (x = +x) > -1e-8 && x < 1e-8 ? x - x * x / 2 : Math.log(1 + x);\n};\n","// 20.2.2.28 Math.sign(x)\nmodule.exports = Math.sign || function sign(x) {\n // eslint-disable-next-line no-self-compare\n return (x = +x) == 0 || x != x ? x : x < 0 ? -1 : 1;\n};\n","var META = require('./_uid')('meta');\nvar isObject = require('./_is-object');\nvar has = require('./_has');\nvar setDesc = require('./_object-dp').f;\nvar id = 0;\nvar isExtensible = Object.isExtensible || function () {\n return true;\n};\nvar FREEZE = !require('./_fails')(function () {\n return isExtensible(Object.preventExtensions({}));\n});\nvar setMeta = function (it) {\n setDesc(it, META, { value: {\n i: 'O' + ++id, // object ID\n w: {} // weak collections IDs\n } });\n};\nvar fastKey = function (it, create) {\n // return primitive with prefix\n if (!isObject(it)) return typeof it == 'symbol' ? it : (typeof it == 'string' ? 'S' : 'P') + it;\n if (!has(it, META)) {\n // can't set metadata to uncaught frozen object\n if (!isExtensible(it)) return 'F';\n // not necessary to add metadata\n if (!create) return 'E';\n // add missing metadata\n setMeta(it);\n // return object ID\n } return it[META].i;\n};\nvar getWeak = function (it, create) {\n if (!has(it, META)) {\n // can't set metadata to uncaught frozen object\n if (!isExtensible(it)) return true;\n // not necessary to add metadata\n if (!create) return false;\n // add missing metadata\n setMeta(it);\n // return hash weak collections IDs\n } return it[META].w;\n};\n// add metadata on freeze-family methods calling\nvar onFreeze = function (it) {\n if (FREEZE && meta.NEED && isExtensible(it) && !has(it, META)) setMeta(it);\n return it;\n};\nvar meta = module.exports = {\n KEY: META,\n NEED: false,\n fastKey: fastKey,\n getWeak: getWeak,\n onFreeze: onFreeze\n};\n","var global = require('./_global');\nvar macrotask = require('./_task').set;\nvar Observer = global.MutationObserver || global.WebKitMutationObserver;\nvar process = global.process;\nvar Promise = global.Promise;\nvar isNode = require('./_cof')(process) == 'process';\n\nmodule.exports = function () {\n var head, last, notify;\n\n var flush = function () {\n var parent, fn;\n if (isNode && (parent = process.domain)) parent.exit();\n while (head) {\n fn = head.fn;\n head = head.next;\n try {\n fn();\n } catch (e) {\n if (head) notify();\n else last = undefined;\n throw e;\n }\n } last = undefined;\n if (parent) parent.enter();\n };\n\n // Node.js\n if (isNode) {\n notify = function () {\n process.nextTick(flush);\n };\n // browsers with MutationObserver, except iOS Safari - https://github.com/zloirock/core-js/issues/339\n } else if (Observer && !(global.navigator && global.navigator.standalone)) {\n var toggle = true;\n var node = document.createTextNode('');\n new Observer(flush).observe(node, { characterData: true }); // eslint-disable-line no-new\n notify = function () {\n node.data = toggle = !toggle;\n };\n // environments with maybe non-completely correct, but existent Promise\n } else if (Promise && Promise.resolve) {\n // Promise.resolve without an argument throws an error in LG WebOS 2\n var promise = Promise.resolve(undefined);\n notify = function () {\n promise.then(flush);\n };\n // for other environments - macrotask based on:\n // - setImmediate\n // - MessageChannel\n // - window.postMessag\n // - onreadystatechange\n // - setTimeout\n } else {\n notify = function () {\n // strange IE + webpack dev server bug - use .call(global)\n macrotask.call(global, flush);\n };\n }\n\n return function (fn) {\n var task = { fn: fn, next: undefined };\n if (last) last.next = task;\n if (!head) {\n head = task;\n notify();\n } last = task;\n };\n};\n","'use strict';\n// 25.4.1.5 NewPromiseCapability(C)\nvar aFunction = require('./_a-function');\n\nfunction PromiseCapability(C) {\n var resolve, reject;\n this.promise = new C(function ($$resolve, $$reject) {\n if (resolve !== undefined || reject !== undefined) throw TypeError('Bad Promise constructor');\n resolve = $$resolve;\n reject = $$reject;\n });\n this.resolve = aFunction(resolve);\n this.reject = aFunction(reject);\n}\n\nmodule.exports.f = function (C) {\n return new PromiseCapability(C);\n};\n","'use strict';\n// 19.1.2.1 Object.assign(target, source, ...)\nvar DESCRIPTORS = require('./_descriptors');\nvar getKeys = require('./_object-keys');\nvar gOPS = require('./_object-gops');\nvar pIE = require('./_object-pie');\nvar toObject = require('./_to-object');\nvar IObject = require('./_iobject');\nvar $assign = Object.assign;\n\n// should work with symbols and should have deterministic property order (V8 bug)\nmodule.exports = !$assign || require('./_fails')(function () {\n var A = {};\n var B = {};\n // eslint-disable-next-line no-undef\n var S = Symbol();\n var K = 'abcdefghijklmnopqrst';\n A[S] = 7;\n K.split('').forEach(function (k) { B[k] = k; });\n return $assign({}, A)[S] != 7 || Object.keys($assign({}, B)).join('') != K;\n}) ? function assign(target, source) { // eslint-disable-line no-unused-vars\n var T = toObject(target);\n var aLen = arguments.length;\n var index = 1;\n var getSymbols = gOPS.f;\n var isEnum = pIE.f;\n while (aLen > index) {\n var S = IObject(arguments[index++]);\n var keys = getSymbols ? getKeys(S).concat(getSymbols(S)) : getKeys(S);\n var length = keys.length;\n var j = 0;\n var key;\n while (length > j) {\n key = keys[j++];\n if (!DESCRIPTORS || isEnum.call(S, key)) T[key] = S[key];\n }\n } return T;\n} : $assign;\n","// 19.1.2.2 / 15.2.3.5 Object.create(O [, Properties])\nvar anObject = require('./_an-object');\nvar dPs = require('./_object-dps');\nvar enumBugKeys = require('./_enum-bug-keys');\nvar IE_PROTO = require('./_shared-key')('IE_PROTO');\nvar Empty = function () { /* empty */ };\nvar PROTOTYPE = 'prototype';\n\n// Create object with fake `null` prototype: use iframe Object with cleared prototype\nvar createDict = function () {\n // Thrash, waste and sodomy: IE GC bug\n var iframe = require('./_dom-create')('iframe');\n var i = enumBugKeys.length;\n var lt = '<';\n var gt = '>';\n var iframeDocument;\n iframe.style.display = 'none';\n require('./_html').appendChild(iframe);\n iframe.src = 'javascript:'; // eslint-disable-line no-script-url\n // createDict = iframe.contentWindow.Object;\n // html.removeChild(iframe);\n iframeDocument = iframe.contentWindow.document;\n iframeDocument.open();\n iframeDocument.write(lt + 'script' + gt + 'document.F=Object' + lt + '/script' + gt);\n iframeDocument.close();\n createDict = iframeDocument.F;\n while (i--) delete createDict[PROTOTYPE][enumBugKeys[i]];\n return createDict();\n};\n\nmodule.exports = Object.create || function create(O, Properties) {\n var result;\n if (O !== null) {\n Empty[PROTOTYPE] = anObject(O);\n result = new Empty();\n Empty[PROTOTYPE] = null;\n // add \"__proto__\" for Object.getPrototypeOf polyfill\n result[IE_PROTO] = O;\n } else result = createDict();\n return Properties === undefined ? result : dPs(result, Properties);\n};\n","var anObject = require('./_an-object');\nvar IE8_DOM_DEFINE = require('./_ie8-dom-define');\nvar toPrimitive = require('./_to-primitive');\nvar dP = Object.defineProperty;\n\nexports.f = require('./_descriptors') ? Object.defineProperty : function defineProperty(O, P, Attributes) {\n anObject(O);\n P = toPrimitive(P, true);\n anObject(Attributes);\n if (IE8_DOM_DEFINE) try {\n return dP(O, P, Attributes);\n } catch (e) { /* empty */ }\n if ('get' in Attributes || 'set' in Attributes) throw TypeError('Accessors not supported!');\n if ('value' in Attributes) O[P] = Attributes.value;\n return O;\n};\n","var dP = require('./_object-dp');\nvar anObject = require('./_an-object');\nvar getKeys = require('./_object-keys');\n\nmodule.exports = require('./_descriptors') ? Object.defineProperties : function defineProperties(O, Properties) {\n anObject(O);\n var keys = getKeys(Properties);\n var length = keys.length;\n var i = 0;\n var P;\n while (length > i) dP.f(O, P = keys[i++], Properties[P]);\n return O;\n};\n","var pIE = require('./_object-pie');\nvar createDesc = require('./_property-desc');\nvar toIObject = require('./_to-iobject');\nvar toPrimitive = require('./_to-primitive');\nvar has = require('./_has');\nvar IE8_DOM_DEFINE = require('./_ie8-dom-define');\nvar gOPD = Object.getOwnPropertyDescriptor;\n\nexports.f = require('./_descriptors') ? gOPD : function getOwnPropertyDescriptor(O, P) {\n O = toIObject(O);\n P = toPrimitive(P, true);\n if (IE8_DOM_DEFINE) try {\n return gOPD(O, P);\n } catch (e) { /* empty */ }\n if (has(O, P)) return createDesc(!pIE.f.call(O, P), O[P]);\n};\n","// fallback for IE11 buggy Object.getOwnPropertyNames with iframe and window\nvar toIObject = require('./_to-iobject');\nvar gOPN = require('./_object-gopn').f;\nvar toString = {}.toString;\n\nvar windowNames = typeof window == 'object' && window && Object.getOwnPropertyNames\n ? Object.getOwnPropertyNames(window) : [];\n\nvar getWindowNames = function (it) {\n try {\n return gOPN(it);\n } catch (e) {\n return windowNames.slice();\n }\n};\n\nmodule.exports.f = function getOwnPropertyNames(it) {\n return windowNames && toString.call(it) == '[object Window]' ? getWindowNames(it) : gOPN(toIObject(it));\n};\n","// 19.1.2.7 / 15.2.3.4 Object.getOwnPropertyNames(O)\nvar $keys = require('./_object-keys-internal');\nvar hiddenKeys = require('./_enum-bug-keys').concat('length', 'prototype');\n\nexports.f = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {\n return $keys(O, hiddenKeys);\n};\n","exports.f = Object.getOwnPropertySymbols;\n","// 19.1.2.9 / 15.2.3.2 Object.getPrototypeOf(O)\nvar has = require('./_has');\nvar toObject = require('./_to-object');\nvar IE_PROTO = require('./_shared-key')('IE_PROTO');\nvar ObjectProto = Object.prototype;\n\nmodule.exports = Object.getPrototypeOf || function (O) {\n O = toObject(O);\n if (has(O, IE_PROTO)) return O[IE_PROTO];\n if (typeof O.constructor == 'function' && O instanceof O.constructor) {\n return O.constructor.prototype;\n } return O instanceof Object ? ObjectProto : null;\n};\n","var has = require('./_has');\nvar toIObject = require('./_to-iobject');\nvar arrayIndexOf = require('./_array-includes')(false);\nvar IE_PROTO = require('./_shared-key')('IE_PROTO');\n\nmodule.exports = function (object, names) {\n var O = toIObject(object);\n var i = 0;\n var result = [];\n var key;\n for (key in O) if (key != IE_PROTO) has(O, key) && result.push(key);\n // Don't enum bug & hidden keys\n while (names.length > i) if (has(O, key = names[i++])) {\n ~arrayIndexOf(result, key) || result.push(key);\n }\n return result;\n};\n","// 19.1.2.14 / 15.2.3.14 Object.keys(O)\nvar $keys = require('./_object-keys-internal');\nvar enumBugKeys = require('./_enum-bug-keys');\n\nmodule.exports = Object.keys || function keys(O) {\n return $keys(O, enumBugKeys);\n};\n","exports.f = {}.propertyIsEnumerable;\n","// most Object methods by ES6 should accept primitives\nvar $export = require('./_export');\nvar core = require('./_core');\nvar fails = require('./_fails');\nmodule.exports = function (KEY, exec) {\n var fn = (core.Object || {})[KEY] || Object[KEY];\n var exp = {};\n exp[KEY] = exec(fn);\n $export($export.S + $export.F * fails(function () { fn(1); }), 'Object', exp);\n};\n","var DESCRIPTORS = require('./_descriptors');\nvar getKeys = require('./_object-keys');\nvar toIObject = require('./_to-iobject');\nvar isEnum = require('./_object-pie').f;\nmodule.exports = function (isEntries) {\n return function (it) {\n var O = toIObject(it);\n var keys = getKeys(O);\n var length = keys.length;\n var i = 0;\n var result = [];\n var key;\n while (length > i) {\n key = keys[i++];\n if (!DESCRIPTORS || isEnum.call(O, key)) {\n result.push(isEntries ? [key, O[key]] : O[key]);\n }\n }\n return result;\n };\n};\n","// all object keys, includes non-enumerable and symbols\nvar gOPN = require('./_object-gopn');\nvar gOPS = require('./_object-gops');\nvar anObject = require('./_an-object');\nvar Reflect = require('./_global').Reflect;\nmodule.exports = Reflect && Reflect.ownKeys || function ownKeys(it) {\n var keys = gOPN.f(anObject(it));\n var getSymbols = gOPS.f;\n return getSymbols ? keys.concat(getSymbols(it)) : keys;\n};\n","var $parseFloat = require('./_global').parseFloat;\nvar $trim = require('./_string-trim').trim;\n\nmodule.exports = 1 / $parseFloat(require('./_string-ws') + '-0') !== -Infinity ? function parseFloat(str) {\n var string = $trim(String(str), 3);\n var result = $parseFloat(string);\n return result === 0 && string.charAt(0) == '-' ? -0 : result;\n} : $parseFloat;\n","var $parseInt = require('./_global').parseInt;\nvar $trim = require('./_string-trim').trim;\nvar ws = require('./_string-ws');\nvar hex = /^[-+]?0[xX]/;\n\nmodule.exports = $parseInt(ws + '08') !== 8 || $parseInt(ws + '0x16') !== 22 ? function parseInt(str, radix) {\n var string = $trim(String(str), 3);\n return $parseInt(string, (radix >>> 0) || (hex.test(string) ? 16 : 10));\n} : $parseInt;\n","module.exports = function (exec) {\n try {\n return { e: false, v: exec() };\n } catch (e) {\n return { e: true, v: e };\n }\n};\n","var anObject = require('./_an-object');\nvar isObject = require('./_is-object');\nvar newPromiseCapability = require('./_new-promise-capability');\n\nmodule.exports = function (C, x) {\n anObject(C);\n if (isObject(x) && x.constructor === C) return x;\n var promiseCapability = newPromiseCapability.f(C);\n var resolve = promiseCapability.resolve;\n resolve(x);\n return promiseCapability.promise;\n};\n","module.exports = function (bitmap, value) {\n return {\n enumerable: !(bitmap & 1),\n configurable: !(bitmap & 2),\n writable: !(bitmap & 4),\n value: value\n };\n};\n","var redefine = require('./_redefine');\nmodule.exports = function (target, src, safe) {\n for (var key in src) redefine(target, key, src[key], safe);\n return target;\n};\n","var global = require('./_global');\nvar hide = require('./_hide');\nvar has = require('./_has');\nvar SRC = require('./_uid')('src');\nvar $toString = require('./_function-to-string');\nvar TO_STRING = 'toString';\nvar TPL = ('' + $toString).split(TO_STRING);\n\nrequire('./_core').inspectSource = function (it) {\n return $toString.call(it);\n};\n\n(module.exports = function (O, key, val, safe) {\n var isFunction = typeof val == 'function';\n if (isFunction) has(val, 'name') || hide(val, 'name', key);\n if (O[key] === val) return;\n if (isFunction) has(val, SRC) || hide(val, SRC, O[key] ? '' + O[key] : TPL.join(String(key)));\n if (O === global) {\n O[key] = val;\n } else if (!safe) {\n delete O[key];\n hide(O, key, val);\n } else if (O[key]) {\n O[key] = val;\n } else {\n hide(O, key, val);\n }\n// add fake Function#toString for correct work wrapped methods / constructors with methods like LoDash isNative\n})(Function.prototype, TO_STRING, function toString() {\n return typeof this == 'function' && this[SRC] || $toString.call(this);\n});\n","'use strict';\n\nvar classof = require('./_classof');\nvar builtinExec = RegExp.prototype.exec;\n\n // `RegExpExec` abstract operation\n// https://tc39.github.io/ecma262/#sec-regexpexec\nmodule.exports = function (R, S) {\n var exec = R.exec;\n if (typeof exec === 'function') {\n var result = exec.call(R, S);\n if (typeof result !== 'object') {\n throw new TypeError('RegExp exec method returned something other than an Object or null');\n }\n return result;\n }\n if (classof(R) !== 'RegExp') {\n throw new TypeError('RegExp#exec called on incompatible receiver');\n }\n return builtinExec.call(R, S);\n};\n","'use strict';\n\nvar regexpFlags = require('./_flags');\n\nvar nativeExec = RegExp.prototype.exec;\n// This always refers to the native implementation, because the\n// String#replace polyfill uses ./fix-regexp-well-known-symbol-logic.js,\n// which loads this file before patching the method.\nvar nativeReplace = String.prototype.replace;\n\nvar patchedExec = nativeExec;\n\nvar LAST_INDEX = 'lastIndex';\n\nvar UPDATES_LAST_INDEX_WRONG = (function () {\n var re1 = /a/,\n re2 = /b*/g;\n nativeExec.call(re1, 'a');\n nativeExec.call(re2, 'a');\n return re1[LAST_INDEX] !== 0 || re2[LAST_INDEX] !== 0;\n})();\n\n// nonparticipating capturing group, copied from es5-shim's String#split patch.\nvar NPCG_INCLUDED = /()??/.exec('')[1] !== undefined;\n\nvar PATCH = UPDATES_LAST_INDEX_WRONG || NPCG_INCLUDED;\n\nif (PATCH) {\n patchedExec = function exec(str) {\n var re = this;\n var lastIndex, reCopy, match, i;\n\n if (NPCG_INCLUDED) {\n reCopy = new RegExp('^' + re.source + '$(?!\\\\s)', regexpFlags.call(re));\n }\n if (UPDATES_LAST_INDEX_WRONG) lastIndex = re[LAST_INDEX];\n\n match = nativeExec.call(re, str);\n\n if (UPDATES_LAST_INDEX_WRONG && match) {\n re[LAST_INDEX] = re.global ? match.index + match[0].length : lastIndex;\n }\n if (NPCG_INCLUDED && match && match.length > 1) {\n // Fix browsers whose `exec` methods don't consistently return `undefined`\n // for NPCG, like IE8. NOTE: This doesn' work for /(.?)?/\n // eslint-disable-next-line no-loop-func\n nativeReplace.call(match[0], reCopy, function () {\n for (i = 1; i < arguments.length - 2; i++) {\n if (arguments[i] === undefined) match[i] = undefined;\n }\n });\n }\n\n return match;\n };\n}\n\nmodule.exports = patchedExec;\n","// 7.2.9 SameValue(x, y)\nmodule.exports = Object.is || function is(x, y) {\n // eslint-disable-next-line no-self-compare\n return x === y ? x !== 0 || 1 / x === 1 / y : x != x && y != y;\n};\n","// Works with __proto__ only. Old v8 can't work with null proto objects.\n/* eslint-disable no-proto */\nvar isObject = require('./_is-object');\nvar anObject = require('./_an-object');\nvar check = function (O, proto) {\n anObject(O);\n if (!isObject(proto) && proto !== null) throw TypeError(proto + \": can't set as prototype!\");\n};\nmodule.exports = {\n set: Object.setPrototypeOf || ('__proto__' in {} ? // eslint-disable-line\n function (test, buggy, set) {\n try {\n set = require('./_ctx')(Function.call, require('./_object-gopd').f(Object.prototype, '__proto__').set, 2);\n set(test, []);\n buggy = !(test instanceof Array);\n } catch (e) { buggy = true; }\n return function setPrototypeOf(O, proto) {\n check(O, proto);\n if (buggy) O.__proto__ = proto;\n else set(O, proto);\n return O;\n };\n }({}, false) : undefined),\n check: check\n};\n","'use strict';\nvar global = require('./_global');\nvar dP = require('./_object-dp');\nvar DESCRIPTORS = require('./_descriptors');\nvar SPECIES = require('./_wks')('species');\n\nmodule.exports = function (KEY) {\n var C = global[KEY];\n if (DESCRIPTORS && C && !C[SPECIES]) dP.f(C, SPECIES, {\n configurable: true,\n get: function () { return this; }\n });\n};\n","var def = require('./_object-dp').f;\nvar has = require('./_has');\nvar TAG = require('./_wks')('toStringTag');\n\nmodule.exports = function (it, tag, stat) {\n if (it && !has(it = stat ? it : it.prototype, TAG)) def(it, TAG, { configurable: true, value: tag });\n};\n","var shared = require('./_shared')('keys');\nvar uid = require('./_uid');\nmodule.exports = function (key) {\n return shared[key] || (shared[key] = uid(key));\n};\n","var core = require('./_core');\nvar global = require('./_global');\nvar SHARED = '__core-js_shared__';\nvar store = global[SHARED] || (global[SHARED] = {});\n\n(module.exports = function (key, value) {\n return store[key] || (store[key] = value !== undefined ? value : {});\n})('versions', []).push({\n version: core.version,\n mode: require('./_library') ? 'pure' : 'global',\n copyright: '© 2020 Denis Pushkarev (zloirock.ru)'\n});\n","// 7.3.20 SpeciesConstructor(O, defaultConstructor)\nvar anObject = require('./_an-object');\nvar aFunction = require('./_a-function');\nvar SPECIES = require('./_wks')('species');\nmodule.exports = function (O, D) {\n var C = anObject(O).constructor;\n var S;\n return C === undefined || (S = anObject(C)[SPECIES]) == undefined ? D : aFunction(S);\n};\n","'use strict';\nvar fails = require('./_fails');\n\nmodule.exports = function (method, arg) {\n return !!method && fails(function () {\n // eslint-disable-next-line no-useless-call\n arg ? method.call(null, function () { /* empty */ }, 1) : method.call(null);\n });\n};\n","var toInteger = require('./_to-integer');\nvar defined = require('./_defined');\n// true -> String#at\n// false -> String#codePointAt\nmodule.exports = function (TO_STRING) {\n return function (that, pos) {\n var s = String(defined(that));\n var i = toInteger(pos);\n var l = s.length;\n var a, b;\n if (i < 0 || i >= l) return TO_STRING ? '' : undefined;\n a = s.charCodeAt(i);\n return a < 0xd800 || a > 0xdbff || i + 1 === l || (b = s.charCodeAt(i + 1)) < 0xdc00 || b > 0xdfff\n ? TO_STRING ? s.charAt(i) : a\n : TO_STRING ? s.slice(i, i + 2) : (a - 0xd800 << 10) + (b - 0xdc00) + 0x10000;\n };\n};\n","// helper for String#{startsWith, endsWith, includes}\nvar isRegExp = require('./_is-regexp');\nvar defined = require('./_defined');\n\nmodule.exports = function (that, searchString, NAME) {\n if (isRegExp(searchString)) throw TypeError('String#' + NAME + \" doesn't accept regex!\");\n return String(defined(that));\n};\n","var $export = require('./_export');\nvar fails = require('./_fails');\nvar defined = require('./_defined');\nvar quot = /\"/g;\n// B.2.3.2.1 CreateHTML(string, tag, attribute, value)\nvar createHTML = function (string, tag, attribute, value) {\n var S = String(defined(string));\n var p1 = '<' + tag;\n if (attribute !== '') p1 += ' ' + attribute + '=\"' + String(value).replace(quot, '&quot;') + '\"';\n return p1 + '>' + S + '</' + tag + '>';\n};\nmodule.exports = function (NAME, exec) {\n var O = {};\n O[NAME] = exec(createHTML);\n $export($export.P + $export.F * fails(function () {\n var test = ''[NAME]('\"');\n return test !== test.toLowerCase() || test.split('\"').length > 3;\n }), 'String', O);\n};\n","// https://github.com/tc39/proposal-string-pad-start-end\nvar toLength = require('./_to-length');\nvar repeat = require('./_string-repeat');\nvar defined = require('./_defined');\n\nmodule.exports = function (that, maxLength, fillString, left) {\n var S = String(defined(that));\n var stringLength = S.length;\n var fillStr = fillString === undefined ? ' ' : String(fillString);\n var intMaxLength = toLength(maxLength);\n if (intMaxLength <= stringLength || fillStr == '') return S;\n var fillLen = intMaxLength - stringLength;\n var stringFiller = repeat.call(fillStr, Math.ceil(fillLen / fillStr.length));\n if (stringFiller.length > fillLen) stringFiller = stringFiller.slice(0, fillLen);\n return left ? stringFiller + S : S + stringFiller;\n};\n","'use strict';\nvar toInteger = require('./_to-integer');\nvar defined = require('./_defined');\n\nmodule.exports = function repeat(count) {\n var str = String(defined(this));\n var res = '';\n var n = toInteger(count);\n if (n < 0 || n == Infinity) throw RangeError(\"Count can't be negative\");\n for (;n > 0; (n >>>= 1) && (str += str)) if (n & 1) res += str;\n return res;\n};\n","var $export = require('./_export');\nvar defined = require('./_defined');\nvar fails = require('./_fails');\nvar spaces = require('./_string-ws');\nvar space = '[' + spaces + ']';\nvar non = '\\u200b\\u0085';\nvar ltrim = RegExp('^' + space + space + '*');\nvar rtrim = RegExp(space + space + '*$');\n\nvar exporter = function (KEY, exec, ALIAS) {\n var exp = {};\n var FORCE = fails(function () {\n return !!spaces[KEY]() || non[KEY]() != non;\n });\n var fn = exp[KEY] = FORCE ? exec(trim) : spaces[KEY];\n if (ALIAS) exp[ALIAS] = fn;\n $export($export.P + $export.F * FORCE, 'String', exp);\n};\n\n// 1 -> String#trimLeft\n// 2 -> String#trimRight\n// 3 -> String#trim\nvar trim = exporter.trim = function (string, TYPE) {\n string = String(defined(string));\n if (TYPE & 1) string = string.replace(ltrim, '');\n if (TYPE & 2) string = string.replace(rtrim, '');\n return string;\n};\n\nmodule.exports = exporter;\n","module.exports = '\\x09\\x0A\\x0B\\x0C\\x0D\\x20\\xA0\\u1680\\u180E\\u2000\\u2001\\u2002\\u2003' +\n '\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200A\\u202F\\u205F\\u3000\\u2028\\u2029\\uFEFF';\n","var ctx = require('./_ctx');\nvar invoke = require('./_invoke');\nvar html = require('./_html');\nvar cel = require('./_dom-create');\nvar global = require('./_global');\nvar process = global.process;\nvar setTask = global.setImmediate;\nvar clearTask = global.clearImmediate;\nvar MessageChannel = global.MessageChannel;\nvar Dispatch = global.Dispatch;\nvar counter = 0;\nvar queue = {};\nvar ONREADYSTATECHANGE = 'onreadystatechange';\nvar defer, channel, port;\nvar run = function () {\n var id = +this;\n // eslint-disable-next-line no-prototype-builtins\n if (queue.hasOwnProperty(id)) {\n var fn = queue[id];\n delete queue[id];\n fn();\n }\n};\nvar listener = function (event) {\n run.call(event.data);\n};\n// Node.js 0.9+ & IE10+ has setImmediate, otherwise:\nif (!setTask || !clearTask) {\n setTask = function setImmediate(fn) {\n var args = [];\n var i = 1;\n while (arguments.length > i) args.push(arguments[i++]);\n queue[++counter] = function () {\n // eslint-disable-next-line no-new-func\n invoke(typeof fn == 'function' ? fn : Function(fn), args);\n };\n defer(counter);\n return counter;\n };\n clearTask = function clearImmediate(id) {\n delete queue[id];\n };\n // Node.js 0.8-\n if (require('./_cof')(process) == 'process') {\n defer = function (id) {\n process.nextTick(ctx(run, id, 1));\n };\n // Sphere (JS game engine) Dispatch API\n } else if (Dispatch && Dispatch.now) {\n defer = function (id) {\n Dispatch.now(ctx(run, id, 1));\n };\n // Browsers with MessageChannel, includes WebWorkers\n } else if (MessageChannel) {\n channel = new MessageChannel();\n port = channel.port2;\n channel.port1.onmessage = listener;\n defer = ctx(port.postMessage, port, 1);\n // Browsers with postMessage, skip WebWorkers\n // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'\n } else if (global.addEventListener && typeof postMessage == 'function' && !global.importScripts) {\n defer = function (id) {\n global.postMessage(id + '', '*');\n };\n global.addEventListener('message', listener, false);\n // IE8-\n } else if (ONREADYSTATECHANGE in cel('script')) {\n defer = function (id) {\n html.appendChild(cel('script'))[ONREADYSTATECHANGE] = function () {\n html.removeChild(this);\n run.call(id);\n };\n };\n // Rest old browsers\n } else {\n defer = function (id) {\n setTimeout(ctx(run, id, 1), 0);\n };\n }\n}\nmodule.exports = {\n set: setTask,\n clear: clearTask\n};\n","var toInteger = require('./_to-integer');\nvar max = Math.max;\nvar min = Math.min;\nmodule.exports = function (index, length) {\n index = toInteger(index);\n return index < 0 ? max(index + length, 0) : min(index, length);\n};\n","// https://tc39.github.io/ecma262/#sec-toindex\nvar toInteger = require('./_to-integer');\nvar toLength = require('./_to-length');\nmodule.exports = function (it) {\n if (it === undefined) return 0;\n var number = toInteger(it);\n var length = toLength(number);\n if (number !== length) throw RangeError('Wrong length!');\n return length;\n};\n","// 7.1.4 ToInteger\nvar ceil = Math.ceil;\nvar floor = Math.floor;\nmodule.exports = function (it) {\n return isNaN(it = +it) ? 0 : (it > 0 ? floor : ceil)(it);\n};\n","// to indexed object, toObject with fallback for non-array-like ES3 strings\nvar IObject = require('./_iobject');\nvar defined = require('./_defined');\nmodule.exports = function (it) {\n return IObject(defined(it));\n};\n","// 7.1.15 ToLength\nvar toInteger = require('./_to-integer');\nvar min = Math.min;\nmodule.exports = function (it) {\n return it > 0 ? min(toInteger(it), 0x1fffffffffffff) : 0; // pow(2, 53) - 1 == 9007199254740991\n};\n","// 7.1.13 ToObject(argument)\nvar defined = require('./_defined');\nmodule.exports = function (it) {\n return Object(defined(it));\n};\n","// 7.1.1 ToPrimitive(input [, PreferredType])\nvar isObject = require('./_is-object');\n// instead of the ES6 spec version, we didn't implement @@toPrimitive case\n// and the second argument - flag - preferred type is a string\nmodule.exports = function (it, S) {\n if (!isObject(it)) return it;\n var fn, val;\n if (S && typeof (fn = it.toString) == 'function' && !isObject(val = fn.call(it))) return val;\n if (typeof (fn = it.valueOf) == 'function' && !isObject(val = fn.call(it))) return val;\n if (!S && typeof (fn = it.toString) == 'function' && !isObject(val = fn.call(it))) return val;\n throw TypeError(\"Can't convert object to primitive value\");\n};\n","'use strict';\nif (require('./_descriptors')) {\n var LIBRARY = require('./_library');\n var global = require('./_global');\n var fails = require('./_fails');\n var $export = require('./_export');\n var $typed = require('./_typed');\n var $buffer = require('./_typed-buffer');\n var ctx = require('./_ctx');\n var anInstance = require('./_an-instance');\n var propertyDesc = require('./_property-desc');\n var hide = require('./_hide');\n var redefineAll = require('./_redefine-all');\n var toInteger = require('./_to-integer');\n var toLength = require('./_to-length');\n var toIndex = require('./_to-index');\n var toAbsoluteIndex = require('./_to-absolute-index');\n var toPrimitive = require('./_to-primitive');\n var has = require('./_has');\n var classof = require('./_classof');\n var isObject = require('./_is-object');\n var toObject = require('./_to-object');\n var isArrayIter = require('./_is-array-iter');\n var create = require('./_object-create');\n var getPrototypeOf = require('./_object-gpo');\n var gOPN = require('./_object-gopn').f;\n var getIterFn = require('./core.get-iterator-method');\n var uid = require('./_uid');\n var wks = require('./_wks');\n var createArrayMethod = require('./_array-methods');\n var createArrayIncludes = require('./_array-includes');\n var speciesConstructor = require('./_species-constructor');\n var ArrayIterators = require('./es6.array.iterator');\n var Iterators = require('./_iterators');\n var $iterDetect = require('./_iter-detect');\n var setSpecies = require('./_set-species');\n var arrayFill = require('./_array-fill');\n var arrayCopyWithin = require('./_array-copy-within');\n var $DP = require('./_object-dp');\n var $GOPD = require('./_object-gopd');\n var dP = $DP.f;\n var gOPD = $GOPD.f;\n var RangeError = global.RangeError;\n var TypeError = global.TypeError;\n var Uint8Array = global.Uint8Array;\n var ARRAY_BUFFER = 'ArrayBuffer';\n var SHARED_BUFFER = 'Shared' + ARRAY_BUFFER;\n var BYTES_PER_ELEMENT = 'BYTES_PER_ELEMENT';\n var PROTOTYPE = 'prototype';\n var ArrayProto = Array[PROTOTYPE];\n var $ArrayBuffer = $buffer.ArrayBuffer;\n var $DataView = $buffer.DataView;\n var arrayForEach = createArrayMethod(0);\n var arrayFilter = createArrayMethod(2);\n var arraySome = createArrayMethod(3);\n var arrayEvery = createArrayMethod(4);\n var arrayFind = createArrayMethod(5);\n var arrayFindIndex = createArrayMethod(6);\n var arrayIncludes = createArrayIncludes(true);\n var arrayIndexOf = createArrayIncludes(false);\n var arrayValues = ArrayIterators.values;\n var arrayKeys = ArrayIterators.keys;\n var arrayEntries = ArrayIterators.entries;\n var arrayLastIndexOf = ArrayProto.lastIndexOf;\n var arrayReduce = ArrayProto.reduce;\n var arrayReduceRight = ArrayProto.reduceRight;\n var arrayJoin = ArrayProto.join;\n var arraySort = ArrayProto.sort;\n var arraySlice = ArrayProto.slice;\n var arrayToString = ArrayProto.toString;\n var arrayToLocaleString = ArrayProto.toLocaleString;\n var ITERATOR = wks('iterator');\n var TAG = wks('toStringTag');\n var TYPED_CONSTRUCTOR = uid('typed_constructor');\n var DEF_CONSTRUCTOR = uid('def_constructor');\n var ALL_CONSTRUCTORS = $typed.CONSTR;\n var TYPED_ARRAY = $typed.TYPED;\n var VIEW = $typed.VIEW;\n var WRONG_LENGTH = 'Wrong length!';\n\n var $map = createArrayMethod(1, function (O, length) {\n return allocate(speciesConstructor(O, O[DEF_CONSTRUCTOR]), length);\n });\n\n var LITTLE_ENDIAN = fails(function () {\n // eslint-disable-next-line no-undef\n return new Uint8Array(new Uint16Array([1]).buffer)[0] === 1;\n });\n\n var FORCED_SET = !!Uint8Array && !!Uint8Array[PROTOTYPE].set && fails(function () {\n new Uint8Array(1).set({});\n });\n\n var toOffset = function (it, BYTES) {\n var offset = toInteger(it);\n if (offset < 0 || offset % BYTES) throw RangeError('Wrong offset!');\n return offset;\n };\n\n var validate = function (it) {\n if (isObject(it) && TYPED_ARRAY in it) return it;\n throw TypeError(it + ' is not a typed array!');\n };\n\n var allocate = function (C, length) {\n if (!(isObject(C) && TYPED_CONSTRUCTOR in C)) {\n throw TypeError('It is not a typed array constructor!');\n } return new C(length);\n };\n\n var speciesFromList = function (O, list) {\n return fromList(speciesConstructor(O, O[DEF_CONSTRUCTOR]), list);\n };\n\n var fromList = function (C, list) {\n var index = 0;\n var length = list.length;\n var result = allocate(C, length);\n while (length > index) result[index] = list[index++];\n return result;\n };\n\n var addGetter = function (it, key, internal) {\n dP(it, key, { get: function () { return this._d[internal]; } });\n };\n\n var $from = function from(source /* , mapfn, thisArg */) {\n var O = toObject(source);\n var aLen = arguments.length;\n var mapfn = aLen > 1 ? arguments[1] : undefined;\n var mapping = mapfn !== undefined;\n var iterFn = getIterFn(O);\n var i, length, values, result, step, iterator;\n if (iterFn != undefined && !isArrayIter(iterFn)) {\n for (iterator = iterFn.call(O), values = [], i = 0; !(step = iterator.next()).done; i++) {\n values.push(step.value);\n } O = values;\n }\n if (mapping && aLen > 2) mapfn = ctx(mapfn, arguments[2], 2);\n for (i = 0, length = toLength(O.length), result = allocate(this, length); length > i; i++) {\n result[i] = mapping ? mapfn(O[i], i) : O[i];\n }\n return result;\n };\n\n var $of = function of(/* ...items */) {\n var index = 0;\n var length = arguments.length;\n var result = allocate(this, length);\n while (length > index) result[index] = arguments[index++];\n return result;\n };\n\n // iOS Safari 6.x fails here\n var TO_LOCALE_BUG = !!Uint8Array && fails(function () { arrayToLocaleString.call(new Uint8Array(1)); });\n\n var $toLocaleString = function toLocaleString() {\n return arrayToLocaleString.apply(TO_LOCALE_BUG ? arraySlice.call(validate(this)) : validate(this), arguments);\n };\n\n var proto = {\n copyWithin: function copyWithin(target, start /* , end */) {\n return arrayCopyWithin.call(validate(this), target, start, arguments.length > 2 ? arguments[2] : undefined);\n },\n every: function every(callbackfn /* , thisArg */) {\n return arrayEvery(validate(this), callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n },\n fill: function fill(value /* , start, end */) { // eslint-disable-line no-unused-vars\n return arrayFill.apply(validate(this), arguments);\n },\n filter: function filter(callbackfn /* , thisArg */) {\n return speciesFromList(this, arrayFilter(validate(this), callbackfn,\n arguments.length > 1 ? arguments[1] : undefined));\n },\n find: function find(predicate /* , thisArg */) {\n return arrayFind(validate(this), predicate, arguments.length > 1 ? arguments[1] : undefined);\n },\n findIndex: function findIndex(predicate /* , thisArg */) {\n return arrayFindIndex(validate(this), predicate, arguments.length > 1 ? arguments[1] : undefined);\n },\n forEach: function forEach(callbackfn /* , thisArg */) {\n arrayForEach(validate(this), callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n },\n indexOf: function indexOf(searchElement /* , fromIndex */) {\n return arrayIndexOf(validate(this), searchElement, arguments.length > 1 ? arguments[1] : undefined);\n },\n includes: function includes(searchElement /* , fromIndex */) {\n return arrayIncludes(validate(this), searchElement, arguments.length > 1 ? arguments[1] : undefined);\n },\n join: function join(separator) { // eslint-disable-line no-unused-vars\n return arrayJoin.apply(validate(this), arguments);\n },\n lastIndexOf: function lastIndexOf(searchElement /* , fromIndex */) { // eslint-disable-line no-unused-vars\n return arrayLastIndexOf.apply(validate(this), arguments);\n },\n map: function map(mapfn /* , thisArg */) {\n return $map(validate(this), mapfn, arguments.length > 1 ? arguments[1] : undefined);\n },\n reduce: function reduce(callbackfn /* , initialValue */) { // eslint-disable-line no-unused-vars\n return arrayReduce.apply(validate(this), arguments);\n },\n reduceRight: function reduceRight(callbackfn /* , initialValue */) { // eslint-disable-line no-unused-vars\n return arrayReduceRight.apply(validate(this), arguments);\n },\n reverse: function reverse() {\n var that = this;\n var length = validate(that).length;\n var middle = Math.floor(length / 2);\n var index = 0;\n var value;\n while (index < middle) {\n value = that[index];\n that[index++] = that[--length];\n that[length] = value;\n } return that;\n },\n some: function some(callbackfn /* , thisArg */) {\n return arraySome(validate(this), callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n },\n sort: function sort(comparefn) {\n return arraySort.call(validate(this), comparefn);\n },\n subarray: function subarray(begin, end) {\n var O = validate(this);\n var length = O.length;\n var $begin = toAbsoluteIndex(begin, length);\n return new (speciesConstructor(O, O[DEF_CONSTRUCTOR]))(\n O.buffer,\n O.byteOffset + $begin * O.BYTES_PER_ELEMENT,\n toLength((end === undefined ? length : toAbsoluteIndex(end, length)) - $begin)\n );\n }\n };\n\n var $slice = function slice(start, end) {\n return speciesFromList(this, arraySlice.call(validate(this), start, end));\n };\n\n var $set = function set(arrayLike /* , offset */) {\n validate(this);\n var offset = toOffset(arguments[1], 1);\n var length = this.length;\n var src = toObject(arrayLike);\n var len = toLength(src.length);\n var index = 0;\n if (len + offset > length) throw RangeError(WRONG_LENGTH);\n while (index < len) this[offset + index] = src[index++];\n };\n\n var $iterators = {\n entries: function entries() {\n return arrayEntries.call(validate(this));\n },\n keys: function keys() {\n return arrayKeys.call(validate(this));\n },\n values: function values() {\n return arrayValues.call(validate(this));\n }\n };\n\n var isTAIndex = function (target, key) {\n return isObject(target)\n && target[TYPED_ARRAY]\n && typeof key != 'symbol'\n && key in target\n && String(+key) == String(key);\n };\n var $getDesc = function getOwnPropertyDescriptor(target, key) {\n return isTAIndex(target, key = toPrimitive(key, true))\n ? propertyDesc(2, target[key])\n : gOPD(target, key);\n };\n var $setDesc = function defineProperty(target, key, desc) {\n if (isTAIndex(target, key = toPrimitive(key, true))\n && isObject(desc)\n && has(desc, 'value')\n && !has(desc, 'get')\n && !has(desc, 'set')\n // TODO: add validation descriptor w/o calling accessors\n && !desc.configurable\n && (!has(desc, 'writable') || desc.writable)\n && (!has(desc, 'enumerable') || desc.enumerable)\n ) {\n target[key] = desc.value;\n return target;\n } return dP(target, key, desc);\n };\n\n if (!ALL_CONSTRUCTORS) {\n $GOPD.f = $getDesc;\n $DP.f = $setDesc;\n }\n\n $export($export.S + $export.F * !ALL_CONSTRUCTORS, 'Object', {\n getOwnPropertyDescriptor: $getDesc,\n defineProperty: $setDesc\n });\n\n if (fails(function () { arrayToString.call({}); })) {\n arrayToString = arrayToLocaleString = function toString() {\n return arrayJoin.call(this);\n };\n }\n\n var $TypedArrayPrototype$ = redefineAll({}, proto);\n redefineAll($TypedArrayPrototype$, $iterators);\n hide($TypedArrayPrototype$, ITERATOR, $iterators.values);\n redefineAll($TypedArrayPrototype$, {\n slice: $slice,\n set: $set,\n constructor: function () { /* noop */ },\n toString: arrayToString,\n toLocaleString: $toLocaleString\n });\n addGetter($TypedArrayPrototype$, 'buffer', 'b');\n addGetter($TypedArrayPrototype$, 'byteOffset', 'o');\n addGetter($TypedArrayPrototype$, 'byteLength', 'l');\n addGetter($TypedArrayPrototype$, 'length', 'e');\n dP($TypedArrayPrototype$, TAG, {\n get: function () { return this[TYPED_ARRAY]; }\n });\n\n // eslint-disable-next-line max-statements\n module.exports = function (KEY, BYTES, wrapper, CLAMPED) {\n CLAMPED = !!CLAMPED;\n var NAME = KEY + (CLAMPED ? 'Clamped' : '') + 'Array';\n var GETTER = 'get' + KEY;\n var SETTER = 'set' + KEY;\n var TypedArray = global[NAME];\n var Base = TypedArray || {};\n var TAC = TypedArray && getPrototypeOf(TypedArray);\n var FORCED = !TypedArray || !$typed.ABV;\n var O = {};\n var TypedArrayPrototype = TypedArray && TypedArray[PROTOTYPE];\n var getter = function (that, index) {\n var data = that._d;\n return data.v[GETTER](index * BYTES + data.o, LITTLE_ENDIAN);\n };\n var setter = function (that, index, value) {\n var data = that._d;\n if (CLAMPED) value = (value = Math.round(value)) < 0 ? 0 : value > 0xff ? 0xff : value & 0xff;\n data.v[SETTER](index * BYTES + data.o, value, LITTLE_ENDIAN);\n };\n var addElement = function (that, index) {\n dP(that, index, {\n get: function () {\n return getter(this, index);\n },\n set: function (value) {\n return setter(this, index, value);\n },\n enumerable: true\n });\n };\n if (FORCED) {\n TypedArray = wrapper(function (that, data, $offset, $length) {\n anInstance(that, TypedArray, NAME, '_d');\n var index = 0;\n var offset = 0;\n var buffer, byteLength, length, klass;\n if (!isObject(data)) {\n length = toIndex(data);\n byteLength = length * BYTES;\n buffer = new $ArrayBuffer(byteLength);\n } else if (data instanceof $ArrayBuffer || (klass = classof(data)) == ARRAY_BUFFER || klass == SHARED_BUFFER) {\n buffer = data;\n offset = toOffset($offset, BYTES);\n var $len = data.byteLength;\n if ($length === undefined) {\n if ($len % BYTES) throw RangeError(WRONG_LENGTH);\n byteLength = $len - offset;\n if (byteLength < 0) throw RangeError(WRONG_LENGTH);\n } else {\n byteLength = toLength($length) * BYTES;\n if (byteLength + offset > $len) throw RangeError(WRONG_LENGTH);\n }\n length = byteLength / BYTES;\n } else if (TYPED_ARRAY in data) {\n return fromList(TypedArray, data);\n } else {\n return $from.call(TypedArray, data);\n }\n hide(that, '_d', {\n b: buffer,\n o: offset,\n l: byteLength,\n e: length,\n v: new $DataView(buffer)\n });\n while (index < length) addElement(that, index++);\n });\n TypedArrayPrototype = TypedArray[PROTOTYPE] = create($TypedArrayPrototype$);\n hide(TypedArrayPrototype, 'constructor', TypedArray);\n } else if (!fails(function () {\n TypedArray(1);\n }) || !fails(function () {\n new TypedArray(-1); // eslint-disable-line no-new\n }) || !$iterDetect(function (iter) {\n new TypedArray(); // eslint-disable-line no-new\n new TypedArray(null); // eslint-disable-line no-new\n new TypedArray(1.5); // eslint-disable-line no-new\n new TypedArray(iter); // eslint-disable-line no-new\n }, true)) {\n TypedArray = wrapper(function (that, data, $offset, $length) {\n anInstance(that, TypedArray, NAME);\n var klass;\n // `ws` module bug, temporarily remove validation length for Uint8Array\n // https://github.com/websockets/ws/pull/645\n if (!isObject(data)) return new Base(toIndex(data));\n if (data instanceof $ArrayBuffer || (klass = classof(data)) == ARRAY_BUFFER || klass == SHARED_BUFFER) {\n return $length !== undefined\n ? new Base(data, toOffset($offset, BYTES), $length)\n : $offset !== undefined\n ? new Base(data, toOffset($offset, BYTES))\n : new Base(data);\n }\n if (TYPED_ARRAY in data) return fromList(TypedArray, data);\n return $from.call(TypedArray, data);\n });\n arrayForEach(TAC !== Function.prototype ? gOPN(Base).concat(gOPN(TAC)) : gOPN(Base), function (key) {\n if (!(key in TypedArray)) hide(TypedArray, key, Base[key]);\n });\n TypedArray[PROTOTYPE] = TypedArrayPrototype;\n if (!LIBRARY) TypedArrayPrototype.constructor = TypedArray;\n }\n var $nativeIterator = TypedArrayPrototype[ITERATOR];\n var CORRECT_ITER_NAME = !!$nativeIterator\n && ($nativeIterator.name == 'values' || $nativeIterator.name == undefined);\n var $iterator = $iterators.values;\n hide(TypedArray, TYPED_CONSTRUCTOR, true);\n hide(TypedArrayPrototype, TYPED_ARRAY, NAME);\n hide(TypedArrayPrototype, VIEW, true);\n hide(TypedArrayPrototype, DEF_CONSTRUCTOR, TypedArray);\n\n if (CLAMPED ? new TypedArray(1)[TAG] != NAME : !(TAG in TypedArrayPrototype)) {\n dP(TypedArrayPrototype, TAG, {\n get: function () { return NAME; }\n });\n }\n\n O[NAME] = TypedArray;\n\n $export($export.G + $export.W + $export.F * (TypedArray != Base), O);\n\n $export($export.S, NAME, {\n BYTES_PER_ELEMENT: BYTES\n });\n\n $export($export.S + $export.F * fails(function () { Base.of.call(TypedArray, 1); }), NAME, {\n from: $from,\n of: $of\n });\n\n if (!(BYTES_PER_ELEMENT in TypedArrayPrototype)) hide(TypedArrayPrototype, BYTES_PER_ELEMENT, BYTES);\n\n $export($export.P, NAME, proto);\n\n setSpecies(NAME);\n\n $export($export.P + $export.F * FORCED_SET, NAME, { set: $set });\n\n $export($export.P + $export.F * !CORRECT_ITER_NAME, NAME, $iterators);\n\n if (!LIBRARY && TypedArrayPrototype.toString != arrayToString) TypedArrayPrototype.toString = arrayToString;\n\n $export($export.P + $export.F * fails(function () {\n new TypedArray(1).slice();\n }), NAME, { slice: $slice });\n\n $export($export.P + $export.F * (fails(function () {\n return [1, 2].toLocaleString() != new TypedArray([1, 2]).toLocaleString();\n }) || !fails(function () {\n TypedArrayPrototype.toLocaleString.call([1, 2]);\n })), NAME, { toLocaleString: $toLocaleString });\n\n Iterators[NAME] = CORRECT_ITER_NAME ? $nativeIterator : $iterator;\n if (!LIBRARY && !CORRECT_ITER_NAME) hide(TypedArrayPrototype, ITERATOR, $iterator);\n };\n} else module.exports = function () { /* empty */ };\n","'use strict';\nvar global = require('./_global');\nvar DESCRIPTORS = require('./_descriptors');\nvar LIBRARY = require('./_library');\nvar $typed = require('./_typed');\nvar hide = require('./_hide');\nvar redefineAll = require('./_redefine-all');\nvar fails = require('./_fails');\nvar anInstance = require('./_an-instance');\nvar toInteger = require('./_to-integer');\nvar toLength = require('./_to-length');\nvar toIndex = require('./_to-index');\nvar gOPN = require('./_object-gopn').f;\nvar dP = require('./_object-dp').f;\nvar arrayFill = require('./_array-fill');\nvar setToStringTag = require('./_set-to-string-tag');\nvar ARRAY_BUFFER = 'ArrayBuffer';\nvar DATA_VIEW = 'DataView';\nvar PROTOTYPE = 'prototype';\nvar WRONG_LENGTH = 'Wrong length!';\nvar WRONG_INDEX = 'Wrong index!';\nvar $ArrayBuffer = global[ARRAY_BUFFER];\nvar $DataView = global[DATA_VIEW];\nvar Math = global.Math;\nvar RangeError = global.RangeError;\n// eslint-disable-next-line no-shadow-restricted-names\nvar Infinity = global.Infinity;\nvar BaseBuffer = $ArrayBuffer;\nvar abs = Math.abs;\nvar pow = Math.pow;\nvar floor = Math.floor;\nvar log = Math.log;\nvar LN2 = Math.LN2;\nvar BUFFER = 'buffer';\nvar BYTE_LENGTH = 'byteLength';\nvar BYTE_OFFSET = 'byteOffset';\nvar $BUFFER = DESCRIPTORS ? '_b' : BUFFER;\nvar $LENGTH = DESCRIPTORS ? '_l' : BYTE_LENGTH;\nvar $OFFSET = DESCRIPTORS ? '_o' : BYTE_OFFSET;\n\n// IEEE754 conversions based on https://github.com/feross/ieee754\nfunction packIEEE754(value, mLen, nBytes) {\n var buffer = new Array(nBytes);\n var eLen = nBytes * 8 - mLen - 1;\n var eMax = (1 << eLen) - 1;\n var eBias = eMax >> 1;\n var rt = mLen === 23 ? pow(2, -24) - pow(2, -77) : 0;\n var i = 0;\n var s = value < 0 || value === 0 && 1 / value < 0 ? 1 : 0;\n var e, m, c;\n value = abs(value);\n // eslint-disable-next-line no-self-compare\n if (value != value || value === Infinity) {\n // eslint-disable-next-line no-self-compare\n m = value != value ? 1 : 0;\n e = eMax;\n } else {\n e = floor(log(value) / LN2);\n if (value * (c = pow(2, -e)) < 1) {\n e--;\n c *= 2;\n }\n if (e + eBias >= 1) {\n value += rt / c;\n } else {\n value += rt * pow(2, 1 - eBias);\n }\n if (value * c >= 2) {\n e++;\n c /= 2;\n }\n if (e + eBias >= eMax) {\n m = 0;\n e = eMax;\n } else if (e + eBias >= 1) {\n m = (value * c - 1) * pow(2, mLen);\n e = e + eBias;\n } else {\n m = value * pow(2, eBias - 1) * pow(2, mLen);\n e = 0;\n }\n }\n for (; mLen >= 8; buffer[i++] = m & 255, m /= 256, mLen -= 8);\n e = e << mLen | m;\n eLen += mLen;\n for (; eLen > 0; buffer[i++] = e & 255, e /= 256, eLen -= 8);\n buffer[--i] |= s * 128;\n return buffer;\n}\nfunction unpackIEEE754(buffer, mLen, nBytes) {\n var eLen = nBytes * 8 - mLen - 1;\n var eMax = (1 << eLen) - 1;\n var eBias = eMax >> 1;\n var nBits = eLen - 7;\n var i = nBytes - 1;\n var s = buffer[i--];\n var e = s & 127;\n var m;\n s >>= 7;\n for (; nBits > 0; e = e * 256 + buffer[i], i--, nBits -= 8);\n m = e & (1 << -nBits) - 1;\n e >>= -nBits;\n nBits += mLen;\n for (; nBits > 0; m = m * 256 + buffer[i], i--, nBits -= 8);\n if (e === 0) {\n e = 1 - eBias;\n } else if (e === eMax) {\n return m ? NaN : s ? -Infinity : Infinity;\n } else {\n m = m + pow(2, mLen);\n e = e - eBias;\n } return (s ? -1 : 1) * m * pow(2, e - mLen);\n}\n\nfunction unpackI32(bytes) {\n return bytes[3] << 24 | bytes[2] << 16 | bytes[1] << 8 | bytes[0];\n}\nfunction packI8(it) {\n return [it & 0xff];\n}\nfunction packI16(it) {\n return [it & 0xff, it >> 8 & 0xff];\n}\nfunction packI32(it) {\n return [it & 0xff, it >> 8 & 0xff, it >> 16 & 0xff, it >> 24 & 0xff];\n}\nfunction packF64(it) {\n return packIEEE754(it, 52, 8);\n}\nfunction packF32(it) {\n return packIEEE754(it, 23, 4);\n}\n\nfunction addGetter(C, key, internal) {\n dP(C[PROTOTYPE], key, { get: function () { return this[internal]; } });\n}\n\nfunction get(view, bytes, index, isLittleEndian) {\n var numIndex = +index;\n var intIndex = toIndex(numIndex);\n if (intIndex + bytes > view[$LENGTH]) throw RangeError(WRONG_INDEX);\n var store = view[$BUFFER]._b;\n var start = intIndex + view[$OFFSET];\n var pack = store.slice(start, start + bytes);\n return isLittleEndian ? pack : pack.reverse();\n}\nfunction set(view, bytes, index, conversion, value, isLittleEndian) {\n var numIndex = +index;\n var intIndex = toIndex(numIndex);\n if (intIndex + bytes > view[$LENGTH]) throw RangeError(WRONG_INDEX);\n var store = view[$BUFFER]._b;\n var start = intIndex + view[$OFFSET];\n var pack = conversion(+value);\n for (var i = 0; i < bytes; i++) store[start + i] = pack[isLittleEndian ? i : bytes - i - 1];\n}\n\nif (!$typed.ABV) {\n $ArrayBuffer = function ArrayBuffer(length) {\n anInstance(this, $ArrayBuffer, ARRAY_BUFFER);\n var byteLength = toIndex(length);\n this._b = arrayFill.call(new Array(byteLength), 0);\n this[$LENGTH] = byteLength;\n };\n\n $DataView = function DataView(buffer, byteOffset, byteLength) {\n anInstance(this, $DataView, DATA_VIEW);\n anInstance(buffer, $ArrayBuffer, DATA_VIEW);\n var bufferLength = buffer[$LENGTH];\n var offset = toInteger(byteOffset);\n if (offset < 0 || offset > bufferLength) throw RangeError('Wrong offset!');\n byteLength = byteLength === undefined ? bufferLength - offset : toLength(byteLength);\n if (offset + byteLength > bufferLength) throw RangeError(WRONG_LENGTH);\n this[$BUFFER] = buffer;\n this[$OFFSET] = offset;\n this[$LENGTH] = byteLength;\n };\n\n if (DESCRIPTORS) {\n addGetter($ArrayBuffer, BYTE_LENGTH, '_l');\n addGetter($DataView, BUFFER, '_b');\n addGetter($DataView, BYTE_LENGTH, '_l');\n addGetter($DataView, BYTE_OFFSET, '_o');\n }\n\n redefineAll($DataView[PROTOTYPE], {\n getInt8: function getInt8(byteOffset) {\n return get(this, 1, byteOffset)[0] << 24 >> 24;\n },\n getUint8: function getUint8(byteOffset) {\n return get(this, 1, byteOffset)[0];\n },\n getInt16: function getInt16(byteOffset /* , littleEndian */) {\n var bytes = get(this, 2, byteOffset, arguments[1]);\n return (bytes[1] << 8 | bytes[0]) << 16 >> 16;\n },\n getUint16: function getUint16(byteOffset /* , littleEndian */) {\n var bytes = get(this, 2, byteOffset, arguments[1]);\n return bytes[1] << 8 | bytes[0];\n },\n getInt32: function getInt32(byteOffset /* , littleEndian */) {\n return unpackI32(get(this, 4, byteOffset, arguments[1]));\n },\n getUint32: function getUint32(byteOffset /* , littleEndian */) {\n return unpackI32(get(this, 4, byteOffset, arguments[1])) >>> 0;\n },\n getFloat32: function getFloat32(byteOffset /* , littleEndian */) {\n return unpackIEEE754(get(this, 4, byteOffset, arguments[1]), 23, 4);\n },\n getFloat64: function getFloat64(byteOffset /* , littleEndian */) {\n return unpackIEEE754(get(this, 8, byteOffset, arguments[1]), 52, 8);\n },\n setInt8: function setInt8(byteOffset, value) {\n set(this, 1, byteOffset, packI8, value);\n },\n setUint8: function setUint8(byteOffset, value) {\n set(this, 1, byteOffset, packI8, value);\n },\n setInt16: function setInt16(byteOffset, value /* , littleEndian */) {\n set(this, 2, byteOffset, packI16, value, arguments[2]);\n },\n setUint16: function setUint16(byteOffset, value /* , littleEndian */) {\n set(this, 2, byteOffset, packI16, value, arguments[2]);\n },\n setInt32: function setInt32(byteOffset, value /* , littleEndian */) {\n set(this, 4, byteOffset, packI32, value, arguments[2]);\n },\n setUint32: function setUint32(byteOffset, value /* , littleEndian */) {\n set(this, 4, byteOffset, packI32, value, arguments[2]);\n },\n setFloat32: function setFloat32(byteOffset, value /* , littleEndian */) {\n set(this, 4, byteOffset, packF32, value, arguments[2]);\n },\n setFloat64: function setFloat64(byteOffset, value /* , littleEndian */) {\n set(this, 8, byteOffset, packF64, value, arguments[2]);\n }\n });\n} else {\n if (!fails(function () {\n $ArrayBuffer(1);\n }) || !fails(function () {\n new $ArrayBuffer(-1); // eslint-disable-line no-new\n }) || fails(function () {\n new $ArrayBuffer(); // eslint-disable-line no-new\n new $ArrayBuffer(1.5); // eslint-disable-line no-new\n new $ArrayBuffer(NaN); // eslint-disable-line no-new\n return $ArrayBuffer.name != ARRAY_BUFFER;\n })) {\n $ArrayBuffer = function ArrayBuffer(length) {\n anInstance(this, $ArrayBuffer);\n return new BaseBuffer(toIndex(length));\n };\n var ArrayBufferProto = $ArrayBuffer[PROTOTYPE] = BaseBuffer[PROTOTYPE];\n for (var keys = gOPN(BaseBuffer), j = 0, key; keys.length > j;) {\n if (!((key = keys[j++]) in $ArrayBuffer)) hide($ArrayBuffer, key, BaseBuffer[key]);\n }\n if (!LIBRARY) ArrayBufferProto.constructor = $ArrayBuffer;\n }\n // iOS Safari 7.x bug\n var view = new $DataView(new $ArrayBuffer(2));\n var $setInt8 = $DataView[PROTOTYPE].setInt8;\n view.setInt8(0, 2147483648);\n view.setInt8(1, 2147483649);\n if (view.getInt8(0) || !view.getInt8(1)) redefineAll($DataView[PROTOTYPE], {\n setInt8: function setInt8(byteOffset, value) {\n $setInt8.call(this, byteOffset, value << 24 >> 24);\n },\n setUint8: function setUint8(byteOffset, value) {\n $setInt8.call(this, byteOffset, value << 24 >> 24);\n }\n }, true);\n}\nsetToStringTag($ArrayBuffer, ARRAY_BUFFER);\nsetToStringTag($DataView, DATA_VIEW);\nhide($DataView[PROTOTYPE], $typed.VIEW, true);\nexports[ARRAY_BUFFER] = $ArrayBuffer;\nexports[DATA_VIEW] = $DataView;\n","var global = require('./_global');\nvar hide = require('./_hide');\nvar uid = require('./_uid');\nvar TYPED = uid('typed_array');\nvar VIEW = uid('view');\nvar ABV = !!(global.ArrayBuffer && global.DataView);\nvar CONSTR = ABV;\nvar i = 0;\nvar l = 9;\nvar Typed;\n\nvar TypedArrayConstructors = (\n 'Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array'\n).split(',');\n\nwhile (i < l) {\n if (Typed = global[TypedArrayConstructors[i++]]) {\n hide(Typed.prototype, TYPED, true);\n hide(Typed.prototype, VIEW, true);\n } else CONSTR = false;\n}\n\nmodule.exports = {\n ABV: ABV,\n CONSTR: CONSTR,\n TYPED: TYPED,\n VIEW: VIEW\n};\n","var id = 0;\nvar px = Math.random();\nmodule.exports = function (key) {\n return 'Symbol('.concat(key === undefined ? '' : key, ')_', (++id + px).toString(36));\n};\n","var global = require('./_global');\nvar navigator = global.navigator;\n\nmodule.exports = navigator && navigator.userAgent || '';\n","var isObject = require('./_is-object');\nmodule.exports = function (it, TYPE) {\n if (!isObject(it) || it._t !== TYPE) throw TypeError('Incompatible receiver, ' + TYPE + ' required!');\n return it;\n};\n","var global = require('./_global');\nvar core = require('./_core');\nvar LIBRARY = require('./_library');\nvar wksExt = require('./_wks-ext');\nvar defineProperty = require('./_object-dp').f;\nmodule.exports = function (name) {\n var $Symbol = core.Symbol || (core.Symbol = LIBRARY ? {} : global.Symbol || {});\n if (name.charAt(0) != '_' && !(name in $Symbol)) defineProperty($Symbol, name, { value: wksExt.f(name) });\n};\n","exports.f = require('./_wks');\n","var store = require('./_shared')('wks');\nvar uid = require('./_uid');\nvar Symbol = require('./_global').Symbol;\nvar USE_SYMBOL = typeof Symbol == 'function';\n\nvar $exports = module.exports = function (name) {\n return store[name] || (store[name] =\n USE_SYMBOL && Symbol[name] || (USE_SYMBOL ? Symbol : uid)('Symbol.' + name));\n};\n\n$exports.store = store;\n","var classof = require('./_classof');\nvar ITERATOR = require('./_wks')('iterator');\nvar Iterators = require('./_iterators');\nmodule.exports = require('./_core').getIteratorMethod = function (it) {\n if (it != undefined) return it[ITERATOR]\n || it['@@iterator']\n || Iterators[classof(it)];\n};\n","// 22.1.3.3 Array.prototype.copyWithin(target, start, end = this.length)\nvar $export = require('./_export');\n\n$export($export.P, 'Array', { copyWithin: require('./_array-copy-within') });\n\nrequire('./_add-to-unscopables')('copyWithin');\n","'use strict';\nvar $export = require('./_export');\nvar $every = require('./_array-methods')(4);\n\n$export($export.P + $export.F * !require('./_strict-method')([].every, true), 'Array', {\n // 22.1.3.5 / 15.4.4.16 Array.prototype.every(callbackfn [, thisArg])\n every: function every(callbackfn /* , thisArg */) {\n return $every(this, callbackfn, arguments[1]);\n }\n});\n","// 22.1.3.6 Array.prototype.fill(value, start = 0, end = this.length)\nvar $export = require('./_export');\n\n$export($export.P, 'Array', { fill: require('./_array-fill') });\n\nrequire('./_add-to-unscopables')('fill');\n","'use strict';\nvar $export = require('./_export');\nvar $filter = require('./_array-methods')(2);\n\n$export($export.P + $export.F * !require('./_strict-method')([].filter, true), 'Array', {\n // 22.1.3.7 / 15.4.4.20 Array.prototype.filter(callbackfn [, thisArg])\n filter: function filter(callbackfn /* , thisArg */) {\n return $filter(this, callbackfn, arguments[1]);\n }\n});\n","'use strict';\n// 22.1.3.9 Array.prototype.findIndex(predicate, thisArg = undefined)\nvar $export = require('./_export');\nvar $find = require('./_array-methods')(6);\nvar KEY = 'findIndex';\nvar forced = true;\n// Shouldn't skip holes\nif (KEY in []) Array(1)[KEY](function () { forced = false; });\n$export($export.P + $export.F * forced, 'Array', {\n findIndex: function findIndex(callbackfn /* , that = undefined */) {\n return $find(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\nrequire('./_add-to-unscopables')(KEY);\n","'use strict';\n// 22.1.3.8 Array.prototype.find(predicate, thisArg = undefined)\nvar $export = require('./_export');\nvar $find = require('./_array-methods')(5);\nvar KEY = 'find';\nvar forced = true;\n// Shouldn't skip holes\nif (KEY in []) Array(1)[KEY](function () { forced = false; });\n$export($export.P + $export.F * forced, 'Array', {\n find: function find(callbackfn /* , that = undefined */) {\n return $find(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\nrequire('./_add-to-unscopables')(KEY);\n","'use strict';\nvar $export = require('./_export');\nvar $forEach = require('./_array-methods')(0);\nvar STRICT = require('./_strict-method')([].forEach, true);\n\n$export($export.P + $export.F * !STRICT, 'Array', {\n // 22.1.3.10 / 15.4.4.18 Array.prototype.forEach(callbackfn [, thisArg])\n forEach: function forEach(callbackfn /* , thisArg */) {\n return $forEach(this, callbackfn, arguments[1]);\n }\n});\n","'use strict';\nvar ctx = require('./_ctx');\nvar $export = require('./_export');\nvar toObject = require('./_to-object');\nvar call = require('./_iter-call');\nvar isArrayIter = require('./_is-array-iter');\nvar toLength = require('./_to-length');\nvar createProperty = require('./_create-property');\nvar getIterFn = require('./core.get-iterator-method');\n\n$export($export.S + $export.F * !require('./_iter-detect')(function (iter) { Array.from(iter); }), 'Array', {\n // 22.1.2.1 Array.from(arrayLike, mapfn = undefined, thisArg = undefined)\n from: function from(arrayLike /* , mapfn = undefined, thisArg = undefined */) {\n var O = toObject(arrayLike);\n var C = typeof this == 'function' ? this : Array;\n var aLen = arguments.length;\n var mapfn = aLen > 1 ? arguments[1] : undefined;\n var mapping = mapfn !== undefined;\n var index = 0;\n var iterFn = getIterFn(O);\n var length, result, step, iterator;\n if (mapping) mapfn = ctx(mapfn, aLen > 2 ? arguments[2] : undefined, 2);\n // if object isn't iterable or it's array with default iterator - use simple case\n if (iterFn != undefined && !(C == Array && isArrayIter(iterFn))) {\n for (iterator = iterFn.call(O), result = new C(); !(step = iterator.next()).done; index++) {\n createProperty(result, index, mapping ? call(iterator, mapfn, [step.value, index], true) : step.value);\n }\n } else {\n length = toLength(O.length);\n for (result = new C(length); length > index; index++) {\n createProperty(result, index, mapping ? mapfn(O[index], index) : O[index]);\n }\n }\n result.length = index;\n return result;\n }\n});\n","'use strict';\nvar $export = require('./_export');\nvar $indexOf = require('./_array-includes')(false);\nvar $native = [].indexOf;\nvar NEGATIVE_ZERO = !!$native && 1 / [1].indexOf(1, -0) < 0;\n\n$export($export.P + $export.F * (NEGATIVE_ZERO || !require('./_strict-method')($native)), 'Array', {\n // 22.1.3.11 / 15.4.4.14 Array.prototype.indexOf(searchElement [, fromIndex])\n indexOf: function indexOf(searchElement /* , fromIndex = 0 */) {\n return NEGATIVE_ZERO\n // convert -0 to +0\n ? $native.apply(this, arguments) || 0\n : $indexOf(this, searchElement, arguments[1]);\n }\n});\n","// 22.1.2.2 / 15.4.3.2 Array.isArray(arg)\nvar $export = require('./_export');\n\n$export($export.S, 'Array', { isArray: require('./_is-array') });\n","'use strict';\nvar addToUnscopables = require('./_add-to-unscopables');\nvar step = require('./_iter-step');\nvar Iterators = require('./_iterators');\nvar toIObject = require('./_to-iobject');\n\n// 22.1.3.4 Array.prototype.entries()\n// 22.1.3.13 Array.prototype.keys()\n// 22.1.3.29 Array.prototype.values()\n// 22.1.3.30 Array.prototype[@@iterator]()\nmodule.exports = require('./_iter-define')(Array, 'Array', function (iterated, kind) {\n this._t = toIObject(iterated); // target\n this._i = 0; // next index\n this._k = kind; // kind\n// 22.1.5.2.1 %ArrayIteratorPrototype%.next()\n}, function () {\n var O = this._t;\n var kind = this._k;\n var index = this._i++;\n if (!O || index >= O.length) {\n this._t = undefined;\n return step(1);\n }\n if (kind == 'keys') return step(0, index);\n if (kind == 'values') return step(0, O[index]);\n return step(0, [index, O[index]]);\n}, 'values');\n\n// argumentsList[@@iterator] is %ArrayProto_values% (9.4.4.6, 9.4.4.7)\nIterators.Arguments = Iterators.Array;\n\naddToUnscopables('keys');\naddToUnscopables('values');\naddToUnscopables('entries');\n","'use strict';\n// 22.1.3.13 Array.prototype.join(separator)\nvar $export = require('./_export');\nvar toIObject = require('./_to-iobject');\nvar arrayJoin = [].join;\n\n// fallback for not array-like strings\n$export($export.P + $export.F * (require('./_iobject') != Object || !require('./_strict-method')(arrayJoin)), 'Array', {\n join: function join(separator) {\n return arrayJoin.call(toIObject(this), separator === undefined ? ',' : separator);\n }\n});\n","'use strict';\nvar $export = require('./_export');\nvar toIObject = require('./_to-iobject');\nvar toInteger = require('./_to-integer');\nvar toLength = require('./_to-length');\nvar $native = [].lastIndexOf;\nvar NEGATIVE_ZERO = !!$native && 1 / [1].lastIndexOf(1, -0) < 0;\n\n$export($export.P + $export.F * (NEGATIVE_ZERO || !require('./_strict-method')($native)), 'Array', {\n // 22.1.3.14 / 15.4.4.15 Array.prototype.lastIndexOf(searchElement [, fromIndex])\n lastIndexOf: function lastIndexOf(searchElement /* , fromIndex = @[*-1] */) {\n // convert -0 to +0\n if (NEGATIVE_ZERO) return $native.apply(this, arguments) || 0;\n var O = toIObject(this);\n var length = toLength(O.length);\n var index = length - 1;\n if (arguments.length > 1) index = Math.min(index, toInteger(arguments[1]));\n if (index < 0) index = length + index;\n for (;index >= 0; index--) if (index in O) if (O[index] === searchElement) return index || 0;\n return -1;\n }\n});\n","'use strict';\nvar $export = require('./_export');\nvar $map = require('./_array-methods')(1);\n\n$export($export.P + $export.F * !require('./_strict-method')([].map, true), 'Array', {\n // 22.1.3.15 / 15.4.4.19 Array.prototype.map(callbackfn [, thisArg])\n map: function map(callbackfn /* , thisArg */) {\n return $map(this, callbackfn, arguments[1]);\n }\n});\n","'use strict';\nvar $export = require('./_export');\nvar createProperty = require('./_create-property');\n\n// WebKit Array.of isn't generic\n$export($export.S + $export.F * require('./_fails')(function () {\n function F() { /* empty */ }\n return !(Array.of.call(F) instanceof F);\n}), 'Array', {\n // 22.1.2.3 Array.of( ...items)\n of: function of(/* ...args */) {\n var index = 0;\n var aLen = arguments.length;\n var result = new (typeof this == 'function' ? this : Array)(aLen);\n while (aLen > index) createProperty(result, index, arguments[index++]);\n result.length = aLen;\n return result;\n }\n});\n","'use strict';\nvar $export = require('./_export');\nvar $reduce = require('./_array-reduce');\n\n$export($export.P + $export.F * !require('./_strict-method')([].reduceRight, true), 'Array', {\n // 22.1.3.19 / 15.4.4.22 Array.prototype.reduceRight(callbackfn [, initialValue])\n reduceRight: function reduceRight(callbackfn /* , initialValue */) {\n return $reduce(this, callbackfn, arguments.length, arguments[1], true);\n }\n});\n","'use strict';\nvar $export = require('./_export');\nvar $reduce = require('./_array-reduce');\n\n$export($export.P + $export.F * !require('./_strict-method')([].reduce, true), 'Array', {\n // 22.1.3.18 / 15.4.4.21 Array.prototype.reduce(callbackfn [, initialValue])\n reduce: function reduce(callbackfn /* , initialValue */) {\n return $reduce(this, callbackfn, arguments.length, arguments[1], false);\n }\n});\n","'use strict';\nvar $export = require('./_export');\nvar html = require('./_html');\nvar cof = require('./_cof');\nvar toAbsoluteIndex = require('./_to-absolute-index');\nvar toLength = require('./_to-length');\nvar arraySlice = [].slice;\n\n// fallback for not array-like ES3 strings and DOM objects\n$export($export.P + $export.F * require('./_fails')(function () {\n if (html) arraySlice.call(html);\n}), 'Array', {\n slice: function slice(begin, end) {\n var len = toLength(this.length);\n var klass = cof(this);\n end = end === undefined ? len : end;\n if (klass == 'Array') return arraySlice.call(this, begin, end);\n var start = toAbsoluteIndex(begin, len);\n var upTo = toAbsoluteIndex(end, len);\n var size = toLength(upTo - start);\n var cloned = new Array(size);\n var i = 0;\n for (; i < size; i++) cloned[i] = klass == 'String'\n ? this.charAt(start + i)\n : this[start + i];\n return cloned;\n }\n});\n","'use strict';\nvar $export = require('./_export');\nvar $some = require('./_array-methods')(3);\n\n$export($export.P + $export.F * !require('./_strict-method')([].some, true), 'Array', {\n // 22.1.3.23 / 15.4.4.17 Array.prototype.some(callbackfn [, thisArg])\n some: function some(callbackfn /* , thisArg */) {\n return $some(this, callbackfn, arguments[1]);\n }\n});\n","'use strict';\nvar $export = require('./_export');\nvar aFunction = require('./_a-function');\nvar toObject = require('./_to-object');\nvar fails = require('./_fails');\nvar $sort = [].sort;\nvar test = [1, 2, 3];\n\n$export($export.P + $export.F * (fails(function () {\n // IE8-\n test.sort(undefined);\n}) || !fails(function () {\n // V8 bug\n test.sort(null);\n // Old WebKit\n}) || !require('./_strict-method')($sort)), 'Array', {\n // 22.1.3.25 Array.prototype.sort(comparefn)\n sort: function sort(comparefn) {\n return comparefn === undefined\n ? $sort.call(toObject(this))\n : $sort.call(toObject(this), aFunction(comparefn));\n }\n});\n","require('./_set-species')('Array');\n","// 20.3.3.1 / 15.9.4.4 Date.now()\nvar $export = require('./_export');\n\n$export($export.S, 'Date', { now: function () { return new Date().getTime(); } });\n","// 20.3.4.36 / 15.9.5.43 Date.prototype.toISOString()\nvar $export = require('./_export');\nvar toISOString = require('./_date-to-iso-string');\n\n// PhantomJS / old WebKit has a broken implementations\n$export($export.P + $export.F * (Date.prototype.toISOString !== toISOString), 'Date', {\n toISOString: toISOString\n});\n","'use strict';\nvar $export = require('./_export');\nvar toObject = require('./_to-object');\nvar toPrimitive = require('./_to-primitive');\n\n$export($export.P + $export.F * require('./_fails')(function () {\n return new Date(NaN).toJSON() !== null\n || Date.prototype.toJSON.call({ toISOString: function () { return 1; } }) !== 1;\n}), 'Date', {\n // eslint-disable-next-line no-unused-vars\n toJSON: function toJSON(key) {\n var O = toObject(this);\n var pv = toPrimitive(O);\n return typeof pv == 'number' && !isFinite(pv) ? null : O.toISOString();\n }\n});\n","var TO_PRIMITIVE = require('./_wks')('toPrimitive');\nvar proto = Date.prototype;\n\nif (!(TO_PRIMITIVE in proto)) require('./_hide')(proto, TO_PRIMITIVE, require('./_date-to-primitive'));\n","var DateProto = Date.prototype;\nvar INVALID_DATE = 'Invalid Date';\nvar TO_STRING = 'toString';\nvar $toString = DateProto[TO_STRING];\nvar getTime = DateProto.getTime;\nif (new Date(NaN) + '' != INVALID_DATE) {\n require('./_redefine')(DateProto, TO_STRING, function toString() {\n var value = getTime.call(this);\n // eslint-disable-next-line no-self-compare\n return value === value ? $toString.call(this) : INVALID_DATE;\n });\n}\n","// 19.2.3.2 / 15.3.4.5 Function.prototype.bind(thisArg, args...)\nvar $export = require('./_export');\n\n$export($export.P, 'Function', { bind: require('./_bind') });\n","'use strict';\nvar isObject = require('./_is-object');\nvar getPrototypeOf = require('./_object-gpo');\nvar HAS_INSTANCE = require('./_wks')('hasInstance');\nvar FunctionProto = Function.prototype;\n// 19.2.3.6 Function.prototype[@@hasInstance](V)\nif (!(HAS_INSTANCE in FunctionProto)) require('./_object-dp').f(FunctionProto, HAS_INSTANCE, { value: function (O) {\n if (typeof this != 'function' || !isObject(O)) return false;\n if (!isObject(this.prototype)) return O instanceof this;\n // for environment w/o native `@@hasInstance` logic enough `instanceof`, but add this:\n while (O = getPrototypeOf(O)) if (this.prototype === O) return true;\n return false;\n} });\n","var dP = require('./_object-dp').f;\nvar FProto = Function.prototype;\nvar nameRE = /^\\s*function ([^ (]*)/;\nvar NAME = 'name';\n\n// 19.2.4.2 name\nNAME in FProto || require('./_descriptors') && dP(FProto, NAME, {\n configurable: true,\n get: function () {\n try {\n return ('' + this).match(nameRE)[1];\n } catch (e) {\n return '';\n }\n }\n});\n","'use strict';\nvar strong = require('./_collection-strong');\nvar validate = require('./_validate-collection');\nvar MAP = 'Map';\n\n// 23.1 Map Objects\nmodule.exports = require('./_collection')(MAP, function (get) {\n return function Map() { return get(this, arguments.length > 0 ? arguments[0] : undefined); };\n}, {\n // 23.1.3.6 Map.prototype.get(key)\n get: function get(key) {\n var entry = strong.getEntry(validate(this, MAP), key);\n return entry && entry.v;\n },\n // 23.1.3.9 Map.prototype.set(key, value)\n set: function set(key, value) {\n return strong.def(validate(this, MAP), key === 0 ? 0 : key, value);\n }\n}, strong, true);\n","// 20.2.2.3 Math.acosh(x)\nvar $export = require('./_export');\nvar log1p = require('./_math-log1p');\nvar sqrt = Math.sqrt;\nvar $acosh = Math.acosh;\n\n$export($export.S + $export.F * !($acosh\n // V8 bug: https://code.google.com/p/v8/issues/detail?id=3509\n && Math.floor($acosh(Number.MAX_VALUE)) == 710\n // Tor Browser bug: Math.acosh(Infinity) -> NaN\n && $acosh(Infinity) == Infinity\n), 'Math', {\n acosh: function acosh(x) {\n return (x = +x) < 1 ? NaN : x > 94906265.62425156\n ? Math.log(x) + Math.LN2\n : log1p(x - 1 + sqrt(x - 1) * sqrt(x + 1));\n }\n});\n","// 20.2.2.5 Math.asinh(x)\nvar $export = require('./_export');\nvar $asinh = Math.asinh;\n\nfunction asinh(x) {\n return !isFinite(x = +x) || x == 0 ? x : x < 0 ? -asinh(-x) : Math.log(x + Math.sqrt(x * x + 1));\n}\n\n// Tor Browser bug: Math.asinh(0) -> -0\n$export($export.S + $export.F * !($asinh && 1 / $asinh(0) > 0), 'Math', { asinh: asinh });\n","// 20.2.2.7 Math.atanh(x)\nvar $export = require('./_export');\nvar $atanh = Math.atanh;\n\n// Tor Browser bug: Math.atanh(-0) -> 0\n$export($export.S + $export.F * !($atanh && 1 / $atanh(-0) < 0), 'Math', {\n atanh: function atanh(x) {\n return (x = +x) == 0 ? x : Math.log((1 + x) / (1 - x)) / 2;\n }\n});\n","// 20.2.2.9 Math.cbrt(x)\nvar $export = require('./_export');\nvar sign = require('./_math-sign');\n\n$export($export.S, 'Math', {\n cbrt: function cbrt(x) {\n return sign(x = +x) * Math.pow(Math.abs(x), 1 / 3);\n }\n});\n","// 20.2.2.11 Math.clz32(x)\nvar $export = require('./_export');\n\n$export($export.S, 'Math', {\n clz32: function clz32(x) {\n return (x >>>= 0) ? 31 - Math.floor(Math.log(x + 0.5) * Math.LOG2E) : 32;\n }\n});\n","// 20.2.2.12 Math.cosh(x)\nvar $export = require('./_export');\nvar exp = Math.exp;\n\n$export($export.S, 'Math', {\n cosh: function cosh(x) {\n return (exp(x = +x) + exp(-x)) / 2;\n }\n});\n","// 20.2.2.14 Math.expm1(x)\nvar $export = require('./_export');\nvar $expm1 = require('./_math-expm1');\n\n$export($export.S + $export.F * ($expm1 != Math.expm1), 'Math', { expm1: $expm1 });\n","// 20.2.2.16 Math.fround(x)\nvar $export = require('./_export');\n\n$export($export.S, 'Math', { fround: require('./_math-fround') });\n","// 20.2.2.17 Math.hypot([value1[, value2[, … ]]])\nvar $export = require('./_export');\nvar abs = Math.abs;\n\n$export($export.S, 'Math', {\n hypot: function hypot(value1, value2) { // eslint-disable-line no-unused-vars\n var sum = 0;\n var i = 0;\n var aLen = arguments.length;\n var larg = 0;\n var arg, div;\n while (i < aLen) {\n arg = abs(arguments[i++]);\n if (larg < arg) {\n div = larg / arg;\n sum = sum * div * div + 1;\n larg = arg;\n } else if (arg > 0) {\n div = arg / larg;\n sum += div * div;\n } else sum += arg;\n }\n return larg === Infinity ? Infinity : larg * Math.sqrt(sum);\n }\n});\n","// 20.2.2.18 Math.imul(x, y)\nvar $export = require('./_export');\nvar $imul = Math.imul;\n\n// some WebKit versions fails with big numbers, some has wrong arity\n$export($export.S + $export.F * require('./_fails')(function () {\n return $imul(0xffffffff, 5) != -5 || $imul.length != 2;\n}), 'Math', {\n imul: function imul(x, y) {\n var UINT16 = 0xffff;\n var xn = +x;\n var yn = +y;\n var xl = UINT16 & xn;\n var yl = UINT16 & yn;\n return 0 | xl * yl + ((UINT16 & xn >>> 16) * yl + xl * (UINT16 & yn >>> 16) << 16 >>> 0);\n }\n});\n","// 20.2.2.21 Math.log10(x)\nvar $export = require('./_export');\n\n$export($export.S, 'Math', {\n log10: function log10(x) {\n return Math.log(x) * Math.LOG10E;\n }\n});\n","// 20.2.2.20 Math.log1p(x)\nvar $export = require('./_export');\n\n$export($export.S, 'Math', { log1p: require('./_math-log1p') });\n","// 20.2.2.22 Math.log2(x)\nvar $export = require('./_export');\n\n$export($export.S, 'Math', {\n log2: function log2(x) {\n return Math.log(x) / Math.LN2;\n }\n});\n","// 20.2.2.28 Math.sign(x)\nvar $export = require('./_export');\n\n$export($export.S, 'Math', { sign: require('./_math-sign') });\n","// 20.2.2.30 Math.sinh(x)\nvar $export = require('./_export');\nvar expm1 = require('./_math-expm1');\nvar exp = Math.exp;\n\n// V8 near Chromium 38 has a problem with very small numbers\n$export($export.S + $export.F * require('./_fails')(function () {\n return !Math.sinh(-2e-17) != -2e-17;\n}), 'Math', {\n sinh: function sinh(x) {\n return Math.abs(x = +x) < 1\n ? (expm1(x) - expm1(-x)) / 2\n : (exp(x - 1) - exp(-x - 1)) * (Math.E / 2);\n }\n});\n","// 20.2.2.33 Math.tanh(x)\nvar $export = require('./_export');\nvar expm1 = require('./_math-expm1');\nvar exp = Math.exp;\n\n$export($export.S, 'Math', {\n tanh: function tanh(x) {\n var a = expm1(x = +x);\n var b = expm1(-x);\n return a == Infinity ? 1 : b == Infinity ? -1 : (a - b) / (exp(x) + exp(-x));\n }\n});\n","// 20.2.2.34 Math.trunc(x)\nvar $export = require('./_export');\n\n$export($export.S, 'Math', {\n trunc: function trunc(it) {\n return (it > 0 ? Math.floor : Math.ceil)(it);\n }\n});\n","'use strict';\nvar global = require('./_global');\nvar has = require('./_has');\nvar cof = require('./_cof');\nvar inheritIfRequired = require('./_inherit-if-required');\nvar toPrimitive = require('./_to-primitive');\nvar fails = require('./_fails');\nvar gOPN = require('./_object-gopn').f;\nvar gOPD = require('./_object-gopd').f;\nvar dP = require('./_object-dp').f;\nvar $trim = require('./_string-trim').trim;\nvar NUMBER = 'Number';\nvar $Number = global[NUMBER];\nvar Base = $Number;\nvar proto = $Number.prototype;\n// Opera ~12 has broken Object#toString\nvar BROKEN_COF = cof(require('./_object-create')(proto)) == NUMBER;\nvar TRIM = 'trim' in String.prototype;\n\n// 7.1.3 ToNumber(argument)\nvar toNumber = function (argument) {\n var it = toPrimitive(argument, false);\n if (typeof it == 'string' && it.length > 2) {\n it = TRIM ? it.trim() : $trim(it, 3);\n var first = it.charCodeAt(0);\n var third, radix, maxCode;\n if (first === 43 || first === 45) {\n third = it.charCodeAt(2);\n if (third === 88 || third === 120) return NaN; // Number('+0x1') should be NaN, old V8 fix\n } else if (first === 48) {\n switch (it.charCodeAt(1)) {\n case 66: case 98: radix = 2; maxCode = 49; break; // fast equal /^0b[01]+$/i\n case 79: case 111: radix = 8; maxCode = 55; break; // fast equal /^0o[0-7]+$/i\n default: return +it;\n }\n for (var digits = it.slice(2), i = 0, l = digits.length, code; i < l; i++) {\n code = digits.charCodeAt(i);\n // parseInt parses a string to a first unavailable symbol\n // but ToNumber should return NaN if a string contains unavailable symbols\n if (code < 48 || code > maxCode) return NaN;\n } return parseInt(digits, radix);\n }\n } return +it;\n};\n\nif (!$Number(' 0o1') || !$Number('0b1') || $Number('+0x1')) {\n $Number = function Number(value) {\n var it = arguments.length < 1 ? 0 : value;\n var that = this;\n return that instanceof $Number\n // check on 1..constructor(foo) case\n && (BROKEN_COF ? fails(function () { proto.valueOf.call(that); }) : cof(that) != NUMBER)\n ? inheritIfRequired(new Base(toNumber(it)), that, $Number) : toNumber(it);\n };\n for (var keys = require('./_descriptors') ? gOPN(Base) : (\n // ES3:\n 'MAX_VALUE,MIN_VALUE,NaN,NEGATIVE_INFINITY,POSITIVE_INFINITY,' +\n // ES6 (in case, if modules with ES6 Number statics required before):\n 'EPSILON,isFinite,isInteger,isNaN,isSafeInteger,MAX_SAFE_INTEGER,' +\n 'MIN_SAFE_INTEGER,parseFloat,parseInt,isInteger'\n ).split(','), j = 0, key; keys.length > j; j++) {\n if (has(Base, key = keys[j]) && !has($Number, key)) {\n dP($Number, key, gOPD(Base, key));\n }\n }\n $Number.prototype = proto;\n proto.constructor = $Number;\n require('./_redefine')(global, NUMBER, $Number);\n}\n","// 20.1.2.1 Number.EPSILON\nvar $export = require('./_export');\n\n$export($export.S, 'Number', { EPSILON: Math.pow(2, -52) });\n","// 20.1.2.2 Number.isFinite(number)\nvar $export = require('./_export');\nvar _isFinite = require('./_global').isFinite;\n\n$export($export.S, 'Number', {\n isFinite: function isFinite(it) {\n return typeof it == 'number' && _isFinite(it);\n }\n});\n","// 20.1.2.3 Number.isInteger(number)\nvar $export = require('./_export');\n\n$export($export.S, 'Number', { isInteger: require('./_is-integer') });\n","// 20.1.2.4 Number.isNaN(number)\nvar $export = require('./_export');\n\n$export($export.S, 'Number', {\n isNaN: function isNaN(number) {\n // eslint-disable-next-line no-self-compare\n return number != number;\n }\n});\n","// 20.1.2.5 Number.isSafeInteger(number)\nvar $export = require('./_export');\nvar isInteger = require('./_is-integer');\nvar abs = Math.abs;\n\n$export($export.S, 'Number', {\n isSafeInteger: function isSafeInteger(number) {\n return isInteger(number) && abs(number) <= 0x1fffffffffffff;\n }\n});\n","// 20.1.2.6 Number.MAX_SAFE_INTEGER\nvar $export = require('./_export');\n\n$export($export.S, 'Number', { MAX_SAFE_INTEGER: 0x1fffffffffffff });\n","// 20.1.2.10 Number.MIN_SAFE_INTEGER\nvar $export = require('./_export');\n\n$export($export.S, 'Number', { MIN_SAFE_INTEGER: -0x1fffffffffffff });\n","var $export = require('./_export');\nvar $parseFloat = require('./_parse-float');\n// 20.1.2.12 Number.parseFloat(string)\n$export($export.S + $export.F * (Number.parseFloat != $parseFloat), 'Number', { parseFloat: $parseFloat });\n","var $export = require('./_export');\nvar $parseInt = require('./_parse-int');\n// 20.1.2.13 Number.parseInt(string, radix)\n$export($export.S + $export.F * (Number.parseInt != $parseInt), 'Number', { parseInt: $parseInt });\n","'use strict';\nvar $export = require('./_export');\nvar toInteger = require('./_to-integer');\nvar aNumberValue = require('./_a-number-value');\nvar repeat = require('./_string-repeat');\nvar $toFixed = 1.0.toFixed;\nvar floor = Math.floor;\nvar data = [0, 0, 0, 0, 0, 0];\nvar ERROR = 'Number.toFixed: incorrect invocation!';\nvar ZERO = '0';\n\nvar multiply = function (n, c) {\n var i = -1;\n var c2 = c;\n while (++i < 6) {\n c2 += n * data[i];\n data[i] = c2 % 1e7;\n c2 = floor(c2 / 1e7);\n }\n};\nvar divide = function (n) {\n var i = 6;\n var c = 0;\n while (--i >= 0) {\n c += data[i];\n data[i] = floor(c / n);\n c = (c % n) * 1e7;\n }\n};\nvar numToString = function () {\n var i = 6;\n var s = '';\n while (--i >= 0) {\n if (s !== '' || i === 0 || data[i] !== 0) {\n var t = String(data[i]);\n s = s === '' ? t : s + repeat.call(ZERO, 7 - t.length) + t;\n }\n } return s;\n};\nvar pow = function (x, n, acc) {\n return n === 0 ? acc : n % 2 === 1 ? pow(x, n - 1, acc * x) : pow(x * x, n / 2, acc);\n};\nvar log = function (x) {\n var n = 0;\n var x2 = x;\n while (x2 >= 4096) {\n n += 12;\n x2 /= 4096;\n }\n while (x2 >= 2) {\n n += 1;\n x2 /= 2;\n } return n;\n};\n\n$export($export.P + $export.F * (!!$toFixed && (\n 0.00008.toFixed(3) !== '0.000' ||\n 0.9.toFixed(0) !== '1' ||\n 1.255.toFixed(2) !== '1.25' ||\n 1000000000000000128.0.toFixed(0) !== '1000000000000000128'\n) || !require('./_fails')(function () {\n // V8 ~ Android 4.3-\n $toFixed.call({});\n})), 'Number', {\n toFixed: function toFixed(fractionDigits) {\n var x = aNumberValue(this, ERROR);\n var f = toInteger(fractionDigits);\n var s = '';\n var m = ZERO;\n var e, z, j, k;\n if (f < 0 || f > 20) throw RangeError(ERROR);\n // eslint-disable-next-line no-self-compare\n if (x != x) return 'NaN';\n if (x <= -1e21 || x >= 1e21) return String(x);\n if (x < 0) {\n s = '-';\n x = -x;\n }\n if (x > 1e-21) {\n e = log(x * pow(2, 69, 1)) - 69;\n z = e < 0 ? x * pow(2, -e, 1) : x / pow(2, e, 1);\n z *= 0x10000000000000;\n e = 52 - e;\n if (e > 0) {\n multiply(0, z);\n j = f;\n while (j >= 7) {\n multiply(1e7, 0);\n j -= 7;\n }\n multiply(pow(10, j, 1), 0);\n j = e - 1;\n while (j >= 23) {\n divide(1 << 23);\n j -= 23;\n }\n divide(1 << j);\n multiply(1, 1);\n divide(2);\n m = numToString();\n } else {\n multiply(0, z);\n multiply(1 << -e, 0);\n m = numToString() + repeat.call(ZERO, f);\n }\n }\n if (f > 0) {\n k = m.length;\n m = s + (k <= f ? '0.' + repeat.call(ZERO, f - k) + m : m.slice(0, k - f) + '.' + m.slice(k - f));\n } else {\n m = s + m;\n } return m;\n }\n});\n","'use strict';\nvar $export = require('./_export');\nvar $fails = require('./_fails');\nvar aNumberValue = require('./_a-number-value');\nvar $toPrecision = 1.0.toPrecision;\n\n$export($export.P + $export.F * ($fails(function () {\n // IE7-\n return $toPrecision.call(1, undefined) !== '1';\n}) || !$fails(function () {\n // V8 ~ Android 4.3-\n $toPrecision.call({});\n})), 'Number', {\n toPrecision: function toPrecision(precision) {\n var that = aNumberValue(this, 'Number#toPrecision: incorrect invocation!');\n return precision === undefined ? $toPrecision.call(that) : $toPrecision.call(that, precision);\n }\n});\n","// 19.1.3.1 Object.assign(target, source)\nvar $export = require('./_export');\n\n$export($export.S + $export.F, 'Object', { assign: require('./_object-assign') });\n","var $export = require('./_export');\n// 19.1.2.2 / 15.2.3.5 Object.create(O [, Properties])\n$export($export.S, 'Object', { create: require('./_object-create') });\n","var $export = require('./_export');\n// 19.1.2.3 / 15.2.3.7 Object.defineProperties(O, Properties)\n$export($export.S + $export.F * !require('./_descriptors'), 'Object', { defineProperties: require('./_object-dps') });\n","var $export = require('./_export');\n// 19.1.2.4 / 15.2.3.6 Object.defineProperty(O, P, Attributes)\n$export($export.S + $export.F * !require('./_descriptors'), 'Object', { defineProperty: require('./_object-dp').f });\n","// 19.1.2.5 Object.freeze(O)\nvar isObject = require('./_is-object');\nvar meta = require('./_meta').onFreeze;\n\nrequire('./_object-sap')('freeze', function ($freeze) {\n return function freeze(it) {\n return $freeze && isObject(it) ? $freeze(meta(it)) : it;\n };\n});\n","// 19.1.2.6 Object.getOwnPropertyDescriptor(O, P)\nvar toIObject = require('./_to-iobject');\nvar $getOwnPropertyDescriptor = require('./_object-gopd').f;\n\nrequire('./_object-sap')('getOwnPropertyDescriptor', function () {\n return function getOwnPropertyDescriptor(it, key) {\n return $getOwnPropertyDescriptor(toIObject(it), key);\n };\n});\n","// 19.1.2.7 Object.getOwnPropertyNames(O)\nrequire('./_object-sap')('getOwnPropertyNames', function () {\n return require('./_object-gopn-ext').f;\n});\n","// 19.1.2.9 Object.getPrototypeOf(O)\nvar toObject = require('./_to-object');\nvar $getPrototypeOf = require('./_object-gpo');\n\nrequire('./_object-sap')('getPrototypeOf', function () {\n return function getPrototypeOf(it) {\n return $getPrototypeOf(toObject(it));\n };\n});\n","// 19.1.2.11 Object.isExtensible(O)\nvar isObject = require('./_is-object');\n\nrequire('./_object-sap')('isExtensible', function ($isExtensible) {\n return function isExtensible(it) {\n return isObject(it) ? $isExtensible ? $isExtensible(it) : true : false;\n };\n});\n","// 19.1.2.12 Object.isFrozen(O)\nvar isObject = require('./_is-object');\n\nrequire('./_object-sap')('isFrozen', function ($isFrozen) {\n return function isFrozen(it) {\n return isObject(it) ? $isFrozen ? $isFrozen(it) : false : true;\n };\n});\n","// 19.1.2.13 Object.isSealed(O)\nvar isObject = require('./_is-object');\n\nrequire('./_object-sap')('isSealed', function ($isSealed) {\n return function isSealed(it) {\n return isObject(it) ? $isSealed ? $isSealed(it) : false : true;\n };\n});\n","// 19.1.3.10 Object.is(value1, value2)\nvar $export = require('./_export');\n$export($export.S, 'Object', { is: require('./_same-value') });\n","// 19.1.2.14 Object.keys(O)\nvar toObject = require('./_to-object');\nvar $keys = require('./_object-keys');\n\nrequire('./_object-sap')('keys', function () {\n return function keys(it) {\n return $keys(toObject(it));\n };\n});\n","// 19.1.2.15 Object.preventExtensions(O)\nvar isObject = require('./_is-object');\nvar meta = require('./_meta').onFreeze;\n\nrequire('./_object-sap')('preventExtensions', function ($preventExtensions) {\n return function preventExtensions(it) {\n return $preventExtensions && isObject(it) ? $preventExtensions(meta(it)) : it;\n };\n});\n","// 19.1.2.17 Object.seal(O)\nvar isObject = require('./_is-object');\nvar meta = require('./_meta').onFreeze;\n\nrequire('./_object-sap')('seal', function ($seal) {\n return function seal(it) {\n return $seal && isObject(it) ? $seal(meta(it)) : it;\n };\n});\n","// 19.1.3.19 Object.setPrototypeOf(O, proto)\nvar $export = require('./_export');\n$export($export.S, 'Object', { setPrototypeOf: require('./_set-proto').set });\n","'use strict';\n// 19.1.3.6 Object.prototype.toString()\nvar classof = require('./_classof');\nvar test = {};\ntest[require('./_wks')('toStringTag')] = 'z';\nif (test + '' != '[object z]') {\n require('./_redefine')(Object.prototype, 'toString', function toString() {\n return '[object ' + classof(this) + ']';\n }, true);\n}\n","var $export = require('./_export');\nvar $parseFloat = require('./_parse-float');\n// 18.2.4 parseFloat(string)\n$export($export.G + $export.F * (parseFloat != $parseFloat), { parseFloat: $parseFloat });\n","var $export = require('./_export');\nvar $parseInt = require('./_parse-int');\n// 18.2.5 parseInt(string, radix)\n$export($export.G + $export.F * (parseInt != $parseInt), { parseInt: $parseInt });\n","'use strict';\nvar LIBRARY = require('./_library');\nvar global = require('./_global');\nvar ctx = require('./_ctx');\nvar classof = require('./_classof');\nvar $export = require('./_export');\nvar isObject = require('./_is-object');\nvar aFunction = require('./_a-function');\nvar anInstance = require('./_an-instance');\nvar forOf = require('./_for-of');\nvar speciesConstructor = require('./_species-constructor');\nvar task = require('./_task').set;\nvar microtask = require('./_microtask')();\nvar newPromiseCapabilityModule = require('./_new-promise-capability');\nvar perform = require('./_perform');\nvar userAgent = require('./_user-agent');\nvar promiseResolve = require('./_promise-resolve');\nvar PROMISE = 'Promise';\nvar TypeError = global.TypeError;\nvar process = global.process;\nvar versions = process && process.versions;\nvar v8 = versions && versions.v8 || '';\nvar $Promise = global[PROMISE];\nvar isNode = classof(process) == 'process';\nvar empty = function () { /* empty */ };\nvar Internal, newGenericPromiseCapability, OwnPromiseCapability, Wrapper;\nvar newPromiseCapability = newGenericPromiseCapability = newPromiseCapabilityModule.f;\n\nvar USE_NATIVE = !!function () {\n try {\n // correct subclassing with @@species support\n var promise = $Promise.resolve(1);\n var FakePromise = (promise.constructor = {})[require('./_wks')('species')] = function (exec) {\n exec(empty, empty);\n };\n // unhandled rejections tracking support, NodeJS Promise without it fails @@species test\n return (isNode || typeof PromiseRejectionEvent == 'function')\n && promise.then(empty) instanceof FakePromise\n // v8 6.6 (Node 10 and Chrome 66) have a bug with resolving custom thenables\n // https://bugs.chromium.org/p/chromium/issues/detail?id=830565\n // we can't detect it synchronously, so just check versions\n && v8.indexOf('6.6') !== 0\n && userAgent.indexOf('Chrome/66') === -1;\n } catch (e) { /* empty */ }\n}();\n\n// helpers\nvar isThenable = function (it) {\n var then;\n return isObject(it) && typeof (then = it.then) == 'function' ? then : false;\n};\nvar notify = function (promise, isReject) {\n if (promise._n) return;\n promise._n = true;\n var chain = promise._c;\n microtask(function () {\n var value = promise._v;\n var ok = promise._s == 1;\n var i = 0;\n var run = function (reaction) {\n var handler = ok ? reaction.ok : reaction.fail;\n var resolve = reaction.resolve;\n var reject = reaction.reject;\n var domain = reaction.domain;\n var result, then, exited;\n try {\n if (handler) {\n if (!ok) {\n if (promise._h == 2) onHandleUnhandled(promise);\n promise._h = 1;\n }\n if (handler === true) result = value;\n else {\n if (domain) domain.enter();\n result = handler(value); // may throw\n if (domain) {\n domain.exit();\n exited = true;\n }\n }\n if (result === reaction.promise) {\n reject(TypeError('Promise-chain cycle'));\n } else if (then = isThenable(result)) {\n then.call(result, resolve, reject);\n } else resolve(result);\n } else reject(value);\n } catch (e) {\n if (domain && !exited) domain.exit();\n reject(e);\n }\n };\n while (chain.length > i) run(chain[i++]); // variable length - can't use forEach\n promise._c = [];\n promise._n = false;\n if (isReject && !promise._h) onUnhandled(promise);\n });\n};\nvar onUnhandled = function (promise) {\n task.call(global, function () {\n var value = promise._v;\n var unhandled = isUnhandled(promise);\n var result, handler, console;\n if (unhandled) {\n result = perform(function () {\n if (isNode) {\n process.emit('unhandledRejection', value, promise);\n } else if (handler = global.onunhandledrejection) {\n handler({ promise: promise, reason: value });\n } else if ((console = global.console) && console.error) {\n console.error('Unhandled promise rejection', value);\n }\n });\n // Browsers should not trigger `rejectionHandled` event if it was handled here, NodeJS - should\n promise._h = isNode || isUnhandled(promise) ? 2 : 1;\n } promise._a = undefined;\n if (unhandled && result.e) throw result.v;\n });\n};\nvar isUnhandled = function (promise) {\n return promise._h !== 1 && (promise._a || promise._c).length === 0;\n};\nvar onHandleUnhandled = function (promise) {\n task.call(global, function () {\n var handler;\n if (isNode) {\n process.emit('rejectionHandled', promise);\n } else if (handler = global.onrejectionhandled) {\n handler({ promise: promise, reason: promise._v });\n }\n });\n};\nvar $reject = function (value) {\n var promise = this;\n if (promise._d) return;\n promise._d = true;\n promise = promise._w || promise; // unwrap\n promise._v = value;\n promise._s = 2;\n if (!promise._a) promise._a = promise._c.slice();\n notify(promise, true);\n};\nvar $resolve = function (value) {\n var promise = this;\n var then;\n if (promise._d) return;\n promise._d = true;\n promise = promise._w || promise; // unwrap\n try {\n if (promise === value) throw TypeError(\"Promise can't be resolved itself\");\n if (then = isThenable(value)) {\n microtask(function () {\n var wrapper = { _w: promise, _d: false }; // wrap\n try {\n then.call(value, ctx($resolve, wrapper, 1), ctx($reject, wrapper, 1));\n } catch (e) {\n $reject.call(wrapper, e);\n }\n });\n } else {\n promise._v = value;\n promise._s = 1;\n notify(promise, false);\n }\n } catch (e) {\n $reject.call({ _w: promise, _d: false }, e); // wrap\n }\n};\n\n// constructor polyfill\nif (!USE_NATIVE) {\n // 25.4.3.1 Promise(executor)\n $Promise = function Promise(executor) {\n anInstance(this, $Promise, PROMISE, '_h');\n aFunction(executor);\n Internal.call(this);\n try {\n executor(ctx($resolve, this, 1), ctx($reject, this, 1));\n } catch (err) {\n $reject.call(this, err);\n }\n };\n // eslint-disable-next-line no-unused-vars\n Internal = function Promise(executor) {\n this._c = []; // <- awaiting reactions\n this._a = undefined; // <- checked in isUnhandled reactions\n this._s = 0; // <- state\n this._d = false; // <- done\n this._v = undefined; // <- value\n this._h = 0; // <- rejection state, 0 - default, 1 - handled, 2 - unhandled\n this._n = false; // <- notify\n };\n Internal.prototype = require('./_redefine-all')($Promise.prototype, {\n // 25.4.5.3 Promise.prototype.then(onFulfilled, onRejected)\n then: function then(onFulfilled, onRejected) {\n var reaction = newPromiseCapability(speciesConstructor(this, $Promise));\n reaction.ok = typeof onFulfilled == 'function' ? onFulfilled : true;\n reaction.fail = typeof onRejected == 'function' && onRejected;\n reaction.domain = isNode ? process.domain : undefined;\n this._c.push(reaction);\n if (this._a) this._a.push(reaction);\n if (this._s) notify(this, false);\n return reaction.promise;\n },\n // 25.4.5.1 Promise.prototype.catch(onRejected)\n 'catch': function (onRejected) {\n return this.then(undefined, onRejected);\n }\n });\n OwnPromiseCapability = function () {\n var promise = new Internal();\n this.promise = promise;\n this.resolve = ctx($resolve, promise, 1);\n this.reject = ctx($reject, promise, 1);\n };\n newPromiseCapabilityModule.f = newPromiseCapability = function (C) {\n return C === $Promise || C === Wrapper\n ? new OwnPromiseCapability(C)\n : newGenericPromiseCapability(C);\n };\n}\n\n$export($export.G + $export.W + $export.F * !USE_NATIVE, { Promise: $Promise });\nrequire('./_set-to-string-tag')($Promise, PROMISE);\nrequire('./_set-species')(PROMISE);\nWrapper = require('./_core')[PROMISE];\n\n// statics\n$export($export.S + $export.F * !USE_NATIVE, PROMISE, {\n // 25.4.4.5 Promise.reject(r)\n reject: function reject(r) {\n var capability = newPromiseCapability(this);\n var $$reject = capability.reject;\n $$reject(r);\n return capability.promise;\n }\n});\n$export($export.S + $export.F * (LIBRARY || !USE_NATIVE), PROMISE, {\n // 25.4.4.6 Promise.resolve(x)\n resolve: function resolve(x) {\n return promiseResolve(LIBRARY && this === Wrapper ? $Promise : this, x);\n }\n});\n$export($export.S + $export.F * !(USE_NATIVE && require('./_iter-detect')(function (iter) {\n $Promise.all(iter)['catch'](empty);\n})), PROMISE, {\n // 25.4.4.1 Promise.all(iterable)\n all: function all(iterable) {\n var C = this;\n var capability = newPromiseCapability(C);\n var resolve = capability.resolve;\n var reject = capability.reject;\n var result = perform(function () {\n var values = [];\n var index = 0;\n var remaining = 1;\n forOf(iterable, false, function (promise) {\n var $index = index++;\n var alreadyCalled = false;\n values.push(undefined);\n remaining++;\n C.resolve(promise).then(function (value) {\n if (alreadyCalled) return;\n alreadyCalled = true;\n values[$index] = value;\n --remaining || resolve(values);\n }, reject);\n });\n --remaining || resolve(values);\n });\n if (result.e) reject(result.v);\n return capability.promise;\n },\n // 25.4.4.4 Promise.race(iterable)\n race: function race(iterable) {\n var C = this;\n var capability = newPromiseCapability(C);\n var reject = capability.reject;\n var result = perform(function () {\n forOf(iterable, false, function (promise) {\n C.resolve(promise).then(capability.resolve, reject);\n });\n });\n if (result.e) reject(result.v);\n return capability.promise;\n }\n});\n","// 26.1.1 Reflect.apply(target, thisArgument, argumentsList)\nvar $export = require('./_export');\nvar aFunction = require('./_a-function');\nvar anObject = require('./_an-object');\nvar rApply = (require('./_global').Reflect || {}).apply;\nvar fApply = Function.apply;\n// MS Edge argumentsList argument is optional\n$export($export.S + $export.F * !require('./_fails')(function () {\n rApply(function () { /* empty */ });\n}), 'Reflect', {\n apply: function apply(target, thisArgument, argumentsList) {\n var T = aFunction(target);\n var L = anObject(argumentsList);\n return rApply ? rApply(T, thisArgument, L) : fApply.call(T, thisArgument, L);\n }\n});\n","// 26.1.2 Reflect.construct(target, argumentsList [, newTarget])\nvar $export = require('./_export');\nvar create = require('./_object-create');\nvar aFunction = require('./_a-function');\nvar anObject = require('./_an-object');\nvar isObject = require('./_is-object');\nvar fails = require('./_fails');\nvar bind = require('./_bind');\nvar rConstruct = (require('./_global').Reflect || {}).construct;\n\n// MS Edge supports only 2 arguments and argumentsList argument is optional\n// FF Nightly sets third argument as `new.target`, but does not create `this` from it\nvar NEW_TARGET_BUG = fails(function () {\n function F() { /* empty */ }\n return !(rConstruct(function () { /* empty */ }, [], F) instanceof F);\n});\nvar ARGS_BUG = !fails(function () {\n rConstruct(function () { /* empty */ });\n});\n\n$export($export.S + $export.F * (NEW_TARGET_BUG || ARGS_BUG), 'Reflect', {\n construct: function construct(Target, args /* , newTarget */) {\n aFunction(Target);\n anObject(args);\n var newTarget = arguments.length < 3 ? Target : aFunction(arguments[2]);\n if (ARGS_BUG && !NEW_TARGET_BUG) return rConstruct(Target, args, newTarget);\n if (Target == newTarget) {\n // w/o altered newTarget, optimization for 0-4 arguments\n switch (args.length) {\n case 0: return new Target();\n case 1: return new Target(args[0]);\n case 2: return new Target(args[0], args[1]);\n case 3: return new Target(args[0], args[1], args[2]);\n case 4: return new Target(args[0], args[1], args[2], args[3]);\n }\n // w/o altered newTarget, lot of arguments case\n var $args = [null];\n $args.push.apply($args, args);\n return new (bind.apply(Target, $args))();\n }\n // with altered newTarget, not support built-in constructors\n var proto = newTarget.prototype;\n var instance = create(isObject(proto) ? proto : Object.prototype);\n var result = Function.apply.call(Target, instance, args);\n return isObject(result) ? result : instance;\n }\n});\n","// 26.1.3 Reflect.defineProperty(target, propertyKey, attributes)\nvar dP = require('./_object-dp');\nvar $export = require('./_export');\nvar anObject = require('./_an-object');\nvar toPrimitive = require('./_to-primitive');\n\n// MS Edge has broken Reflect.defineProperty - throwing instead of returning false\n$export($export.S + $export.F * require('./_fails')(function () {\n // eslint-disable-next-line no-undef\n Reflect.defineProperty(dP.f({}, 1, { value: 1 }), 1, { value: 2 });\n}), 'Reflect', {\n defineProperty: function defineProperty(target, propertyKey, attributes) {\n anObject(target);\n propertyKey = toPrimitive(propertyKey, true);\n anObject(attributes);\n try {\n dP.f(target, propertyKey, attributes);\n return true;\n } catch (e) {\n return false;\n }\n }\n});\n","// 26.1.4 Reflect.deleteProperty(target, propertyKey)\nvar $export = require('./_export');\nvar gOPD = require('./_object-gopd').f;\nvar anObject = require('./_an-object');\n\n$export($export.S, 'Reflect', {\n deleteProperty: function deleteProperty(target, propertyKey) {\n var desc = gOPD(anObject(target), propertyKey);\n return desc && !desc.configurable ? false : delete target[propertyKey];\n }\n});\n","'use strict';\n// 26.1.5 Reflect.enumerate(target)\nvar $export = require('./_export');\nvar anObject = require('./_an-object');\nvar Enumerate = function (iterated) {\n this._t = anObject(iterated); // target\n this._i = 0; // next index\n var keys = this._k = []; // keys\n var key;\n for (key in iterated) keys.push(key);\n};\nrequire('./_iter-create')(Enumerate, 'Object', function () {\n var that = this;\n var keys = that._k;\n var key;\n do {\n if (that._i >= keys.length) return { value: undefined, done: true };\n } while (!((key = keys[that._i++]) in that._t));\n return { value: key, done: false };\n});\n\n$export($export.S, 'Reflect', {\n enumerate: function enumerate(target) {\n return new Enumerate(target);\n }\n});\n","// 26.1.7 Reflect.getOwnPropertyDescriptor(target, propertyKey)\nvar gOPD = require('./_object-gopd');\nvar $export = require('./_export');\nvar anObject = require('./_an-object');\n\n$export($export.S, 'Reflect', {\n getOwnPropertyDescriptor: function getOwnPropertyDescriptor(target, propertyKey) {\n return gOPD.f(anObject(target), propertyKey);\n }\n});\n","// 26.1.8 Reflect.getPrototypeOf(target)\nvar $export = require('./_export');\nvar getProto = require('./_object-gpo');\nvar anObject = require('./_an-object');\n\n$export($export.S, 'Reflect', {\n getPrototypeOf: function getPrototypeOf(target) {\n return getProto(anObject(target));\n }\n});\n","// 26.1.6 Reflect.get(target, propertyKey [, receiver])\nvar gOPD = require('./_object-gopd');\nvar getPrototypeOf = require('./_object-gpo');\nvar has = require('./_has');\nvar $export = require('./_export');\nvar isObject = require('./_is-object');\nvar anObject = require('./_an-object');\n\nfunction get(target, propertyKey /* , receiver */) {\n var receiver = arguments.length < 3 ? target : arguments[2];\n var desc, proto;\n if (anObject(target) === receiver) return target[propertyKey];\n if (desc = gOPD.f(target, propertyKey)) return has(desc, 'value')\n ? desc.value\n : desc.get !== undefined\n ? desc.get.call(receiver)\n : undefined;\n if (isObject(proto = getPrototypeOf(target))) return get(proto, propertyKey, receiver);\n}\n\n$export($export.S, 'Reflect', { get: get });\n","// 26.1.9 Reflect.has(target, propertyKey)\nvar $export = require('./_export');\n\n$export($export.S, 'Reflect', {\n has: function has(target, propertyKey) {\n return propertyKey in target;\n }\n});\n","// 26.1.10 Reflect.isExtensible(target)\nvar $export = require('./_export');\nvar anObject = require('./_an-object');\nvar $isExtensible = Object.isExtensible;\n\n$export($export.S, 'Reflect', {\n isExtensible: function isExtensible(target) {\n anObject(target);\n return $isExtensible ? $isExtensible(target) : true;\n }\n});\n","// 26.1.11 Reflect.ownKeys(target)\nvar $export = require('./_export');\n\n$export($export.S, 'Reflect', { ownKeys: require('./_own-keys') });\n","// 26.1.12 Reflect.preventExtensions(target)\nvar $export = require('./_export');\nvar anObject = require('./_an-object');\nvar $preventExtensions = Object.preventExtensions;\n\n$export($export.S, 'Reflect', {\n preventExtensions: function preventExtensions(target) {\n anObject(target);\n try {\n if ($preventExtensions) $preventExtensions(target);\n return true;\n } catch (e) {\n return false;\n }\n }\n});\n","// 26.1.14 Reflect.setPrototypeOf(target, proto)\nvar $export = require('./_export');\nvar setProto = require('./_set-proto');\n\nif (setProto) $export($export.S, 'Reflect', {\n setPrototypeOf: function setPrototypeOf(target, proto) {\n setProto.check(target, proto);\n try {\n setProto.set(target, proto);\n return true;\n } catch (e) {\n return false;\n }\n }\n});\n","// 26.1.13 Reflect.set(target, propertyKey, V [, receiver])\nvar dP = require('./_object-dp');\nvar gOPD = require('./_object-gopd');\nvar getPrototypeOf = require('./_object-gpo');\nvar has = require('./_has');\nvar $export = require('./_export');\nvar createDesc = require('./_property-desc');\nvar anObject = require('./_an-object');\nvar isObject = require('./_is-object');\n\nfunction set(target, propertyKey, V /* , receiver */) {\n var receiver = arguments.length < 4 ? target : arguments[3];\n var ownDesc = gOPD.f(anObject(target), propertyKey);\n var existingDescriptor, proto;\n if (!ownDesc) {\n if (isObject(proto = getPrototypeOf(target))) {\n return set(proto, propertyKey, V, receiver);\n }\n ownDesc = createDesc(0);\n }\n if (has(ownDesc, 'value')) {\n if (ownDesc.writable === false || !isObject(receiver)) return false;\n if (existingDescriptor = gOPD.f(receiver, propertyKey)) {\n if (existingDescriptor.get || existingDescriptor.set || existingDescriptor.writable === false) return false;\n existingDescriptor.value = V;\n dP.f(receiver, propertyKey, existingDescriptor);\n } else dP.f(receiver, propertyKey, createDesc(0, V));\n return true;\n }\n return ownDesc.set === undefined ? false : (ownDesc.set.call(receiver, V), true);\n}\n\n$export($export.S, 'Reflect', { set: set });\n","var global = require('./_global');\nvar inheritIfRequired = require('./_inherit-if-required');\nvar dP = require('./_object-dp').f;\nvar gOPN = require('./_object-gopn').f;\nvar isRegExp = require('./_is-regexp');\nvar $flags = require('./_flags');\nvar $RegExp = global.RegExp;\nvar Base = $RegExp;\nvar proto = $RegExp.prototype;\nvar re1 = /a/g;\nvar re2 = /a/g;\n// \"new\" creates a new object, old webkit buggy here\nvar CORRECT_NEW = new $RegExp(re1) !== re1;\n\nif (require('./_descriptors') && (!CORRECT_NEW || require('./_fails')(function () {\n re2[require('./_wks')('match')] = false;\n // RegExp constructor can alter flags and IsRegExp works correct with @@match\n return $RegExp(re1) != re1 || $RegExp(re2) == re2 || $RegExp(re1, 'i') != '/a/i';\n}))) {\n $RegExp = function RegExp(p, f) {\n var tiRE = this instanceof $RegExp;\n var piRE = isRegExp(p);\n var fiU = f === undefined;\n return !tiRE && piRE && p.constructor === $RegExp && fiU ? p\n : inheritIfRequired(CORRECT_NEW\n ? new Base(piRE && !fiU ? p.source : p, f)\n : Base((piRE = p instanceof $RegExp) ? p.source : p, piRE && fiU ? $flags.call(p) : f)\n , tiRE ? this : proto, $RegExp);\n };\n var proxy = function (key) {\n key in $RegExp || dP($RegExp, key, {\n configurable: true,\n get: function () { return Base[key]; },\n set: function (it) { Base[key] = it; }\n });\n };\n for (var keys = gOPN(Base), i = 0; keys.length > i;) proxy(keys[i++]);\n proto.constructor = $RegExp;\n $RegExp.prototype = proto;\n require('./_redefine')(global, 'RegExp', $RegExp);\n}\n\nrequire('./_set-species')('RegExp');\n","'use strict';\nvar regexpExec = require('./_regexp-exec');\nrequire('./_export')({\n target: 'RegExp',\n proto: true,\n forced: regexpExec !== /./.exec\n}, {\n exec: regexpExec\n});\n","// 21.2.5.3 get RegExp.prototype.flags()\nif (require('./_descriptors') && /./g.flags != 'g') require('./_object-dp').f(RegExp.prototype, 'flags', {\n configurable: true,\n get: require('./_flags')\n});\n","'use strict';\n\nvar anObject = require('./_an-object');\nvar toLength = require('./_to-length');\nvar advanceStringIndex = require('./_advance-string-index');\nvar regExpExec = require('./_regexp-exec-abstract');\n\n// @@match logic\nrequire('./_fix-re-wks')('match', 1, function (defined, MATCH, $match, maybeCallNative) {\n return [\n // `String.prototype.match` method\n // https://tc39.github.io/ecma262/#sec-string.prototype.match\n function match(regexp) {\n var O = defined(this);\n var fn = regexp == undefined ? undefined : regexp[MATCH];\n return fn !== undefined ? fn.call(regexp, O) : new RegExp(regexp)[MATCH](String(O));\n },\n // `RegExp.prototype[@@match]` method\n // https://tc39.github.io/ecma262/#sec-regexp.prototype-@@match\n function (regexp) {\n var res = maybeCallNative($match, regexp, this);\n if (res.done) return res.value;\n var rx = anObject(regexp);\n var S = String(this);\n if (!rx.global) return regExpExec(rx, S);\n var fullUnicode = rx.unicode;\n rx.lastIndex = 0;\n var A = [];\n var n = 0;\n var result;\n while ((result = regExpExec(rx, S)) !== null) {\n var matchStr = String(result[0]);\n A[n] = matchStr;\n if (matchStr === '') rx.lastIndex = advanceStringIndex(S, toLength(rx.lastIndex), fullUnicode);\n n++;\n }\n return n === 0 ? null : A;\n }\n ];\n});\n","'use strict';\n\nvar anObject = require('./_an-object');\nvar toObject = require('./_to-object');\nvar toLength = require('./_to-length');\nvar toInteger = require('./_to-integer');\nvar advanceStringIndex = require('./_advance-string-index');\nvar regExpExec = require('./_regexp-exec-abstract');\nvar max = Math.max;\nvar min = Math.min;\nvar floor = Math.floor;\nvar SUBSTITUTION_SYMBOLS = /\\$([$&`']|\\d\\d?|<[^>]*>)/g;\nvar SUBSTITUTION_SYMBOLS_NO_NAMED = /\\$([$&`']|\\d\\d?)/g;\n\nvar maybeToString = function (it) {\n return it === undefined ? it : String(it);\n};\n\n// @@replace logic\nrequire('./_fix-re-wks')('replace', 2, function (defined, REPLACE, $replace, maybeCallNative) {\n return [\n // `String.prototype.replace` method\n // https://tc39.github.io/ecma262/#sec-string.prototype.replace\n function replace(searchValue, replaceValue) {\n var O = defined(this);\n var fn = searchValue == undefined ? undefined : searchValue[REPLACE];\n return fn !== undefined\n ? fn.call(searchValue, O, replaceValue)\n : $replace.call(String(O), searchValue, replaceValue);\n },\n // `RegExp.prototype[@@replace]` method\n // https://tc39.github.io/ecma262/#sec-regexp.prototype-@@replace\n function (regexp, replaceValue) {\n var res = maybeCallNative($replace, regexp, this, replaceValue);\n if (res.done) return res.value;\n\n var rx = anObject(regexp);\n var S = String(this);\n var functionalReplace = typeof replaceValue === 'function';\n if (!functionalReplace) replaceValue = String(replaceValue);\n var global = rx.global;\n if (global) {\n var fullUnicode = rx.unicode;\n rx.lastIndex = 0;\n }\n var results = [];\n while (true) {\n var result = regExpExec(rx, S);\n if (result === null) break;\n results.push(result);\n if (!global) break;\n var matchStr = String(result[0]);\n if (matchStr === '') rx.lastIndex = advanceStringIndex(S, toLength(rx.lastIndex), fullUnicode);\n }\n var accumulatedResult = '';\n var nextSourcePosition = 0;\n for (var i = 0; i < results.length; i++) {\n result = results[i];\n var matched = String(result[0]);\n var position = max(min(toInteger(result.index), S.length), 0);\n var captures = [];\n // NOTE: This is equivalent to\n // captures = result.slice(1).map(maybeToString)\n // but for some reason `nativeSlice.call(result, 1, result.length)` (called in\n // the slice polyfill when slicing native arrays) \"doesn't work\" in safari 9 and\n // causes a crash (https://pastebin.com/N21QzeQA) when trying to debug it.\n for (var j = 1; j < result.length; j++) captures.push(maybeToString(result[j]));\n var namedCaptures = result.groups;\n if (functionalReplace) {\n var replacerArgs = [matched].concat(captures, position, S);\n if (namedCaptures !== undefined) replacerArgs.push(namedCaptures);\n var replacement = String(replaceValue.apply(undefined, replacerArgs));\n } else {\n replacement = getSubstitution(matched, S, position, captures, namedCaptures, replaceValue);\n }\n if (position >= nextSourcePosition) {\n accumulatedResult += S.slice(nextSourcePosition, position) + replacement;\n nextSourcePosition = position + matched.length;\n }\n }\n return accumulatedResult + S.slice(nextSourcePosition);\n }\n ];\n\n // https://tc39.github.io/ecma262/#sec-getsubstitution\n function getSubstitution(matched, str, position, captures, namedCaptures, replacement) {\n var tailPos = position + matched.length;\n var m = captures.length;\n var symbols = SUBSTITUTION_SYMBOLS_NO_NAMED;\n if (namedCaptures !== undefined) {\n namedCaptures = toObject(namedCaptures);\n symbols = SUBSTITUTION_SYMBOLS;\n }\n return $replace.call(replacement, symbols, function (match, ch) {\n var capture;\n switch (ch.charAt(0)) {\n case '$': return '$';\n case '&': return matched;\n case '`': return str.slice(0, position);\n case \"'\": return str.slice(tailPos);\n case '<':\n capture = namedCaptures[ch.slice(1, -1)];\n break;\n default: // \\d\\d?\n var n = +ch;\n if (n === 0) return match;\n if (n > m) {\n var f = floor(n / 10);\n if (f === 0) return match;\n if (f <= m) return captures[f - 1] === undefined ? ch.charAt(1) : captures[f - 1] + ch.charAt(1);\n return match;\n }\n capture = captures[n - 1];\n }\n return capture === undefined ? '' : capture;\n });\n }\n});\n","'use strict';\n\nvar anObject = require('./_an-object');\nvar sameValue = require('./_same-value');\nvar regExpExec = require('./_regexp-exec-abstract');\n\n// @@search logic\nrequire('./_fix-re-wks')('search', 1, function (defined, SEARCH, $search, maybeCallNative) {\n return [\n // `String.prototype.search` method\n // https://tc39.github.io/ecma262/#sec-string.prototype.search\n function search(regexp) {\n var O = defined(this);\n var fn = regexp == undefined ? undefined : regexp[SEARCH];\n return fn !== undefined ? fn.call(regexp, O) : new RegExp(regexp)[SEARCH](String(O));\n },\n // `RegExp.prototype[@@search]` method\n // https://tc39.github.io/ecma262/#sec-regexp.prototype-@@search\n function (regexp) {\n var res = maybeCallNative($search, regexp, this);\n if (res.done) return res.value;\n var rx = anObject(regexp);\n var S = String(this);\n var previousLastIndex = rx.lastIndex;\n if (!sameValue(previousLastIndex, 0)) rx.lastIndex = 0;\n var result = regExpExec(rx, S);\n if (!sameValue(rx.lastIndex, previousLastIndex)) rx.lastIndex = previousLastIndex;\n return result === null ? -1 : result.index;\n }\n ];\n});\n","'use strict';\n\nvar isRegExp = require('./_is-regexp');\nvar anObject = require('./_an-object');\nvar speciesConstructor = require('./_species-constructor');\nvar advanceStringIndex = require('./_advance-string-index');\nvar toLength = require('./_to-length');\nvar callRegExpExec = require('./_regexp-exec-abstract');\nvar regexpExec = require('./_regexp-exec');\nvar fails = require('./_fails');\nvar $min = Math.min;\nvar $push = [].push;\nvar $SPLIT = 'split';\nvar LENGTH = 'length';\nvar LAST_INDEX = 'lastIndex';\nvar MAX_UINT32 = 0xffffffff;\n\n// babel-minify transpiles RegExp('x', 'y') -> /x/y and it causes SyntaxError\nvar SUPPORTS_Y = !fails(function () { RegExp(MAX_UINT32, 'y'); });\n\n// @@split logic\nrequire('./_fix-re-wks')('split', 2, function (defined, SPLIT, $split, maybeCallNative) {\n var internalSplit;\n if (\n 'abbc'[$SPLIT](/(b)*/)[1] == 'c' ||\n 'test'[$SPLIT](/(?:)/, -1)[LENGTH] != 4 ||\n 'ab'[$SPLIT](/(?:ab)*/)[LENGTH] != 2 ||\n '.'[$SPLIT](/(.?)(.?)/)[LENGTH] != 4 ||\n '.'[$SPLIT](/()()/)[LENGTH] > 1 ||\n ''[$SPLIT](/.?/)[LENGTH]\n ) {\n // based on es5-shim implementation, need to rework it\n internalSplit = function (separator, limit) {\n var string = String(this);\n if (separator === undefined && limit === 0) return [];\n // If `separator` is not a regex, use native split\n if (!isRegExp(separator)) return $split.call(string, separator, limit);\n var output = [];\n var flags = (separator.ignoreCase ? 'i' : '') +\n (separator.multiline ? 'm' : '') +\n (separator.unicode ? 'u' : '') +\n (separator.sticky ? 'y' : '');\n var lastLastIndex = 0;\n var splitLimit = limit === undefined ? MAX_UINT32 : limit >>> 0;\n // Make `global` and avoid `lastIndex` issues by working with a copy\n var separatorCopy = new RegExp(separator.source, flags + 'g');\n var match, lastIndex, lastLength;\n while (match = regexpExec.call(separatorCopy, string)) {\n lastIndex = separatorCopy[LAST_INDEX];\n if (lastIndex > lastLastIndex) {\n output.push(string.slice(lastLastIndex, match.index));\n if (match[LENGTH] > 1 && match.index < string[LENGTH]) $push.apply(output, match.slice(1));\n lastLength = match[0][LENGTH];\n lastLastIndex = lastIndex;\n if (output[LENGTH] >= splitLimit) break;\n }\n if (separatorCopy[LAST_INDEX] === match.index) separatorCopy[LAST_INDEX]++; // Avoid an infinite loop\n }\n if (lastLastIndex === string[LENGTH]) {\n if (lastLength || !separatorCopy.test('')) output.push('');\n } else output.push(string.slice(lastLastIndex));\n return output[LENGTH] > splitLimit ? output.slice(0, splitLimit) : output;\n };\n // Chakra, V8\n } else if ('0'[$SPLIT](undefined, 0)[LENGTH]) {\n internalSplit = function (separator, limit) {\n return separator === undefined && limit === 0 ? [] : $split.call(this, separator, limit);\n };\n } else {\n internalSplit = $split;\n }\n\n return [\n // `String.prototype.split` method\n // https://tc39.github.io/ecma262/#sec-string.prototype.split\n function split(separator, limit) {\n var O = defined(this);\n var splitter = separator == undefined ? undefined : separator[SPLIT];\n return splitter !== undefined\n ? splitter.call(separator, O, limit)\n : internalSplit.call(String(O), separator, limit);\n },\n // `RegExp.prototype[@@split]` method\n // https://tc39.github.io/ecma262/#sec-regexp.prototype-@@split\n //\n // NOTE: This cannot be properly polyfilled in engines that don't support\n // the 'y' flag.\n function (regexp, limit) {\n var res = maybeCallNative(internalSplit, regexp, this, limit, internalSplit !== $split);\n if (res.done) return res.value;\n\n var rx = anObject(regexp);\n var S = String(this);\n var C = speciesConstructor(rx, RegExp);\n\n var unicodeMatching = rx.unicode;\n var flags = (rx.ignoreCase ? 'i' : '') +\n (rx.multiline ? 'm' : '') +\n (rx.unicode ? 'u' : '') +\n (SUPPORTS_Y ? 'y' : 'g');\n\n // ^(? + rx + ) is needed, in combination with some S slicing, to\n // simulate the 'y' flag.\n var splitter = new C(SUPPORTS_Y ? rx : '^(?:' + rx.source + ')', flags);\n var lim = limit === undefined ? MAX_UINT32 : limit >>> 0;\n if (lim === 0) return [];\n if (S.length === 0) return callRegExpExec(splitter, S) === null ? [S] : [];\n var p = 0;\n var q = 0;\n var A = [];\n while (q < S.length) {\n splitter.lastIndex = SUPPORTS_Y ? q : 0;\n var z = callRegExpExec(splitter, SUPPORTS_Y ? S : S.slice(q));\n var e;\n if (\n z === null ||\n (e = $min(toLength(splitter.lastIndex + (SUPPORTS_Y ? 0 : q)), S.length)) === p\n ) {\n q = advanceStringIndex(S, q, unicodeMatching);\n } else {\n A.push(S.slice(p, q));\n if (A.length === lim) return A;\n for (var i = 1; i <= z.length - 1; i++) {\n A.push(z[i]);\n if (A.length === lim) return A;\n }\n q = p = e;\n }\n }\n A.push(S.slice(p));\n return A;\n }\n ];\n});\n","'use strict';\nrequire('./es6.regexp.flags');\nvar anObject = require('./_an-object');\nvar $flags = require('./_flags');\nvar DESCRIPTORS = require('./_descriptors');\nvar TO_STRING = 'toString';\nvar $toString = /./[TO_STRING];\n\nvar define = function (fn) {\n require('./_redefine')(RegExp.prototype, TO_STRING, fn, true);\n};\n\n// 21.2.5.14 RegExp.prototype.toString()\nif (require('./_fails')(function () { return $toString.call({ source: 'a', flags: 'b' }) != '/a/b'; })) {\n define(function toString() {\n var R = anObject(this);\n return '/'.concat(R.source, '/',\n 'flags' in R ? R.flags : !DESCRIPTORS && R instanceof RegExp ? $flags.call(R) : undefined);\n });\n// FF44- RegExp#toString has a wrong name\n} else if ($toString.name != TO_STRING) {\n define(function toString() {\n return $toString.call(this);\n });\n}\n","'use strict';\nvar strong = require('./_collection-strong');\nvar validate = require('./_validate-collection');\nvar SET = 'Set';\n\n// 23.2 Set Objects\nmodule.exports = require('./_collection')(SET, function (get) {\n return function Set() { return get(this, arguments.length > 0 ? arguments[0] : undefined); };\n}, {\n // 23.2.3.1 Set.prototype.add(value)\n add: function add(value) {\n return strong.def(validate(this, SET), value = value === 0 ? 0 : value, value);\n }\n}, strong);\n","'use strict';\n// B.2.3.2 String.prototype.anchor(name)\nrequire('./_string-html')('anchor', function (createHTML) {\n return function anchor(name) {\n return createHTML(this, 'a', 'name', name);\n };\n});\n","'use strict';\n// B.2.3.3 String.prototype.big()\nrequire('./_string-html')('big', function (createHTML) {\n return function big() {\n return createHTML(this, 'big', '', '');\n };\n});\n","'use strict';\n// B.2.3.4 String.prototype.blink()\nrequire('./_string-html')('blink', function (createHTML) {\n return function blink() {\n return createHTML(this, 'blink', '', '');\n };\n});\n","'use strict';\n// B.2.3.5 String.prototype.bold()\nrequire('./_string-html')('bold', function (createHTML) {\n return function bold() {\n return createHTML(this, 'b', '', '');\n };\n});\n","'use strict';\nvar $export = require('./_export');\nvar $at = require('./_string-at')(false);\n$export($export.P, 'String', {\n // 21.1.3.3 String.prototype.codePointAt(pos)\n codePointAt: function codePointAt(pos) {\n return $at(this, pos);\n }\n});\n","// 21.1.3.6 String.prototype.endsWith(searchString [, endPosition])\n'use strict';\nvar $export = require('./_export');\nvar toLength = require('./_to-length');\nvar context = require('./_string-context');\nvar ENDS_WITH = 'endsWith';\nvar $endsWith = ''[ENDS_WITH];\n\n$export($export.P + $export.F * require('./_fails-is-regexp')(ENDS_WITH), 'String', {\n endsWith: function endsWith(searchString /* , endPosition = @length */) {\n var that = context(this, searchString, ENDS_WITH);\n var endPosition = arguments.length > 1 ? arguments[1] : undefined;\n var len = toLength(that.length);\n var end = endPosition === undefined ? len : Math.min(toLength(endPosition), len);\n var search = String(searchString);\n return $endsWith\n ? $endsWith.call(that, search, end)\n : that.slice(end - search.length, end) === search;\n }\n});\n","'use strict';\n// B.2.3.6 String.prototype.fixed()\nrequire('./_string-html')('fixed', function (createHTML) {\n return function fixed() {\n return createHTML(this, 'tt', '', '');\n };\n});\n","'use strict';\n// B.2.3.7 String.prototype.fontcolor(color)\nrequire('./_string-html')('fontcolor', function (createHTML) {\n return function fontcolor(color) {\n return createHTML(this, 'font', 'color', color);\n };\n});\n","'use strict';\n// B.2.3.8 String.prototype.fontsize(size)\nrequire('./_string-html')('fontsize', function (createHTML) {\n return function fontsize(size) {\n return createHTML(this, 'font', 'size', size);\n };\n});\n","var $export = require('./_export');\nvar toAbsoluteIndex = require('./_to-absolute-index');\nvar fromCharCode = String.fromCharCode;\nvar $fromCodePoint = String.fromCodePoint;\n\n// length should be 1, old FF problem\n$export($export.S + $export.F * (!!$fromCodePoint && $fromCodePoint.length != 1), 'String', {\n // 21.1.2.2 String.fromCodePoint(...codePoints)\n fromCodePoint: function fromCodePoint(x) { // eslint-disable-line no-unused-vars\n var res = [];\n var aLen = arguments.length;\n var i = 0;\n var code;\n while (aLen > i) {\n code = +arguments[i++];\n if (toAbsoluteIndex(code, 0x10ffff) !== code) throw RangeError(code + ' is not a valid code point');\n res.push(code < 0x10000\n ? fromCharCode(code)\n : fromCharCode(((code -= 0x10000) >> 10) + 0xd800, code % 0x400 + 0xdc00)\n );\n } return res.join('');\n }\n});\n","// 21.1.3.7 String.prototype.includes(searchString, position = 0)\n'use strict';\nvar $export = require('./_export');\nvar context = require('./_string-context');\nvar INCLUDES = 'includes';\n\n$export($export.P + $export.F * require('./_fails-is-regexp')(INCLUDES), 'String', {\n includes: function includes(searchString /* , position = 0 */) {\n return !!~context(this, searchString, INCLUDES)\n .indexOf(searchString, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\n","'use strict';\n// B.2.3.9 String.prototype.italics()\nrequire('./_string-html')('italics', function (createHTML) {\n return function italics() {\n return createHTML(this, 'i', '', '');\n };\n});\n","'use strict';\nvar $at = require('./_string-at')(true);\n\n// 21.1.3.27 String.prototype[@@iterator]()\nrequire('./_iter-define')(String, 'String', function (iterated) {\n this._t = String(iterated); // target\n this._i = 0; // next index\n// 21.1.5.2.1 %StringIteratorPrototype%.next()\n}, function () {\n var O = this._t;\n var index = this._i;\n var point;\n if (index >= O.length) return { value: undefined, done: true };\n point = $at(O, index);\n this._i += point.length;\n return { value: point, done: false };\n});\n","'use strict';\n// B.2.3.10 String.prototype.link(url)\nrequire('./_string-html')('link', function (createHTML) {\n return function link(url) {\n return createHTML(this, 'a', 'href', url);\n };\n});\n","var $export = require('./_export');\nvar toIObject = require('./_to-iobject');\nvar toLength = require('./_to-length');\n\n$export($export.S, 'String', {\n // 21.1.2.4 String.raw(callSite, ...substitutions)\n raw: function raw(callSite) {\n var tpl = toIObject(callSite.raw);\n var len = toLength(tpl.length);\n var aLen = arguments.length;\n var res = [];\n var i = 0;\n while (len > i) {\n res.push(String(tpl[i++]));\n if (i < aLen) res.push(String(arguments[i]));\n } return res.join('');\n }\n});\n","var $export = require('./_export');\n\n$export($export.P, 'String', {\n // 21.1.3.13 String.prototype.repeat(count)\n repeat: require('./_string-repeat')\n});\n","'use strict';\n// B.2.3.11 String.prototype.small()\nrequire('./_string-html')('small', function (createHTML) {\n return function small() {\n return createHTML(this, 'small', '', '');\n };\n});\n","// 21.1.3.18 String.prototype.startsWith(searchString [, position ])\n'use strict';\nvar $export = require('./_export');\nvar toLength = require('./_to-length');\nvar context = require('./_string-context');\nvar STARTS_WITH = 'startsWith';\nvar $startsWith = ''[STARTS_WITH];\n\n$export($export.P + $export.F * require('./_fails-is-regexp')(STARTS_WITH), 'String', {\n startsWith: function startsWith(searchString /* , position = 0 */) {\n var that = context(this, searchString, STARTS_WITH);\n var index = toLength(Math.min(arguments.length > 1 ? arguments[1] : undefined, that.length));\n var search = String(searchString);\n return $startsWith\n ? $startsWith.call(that, search, index)\n : that.slice(index, index + search.length) === search;\n }\n});\n","'use strict';\n// B.2.3.12 String.prototype.strike()\nrequire('./_string-html')('strike', function (createHTML) {\n return function strike() {\n return createHTML(this, 'strike', '', '');\n };\n});\n","'use strict';\n// B.2.3.13 String.prototype.sub()\nrequire('./_string-html')('sub', function (createHTML) {\n return function sub() {\n return createHTML(this, 'sub', '', '');\n };\n});\n","'use strict';\n// B.2.3.14 String.prototype.sup()\nrequire('./_string-html')('sup', function (createHTML) {\n return function sup() {\n return createHTML(this, 'sup', '', '');\n };\n});\n","'use strict';\n// 21.1.3.25 String.prototype.trim()\nrequire('./_string-trim')('trim', function ($trim) {\n return function trim() {\n return $trim(this, 3);\n };\n});\n","'use strict';\n// ECMAScript 6 symbols shim\nvar global = require('./_global');\nvar has = require('./_has');\nvar DESCRIPTORS = require('./_descriptors');\nvar $export = require('./_export');\nvar redefine = require('./_redefine');\nvar META = require('./_meta').KEY;\nvar $fails = require('./_fails');\nvar shared = require('./_shared');\nvar setToStringTag = require('./_set-to-string-tag');\nvar uid = require('./_uid');\nvar wks = require('./_wks');\nvar wksExt = require('./_wks-ext');\nvar wksDefine = require('./_wks-define');\nvar enumKeys = require('./_enum-keys');\nvar isArray = require('./_is-array');\nvar anObject = require('./_an-object');\nvar isObject = require('./_is-object');\nvar toObject = require('./_to-object');\nvar toIObject = require('./_to-iobject');\nvar toPrimitive = require('./_to-primitive');\nvar createDesc = require('./_property-desc');\nvar _create = require('./_object-create');\nvar gOPNExt = require('./_object-gopn-ext');\nvar $GOPD = require('./_object-gopd');\nvar $GOPS = require('./_object-gops');\nvar $DP = require('./_object-dp');\nvar $keys = require('./_object-keys');\nvar gOPD = $GOPD.f;\nvar dP = $DP.f;\nvar gOPN = gOPNExt.f;\nvar $Symbol = global.Symbol;\nvar $JSON = global.JSON;\nvar _stringify = $JSON && $JSON.stringify;\nvar PROTOTYPE = 'prototype';\nvar HIDDEN = wks('_hidden');\nvar TO_PRIMITIVE = wks('toPrimitive');\nvar isEnum = {}.propertyIsEnumerable;\nvar SymbolRegistry = shared('symbol-registry');\nvar AllSymbols = shared('symbols');\nvar OPSymbols = shared('op-symbols');\nvar ObjectProto = Object[PROTOTYPE];\nvar USE_NATIVE = typeof $Symbol == 'function' && !!$GOPS.f;\nvar QObject = global.QObject;\n// Don't use setters in Qt Script, https://github.com/zloirock/core-js/issues/173\nvar setter = !QObject || !QObject[PROTOTYPE] || !QObject[PROTOTYPE].findChild;\n\n// fallback for old Android, https://code.google.com/p/v8/issues/detail?id=687\nvar setSymbolDesc = DESCRIPTORS && $fails(function () {\n return _create(dP({}, 'a', {\n get: function () { return dP(this, 'a', { value: 7 }).a; }\n })).a != 7;\n}) ? function (it, key, D) {\n var protoDesc = gOPD(ObjectProto, key);\n if (protoDesc) delete ObjectProto[key];\n dP(it, key, D);\n if (protoDesc && it !== ObjectProto) dP(ObjectProto, key, protoDesc);\n} : dP;\n\nvar wrap = function (tag) {\n var sym = AllSymbols[tag] = _create($Symbol[PROTOTYPE]);\n sym._k = tag;\n return sym;\n};\n\nvar isSymbol = USE_NATIVE && typeof $Symbol.iterator == 'symbol' ? function (it) {\n return typeof it == 'symbol';\n} : function (it) {\n return it instanceof $Symbol;\n};\n\nvar $defineProperty = function defineProperty(it, key, D) {\n if (it === ObjectProto) $defineProperty(OPSymbols, key, D);\n anObject(it);\n key = toPrimitive(key, true);\n anObject(D);\n if (has(AllSymbols, key)) {\n if (!D.enumerable) {\n if (!has(it, HIDDEN)) dP(it, HIDDEN, createDesc(1, {}));\n it[HIDDEN][key] = true;\n } else {\n if (has(it, HIDDEN) && it[HIDDEN][key]) it[HIDDEN][key] = false;\n D = _create(D, { enumerable: createDesc(0, false) });\n } return setSymbolDesc(it, key, D);\n } return dP(it, key, D);\n};\nvar $defineProperties = function defineProperties(it, P) {\n anObject(it);\n var keys = enumKeys(P = toIObject(P));\n var i = 0;\n var l = keys.length;\n var key;\n while (l > i) $defineProperty(it, key = keys[i++], P[key]);\n return it;\n};\nvar $create = function create(it, P) {\n return P === undefined ? _create(it) : $defineProperties(_create(it), P);\n};\nvar $propertyIsEnumerable = function propertyIsEnumerable(key) {\n var E = isEnum.call(this, key = toPrimitive(key, true));\n if (this === ObjectProto && has(AllSymbols, key) && !has(OPSymbols, key)) return false;\n return E || !has(this, key) || !has(AllSymbols, key) || has(this, HIDDEN) && this[HIDDEN][key] ? E : true;\n};\nvar $getOwnPropertyDescriptor = function getOwnPropertyDescriptor(it, key) {\n it = toIObject(it);\n key = toPrimitive(key, true);\n if (it === ObjectProto && has(AllSymbols, key) && !has(OPSymbols, key)) return;\n var D = gOPD(it, key);\n if (D && has(AllSymbols, key) && !(has(it, HIDDEN) && it[HIDDEN][key])) D.enumerable = true;\n return D;\n};\nvar $getOwnPropertyNames = function getOwnPropertyNames(it) {\n var names = gOPN(toIObject(it));\n var result = [];\n var i = 0;\n var key;\n while (names.length > i) {\n if (!has(AllSymbols, key = names[i++]) && key != HIDDEN && key != META) result.push(key);\n } return result;\n};\nvar $getOwnPropertySymbols = function getOwnPropertySymbols(it) {\n var IS_OP = it === ObjectProto;\n var names = gOPN(IS_OP ? OPSymbols : toIObject(it));\n var result = [];\n var i = 0;\n var key;\n while (names.length > i) {\n if (has(AllSymbols, key = names[i++]) && (IS_OP ? has(ObjectProto, key) : true)) result.push(AllSymbols[key]);\n } return result;\n};\n\n// 19.4.1.1 Symbol([description])\nif (!USE_NATIVE) {\n $Symbol = function Symbol() {\n if (this instanceof $Symbol) throw TypeError('Symbol is not a constructor!');\n var tag = uid(arguments.length > 0 ? arguments[0] : undefined);\n var $set = function (value) {\n if (this === ObjectProto) $set.call(OPSymbols, value);\n if (has(this, HIDDEN) && has(this[HIDDEN], tag)) this[HIDDEN][tag] = false;\n setSymbolDesc(this, tag, createDesc(1, value));\n };\n if (DESCRIPTORS && setter) setSymbolDesc(ObjectProto, tag, { configurable: true, set: $set });\n return wrap(tag);\n };\n redefine($Symbol[PROTOTYPE], 'toString', function toString() {\n return this._k;\n });\n\n $GOPD.f = $getOwnPropertyDescriptor;\n $DP.f = $defineProperty;\n require('./_object-gopn').f = gOPNExt.f = $getOwnPropertyNames;\n require('./_object-pie').f = $propertyIsEnumerable;\n $GOPS.f = $getOwnPropertySymbols;\n\n if (DESCRIPTORS && !require('./_library')) {\n redefine(ObjectProto, 'propertyIsEnumerable', $propertyIsEnumerable, true);\n }\n\n wksExt.f = function (name) {\n return wrap(wks(name));\n };\n}\n\n$export($export.G + $export.W + $export.F * !USE_NATIVE, { Symbol: $Symbol });\n\nfor (var es6Symbols = (\n // 19.4.2.2, 19.4.2.3, 19.4.2.4, 19.4.2.6, 19.4.2.8, 19.4.2.9, 19.4.2.10, 19.4.2.11, 19.4.2.12, 19.4.2.13, 19.4.2.14\n 'hasInstance,isConcatSpreadable,iterator,match,replace,search,species,split,toPrimitive,toStringTag,unscopables'\n).split(','), j = 0; es6Symbols.length > j;)wks(es6Symbols[j++]);\n\nfor (var wellKnownSymbols = $keys(wks.store), k = 0; wellKnownSymbols.length > k;) wksDefine(wellKnownSymbols[k++]);\n\n$export($export.S + $export.F * !USE_NATIVE, 'Symbol', {\n // 19.4.2.1 Symbol.for(key)\n 'for': function (key) {\n return has(SymbolRegistry, key += '')\n ? SymbolRegistry[key]\n : SymbolRegistry[key] = $Symbol(key);\n },\n // 19.4.2.5 Symbol.keyFor(sym)\n keyFor: function keyFor(sym) {\n if (!isSymbol(sym)) throw TypeError(sym + ' is not a symbol!');\n for (var key in SymbolRegistry) if (SymbolRegistry[key] === sym) return key;\n },\n useSetter: function () { setter = true; },\n useSimple: function () { setter = false; }\n});\n\n$export($export.S + $export.F * !USE_NATIVE, 'Object', {\n // 19.1.2.2 Object.create(O [, Properties])\n create: $create,\n // 19.1.2.4 Object.defineProperty(O, P, Attributes)\n defineProperty: $defineProperty,\n // 19.1.2.3 Object.defineProperties(O, Properties)\n defineProperties: $defineProperties,\n // 19.1.2.6 Object.getOwnPropertyDescriptor(O, P)\n getOwnPropertyDescriptor: $getOwnPropertyDescriptor,\n // 19.1.2.7 Object.getOwnPropertyNames(O)\n getOwnPropertyNames: $getOwnPropertyNames,\n // 19.1.2.8 Object.getOwnPropertySymbols(O)\n getOwnPropertySymbols: $getOwnPropertySymbols\n});\n\n// Chrome 38 and 39 `Object.getOwnPropertySymbols` fails on primitives\n// https://bugs.chromium.org/p/v8/issues/detail?id=3443\nvar FAILS_ON_PRIMITIVES = $fails(function () { $GOPS.f(1); });\n\n$export($export.S + $export.F * FAILS_ON_PRIMITIVES, 'Object', {\n getOwnPropertySymbols: function getOwnPropertySymbols(it) {\n return $GOPS.f(toObject(it));\n }\n});\n\n// 24.3.2 JSON.stringify(value [, replacer [, space]])\n$JSON && $export($export.S + $export.F * (!USE_NATIVE || $fails(function () {\n var S = $Symbol();\n // MS Edge converts symbol values to JSON as {}\n // WebKit converts symbol values to JSON as null\n // V8 throws on boxed symbols\n return _stringify([S]) != '[null]' || _stringify({ a: S }) != '{}' || _stringify(Object(S)) != '{}';\n})), 'JSON', {\n stringify: function stringify(it) {\n var args = [it];\n var i = 1;\n var replacer, $replacer;\n while (arguments.length > i) args.push(arguments[i++]);\n $replacer = replacer = args[1];\n if (!isObject(replacer) && it === undefined || isSymbol(it)) return; // IE8 returns string on undefined\n if (!isArray(replacer)) replacer = function (key, value) {\n if (typeof $replacer == 'function') value = $replacer.call(this, key, value);\n if (!isSymbol(value)) return value;\n };\n args[1] = replacer;\n return _stringify.apply($JSON, args);\n }\n});\n\n// 19.4.3.4 Symbol.prototype[@@toPrimitive](hint)\n$Symbol[PROTOTYPE][TO_PRIMITIVE] || require('./_hide')($Symbol[PROTOTYPE], TO_PRIMITIVE, $Symbol[PROTOTYPE].valueOf);\n// 19.4.3.5 Symbol.prototype[@@toStringTag]\nsetToStringTag($Symbol, 'Symbol');\n// 20.2.1.9 Math[@@toStringTag]\nsetToStringTag(Math, 'Math', true);\n// 24.3.3 JSON[@@toStringTag]\nsetToStringTag(global.JSON, 'JSON', true);\n","'use strict';\nvar $export = require('./_export');\nvar $typed = require('./_typed');\nvar buffer = require('./_typed-buffer');\nvar anObject = require('./_an-object');\nvar toAbsoluteIndex = require('./_to-absolute-index');\nvar toLength = require('./_to-length');\nvar isObject = require('./_is-object');\nvar ArrayBuffer = require('./_global').ArrayBuffer;\nvar speciesConstructor = require('./_species-constructor');\nvar $ArrayBuffer = buffer.ArrayBuffer;\nvar $DataView = buffer.DataView;\nvar $isView = $typed.ABV && ArrayBuffer.isView;\nvar $slice = $ArrayBuffer.prototype.slice;\nvar VIEW = $typed.VIEW;\nvar ARRAY_BUFFER = 'ArrayBuffer';\n\n$export($export.G + $export.W + $export.F * (ArrayBuffer !== $ArrayBuffer), { ArrayBuffer: $ArrayBuffer });\n\n$export($export.S + $export.F * !$typed.CONSTR, ARRAY_BUFFER, {\n // 24.1.3.1 ArrayBuffer.isView(arg)\n isView: function isView(it) {\n return $isView && $isView(it) || isObject(it) && VIEW in it;\n }\n});\n\n$export($export.P + $export.U + $export.F * require('./_fails')(function () {\n return !new $ArrayBuffer(2).slice(1, undefined).byteLength;\n}), ARRAY_BUFFER, {\n // 24.1.4.3 ArrayBuffer.prototype.slice(start, end)\n slice: function slice(start, end) {\n if ($slice !== undefined && end === undefined) return $slice.call(anObject(this), start); // FF fix\n var len = anObject(this).byteLength;\n var first = toAbsoluteIndex(start, len);\n var fin = toAbsoluteIndex(end === undefined ? len : end, len);\n var result = new (speciesConstructor(this, $ArrayBuffer))(toLength(fin - first));\n var viewS = new $DataView(this);\n var viewT = new $DataView(result);\n var index = 0;\n while (first < fin) {\n viewT.setUint8(index++, viewS.getUint8(first++));\n } return result;\n }\n});\n\nrequire('./_set-species')(ARRAY_BUFFER);\n","var $export = require('./_export');\n$export($export.G + $export.W + $export.F * !require('./_typed').ABV, {\n DataView: require('./_typed-buffer').DataView\n});\n","require('./_typed-array')('Float32', 4, function (init) {\n return function Float32Array(data, byteOffset, length) {\n return init(this, data, byteOffset, length);\n };\n});\n","require('./_typed-array')('Float64', 8, function (init) {\n return function Float64Array(data, byteOffset, length) {\n return init(this, data, byteOffset, length);\n };\n});\n","require('./_typed-array')('Int16', 2, function (init) {\n return function Int16Array(data, byteOffset, length) {\n return init(this, data, byteOffset, length);\n };\n});\n","require('./_typed-array')('Int32', 4, function (init) {\n return function Int32Array(data, byteOffset, length) {\n return init(this, data, byteOffset, length);\n };\n});\n","require('./_typed-array')('Int8', 1, function (init) {\n return function Int8Array(data, byteOffset, length) {\n return init(this, data, byteOffset, length);\n };\n});\n","require('./_typed-array')('Uint16', 2, function (init) {\n return function Uint16Array(data, byteOffset, length) {\n return init(this, data, byteOffset, length);\n };\n});\n","require('./_typed-array')('Uint32', 4, function (init) {\n return function Uint32Array(data, byteOffset, length) {\n return init(this, data, byteOffset, length);\n };\n});\n","require('./_typed-array')('Uint8', 1, function (init) {\n return function Uint8Array(data, byteOffset, length) {\n return init(this, data, byteOffset, length);\n };\n});\n","require('./_typed-array')('Uint8', 1, function (init) {\n return function Uint8ClampedArray(data, byteOffset, length) {\n return init(this, data, byteOffset, length);\n };\n}, true);\n","'use strict';\nvar global = require('./_global');\nvar each = require('./_array-methods')(0);\nvar redefine = require('./_redefine');\nvar meta = require('./_meta');\nvar assign = require('./_object-assign');\nvar weak = require('./_collection-weak');\nvar isObject = require('./_is-object');\nvar validate = require('./_validate-collection');\nvar NATIVE_WEAK_MAP = require('./_validate-collection');\nvar IS_IE11 = !global.ActiveXObject && 'ActiveXObject' in global;\nvar WEAK_MAP = 'WeakMap';\nvar getWeak = meta.getWeak;\nvar isExtensible = Object.isExtensible;\nvar uncaughtFrozenStore = weak.ufstore;\nvar InternalMap;\n\nvar wrapper = function (get) {\n return function WeakMap() {\n return get(this, arguments.length > 0 ? arguments[0] : undefined);\n };\n};\n\nvar methods = {\n // 23.3.3.3 WeakMap.prototype.get(key)\n get: function get(key) {\n if (isObject(key)) {\n var data = getWeak(key);\n if (data === true) return uncaughtFrozenStore(validate(this, WEAK_MAP)).get(key);\n return data ? data[this._i] : undefined;\n }\n },\n // 23.3.3.5 WeakMap.prototype.set(key, value)\n set: function set(key, value) {\n return weak.def(validate(this, WEAK_MAP), key, value);\n }\n};\n\n// 23.3 WeakMap Objects\nvar $WeakMap = module.exports = require('./_collection')(WEAK_MAP, wrapper, methods, weak, true, true);\n\n// IE11 WeakMap frozen keys fix\nif (NATIVE_WEAK_MAP && IS_IE11) {\n InternalMap = weak.getConstructor(wrapper, WEAK_MAP);\n assign(InternalMap.prototype, methods);\n meta.NEED = true;\n each(['delete', 'has', 'get', 'set'], function (key) {\n var proto = $WeakMap.prototype;\n var method = proto[key];\n redefine(proto, key, function (a, b) {\n // store frozen objects on internal weakmap shim\n if (isObject(a) && !isExtensible(a)) {\n if (!this._f) this._f = new InternalMap();\n var result = this._f[key](a, b);\n return key == 'set' ? this : result;\n // store all the rest on native weakmap\n } return method.call(this, a, b);\n });\n });\n}\n","'use strict';\nvar weak = require('./_collection-weak');\nvar validate = require('./_validate-collection');\nvar WEAK_SET = 'WeakSet';\n\n// 23.4 WeakSet Objects\nrequire('./_collection')(WEAK_SET, function (get) {\n return function WeakSet() { return get(this, arguments.length > 0 ? arguments[0] : undefined); };\n}, {\n // 23.4.3.1 WeakSet.prototype.add(value)\n add: function add(value) {\n return weak.def(validate(this, WEAK_SET), value, true);\n }\n}, weak, false, true);\n","'use strict';\n// https://tc39.github.io/proposal-flatMap/#sec-Array.prototype.flatMap\nvar $export = require('./_export');\nvar flattenIntoArray = require('./_flatten-into-array');\nvar toObject = require('./_to-object');\nvar toLength = require('./_to-length');\nvar aFunction = require('./_a-function');\nvar arraySpeciesCreate = require('./_array-species-create');\n\n$export($export.P, 'Array', {\n flatMap: function flatMap(callbackfn /* , thisArg */) {\n var O = toObject(this);\n var sourceLen, A;\n aFunction(callbackfn);\n sourceLen = toLength(O.length);\n A = arraySpeciesCreate(O, 0);\n flattenIntoArray(A, O, O, sourceLen, 0, 1, callbackfn, arguments[1]);\n return A;\n }\n});\n\nrequire('./_add-to-unscopables')('flatMap');\n","'use strict';\n// https://github.com/tc39/Array.prototype.includes\nvar $export = require('./_export');\nvar $includes = require('./_array-includes')(true);\n\n$export($export.P, 'Array', {\n includes: function includes(el /* , fromIndex = 0 */) {\n return $includes(this, el, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\n\nrequire('./_add-to-unscopables')('includes');\n","// https://github.com/tc39/proposal-object-values-entries\nvar $export = require('./_export');\nvar $entries = require('./_object-to-array')(true);\n\n$export($export.S, 'Object', {\n entries: function entries(it) {\n return $entries(it);\n }\n});\n","// https://github.com/tc39/proposal-object-getownpropertydescriptors\nvar $export = require('./_export');\nvar ownKeys = require('./_own-keys');\nvar toIObject = require('./_to-iobject');\nvar gOPD = require('./_object-gopd');\nvar createProperty = require('./_create-property');\n\n$export($export.S, 'Object', {\n getOwnPropertyDescriptors: function getOwnPropertyDescriptors(object) {\n var O = toIObject(object);\n var getDesc = gOPD.f;\n var keys = ownKeys(O);\n var result = {};\n var i = 0;\n var key, desc;\n while (keys.length > i) {\n desc = getDesc(O, key = keys[i++]);\n if (desc !== undefined) createProperty(result, key, desc);\n }\n return result;\n }\n});\n","// https://github.com/tc39/proposal-object-values-entries\nvar $export = require('./_export');\nvar $values = require('./_object-to-array')(false);\n\n$export($export.S, 'Object', {\n values: function values(it) {\n return $values(it);\n }\n});\n","// https://github.com/tc39/proposal-promise-finally\n'use strict';\nvar $export = require('./_export');\nvar core = require('./_core');\nvar global = require('./_global');\nvar speciesConstructor = require('./_species-constructor');\nvar promiseResolve = require('./_promise-resolve');\n\n$export($export.P + $export.R, 'Promise', { 'finally': function (onFinally) {\n var C = speciesConstructor(this, core.Promise || global.Promise);\n var isFunction = typeof onFinally == 'function';\n return this.then(\n isFunction ? function (x) {\n return promiseResolve(C, onFinally()).then(function () { return x; });\n } : onFinally,\n isFunction ? function (e) {\n return promiseResolve(C, onFinally()).then(function () { throw e; });\n } : onFinally\n );\n} });\n","'use strict';\n// https://github.com/tc39/proposal-string-pad-start-end\nvar $export = require('./_export');\nvar $pad = require('./_string-pad');\nvar userAgent = require('./_user-agent');\n\n// https://github.com/zloirock/core-js/issues/280\nvar WEBKIT_BUG = /Version\\/10\\.\\d+(\\.\\d+)?( Mobile\\/\\w+)? Safari\\//.test(userAgent);\n\n$export($export.P + $export.F * WEBKIT_BUG, 'String', {\n padEnd: function padEnd(maxLength /* , fillString = ' ' */) {\n return $pad(this, maxLength, arguments.length > 1 ? arguments[1] : undefined, false);\n }\n});\n","'use strict';\n// https://github.com/tc39/proposal-string-pad-start-end\nvar $export = require('./_export');\nvar $pad = require('./_string-pad');\nvar userAgent = require('./_user-agent');\n\n// https://github.com/zloirock/core-js/issues/280\nvar WEBKIT_BUG = /Version\\/10\\.\\d+(\\.\\d+)?( Mobile\\/\\w+)? Safari\\//.test(userAgent);\n\n$export($export.P + $export.F * WEBKIT_BUG, 'String', {\n padStart: function padStart(maxLength /* , fillString = ' ' */) {\n return $pad(this, maxLength, arguments.length > 1 ? arguments[1] : undefined, true);\n }\n});\n","'use strict';\n// https://github.com/sebmarkbage/ecmascript-string-left-right-trim\nrequire('./_string-trim')('trimLeft', function ($trim) {\n return function trimLeft() {\n return $trim(this, 1);\n };\n}, 'trimStart');\n","'use strict';\n// https://github.com/sebmarkbage/ecmascript-string-left-right-trim\nrequire('./_string-trim')('trimRight', function ($trim) {\n return function trimRight() {\n return $trim(this, 2);\n };\n}, 'trimEnd');\n","require('./_wks-define')('asyncIterator');\n","var $iterators = require('./es6.array.iterator');\nvar getKeys = require('./_object-keys');\nvar redefine = require('./_redefine');\nvar global = require('./_global');\nvar hide = require('./_hide');\nvar Iterators = require('./_iterators');\nvar wks = require('./_wks');\nvar ITERATOR = wks('iterator');\nvar TO_STRING_TAG = wks('toStringTag');\nvar ArrayValues = Iterators.Array;\n\nvar DOMIterables = {\n CSSRuleList: true, // TODO: Not spec compliant, should be false.\n CSSStyleDeclaration: false,\n CSSValueList: false,\n ClientRectList: false,\n DOMRectList: false,\n DOMStringList: false,\n DOMTokenList: true,\n DataTransferItemList: false,\n FileList: false,\n HTMLAllCollection: false,\n HTMLCollection: false,\n HTMLFormElement: false,\n HTMLSelectElement: false,\n MediaList: true, // TODO: Not spec compliant, should be false.\n MimeTypeArray: false,\n NamedNodeMap: false,\n NodeList: true,\n PaintRequestList: false,\n Plugin: false,\n PluginArray: false,\n SVGLengthList: false,\n SVGNumberList: false,\n SVGPathSegList: false,\n SVGPointList: false,\n SVGStringList: false,\n SVGTransformList: false,\n SourceBufferList: false,\n StyleSheetList: true, // TODO: Not spec compliant, should be false.\n TextTrackCueList: false,\n TextTrackList: false,\n TouchList: false\n};\n\nfor (var collections = getKeys(DOMIterables), i = 0; i < collections.length; i++) {\n var NAME = collections[i];\n var explicit = DOMIterables[NAME];\n var Collection = global[NAME];\n var proto = Collection && Collection.prototype;\n var key;\n if (proto) {\n if (!proto[ITERATOR]) hide(proto, ITERATOR, ArrayValues);\n if (!proto[TO_STRING_TAG]) hide(proto, TO_STRING_TAG, NAME);\n Iterators[NAME] = ArrayValues;\n if (explicit) for (key in $iterators) if (!proto[key]) redefine(proto, key, $iterators[key], true);\n }\n}\n","var $export = require('./_export');\nvar $task = require('./_task');\n$export($export.G + $export.B, {\n setImmediate: $task.set,\n clearImmediate: $task.clear\n});\n","// ie9- setTimeout & setInterval additional parameters fix\nvar global = require('./_global');\nvar $export = require('./_export');\nvar userAgent = require('./_user-agent');\nvar slice = [].slice;\nvar MSIE = /MSIE .\\./.test(userAgent); // <- dirty ie9- check\nvar wrap = function (set) {\n return function (fn, time /* , ...args */) {\n var boundArgs = arguments.length > 2;\n var args = boundArgs ? slice.call(arguments, 2) : false;\n return set(boundArgs ? function () {\n // eslint-disable-next-line no-new-func\n (typeof fn == 'function' ? fn : Function(fn)).apply(this, args);\n } : fn, time);\n };\n};\n$export($export.G + $export.B + $export.F * MSIE, {\n setTimeout: wrap(global.setTimeout),\n setInterval: wrap(global.setInterval)\n});\n","require('../modules/web.timers');\nrequire('../modules/web.immediate');\nrequire('../modules/web.dom.iterable');\nmodule.exports = require('../modules/_core');\n","/*\nCopyright (c) 2012-2014 Chris Pettitt\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n*/\n\nmodule.exports = {\n graphlib: require(\"./lib/graphlib\"),\n\n layout: require(\"./lib/layout\"),\n debug: require(\"./lib/debug\"),\n util: {\n time: require(\"./lib/util\").time,\n notime: require(\"./lib/util\").notime\n },\n version: require(\"./lib/version\")\n};\n","\"use strict\";\n\nvar _ = require(\"./lodash\");\nvar greedyFAS = require(\"./greedy-fas\");\n\nmodule.exports = {\n run: run,\n undo: undo\n};\n\nfunction run(g) {\n var fas = (g.graph().acyclicer === \"greedy\"\n ? greedyFAS(g, weightFn(g))\n : dfsFAS(g));\n _.forEach(fas, function(e) {\n var label = g.edge(e);\n g.removeEdge(e);\n label.forwardName = e.name;\n label.reversed = true;\n g.setEdge(e.w, e.v, label, _.uniqueId(\"rev\"));\n });\n\n function weightFn(g) {\n return function(e) {\n return g.edge(e).weight;\n };\n }\n}\n\nfunction dfsFAS(g) {\n var fas = [];\n var stack = {};\n var visited = {};\n\n function dfs(v) {\n if (_.has(visited, v)) {\n return;\n }\n visited[v] = true;\n stack[v] = true;\n _.forEach(g.outEdges(v), function(e) {\n if (_.has(stack, e.w)) {\n fas.push(e);\n } else {\n dfs(e.w);\n }\n });\n delete stack[v];\n }\n\n _.forEach(g.nodes(), dfs);\n return fas;\n}\n\nfunction undo(g) {\n _.forEach(g.edges(), function(e) {\n var label = g.edge(e);\n if (label.reversed) {\n g.removeEdge(e);\n\n var forwardName = label.forwardName;\n delete label.reversed;\n delete label.forwardName;\n g.setEdge(e.w, e.v, label, forwardName);\n }\n });\n}\n","var _ = require(\"./lodash\");\nvar util = require(\"./util\");\n\nmodule.exports = addBorderSegments;\n\nfunction addBorderSegments(g) {\n function dfs(v) {\n var children = g.children(v);\n var node = g.node(v);\n if (children.length) {\n _.forEach(children, dfs);\n }\n\n if (_.has(node, \"minRank\")) {\n node.borderLeft = [];\n node.borderRight = [];\n for (var rank = node.minRank, maxRank = node.maxRank + 1;\n rank < maxRank;\n ++rank) {\n addBorderNode(g, \"borderLeft\", \"_bl\", v, node, rank);\n addBorderNode(g, \"borderRight\", \"_br\", v, node, rank);\n }\n }\n }\n\n _.forEach(g.children(), dfs);\n}\n\nfunction addBorderNode(g, prop, prefix, sg, sgNode, rank) {\n var label = { width: 0, height: 0, rank: rank, borderType: prop };\n var prev = sgNode[prop][rank - 1];\n var curr = util.addDummyNode(g, \"border\", label, prefix);\n sgNode[prop][rank] = curr;\n g.setParent(curr, sg);\n if (prev) {\n g.setEdge(prev, curr, { weight: 1 });\n }\n}\n","\"use strict\";\n\nvar _ = require(\"./lodash\");\n\nmodule.exports = {\n adjust: adjust,\n undo: undo\n};\n\nfunction adjust(g) {\n var rankDir = g.graph().rankdir.toLowerCase();\n if (rankDir === \"lr\" || rankDir === \"rl\") {\n swapWidthHeight(g);\n }\n}\n\nfunction undo(g) {\n var rankDir = g.graph().rankdir.toLowerCase();\n if (rankDir === \"bt\" || rankDir === \"rl\") {\n reverseY(g);\n }\n\n if (rankDir === \"lr\" || rankDir === \"rl\") {\n swapXY(g);\n swapWidthHeight(g);\n }\n}\n\nfunction swapWidthHeight(g) {\n _.forEach(g.nodes(), function(v) { swapWidthHeightOne(g.node(v)); });\n _.forEach(g.edges(), function(e) { swapWidthHeightOne(g.edge(e)); });\n}\n\nfunction swapWidthHeightOne(attrs) {\n var w = attrs.width;\n attrs.width = attrs.height;\n attrs.height = w;\n}\n\nfunction reverseY(g) {\n _.forEach(g.nodes(), function(v) { reverseYOne(g.node(v)); });\n\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n _.forEach(edge.points, reverseYOne);\n if (_.has(edge, \"y\")) {\n reverseYOne(edge);\n }\n });\n}\n\nfunction reverseYOne(attrs) {\n attrs.y = -attrs.y;\n}\n\nfunction swapXY(g) {\n _.forEach(g.nodes(), function(v) { swapXYOne(g.node(v)); });\n\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n _.forEach(edge.points, swapXYOne);\n if (_.has(edge, \"x\")) {\n swapXYOne(edge);\n }\n });\n}\n\nfunction swapXYOne(attrs) {\n var x = attrs.x;\n attrs.x = attrs.y;\n attrs.y = x;\n}\n","/*\n * Simple doubly linked list implementation derived from Cormen, et al.,\n * \"Introduction to Algorithms\".\n */\n\nmodule.exports = List;\n\nfunction List() {\n var sentinel = {};\n sentinel._next = sentinel._prev = sentinel;\n this._sentinel = sentinel;\n}\n\nList.prototype.dequeue = function() {\n var sentinel = this._sentinel;\n var entry = sentinel._prev;\n if (entry !== sentinel) {\n unlink(entry);\n return entry;\n }\n};\n\nList.prototype.enqueue = function(entry) {\n var sentinel = this._sentinel;\n if (entry._prev && entry._next) {\n unlink(entry);\n }\n entry._next = sentinel._next;\n sentinel._next._prev = entry;\n sentinel._next = entry;\n entry._prev = sentinel;\n};\n\nList.prototype.toString = function() {\n var strs = [];\n var sentinel = this._sentinel;\n var curr = sentinel._prev;\n while (curr !== sentinel) {\n strs.push(JSON.stringify(curr, filterOutLinks));\n curr = curr._prev;\n }\n return \"[\" + strs.join(\", \") + \"]\";\n};\n\nfunction unlink(entry) {\n entry._prev._next = entry._next;\n entry._next._prev = entry._prev;\n delete entry._next;\n delete entry._prev;\n}\n\nfunction filterOutLinks(k, v) {\n if (k !== \"_next\" && k !== \"_prev\") {\n return v;\n }\n}\n","var _ = require(\"./lodash\");\nvar util = require(\"./util\");\nvar Graph = require(\"./graphlib\").Graph;\n\nmodule.exports = {\n debugOrdering: debugOrdering\n};\n\n/* istanbul ignore next */\nfunction debugOrdering(g) {\n var layerMatrix = util.buildLayerMatrix(g);\n\n var h = new Graph({ compound: true, multigraph: true }).setGraph({});\n\n _.forEach(g.nodes(), function(v) {\n h.setNode(v, { label: v });\n h.setParent(v, \"layer\" + g.node(v).rank);\n });\n\n _.forEach(g.edges(), function(e) {\n h.setEdge(e.v, e.w, {}, e.name);\n });\n\n _.forEach(layerMatrix, function(layer, i) {\n var layerV = \"layer\" + i;\n h.setNode(layerV, { rank: \"same\" });\n _.reduce(layer, function(u, v) {\n h.setEdge(u, v, { style: \"invis\" });\n return v;\n });\n });\n\n return h;\n}\n","/* global window */\n\nvar graphlib;\n\nif (typeof require === \"function\") {\n try {\n graphlib = require(\"graphlib\");\n } catch (e) {\n // continue regardless of error\n }\n}\n\nif (!graphlib) {\n graphlib = window.graphlib;\n}\n\nmodule.exports = graphlib;\n","var _ = require(\"./lodash\");\nvar Graph = require(\"./graphlib\").Graph;\nvar List = require(\"./data/list\");\n\n/*\n * A greedy heuristic for finding a feedback arc set for a graph. A feedback\n * arc set is a set of edges that can be removed to make a graph acyclic.\n * The algorithm comes from: P. Eades, X. Lin, and W. F. Smyth, \"A fast and\n * effective heuristic for the feedback arc set problem.\" This implementation\n * adjusts that from the paper to allow for weighted edges.\n */\nmodule.exports = greedyFAS;\n\nvar DEFAULT_WEIGHT_FN = _.constant(1);\n\nfunction greedyFAS(g, weightFn) {\n if (g.nodeCount() <= 1) {\n return [];\n }\n var state = buildState(g, weightFn || DEFAULT_WEIGHT_FN);\n var results = doGreedyFAS(state.graph, state.buckets, state.zeroIdx);\n\n // Expand multi-edges\n return _.flatten(_.map(results, function(e) {\n return g.outEdges(e.v, e.w);\n }), true);\n}\n\nfunction doGreedyFAS(g, buckets, zeroIdx) {\n var results = [];\n var sources = buckets[buckets.length - 1];\n var sinks = buckets[0];\n\n var entry;\n while (g.nodeCount()) {\n while ((entry = sinks.dequeue())) { removeNode(g, buckets, zeroIdx, entry); }\n while ((entry = sources.dequeue())) { removeNode(g, buckets, zeroIdx, entry); }\n if (g.nodeCount()) {\n for (var i = buckets.length - 2; i > 0; --i) {\n entry = buckets[i].dequeue();\n if (entry) {\n results = results.concat(removeNode(g, buckets, zeroIdx, entry, true));\n break;\n }\n }\n }\n }\n\n return results;\n}\n\nfunction removeNode(g, buckets, zeroIdx, entry, collectPredecessors) {\n var results = collectPredecessors ? [] : undefined;\n\n _.forEach(g.inEdges(entry.v), function(edge) {\n var weight = g.edge(edge);\n var uEntry = g.node(edge.v);\n\n if (collectPredecessors) {\n results.push({ v: edge.v, w: edge.w });\n }\n\n uEntry.out -= weight;\n assignBucket(buckets, zeroIdx, uEntry);\n });\n\n _.forEach(g.outEdges(entry.v), function(edge) {\n var weight = g.edge(edge);\n var w = edge.w;\n var wEntry = g.node(w);\n wEntry[\"in\"] -= weight;\n assignBucket(buckets, zeroIdx, wEntry);\n });\n\n g.removeNode(entry.v);\n\n return results;\n}\n\nfunction buildState(g, weightFn) {\n var fasGraph = new Graph();\n var maxIn = 0;\n var maxOut = 0;\n\n _.forEach(g.nodes(), function(v) {\n fasGraph.setNode(v, { v: v, \"in\": 0, out: 0 });\n });\n\n // Aggregate weights on nodes, but also sum the weights across multi-edges\n // into a single edge for the fasGraph.\n _.forEach(g.edges(), function(e) {\n var prevWeight = fasGraph.edge(e.v, e.w) || 0;\n var weight = weightFn(e);\n var edgeWeight = prevWeight + weight;\n fasGraph.setEdge(e.v, e.w, edgeWeight);\n maxOut = Math.max(maxOut, fasGraph.node(e.v).out += weight);\n maxIn = Math.max(maxIn, fasGraph.node(e.w)[\"in\"] += weight);\n });\n\n var buckets = _.range(maxOut + maxIn + 3).map(function() { return new List(); });\n var zeroIdx = maxIn + 1;\n\n _.forEach(fasGraph.nodes(), function(v) {\n assignBucket(buckets, zeroIdx, fasGraph.node(v));\n });\n\n return { graph: fasGraph, buckets: buckets, zeroIdx: zeroIdx };\n}\n\nfunction assignBucket(buckets, zeroIdx, entry) {\n if (!entry.out) {\n buckets[0].enqueue(entry);\n } else if (!entry[\"in\"]) {\n buckets[buckets.length - 1].enqueue(entry);\n } else {\n buckets[entry.out - entry[\"in\"] + zeroIdx].enqueue(entry);\n }\n}\n","\"use strict\";\n\nvar _ = require(\"./lodash\");\nvar acyclic = require(\"./acyclic\");\nvar normalize = require(\"./normalize\");\nvar rank = require(\"./rank\");\nvar normalizeRanks = require(\"./util\").normalizeRanks;\nvar parentDummyChains = require(\"./parent-dummy-chains\");\nvar removeEmptyRanks = require(\"./util\").removeEmptyRanks;\nvar nestingGraph = require(\"./nesting-graph\");\nvar addBorderSegments = require(\"./add-border-segments\");\nvar coordinateSystem = require(\"./coordinate-system\");\nvar order = require(\"./order\");\nvar position = require(\"./position\");\nvar util = require(\"./util\");\nvar Graph = require(\"./graphlib\").Graph;\n\nmodule.exports = layout;\n\nfunction layout(g, opts) {\n var time = opts && opts.debugTiming ? util.time : util.notime;\n time(\"layout\", function() {\n var layoutGraph = \n time(\" buildLayoutGraph\", function() { return buildLayoutGraph(g); });\n time(\" runLayout\", function() { runLayout(layoutGraph, time); });\n time(\" updateInputGraph\", function() { updateInputGraph(g, layoutGraph); });\n });\n}\n\nfunction runLayout(g, time) {\n time(\" makeSpaceForEdgeLabels\", function() { makeSpaceForEdgeLabels(g); });\n time(\" removeSelfEdges\", function() { removeSelfEdges(g); });\n time(\" acyclic\", function() { acyclic.run(g); });\n time(\" nestingGraph.run\", function() { nestingGraph.run(g); });\n time(\" rank\", function() { rank(util.asNonCompoundGraph(g)); });\n time(\" injectEdgeLabelProxies\", function() { injectEdgeLabelProxies(g); });\n time(\" removeEmptyRanks\", function() { removeEmptyRanks(g); });\n time(\" nestingGraph.cleanup\", function() { nestingGraph.cleanup(g); });\n time(\" normalizeRanks\", function() { normalizeRanks(g); });\n time(\" assignRankMinMax\", function() { assignRankMinMax(g); });\n time(\" removeEdgeLabelProxies\", function() { removeEdgeLabelProxies(g); });\n time(\" normalize.run\", function() { normalize.run(g); });\n time(\" parentDummyChains\", function() { parentDummyChains(g); });\n time(\" addBorderSegments\", function() { addBorderSegments(g); });\n time(\" order\", function() { order(g); });\n time(\" insertSelfEdges\", function() { insertSelfEdges(g); });\n time(\" adjustCoordinateSystem\", function() { coordinateSystem.adjust(g); });\n time(\" position\", function() { position(g); });\n time(\" positionSelfEdges\", function() { positionSelfEdges(g); });\n time(\" removeBorderNodes\", function() { removeBorderNodes(g); });\n time(\" normalize.undo\", function() { normalize.undo(g); });\n time(\" fixupEdgeLabelCoords\", function() { fixupEdgeLabelCoords(g); });\n time(\" undoCoordinateSystem\", function() { coordinateSystem.undo(g); });\n time(\" translateGraph\", function() { translateGraph(g); });\n time(\" assignNodeIntersects\", function() { assignNodeIntersects(g); });\n time(\" reversePoints\", function() { reversePointsForReversedEdges(g); });\n time(\" acyclic.undo\", function() { acyclic.undo(g); });\n}\n\n/*\n * Copies final layout information from the layout graph back to the input\n * graph. This process only copies whitelisted attributes from the layout graph\n * to the input graph, so it serves as a good place to determine what\n * attributes can influence layout.\n */\nfunction updateInputGraph(inputGraph, layoutGraph) {\n _.forEach(inputGraph.nodes(), function(v) {\n var inputLabel = inputGraph.node(v);\n var layoutLabel = layoutGraph.node(v);\n\n if (inputLabel) {\n inputLabel.x = layoutLabel.x;\n inputLabel.y = layoutLabel.y;\n\n if (layoutGraph.children(v).length) {\n inputLabel.width = layoutLabel.width;\n inputLabel.height = layoutLabel.height;\n }\n }\n });\n\n _.forEach(inputGraph.edges(), function(e) {\n var inputLabel = inputGraph.edge(e);\n var layoutLabel = layoutGraph.edge(e);\n\n inputLabel.points = layoutLabel.points;\n if (_.has(layoutLabel, \"x\")) {\n inputLabel.x = layoutLabel.x;\n inputLabel.y = layoutLabel.y;\n }\n });\n\n inputGraph.graph().width = layoutGraph.graph().width;\n inputGraph.graph().height = layoutGraph.graph().height;\n}\n\nvar graphNumAttrs = [\"nodesep\", \"edgesep\", \"ranksep\", \"marginx\", \"marginy\"];\nvar graphDefaults = { ranksep: 50, edgesep: 20, nodesep: 50, rankdir: \"tb\" };\nvar graphAttrs = [\"acyclicer\", \"ranker\", \"rankdir\", \"align\"];\nvar nodeNumAttrs = [\"width\", \"height\"];\nvar nodeDefaults = { width: 0, height: 0 };\nvar edgeNumAttrs = [\"minlen\", \"weight\", \"width\", \"height\", \"labeloffset\"];\nvar edgeDefaults = {\n minlen: 1, weight: 1, width: 0, height: 0,\n labeloffset: 10, labelpos: \"r\"\n};\nvar edgeAttrs = [\"labelpos\"];\n\n/*\n * Constructs a new graph from the input graph, which can be used for layout.\n * This process copies only whitelisted attributes from the input graph to the\n * layout graph. Thus this function serves as a good place to determine what\n * attributes can influence layout.\n */\nfunction buildLayoutGraph(inputGraph) {\n var g = new Graph({ multigraph: true, compound: true });\n var graph = canonicalize(inputGraph.graph());\n\n g.setGraph(_.merge({},\n graphDefaults,\n selectNumberAttrs(graph, graphNumAttrs),\n _.pick(graph, graphAttrs)));\n\n _.forEach(inputGraph.nodes(), function(v) {\n var node = canonicalize(inputGraph.node(v));\n g.setNode(v, _.defaults(selectNumberAttrs(node, nodeNumAttrs), nodeDefaults));\n g.setParent(v, inputGraph.parent(v));\n });\n\n _.forEach(inputGraph.edges(), function(e) {\n var edge = canonicalize(inputGraph.edge(e));\n g.setEdge(e, _.merge({},\n edgeDefaults,\n selectNumberAttrs(edge, edgeNumAttrs),\n _.pick(edge, edgeAttrs)));\n });\n\n return g;\n}\n\n/*\n * This idea comes from the Gansner paper: to account for edge labels in our\n * layout we split each rank in half by doubling minlen and halving ranksep.\n * Then we can place labels at these mid-points between nodes.\n *\n * We also add some minimal padding to the width to push the label for the edge\n * away from the edge itself a bit.\n */\nfunction makeSpaceForEdgeLabels(g) {\n var graph = g.graph();\n graph.ranksep /= 2;\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n edge.minlen *= 2;\n if (edge.labelpos.toLowerCase() !== \"c\") {\n if (graph.rankdir === \"TB\" || graph.rankdir === \"BT\") {\n edge.width += edge.labeloffset;\n } else {\n edge.height += edge.labeloffset;\n }\n }\n });\n}\n\n/*\n * Creates temporary dummy nodes that capture the rank in which each edge's\n * label is going to, if it has one of non-zero width and height. We do this\n * so that we can safely remove empty ranks while preserving balance for the\n * label's position.\n */\nfunction injectEdgeLabelProxies(g) {\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n if (edge.width && edge.height) {\n var v = g.node(e.v);\n var w = g.node(e.w);\n var label = { rank: (w.rank - v.rank) / 2 + v.rank, e: e };\n util.addDummyNode(g, \"edge-proxy\", label, \"_ep\");\n }\n });\n}\n\nfunction assignRankMinMax(g) {\n var maxRank = 0;\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v);\n if (node.borderTop) {\n node.minRank = g.node(node.borderTop).rank;\n node.maxRank = g.node(node.borderBottom).rank;\n maxRank = _.max(maxRank, node.maxRank);\n }\n });\n g.graph().maxRank = maxRank;\n}\n\nfunction removeEdgeLabelProxies(g) {\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v);\n if (node.dummy === \"edge-proxy\") {\n g.edge(node.e).labelRank = node.rank;\n g.removeNode(v);\n }\n });\n}\n\nfunction translateGraph(g) {\n var minX = Number.POSITIVE_INFINITY;\n var maxX = 0;\n var minY = Number.POSITIVE_INFINITY;\n var maxY = 0;\n var graphLabel = g.graph();\n var marginX = graphLabel.marginx || 0;\n var marginY = graphLabel.marginy || 0;\n\n function getExtremes(attrs) {\n var x = attrs.x;\n var y = attrs.y;\n var w = attrs.width;\n var h = attrs.height;\n minX = Math.min(minX, x - w / 2);\n maxX = Math.max(maxX, x + w / 2);\n minY = Math.min(minY, y - h / 2);\n maxY = Math.max(maxY, y + h / 2);\n }\n\n _.forEach(g.nodes(), function(v) { getExtremes(g.node(v)); });\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n if (_.has(edge, \"x\")) {\n getExtremes(edge);\n }\n });\n\n minX -= marginX;\n minY -= marginY;\n\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v);\n node.x -= minX;\n node.y -= minY;\n });\n\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n _.forEach(edge.points, function(p) {\n p.x -= minX;\n p.y -= minY;\n });\n if (_.has(edge, \"x\")) { edge.x -= minX; }\n if (_.has(edge, \"y\")) { edge.y -= minY; }\n });\n\n graphLabel.width = maxX - minX + marginX;\n graphLabel.height = maxY - minY + marginY;\n}\n\nfunction assignNodeIntersects(g) {\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n var nodeV = g.node(e.v);\n var nodeW = g.node(e.w);\n var p1, p2;\n if (!edge.points) {\n edge.points = [];\n p1 = nodeW;\n p2 = nodeV;\n } else {\n p1 = edge.points[0];\n p2 = edge.points[edge.points.length - 1];\n }\n edge.points.unshift(util.intersectRect(nodeV, p1));\n edge.points.push(util.intersectRect(nodeW, p2));\n });\n}\n\nfunction fixupEdgeLabelCoords(g) {\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n if (_.has(edge, \"x\")) {\n if (edge.labelpos === \"l\" || edge.labelpos === \"r\") {\n edge.width -= edge.labeloffset;\n }\n switch (edge.labelpos) {\n case \"l\": edge.x -= edge.width / 2 + edge.labeloffset; break;\n case \"r\": edge.x += edge.width / 2 + edge.labeloffset; break;\n }\n }\n });\n}\n\nfunction reversePointsForReversedEdges(g) {\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n if (edge.reversed) {\n edge.points.reverse();\n }\n });\n}\n\nfunction removeBorderNodes(g) {\n _.forEach(g.nodes(), function(v) {\n if (g.children(v).length) {\n var node = g.node(v);\n var t = g.node(node.borderTop);\n var b = g.node(node.borderBottom);\n var l = g.node(_.last(node.borderLeft));\n var r = g.node(_.last(node.borderRight));\n\n node.width = Math.abs(r.x - l.x);\n node.height = Math.abs(b.y - t.y);\n node.x = l.x + node.width / 2;\n node.y = t.y + node.height / 2;\n }\n });\n\n _.forEach(g.nodes(), function(v) {\n if (g.node(v).dummy === \"border\") {\n g.removeNode(v);\n }\n });\n}\n\nfunction removeSelfEdges(g) {\n _.forEach(g.edges(), function(e) {\n if (e.v === e.w) {\n var node = g.node(e.v);\n if (!node.selfEdges) {\n node.selfEdges = [];\n }\n node.selfEdges.push({ e: e, label: g.edge(e) });\n g.removeEdge(e);\n }\n });\n}\n\nfunction insertSelfEdges(g) {\n var layers = util.buildLayerMatrix(g);\n _.forEach(layers, function(layer) {\n var orderShift = 0;\n _.forEach(layer, function(v, i) {\n var node = g.node(v);\n node.order = i + orderShift;\n _.forEach(node.selfEdges, function(selfEdge) {\n util.addDummyNode(g, \"selfedge\", {\n width: selfEdge.label.width,\n height: selfEdge.label.height,\n rank: node.rank,\n order: i + (++orderShift),\n e: selfEdge.e,\n label: selfEdge.label\n }, \"_se\");\n });\n delete node.selfEdges;\n });\n });\n}\n\nfunction positionSelfEdges(g) {\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v);\n if (node.dummy === \"selfedge\") {\n var selfNode = g.node(node.e.v);\n var x = selfNode.x + selfNode.width / 2;\n var y = selfNode.y;\n var dx = node.x - x;\n var dy = selfNode.height / 2;\n g.setEdge(node.e, node.label);\n g.removeNode(v);\n node.label.points = [\n { x: x + 2 * dx / 3, y: y - dy },\n { x: x + 5 * dx / 6, y: y - dy },\n { x: x + dx , y: y },\n { x: x + 5 * dx / 6, y: y + dy },\n { x: x + 2 * dx / 3, y: y + dy }\n ];\n node.label.x = node.x;\n node.label.y = node.y;\n }\n });\n}\n\nfunction selectNumberAttrs(obj, attrs) {\n return _.mapValues(_.pick(obj, attrs), Number);\n}\n\nfunction canonicalize(attrs) {\n var newAttrs = {};\n _.forEach(attrs, function(v, k) {\n newAttrs[k.toLowerCase()] = v;\n });\n return newAttrs;\n}\n","/* global window */\n\nvar lodash;\n\nif (typeof require === \"function\") {\n try {\n lodash = {\n cloneDeep: require(\"lodash/cloneDeep\"),\n constant: require(\"lodash/constant\"),\n defaults: require(\"lodash/defaults\"),\n each: require(\"lodash/each\"),\n filter: require(\"lodash/filter\"),\n find: require(\"lodash/find\"),\n flatten: require(\"lodash/flatten\"),\n forEach: require(\"lodash/forEach\"),\n forIn: require(\"lodash/forIn\"),\n has: require(\"lodash/has\"),\n isUndefined: require(\"lodash/isUndefined\"),\n last: require(\"lodash/last\"),\n map: require(\"lodash/map\"),\n mapValues: require(\"lodash/mapValues\"),\n max: require(\"lodash/max\"),\n merge: require(\"lodash/merge\"),\n min: require(\"lodash/min\"),\n minBy: require(\"lodash/minBy\"),\n now: require(\"lodash/now\"),\n pick: require(\"lodash/pick\"),\n range: require(\"lodash/range\"),\n reduce: require(\"lodash/reduce\"),\n sortBy: require(\"lodash/sortBy\"),\n uniqueId: require(\"lodash/uniqueId\"),\n values: require(\"lodash/values\"),\n zipObject: require(\"lodash/zipObject\"),\n };\n } catch (e) {\n // continue regardless of error\n }\n}\n\nif (!lodash) {\n lodash = window._;\n}\n\nmodule.exports = lodash;\n","var _ = require(\"./lodash\");\nvar util = require(\"./util\");\n\nmodule.exports = {\n run: run,\n cleanup: cleanup\n};\n\n/*\n * A nesting graph creates dummy nodes for the tops and bottoms of subgraphs,\n * adds appropriate edges to ensure that all cluster nodes are placed between\n * these boundries, and ensures that the graph is connected.\n *\n * In addition we ensure, through the use of the minlen property, that nodes\n * and subgraph border nodes to not end up on the same rank.\n *\n * Preconditions:\n *\n * 1. Input graph is a DAG\n * 2. Nodes in the input graph has a minlen attribute\n *\n * Postconditions:\n *\n * 1. Input graph is connected.\n * 2. Dummy nodes are added for the tops and bottoms of subgraphs.\n * 3. The minlen attribute for nodes is adjusted to ensure nodes do not\n * get placed on the same rank as subgraph border nodes.\n *\n * The nesting graph idea comes from Sander, \"Layout of Compound Directed\n * Graphs.\"\n */\nfunction run(g) {\n var root = util.addDummyNode(g, \"root\", {}, \"_root\");\n var depths = treeDepths(g);\n var height = _.max(_.values(depths)) - 1; // Note: depths is an Object not an array\n var nodeSep = 2 * height + 1;\n\n g.graph().nestingRoot = root;\n\n // Multiply minlen by nodeSep to align nodes on non-border ranks.\n _.forEach(g.edges(), function(e) { g.edge(e).minlen *= nodeSep; });\n\n // Calculate a weight that is sufficient to keep subgraphs vertically compact\n var weight = sumWeights(g) + 1;\n\n // Create border nodes and link them up\n _.forEach(g.children(), function(child) {\n dfs(g, root, nodeSep, weight, height, depths, child);\n });\n\n // Save the multiplier for node layers for later removal of empty border\n // layers.\n g.graph().nodeRankFactor = nodeSep;\n}\n\nfunction dfs(g, root, nodeSep, weight, height, depths, v) {\n var children = g.children(v);\n if (!children.length) {\n if (v !== root) {\n g.setEdge(root, v, { weight: 0, minlen: nodeSep });\n }\n return;\n }\n\n var top = util.addBorderNode(g, \"_bt\");\n var bottom = util.addBorderNode(g, \"_bb\");\n var label = g.node(v);\n\n g.setParent(top, v);\n label.borderTop = top;\n g.setParent(bottom, v);\n label.borderBottom = bottom;\n\n _.forEach(children, function(child) {\n dfs(g, root, nodeSep, weight, height, depths, child);\n\n var childNode = g.node(child);\n var childTop = childNode.borderTop ? childNode.borderTop : child;\n var childBottom = childNode.borderBottom ? childNode.borderBottom : child;\n var thisWeight = childNode.borderTop ? weight : 2 * weight;\n var minlen = childTop !== childBottom ? 1 : height - depths[v] + 1;\n\n g.setEdge(top, childTop, {\n weight: thisWeight,\n minlen: minlen,\n nestingEdge: true\n });\n\n g.setEdge(childBottom, bottom, {\n weight: thisWeight,\n minlen: minlen,\n nestingEdge: true\n });\n });\n\n if (!g.parent(v)) {\n g.setEdge(root, top, { weight: 0, minlen: height + depths[v] });\n }\n}\n\nfunction treeDepths(g) {\n var depths = {};\n function dfs(v, depth) {\n var children = g.children(v);\n if (children && children.length) {\n _.forEach(children, function(child) {\n dfs(child, depth + 1);\n });\n }\n depths[v] = depth;\n }\n _.forEach(g.children(), function(v) { dfs(v, 1); });\n return depths;\n}\n\nfunction sumWeights(g) {\n return _.reduce(g.edges(), function(acc, e) {\n return acc + g.edge(e).weight;\n }, 0);\n}\n\nfunction cleanup(g) {\n var graphLabel = g.graph();\n g.removeNode(graphLabel.nestingRoot);\n delete graphLabel.nestingRoot;\n _.forEach(g.edges(), function(e) {\n var edge = g.edge(e);\n if (edge.nestingEdge) {\n g.removeEdge(e);\n }\n });\n}\n","\"use strict\";\n\nvar _ = require(\"./lodash\");\nvar util = require(\"./util\");\n\nmodule.exports = {\n run: run,\n undo: undo\n};\n\n/*\n * Breaks any long edges in the graph into short segments that span 1 layer\n * each. This operation is undoable with the denormalize function.\n *\n * Pre-conditions:\n *\n * 1. The input graph is a DAG.\n * 2. Each node in the graph has a \"rank\" property.\n *\n * Post-condition:\n *\n * 1. All edges in the graph have a length of 1.\n * 2. Dummy nodes are added where edges have been split into segments.\n * 3. The graph is augmented with a \"dummyChains\" attribute which contains\n * the first dummy in each chain of dummy nodes produced.\n */\nfunction run(g) {\n g.graph().dummyChains = [];\n _.forEach(g.edges(), function(edge) { normalizeEdge(g, edge); });\n}\n\nfunction normalizeEdge(g, e) {\n var v = e.v;\n var vRank = g.node(v).rank;\n var w = e.w;\n var wRank = g.node(w).rank;\n var name = e.name;\n var edgeLabel = g.edge(e);\n var labelRank = edgeLabel.labelRank;\n\n if (wRank === vRank + 1) return;\n\n g.removeEdge(e);\n\n var dummy, attrs, i;\n for (i = 0, ++vRank; vRank < wRank; ++i, ++vRank) {\n edgeLabel.points = [];\n attrs = {\n width: 0, height: 0,\n edgeLabel: edgeLabel, edgeObj: e,\n rank: vRank\n };\n dummy = util.addDummyNode(g, \"edge\", attrs, \"_d\");\n if (vRank === labelRank) {\n attrs.width = edgeLabel.width;\n attrs.height = edgeLabel.height;\n attrs.dummy = \"edge-label\";\n attrs.labelpos = edgeLabel.labelpos;\n }\n g.setEdge(v, dummy, { weight: edgeLabel.weight }, name);\n if (i === 0) {\n g.graph().dummyChains.push(dummy);\n }\n v = dummy;\n }\n\n g.setEdge(v, w, { weight: edgeLabel.weight }, name);\n}\n\nfunction undo(g) {\n _.forEach(g.graph().dummyChains, function(v) {\n var node = g.node(v);\n var origLabel = node.edgeLabel;\n var w;\n g.setEdge(node.edgeObj, origLabel);\n while (node.dummy) {\n w = g.successors(v)[0];\n g.removeNode(v);\n origLabel.points.push({ x: node.x, y: node.y });\n if (node.dummy === \"edge-label\") {\n origLabel.x = node.x;\n origLabel.y = node.y;\n origLabel.width = node.width;\n origLabel.height = node.height;\n }\n v = w;\n node = g.node(v);\n }\n });\n}\n","var _ = require(\"../lodash\");\n\nmodule.exports = addSubgraphConstraints;\n\nfunction addSubgraphConstraints(g, cg, vs) {\n var prev = {},\n rootPrev;\n\n _.forEach(vs, function(v) {\n var child = g.parent(v),\n parent,\n prevChild;\n while (child) {\n parent = g.parent(child);\n if (parent) {\n prevChild = prev[parent];\n prev[parent] = child;\n } else {\n prevChild = rootPrev;\n rootPrev = child;\n }\n if (prevChild && prevChild !== child) {\n cg.setEdge(prevChild, child);\n return;\n }\n child = parent;\n }\n });\n\n /*\n function dfs(v) {\n var children = v ? g.children(v) : g.children();\n if (children.length) {\n var min = Number.POSITIVE_INFINITY,\n subgraphs = [];\n _.each(children, function(child) {\n var childMin = dfs(child);\n if (g.children(child).length) {\n subgraphs.push({ v: child, order: childMin });\n }\n min = Math.min(min, childMin);\n });\n _.reduce(_.sortBy(subgraphs, \"order\"), function(prev, curr) {\n cg.setEdge(prev.v, curr.v);\n return curr;\n });\n return min;\n }\n return g.node(v).order;\n }\n dfs(undefined);\n */\n}\n","var _ = require(\"../lodash\");\n\nmodule.exports = barycenter;\n\nfunction barycenter(g, movable) {\n return _.map(movable, function(v) {\n var inV = g.inEdges(v);\n if (!inV.length) {\n return { v: v };\n } else {\n var result = _.reduce(inV, function(acc, e) {\n var edge = g.edge(e),\n nodeU = g.node(e.v);\n return {\n sum: acc.sum + (edge.weight * nodeU.order),\n weight: acc.weight + edge.weight\n };\n }, { sum: 0, weight: 0 });\n\n return {\n v: v,\n barycenter: result.sum / result.weight,\n weight: result.weight\n };\n }\n });\n}\n\n","var _ = require(\"../lodash\");\nvar Graph = require(\"../graphlib\").Graph;\n\nmodule.exports = buildLayerGraph;\n\n/*\n * Constructs a graph that can be used to sort a layer of nodes. The graph will\n * contain all base and subgraph nodes from the request layer in their original\n * hierarchy and any edges that are incident on these nodes and are of the type\n * requested by the \"relationship\" parameter.\n *\n * Nodes from the requested rank that do not have parents are assigned a root\n * node in the output graph, which is set in the root graph attribute. This\n * makes it easy to walk the hierarchy of movable nodes during ordering.\n *\n * Pre-conditions:\n *\n * 1. Input graph is a DAG\n * 2. Base nodes in the input graph have a rank attribute\n * 3. Subgraph nodes in the input graph has minRank and maxRank attributes\n * 4. Edges have an assigned weight\n *\n * Post-conditions:\n *\n * 1. Output graph has all nodes in the movable rank with preserved\n * hierarchy.\n * 2. Root nodes in the movable layer are made children of the node\n * indicated by the root attribute of the graph.\n * 3. Non-movable nodes incident on movable nodes, selected by the\n * relationship parameter, are included in the graph (without hierarchy).\n * 4. Edges incident on movable nodes, selected by the relationship\n * parameter, are added to the output graph.\n * 5. The weights for copied edges are aggregated as need, since the output\n * graph is not a multi-graph.\n */\nfunction buildLayerGraph(g, rank, relationship) {\n var root = createRootNode(g),\n result = new Graph({ compound: true }).setGraph({ root: root })\n .setDefaultNodeLabel(function(v) { return g.node(v); });\n\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v),\n parent = g.parent(v);\n\n if (node.rank === rank || node.minRank <= rank && rank <= node.maxRank) {\n result.setNode(v);\n result.setParent(v, parent || root);\n\n // This assumes we have only short edges!\n _.forEach(g[relationship](v), function(e) {\n var u = e.v === v ? e.w : e.v,\n edge = result.edge(u, v),\n weight = !_.isUndefined(edge) ? edge.weight : 0;\n result.setEdge(u, v, { weight: g.edge(e).weight + weight });\n });\n\n if (_.has(node, \"minRank\")) {\n result.setNode(v, {\n borderLeft: node.borderLeft[rank],\n borderRight: node.borderRight[rank]\n });\n }\n }\n });\n\n return result;\n}\n\nfunction createRootNode(g) {\n var v;\n while (g.hasNode((v = _.uniqueId(\"_root\"))));\n return v;\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\n\nmodule.exports = crossCount;\n\n/*\n * A function that takes a layering (an array of layers, each with an array of\n * ordererd nodes) and a graph and returns a weighted crossing count.\n *\n * Pre-conditions:\n *\n * 1. Input graph must be simple (not a multigraph), directed, and include\n * only simple edges.\n * 2. Edges in the input graph must have assigned weights.\n *\n * Post-conditions:\n *\n * 1. The graph and layering matrix are left unchanged.\n *\n * This algorithm is derived from Barth, et al., \"Bilayer Cross Counting.\"\n */\nfunction crossCount(g, layering) {\n var cc = 0;\n for (var i = 1; i < layering.length; ++i) {\n cc += twoLayerCrossCount(g, layering[i-1], layering[i]);\n }\n return cc;\n}\n\nfunction twoLayerCrossCount(g, northLayer, southLayer) {\n // Sort all of the edges between the north and south layers by their position\n // in the north layer and then the south. Map these edges to the position of\n // their head in the south layer.\n var southPos = _.zipObject(southLayer,\n _.map(southLayer, function (v, i) { return i; }));\n var southEntries = _.flatten(_.map(northLayer, function(v) {\n return _.sortBy(_.map(g.outEdges(v), function(e) {\n return { pos: southPos[e.w], weight: g.edge(e).weight };\n }), \"pos\");\n }), true);\n\n // Build the accumulator tree\n var firstIndex = 1;\n while (firstIndex < southLayer.length) firstIndex <<= 1;\n var treeSize = 2 * firstIndex - 1;\n firstIndex -= 1;\n var tree = _.map(new Array(treeSize), function() { return 0; });\n\n // Calculate the weighted crossings\n var cc = 0;\n _.forEach(southEntries.forEach(function(entry) {\n var index = entry.pos + firstIndex;\n tree[index] += entry.weight;\n var weightSum = 0;\n while (index > 0) {\n if (index % 2) {\n weightSum += tree[index + 1];\n }\n index = (index - 1) >> 1;\n tree[index] += entry.weight;\n }\n cc += entry.weight * weightSum;\n }));\n\n return cc;\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\nvar initOrder = require(\"./init-order\");\nvar crossCount = require(\"./cross-count\");\nvar sortSubgraph = require(\"./sort-subgraph\");\nvar buildLayerGraph = require(\"./build-layer-graph\");\nvar addSubgraphConstraints = require(\"./add-subgraph-constraints\");\nvar Graph = require(\"../graphlib\").Graph;\nvar util = require(\"../util\");\n\nmodule.exports = order;\n\n/*\n * Applies heuristics to minimize edge crossings in the graph and sets the best\n * order solution as an order attribute on each node.\n *\n * Pre-conditions:\n *\n * 1. Graph must be DAG\n * 2. Graph nodes must be objects with a \"rank\" attribute\n * 3. Graph edges must have the \"weight\" attribute\n *\n * Post-conditions:\n *\n * 1. Graph nodes will have an \"order\" attribute based on the results of the\n * algorithm.\n */\nfunction order(g) {\n var maxRank = util.maxRank(g),\n downLayerGraphs = buildLayerGraphs(g, _.range(1, maxRank + 1), \"inEdges\"),\n upLayerGraphs = buildLayerGraphs(g, _.range(maxRank - 1, -1, -1), \"outEdges\");\n\n var layering = initOrder(g);\n assignOrder(g, layering);\n\n var bestCC = Number.POSITIVE_INFINITY,\n best;\n\n for (var i = 0, lastBest = 0; lastBest < 4; ++i, ++lastBest) {\n sweepLayerGraphs(i % 2 ? downLayerGraphs : upLayerGraphs, i % 4 >= 2);\n\n layering = util.buildLayerMatrix(g);\n var cc = crossCount(g, layering);\n if (cc < bestCC) {\n lastBest = 0;\n best = _.cloneDeep(layering);\n bestCC = cc;\n }\n }\n\n assignOrder(g, best);\n}\n\nfunction buildLayerGraphs(g, ranks, relationship) {\n return _.map(ranks, function(rank) {\n return buildLayerGraph(g, rank, relationship);\n });\n}\n\nfunction sweepLayerGraphs(layerGraphs, biasRight) {\n var cg = new Graph();\n _.forEach(layerGraphs, function(lg) {\n var root = lg.graph().root;\n var sorted = sortSubgraph(lg, root, cg, biasRight);\n _.forEach(sorted.vs, function(v, i) {\n lg.node(v).order = i;\n });\n addSubgraphConstraints(lg, cg, sorted.vs);\n });\n}\n\nfunction assignOrder(g, layering) {\n _.forEach(layering, function(layer) {\n _.forEach(layer, function(v, i) {\n g.node(v).order = i;\n });\n });\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\n\nmodule.exports = initOrder;\n\n/*\n * Assigns an initial order value for each node by performing a DFS search\n * starting from nodes in the first rank. Nodes are assigned an order in their\n * rank as they are first visited.\n *\n * This approach comes from Gansner, et al., \"A Technique for Drawing Directed\n * Graphs.\"\n *\n * Returns a layering matrix with an array per layer and each layer sorted by\n * the order of its nodes.\n */\nfunction initOrder(g) {\n var visited = {};\n var simpleNodes = _.filter(g.nodes(), function(v) {\n return !g.children(v).length;\n });\n var maxRank = _.max(_.map(simpleNodes, function(v) { return g.node(v).rank; }));\n var layers = _.map(_.range(maxRank + 1), function() { return []; });\n\n function dfs(v) {\n if (_.has(visited, v)) return;\n visited[v] = true;\n var node = g.node(v);\n layers[node.rank].push(v);\n _.forEach(g.successors(v), dfs);\n }\n\n var orderedVs = _.sortBy(simpleNodes, function(v) { return g.node(v).rank; });\n _.forEach(orderedVs, dfs);\n\n return layers;\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\n\nmodule.exports = resolveConflicts;\n\n/*\n * Given a list of entries of the form {v, barycenter, weight} and a\n * constraint graph this function will resolve any conflicts between the\n * constraint graph and the barycenters for the entries. If the barycenters for\n * an entry would violate a constraint in the constraint graph then we coalesce\n * the nodes in the conflict into a new node that respects the contraint and\n * aggregates barycenter and weight information.\n *\n * This implementation is based on the description in Forster, \"A Fast and\n * Simple Hueristic for Constrained Two-Level Crossing Reduction,\" thought it\n * differs in some specific details.\n *\n * Pre-conditions:\n *\n * 1. Each entry has the form {v, barycenter, weight}, or if the node has\n * no barycenter, then {v}.\n *\n * Returns:\n *\n * A new list of entries of the form {vs, i, barycenter, weight}. The list\n * `vs` may either be a singleton or it may be an aggregation of nodes\n * ordered such that they do not violate constraints from the constraint\n * graph. The property `i` is the lowest original index of any of the\n * elements in `vs`.\n */\nfunction resolveConflicts(entries, cg) {\n var mappedEntries = {};\n _.forEach(entries, function(entry, i) {\n var tmp = mappedEntries[entry.v] = {\n indegree: 0,\n \"in\": [],\n out: [],\n vs: [entry.v],\n i: i\n };\n if (!_.isUndefined(entry.barycenter)) {\n tmp.barycenter = entry.barycenter;\n tmp.weight = entry.weight;\n }\n });\n\n _.forEach(cg.edges(), function(e) {\n var entryV = mappedEntries[e.v];\n var entryW = mappedEntries[e.w];\n if (!_.isUndefined(entryV) && !_.isUndefined(entryW)) {\n entryW.indegree++;\n entryV.out.push(mappedEntries[e.w]);\n }\n });\n\n var sourceSet = _.filter(mappedEntries, function(entry) {\n return !entry.indegree;\n });\n\n return doResolveConflicts(sourceSet);\n}\n\nfunction doResolveConflicts(sourceSet) {\n var entries = [];\n\n function handleIn(vEntry) {\n return function(uEntry) {\n if (uEntry.merged) {\n return;\n }\n if (_.isUndefined(uEntry.barycenter) ||\n _.isUndefined(vEntry.barycenter) ||\n uEntry.barycenter >= vEntry.barycenter) {\n mergeEntries(vEntry, uEntry);\n }\n };\n }\n\n function handleOut(vEntry) {\n return function(wEntry) {\n wEntry[\"in\"].push(vEntry);\n if (--wEntry.indegree === 0) {\n sourceSet.push(wEntry);\n }\n };\n }\n\n while (sourceSet.length) {\n var entry = sourceSet.pop();\n entries.push(entry);\n _.forEach(entry[\"in\"].reverse(), handleIn(entry));\n _.forEach(entry.out, handleOut(entry));\n }\n\n return _.map(_.filter(entries, function(entry) { return !entry.merged; }),\n function(entry) {\n return _.pick(entry, [\"vs\", \"i\", \"barycenter\", \"weight\"]);\n });\n\n}\n\nfunction mergeEntries(target, source) {\n var sum = 0;\n var weight = 0;\n\n if (target.weight) {\n sum += target.barycenter * target.weight;\n weight += target.weight;\n }\n\n if (source.weight) {\n sum += source.barycenter * source.weight;\n weight += source.weight;\n }\n\n target.vs = source.vs.concat(target.vs);\n target.barycenter = sum / weight;\n target.weight = weight;\n target.i = Math.min(source.i, target.i);\n source.merged = true;\n}\n","var _ = require(\"../lodash\");\nvar barycenter = require(\"./barycenter\");\nvar resolveConflicts = require(\"./resolve-conflicts\");\nvar sort = require(\"./sort\");\n\nmodule.exports = sortSubgraph;\n\nfunction sortSubgraph(g, v, cg, biasRight) {\n var movable = g.children(v);\n var node = g.node(v);\n var bl = node ? node.borderLeft : undefined;\n var br = node ? node.borderRight: undefined;\n var subgraphs = {};\n\n if (bl) {\n movable = _.filter(movable, function(w) {\n return w !== bl && w !== br;\n });\n }\n\n var barycenters = barycenter(g, movable);\n _.forEach(barycenters, function(entry) {\n if (g.children(entry.v).length) {\n var subgraphResult = sortSubgraph(g, entry.v, cg, biasRight);\n subgraphs[entry.v] = subgraphResult;\n if (_.has(subgraphResult, \"barycenter\")) {\n mergeBarycenters(entry, subgraphResult);\n }\n }\n });\n\n var entries = resolveConflicts(barycenters, cg);\n expandSubgraphs(entries, subgraphs);\n\n var result = sort(entries, biasRight);\n\n if (bl) {\n result.vs = _.flatten([bl, result.vs, br], true);\n if (g.predecessors(bl).length) {\n var blPred = g.node(g.predecessors(bl)[0]),\n brPred = g.node(g.predecessors(br)[0]);\n if (!_.has(result, \"barycenter\")) {\n result.barycenter = 0;\n result.weight = 0;\n }\n result.barycenter = (result.barycenter * result.weight +\n blPred.order + brPred.order) / (result.weight + 2);\n result.weight += 2;\n }\n }\n\n return result;\n}\n\nfunction expandSubgraphs(entries, subgraphs) {\n _.forEach(entries, function(entry) {\n entry.vs = _.flatten(entry.vs.map(function(v) {\n if (subgraphs[v]) {\n return subgraphs[v].vs;\n }\n return v;\n }), true);\n });\n}\n\nfunction mergeBarycenters(target, other) {\n if (!_.isUndefined(target.barycenter)) {\n target.barycenter = (target.barycenter * target.weight +\n other.barycenter * other.weight) /\n (target.weight + other.weight);\n target.weight += other.weight;\n } else {\n target.barycenter = other.barycenter;\n target.weight = other.weight;\n }\n}\n","var _ = require(\"../lodash\");\nvar util = require(\"../util\");\n\nmodule.exports = sort;\n\nfunction sort(entries, biasRight) {\n var parts = util.partition(entries, function(entry) {\n return _.has(entry, \"barycenter\");\n });\n var sortable = parts.lhs,\n unsortable = _.sortBy(parts.rhs, function(entry) { return -entry.i; }),\n vs = [],\n sum = 0,\n weight = 0,\n vsIndex = 0;\n\n sortable.sort(compareWithBias(!!biasRight));\n\n vsIndex = consumeUnsortable(vs, unsortable, vsIndex);\n\n _.forEach(sortable, function (entry) {\n vsIndex += entry.vs.length;\n vs.push(entry.vs);\n sum += entry.barycenter * entry.weight;\n weight += entry.weight;\n vsIndex = consumeUnsortable(vs, unsortable, vsIndex);\n });\n\n var result = { vs: _.flatten(vs, true) };\n if (weight) {\n result.barycenter = sum / weight;\n result.weight = weight;\n }\n return result;\n}\n\nfunction consumeUnsortable(vs, unsortable, index) {\n var last;\n while (unsortable.length && (last = _.last(unsortable)).i <= index) {\n unsortable.pop();\n vs.push(last.vs);\n index++;\n }\n return index;\n}\n\nfunction compareWithBias(bias) {\n return function(entryV, entryW) {\n if (entryV.barycenter < entryW.barycenter) {\n return -1;\n } else if (entryV.barycenter > entryW.barycenter) {\n return 1;\n }\n\n return !bias ? entryV.i - entryW.i : entryW.i - entryV.i;\n };\n}\n","var _ = require(\"./lodash\");\n\nmodule.exports = parentDummyChains;\n\nfunction parentDummyChains(g) {\n var postorderNums = postorder(g);\n\n _.forEach(g.graph().dummyChains, function(v) {\n var node = g.node(v);\n var edgeObj = node.edgeObj;\n var pathData = findPath(g, postorderNums, edgeObj.v, edgeObj.w);\n var path = pathData.path;\n var lca = pathData.lca;\n var pathIdx = 0;\n var pathV = path[pathIdx];\n var ascending = true;\n\n while (v !== edgeObj.w) {\n node = g.node(v);\n\n if (ascending) {\n while ((pathV = path[pathIdx]) !== lca &&\n g.node(pathV).maxRank < node.rank) {\n pathIdx++;\n }\n\n if (pathV === lca) {\n ascending = false;\n }\n }\n\n if (!ascending) {\n while (pathIdx < path.length - 1 &&\n g.node(pathV = path[pathIdx + 1]).minRank <= node.rank) {\n pathIdx++;\n }\n pathV = path[pathIdx];\n }\n\n g.setParent(v, pathV);\n v = g.successors(v)[0];\n }\n });\n}\n\n// Find a path from v to w through the lowest common ancestor (LCA). Return the\n// full path and the LCA.\nfunction findPath(g, postorderNums, v, w) {\n var vPath = [];\n var wPath = [];\n var low = Math.min(postorderNums[v].low, postorderNums[w].low);\n var lim = Math.max(postorderNums[v].lim, postorderNums[w].lim);\n var parent;\n var lca;\n\n // Traverse up from v to find the LCA\n parent = v;\n do {\n parent = g.parent(parent);\n vPath.push(parent);\n } while (parent &&\n (postorderNums[parent].low > low || lim > postorderNums[parent].lim));\n lca = parent;\n\n // Traverse from w to LCA\n parent = w;\n while ((parent = g.parent(parent)) !== lca) {\n wPath.push(parent);\n }\n\n return { path: vPath.concat(wPath.reverse()), lca: lca };\n}\n\nfunction postorder(g) {\n var result = {};\n var lim = 0;\n\n function dfs(v) {\n var low = lim;\n _.forEach(g.children(v), dfs);\n result[v] = { low: low, lim: lim++ };\n }\n _.forEach(g.children(), dfs);\n\n return result;\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\nvar Graph = require(\"../graphlib\").Graph;\nvar util = require(\"../util\");\n\n/*\n * This module provides coordinate assignment based on Brandes and Köpf, \"Fast\n * and Simple Horizontal Coordinate Assignment.\"\n */\n\nmodule.exports = {\n positionX: positionX,\n findType1Conflicts: findType1Conflicts,\n findType2Conflicts: findType2Conflicts,\n addConflict: addConflict,\n hasConflict: hasConflict,\n verticalAlignment: verticalAlignment,\n horizontalCompaction: horizontalCompaction,\n alignCoordinates: alignCoordinates,\n findSmallestWidthAlignment: findSmallestWidthAlignment,\n balance: balance\n};\n\n/*\n * Marks all edges in the graph with a type-1 conflict with the \"type1Conflict\"\n * property. A type-1 conflict is one where a non-inner segment crosses an\n * inner segment. An inner segment is an edge with both incident nodes marked\n * with the \"dummy\" property.\n *\n * This algorithm scans layer by layer, starting with the second, for type-1\n * conflicts between the current layer and the previous layer. For each layer\n * it scans the nodes from left to right until it reaches one that is incident\n * on an inner segment. It then scans predecessors to determine if they have\n * edges that cross that inner segment. At the end a final scan is done for all\n * nodes on the current rank to see if they cross the last visited inner\n * segment.\n *\n * This algorithm (safely) assumes that a dummy node will only be incident on a\n * single node in the layers being scanned.\n */\nfunction findType1Conflicts(g, layering) {\n var conflicts = {};\n\n function visitLayer(prevLayer, layer) {\n var\n // last visited node in the previous layer that is incident on an inner\n // segment.\n k0 = 0,\n // Tracks the last node in this layer scanned for crossings with a type-1\n // segment.\n scanPos = 0,\n prevLayerLength = prevLayer.length,\n lastNode = _.last(layer);\n\n _.forEach(layer, function(v, i) {\n var w = findOtherInnerSegmentNode(g, v),\n k1 = w ? g.node(w).order : prevLayerLength;\n\n if (w || v === lastNode) {\n _.forEach(layer.slice(scanPos, i +1), function(scanNode) {\n _.forEach(g.predecessors(scanNode), function(u) {\n var uLabel = g.node(u),\n uPos = uLabel.order;\n if ((uPos < k0 || k1 < uPos) &&\n !(uLabel.dummy && g.node(scanNode).dummy)) {\n addConflict(conflicts, u, scanNode);\n }\n });\n });\n scanPos = i + 1;\n k0 = k1;\n }\n });\n\n return layer;\n }\n\n _.reduce(layering, visitLayer);\n return conflicts;\n}\n\nfunction findType2Conflicts(g, layering) {\n var conflicts = {};\n\n function scan(south, southPos, southEnd, prevNorthBorder, nextNorthBorder) {\n var v;\n _.forEach(_.range(southPos, southEnd), function(i) {\n v = south[i];\n if (g.node(v).dummy) {\n _.forEach(g.predecessors(v), function(u) {\n var uNode = g.node(u);\n if (uNode.dummy &&\n (uNode.order < prevNorthBorder || uNode.order > nextNorthBorder)) {\n addConflict(conflicts, u, v);\n }\n });\n }\n });\n }\n\n\n function visitLayer(north, south) {\n var prevNorthPos = -1,\n nextNorthPos,\n southPos = 0;\n\n _.forEach(south, function(v, southLookahead) {\n if (g.node(v).dummy === \"border\") {\n var predecessors = g.predecessors(v);\n if (predecessors.length) {\n nextNorthPos = g.node(predecessors[0]).order;\n scan(south, southPos, southLookahead, prevNorthPos, nextNorthPos);\n southPos = southLookahead;\n prevNorthPos = nextNorthPos;\n }\n }\n scan(south, southPos, south.length, nextNorthPos, north.length);\n });\n\n return south;\n }\n\n _.reduce(layering, visitLayer);\n return conflicts;\n}\n\nfunction findOtherInnerSegmentNode(g, v) {\n if (g.node(v).dummy) {\n return _.find(g.predecessors(v), function(u) {\n return g.node(u).dummy;\n });\n }\n}\n\nfunction addConflict(conflicts, v, w) {\n if (v > w) {\n var tmp = v;\n v = w;\n w = tmp;\n }\n\n var conflictsV = conflicts[v];\n if (!conflictsV) {\n conflicts[v] = conflictsV = {};\n }\n conflictsV[w] = true;\n}\n\nfunction hasConflict(conflicts, v, w) {\n if (v > w) {\n var tmp = v;\n v = w;\n w = tmp;\n }\n return _.has(conflicts[v], w);\n}\n\n/*\n * Try to align nodes into vertical \"blocks\" where possible. This algorithm\n * attempts to align a node with one of its median neighbors. If the edge\n * connecting a neighbor is a type-1 conflict then we ignore that possibility.\n * If a previous node has already formed a block with a node after the node\n * we're trying to form a block with, we also ignore that possibility - our\n * blocks would be split in that scenario.\n */\nfunction verticalAlignment(g, layering, conflicts, neighborFn) {\n var root = {},\n align = {},\n pos = {};\n\n // We cache the position here based on the layering because the graph and\n // layering may be out of sync. The layering matrix is manipulated to\n // generate different extreme alignments.\n _.forEach(layering, function(layer) {\n _.forEach(layer, function(v, order) {\n root[v] = v;\n align[v] = v;\n pos[v] = order;\n });\n });\n\n _.forEach(layering, function(layer) {\n var prevIdx = -1;\n _.forEach(layer, function(v) {\n var ws = neighborFn(v);\n if (ws.length) {\n ws = _.sortBy(ws, function(w) { return pos[w]; });\n var mp = (ws.length - 1) / 2;\n for (var i = Math.floor(mp), il = Math.ceil(mp); i <= il; ++i) {\n var w = ws[i];\n if (align[v] === v &&\n prevIdx < pos[w] &&\n !hasConflict(conflicts, v, w)) {\n align[w] = v;\n align[v] = root[v] = root[w];\n prevIdx = pos[w];\n }\n }\n }\n });\n });\n\n return { root: root, align: align };\n}\n\nfunction horizontalCompaction(g, layering, root, align, reverseSep) {\n // This portion of the algorithm differs from BK due to a number of problems.\n // Instead of their algorithm we construct a new block graph and do two\n // sweeps. The first sweep places blocks with the smallest possible\n // coordinates. The second sweep removes unused space by moving blocks to the\n // greatest coordinates without violating separation.\n var xs = {},\n blockG = buildBlockGraph(g, layering, root, reverseSep),\n borderType = reverseSep ? \"borderLeft\" : \"borderRight\";\n\n function iterate(setXsFunc, nextNodesFunc) {\n var stack = blockG.nodes();\n var elem = stack.pop();\n var visited = {};\n while (elem) {\n if (visited[elem]) {\n setXsFunc(elem);\n } else {\n visited[elem] = true;\n stack.push(elem);\n stack = stack.concat(nextNodesFunc(elem));\n }\n\n elem = stack.pop();\n }\n }\n\n // First pass, assign smallest coordinates\n function pass1(elem) {\n xs[elem] = blockG.inEdges(elem).reduce(function(acc, e) {\n return Math.max(acc, xs[e.v] + blockG.edge(e));\n }, 0);\n }\n\n // Second pass, assign greatest coordinates\n function pass2(elem) {\n var min = blockG.outEdges(elem).reduce(function(acc, e) {\n return Math.min(acc, xs[e.w] - blockG.edge(e));\n }, Number.POSITIVE_INFINITY);\n\n var node = g.node(elem);\n if (min !== Number.POSITIVE_INFINITY && node.borderType !== borderType) {\n xs[elem] = Math.max(xs[elem], min);\n }\n }\n\n iterate(pass1, blockG.predecessors.bind(blockG));\n iterate(pass2, blockG.successors.bind(blockG));\n\n // Assign x coordinates to all nodes\n _.forEach(align, function(v) {\n xs[v] = xs[root[v]];\n });\n\n return xs;\n}\n\n\nfunction buildBlockGraph(g, layering, root, reverseSep) {\n var blockGraph = new Graph(),\n graphLabel = g.graph(),\n sepFn = sep(graphLabel.nodesep, graphLabel.edgesep, reverseSep);\n\n _.forEach(layering, function(layer) {\n var u;\n _.forEach(layer, function(v) {\n var vRoot = root[v];\n blockGraph.setNode(vRoot);\n if (u) {\n var uRoot = root[u],\n prevMax = blockGraph.edge(uRoot, vRoot);\n blockGraph.setEdge(uRoot, vRoot, Math.max(sepFn(g, v, u), prevMax || 0));\n }\n u = v;\n });\n });\n\n return blockGraph;\n}\n\n/*\n * Returns the alignment that has the smallest width of the given alignments.\n */\nfunction findSmallestWidthAlignment(g, xss) {\n return _.minBy(_.values(xss), function (xs) {\n var max = Number.NEGATIVE_INFINITY;\n var min = Number.POSITIVE_INFINITY;\n\n _.forIn(xs, function (x, v) {\n var halfWidth = width(g, v) / 2;\n\n max = Math.max(x + halfWidth, max);\n min = Math.min(x - halfWidth, min);\n });\n\n return max - min;\n });\n}\n\n/*\n * Align the coordinates of each of the layout alignments such that\n * left-biased alignments have their minimum coordinate at the same point as\n * the minimum coordinate of the smallest width alignment and right-biased\n * alignments have their maximum coordinate at the same point as the maximum\n * coordinate of the smallest width alignment.\n */\nfunction alignCoordinates(xss, alignTo) {\n var alignToVals = _.values(alignTo),\n alignToMin = _.min(alignToVals),\n alignToMax = _.max(alignToVals);\n\n _.forEach([\"u\", \"d\"], function(vert) {\n _.forEach([\"l\", \"r\"], function(horiz) {\n var alignment = vert + horiz,\n xs = xss[alignment],\n delta;\n if (xs === alignTo) return;\n\n var xsVals = _.values(xs);\n delta = horiz === \"l\" ? alignToMin - _.min(xsVals) : alignToMax - _.max(xsVals);\n\n if (delta) {\n xss[alignment] = _.mapValues(xs, function(x) { return x + delta; });\n }\n });\n });\n}\n\nfunction balance(xss, align) {\n return _.mapValues(xss.ul, function(ignore, v) {\n if (align) {\n return xss[align.toLowerCase()][v];\n } else {\n var xs = _.sortBy(_.map(xss, v));\n return (xs[1] + xs[2]) / 2;\n }\n });\n}\n\nfunction positionX(g) {\n var layering = util.buildLayerMatrix(g);\n var conflicts = _.merge(\n findType1Conflicts(g, layering),\n findType2Conflicts(g, layering));\n\n var xss = {};\n var adjustedLayering;\n _.forEach([\"u\", \"d\"], function(vert) {\n adjustedLayering = vert === \"u\" ? layering : _.values(layering).reverse();\n _.forEach([\"l\", \"r\"], function(horiz) {\n if (horiz === \"r\") {\n adjustedLayering = _.map(adjustedLayering, function(inner) {\n return _.values(inner).reverse();\n });\n }\n\n var neighborFn = (vert === \"u\" ? g.predecessors : g.successors).bind(g);\n var align = verticalAlignment(g, adjustedLayering, conflicts, neighborFn);\n var xs = horizontalCompaction(g, adjustedLayering,\n align.root, align.align, horiz === \"r\");\n if (horiz === \"r\") {\n xs = _.mapValues(xs, function(x) { return -x; });\n }\n xss[vert + horiz] = xs;\n });\n });\n\n var smallestWidth = findSmallestWidthAlignment(g, xss);\n alignCoordinates(xss, smallestWidth);\n return balance(xss, g.graph().align);\n}\n\nfunction sep(nodeSep, edgeSep, reverseSep) {\n return function(g, v, w) {\n var vLabel = g.node(v);\n var wLabel = g.node(w);\n var sum = 0;\n var delta;\n\n sum += vLabel.width / 2;\n if (_.has(vLabel, \"labelpos\")) {\n switch (vLabel.labelpos.toLowerCase()) {\n case \"l\": delta = -vLabel.width / 2; break;\n case \"r\": delta = vLabel.width / 2; break;\n }\n }\n if (delta) {\n sum += reverseSep ? delta : -delta;\n }\n delta = 0;\n\n sum += (vLabel.dummy ? edgeSep : nodeSep) / 2;\n sum += (wLabel.dummy ? edgeSep : nodeSep) / 2;\n\n sum += wLabel.width / 2;\n if (_.has(wLabel, \"labelpos\")) {\n switch (wLabel.labelpos.toLowerCase()) {\n case \"l\": delta = wLabel.width / 2; break;\n case \"r\": delta = -wLabel.width / 2; break;\n }\n }\n if (delta) {\n sum += reverseSep ? delta : -delta;\n }\n delta = 0;\n\n return sum;\n };\n}\n\nfunction width(g, v) {\n return g.node(v).width;\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\nvar util = require(\"../util\");\nvar positionX = require(\"./bk\").positionX;\n\nmodule.exports = position;\n\nfunction position(g) {\n g = util.asNonCompoundGraph(g);\n\n positionY(g);\n _.forEach(positionX(g), function(x, v) {\n g.node(v).x = x;\n });\n}\n\nfunction positionY(g) {\n var layering = util.buildLayerMatrix(g);\n var rankSep = g.graph().ranksep;\n var prevY = 0;\n _.forEach(layering, function(layer) {\n var maxHeight = _.max(_.map(layer, function(v) { return g.node(v).height; }));\n _.forEach(layer, function(v) {\n g.node(v).y = prevY + maxHeight / 2;\n });\n prevY += maxHeight + rankSep;\n });\n}\n\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\nvar Graph = require(\"../graphlib\").Graph;\nvar slack = require(\"./util\").slack;\n\nmodule.exports = feasibleTree;\n\n/*\n * Constructs a spanning tree with tight edges and adjusted the input node's\n * ranks to achieve this. A tight edge is one that is has a length that matches\n * its \"minlen\" attribute.\n *\n * The basic structure for this function is derived from Gansner, et al., \"A\n * Technique for Drawing Directed Graphs.\"\n *\n * Pre-conditions:\n *\n * 1. Graph must be a DAG.\n * 2. Graph must be connected.\n * 3. Graph must have at least one node.\n * 5. Graph nodes must have been previously assigned a \"rank\" property that\n * respects the \"minlen\" property of incident edges.\n * 6. Graph edges must have a \"minlen\" property.\n *\n * Post-conditions:\n *\n * - Graph nodes will have their rank adjusted to ensure that all edges are\n * tight.\n *\n * Returns a tree (undirected graph) that is constructed using only \"tight\"\n * edges.\n */\nfunction feasibleTree(g) {\n var t = new Graph({ directed: false });\n\n // Choose arbitrary node from which to start our tree\n var start = g.nodes()[0];\n var size = g.nodeCount();\n t.setNode(start, {});\n\n var edge, delta;\n while (tightTree(t, g) < size) {\n edge = findMinSlackEdge(t, g);\n delta = t.hasNode(edge.v) ? slack(g, edge) : -slack(g, edge);\n shiftRanks(t, g, delta);\n }\n\n return t;\n}\n\n/*\n * Finds a maximal tree of tight edges and returns the number of nodes in the\n * tree.\n */\nfunction tightTree(t, g) {\n function dfs(v) {\n _.forEach(g.nodeEdges(v), function(e) {\n var edgeV = e.v,\n w = (v === edgeV) ? e.w : edgeV;\n if (!t.hasNode(w) && !slack(g, e)) {\n t.setNode(w, {});\n t.setEdge(v, w, {});\n dfs(w);\n }\n });\n }\n\n _.forEach(t.nodes(), dfs);\n return t.nodeCount();\n}\n\n/*\n * Finds the edge with the smallest slack that is incident on tree and returns\n * it.\n */\nfunction findMinSlackEdge(t, g) {\n return _.minBy(g.edges(), function(e) {\n if (t.hasNode(e.v) !== t.hasNode(e.w)) {\n return slack(g, e);\n }\n });\n}\n\nfunction shiftRanks(t, g, delta) {\n _.forEach(t.nodes(), function(v) {\n g.node(v).rank += delta;\n });\n}\n","\"use strict\";\n\nvar rankUtil = require(\"./util\");\nvar longestPath = rankUtil.longestPath;\nvar feasibleTree = require(\"./feasible-tree\");\nvar networkSimplex = require(\"./network-simplex\");\n\nmodule.exports = rank;\n\n/*\n * Assigns a rank to each node in the input graph that respects the \"minlen\"\n * constraint specified on edges between nodes.\n *\n * This basic structure is derived from Gansner, et al., \"A Technique for\n * Drawing Directed Graphs.\"\n *\n * Pre-conditions:\n *\n * 1. Graph must be a connected DAG\n * 2. Graph nodes must be objects\n * 3. Graph edges must have \"weight\" and \"minlen\" attributes\n *\n * Post-conditions:\n *\n * 1. Graph nodes will have a \"rank\" attribute based on the results of the\n * algorithm. Ranks can start at any index (including negative), we'll\n * fix them up later.\n */\nfunction rank(g) {\n switch(g.graph().ranker) {\n case \"network-simplex\": networkSimplexRanker(g); break;\n case \"tight-tree\": tightTreeRanker(g); break;\n case \"longest-path\": longestPathRanker(g); break;\n default: networkSimplexRanker(g);\n }\n}\n\n// A fast and simple ranker, but results are far from optimal.\nvar longestPathRanker = longestPath;\n\nfunction tightTreeRanker(g) {\n longestPath(g);\n feasibleTree(g);\n}\n\nfunction networkSimplexRanker(g) {\n networkSimplex(g);\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\nvar feasibleTree = require(\"./feasible-tree\");\nvar slack = require(\"./util\").slack;\nvar initRank = require(\"./util\").longestPath;\nvar preorder = require(\"../graphlib\").alg.preorder;\nvar postorder = require(\"../graphlib\").alg.postorder;\nvar simplify = require(\"../util\").simplify;\n\nmodule.exports = networkSimplex;\n\n// Expose some internals for testing purposes\nnetworkSimplex.initLowLimValues = initLowLimValues;\nnetworkSimplex.initCutValues = initCutValues;\nnetworkSimplex.calcCutValue = calcCutValue;\nnetworkSimplex.leaveEdge = leaveEdge;\nnetworkSimplex.enterEdge = enterEdge;\nnetworkSimplex.exchangeEdges = exchangeEdges;\n\n/*\n * The network simplex algorithm assigns ranks to each node in the input graph\n * and iteratively improves the ranking to reduce the length of edges.\n *\n * Preconditions:\n *\n * 1. The input graph must be a DAG.\n * 2. All nodes in the graph must have an object value.\n * 3. All edges in the graph must have \"minlen\" and \"weight\" attributes.\n *\n * Postconditions:\n *\n * 1. All nodes in the graph will have an assigned \"rank\" attribute that has\n * been optimized by the network simplex algorithm. Ranks start at 0.\n *\n *\n * A rough sketch of the algorithm is as follows:\n *\n * 1. Assign initial ranks to each node. We use the longest path algorithm,\n * which assigns ranks to the lowest position possible. In general this\n * leads to very wide bottom ranks and unnecessarily long edges.\n * 2. Construct a feasible tight tree. A tight tree is one such that all\n * edges in the tree have no slack (difference between length of edge\n * and minlen for the edge). This by itself greatly improves the assigned\n * rankings by shorting edges.\n * 3. Iteratively find edges that have negative cut values. Generally a\n * negative cut value indicates that the edge could be removed and a new\n * tree edge could be added to produce a more compact graph.\n *\n * Much of the algorithms here are derived from Gansner, et al., \"A Technique\n * for Drawing Directed Graphs.\" The structure of the file roughly follows the\n * structure of the overall algorithm.\n */\nfunction networkSimplex(g) {\n g = simplify(g);\n initRank(g);\n var t = feasibleTree(g);\n initLowLimValues(t);\n initCutValues(t, g);\n\n var e, f;\n while ((e = leaveEdge(t))) {\n f = enterEdge(t, g, e);\n exchangeEdges(t, g, e, f);\n }\n}\n\n/*\n * Initializes cut values for all edges in the tree.\n */\nfunction initCutValues(t, g) {\n var vs = postorder(t, t.nodes());\n vs = vs.slice(0, vs.length - 1);\n _.forEach(vs, function(v) {\n assignCutValue(t, g, v);\n });\n}\n\nfunction assignCutValue(t, g, child) {\n var childLab = t.node(child);\n var parent = childLab.parent;\n t.edge(child, parent).cutvalue = calcCutValue(t, g, child);\n}\n\n/*\n * Given the tight tree, its graph, and a child in the graph calculate and\n * return the cut value for the edge between the child and its parent.\n */\nfunction calcCutValue(t, g, child) {\n var childLab = t.node(child);\n var parent = childLab.parent;\n // True if the child is on the tail end of the edge in the directed graph\n var childIsTail = true;\n // The graph's view of the tree edge we're inspecting\n var graphEdge = g.edge(child, parent);\n // The accumulated cut value for the edge between this node and its parent\n var cutValue = 0;\n\n if (!graphEdge) {\n childIsTail = false;\n graphEdge = g.edge(parent, child);\n }\n\n cutValue = graphEdge.weight;\n\n _.forEach(g.nodeEdges(child), function(e) {\n var isOutEdge = e.v === child,\n other = isOutEdge ? e.w : e.v;\n\n if (other !== parent) {\n var pointsToHead = isOutEdge === childIsTail,\n otherWeight = g.edge(e).weight;\n\n cutValue += pointsToHead ? otherWeight : -otherWeight;\n if (isTreeEdge(t, child, other)) {\n var otherCutValue = t.edge(child, other).cutvalue;\n cutValue += pointsToHead ? -otherCutValue : otherCutValue;\n }\n }\n });\n\n return cutValue;\n}\n\nfunction initLowLimValues(tree, root) {\n if (arguments.length < 2) {\n root = tree.nodes()[0];\n }\n dfsAssignLowLim(tree, {}, 1, root);\n}\n\nfunction dfsAssignLowLim(tree, visited, nextLim, v, parent) {\n var low = nextLim;\n var label = tree.node(v);\n\n visited[v] = true;\n _.forEach(tree.neighbors(v), function(w) {\n if (!_.has(visited, w)) {\n nextLim = dfsAssignLowLim(tree, visited, nextLim, w, v);\n }\n });\n\n label.low = low;\n label.lim = nextLim++;\n if (parent) {\n label.parent = parent;\n } else {\n // TODO should be able to remove this when we incrementally update low lim\n delete label.parent;\n }\n\n return nextLim;\n}\n\nfunction leaveEdge(tree) {\n return _.find(tree.edges(), function(e) {\n return tree.edge(e).cutvalue < 0;\n });\n}\n\nfunction enterEdge(t, g, edge) {\n var v = edge.v;\n var w = edge.w;\n\n // For the rest of this function we assume that v is the tail and w is the\n // head, so if we don't have this edge in the graph we should flip it to\n // match the correct orientation.\n if (!g.hasEdge(v, w)) {\n v = edge.w;\n w = edge.v;\n }\n\n var vLabel = t.node(v);\n var wLabel = t.node(w);\n var tailLabel = vLabel;\n var flip = false;\n\n // If the root is in the tail of the edge then we need to flip the logic that\n // checks for the head and tail nodes in the candidates function below.\n if (vLabel.lim > wLabel.lim) {\n tailLabel = wLabel;\n flip = true;\n }\n\n var candidates = _.filter(g.edges(), function(edge) {\n return flip === isDescendant(t, t.node(edge.v), tailLabel) &&\n flip !== isDescendant(t, t.node(edge.w), tailLabel);\n });\n\n return _.minBy(candidates, function(edge) { return slack(g, edge); });\n}\n\nfunction exchangeEdges(t, g, e, f) {\n var v = e.v;\n var w = e.w;\n t.removeEdge(v, w);\n t.setEdge(f.v, f.w, {});\n initLowLimValues(t);\n initCutValues(t, g);\n updateRanks(t, g);\n}\n\nfunction updateRanks(t, g) {\n var root = _.find(t.nodes(), function(v) { return !g.node(v).parent; });\n var vs = preorder(t, root);\n vs = vs.slice(1);\n _.forEach(vs, function(v) {\n var parent = t.node(v).parent,\n edge = g.edge(v, parent),\n flipped = false;\n\n if (!edge) {\n edge = g.edge(parent, v);\n flipped = true;\n }\n\n g.node(v).rank = g.node(parent).rank + (flipped ? edge.minlen : -edge.minlen);\n });\n}\n\n/*\n * Returns true if the edge is in the tree.\n */\nfunction isTreeEdge(tree, u, v) {\n return tree.hasEdge(u, v);\n}\n\n/*\n * Returns true if the specified node is descendant of the root node per the\n * assigned low and lim attributes in the tree.\n */\nfunction isDescendant(tree, vLabel, rootLabel) {\n return rootLabel.low <= vLabel.lim && vLabel.lim <= rootLabel.lim;\n}\n","\"use strict\";\n\nvar _ = require(\"../lodash\");\n\nmodule.exports = {\n longestPath: longestPath,\n slack: slack\n};\n\n/*\n * Initializes ranks for the input graph using the longest path algorithm. This\n * algorithm scales well and is fast in practice, it yields rather poor\n * solutions. Nodes are pushed to the lowest layer possible, leaving the bottom\n * ranks wide and leaving edges longer than necessary. However, due to its\n * speed, this algorithm is good for getting an initial ranking that can be fed\n * into other algorithms.\n *\n * This algorithm does not normalize layers because it will be used by other\n * algorithms in most cases. If using this algorithm directly, be sure to\n * run normalize at the end.\n *\n * Pre-conditions:\n *\n * 1. Input graph is a DAG.\n * 2. Input graph node labels can be assigned properties.\n *\n * Post-conditions:\n *\n * 1. Each node will be assign an (unnormalized) \"rank\" property.\n */\nfunction longestPath(g) {\n var visited = {};\n\n function dfs(v) {\n var label = g.node(v);\n if (_.has(visited, v)) {\n return label.rank;\n }\n visited[v] = true;\n\n var rank = _.min(_.map(g.outEdges(v), function(e) {\n return dfs(e.w) - g.edge(e).minlen;\n }));\n\n if (rank === Number.POSITIVE_INFINITY || // return value of _.map([]) for Lodash 3\n rank === undefined || // return value of _.map([]) for Lodash 4\n rank === null) { // return value of _.map([null])\n rank = 0;\n }\n\n return (label.rank = rank);\n }\n\n _.forEach(g.sources(), dfs);\n}\n\n/*\n * Returns the amount of slack for the given edge. The slack is defined as the\n * difference between the length of the edge and its minimum length.\n */\nfunction slack(g, e) {\n return g.node(e.w).rank - g.node(e.v).rank - g.edge(e).minlen;\n}\n","/* eslint \"no-console\": off */\n\n\"use strict\";\n\nvar _ = require(\"./lodash\");\nvar Graph = require(\"./graphlib\").Graph;\n\nmodule.exports = {\n addDummyNode: addDummyNode,\n simplify: simplify,\n asNonCompoundGraph: asNonCompoundGraph,\n successorWeights: successorWeights,\n predecessorWeights: predecessorWeights,\n intersectRect: intersectRect,\n buildLayerMatrix: buildLayerMatrix,\n normalizeRanks: normalizeRanks,\n removeEmptyRanks: removeEmptyRanks,\n addBorderNode: addBorderNode,\n maxRank: maxRank,\n partition: partition,\n time: time,\n notime: notime\n};\n\n/*\n * Adds a dummy node to the graph and return v.\n */\nfunction addDummyNode(g, type, attrs, name) {\n var v;\n do {\n v = _.uniqueId(name);\n } while (g.hasNode(v));\n\n attrs.dummy = type;\n g.setNode(v, attrs);\n return v;\n}\n\n/*\n * Returns a new graph with only simple edges. Handles aggregation of data\n * associated with multi-edges.\n */\nfunction simplify(g) {\n var simplified = new Graph().setGraph(g.graph());\n _.forEach(g.nodes(), function(v) { simplified.setNode(v, g.node(v)); });\n _.forEach(g.edges(), function(e) {\n var simpleLabel = simplified.edge(e.v, e.w) || { weight: 0, minlen: 1 };\n var label = g.edge(e);\n simplified.setEdge(e.v, e.w, {\n weight: simpleLabel.weight + label.weight,\n minlen: Math.max(simpleLabel.minlen, label.minlen)\n });\n });\n return simplified;\n}\n\nfunction asNonCompoundGraph(g) {\n var simplified = new Graph({ multigraph: g.isMultigraph() }).setGraph(g.graph());\n _.forEach(g.nodes(), function(v) {\n if (!g.children(v).length) {\n simplified.setNode(v, g.node(v));\n }\n });\n _.forEach(g.edges(), function(e) {\n simplified.setEdge(e, g.edge(e));\n });\n return simplified;\n}\n\nfunction successorWeights(g) {\n var weightMap = _.map(g.nodes(), function(v) {\n var sucs = {};\n _.forEach(g.outEdges(v), function(e) {\n sucs[e.w] = (sucs[e.w] || 0) + g.edge(e).weight;\n });\n return sucs;\n });\n return _.zipObject(g.nodes(), weightMap);\n}\n\nfunction predecessorWeights(g) {\n var weightMap = _.map(g.nodes(), function(v) {\n var preds = {};\n _.forEach(g.inEdges(v), function(e) {\n preds[e.v] = (preds[e.v] || 0) + g.edge(e).weight;\n });\n return preds;\n });\n return _.zipObject(g.nodes(), weightMap);\n}\n\n/*\n * Finds where a line starting at point ({x, y}) would intersect a rectangle\n * ({x, y, width, height}) if it were pointing at the rectangle's center.\n */\nfunction intersectRect(rect, point) {\n var x = rect.x;\n var y = rect.y;\n\n // Rectangle intersection algorithm from:\n // http://math.stackexchange.com/questions/108113/find-edge-between-two-boxes\n var dx = point.x - x;\n var dy = point.y - y;\n var w = rect.width / 2;\n var h = rect.height / 2;\n\n if (!dx && !dy) {\n throw new Error(\"Not possible to find intersection inside of the rectangle\");\n }\n\n var sx, sy;\n if (Math.abs(dy) * w > Math.abs(dx) * h) {\n // Intersection is top or bottom of rect.\n if (dy < 0) {\n h = -h;\n }\n sx = h * dx / dy;\n sy = h;\n } else {\n // Intersection is left or right of rect.\n if (dx < 0) {\n w = -w;\n }\n sx = w;\n sy = w * dy / dx;\n }\n\n return { x: x + sx, y: y + sy };\n}\n\n/*\n * Given a DAG with each node assigned \"rank\" and \"order\" properties, this\n * function will produce a matrix with the ids of each node.\n */\nfunction buildLayerMatrix(g) {\n var layering = _.map(_.range(maxRank(g) + 1), function() { return []; });\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v);\n var rank = node.rank;\n if (!_.isUndefined(rank)) {\n layering[rank][node.order] = v;\n }\n });\n return layering;\n}\n\n/*\n * Adjusts the ranks for all nodes in the graph such that all nodes v have\n * rank(v) >= 0 and at least one node w has rank(w) = 0.\n */\nfunction normalizeRanks(g) {\n var min = _.min(_.map(g.nodes(), function(v) { return g.node(v).rank; }));\n _.forEach(g.nodes(), function(v) {\n var node = g.node(v);\n if (_.has(node, \"rank\")) {\n node.rank -= min;\n }\n });\n}\n\nfunction removeEmptyRanks(g) {\n // Ranks may not start at 0, so we need to offset them\n var offset = _.min(_.map(g.nodes(), function(v) { return g.node(v).rank; }));\n\n var layers = [];\n _.forEach(g.nodes(), function(v) {\n var rank = g.node(v).rank - offset;\n if (!layers[rank]) {\n layers[rank] = [];\n }\n layers[rank].push(v);\n });\n\n var delta = 0;\n var nodeRankFactor = g.graph().nodeRankFactor;\n _.forEach(layers, function(vs, i) {\n if (_.isUndefined(vs) && i % nodeRankFactor !== 0) {\n --delta;\n } else if (delta) {\n _.forEach(vs, function(v) { g.node(v).rank += delta; });\n }\n });\n}\n\nfunction addBorderNode(g, prefix, rank, order) {\n var node = {\n width: 0,\n height: 0\n };\n if (arguments.length >= 4) {\n node.rank = rank;\n node.order = order;\n }\n return addDummyNode(g, \"border\", node, prefix);\n}\n\nfunction maxRank(g) {\n return _.max(_.map(g.nodes(), function(v) {\n var rank = g.node(v).rank;\n if (!_.isUndefined(rank)) {\n return rank;\n }\n }));\n}\n\n/*\n * Partition a collection into two groups: `lhs` and `rhs`. If the supplied\n * function returns true for an entry it goes into `lhs`. Otherwise it goes\n * into `rhs.\n */\nfunction partition(collection, fn) {\n var result = { lhs: [], rhs: [] };\n _.forEach(collection, function(value) {\n if (fn(value)) {\n result.lhs.push(value);\n } else {\n result.rhs.push(value);\n }\n });\n return result;\n}\n\n/*\n * Returns a new function that wraps `fn` with a timer. The wrapper logs the\n * time it takes to execute the function.\n */\nfunction time(name, fn) {\n var start = _.now();\n try {\n return fn();\n } finally {\n console.log(name + \" time: \" + (_.now() - start) + \"ms\");\n }\n}\n\nfunction notime(name, fn) {\n return fn();\n}\n","module.exports = \"0.8.5\";\n","module.exports = add\n\n/**\n * Adds two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nfunction add(out, a, b) {\n out[0] = a[0] + b[0]\n out[1] = a[1] + b[1]\n return out\n}","module.exports = ceil\n\n/**\n * Math.ceil the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to ceil\n * @returns {vec2} out\n */\nfunction ceil(out, a) {\n out[0] = Math.ceil(a[0])\n out[1] = Math.ceil(a[1])\n return out\n}\n","module.exports = clone\n\n/**\n * Creates a new vec2 initialized with values from an existing vector\n *\n * @param {vec2} a vector to clone\n * @returns {vec2} a new 2D vector\n */\nfunction clone(a) {\n var out = new Float32Array(2)\n out[0] = a[0]\n out[1] = a[1]\n return out\n}","module.exports = copy\n\n/**\n * Copy the values from one vec2 to another\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the source vector\n * @returns {vec2} out\n */\nfunction copy(out, a) {\n out[0] = a[0]\n out[1] = a[1]\n return out\n}","module.exports = create\n\n/**\n * Creates a new, empty vec2\n *\n * @returns {vec2} a new 2D vector\n */\nfunction create() {\n var out = new Float32Array(2)\n out[0] = 0\n out[1] = 0\n return out\n}","module.exports = cross\n\n/**\n * Computes the cross product of two vec2's\n * Note that the cross product must by definition produce a 3D vector\n *\n * @param {vec3} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec3} out\n */\nfunction cross(out, a, b) {\n var z = a[0] * b[1] - a[1] * b[0]\n out[0] = out[1] = 0\n out[2] = z\n return out\n}","module.exports = require('./distance')\n","module.exports = distance\n\n/**\n * Calculates the euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} distance between a and b\n */\nfunction distance(a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1]\n return Math.sqrt(x*x + y*y)\n}","module.exports = require('./divide')\n","module.exports = divide\n\n/**\n * Divides two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nfunction divide(out, a, b) {\n out[0] = a[0] / b[0]\n out[1] = a[1] / b[1]\n return out\n}","module.exports = dot\n\n/**\n * Calculates the dot product of two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} dot product of a and b\n */\nfunction dot(a, b) {\n return a[0] * b[0] + a[1] * b[1]\n}","module.exports = 0.000001\n","module.exports = equals\n\nvar EPSILON = require('./epsilon')\n\n/**\n * Returns whether or not the vectors have approximately the same elements in the same position.\n *\n * @param {vec2} a The first vector.\n * @param {vec2} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\nfunction equals(a, b) {\n var a0 = a[0]\n var a1 = a[1]\n var b0 = b[0]\n var b1 = b[1]\n return (Math.abs(a0 - b0) <= EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) &&\n Math.abs(a1 - b1) <= EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)))\n}\n","module.exports = exactEquals\n\n/**\n * Returns whether or not the vectors exactly have the same elements in the same position (when compared with ===)\n *\n * @param {vec2} a The first vector.\n * @param {vec2} b The second vector.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\nfunction exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1]\n}\n","module.exports = floor\n\n/**\n * Math.floor the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to floor\n * @returns {vec2} out\n */\nfunction floor(out, a) {\n out[0] = Math.floor(a[0])\n out[1] = Math.floor(a[1])\n return out\n}\n","module.exports = forEach\n\nvar vec = require('./create')()\n\n/**\n * Perform some operation over an array of vec2s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nfunction forEach(a, stride, offset, count, fn, arg) {\n var i, l\n if(!stride) {\n stride = 2\n }\n\n if(!offset) {\n offset = 0\n }\n \n if(count) {\n l = Math.min((count * stride) + offset, a.length)\n } else {\n l = a.length\n }\n\n for(i = offset; i < l; i += stride) {\n vec[0] = a[i]\n vec[1] = a[i+1]\n fn(vec, vec, arg)\n a[i] = vec[0]\n a[i+1] = vec[1]\n }\n \n return a\n}","module.exports = fromValues\n\n/**\n * Creates a new vec2 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} a new 2D vector\n */\nfunction fromValues(x, y) {\n var out = new Float32Array(2)\n out[0] = x\n out[1] = y\n return out\n}","module.exports = {\n EPSILON: require('./epsilon')\n , create: require('./create')\n , clone: require('./clone')\n , fromValues: require('./fromValues')\n , copy: require('./copy')\n , set: require('./set')\n , equals: require('./equals')\n , exactEquals: require('./exactEquals')\n , add: require('./add')\n , subtract: require('./subtract')\n , sub: require('./sub')\n , multiply: require('./multiply')\n , mul: require('./mul')\n , divide: require('./divide')\n , div: require('./div')\n , inverse: require('./inverse')\n , min: require('./min')\n , max: require('./max')\n , rotate: require('./rotate')\n , floor: require('./floor')\n , ceil: require('./ceil')\n , round: require('./round')\n , scale: require('./scale')\n , scaleAndAdd: require('./scaleAndAdd')\n , distance: require('./distance')\n , dist: require('./dist')\n , squaredDistance: require('./squaredDistance')\n , sqrDist: require('./sqrDist')\n , length: require('./length')\n , len: require('./len')\n , squaredLength: require('./squaredLength')\n , sqrLen: require('./sqrLen')\n , negate: require('./negate')\n , normalize: require('./normalize')\n , dot: require('./dot')\n , cross: require('./cross')\n , lerp: require('./lerp')\n , random: require('./random')\n , transformMat2: require('./transformMat2')\n , transformMat2d: require('./transformMat2d')\n , transformMat3: require('./transformMat3')\n , transformMat4: require('./transformMat4')\n , forEach: require('./forEach')\n , limit: require('./limit')\n}\n","module.exports = inverse\n\n/**\n * Returns the inverse of the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to invert\n * @returns {vec2} out\n */\nfunction inverse(out, a) {\n out[0] = 1.0 / a[0]\n out[1] = 1.0 / a[1]\n return out\n}\n","module.exports = require('./length')\n","module.exports = length\n\n/**\n * Calculates the length of a vec2\n *\n * @param {vec2} a vector to calculate length of\n * @returns {Number} length of a\n */\nfunction length(a) {\n var x = a[0],\n y = a[1]\n return Math.sqrt(x*x + y*y)\n}","module.exports = lerp\n\n/**\n * Performs a linear interpolation between two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec2} out\n */\nfunction lerp(out, a, b, t) {\n var ax = a[0],\n ay = a[1]\n out[0] = ax + t * (b[0] - ax)\n out[1] = ay + t * (b[1] - ay)\n return out\n}","module.exports = limit;\n\n/**\n * Limit the magnitude of this vector to the value used for the `max`\n * parameter.\n *\n * @param {vec2} the vector to limit\n * @param {Number} max the maximum magnitude for the vector\n * @returns {vec2} out\n */\nfunction limit(out, a, max) {\n var mSq = a[0] * a[0] + a[1] * a[1];\n\n if (mSq > max * max) {\n var n = Math.sqrt(mSq);\n out[0] = a[0] / n * max;\n out[1] = a[1] / n * max;\n } else {\n out[0] = a[0];\n out[1] = a[1];\n }\n\n return out;\n}\n","module.exports = max\n\n/**\n * Returns the maximum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nfunction max(out, a, b) {\n out[0] = Math.max(a[0], b[0])\n out[1] = Math.max(a[1], b[1])\n return out\n}","module.exports = min\n\n/**\n * Returns the minimum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nfunction min(out, a, b) {\n out[0] = Math.min(a[0], b[0])\n out[1] = Math.min(a[1], b[1])\n return out\n}","module.exports = require('./multiply')\n","module.exports = multiply\n\n/**\n * Multiplies two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nfunction multiply(out, a, b) {\n out[0] = a[0] * b[0]\n out[1] = a[1] * b[1]\n return out\n}","module.exports = negate\n\n/**\n * Negates the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to negate\n * @returns {vec2} out\n */\nfunction negate(out, a) {\n out[0] = -a[0]\n out[1] = -a[1]\n return out\n}","module.exports = normalize\n\n/**\n * Normalize a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to normalize\n * @returns {vec2} out\n */\nfunction normalize(out, a) {\n var x = a[0],\n y = a[1]\n var len = x*x + y*y\n if (len > 0) {\n //TODO: evaluate use of glm_invsqrt here?\n len = 1 / Math.sqrt(len)\n out[0] = a[0] * len\n out[1] = a[1] * len\n }\n return out\n}","module.exports = random\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec2} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec2} out\n */\nfunction random(out, scale) {\n scale = scale || 1.0\n var r = Math.random() * 2.0 * Math.PI\n out[0] = Math.cos(r) * scale\n out[1] = Math.sin(r) * scale\n return out\n}","module.exports = rotate\n\n/**\n * Rotates a vec2 by an angle\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to rotate\n * @param {Number} angle the angle of rotation (in radians)\n * @returns {vec2} out\n */\nfunction rotate(out, a, angle) {\n var c = Math.cos(angle),\n s = Math.sin(angle)\n var x = a[0],\n y = a[1]\n\n out[0] = x * c - y * s\n out[1] = x * s + y * c\n\n return out\n}\n\n","module.exports = round\n\n/**\n * Math.round the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to round\n * @returns {vec2} out\n */\nfunction round(out, a) {\n out[0] = Math.round(a[0])\n out[1] = Math.round(a[1])\n return out\n}\n","module.exports = scale\n\n/**\n * Scales a vec2 by a scalar number\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec2} out\n */\nfunction scale(out, a, b) {\n out[0] = a[0] * b\n out[1] = a[1] * b\n return out\n}","module.exports = scaleAndAdd\n\n/**\n * Adds two vec2's after scaling the second operand by a scalar value\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec2} out\n */\nfunction scaleAndAdd(out, a, b, scale) {\n out[0] = a[0] + (b[0] * scale)\n out[1] = a[1] + (b[1] * scale)\n return out\n}","module.exports = set\n\n/**\n * Set the components of a vec2 to the given values\n *\n * @param {vec2} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} out\n */\nfunction set(out, x, y) {\n out[0] = x\n out[1] = y\n return out\n}","module.exports = require('./squaredDistance')\n","module.exports = require('./squaredLength')\n","module.exports = squaredDistance\n\n/**\n * Calculates the squared euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} squared distance between a and b\n */\nfunction squaredDistance(a, b) {\n var x = b[0] - a[0],\n y = b[1] - a[1]\n return x*x + y*y\n}","module.exports = squaredLength\n\n/**\n * Calculates the squared length of a vec2\n *\n * @param {vec2} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nfunction squaredLength(a) {\n var x = a[0],\n y = a[1]\n return x*x + y*y\n}","module.exports = require('./subtract')\n","module.exports = subtract\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nfunction subtract(out, a, b) {\n out[0] = a[0] - b[0]\n out[1] = a[1] - b[1]\n return out\n}","module.exports = transformMat2\n\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2} m matrix to transform with\n * @returns {vec2} out\n */\nfunction transformMat2(out, a, m) {\n var x = a[0],\n y = a[1]\n out[0] = m[0] * x + m[2] * y\n out[1] = m[1] * x + m[3] * y\n return out\n}","module.exports = transformMat2d\n\n/**\n * Transforms the vec2 with a mat2d\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2d} m matrix to transform with\n * @returns {vec2} out\n */\nfunction transformMat2d(out, a, m) {\n var x = a[0],\n y = a[1]\n out[0] = m[0] * x + m[2] * y + m[4]\n out[1] = m[1] * x + m[3] * y + m[5]\n return out\n}","module.exports = transformMat3\n\n/**\n * Transforms the vec2 with a mat3\n * 3rd vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat3} m matrix to transform with\n * @returns {vec2} out\n */\nfunction transformMat3(out, a, m) {\n var x = a[0],\n y = a[1]\n out[0] = m[0] * x + m[3] * y + m[6]\n out[1] = m[1] * x + m[4] * y + m[7]\n return out\n}","module.exports = transformMat4\n\n/**\n * Transforms the vec2 with a mat4\n * 3rd vector component is implicitly '0'\n * 4th vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec2} out\n */\nfunction transformMat4(out, a, m) {\n var x = a[0], \n y = a[1]\n out[0] = m[0] * x + m[4] * y + m[12]\n out[1] = m[1] * x + m[5] * y + m[13]\n return out\n}","/**\n * Copyright (c) 2014, Chris Pettitt\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n *\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the documentation\n * and/or other materials provided with the distribution.\n *\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nvar lib = require(\"./lib\");\n\nmodule.exports = {\n Graph: lib.Graph,\n json: require(\"./lib/json\"),\n alg: require(\"./lib/alg\"),\n version: lib.version\n};\n","var _ = require(\"../lodash\");\n\nmodule.exports = components;\n\nfunction components(g) {\n var visited = {};\n var cmpts = [];\n var cmpt;\n\n function dfs(v) {\n if (_.has(visited, v)) return;\n visited[v] = true;\n cmpt.push(v);\n _.each(g.successors(v), dfs);\n _.each(g.predecessors(v), dfs);\n }\n\n _.each(g.nodes(), function(v) {\n cmpt = [];\n dfs(v);\n if (cmpt.length) {\n cmpts.push(cmpt);\n }\n });\n\n return cmpts;\n}\n","var _ = require(\"../lodash\");\n\nmodule.exports = dfs;\n\n/*\n * A helper that preforms a pre- or post-order traversal on the input graph\n * and returns the nodes in the order they were visited. If the graph is\n * undirected then this algorithm will navigate using neighbors. If the graph\n * is directed then this algorithm will navigate using successors.\n *\n * Order must be one of \"pre\" or \"post\".\n */\nfunction dfs(g, vs, order) {\n if (!_.isArray(vs)) {\n vs = [vs];\n }\n\n var navigation = (g.isDirected() ? g.successors : g.neighbors).bind(g);\n\n var acc = [];\n var visited = {};\n _.each(vs, function(v) {\n if (!g.hasNode(v)) {\n throw new Error(\"Graph does not have node: \" + v);\n }\n\n doDfs(g, v, order === \"post\", visited, navigation, acc);\n });\n return acc;\n}\n\nfunction doDfs(g, v, postorder, visited, navigation, acc) {\n if (!_.has(visited, v)) {\n visited[v] = true;\n\n if (!postorder) { acc.push(v); }\n _.each(navigation(v), function(w) {\n doDfs(g, w, postorder, visited, navigation, acc);\n });\n if (postorder) { acc.push(v); }\n }\n}\n","var dijkstra = require(\"./dijkstra\");\nvar _ = require(\"../lodash\");\n\nmodule.exports = dijkstraAll;\n\nfunction dijkstraAll(g, weightFunc, edgeFunc) {\n return _.transform(g.nodes(), function(acc, v) {\n acc[v] = dijkstra(g, v, weightFunc, edgeFunc);\n }, {});\n}\n","var _ = require(\"../lodash\");\nvar PriorityQueue = require(\"../data/priority-queue\");\n\nmodule.exports = dijkstra;\n\nvar DEFAULT_WEIGHT_FUNC = _.constant(1);\n\nfunction dijkstra(g, source, weightFn, edgeFn) {\n return runDijkstra(g, String(source),\n weightFn || DEFAULT_WEIGHT_FUNC,\n edgeFn || function(v) { return g.outEdges(v); });\n}\n\nfunction runDijkstra(g, source, weightFn, edgeFn) {\n var results = {};\n var pq = new PriorityQueue();\n var v, vEntry;\n\n var updateNeighbors = function(edge) {\n var w = edge.v !== v ? edge.v : edge.w;\n var wEntry = results[w];\n var weight = weightFn(edge);\n var distance = vEntry.distance + weight;\n\n if (weight < 0) {\n throw new Error(\"dijkstra does not allow negative edge weights. \" +\n \"Bad edge: \" + edge + \" Weight: \" + weight);\n }\n\n if (distance < wEntry.distance) {\n wEntry.distance = distance;\n wEntry.predecessor = v;\n pq.decrease(w, distance);\n }\n };\n\n g.nodes().forEach(function(v) {\n var distance = v === source ? 0 : Number.POSITIVE_INFINITY;\n results[v] = { distance: distance };\n pq.add(v, distance);\n });\n\n while (pq.size() > 0) {\n v = pq.removeMin();\n vEntry = results[v];\n if (vEntry.distance === Number.POSITIVE_INFINITY) {\n break;\n }\n\n edgeFn(v).forEach(updateNeighbors);\n }\n\n return results;\n}\n","var _ = require(\"../lodash\");\nvar tarjan = require(\"./tarjan\");\n\nmodule.exports = findCycles;\n\nfunction findCycles(g) {\n return _.filter(tarjan(g), function(cmpt) {\n return cmpt.length > 1 || (cmpt.length === 1 && g.hasEdge(cmpt[0], cmpt[0]));\n });\n}\n","var _ = require(\"../lodash\");\n\nmodule.exports = floydWarshall;\n\nvar DEFAULT_WEIGHT_FUNC = _.constant(1);\n\nfunction floydWarshall(g, weightFn, edgeFn) {\n return runFloydWarshall(g,\n weightFn || DEFAULT_WEIGHT_FUNC,\n edgeFn || function(v) { return g.outEdges(v); });\n}\n\nfunction runFloydWarshall(g, weightFn, edgeFn) {\n var results = {};\n var nodes = g.nodes();\n\n nodes.forEach(function(v) {\n results[v] = {};\n results[v][v] = { distance: 0 };\n nodes.forEach(function(w) {\n if (v !== w) {\n results[v][w] = { distance: Number.POSITIVE_INFINITY };\n }\n });\n edgeFn(v).forEach(function(edge) {\n var w = edge.v === v ? edge.w : edge.v;\n var d = weightFn(edge);\n results[v][w] = { distance: d, predecessor: v };\n });\n });\n\n nodes.forEach(function(k) {\n var rowK = results[k];\n nodes.forEach(function(i) {\n var rowI = results[i];\n nodes.forEach(function(j) {\n var ik = rowI[k];\n var kj = rowK[j];\n var ij = rowI[j];\n var altDistance = ik.distance + kj.distance;\n if (altDistance < ij.distance) {\n ij.distance = altDistance;\n ij.predecessor = kj.predecessor;\n }\n });\n });\n });\n\n return results;\n}\n","module.exports = {\n components: require(\"./components\"),\n dijkstra: require(\"./dijkstra\"),\n dijkstraAll: require(\"./dijkstra-all\"),\n findCycles: require(\"./find-cycles\"),\n floydWarshall: require(\"./floyd-warshall\"),\n isAcyclic: require(\"./is-acyclic\"),\n postorder: require(\"./postorder\"),\n preorder: require(\"./preorder\"),\n prim: require(\"./prim\"),\n tarjan: require(\"./tarjan\"),\n topsort: require(\"./topsort\")\n};\n","var topsort = require(\"./topsort\");\n\nmodule.exports = isAcyclic;\n\nfunction isAcyclic(g) {\n try {\n topsort(g);\n } catch (e) {\n if (e instanceof topsort.CycleException) {\n return false;\n }\n throw e;\n }\n return true;\n}\n","var dfs = require(\"./dfs\");\n\nmodule.exports = postorder;\n\nfunction postorder(g, vs) {\n return dfs(g, vs, \"post\");\n}\n","var dfs = require(\"./dfs\");\n\nmodule.exports = preorder;\n\nfunction preorder(g, vs) {\n return dfs(g, vs, \"pre\");\n}\n","var _ = require(\"../lodash\");\nvar Graph = require(\"../graph\");\nvar PriorityQueue = require(\"../data/priority-queue\");\n\nmodule.exports = prim;\n\nfunction prim(g, weightFunc) {\n var result = new Graph();\n var parents = {};\n var pq = new PriorityQueue();\n var v;\n\n function updateNeighbors(edge) {\n var w = edge.v === v ? edge.w : edge.v;\n var pri = pq.priority(w);\n if (pri !== undefined) {\n var edgeWeight = weightFunc(edge);\n if (edgeWeight < pri) {\n parents[w] = v;\n pq.decrease(w, edgeWeight);\n }\n }\n }\n\n if (g.nodeCount() === 0) {\n return result;\n }\n\n _.each(g.nodes(), function(v) {\n pq.add(v, Number.POSITIVE_INFINITY);\n result.setNode(v);\n });\n\n // Start from an arbitrary node\n pq.decrease(g.nodes()[0], 0);\n\n var init = false;\n while (pq.size() > 0) {\n v = pq.removeMin();\n if (_.has(parents, v)) {\n result.setEdge(v, parents[v]);\n } else if (init) {\n throw new Error(\"Input graph is not connected: \" + g);\n } else {\n init = true;\n }\n\n g.nodeEdges(v).forEach(updateNeighbors);\n }\n\n return result;\n}\n","var _ = require(\"../lodash\");\n\nmodule.exports = tarjan;\n\nfunction tarjan(g) {\n var index = 0;\n var stack = [];\n var visited = {}; // node id -> { onStack, lowlink, index }\n var results = [];\n\n function dfs(v) {\n var entry = visited[v] = {\n onStack: true,\n lowlink: index,\n index: index++\n };\n stack.push(v);\n\n g.successors(v).forEach(function(w) {\n if (!_.has(visited, w)) {\n dfs(w);\n entry.lowlink = Math.min(entry.lowlink, visited[w].lowlink);\n } else if (visited[w].onStack) {\n entry.lowlink = Math.min(entry.lowlink, visited[w].index);\n }\n });\n\n if (entry.lowlink === entry.index) {\n var cmpt = [];\n var w;\n do {\n w = stack.pop();\n visited[w].onStack = false;\n cmpt.push(w);\n } while (v !== w);\n results.push(cmpt);\n }\n }\n\n g.nodes().forEach(function(v) {\n if (!_.has(visited, v)) {\n dfs(v);\n }\n });\n\n return results;\n}\n","var _ = require(\"../lodash\");\n\nmodule.exports = topsort;\ntopsort.CycleException = CycleException;\n\nfunction topsort(g) {\n var visited = {};\n var stack = {};\n var results = [];\n\n function visit(node) {\n if (_.has(stack, node)) {\n throw new CycleException();\n }\n\n if (!_.has(visited, node)) {\n stack[node] = true;\n visited[node] = true;\n _.each(g.predecessors(node), visit);\n delete stack[node];\n results.push(node);\n }\n }\n\n _.each(g.sinks(), visit);\n\n if (_.size(visited) !== g.nodeCount()) {\n throw new CycleException();\n }\n\n return results;\n}\n\nfunction CycleException() {}\nCycleException.prototype = new Error(); // must be an instance of Error to pass testing","var _ = require(\"../lodash\");\n\nmodule.exports = PriorityQueue;\n\n/**\n * A min-priority queue data structure. This algorithm is derived from Cormen,\n * et al., \"Introduction to Algorithms\". The basic idea of a min-priority\n * queue is that you can efficiently (in O(1) time) get the smallest key in\n * the queue. Adding and removing elements takes O(log n) time. A key can\n * have its priority decreased in O(log n) time.\n */\nfunction PriorityQueue() {\n this._arr = [];\n this._keyIndices = {};\n}\n\n/**\n * Returns the number of elements in the queue. Takes `O(1)` time.\n */\nPriorityQueue.prototype.size = function() {\n return this._arr.length;\n};\n\n/**\n * Returns the keys that are in the queue. Takes `O(n)` time.\n */\nPriorityQueue.prototype.keys = function() {\n return this._arr.map(function(x) { return x.key; });\n};\n\n/**\n * Returns `true` if **key** is in the queue and `false` if not.\n */\nPriorityQueue.prototype.has = function(key) {\n return _.has(this._keyIndices, key);\n};\n\n/**\n * Returns the priority for **key**. If **key** is not present in the queue\n * then this function returns `undefined`. Takes `O(1)` time.\n *\n * @param {Object} key\n */\nPriorityQueue.prototype.priority = function(key) {\n var index = this._keyIndices[key];\n if (index !== undefined) {\n return this._arr[index].priority;\n }\n};\n\n/**\n * Returns the key for the minimum element in this queue. If the queue is\n * empty this function throws an Error. Takes `O(1)` time.\n */\nPriorityQueue.prototype.min = function() {\n if (this.size() === 0) {\n throw new Error(\"Queue underflow\");\n }\n return this._arr[0].key;\n};\n\n/**\n * Inserts a new key into the priority queue. If the key already exists in\n * the queue this function returns `false`; otherwise it will return `true`.\n * Takes `O(n)` time.\n *\n * @param {Object} key the key to add\n * @param {Number} priority the initial priority for the key\n */\nPriorityQueue.prototype.add = function(key, priority) {\n var keyIndices = this._keyIndices;\n key = String(key);\n if (!_.has(keyIndices, key)) {\n var arr = this._arr;\n var index = arr.length;\n keyIndices[key] = index;\n arr.push({key: key, priority: priority});\n this._decrease(index);\n return true;\n }\n return false;\n};\n\n/**\n * Removes and returns the smallest key in the queue. Takes `O(log n)` time.\n */\nPriorityQueue.prototype.removeMin = function() {\n this._swap(0, this._arr.length - 1);\n var min = this._arr.pop();\n delete this._keyIndices[min.key];\n this._heapify(0);\n return min.key;\n};\n\n/**\n * Decreases the priority for **key** to **priority**. If the new priority is\n * greater than the previous priority, this function will throw an Error.\n *\n * @param {Object} key the key for which to raise priority\n * @param {Number} priority the new priority for the key\n */\nPriorityQueue.prototype.decrease = function(key, priority) {\n var index = this._keyIndices[key];\n if (priority > this._arr[index].priority) {\n throw new Error(\"New priority is greater than current priority. \" +\n \"Key: \" + key + \" Old: \" + this._arr[index].priority + \" New: \" + priority);\n }\n this._arr[index].priority = priority;\n this._decrease(index);\n};\n\nPriorityQueue.prototype._heapify = function(i) {\n var arr = this._arr;\n var l = 2 * i;\n var r = l + 1;\n var largest = i;\n if (l < arr.length) {\n largest = arr[l].priority < arr[largest].priority ? l : largest;\n if (r < arr.length) {\n largest = arr[r].priority < arr[largest].priority ? r : largest;\n }\n if (largest !== i) {\n this._swap(i, largest);\n this._heapify(largest);\n }\n }\n};\n\nPriorityQueue.prototype._decrease = function(index) {\n var arr = this._arr;\n var priority = arr[index].priority;\n var parent;\n while (index !== 0) {\n parent = index >> 1;\n if (arr[parent].priority < priority) {\n break;\n }\n this._swap(index, parent);\n index = parent;\n }\n};\n\nPriorityQueue.prototype._swap = function(i, j) {\n var arr = this._arr;\n var keyIndices = this._keyIndices;\n var origArrI = arr[i];\n var origArrJ = arr[j];\n arr[i] = origArrJ;\n arr[j] = origArrI;\n keyIndices[origArrJ.key] = i;\n keyIndices[origArrI.key] = j;\n};\n","\"use strict\";\n\nvar _ = require(\"./lodash\");\n\nmodule.exports = Graph;\n\nvar DEFAULT_EDGE_NAME = \"\\x00\";\nvar GRAPH_NODE = \"\\x00\";\nvar EDGE_KEY_DELIM = \"\\x01\";\n\n// Implementation notes:\n//\n// * Node id query functions should return string ids for the nodes\n// * Edge id query functions should return an \"edgeObj\", edge object, that is\n// composed of enough information to uniquely identify an edge: {v, w, name}.\n// * Internally we use an \"edgeId\", a stringified form of the edgeObj, to\n// reference edges. This is because we need a performant way to look these\n// edges up and, object properties, which have string keys, are the closest\n// we're going to get to a performant hashtable in JavaScript.\n\nfunction Graph(opts) {\n this._isDirected = _.has(opts, \"directed\") ? opts.directed : true;\n this._isMultigraph = _.has(opts, \"multigraph\") ? opts.multigraph : false;\n this._isCompound = _.has(opts, \"compound\") ? opts.compound : false;\n\n // Label for the graph itself\n this._label = undefined;\n\n // Defaults to be set when creating a new node\n this._defaultNodeLabelFn = _.constant(undefined);\n\n // Defaults to be set when creating a new edge\n this._defaultEdgeLabelFn = _.constant(undefined);\n\n // v -> label\n this._nodes = {};\n\n if (this._isCompound) {\n // v -> parent\n this._parent = {};\n\n // v -> children\n this._children = {};\n this._children[GRAPH_NODE] = {};\n }\n\n // v -> edgeObj\n this._in = {};\n\n // u -> v -> Number\n this._preds = {};\n\n // v -> edgeObj\n this._out = {};\n\n // v -> w -> Number\n this._sucs = {};\n\n // e -> edgeObj\n this._edgeObjs = {};\n\n // e -> label\n this._edgeLabels = {};\n}\n\n/* Number of nodes in the graph. Should only be changed by the implementation. */\nGraph.prototype._nodeCount = 0;\n\n/* Number of edges in the graph. Should only be changed by the implementation. */\nGraph.prototype._edgeCount = 0;\n\n\n/* === Graph functions ========= */\n\nGraph.prototype.isDirected = function() {\n return this._isDirected;\n};\n\nGraph.prototype.isMultigraph = function() {\n return this._isMultigraph;\n};\n\nGraph.prototype.isCompound = function() {\n return this._isCompound;\n};\n\nGraph.prototype.setGraph = function(label) {\n this._label = label;\n return this;\n};\n\nGraph.prototype.graph = function() {\n return this._label;\n};\n\n\n/* === Node functions ========== */\n\nGraph.prototype.setDefaultNodeLabel = function(newDefault) {\n if (!_.isFunction(newDefault)) {\n newDefault = _.constant(newDefault);\n }\n this._defaultNodeLabelFn = newDefault;\n return this;\n};\n\nGraph.prototype.nodeCount = function() {\n return this._nodeCount;\n};\n\nGraph.prototype.nodes = function() {\n return _.keys(this._nodes);\n};\n\nGraph.prototype.sources = function() {\n var self = this;\n return _.filter(this.nodes(), function(v) {\n return _.isEmpty(self._in[v]);\n });\n};\n\nGraph.prototype.sinks = function() {\n var self = this;\n return _.filter(this.nodes(), function(v) {\n return _.isEmpty(self._out[v]);\n });\n};\n\nGraph.prototype.setNodes = function(vs, value) {\n var args = arguments;\n var self = this;\n _.each(vs, function(v) {\n if (args.length > 1) {\n self.setNode(v, value);\n } else {\n self.setNode(v);\n }\n });\n return this;\n};\n\nGraph.prototype.setNode = function(v, value) {\n if (_.has(this._nodes, v)) {\n if (arguments.length > 1) {\n this._nodes[v] = value;\n }\n return this;\n }\n\n this._nodes[v] = arguments.length > 1 ? value : this._defaultNodeLabelFn(v);\n if (this._isCompound) {\n this._parent[v] = GRAPH_NODE;\n this._children[v] = {};\n this._children[GRAPH_NODE][v] = true;\n }\n this._in[v] = {};\n this._preds[v] = {};\n this._out[v] = {};\n this._sucs[v] = {};\n ++this._nodeCount;\n return this;\n};\n\nGraph.prototype.node = function(v) {\n return this._nodes[v];\n};\n\nGraph.prototype.hasNode = function(v) {\n return _.has(this._nodes, v);\n};\n\nGraph.prototype.removeNode = function(v) {\n var self = this;\n if (_.has(this._nodes, v)) {\n var removeEdge = function(e) { self.removeEdge(self._edgeObjs[e]); };\n delete this._nodes[v];\n if (this._isCompound) {\n this._removeFromParentsChildList(v);\n delete this._parent[v];\n _.each(this.children(v), function(child) {\n self.setParent(child);\n });\n delete this._children[v];\n }\n _.each(_.keys(this._in[v]), removeEdge);\n delete this._in[v];\n delete this._preds[v];\n _.each(_.keys(this._out[v]), removeEdge);\n delete this._out[v];\n delete this._sucs[v];\n --this._nodeCount;\n }\n return this;\n};\n\nGraph.prototype.setParent = function(v, parent) {\n if (!this._isCompound) {\n throw new Error(\"Cannot set parent in a non-compound graph\");\n }\n\n if (_.isUndefined(parent)) {\n parent = GRAPH_NODE;\n } else {\n // Coerce parent to string\n parent += \"\";\n for (var ancestor = parent;\n !_.isUndefined(ancestor);\n ancestor = this.parent(ancestor)) {\n if (ancestor === v) {\n throw new Error(\"Setting \" + parent+ \" as parent of \" + v +\n \" would create a cycle\");\n }\n }\n\n this.setNode(parent);\n }\n\n this.setNode(v);\n this._removeFromParentsChildList(v);\n this._parent[v] = parent;\n this._children[parent][v] = true;\n return this;\n};\n\nGraph.prototype._removeFromParentsChildList = function(v) {\n delete this._children[this._parent[v]][v];\n};\n\nGraph.prototype.parent = function(v) {\n if (this._isCompound) {\n var parent = this._parent[v];\n if (parent !== GRAPH_NODE) {\n return parent;\n }\n }\n};\n\nGraph.prototype.children = function(v) {\n if (_.isUndefined(v)) {\n v = GRAPH_NODE;\n }\n\n if (this._isCompound) {\n var children = this._children[v];\n if (children) {\n return _.keys(children);\n }\n } else if (v === GRAPH_NODE) {\n return this.nodes();\n } else if (this.hasNode(v)) {\n return [];\n }\n};\n\nGraph.prototype.predecessors = function(v) {\n var predsV = this._preds[v];\n if (predsV) {\n return _.keys(predsV);\n }\n};\n\nGraph.prototype.successors = function(v) {\n var sucsV = this._sucs[v];\n if (sucsV) {\n return _.keys(sucsV);\n }\n};\n\nGraph.prototype.neighbors = function(v) {\n var preds = this.predecessors(v);\n if (preds) {\n return _.union(preds, this.successors(v));\n }\n};\n\nGraph.prototype.isLeaf = function (v) {\n var neighbors;\n if (this.isDirected()) {\n neighbors = this.successors(v);\n } else {\n neighbors = this.neighbors(v);\n }\n return neighbors.length === 0;\n};\n\nGraph.prototype.filterNodes = function(filter) {\n var copy = new this.constructor({\n directed: this._isDirected,\n multigraph: this._isMultigraph,\n compound: this._isCompound\n });\n\n copy.setGraph(this.graph());\n\n var self = this;\n _.each(this._nodes, function(value, v) {\n if (filter(v)) {\n copy.setNode(v, value);\n }\n });\n\n _.each(this._edgeObjs, function(e) {\n if (copy.hasNode(e.v) && copy.hasNode(e.w)) {\n copy.setEdge(e, self.edge(e));\n }\n });\n\n var parents = {};\n function findParent(v) {\n var parent = self.parent(v);\n if (parent === undefined || copy.hasNode(parent)) {\n parents[v] = parent;\n return parent;\n } else if (parent in parents) {\n return parents[parent];\n } else {\n return findParent(parent);\n }\n }\n\n if (this._isCompound) {\n _.each(copy.nodes(), function(v) {\n copy.setParent(v, findParent(v));\n });\n }\n\n return copy;\n};\n\n/* === Edge functions ========== */\n\nGraph.prototype.setDefaultEdgeLabel = function(newDefault) {\n if (!_.isFunction(newDefault)) {\n newDefault = _.constant(newDefault);\n }\n this._defaultEdgeLabelFn = newDefault;\n return this;\n};\n\nGraph.prototype.edgeCount = function() {\n return this._edgeCount;\n};\n\nGraph.prototype.edges = function() {\n return _.values(this._edgeObjs);\n};\n\nGraph.prototype.setPath = function(vs, value) {\n var self = this;\n var args = arguments;\n _.reduce(vs, function(v, w) {\n if (args.length > 1) {\n self.setEdge(v, w, value);\n } else {\n self.setEdge(v, w);\n }\n return w;\n });\n return this;\n};\n\n/*\n * setEdge(v, w, [value, [name]])\n * setEdge({ v, w, [name] }, [value])\n */\nGraph.prototype.setEdge = function() {\n var v, w, name, value;\n var valueSpecified = false;\n var arg0 = arguments[0];\n\n if (typeof arg0 === \"object\" && arg0 !== null && \"v\" in arg0) {\n v = arg0.v;\n w = arg0.w;\n name = arg0.name;\n if (arguments.length === 2) {\n value = arguments[1];\n valueSpecified = true;\n }\n } else {\n v = arg0;\n w = arguments[1];\n name = arguments[3];\n if (arguments.length > 2) {\n value = arguments[2];\n valueSpecified = true;\n }\n }\n\n v = \"\" + v;\n w = \"\" + w;\n if (!_.isUndefined(name)) {\n name = \"\" + name;\n }\n\n var e = edgeArgsToId(this._isDirected, v, w, name);\n if (_.has(this._edgeLabels, e)) {\n if (valueSpecified) {\n this._edgeLabels[e] = value;\n }\n return this;\n }\n\n if (!_.isUndefined(name) && !this._isMultigraph) {\n throw new Error(\"Cannot set a named edge when isMultigraph = false\");\n }\n\n // It didn't exist, so we need to create it.\n // First ensure the nodes exist.\n this.setNode(v);\n this.setNode(w);\n\n this._edgeLabels[e] = valueSpecified ? value : this._defaultEdgeLabelFn(v, w, name);\n\n var edgeObj = edgeArgsToObj(this._isDirected, v, w, name);\n // Ensure we add undirected edges in a consistent way.\n v = edgeObj.v;\n w = edgeObj.w;\n\n Object.freeze(edgeObj);\n this._edgeObjs[e] = edgeObj;\n incrementOrInitEntry(this._preds[w], v);\n incrementOrInitEntry(this._sucs[v], w);\n this._in[w][e] = edgeObj;\n this._out[v][e] = edgeObj;\n this._edgeCount++;\n return this;\n};\n\nGraph.prototype.edge = function(v, w, name) {\n var e = (arguments.length === 1\n ? edgeObjToId(this._isDirected, arguments[0])\n : edgeArgsToId(this._isDirected, v, w, name));\n return this._edgeLabels[e];\n};\n\nGraph.prototype.hasEdge = function(v, w, name) {\n var e = (arguments.length === 1\n ? edgeObjToId(this._isDirected, arguments[0])\n : edgeArgsToId(this._isDirected, v, w, name));\n return _.has(this._edgeLabels, e);\n};\n\nGraph.prototype.removeEdge = function(v, w, name) {\n var e = (arguments.length === 1\n ? edgeObjToId(this._isDirected, arguments[0])\n : edgeArgsToId(this._isDirected, v, w, name));\n var edge = this._edgeObjs[e];\n if (edge) {\n v = edge.v;\n w = edge.w;\n delete this._edgeLabels[e];\n delete this._edgeObjs[e];\n decrementOrRemoveEntry(this._preds[w], v);\n decrementOrRemoveEntry(this._sucs[v], w);\n delete this._in[w][e];\n delete this._out[v][e];\n this._edgeCount--;\n }\n return this;\n};\n\nGraph.prototype.inEdges = function(v, u) {\n var inV = this._in[v];\n if (inV) {\n var edges = _.values(inV);\n if (!u) {\n return edges;\n }\n return _.filter(edges, function(edge) { return edge.v === u; });\n }\n};\n\nGraph.prototype.outEdges = function(v, w) {\n var outV = this._out[v];\n if (outV) {\n var edges = _.values(outV);\n if (!w) {\n return edges;\n }\n return _.filter(edges, function(edge) { return edge.w === w; });\n }\n};\n\nGraph.prototype.nodeEdges = function(v, w) {\n var inEdges = this.inEdges(v, w);\n if (inEdges) {\n return inEdges.concat(this.outEdges(v, w));\n }\n};\n\nfunction incrementOrInitEntry(map, k) {\n if (map[k]) {\n map[k]++;\n } else {\n map[k] = 1;\n }\n}\n\nfunction decrementOrRemoveEntry(map, k) {\n if (!--map[k]) { delete map[k]; }\n}\n\nfunction edgeArgsToId(isDirected, v_, w_, name) {\n var v = \"\" + v_;\n var w = \"\" + w_;\n if (!isDirected && v > w) {\n var tmp = v;\n v = w;\n w = tmp;\n }\n return v + EDGE_KEY_DELIM + w + EDGE_KEY_DELIM +\n (_.isUndefined(name) ? DEFAULT_EDGE_NAME : name);\n}\n\nfunction edgeArgsToObj(isDirected, v_, w_, name) {\n var v = \"\" + v_;\n var w = \"\" + w_;\n if (!isDirected && v > w) {\n var tmp = v;\n v = w;\n w = tmp;\n }\n var edgeObj = { v: v, w: w };\n if (name) {\n edgeObj.name = name;\n }\n return edgeObj;\n}\n\nfunction edgeObjToId(isDirected, edgeObj) {\n return edgeArgsToId(isDirected, edgeObj.v, edgeObj.w, edgeObj.name);\n}\n","// Includes only the \"core\" of graphlib\nmodule.exports = {\n Graph: require(\"./graph\"),\n version: require(\"./version\")\n};\n","var _ = require(\"./lodash\");\nvar Graph = require(\"./graph\");\n\nmodule.exports = {\n write: write,\n read: read\n};\n\nfunction write(g) {\n var json = {\n options: {\n directed: g.isDirected(),\n multigraph: g.isMultigraph(),\n compound: g.isCompound()\n },\n nodes: writeNodes(g),\n edges: writeEdges(g)\n };\n if (!_.isUndefined(g.graph())) {\n json.value = _.clone(g.graph());\n }\n return json;\n}\n\nfunction writeNodes(g) {\n return _.map(g.nodes(), function(v) {\n var nodeValue = g.node(v);\n var parent = g.parent(v);\n var node = { v: v };\n if (!_.isUndefined(nodeValue)) {\n node.value = nodeValue;\n }\n if (!_.isUndefined(parent)) {\n node.parent = parent;\n }\n return node;\n });\n}\n\nfunction writeEdges(g) {\n return _.map(g.edges(), function(e) {\n var edgeValue = g.edge(e);\n var edge = { v: e.v, w: e.w };\n if (!_.isUndefined(e.name)) {\n edge.name = e.name;\n }\n if (!_.isUndefined(edgeValue)) {\n edge.value = edgeValue;\n }\n return edge;\n });\n}\n\nfunction read(json) {\n var g = new Graph(json.options).setGraph(json.value);\n _.each(json.nodes, function(entry) {\n g.setNode(entry.v, entry.value);\n if (entry.parent) {\n g.setParent(entry.v, entry.parent);\n }\n });\n _.each(json.edges, function(entry) {\n g.setEdge({ v: entry.v, w: entry.w, name: entry.name }, entry.value);\n });\n return g;\n}\n","/* global window */\n\nvar lodash;\n\nif (typeof require === \"function\") {\n try {\n lodash = {\n clone: require(\"lodash/clone\"),\n constant: require(\"lodash/constant\"),\n each: require(\"lodash/each\"),\n filter: require(\"lodash/filter\"),\n has: require(\"lodash/has\"),\n isArray: require(\"lodash/isArray\"),\n isEmpty: require(\"lodash/isEmpty\"),\n isFunction: require(\"lodash/isFunction\"),\n isUndefined: require(\"lodash/isUndefined\"),\n keys: require(\"lodash/keys\"),\n map: require(\"lodash/map\"),\n reduce: require(\"lodash/reduce\"),\n size: require(\"lodash/size\"),\n transform: require(\"lodash/transform\"),\n union: require(\"lodash/union\"),\n values: require(\"lodash/values\")\n };\n } catch (e) {\n // continue regardless of error\n }\n}\n\nif (!lodash) {\n lodash = window._;\n}\n\nmodule.exports = lodash;\n","module.exports = '2.1.8';\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar INJECTION = Symbol.for(\"INJECTION\");\nfunction _proxyGetter(proto, key, resolve, doCache) {\n function getter() {\n if (doCache && !Reflect.hasMetadata(INJECTION, this, key)) {\n Reflect.defineMetadata(INJECTION, resolve(), this, key);\n }\n if (Reflect.hasMetadata(INJECTION, this, key)) {\n return Reflect.getMetadata(INJECTION, this, key);\n }\n else {\n return resolve();\n }\n }\n function setter(newVal) {\n Reflect.defineMetadata(INJECTION, newVal, this, key);\n }\n Object.defineProperty(proto, key, {\n configurable: true,\n enumerable: true,\n get: getter,\n set: setter\n });\n}\nfunction makePropertyInjectDecorator(container, doCache) {\n return function (serviceIdentifier) {\n return function (proto, key) {\n var resolve = function () {\n return container.get(serviceIdentifier);\n };\n _proxyGetter(proto, key, resolve, doCache);\n };\n };\n}\nexports.makePropertyInjectDecorator = makePropertyInjectDecorator;\nfunction makePropertyInjectNamedDecorator(container, doCache) {\n return function (serviceIdentifier, named) {\n return function (proto, key) {\n var resolve = function () {\n return container.getNamed(serviceIdentifier, named);\n };\n _proxyGetter(proto, key, resolve, doCache);\n };\n };\n}\nexports.makePropertyInjectNamedDecorator = makePropertyInjectNamedDecorator;\nfunction makePropertyInjectTaggedDecorator(container, doCache) {\n return function (serviceIdentifier, key, value) {\n return function (proto, propertyName) {\n var resolve = function () {\n return container.getTagged(serviceIdentifier, key, value);\n };\n _proxyGetter(proto, propertyName, resolve, doCache);\n };\n };\n}\nexports.makePropertyInjectTaggedDecorator = makePropertyInjectTaggedDecorator;\nfunction makePropertyMultiInjectDecorator(container, doCache) {\n return function (serviceIdentifier) {\n return function (proto, key) {\n var resolve = function () {\n return container.getAll(serviceIdentifier);\n };\n _proxyGetter(proto, key, resolve, doCache);\n };\n };\n}\nexports.makePropertyMultiInjectDecorator = makePropertyMultiInjectDecorator;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar decorators_1 = require(\"./decorators\");\nfunction getDecorators(container, doCache) {\n if (doCache === void 0) { doCache = true; }\n var lazyInject = decorators_1.makePropertyInjectDecorator(container, doCache);\n var lazyInjectNamed = decorators_1.makePropertyInjectNamedDecorator(container, doCache);\n var lazyInjectTagged = decorators_1.makePropertyInjectTaggedDecorator(container, doCache);\n var lazyMultiInject = decorators_1.makePropertyMultiInjectDecorator(container, doCache);\n return {\n lazyInject: lazyInject,\n lazyInjectNamed: lazyInjectNamed,\n lazyInjectTagged: lazyInjectTagged,\n lazyMultiInject: lazyMultiInject\n };\n}\nexports.default = getDecorators;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.tagProperty = exports.tagParameter = exports.decorate = void 0;\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nfunction tagParameter(annotationTarget, propertyName, parameterIndex, metadata) {\n var metadataKey = METADATA_KEY.TAGGED;\n _tagParameterOrProperty(metadataKey, annotationTarget, propertyName, metadata, parameterIndex);\n}\nexports.tagParameter = tagParameter;\nfunction tagProperty(annotationTarget, propertyName, metadata) {\n var metadataKey = METADATA_KEY.TAGGED_PROP;\n _tagParameterOrProperty(metadataKey, annotationTarget.constructor, propertyName, metadata);\n}\nexports.tagProperty = tagProperty;\nfunction _tagParameterOrProperty(metadataKey, annotationTarget, propertyName, metadata, parameterIndex) {\n var paramsOrPropertiesMetadata = {};\n var isParameterDecorator = (typeof parameterIndex === \"number\");\n var key = (parameterIndex !== undefined && isParameterDecorator) ? parameterIndex.toString() : propertyName;\n if (isParameterDecorator && propertyName !== undefined) {\n throw new Error(ERROR_MSGS.INVALID_DECORATOR_OPERATION);\n }\n if (Reflect.hasOwnMetadata(metadataKey, annotationTarget)) {\n paramsOrPropertiesMetadata = Reflect.getMetadata(metadataKey, annotationTarget);\n }\n var paramOrPropertyMetadata = paramsOrPropertiesMetadata[key];\n if (!Array.isArray(paramOrPropertyMetadata)) {\n paramOrPropertyMetadata = [];\n }\n else {\n for (var _i = 0, paramOrPropertyMetadata_1 = paramOrPropertyMetadata; _i < paramOrPropertyMetadata_1.length; _i++) {\n var m = paramOrPropertyMetadata_1[_i];\n if (m.key === metadata.key) {\n throw new Error(ERROR_MSGS.DUPLICATED_METADATA + \" \" + m.key.toString());\n }\n }\n }\n paramOrPropertyMetadata.push(metadata);\n paramsOrPropertiesMetadata[key] = paramOrPropertyMetadata;\n Reflect.defineMetadata(metadataKey, paramsOrPropertiesMetadata, annotationTarget);\n}\nfunction _decorate(decorators, target) {\n Reflect.decorate(decorators, target);\n}\nfunction _param(paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); };\n}\nfunction decorate(decorator, target, parameterIndex) {\n if (typeof parameterIndex === \"number\") {\n _decorate([_param(parameterIndex, decorator)], target);\n }\n else if (typeof parameterIndex === \"string\") {\n Reflect.decorate([decorator], target, parameterIndex);\n }\n else {\n _decorate([decorator], target);\n }\n}\nexports.decorate = decorate;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.inject = exports.LazyServiceIdentifer = void 0;\nvar error_msgs_1 = require(\"../constants/error_msgs\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nvar LazyServiceIdentifer = (function () {\n function LazyServiceIdentifer(cb) {\n this._cb = cb;\n }\n LazyServiceIdentifer.prototype.unwrap = function () {\n return this._cb();\n };\n return LazyServiceIdentifer;\n}());\nexports.LazyServiceIdentifer = LazyServiceIdentifer;\nfunction inject(serviceIdentifier) {\n return function (target, targetKey, index) {\n if (serviceIdentifier === undefined) {\n throw new Error(error_msgs_1.UNDEFINED_INJECT_ANNOTATION(target.name));\n }\n var metadata = new metadata_1.Metadata(METADATA_KEY.INJECT_TAG, serviceIdentifier);\n if (typeof index === \"number\") {\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n }\n else {\n decorator_utils_1.tagProperty(target, targetKey, metadata);\n }\n };\n}\nexports.inject = inject;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.injectable = void 0;\nvar ERRORS_MSGS = require(\"../constants/error_msgs\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nfunction injectable() {\n return function (target) {\n if (Reflect.hasOwnMetadata(METADATA_KEY.PARAM_TYPES, target)) {\n throw new Error(ERRORS_MSGS.DUPLICATED_INJECTABLE_DECORATOR);\n }\n var types = Reflect.getMetadata(METADATA_KEY.DESIGN_PARAM_TYPES, target) || [];\n Reflect.defineMetadata(METADATA_KEY.PARAM_TYPES, types, target);\n return target;\n };\n}\nexports.injectable = injectable;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.multiInject = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nfunction multiInject(serviceIdentifier) {\n return function (target, targetKey, index) {\n var metadata = new metadata_1.Metadata(METADATA_KEY.MULTI_INJECT_TAG, serviceIdentifier);\n if (typeof index === \"number\") {\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n }\n else {\n decorator_utils_1.tagProperty(target, targetKey, metadata);\n }\n };\n}\nexports.multiInject = multiInject;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.named = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nfunction named(name) {\n return function (target, targetKey, index) {\n var metadata = new metadata_1.Metadata(METADATA_KEY.NAMED_TAG, name);\n if (typeof index === \"number\") {\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n }\n else {\n decorator_utils_1.tagProperty(target, targetKey, metadata);\n }\n };\n}\nexports.named = named;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.optional = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nfunction optional() {\n return function (target, targetKey, index) {\n var metadata = new metadata_1.Metadata(METADATA_KEY.OPTIONAL_TAG, true);\n if (typeof index === \"number\") {\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n }\n else {\n decorator_utils_1.tagProperty(target, targetKey, metadata);\n }\n };\n}\nexports.optional = optional;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.postConstruct = void 0;\nvar ERRORS_MSGS = require(\"../constants/error_msgs\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nfunction postConstruct() {\n return function (target, propertyKey, descriptor) {\n var metadata = new metadata_1.Metadata(METADATA_KEY.POST_CONSTRUCT, propertyKey);\n if (Reflect.hasOwnMetadata(METADATA_KEY.POST_CONSTRUCT, target.constructor)) {\n throw new Error(ERRORS_MSGS.MULTIPLE_POST_CONSTRUCT_METHODS);\n }\n Reflect.defineMetadata(METADATA_KEY.POST_CONSTRUCT, metadata, target.constructor);\n };\n}\nexports.postConstruct = postConstruct;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.tagged = void 0;\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nfunction tagged(metadataKey, metadataValue) {\n return function (target, targetKey, index) {\n var metadata = new metadata_1.Metadata(metadataKey, metadataValue);\n if (typeof index === \"number\") {\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n }\n else {\n decorator_utils_1.tagProperty(target, targetKey, metadata);\n }\n };\n}\nexports.tagged = tagged;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.targetName = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nfunction targetName(name) {\n return function (target, targetKey, index) {\n var metadata = new metadata_1.Metadata(METADATA_KEY.NAME_TAG, name);\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n };\n}\nexports.targetName = targetName;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.unmanaged = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar decorator_utils_1 = require(\"./decorator_utils\");\nfunction unmanaged() {\n return function (target, targetKey, index) {\n var metadata = new metadata_1.Metadata(METADATA_KEY.UNMANAGED_TAG, true);\n decorator_utils_1.tagParameter(target, targetKey, index, metadata);\n };\n}\nexports.unmanaged = unmanaged;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Binding = void 0;\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar id_1 = require(\"../utils/id\");\nvar Binding = (function () {\n function Binding(serviceIdentifier, scope) {\n this.id = id_1.id();\n this.activated = false;\n this.serviceIdentifier = serviceIdentifier;\n this.scope = scope;\n this.type = literal_types_1.BindingTypeEnum.Invalid;\n this.constraint = function (request) { return true; };\n this.implementationType = null;\n this.cache = null;\n this.factory = null;\n this.provider = null;\n this.onActivation = null;\n this.dynamicValue = null;\n }\n Binding.prototype.clone = function () {\n var clone = new Binding(this.serviceIdentifier, this.scope);\n clone.activated = false;\n clone.implementationType = this.implementationType;\n clone.dynamicValue = this.dynamicValue;\n clone.scope = this.scope;\n clone.type = this.type;\n clone.factory = this.factory;\n clone.provider = this.provider;\n clone.constraint = this.constraint;\n clone.onActivation = this.onActivation;\n clone.cache = this.cache;\n return clone;\n };\n return Binding;\n}());\nexports.Binding = Binding;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingCount = void 0;\nvar BindingCount = {\n MultipleBindingsAvailable: 2,\n NoBindingsAvailable: 0,\n OnlyOneBindingAvailable: 1\n};\nexports.BindingCount = BindingCount;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.STACK_OVERFLOW = exports.CIRCULAR_DEPENDENCY_IN_FACTORY = exports.POST_CONSTRUCT_ERROR = exports.MULTIPLE_POST_CONSTRUCT_METHODS = exports.CONTAINER_OPTIONS_INVALID_SKIP_BASE_CHECK = exports.CONTAINER_OPTIONS_INVALID_AUTO_BIND_INJECTABLE = exports.CONTAINER_OPTIONS_INVALID_DEFAULT_SCOPE = exports.CONTAINER_OPTIONS_MUST_BE_AN_OBJECT = exports.ARGUMENTS_LENGTH_MISMATCH = exports.INVALID_DECORATOR_OPERATION = exports.INVALID_TO_SELF_VALUE = exports.INVALID_FUNCTION_BINDING = exports.INVALID_MIDDLEWARE_RETURN = exports.NO_MORE_SNAPSHOTS_AVAILABLE = exports.INVALID_BINDING_TYPE = exports.NOT_IMPLEMENTED = exports.CIRCULAR_DEPENDENCY = exports.UNDEFINED_INJECT_ANNOTATION = exports.MISSING_INJECT_ANNOTATION = exports.MISSING_INJECTABLE_ANNOTATION = exports.NOT_REGISTERED = exports.CANNOT_UNBIND = exports.AMBIGUOUS_MATCH = exports.KEY_NOT_FOUND = exports.NULL_ARGUMENT = exports.DUPLICATED_METADATA = exports.DUPLICATED_INJECTABLE_DECORATOR = void 0;\nexports.DUPLICATED_INJECTABLE_DECORATOR = \"Cannot apply @injectable decorator multiple times.\";\nexports.DUPLICATED_METADATA = \"Metadata key was used more than once in a parameter:\";\nexports.NULL_ARGUMENT = \"NULL argument\";\nexports.KEY_NOT_FOUND = \"Key Not Found\";\nexports.AMBIGUOUS_MATCH = \"Ambiguous match found for serviceIdentifier:\";\nexports.CANNOT_UNBIND = \"Could not unbind serviceIdentifier:\";\nexports.NOT_REGISTERED = \"No matching bindings found for serviceIdentifier:\";\nexports.MISSING_INJECTABLE_ANNOTATION = \"Missing required @injectable annotation in:\";\nexports.MISSING_INJECT_ANNOTATION = \"Missing required @inject or @multiInject annotation in:\";\nexports.UNDEFINED_INJECT_ANNOTATION = function (name) {\n return \"@inject called with undefined this could mean that the class \" + name + \" has \" +\n \"a circular dependency problem. You can use a LazyServiceIdentifer to \" +\n \"overcome this limitation.\";\n};\nexports.CIRCULAR_DEPENDENCY = \"Circular dependency found:\";\nexports.NOT_IMPLEMENTED = \"Sorry, this feature is not fully implemented yet.\";\nexports.INVALID_BINDING_TYPE = \"Invalid binding type:\";\nexports.NO_MORE_SNAPSHOTS_AVAILABLE = \"No snapshot available to restore.\";\nexports.INVALID_MIDDLEWARE_RETURN = \"Invalid return type in middleware. Middleware must return!\";\nexports.INVALID_FUNCTION_BINDING = \"Value provided to function binding must be a function!\";\nexports.INVALID_TO_SELF_VALUE = \"The toSelf function can only be applied when a constructor is \" +\n \"used as service identifier\";\nexports.INVALID_DECORATOR_OPERATION = \"The @inject @multiInject @tagged and @named decorators \" +\n \"must be applied to the parameters of a class constructor or a class property.\";\nexports.ARGUMENTS_LENGTH_MISMATCH = function () {\n var values = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n values[_i] = arguments[_i];\n }\n return \"The number of constructor arguments in the derived class \" +\n (values[0] + \" must be >= than the number of constructor arguments of its base class.\");\n};\nexports.CONTAINER_OPTIONS_MUST_BE_AN_OBJECT = \"Invalid Container constructor argument. Container options \" +\n \"must be an object.\";\nexports.CONTAINER_OPTIONS_INVALID_DEFAULT_SCOPE = \"Invalid Container option. Default scope must \" +\n \"be a string ('singleton' or 'transient').\";\nexports.CONTAINER_OPTIONS_INVALID_AUTO_BIND_INJECTABLE = \"Invalid Container option. Auto bind injectable must \" +\n \"be a boolean\";\nexports.CONTAINER_OPTIONS_INVALID_SKIP_BASE_CHECK = \"Invalid Container option. Skip base check must \" +\n \"be a boolean\";\nexports.MULTIPLE_POST_CONSTRUCT_METHODS = \"Cannot apply @postConstruct decorator multiple times in the same class\";\nexports.POST_CONSTRUCT_ERROR = function () {\n var values = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n values[_i] = arguments[_i];\n }\n return \"@postConstruct error in class \" + values[0] + \": \" + values[1];\n};\nexports.CIRCULAR_DEPENDENCY_IN_FACTORY = function () {\n var values = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n values[_i] = arguments[_i];\n }\n return \"It looks like there is a circular dependency \" +\n (\"in one of the '\" + values[0] + \"' bindings. Please investigate bindings with\") +\n (\"service identifier '\" + values[1] + \"'.\");\n};\nexports.STACK_OVERFLOW = \"Maximum call stack size exceeded\";\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.TargetTypeEnum = exports.BindingTypeEnum = exports.BindingScopeEnum = void 0;\nvar BindingScopeEnum = {\n Request: \"Request\",\n Singleton: \"Singleton\",\n Transient: \"Transient\"\n};\nexports.BindingScopeEnum = BindingScopeEnum;\nvar BindingTypeEnum = {\n ConstantValue: \"ConstantValue\",\n Constructor: \"Constructor\",\n DynamicValue: \"DynamicValue\",\n Factory: \"Factory\",\n Function: \"Function\",\n Instance: \"Instance\",\n Invalid: \"Invalid\",\n Provider: \"Provider\"\n};\nexports.BindingTypeEnum = BindingTypeEnum;\nvar TargetTypeEnum = {\n ClassProperty: \"ClassProperty\",\n ConstructorArgument: \"ConstructorArgument\",\n Variable: \"Variable\"\n};\nexports.TargetTypeEnum = TargetTypeEnum;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.POST_CONSTRUCT = exports.DESIGN_PARAM_TYPES = exports.PARAM_TYPES = exports.TAGGED_PROP = exports.TAGGED = exports.MULTI_INJECT_TAG = exports.INJECT_TAG = exports.OPTIONAL_TAG = exports.UNMANAGED_TAG = exports.NAME_TAG = exports.NAMED_TAG = void 0;\nexports.NAMED_TAG = \"named\";\nexports.NAME_TAG = \"name\";\nexports.UNMANAGED_TAG = \"unmanaged\";\nexports.OPTIONAL_TAG = \"optional\";\nexports.INJECT_TAG = \"inject\";\nexports.MULTI_INJECT_TAG = \"multi_inject\";\nexports.TAGGED = \"inversify:tagged\";\nexports.TAGGED_PROP = \"inversify:tagged_props\";\nexports.PARAM_TYPES = \"inversify:paramtypes\";\nexports.DESIGN_PARAM_TYPES = \"design:paramtypes\";\nexports.POST_CONSTRUCT = \"post_construct\";\n","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\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;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Container = void 0;\nvar binding_1 = require(\"../bindings/binding\");\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_reader_1 = require(\"../planning/metadata_reader\");\nvar planner_1 = require(\"../planning/planner\");\nvar resolver_1 = require(\"../resolution/resolver\");\nvar binding_to_syntax_1 = require(\"../syntax/binding_to_syntax\");\nvar id_1 = require(\"../utils/id\");\nvar serialization_1 = require(\"../utils/serialization\");\nvar container_snapshot_1 = require(\"./container_snapshot\");\nvar lookup_1 = require(\"./lookup\");\nvar Container = (function () {\n function Container(containerOptions) {\n var options = containerOptions || {};\n if (typeof options !== \"object\") {\n throw new Error(\"\" + ERROR_MSGS.CONTAINER_OPTIONS_MUST_BE_AN_OBJECT);\n }\n if (options.defaultScope === undefined) {\n options.defaultScope = literal_types_1.BindingScopeEnum.Transient;\n }\n else if (options.defaultScope !== literal_types_1.BindingScopeEnum.Singleton &&\n options.defaultScope !== literal_types_1.BindingScopeEnum.Transient &&\n options.defaultScope !== literal_types_1.BindingScopeEnum.Request) {\n throw new Error(\"\" + ERROR_MSGS.CONTAINER_OPTIONS_INVALID_DEFAULT_SCOPE);\n }\n if (options.autoBindInjectable === undefined) {\n options.autoBindInjectable = false;\n }\n else if (typeof options.autoBindInjectable !== \"boolean\") {\n throw new Error(\"\" + ERROR_MSGS.CONTAINER_OPTIONS_INVALID_AUTO_BIND_INJECTABLE);\n }\n if (options.skipBaseClassChecks === undefined) {\n options.skipBaseClassChecks = false;\n }\n else if (typeof options.skipBaseClassChecks !== \"boolean\") {\n throw new Error(\"\" + ERROR_MSGS.CONTAINER_OPTIONS_INVALID_SKIP_BASE_CHECK);\n }\n this.options = {\n autoBindInjectable: options.autoBindInjectable,\n defaultScope: options.defaultScope,\n skipBaseClassChecks: options.skipBaseClassChecks\n };\n this.id = id_1.id();\n this._bindingDictionary = new lookup_1.Lookup();\n this._snapshots = [];\n this._middleware = null;\n this.parent = null;\n this._metadataReader = new metadata_reader_1.MetadataReader();\n }\n Container.merge = function (container1, container2) {\n var container = new Container();\n var bindingDictionary = planner_1.getBindingDictionary(container);\n var bindingDictionary1 = planner_1.getBindingDictionary(container1);\n var bindingDictionary2 = planner_1.getBindingDictionary(container2);\n function copyDictionary(origin, destination) {\n origin.traverse(function (key, value) {\n value.forEach(function (binding) {\n destination.add(binding.serviceIdentifier, binding.clone());\n });\n });\n }\n copyDictionary(bindingDictionary1, bindingDictionary);\n copyDictionary(bindingDictionary2, bindingDictionary);\n return container;\n };\n Container.prototype.load = function () {\n var modules = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n modules[_i] = arguments[_i];\n }\n var getHelpers = this._getContainerModuleHelpersFactory();\n for (var _a = 0, modules_1 = modules; _a < modules_1.length; _a++) {\n var currentModule = modules_1[_a];\n var containerModuleHelpers = getHelpers(currentModule.id);\n currentModule.registry(containerModuleHelpers.bindFunction, containerModuleHelpers.unbindFunction, containerModuleHelpers.isboundFunction, containerModuleHelpers.rebindFunction);\n }\n };\n Container.prototype.loadAsync = function () {\n var modules = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n modules[_i] = arguments[_i];\n }\n return __awaiter(this, void 0, void 0, function () {\n var getHelpers, _a, modules_2, currentModule, containerModuleHelpers;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n getHelpers = this._getContainerModuleHelpersFactory();\n _a = 0, modules_2 = modules;\n _b.label = 1;\n case 1:\n if (!(_a < modules_2.length)) return [3, 4];\n currentModule = modules_2[_a];\n containerModuleHelpers = getHelpers(currentModule.id);\n return [4, currentModule.registry(containerModuleHelpers.bindFunction, containerModuleHelpers.unbindFunction, containerModuleHelpers.isboundFunction, containerModuleHelpers.rebindFunction)];\n case 2:\n _b.sent();\n _b.label = 3;\n case 3:\n _a++;\n return [3, 1];\n case 4: return [2];\n }\n });\n });\n };\n Container.prototype.unload = function () {\n var _this = this;\n var modules = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n modules[_i] = arguments[_i];\n }\n var conditionFactory = function (expected) { return function (item) {\n return item.moduleId === expected;\n }; };\n modules.forEach(function (module) {\n var condition = conditionFactory(module.id);\n _this._bindingDictionary.removeByCondition(condition);\n });\n };\n Container.prototype.bind = function (serviceIdentifier) {\n var scope = this.options.defaultScope || literal_types_1.BindingScopeEnum.Transient;\n var binding = new binding_1.Binding(serviceIdentifier, scope);\n this._bindingDictionary.add(serviceIdentifier, binding);\n return new binding_to_syntax_1.BindingToSyntax(binding);\n };\n Container.prototype.rebind = function (serviceIdentifier) {\n this.unbind(serviceIdentifier);\n return this.bind(serviceIdentifier);\n };\n Container.prototype.unbind = function (serviceIdentifier) {\n try {\n this._bindingDictionary.remove(serviceIdentifier);\n }\n catch (e) {\n throw new Error(ERROR_MSGS.CANNOT_UNBIND + \" \" + serialization_1.getServiceIdentifierAsString(serviceIdentifier));\n }\n };\n Container.prototype.unbindAll = function () {\n this._bindingDictionary = new lookup_1.Lookup();\n };\n Container.prototype.isBound = function (serviceIdentifier) {\n var bound = this._bindingDictionary.hasKey(serviceIdentifier);\n if (!bound && this.parent) {\n bound = this.parent.isBound(serviceIdentifier);\n }\n return bound;\n };\n Container.prototype.isBoundNamed = function (serviceIdentifier, named) {\n return this.isBoundTagged(serviceIdentifier, METADATA_KEY.NAMED_TAG, named);\n };\n Container.prototype.isBoundTagged = function (serviceIdentifier, key, value) {\n var bound = false;\n if (this._bindingDictionary.hasKey(serviceIdentifier)) {\n var bindings = this._bindingDictionary.get(serviceIdentifier);\n var request_1 = planner_1.createMockRequest(this, serviceIdentifier, key, value);\n bound = bindings.some(function (b) { return b.constraint(request_1); });\n }\n if (!bound && this.parent) {\n bound = this.parent.isBoundTagged(serviceIdentifier, key, value);\n }\n return bound;\n };\n Container.prototype.snapshot = function () {\n this._snapshots.push(container_snapshot_1.ContainerSnapshot.of(this._bindingDictionary.clone(), this._middleware));\n };\n Container.prototype.restore = function () {\n var snapshot = this._snapshots.pop();\n if (snapshot === undefined) {\n throw new Error(ERROR_MSGS.NO_MORE_SNAPSHOTS_AVAILABLE);\n }\n this._bindingDictionary = snapshot.bindings;\n this._middleware = snapshot.middleware;\n };\n Container.prototype.createChild = function (containerOptions) {\n var child = new Container(containerOptions || this.options);\n child.parent = this;\n return child;\n };\n Container.prototype.applyMiddleware = function () {\n var middlewares = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n middlewares[_i] = arguments[_i];\n }\n var initial = (this._middleware) ? this._middleware : this._planAndResolve();\n this._middleware = middlewares.reduce(function (prev, curr) { return curr(prev); }, initial);\n };\n Container.prototype.applyCustomMetadataReader = function (metadataReader) {\n this._metadataReader = metadataReader;\n };\n Container.prototype.get = function (serviceIdentifier) {\n return this._get(false, false, literal_types_1.TargetTypeEnum.Variable, serviceIdentifier);\n };\n Container.prototype.getTagged = function (serviceIdentifier, key, value) {\n return this._get(false, false, literal_types_1.TargetTypeEnum.Variable, serviceIdentifier, key, value);\n };\n Container.prototype.getNamed = function (serviceIdentifier, named) {\n return this.getTagged(serviceIdentifier, METADATA_KEY.NAMED_TAG, named);\n };\n Container.prototype.getAll = function (serviceIdentifier) {\n return this._get(true, true, literal_types_1.TargetTypeEnum.Variable, serviceIdentifier);\n };\n Container.prototype.getAllTagged = function (serviceIdentifier, key, value) {\n return this._get(false, true, literal_types_1.TargetTypeEnum.Variable, serviceIdentifier, key, value);\n };\n Container.prototype.getAllNamed = function (serviceIdentifier, named) {\n return this.getAllTagged(serviceIdentifier, METADATA_KEY.NAMED_TAG, named);\n };\n Container.prototype.resolve = function (constructorFunction) {\n var tempContainer = this.createChild();\n tempContainer.bind(constructorFunction).toSelf();\n return tempContainer.get(constructorFunction);\n };\n Container.prototype._getContainerModuleHelpersFactory = function () {\n var _this = this;\n var setModuleId = function (bindingToSyntax, moduleId) {\n bindingToSyntax._binding.moduleId = moduleId;\n };\n var getBindFunction = function (moduleId) {\n return function (serviceIdentifier) {\n var _bind = _this.bind.bind(_this);\n var bindingToSyntax = _bind(serviceIdentifier);\n setModuleId(bindingToSyntax, moduleId);\n return bindingToSyntax;\n };\n };\n var getUnbindFunction = function (moduleId) {\n return function (serviceIdentifier) {\n var _unbind = _this.unbind.bind(_this);\n _unbind(serviceIdentifier);\n };\n };\n var getIsboundFunction = function (moduleId) {\n return function (serviceIdentifier) {\n var _isBound = _this.isBound.bind(_this);\n return _isBound(serviceIdentifier);\n };\n };\n var getRebindFunction = function (moduleId) {\n return function (serviceIdentifier) {\n var _rebind = _this.rebind.bind(_this);\n var bindingToSyntax = _rebind(serviceIdentifier);\n setModuleId(bindingToSyntax, moduleId);\n return bindingToSyntax;\n };\n };\n return function (mId) { return ({\n bindFunction: getBindFunction(mId),\n isboundFunction: getIsboundFunction(mId),\n rebindFunction: getRebindFunction(mId),\n unbindFunction: getUnbindFunction(mId)\n }); };\n };\n Container.prototype._get = function (avoidConstraints, isMultiInject, targetType, serviceIdentifier, key, value) {\n var result = null;\n var defaultArgs = {\n avoidConstraints: avoidConstraints,\n contextInterceptor: function (context) { return context; },\n isMultiInject: isMultiInject,\n key: key,\n serviceIdentifier: serviceIdentifier,\n targetType: targetType,\n value: value\n };\n if (this._middleware) {\n result = this._middleware(defaultArgs);\n if (result === undefined || result === null) {\n throw new Error(ERROR_MSGS.INVALID_MIDDLEWARE_RETURN);\n }\n }\n else {\n result = this._planAndResolve()(defaultArgs);\n }\n return result;\n };\n Container.prototype._planAndResolve = function () {\n var _this = this;\n return function (args) {\n var context = planner_1.plan(_this._metadataReader, _this, args.isMultiInject, args.targetType, args.serviceIdentifier, args.key, args.value, args.avoidConstraints);\n context = args.contextInterceptor(context);\n var result = resolver_1.resolve(context);\n return result;\n };\n };\n return Container;\n}());\nexports.Container = Container;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.AsyncContainerModule = exports.ContainerModule = void 0;\nvar id_1 = require(\"../utils/id\");\nvar ContainerModule = (function () {\n function ContainerModule(registry) {\n this.id = id_1.id();\n this.registry = registry;\n }\n return ContainerModule;\n}());\nexports.ContainerModule = ContainerModule;\nvar AsyncContainerModule = (function () {\n function AsyncContainerModule(registry) {\n this.id = id_1.id();\n this.registry = registry;\n }\n return AsyncContainerModule;\n}());\nexports.AsyncContainerModule = AsyncContainerModule;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ContainerSnapshot = void 0;\nvar ContainerSnapshot = (function () {\n function ContainerSnapshot() {\n }\n ContainerSnapshot.of = function (bindings, middleware) {\n var snapshot = new ContainerSnapshot();\n snapshot.bindings = bindings;\n snapshot.middleware = middleware;\n return snapshot;\n };\n return ContainerSnapshot;\n}());\nexports.ContainerSnapshot = ContainerSnapshot;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Lookup = void 0;\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar Lookup = (function () {\n function Lookup() {\n this._map = new Map();\n }\n Lookup.prototype.getMap = function () {\n return this._map;\n };\n Lookup.prototype.add = function (serviceIdentifier, value) {\n if (serviceIdentifier === null || serviceIdentifier === undefined) {\n throw new Error(ERROR_MSGS.NULL_ARGUMENT);\n }\n if (value === null || value === undefined) {\n throw new Error(ERROR_MSGS.NULL_ARGUMENT);\n }\n var entry = this._map.get(serviceIdentifier);\n if (entry !== undefined) {\n entry.push(value);\n this._map.set(serviceIdentifier, entry);\n }\n else {\n this._map.set(serviceIdentifier, [value]);\n }\n };\n Lookup.prototype.get = function (serviceIdentifier) {\n if (serviceIdentifier === null || serviceIdentifier === undefined) {\n throw new Error(ERROR_MSGS.NULL_ARGUMENT);\n }\n var entry = this._map.get(serviceIdentifier);\n if (entry !== undefined) {\n return entry;\n }\n else {\n throw new Error(ERROR_MSGS.KEY_NOT_FOUND);\n }\n };\n Lookup.prototype.remove = function (serviceIdentifier) {\n if (serviceIdentifier === null || serviceIdentifier === undefined) {\n throw new Error(ERROR_MSGS.NULL_ARGUMENT);\n }\n if (!this._map.delete(serviceIdentifier)) {\n throw new Error(ERROR_MSGS.KEY_NOT_FOUND);\n }\n };\n Lookup.prototype.removeByCondition = function (condition) {\n var _this = this;\n this._map.forEach(function (entries, key) {\n var updatedEntries = entries.filter(function (entry) { return !condition(entry); });\n if (updatedEntries.length > 0) {\n _this._map.set(key, updatedEntries);\n }\n else {\n _this._map.delete(key);\n }\n });\n };\n Lookup.prototype.hasKey = function (serviceIdentifier) {\n if (serviceIdentifier === null || serviceIdentifier === undefined) {\n throw new Error(ERROR_MSGS.NULL_ARGUMENT);\n }\n return this._map.has(serviceIdentifier);\n };\n Lookup.prototype.clone = function () {\n var copy = new Lookup();\n this._map.forEach(function (value, key) {\n value.forEach(function (b) { return copy.add(key, b.clone()); });\n });\n return copy;\n };\n Lookup.prototype.traverse = function (func) {\n this._map.forEach(function (value, key) {\n func(key, value);\n });\n };\n return Lookup;\n}());\nexports.Lookup = Lookup;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.METADATA_KEY = void 0;\nvar keys = require(\"./constants/metadata_keys\");\nexports.METADATA_KEY = keys;\nvar container_1 = require(\"./container/container\");\nObject.defineProperty(exports, \"Container\", { enumerable: true, get: function () { return container_1.Container; } });\nvar literal_types_1 = require(\"./constants/literal_types\");\nObject.defineProperty(exports, \"BindingScopeEnum\", { enumerable: true, get: function () { return literal_types_1.BindingScopeEnum; } });\nObject.defineProperty(exports, \"BindingTypeEnum\", { enumerable: true, get: function () { return literal_types_1.BindingTypeEnum; } });\nObject.defineProperty(exports, \"TargetTypeEnum\", { enumerable: true, get: function () { return literal_types_1.TargetTypeEnum; } });\nvar container_module_1 = require(\"./container/container_module\");\nObject.defineProperty(exports, \"AsyncContainerModule\", { enumerable: true, get: function () { return container_module_1.AsyncContainerModule; } });\nObject.defineProperty(exports, \"ContainerModule\", { enumerable: true, get: function () { return container_module_1.ContainerModule; } });\nvar injectable_1 = require(\"./annotation/injectable\");\nObject.defineProperty(exports, \"injectable\", { enumerable: true, get: function () { return injectable_1.injectable; } });\nvar tagged_1 = require(\"./annotation/tagged\");\nObject.defineProperty(exports, \"tagged\", { enumerable: true, get: function () { return tagged_1.tagged; } });\nvar named_1 = require(\"./annotation/named\");\nObject.defineProperty(exports, \"named\", { enumerable: true, get: function () { return named_1.named; } });\nvar inject_1 = require(\"./annotation/inject\");\nObject.defineProperty(exports, \"inject\", { enumerable: true, get: function () { return inject_1.inject; } });\nObject.defineProperty(exports, \"LazyServiceIdentifer\", { enumerable: true, get: function () { return inject_1.LazyServiceIdentifer; } });\nvar optional_1 = require(\"./annotation/optional\");\nObject.defineProperty(exports, \"optional\", { enumerable: true, get: function () { return optional_1.optional; } });\nvar unmanaged_1 = require(\"./annotation/unmanaged\");\nObject.defineProperty(exports, \"unmanaged\", { enumerable: true, get: function () { return unmanaged_1.unmanaged; } });\nvar multi_inject_1 = require(\"./annotation/multi_inject\");\nObject.defineProperty(exports, \"multiInject\", { enumerable: true, get: function () { return multi_inject_1.multiInject; } });\nvar target_name_1 = require(\"./annotation/target_name\");\nObject.defineProperty(exports, \"targetName\", { enumerable: true, get: function () { return target_name_1.targetName; } });\nvar post_construct_1 = require(\"./annotation/post_construct\");\nObject.defineProperty(exports, \"postConstruct\", { enumerable: true, get: function () { return post_construct_1.postConstruct; } });\nvar metadata_reader_1 = require(\"./planning/metadata_reader\");\nObject.defineProperty(exports, \"MetadataReader\", { enumerable: true, get: function () { return metadata_reader_1.MetadataReader; } });\nvar id_1 = require(\"./utils/id\");\nObject.defineProperty(exports, \"id\", { enumerable: true, get: function () { return id_1.id; } });\nvar decorator_utils_1 = require(\"./annotation/decorator_utils\");\nObject.defineProperty(exports, \"decorate\", { enumerable: true, get: function () { return decorator_utils_1.decorate; } });\nvar constraint_helpers_1 = require(\"./syntax/constraint_helpers\");\nObject.defineProperty(exports, \"traverseAncerstors\", { enumerable: true, get: function () { return constraint_helpers_1.traverseAncerstors; } });\nObject.defineProperty(exports, \"taggedConstraint\", { enumerable: true, get: function () { return constraint_helpers_1.taggedConstraint; } });\nObject.defineProperty(exports, \"namedConstraint\", { enumerable: true, get: function () { return constraint_helpers_1.namedConstraint; } });\nObject.defineProperty(exports, \"typeConstraint\", { enumerable: true, get: function () { return constraint_helpers_1.typeConstraint; } });\nvar serialization_1 = require(\"./utils/serialization\");\nObject.defineProperty(exports, \"getServiceIdentifierAsString\", { enumerable: true, get: function () { return serialization_1.getServiceIdentifierAsString; } });\nvar binding_utils_1 = require(\"./utils/binding_utils\");\nObject.defineProperty(exports, \"multiBindToService\", { enumerable: true, get: function () { return binding_utils_1.multiBindToService; } });\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Context = void 0;\nvar id_1 = require(\"../utils/id\");\nvar Context = (function () {\n function Context(container) {\n this.id = id_1.id();\n this.container = container;\n }\n Context.prototype.addPlan = function (plan) {\n this.plan = plan;\n };\n Context.prototype.setCurrentRequest = function (currentRequest) {\n this.currentRequest = currentRequest;\n };\n return Context;\n}());\nexports.Context = Context;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Metadata = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar Metadata = (function () {\n function Metadata(key, value) {\n this.key = key;\n this.value = value;\n }\n Metadata.prototype.toString = function () {\n if (this.key === METADATA_KEY.NAMED_TAG) {\n return \"named: \" + this.value.toString() + \" \";\n }\n else {\n return \"tagged: { key:\" + this.key.toString() + \", value: \" + this.value + \" }\";\n }\n };\n return Metadata;\n}());\nexports.Metadata = Metadata;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.MetadataReader = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar MetadataReader = (function () {\n function MetadataReader() {\n }\n MetadataReader.prototype.getConstructorMetadata = function (constructorFunc) {\n var compilerGeneratedMetadata = Reflect.getMetadata(METADATA_KEY.PARAM_TYPES, constructorFunc);\n var userGeneratedMetadata = Reflect.getMetadata(METADATA_KEY.TAGGED, constructorFunc);\n return {\n compilerGeneratedMetadata: compilerGeneratedMetadata,\n userGeneratedMetadata: userGeneratedMetadata || {}\n };\n };\n MetadataReader.prototype.getPropertiesMetadata = function (constructorFunc) {\n var userGeneratedMetadata = Reflect.getMetadata(METADATA_KEY.TAGGED_PROP, constructorFunc) || [];\n return userGeneratedMetadata;\n };\n return MetadataReader;\n}());\nexports.MetadataReader = MetadataReader;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Plan = void 0;\nvar Plan = (function () {\n function Plan(parentContext, rootRequest) {\n this.parentContext = parentContext;\n this.rootRequest = rootRequest;\n }\n return Plan;\n}());\nexports.Plan = Plan;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getBindingDictionary = exports.createMockRequest = exports.plan = void 0;\nvar binding_count_1 = require(\"../bindings/binding_count\");\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar exceptions_1 = require(\"../utils/exceptions\");\nvar serialization_1 = require(\"../utils/serialization\");\nvar context_1 = require(\"./context\");\nvar metadata_1 = require(\"./metadata\");\nvar plan_1 = require(\"./plan\");\nvar reflection_utils_1 = require(\"./reflection_utils\");\nvar request_1 = require(\"./request\");\nvar target_1 = require(\"./target\");\nfunction getBindingDictionary(cntnr) {\n return cntnr._bindingDictionary;\n}\nexports.getBindingDictionary = getBindingDictionary;\nfunction _createTarget(isMultiInject, targetType, serviceIdentifier, name, key, value) {\n var metadataKey = isMultiInject ? METADATA_KEY.MULTI_INJECT_TAG : METADATA_KEY.INJECT_TAG;\n var injectMetadata = new metadata_1.Metadata(metadataKey, serviceIdentifier);\n var target = new target_1.Target(targetType, name, serviceIdentifier, injectMetadata);\n if (key !== undefined) {\n var tagMetadata = new metadata_1.Metadata(key, value);\n target.metadata.push(tagMetadata);\n }\n return target;\n}\nfunction _getActiveBindings(metadataReader, avoidConstraints, context, parentRequest, target) {\n var bindings = getBindings(context.container, target.serviceIdentifier);\n var activeBindings = [];\n if (bindings.length === binding_count_1.BindingCount.NoBindingsAvailable &&\n context.container.options.autoBindInjectable &&\n typeof target.serviceIdentifier === \"function\" &&\n metadataReader.getConstructorMetadata(target.serviceIdentifier).compilerGeneratedMetadata) {\n context.container.bind(target.serviceIdentifier).toSelf();\n bindings = getBindings(context.container, target.serviceIdentifier);\n }\n if (!avoidConstraints) {\n activeBindings = bindings.filter(function (binding) {\n var request = new request_1.Request(binding.serviceIdentifier, context, parentRequest, binding, target);\n return binding.constraint(request);\n });\n }\n else {\n activeBindings = bindings;\n }\n _validateActiveBindingCount(target.serviceIdentifier, activeBindings, target, context.container);\n return activeBindings;\n}\nfunction _validateActiveBindingCount(serviceIdentifier, bindings, target, container) {\n switch (bindings.length) {\n case binding_count_1.BindingCount.NoBindingsAvailable:\n if (target.isOptional()) {\n return bindings;\n }\n else {\n var serviceIdentifierString = serialization_1.getServiceIdentifierAsString(serviceIdentifier);\n var msg = ERROR_MSGS.NOT_REGISTERED;\n msg += serialization_1.listMetadataForTarget(serviceIdentifierString, target);\n msg += serialization_1.listRegisteredBindingsForServiceIdentifier(container, serviceIdentifierString, getBindings);\n throw new Error(msg);\n }\n case binding_count_1.BindingCount.OnlyOneBindingAvailable:\n if (!target.isArray()) {\n return bindings;\n }\n case binding_count_1.BindingCount.MultipleBindingsAvailable:\n default:\n if (!target.isArray()) {\n var serviceIdentifierString = serialization_1.getServiceIdentifierAsString(serviceIdentifier);\n var msg = ERROR_MSGS.AMBIGUOUS_MATCH + \" \" + serviceIdentifierString;\n msg += serialization_1.listRegisteredBindingsForServiceIdentifier(container, serviceIdentifierString, getBindings);\n throw new Error(msg);\n }\n else {\n return bindings;\n }\n }\n}\nfunction _createSubRequests(metadataReader, avoidConstraints, serviceIdentifier, context, parentRequest, target) {\n var activeBindings;\n var childRequest;\n if (parentRequest === null) {\n activeBindings = _getActiveBindings(metadataReader, avoidConstraints, context, null, target);\n childRequest = new request_1.Request(serviceIdentifier, context, null, activeBindings, target);\n var thePlan = new plan_1.Plan(context, childRequest);\n context.addPlan(thePlan);\n }\n else {\n activeBindings = _getActiveBindings(metadataReader, avoidConstraints, context, parentRequest, target);\n childRequest = parentRequest.addChildRequest(target.serviceIdentifier, activeBindings, target);\n }\n activeBindings.forEach(function (binding) {\n var subChildRequest = null;\n if (target.isArray()) {\n subChildRequest = childRequest.addChildRequest(binding.serviceIdentifier, binding, target);\n }\n else {\n if (binding.cache) {\n return;\n }\n subChildRequest = childRequest;\n }\n if (binding.type === literal_types_1.BindingTypeEnum.Instance && binding.implementationType !== null) {\n var dependencies = reflection_utils_1.getDependencies(metadataReader, binding.implementationType);\n if (!context.container.options.skipBaseClassChecks) {\n var baseClassDependencyCount = reflection_utils_1.getBaseClassDependencyCount(metadataReader, binding.implementationType);\n if (dependencies.length < baseClassDependencyCount) {\n var error = ERROR_MSGS.ARGUMENTS_LENGTH_MISMATCH(reflection_utils_1.getFunctionName(binding.implementationType));\n throw new Error(error);\n }\n }\n dependencies.forEach(function (dependency) {\n _createSubRequests(metadataReader, false, dependency.serviceIdentifier, context, subChildRequest, dependency);\n });\n }\n });\n}\nfunction getBindings(container, serviceIdentifier) {\n var bindings = [];\n var bindingDictionary = getBindingDictionary(container);\n if (bindingDictionary.hasKey(serviceIdentifier)) {\n bindings = bindingDictionary.get(serviceIdentifier);\n }\n else if (container.parent !== null) {\n bindings = getBindings(container.parent, serviceIdentifier);\n }\n return bindings;\n}\nfunction plan(metadataReader, container, isMultiInject, targetType, serviceIdentifier, key, value, avoidConstraints) {\n if (avoidConstraints === void 0) { avoidConstraints = false; }\n var context = new context_1.Context(container);\n var target = _createTarget(isMultiInject, targetType, serviceIdentifier, \"\", key, value);\n try {\n _createSubRequests(metadataReader, avoidConstraints, serviceIdentifier, context, null, target);\n return context;\n }\n catch (error) {\n if (exceptions_1.isStackOverflowExeption(error)) {\n if (context.plan) {\n serialization_1.circularDependencyToException(context.plan.rootRequest);\n }\n }\n throw error;\n }\n}\nexports.plan = plan;\nfunction createMockRequest(container, serviceIdentifier, key, value) {\n var target = new target_1.Target(literal_types_1.TargetTypeEnum.Variable, \"\", serviceIdentifier, new metadata_1.Metadata(key, value));\n var context = new context_1.Context(container);\n var request = new request_1.Request(serviceIdentifier, context, null, [], target);\n return request;\n}\nexports.createMockRequest = createMockRequest;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.QueryableString = void 0;\nvar QueryableString = (function () {\n function QueryableString(str) {\n this.str = str;\n }\n QueryableString.prototype.startsWith = function (searchString) {\n return this.str.indexOf(searchString) === 0;\n };\n QueryableString.prototype.endsWith = function (searchString) {\n var reverseString = \"\";\n var reverseSearchString = searchString.split(\"\").reverse().join(\"\");\n reverseString = this.str.split(\"\").reverse().join(\"\");\n return this.startsWith.call({ str: reverseString }, reverseSearchString);\n };\n QueryableString.prototype.contains = function (searchString) {\n return (this.str.indexOf(searchString) !== -1);\n };\n QueryableString.prototype.equals = function (compareString) {\n return this.str === compareString;\n };\n QueryableString.prototype.value = function () {\n return this.str;\n };\n return QueryableString;\n}());\nexports.QueryableString = QueryableString;\n","\"use strict\";\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getFunctionName = exports.getBaseClassDependencyCount = exports.getDependencies = void 0;\nvar inject_1 = require(\"../annotation/inject\");\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar serialization_1 = require(\"../utils/serialization\");\nObject.defineProperty(exports, \"getFunctionName\", { enumerable: true, get: function () { return serialization_1.getFunctionName; } });\nvar target_1 = require(\"./target\");\nfunction getDependencies(metadataReader, func) {\n var constructorName = serialization_1.getFunctionName(func);\n var targets = getTargets(metadataReader, constructorName, func, false);\n return targets;\n}\nexports.getDependencies = getDependencies;\nfunction getTargets(metadataReader, constructorName, func, isBaseClass) {\n var metadata = metadataReader.getConstructorMetadata(func);\n var serviceIdentifiers = metadata.compilerGeneratedMetadata;\n if (serviceIdentifiers === undefined) {\n var msg = ERROR_MSGS.MISSING_INJECTABLE_ANNOTATION + \" \" + constructorName + \".\";\n throw new Error(msg);\n }\n var constructorArgsMetadata = metadata.userGeneratedMetadata;\n var keys = Object.keys(constructorArgsMetadata);\n var hasUserDeclaredUnknownInjections = (func.length === 0 && keys.length > 0);\n var iterations = (hasUserDeclaredUnknownInjections) ? keys.length : func.length;\n var constructorTargets = getConstructorArgsAsTargets(isBaseClass, constructorName, serviceIdentifiers, constructorArgsMetadata, iterations);\n var propertyTargets = getClassPropsAsTargets(metadataReader, func);\n var targets = __spreadArrays(constructorTargets, propertyTargets);\n return targets;\n}\nfunction getConstructorArgsAsTarget(index, isBaseClass, constructorName, serviceIdentifiers, constructorArgsMetadata) {\n var targetMetadata = constructorArgsMetadata[index.toString()] || [];\n var metadata = formatTargetMetadata(targetMetadata);\n var isManaged = metadata.unmanaged !== true;\n var serviceIdentifier = serviceIdentifiers[index];\n var injectIdentifier = (metadata.inject || metadata.multiInject);\n serviceIdentifier = (injectIdentifier) ? (injectIdentifier) : serviceIdentifier;\n if (serviceIdentifier instanceof inject_1.LazyServiceIdentifer) {\n serviceIdentifier = serviceIdentifier.unwrap();\n }\n if (isManaged) {\n var isObject = serviceIdentifier === Object;\n var isFunction = serviceIdentifier === Function;\n var isUndefined = serviceIdentifier === undefined;\n var isUnknownType = (isObject || isFunction || isUndefined);\n if (!isBaseClass && isUnknownType) {\n var msg = ERROR_MSGS.MISSING_INJECT_ANNOTATION + \" argument \" + index + \" in class \" + constructorName + \".\";\n throw new Error(msg);\n }\n var target = new target_1.Target(literal_types_1.TargetTypeEnum.ConstructorArgument, metadata.targetName, serviceIdentifier);\n target.metadata = targetMetadata;\n return target;\n }\n return null;\n}\nfunction getConstructorArgsAsTargets(isBaseClass, constructorName, serviceIdentifiers, constructorArgsMetadata, iterations) {\n var targets = [];\n for (var i = 0; i < iterations; i++) {\n var index = i;\n var target = getConstructorArgsAsTarget(index, isBaseClass, constructorName, serviceIdentifiers, constructorArgsMetadata);\n if (target !== null) {\n targets.push(target);\n }\n }\n return targets;\n}\nfunction getClassPropsAsTargets(metadataReader, constructorFunc) {\n var classPropsMetadata = metadataReader.getPropertiesMetadata(constructorFunc);\n var targets = [];\n var keys = Object.keys(classPropsMetadata);\n for (var _i = 0, keys_1 = keys; _i < keys_1.length; _i++) {\n var key = keys_1[_i];\n var targetMetadata = classPropsMetadata[key];\n var metadata = formatTargetMetadata(classPropsMetadata[key]);\n var targetName = metadata.targetName || key;\n var serviceIdentifier = (metadata.inject || metadata.multiInject);\n var target = new target_1.Target(literal_types_1.TargetTypeEnum.ClassProperty, targetName, serviceIdentifier);\n target.metadata = targetMetadata;\n targets.push(target);\n }\n var baseConstructor = Object.getPrototypeOf(constructorFunc.prototype).constructor;\n if (baseConstructor !== Object) {\n var baseTargets = getClassPropsAsTargets(metadataReader, baseConstructor);\n targets = __spreadArrays(targets, baseTargets);\n }\n return targets;\n}\nfunction getBaseClassDependencyCount(metadataReader, func) {\n var baseConstructor = Object.getPrototypeOf(func.prototype).constructor;\n if (baseConstructor !== Object) {\n var baseConstructorName = serialization_1.getFunctionName(baseConstructor);\n var targets = getTargets(metadataReader, baseConstructorName, baseConstructor, true);\n var metadata = targets.map(function (t) {\n return t.metadata.filter(function (m) {\n return m.key === METADATA_KEY.UNMANAGED_TAG;\n });\n });\n var unmanagedCount = [].concat.apply([], metadata).length;\n var dependencyCount = targets.length - unmanagedCount;\n if (dependencyCount > 0) {\n return dependencyCount;\n }\n else {\n return getBaseClassDependencyCount(metadataReader, baseConstructor);\n }\n }\n else {\n return 0;\n }\n}\nexports.getBaseClassDependencyCount = getBaseClassDependencyCount;\nfunction formatTargetMetadata(targetMetadata) {\n var targetMetadataMap = {};\n targetMetadata.forEach(function (m) {\n targetMetadataMap[m.key.toString()] = m.value;\n });\n return {\n inject: targetMetadataMap[METADATA_KEY.INJECT_TAG],\n multiInject: targetMetadataMap[METADATA_KEY.MULTI_INJECT_TAG],\n targetName: targetMetadataMap[METADATA_KEY.NAME_TAG],\n unmanaged: targetMetadataMap[METADATA_KEY.UNMANAGED_TAG]\n };\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Request = void 0;\nvar id_1 = require(\"../utils/id\");\nvar Request = (function () {\n function Request(serviceIdentifier, parentContext, parentRequest, bindings, target) {\n this.id = id_1.id();\n this.serviceIdentifier = serviceIdentifier;\n this.parentContext = parentContext;\n this.parentRequest = parentRequest;\n this.target = target;\n this.childRequests = [];\n this.bindings = (Array.isArray(bindings) ? bindings : [bindings]);\n this.requestScope = parentRequest === null\n ? new Map()\n : null;\n }\n Request.prototype.addChildRequest = function (serviceIdentifier, bindings, target) {\n var child = new Request(serviceIdentifier, this.parentContext, this, bindings, target);\n this.childRequests.push(child);\n return child;\n };\n return Request;\n}());\nexports.Request = Request;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Target = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar id_1 = require(\"../utils/id\");\nvar metadata_1 = require(\"./metadata\");\nvar queryable_string_1 = require(\"./queryable_string\");\nvar Target = (function () {\n function Target(type, name, serviceIdentifier, namedOrTagged) {\n this.id = id_1.id();\n this.type = type;\n this.serviceIdentifier = serviceIdentifier;\n this.name = new queryable_string_1.QueryableString(name || \"\");\n this.metadata = new Array();\n var metadataItem = null;\n if (typeof namedOrTagged === \"string\") {\n metadataItem = new metadata_1.Metadata(METADATA_KEY.NAMED_TAG, namedOrTagged);\n }\n else if (namedOrTagged instanceof metadata_1.Metadata) {\n metadataItem = namedOrTagged;\n }\n if (metadataItem !== null) {\n this.metadata.push(metadataItem);\n }\n }\n Target.prototype.hasTag = function (key) {\n for (var _i = 0, _a = this.metadata; _i < _a.length; _i++) {\n var m = _a[_i];\n if (m.key === key) {\n return true;\n }\n }\n return false;\n };\n Target.prototype.isArray = function () {\n return this.hasTag(METADATA_KEY.MULTI_INJECT_TAG);\n };\n Target.prototype.matchesArray = function (name) {\n return this.matchesTag(METADATA_KEY.MULTI_INJECT_TAG)(name);\n };\n Target.prototype.isNamed = function () {\n return this.hasTag(METADATA_KEY.NAMED_TAG);\n };\n Target.prototype.isTagged = function () {\n return this.metadata.some(function (m) {\n return (m.key !== METADATA_KEY.INJECT_TAG) &&\n (m.key !== METADATA_KEY.MULTI_INJECT_TAG) &&\n (m.key !== METADATA_KEY.NAME_TAG) &&\n (m.key !== METADATA_KEY.UNMANAGED_TAG) &&\n (m.key !== METADATA_KEY.NAMED_TAG);\n });\n };\n Target.prototype.isOptional = function () {\n return this.matchesTag(METADATA_KEY.OPTIONAL_TAG)(true);\n };\n Target.prototype.getNamedTag = function () {\n if (this.isNamed()) {\n return this.metadata.filter(function (m) { return m.key === METADATA_KEY.NAMED_TAG; })[0];\n }\n return null;\n };\n Target.prototype.getCustomTags = function () {\n if (this.isTagged()) {\n return this.metadata.filter(function (m) {\n return (m.key !== METADATA_KEY.INJECT_TAG) &&\n (m.key !== METADATA_KEY.MULTI_INJECT_TAG) &&\n (m.key !== METADATA_KEY.NAME_TAG) &&\n (m.key !== METADATA_KEY.UNMANAGED_TAG) &&\n (m.key !== METADATA_KEY.NAMED_TAG);\n });\n }\n return null;\n };\n Target.prototype.matchesNamedTag = function (name) {\n return this.matchesTag(METADATA_KEY.NAMED_TAG)(name);\n };\n Target.prototype.matchesTag = function (key) {\n var _this = this;\n return function (value) {\n for (var _i = 0, _a = _this.metadata; _i < _a.length; _i++) {\n var m = _a[_i];\n if (m.key === key && m.value === value) {\n return true;\n }\n }\n return false;\n };\n };\n return Target;\n}());\nexports.Target = Target;\n","\"use strict\";\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.resolveInstance = void 0;\nvar error_msgs_1 = require(\"../constants/error_msgs\");\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nfunction _injectProperties(instance, childRequests, resolveRequest) {\n var propertyInjectionsRequests = childRequests.filter(function (childRequest) {\n return (childRequest.target !== null &&\n childRequest.target.type === literal_types_1.TargetTypeEnum.ClassProperty);\n });\n var propertyInjections = propertyInjectionsRequests.map(resolveRequest);\n propertyInjectionsRequests.forEach(function (r, index) {\n var propertyName = \"\";\n propertyName = r.target.name.value();\n var injection = propertyInjections[index];\n instance[propertyName] = injection;\n });\n return instance;\n}\nfunction _createInstance(Func, injections) {\n return new (Func.bind.apply(Func, __spreadArrays([void 0], injections)))();\n}\nfunction _postConstruct(constr, result) {\n if (Reflect.hasMetadata(METADATA_KEY.POST_CONSTRUCT, constr)) {\n var data = Reflect.getMetadata(METADATA_KEY.POST_CONSTRUCT, constr);\n try {\n result[data.value]();\n }\n catch (e) {\n throw new Error(error_msgs_1.POST_CONSTRUCT_ERROR(constr.name, e.message));\n }\n }\n}\nfunction resolveInstance(constr, childRequests, resolveRequest) {\n var result = null;\n if (childRequests.length > 0) {\n var constructorInjectionsRequests = childRequests.filter(function (childRequest) {\n return (childRequest.target !== null && childRequest.target.type === literal_types_1.TargetTypeEnum.ConstructorArgument);\n });\n var constructorInjections = constructorInjectionsRequests.map(resolveRequest);\n result = _createInstance(constr, constructorInjections);\n result = _injectProperties(result, childRequests, resolveRequest);\n }\n else {\n result = new constr();\n }\n _postConstruct(constr, result);\n return result;\n}\nexports.resolveInstance = resolveInstance;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.resolve = void 0;\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar exceptions_1 = require(\"../utils/exceptions\");\nvar serialization_1 = require(\"../utils/serialization\");\nvar instantiation_1 = require(\"./instantiation\");\nvar invokeFactory = function (factoryType, serviceIdentifier, fn) {\n try {\n return fn();\n }\n catch (error) {\n if (exceptions_1.isStackOverflowExeption(error)) {\n throw new Error(ERROR_MSGS.CIRCULAR_DEPENDENCY_IN_FACTORY(factoryType, serviceIdentifier.toString()));\n }\n else {\n throw error;\n }\n }\n};\nvar _resolveRequest = function (requestScope) {\n return function (request) {\n request.parentContext.setCurrentRequest(request);\n var bindings = request.bindings;\n var childRequests = request.childRequests;\n var targetIsAnArray = request.target && request.target.isArray();\n var targetParentIsNotAnArray = !request.parentRequest ||\n !request.parentRequest.target ||\n !request.target ||\n !request.parentRequest.target.matchesArray(request.target.serviceIdentifier);\n if (targetIsAnArray && targetParentIsNotAnArray) {\n return childRequests.map(function (childRequest) {\n var _f = _resolveRequest(requestScope);\n return _f(childRequest);\n });\n }\n else {\n var result = null;\n if (request.target.isOptional() && bindings.length === 0) {\n return undefined;\n }\n var binding_1 = bindings[0];\n var isSingleton = binding_1.scope === literal_types_1.BindingScopeEnum.Singleton;\n var isRequestSingleton = binding_1.scope === literal_types_1.BindingScopeEnum.Request;\n if (isSingleton && binding_1.activated) {\n return binding_1.cache;\n }\n if (isRequestSingleton &&\n requestScope !== null &&\n requestScope.has(binding_1.id)) {\n return requestScope.get(binding_1.id);\n }\n if (binding_1.type === literal_types_1.BindingTypeEnum.ConstantValue) {\n result = binding_1.cache;\n }\n else if (binding_1.type === literal_types_1.BindingTypeEnum.Function) {\n result = binding_1.cache;\n }\n else if (binding_1.type === literal_types_1.BindingTypeEnum.Constructor) {\n result = binding_1.implementationType;\n }\n else if (binding_1.type === literal_types_1.BindingTypeEnum.DynamicValue && binding_1.dynamicValue !== null) {\n result = invokeFactory(\"toDynamicValue\", binding_1.serviceIdentifier, function () { return binding_1.dynamicValue(request.parentContext); });\n }\n else if (binding_1.type === literal_types_1.BindingTypeEnum.Factory && binding_1.factory !== null) {\n result = invokeFactory(\"toFactory\", binding_1.serviceIdentifier, function () { return binding_1.factory(request.parentContext); });\n }\n else if (binding_1.type === literal_types_1.BindingTypeEnum.Provider && binding_1.provider !== null) {\n result = invokeFactory(\"toProvider\", binding_1.serviceIdentifier, function () { return binding_1.provider(request.parentContext); });\n }\n else if (binding_1.type === literal_types_1.BindingTypeEnum.Instance && binding_1.implementationType !== null) {\n result = instantiation_1.resolveInstance(binding_1.implementationType, childRequests, _resolveRequest(requestScope));\n }\n else {\n var serviceIdentifier = serialization_1.getServiceIdentifierAsString(request.serviceIdentifier);\n throw new Error(ERROR_MSGS.INVALID_BINDING_TYPE + \" \" + serviceIdentifier);\n }\n if (typeof binding_1.onActivation === \"function\") {\n result = binding_1.onActivation(request.parentContext, result);\n }\n if (isSingleton) {\n binding_1.cache = result;\n binding_1.activated = true;\n }\n if (isRequestSingleton &&\n requestScope !== null &&\n !requestScope.has(binding_1.id)) {\n requestScope.set(binding_1.id, result);\n }\n return result;\n }\n };\n};\nfunction resolve(context) {\n var _f = _resolveRequest(context.plan.rootRequest.requestScope);\n return _f(context.plan.rootRequest);\n}\nexports.resolve = resolve;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingInSyntax = void 0;\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar binding_when_on_syntax_1 = require(\"./binding_when_on_syntax\");\nvar BindingInSyntax = (function () {\n function BindingInSyntax(binding) {\n this._binding = binding;\n }\n BindingInSyntax.prototype.inRequestScope = function () {\n this._binding.scope = literal_types_1.BindingScopeEnum.Request;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingInSyntax.prototype.inSingletonScope = function () {\n this._binding.scope = literal_types_1.BindingScopeEnum.Singleton;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingInSyntax.prototype.inTransientScope = function () {\n this._binding.scope = literal_types_1.BindingScopeEnum.Transient;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n return BindingInSyntax;\n}());\nexports.BindingInSyntax = BindingInSyntax;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingInWhenOnSyntax = void 0;\nvar binding_in_syntax_1 = require(\"./binding_in_syntax\");\nvar binding_on_syntax_1 = require(\"./binding_on_syntax\");\nvar binding_when_syntax_1 = require(\"./binding_when_syntax\");\nvar BindingInWhenOnSyntax = (function () {\n function BindingInWhenOnSyntax(binding) {\n this._binding = binding;\n this._bindingWhenSyntax = new binding_when_syntax_1.BindingWhenSyntax(this._binding);\n this._bindingOnSyntax = new binding_on_syntax_1.BindingOnSyntax(this._binding);\n this._bindingInSyntax = new binding_in_syntax_1.BindingInSyntax(binding);\n }\n BindingInWhenOnSyntax.prototype.inRequestScope = function () {\n return this._bindingInSyntax.inRequestScope();\n };\n BindingInWhenOnSyntax.prototype.inSingletonScope = function () {\n return this._bindingInSyntax.inSingletonScope();\n };\n BindingInWhenOnSyntax.prototype.inTransientScope = function () {\n return this._bindingInSyntax.inTransientScope();\n };\n BindingInWhenOnSyntax.prototype.when = function (constraint) {\n return this._bindingWhenSyntax.when(constraint);\n };\n BindingInWhenOnSyntax.prototype.whenTargetNamed = function (name) {\n return this._bindingWhenSyntax.whenTargetNamed(name);\n };\n BindingInWhenOnSyntax.prototype.whenTargetIsDefault = function () {\n return this._bindingWhenSyntax.whenTargetIsDefault();\n };\n BindingInWhenOnSyntax.prototype.whenTargetTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenTargetTagged(tag, value);\n };\n BindingInWhenOnSyntax.prototype.whenInjectedInto = function (parent) {\n return this._bindingWhenSyntax.whenInjectedInto(parent);\n };\n BindingInWhenOnSyntax.prototype.whenParentNamed = function (name) {\n return this._bindingWhenSyntax.whenParentNamed(name);\n };\n BindingInWhenOnSyntax.prototype.whenParentTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenParentTagged(tag, value);\n };\n BindingInWhenOnSyntax.prototype.whenAnyAncestorIs = function (ancestor) {\n return this._bindingWhenSyntax.whenAnyAncestorIs(ancestor);\n };\n BindingInWhenOnSyntax.prototype.whenNoAncestorIs = function (ancestor) {\n return this._bindingWhenSyntax.whenNoAncestorIs(ancestor);\n };\n BindingInWhenOnSyntax.prototype.whenAnyAncestorNamed = function (name) {\n return this._bindingWhenSyntax.whenAnyAncestorNamed(name);\n };\n BindingInWhenOnSyntax.prototype.whenAnyAncestorTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenAnyAncestorTagged(tag, value);\n };\n BindingInWhenOnSyntax.prototype.whenNoAncestorNamed = function (name) {\n return this._bindingWhenSyntax.whenNoAncestorNamed(name);\n };\n BindingInWhenOnSyntax.prototype.whenNoAncestorTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenNoAncestorTagged(tag, value);\n };\n BindingInWhenOnSyntax.prototype.whenAnyAncestorMatches = function (constraint) {\n return this._bindingWhenSyntax.whenAnyAncestorMatches(constraint);\n };\n BindingInWhenOnSyntax.prototype.whenNoAncestorMatches = function (constraint) {\n return this._bindingWhenSyntax.whenNoAncestorMatches(constraint);\n };\n BindingInWhenOnSyntax.prototype.onActivation = function (handler) {\n return this._bindingOnSyntax.onActivation(handler);\n };\n return BindingInWhenOnSyntax;\n}());\nexports.BindingInWhenOnSyntax = BindingInWhenOnSyntax;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingOnSyntax = void 0;\nvar binding_when_syntax_1 = require(\"./binding_when_syntax\");\nvar BindingOnSyntax = (function () {\n function BindingOnSyntax(binding) {\n this._binding = binding;\n }\n BindingOnSyntax.prototype.onActivation = function (handler) {\n this._binding.onActivation = handler;\n return new binding_when_syntax_1.BindingWhenSyntax(this._binding);\n };\n return BindingOnSyntax;\n}());\nexports.BindingOnSyntax = BindingOnSyntax;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingToSyntax = void 0;\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nvar literal_types_1 = require(\"../constants/literal_types\");\nvar binding_in_when_on_syntax_1 = require(\"./binding_in_when_on_syntax\");\nvar binding_when_on_syntax_1 = require(\"./binding_when_on_syntax\");\nvar BindingToSyntax = (function () {\n function BindingToSyntax(binding) {\n this._binding = binding;\n }\n BindingToSyntax.prototype.to = function (constructor) {\n this._binding.type = literal_types_1.BindingTypeEnum.Instance;\n this._binding.implementationType = constructor;\n return new binding_in_when_on_syntax_1.BindingInWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toSelf = function () {\n if (typeof this._binding.serviceIdentifier !== \"function\") {\n throw new Error(\"\" + ERROR_MSGS.INVALID_TO_SELF_VALUE);\n }\n var self = this._binding.serviceIdentifier;\n return this.to(self);\n };\n BindingToSyntax.prototype.toConstantValue = function (value) {\n this._binding.type = literal_types_1.BindingTypeEnum.ConstantValue;\n this._binding.cache = value;\n this._binding.dynamicValue = null;\n this._binding.implementationType = null;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toDynamicValue = function (func) {\n this._binding.type = literal_types_1.BindingTypeEnum.DynamicValue;\n this._binding.cache = null;\n this._binding.dynamicValue = func;\n this._binding.implementationType = null;\n return new binding_in_when_on_syntax_1.BindingInWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toConstructor = function (constructor) {\n this._binding.type = literal_types_1.BindingTypeEnum.Constructor;\n this._binding.implementationType = constructor;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toFactory = function (factory) {\n this._binding.type = literal_types_1.BindingTypeEnum.Factory;\n this._binding.factory = factory;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toFunction = function (func) {\n if (typeof func !== \"function\") {\n throw new Error(ERROR_MSGS.INVALID_FUNCTION_BINDING);\n }\n var bindingWhenOnSyntax = this.toConstantValue(func);\n this._binding.type = literal_types_1.BindingTypeEnum.Function;\n return bindingWhenOnSyntax;\n };\n BindingToSyntax.prototype.toAutoFactory = function (serviceIdentifier) {\n this._binding.type = literal_types_1.BindingTypeEnum.Factory;\n this._binding.factory = function (context) {\n var autofactory = function () { return context.container.get(serviceIdentifier); };\n return autofactory;\n };\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toProvider = function (provider) {\n this._binding.type = literal_types_1.BindingTypeEnum.Provider;\n this._binding.provider = provider;\n return new binding_when_on_syntax_1.BindingWhenOnSyntax(this._binding);\n };\n BindingToSyntax.prototype.toService = function (service) {\n this.toDynamicValue(function (context) { return context.container.get(service); });\n };\n return BindingToSyntax;\n}());\nexports.BindingToSyntax = BindingToSyntax;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingWhenOnSyntax = void 0;\nvar binding_on_syntax_1 = require(\"./binding_on_syntax\");\nvar binding_when_syntax_1 = require(\"./binding_when_syntax\");\nvar BindingWhenOnSyntax = (function () {\n function BindingWhenOnSyntax(binding) {\n this._binding = binding;\n this._bindingWhenSyntax = new binding_when_syntax_1.BindingWhenSyntax(this._binding);\n this._bindingOnSyntax = new binding_on_syntax_1.BindingOnSyntax(this._binding);\n }\n BindingWhenOnSyntax.prototype.when = function (constraint) {\n return this._bindingWhenSyntax.when(constraint);\n };\n BindingWhenOnSyntax.prototype.whenTargetNamed = function (name) {\n return this._bindingWhenSyntax.whenTargetNamed(name);\n };\n BindingWhenOnSyntax.prototype.whenTargetIsDefault = function () {\n return this._bindingWhenSyntax.whenTargetIsDefault();\n };\n BindingWhenOnSyntax.prototype.whenTargetTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenTargetTagged(tag, value);\n };\n BindingWhenOnSyntax.prototype.whenInjectedInto = function (parent) {\n return this._bindingWhenSyntax.whenInjectedInto(parent);\n };\n BindingWhenOnSyntax.prototype.whenParentNamed = function (name) {\n return this._bindingWhenSyntax.whenParentNamed(name);\n };\n BindingWhenOnSyntax.prototype.whenParentTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenParentTagged(tag, value);\n };\n BindingWhenOnSyntax.prototype.whenAnyAncestorIs = function (ancestor) {\n return this._bindingWhenSyntax.whenAnyAncestorIs(ancestor);\n };\n BindingWhenOnSyntax.prototype.whenNoAncestorIs = function (ancestor) {\n return this._bindingWhenSyntax.whenNoAncestorIs(ancestor);\n };\n BindingWhenOnSyntax.prototype.whenAnyAncestorNamed = function (name) {\n return this._bindingWhenSyntax.whenAnyAncestorNamed(name);\n };\n BindingWhenOnSyntax.prototype.whenAnyAncestorTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenAnyAncestorTagged(tag, value);\n };\n BindingWhenOnSyntax.prototype.whenNoAncestorNamed = function (name) {\n return this._bindingWhenSyntax.whenNoAncestorNamed(name);\n };\n BindingWhenOnSyntax.prototype.whenNoAncestorTagged = function (tag, value) {\n return this._bindingWhenSyntax.whenNoAncestorTagged(tag, value);\n };\n BindingWhenOnSyntax.prototype.whenAnyAncestorMatches = function (constraint) {\n return this._bindingWhenSyntax.whenAnyAncestorMatches(constraint);\n };\n BindingWhenOnSyntax.prototype.whenNoAncestorMatches = function (constraint) {\n return this._bindingWhenSyntax.whenNoAncestorMatches(constraint);\n };\n BindingWhenOnSyntax.prototype.onActivation = function (handler) {\n return this._bindingOnSyntax.onActivation(handler);\n };\n return BindingWhenOnSyntax;\n}());\nexports.BindingWhenOnSyntax = BindingWhenOnSyntax;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BindingWhenSyntax = void 0;\nvar binding_on_syntax_1 = require(\"./binding_on_syntax\");\nvar constraint_helpers_1 = require(\"./constraint_helpers\");\nvar BindingWhenSyntax = (function () {\n function BindingWhenSyntax(binding) {\n this._binding = binding;\n }\n BindingWhenSyntax.prototype.when = function (constraint) {\n this._binding.constraint = constraint;\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenTargetNamed = function (name) {\n this._binding.constraint = constraint_helpers_1.namedConstraint(name);\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenTargetIsDefault = function () {\n this._binding.constraint = function (request) {\n var targetIsDefault = (request.target !== null) &&\n (!request.target.isNamed()) &&\n (!request.target.isTagged());\n return targetIsDefault;\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenTargetTagged = function (tag, value) {\n this._binding.constraint = constraint_helpers_1.taggedConstraint(tag)(value);\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenInjectedInto = function (parent) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.typeConstraint(parent)(request.parentRequest);\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenParentNamed = function (name) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.namedConstraint(name)(request.parentRequest);\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenParentTagged = function (tag, value) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.taggedConstraint(tag)(value)(request.parentRequest);\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenAnyAncestorIs = function (ancestor) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.traverseAncerstors(request, constraint_helpers_1.typeConstraint(ancestor));\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenNoAncestorIs = function (ancestor) {\n this._binding.constraint = function (request) {\n return !constraint_helpers_1.traverseAncerstors(request, constraint_helpers_1.typeConstraint(ancestor));\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenAnyAncestorNamed = function (name) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.traverseAncerstors(request, constraint_helpers_1.namedConstraint(name));\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenNoAncestorNamed = function (name) {\n this._binding.constraint = function (request) {\n return !constraint_helpers_1.traverseAncerstors(request, constraint_helpers_1.namedConstraint(name));\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenAnyAncestorTagged = function (tag, value) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.traverseAncerstors(request, constraint_helpers_1.taggedConstraint(tag)(value));\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenNoAncestorTagged = function (tag, value) {\n this._binding.constraint = function (request) {\n return !constraint_helpers_1.traverseAncerstors(request, constraint_helpers_1.taggedConstraint(tag)(value));\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenAnyAncestorMatches = function (constraint) {\n this._binding.constraint = function (request) {\n return constraint_helpers_1.traverseAncerstors(request, constraint);\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n BindingWhenSyntax.prototype.whenNoAncestorMatches = function (constraint) {\n this._binding.constraint = function (request) {\n return !constraint_helpers_1.traverseAncerstors(request, constraint);\n };\n return new binding_on_syntax_1.BindingOnSyntax(this._binding);\n };\n return BindingWhenSyntax;\n}());\nexports.BindingWhenSyntax = BindingWhenSyntax;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.typeConstraint = exports.namedConstraint = exports.taggedConstraint = exports.traverseAncerstors = void 0;\nvar METADATA_KEY = require(\"../constants/metadata_keys\");\nvar metadata_1 = require(\"../planning/metadata\");\nvar traverseAncerstors = function (request, constraint) {\n var parent = request.parentRequest;\n if (parent !== null) {\n return constraint(parent) ? true : traverseAncerstors(parent, constraint);\n }\n else {\n return false;\n }\n};\nexports.traverseAncerstors = traverseAncerstors;\nvar taggedConstraint = function (key) { return function (value) {\n var constraint = function (request) {\n return request !== null && request.target !== null && request.target.matchesTag(key)(value);\n };\n constraint.metaData = new metadata_1.Metadata(key, value);\n return constraint;\n}; };\nexports.taggedConstraint = taggedConstraint;\nvar namedConstraint = taggedConstraint(METADATA_KEY.NAMED_TAG);\nexports.namedConstraint = namedConstraint;\nvar typeConstraint = function (type) { return function (request) {\n var binding = null;\n if (request !== null) {\n binding = request.bindings[0];\n if (typeof type === \"string\") {\n var serviceIdentifier = binding.serviceIdentifier;\n return serviceIdentifier === type;\n }\n else {\n var constructor = request.bindings[0].implementationType;\n return type === constructor;\n }\n }\n return false;\n}; };\nexports.typeConstraint = typeConstraint;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.multiBindToService = void 0;\nexports.multiBindToService = function (container) {\n return function (service) {\n return function () {\n var types = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n types[_i] = arguments[_i];\n }\n return types.forEach(function (t) { return container.bind(t).toService(service); });\n };\n };\n};\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isStackOverflowExeption = void 0;\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nfunction isStackOverflowExeption(error) {\n return (error instanceof RangeError ||\n error.message === ERROR_MSGS.STACK_OVERFLOW);\n}\nexports.isStackOverflowExeption = isStackOverflowExeption;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.id = void 0;\nvar idCounter = 0;\nfunction id() {\n return idCounter++;\n}\nexports.id = id;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.circularDependencyToException = exports.listMetadataForTarget = exports.listRegisteredBindingsForServiceIdentifier = exports.getServiceIdentifierAsString = exports.getFunctionName = void 0;\nvar ERROR_MSGS = require(\"../constants/error_msgs\");\nfunction getServiceIdentifierAsString(serviceIdentifier) {\n if (typeof serviceIdentifier === \"function\") {\n var _serviceIdentifier = serviceIdentifier;\n return _serviceIdentifier.name;\n }\n else if (typeof serviceIdentifier === \"symbol\") {\n return serviceIdentifier.toString();\n }\n else {\n var _serviceIdentifier = serviceIdentifier;\n return _serviceIdentifier;\n }\n}\nexports.getServiceIdentifierAsString = getServiceIdentifierAsString;\nfunction listRegisteredBindingsForServiceIdentifier(container, serviceIdentifier, getBindings) {\n var registeredBindingsList = \"\";\n var registeredBindings = getBindings(container, serviceIdentifier);\n if (registeredBindings.length !== 0) {\n registeredBindingsList = \"\\nRegistered bindings:\";\n registeredBindings.forEach(function (binding) {\n var name = \"Object\";\n if (binding.implementationType !== null) {\n name = getFunctionName(binding.implementationType);\n }\n registeredBindingsList = registeredBindingsList + \"\\n \" + name;\n if (binding.constraint.metaData) {\n registeredBindingsList = registeredBindingsList + \" - \" + binding.constraint.metaData;\n }\n });\n }\n return registeredBindingsList;\n}\nexports.listRegisteredBindingsForServiceIdentifier = listRegisteredBindingsForServiceIdentifier;\nfunction alreadyDependencyChain(request, serviceIdentifier) {\n if (request.parentRequest === null) {\n return false;\n }\n else if (request.parentRequest.serviceIdentifier === serviceIdentifier) {\n return true;\n }\n else {\n return alreadyDependencyChain(request.parentRequest, serviceIdentifier);\n }\n}\nfunction dependencyChainToString(request) {\n function _createStringArr(req, result) {\n if (result === void 0) { result = []; }\n var serviceIdentifier = getServiceIdentifierAsString(req.serviceIdentifier);\n result.push(serviceIdentifier);\n if (req.parentRequest !== null) {\n return _createStringArr(req.parentRequest, result);\n }\n return result;\n }\n var stringArr = _createStringArr(request);\n return stringArr.reverse().join(\" --> \");\n}\nfunction circularDependencyToException(request) {\n request.childRequests.forEach(function (childRequest) {\n if (alreadyDependencyChain(childRequest, childRequest.serviceIdentifier)) {\n var services = dependencyChainToString(childRequest);\n throw new Error(ERROR_MSGS.CIRCULAR_DEPENDENCY + \" \" + services);\n }\n else {\n circularDependencyToException(childRequest);\n }\n });\n}\nexports.circularDependencyToException = circularDependencyToException;\nfunction listMetadataForTarget(serviceIdentifierString, target) {\n if (target.isTagged() || target.isNamed()) {\n var m_1 = \"\";\n var namedTag = target.getNamedTag();\n var otherTags = target.getCustomTags();\n if (namedTag !== null) {\n m_1 += namedTag.toString() + \"\\n\";\n }\n if (otherTags !== null) {\n otherTags.forEach(function (tag) {\n m_1 += tag.toString() + \"\\n\";\n });\n }\n return \" \" + serviceIdentifierString + \"\\n \" + serviceIdentifierString + \" - \" + m_1;\n }\n else {\n return \" \" + serviceIdentifierString;\n }\n}\nexports.listMetadataForTarget = listMetadataForTarget;\nfunction getFunctionName(v) {\n if (v.name) {\n return v.name;\n }\n else {\n var name_1 = v.toString();\n var match = name_1.match(/^function\\s*([^\\s(]+)/);\n return match ? match[1] : \"Anonymous function: \" + name_1;\n }\n}\nexports.getFunctionName = getFunctionName;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nmodule.exports = DataView;\n","var hashClear = require('./_hashClear'),\n hashDelete = require('./_hashDelete'),\n hashGet = require('./_hashGet'),\n hashHas = require('./_hashHas'),\n hashSet = require('./_hashSet');\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nmodule.exports = Hash;\n","var listCacheClear = require('./_listCacheClear'),\n listCacheDelete = require('./_listCacheDelete'),\n listCacheGet = require('./_listCacheGet'),\n listCacheHas = require('./_listCacheHas'),\n listCacheSet = require('./_listCacheSet');\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nmodule.exports = ListCache;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n","var mapCacheClear = require('./_mapCacheClear'),\n mapCacheDelete = require('./_mapCacheDelete'),\n mapCacheGet = require('./_mapCacheGet'),\n mapCacheHas = require('./_mapCacheHas'),\n mapCacheSet = require('./_mapCacheSet');\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nmodule.exports = MapCache;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nmodule.exports = Promise;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nmodule.exports = Set;\n","var MapCache = require('./_MapCache'),\n setCacheAdd = require('./_setCacheAdd'),\n setCacheHas = require('./_setCacheHas');\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\nmodule.exports = SetCache;\n","var ListCache = require('./_ListCache'),\n stackClear = require('./_stackClear'),\n stackDelete = require('./_stackDelete'),\n stackGet = require('./_stackGet'),\n stackHas = require('./_stackHas'),\n stackSet = require('./_stackSet');\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nmodule.exports = Stack;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nmodule.exports = WeakMap;\n","/**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\nfunction apply(func, thisArg, args) {\n switch (args.length) {\n case 0: return func.call(thisArg);\n case 1: return func.call(thisArg, args[0]);\n case 2: return func.call(thisArg, args[0], args[1]);\n case 3: return func.call(thisArg, args[0], args[1], args[2]);\n }\n return func.apply(thisArg, args);\n}\n\nmodule.exports = apply;\n","/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEach(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (iteratee(array[index], index, array) === false) {\n break;\n }\n }\n return array;\n}\n\nmodule.exports = arrayEach;\n","/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\nmodule.exports = arrayFilter;\n","var baseIndexOf = require('./_baseIndexOf');\n\n/**\n * A specialized version of `_.includes` for arrays without support for\n * specifying an index to search from.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\nfunction arrayIncludes(array, value) {\n var length = array == null ? 0 : array.length;\n return !!length && baseIndexOf(array, value, 0) > -1;\n}\n\nmodule.exports = arrayIncludes;\n","/**\n * This function is like `arrayIncludes` except that it accepts a comparator.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @param {Function} comparator The comparator invoked per element.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\nfunction arrayIncludesWith(array, value, comparator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (comparator(value, array[index])) {\n return true;\n }\n }\n return false;\n}\n\nmodule.exports = arrayIncludesWith;\n","var baseTimes = require('./_baseTimes'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isIndex = require('./_isIndex'),\n isTypedArray = require('./isTypedArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = arrayLikeKeys;\n","/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n}\n\nmodule.exports = arrayMap;\n","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\nmodule.exports = arrayPush;\n","/**\n * A specialized version of `_.reduce` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the first element of `array` as\n * the initial value.\n * @returns {*} Returns the accumulated value.\n */\nfunction arrayReduce(array, iteratee, accumulator, initAccum) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n if (initAccum && length) {\n accumulator = array[++index];\n }\n while (++index < length) {\n accumulator = iteratee(accumulator, array[index], index, array);\n }\n return accumulator;\n}\n\nmodule.exports = arrayReduce;\n","/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\nmodule.exports = arraySome;\n","var baseProperty = require('./_baseProperty');\n\n/**\n * Gets the size of an ASCII `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\nvar asciiSize = baseProperty('length');\n\nmodule.exports = asciiSize;\n","var baseAssignValue = require('./_baseAssignValue'),\n eq = require('./eq');\n\n/**\n * This function is like `assignValue` except that it doesn't assign\n * `undefined` values.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignMergeValue(object, key, value) {\n if ((value !== undefined && !eq(object[key], value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n}\n\nmodule.exports = assignMergeValue;\n","var baseAssignValue = require('./_baseAssignValue'),\n eq = require('./eq');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n}\n\nmodule.exports = assignValue;\n","var eq = require('./eq');\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\nmodule.exports = assocIndexOf;\n","var copyObject = require('./_copyObject'),\n keys = require('./keys');\n\n/**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssign(object, source) {\n return object && copyObject(source, keys(source), object);\n}\n\nmodule.exports = baseAssign;\n","var copyObject = require('./_copyObject'),\n keysIn = require('./keysIn');\n\n/**\n * The base implementation of `_.assignIn` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssignIn(object, source) {\n return object && copyObject(source, keysIn(source), object);\n}\n\nmodule.exports = baseAssignIn;\n","var defineProperty = require('./_defineProperty');\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n}\n\nmodule.exports = baseAssignValue;\n","var Stack = require('./_Stack'),\n arrayEach = require('./_arrayEach'),\n assignValue = require('./_assignValue'),\n baseAssign = require('./_baseAssign'),\n baseAssignIn = require('./_baseAssignIn'),\n cloneBuffer = require('./_cloneBuffer'),\n copyArray = require('./_copyArray'),\n copySymbols = require('./_copySymbols'),\n copySymbolsIn = require('./_copySymbolsIn'),\n getAllKeys = require('./_getAllKeys'),\n getAllKeysIn = require('./_getAllKeysIn'),\n getTag = require('./_getTag'),\n initCloneArray = require('./_initCloneArray'),\n initCloneByTag = require('./_initCloneByTag'),\n initCloneObject = require('./_initCloneObject'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isMap = require('./isMap'),\n isObject = require('./isObject'),\n isSet = require('./isSet'),\n keys = require('./keys'),\n keysIn = require('./keysIn');\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\ncloneableTags[boolTag] = cloneableTags[dateTag] =\ncloneableTags[float32Tag] = cloneableTags[float64Tag] =\ncloneableTags[int8Tag] = cloneableTags[int16Tag] =\ncloneableTags[int32Tag] = cloneableTags[mapTag] =\ncloneableTags[numberTag] = cloneableTags[objectTag] =\ncloneableTags[regexpTag] = cloneableTags[setTag] =\ncloneableTags[stringTag] = cloneableTags[symbolTag] =\ncloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\ncloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Deep clone\n * 2 - Flatten inherited properties\n * 4 - Clone symbols\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, bitmask, customizer, key, object, stack) {\n var result,\n isDeep = bitmask & CLONE_DEEP_FLAG,\n isFlat = bitmask & CLONE_FLAT_FLAG,\n isFull = bitmask & CLONE_SYMBOLS_FLAG;\n\n if (customizer) {\n result = object ? customizer(value, key, object, stack) : customizer(value);\n }\n if (result !== undefined) {\n return result;\n }\n if (!isObject(value)) {\n return value;\n }\n var isArr = isArray(value);\n if (isArr) {\n result = initCloneArray(value);\n if (!isDeep) {\n return copyArray(value, result);\n }\n } else {\n var tag = getTag(value),\n isFunc = tag == funcTag || tag == genTag;\n\n if (isBuffer(value)) {\n return cloneBuffer(value, isDeep);\n }\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n result = (isFlat || isFunc) ? {} : initCloneObject(value);\n if (!isDeep) {\n return isFlat\n ? copySymbolsIn(value, baseAssignIn(result, value))\n : copySymbols(value, baseAssign(result, value));\n }\n } else {\n if (!cloneableTags[tag]) {\n return object ? value : {};\n }\n result = initCloneByTag(value, tag, isDeep);\n }\n }\n // Check for circular references and return its corresponding clone.\n stack || (stack = new Stack);\n var stacked = stack.get(value);\n if (stacked) {\n return stacked;\n }\n stack.set(value, result);\n\n if (isSet(value)) {\n value.forEach(function(subValue) {\n result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\n });\n } else if (isMap(value)) {\n value.forEach(function(subValue, key) {\n result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n }\n\n var keysFunc = isFull\n ? (isFlat ? getAllKeysIn : getAllKeys)\n : (isFlat ? keysIn : keys);\n\n var props = isArr ? undefined : keysFunc(value);\n arrayEach(props || value, function(subValue, key) {\n if (props) {\n key = subValue;\n subValue = value[key];\n }\n // Recursively populate clone (susceptible to call stack limits).\n assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n return result;\n}\n\nmodule.exports = baseClone;\n","var isObject = require('./isObject');\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n function object() {}\n return function(proto) {\n if (!isObject(proto)) {\n return {};\n }\n if (objectCreate) {\n return objectCreate(proto);\n }\n object.prototype = proto;\n var result = new object;\n object.prototype = undefined;\n return result;\n };\n}());\n\nmodule.exports = baseCreate;\n","var baseForOwn = require('./_baseForOwn'),\n createBaseEach = require('./_createBaseEach');\n\n/**\n * The base implementation of `_.forEach` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\nvar baseEach = createBaseEach(baseForOwn);\n\nmodule.exports = baseEach;\n","var isSymbol = require('./isSymbol');\n\n/**\n * The base implementation of methods like `_.max` and `_.min` which accepts a\n * `comparator` to determine the extremum value.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The iteratee invoked per iteration.\n * @param {Function} comparator The comparator used to compare values.\n * @returns {*} Returns the extremum value.\n */\nfunction baseExtremum(array, iteratee, comparator) {\n var index = -1,\n length = array.length;\n\n while (++index < length) {\n var value = array[index],\n current = iteratee(value);\n\n if (current != null && (computed === undefined\n ? (current === current && !isSymbol(current))\n : comparator(current, computed)\n )) {\n var computed = current,\n result = value;\n }\n }\n return result;\n}\n\nmodule.exports = baseExtremum;\n","var baseEach = require('./_baseEach');\n\n/**\n * The base implementation of `_.filter` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction baseFilter(collection, predicate) {\n var result = [];\n baseEach(collection, function(value, index, collection) {\n if (predicate(value, index, collection)) {\n result.push(value);\n }\n });\n return result;\n}\n\nmodule.exports = baseFilter;\n","/**\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {number} fromIndex The index to search from.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseFindIndex(array, predicate, fromIndex, fromRight) {\n var length = array.length,\n index = fromIndex + (fromRight ? 1 : -1);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (predicate(array[index], index, array)) {\n return index;\n }\n }\n return -1;\n}\n\nmodule.exports = baseFindIndex;\n","var arrayPush = require('./_arrayPush'),\n isFlattenable = require('./_isFlattenable');\n\n/**\n * The base implementation of `_.flatten` with support for restricting flattening.\n *\n * @private\n * @param {Array} array The array to flatten.\n * @param {number} depth The maximum recursion depth.\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\nfunction baseFlatten(array, depth, predicate, isStrict, result) {\n var index = -1,\n length = array.length;\n\n predicate || (predicate = isFlattenable);\n result || (result = []);\n\n while (++index < length) {\n var value = array[index];\n if (depth > 0 && predicate(value)) {\n if (depth > 1) {\n // Recursively flatten arrays (susceptible to call stack limits).\n baseFlatten(value, depth - 1, predicate, isStrict, result);\n } else {\n arrayPush(result, value);\n }\n } else if (!isStrict) {\n result[result.length] = value;\n }\n }\n return result;\n}\n\nmodule.exports = baseFlatten;\n","var createBaseFor = require('./_createBaseFor');\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nmodule.exports = baseFor;\n","var baseFor = require('./_baseFor'),\n keys = require('./keys');\n\n/**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForOwn(object, iteratee) {\n return object && baseFor(object, iteratee, keys);\n}\n\nmodule.exports = baseForOwn;\n","var castPath = require('./_castPath'),\n toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n path = castPath(path, object);\n\n var index = 0,\n length = path.length;\n\n while (object != null && index < length) {\n object = object[toKey(path[index++])];\n }\n return (index && index == length) ? object : undefined;\n}\n\nmodule.exports = baseGet;\n","var arrayPush = require('./_arrayPush'),\n isArray = require('./isArray');\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\nmodule.exports = baseGetAllKeys;\n","var Symbol = require('./_Symbol'),\n getRawTag = require('./_getRawTag'),\n objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\n","/**\n * The base implementation of `_.gt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\n * else `false`.\n */\nfunction baseGt(value, other) {\n return value > other;\n}\n\nmodule.exports = baseGt;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.has` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHas(object, key) {\n return object != null && hasOwnProperty.call(object, key);\n}\n\nmodule.exports = baseHas;\n","/**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHasIn(object, key) {\n return object != null && key in Object(object);\n}\n\nmodule.exports = baseHasIn;\n","var baseFindIndex = require('./_baseFindIndex'),\n baseIsNaN = require('./_baseIsNaN'),\n strictIndexOf = require('./_strictIndexOf');\n\n/**\n * The base implementation of `_.indexOf` without `fromIndex` bounds checks.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseIndexOf(array, value, fromIndex) {\n return value === value\n ? strictIndexOf(array, value, fromIndex)\n : baseFindIndex(array, baseIsNaN, fromIndex);\n}\n\nmodule.exports = baseIndexOf;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nmodule.exports = baseIsArguments;\n","var baseIsEqualDeep = require('./_baseIsEqualDeep'),\n isObjectLike = require('./isObjectLike');\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\nmodule.exports = baseIsEqual;\n","var Stack = require('./_Stack'),\n equalArrays = require('./_equalArrays'),\n equalByTag = require('./_equalByTag'),\n equalObjects = require('./_equalObjects'),\n getTag = require('./_getTag'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isTypedArray = require('./isTypedArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\nmodule.exports = baseIsEqualDeep;\n","var getTag = require('./_getTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]';\n\n/**\n * The base implementation of `_.isMap` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n */\nfunction baseIsMap(value) {\n return isObjectLike(value) && getTag(value) == mapTag;\n}\n\nmodule.exports = baseIsMap;\n","var Stack = require('./_Stack'),\n baseIsEqual = require('./_baseIsEqual');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Array} matchData The property names, values, and compare flags to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n */\nfunction baseIsMatch(object, source, matchData, customizer) {\n var index = matchData.length,\n length = index,\n noCustomizer = !customizer;\n\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (index--) {\n var data = matchData[index];\n if ((noCustomizer && data[2])\n ? data[1] !== object[data[0]]\n : !(data[0] in object)\n ) {\n return false;\n }\n }\n while (++index < length) {\n data = matchData[index];\n var key = data[0],\n objValue = object[key],\n srcValue = data[1];\n\n if (noCustomizer && data[2]) {\n if (objValue === undefined && !(key in object)) {\n return false;\n }\n } else {\n var stack = new Stack;\n if (customizer) {\n var result = customizer(objValue, srcValue, key, object, source, stack);\n }\n if (!(result === undefined\n ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack)\n : result\n )) {\n return false;\n }\n }\n }\n return true;\n}\n\nmodule.exports = baseIsMatch;\n","/**\n * The base implementation of `_.isNaN` without support for number objects.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n */\nfunction baseIsNaN(value) {\n return value !== value;\n}\n\nmodule.exports = baseIsNaN;\n","var isFunction = require('./isFunction'),\n isMasked = require('./_isMasked'),\n isObject = require('./isObject'),\n toSource = require('./_toSource');\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\nmodule.exports = baseIsNative;\n","var getTag = require('./_getTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar setTag = '[object Set]';\n\n/**\n * The base implementation of `_.isSet` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n */\nfunction baseIsSet(value) {\n return isObjectLike(value) && getTag(value) == setTag;\n}\n\nmodule.exports = baseIsSet;\n","var baseGetTag = require('./_baseGetTag'),\n isLength = require('./isLength'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nmodule.exports = baseIsTypedArray;\n","var baseMatches = require('./_baseMatches'),\n baseMatchesProperty = require('./_baseMatchesProperty'),\n identity = require('./identity'),\n isArray = require('./isArray'),\n property = require('./property');\n\n/**\n * The base implementation of `_.iteratee`.\n *\n * @private\n * @param {*} [value=_.identity] The value to convert to an iteratee.\n * @returns {Function} Returns the iteratee.\n */\nfunction baseIteratee(value) {\n // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\n // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\n if (typeof value == 'function') {\n return value;\n }\n if (value == null) {\n return identity;\n }\n if (typeof value == 'object') {\n return isArray(value)\n ? baseMatchesProperty(value[0], value[1])\n : baseMatches(value);\n }\n return property(value);\n}\n\nmodule.exports = baseIteratee;\n","var isPrototype = require('./_isPrototype'),\n nativeKeys = require('./_nativeKeys');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = baseKeys;\n","var isObject = require('./isObject'),\n isPrototype = require('./_isPrototype'),\n nativeKeysIn = require('./_nativeKeysIn');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeysIn(object) {\n if (!isObject(object)) {\n return nativeKeysIn(object);\n }\n var isProto = isPrototype(object),\n result = [];\n\n for (var key in object) {\n if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = baseKeysIn;\n","/**\n * The base implementation of `_.lt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than `other`,\n * else `false`.\n */\nfunction baseLt(value, other) {\n return value < other;\n}\n\nmodule.exports = baseLt;\n","var baseEach = require('./_baseEach'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * The base implementation of `_.map` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction baseMap(collection, iteratee) {\n var index = -1,\n result = isArrayLike(collection) ? Array(collection.length) : [];\n\n baseEach(collection, function(value, key, collection) {\n result[++index] = iteratee(value, key, collection);\n });\n return result;\n}\n\nmodule.exports = baseMap;\n","var baseIsMatch = require('./_baseIsMatch'),\n getMatchData = require('./_getMatchData'),\n matchesStrictComparable = require('./_matchesStrictComparable');\n\n/**\n * The base implementation of `_.matches` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatches(source) {\n var matchData = getMatchData(source);\n if (matchData.length == 1 && matchData[0][2]) {\n return matchesStrictComparable(matchData[0][0], matchData[0][1]);\n }\n return function(object) {\n return object === source || baseIsMatch(object, source, matchData);\n };\n}\n\nmodule.exports = baseMatches;\n","var baseIsEqual = require('./_baseIsEqual'),\n get = require('./get'),\n hasIn = require('./hasIn'),\n isKey = require('./_isKey'),\n isStrictComparable = require('./_isStrictComparable'),\n matchesStrictComparable = require('./_matchesStrictComparable'),\n toKey = require('./_toKey');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\n *\n * @private\n * @param {string} path The path of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatchesProperty(path, srcValue) {\n if (isKey(path) && isStrictComparable(srcValue)) {\n return matchesStrictComparable(toKey(path), srcValue);\n }\n return function(object) {\n var objValue = get(object, path);\n return (objValue === undefined && objValue === srcValue)\n ? hasIn(object, path)\n : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG);\n };\n}\n\nmodule.exports = baseMatchesProperty;\n","var Stack = require('./_Stack'),\n assignMergeValue = require('./_assignMergeValue'),\n baseFor = require('./_baseFor'),\n baseMergeDeep = require('./_baseMergeDeep'),\n isObject = require('./isObject'),\n keysIn = require('./keysIn'),\n safeGet = require('./_safeGet');\n\n/**\n * The base implementation of `_.merge` without support for multiple sources.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n */\nfunction baseMerge(object, source, srcIndex, customizer, stack) {\n if (object === source) {\n return;\n }\n baseFor(source, function(srcValue, key) {\n stack || (stack = new Stack);\n if (isObject(srcValue)) {\n baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\n }\n else {\n var newValue = customizer\n ? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack)\n : undefined;\n\n if (newValue === undefined) {\n newValue = srcValue;\n }\n assignMergeValue(object, key, newValue);\n }\n }, keysIn);\n}\n\nmodule.exports = baseMerge;\n","var assignMergeValue = require('./_assignMergeValue'),\n cloneBuffer = require('./_cloneBuffer'),\n cloneTypedArray = require('./_cloneTypedArray'),\n copyArray = require('./_copyArray'),\n initCloneObject = require('./_initCloneObject'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isArrayLikeObject = require('./isArrayLikeObject'),\n isBuffer = require('./isBuffer'),\n isFunction = require('./isFunction'),\n isObject = require('./isObject'),\n isPlainObject = require('./isPlainObject'),\n isTypedArray = require('./isTypedArray'),\n safeGet = require('./_safeGet'),\n toPlainObject = require('./toPlainObject');\n\n/**\n * A specialized version of `baseMerge` for arrays and objects which performs\n * deep merges and tracks traversed objects enabling objects with circular\n * references to be merged.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {string} key The key of the value to merge.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n */\nfunction baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n var objValue = safeGet(object, key),\n srcValue = safeGet(source, key),\n stacked = stack.get(srcValue);\n\n if (stacked) {\n assignMergeValue(object, key, stacked);\n return;\n }\n var newValue = customizer\n ? customizer(objValue, srcValue, (key + ''), object, source, stack)\n : undefined;\n\n var isCommon = newValue === undefined;\n\n if (isCommon) {\n var isArr = isArray(srcValue),\n isBuff = !isArr && isBuffer(srcValue),\n isTyped = !isArr && !isBuff && isTypedArray(srcValue);\n\n newValue = srcValue;\n if (isArr || isBuff || isTyped) {\n if (isArray(objValue)) {\n newValue = objValue;\n }\n else if (isArrayLikeObject(objValue)) {\n newValue = copyArray(objValue);\n }\n else if (isBuff) {\n isCommon = false;\n newValue = cloneBuffer(srcValue, true);\n }\n else if (isTyped) {\n isCommon = false;\n newValue = cloneTypedArray(srcValue, true);\n }\n else {\n newValue = [];\n }\n }\n else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n newValue = objValue;\n if (isArguments(objValue)) {\n newValue = toPlainObject(objValue);\n }\n else if (!isObject(objValue) || isFunction(objValue)) {\n newValue = initCloneObject(srcValue);\n }\n }\n else {\n isCommon = false;\n }\n }\n if (isCommon) {\n // Recursively merge objects and arrays (susceptible to call stack limits).\n stack.set(srcValue, newValue);\n mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n stack['delete'](srcValue);\n }\n assignMergeValue(object, key, newValue);\n}\n\nmodule.exports = baseMergeDeep;\n","var arrayMap = require('./_arrayMap'),\n baseGet = require('./_baseGet'),\n baseIteratee = require('./_baseIteratee'),\n baseMap = require('./_baseMap'),\n baseSortBy = require('./_baseSortBy'),\n baseUnary = require('./_baseUnary'),\n compareMultiple = require('./_compareMultiple'),\n identity = require('./identity'),\n isArray = require('./isArray');\n\n/**\n * The base implementation of `_.orderBy` without param guards.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by.\n * @param {string[]} orders The sort orders of `iteratees`.\n * @returns {Array} Returns the new sorted array.\n */\nfunction baseOrderBy(collection, iteratees, orders) {\n if (iteratees.length) {\n iteratees = arrayMap(iteratees, function(iteratee) {\n if (isArray(iteratee)) {\n return function(value) {\n return baseGet(value, iteratee.length === 1 ? iteratee[0] : iteratee);\n }\n }\n return iteratee;\n });\n } else {\n iteratees = [identity];\n }\n\n var index = -1;\n iteratees = arrayMap(iteratees, baseUnary(baseIteratee));\n\n var result = baseMap(collection, function(value, key, collection) {\n var criteria = arrayMap(iteratees, function(iteratee) {\n return iteratee(value);\n });\n return { 'criteria': criteria, 'index': ++index, 'value': value };\n });\n\n return baseSortBy(result, function(object, other) {\n return compareMultiple(object, other, orders);\n });\n}\n\nmodule.exports = baseOrderBy;\n","var basePickBy = require('./_basePickBy'),\n hasIn = require('./hasIn');\n\n/**\n * The base implementation of `_.pick` without support for individual\n * property identifiers.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @returns {Object} Returns the new object.\n */\nfunction basePick(object, paths) {\n return basePickBy(object, paths, function(value, path) {\n return hasIn(object, path);\n });\n}\n\nmodule.exports = basePick;\n","var baseGet = require('./_baseGet'),\n baseSet = require('./_baseSet'),\n castPath = require('./_castPath');\n\n/**\n * The base implementation of `_.pickBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @param {Function} predicate The function invoked per property.\n * @returns {Object} Returns the new object.\n */\nfunction basePickBy(object, paths, predicate) {\n var index = -1,\n length = paths.length,\n result = {};\n\n while (++index < length) {\n var path = paths[index],\n value = baseGet(object, path);\n\n if (predicate(value, path)) {\n baseSet(result, castPath(path, object), value);\n }\n }\n return result;\n}\n\nmodule.exports = basePickBy;\n","/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction baseProperty(key) {\n return function(object) {\n return object == null ? undefined : object[key];\n };\n}\n\nmodule.exports = baseProperty;\n","var baseGet = require('./_baseGet');\n\n/**\n * A specialized version of `baseProperty` which supports deep paths.\n *\n * @private\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction basePropertyDeep(path) {\n return function(object) {\n return baseGet(object, path);\n };\n}\n\nmodule.exports = basePropertyDeep;\n","/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeCeil = Math.ceil,\n nativeMax = Math.max;\n\n/**\n * The base implementation of `_.range` and `_.rangeRight` which doesn't\n * coerce arguments.\n *\n * @private\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @param {number} step The value to increment or decrement by.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the range of numbers.\n */\nfunction baseRange(start, end, step, fromRight) {\n var index = -1,\n length = nativeMax(nativeCeil((end - start) / (step || 1)), 0),\n result = Array(length);\n\n while (length--) {\n result[fromRight ? length : ++index] = start;\n start += step;\n }\n return result;\n}\n\nmodule.exports = baseRange;\n","/**\n * The base implementation of `_.reduce` and `_.reduceRight`, without support\n * for iteratee shorthands, which iterates over `collection` using `eachFunc`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} accumulator The initial value.\n * @param {boolean} initAccum Specify using the first or last element of\n * `collection` as the initial value.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @returns {*} Returns the accumulated value.\n */\nfunction baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) {\n eachFunc(collection, function(value, index, collection) {\n accumulator = initAccum\n ? (initAccum = false, value)\n : iteratee(accumulator, value, index, collection);\n });\n return accumulator;\n}\n\nmodule.exports = baseReduce;\n","var identity = require('./identity'),\n overRest = require('./_overRest'),\n setToString = require('./_setToString');\n\n/**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\nfunction baseRest(func, start) {\n return setToString(overRest(func, start, identity), func + '');\n}\n\nmodule.exports = baseRest;\n","var assignValue = require('./_assignValue'),\n castPath = require('./_castPath'),\n isIndex = require('./_isIndex'),\n isObject = require('./isObject'),\n toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\nfunction baseSet(object, path, value, customizer) {\n if (!isObject(object)) {\n return object;\n }\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n lastIndex = length - 1,\n nested = object;\n\n while (nested != null && ++index < length) {\n var key = toKey(path[index]),\n newValue = value;\n\n if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n return object;\n }\n\n if (index != lastIndex) {\n var objValue = nested[key];\n newValue = customizer ? customizer(objValue, key, nested) : undefined;\n if (newValue === undefined) {\n newValue = isObject(objValue)\n ? objValue\n : (isIndex(path[index + 1]) ? [] : {});\n }\n }\n assignValue(nested, key, newValue);\n nested = nested[key];\n }\n return object;\n}\n\nmodule.exports = baseSet;\n","var constant = require('./constant'),\n defineProperty = require('./_defineProperty'),\n identity = require('./identity');\n\n/**\n * The base implementation of `setToString` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar baseSetToString = !defineProperty ? identity : function(func, string) {\n return defineProperty(func, 'toString', {\n 'configurable': true,\n 'enumerable': false,\n 'value': constant(string),\n 'writable': true\n });\n};\n\nmodule.exports = baseSetToString;\n","/**\n * The base implementation of `_.sortBy` which uses `comparer` to define the\n * sort order of `array` and replaces criteria objects with their corresponding\n * values.\n *\n * @private\n * @param {Array} array The array to sort.\n * @param {Function} comparer The function to define sort order.\n * @returns {Array} Returns `array`.\n */\nfunction baseSortBy(array, comparer) {\n var length = array.length;\n\n array.sort(comparer);\n while (length--) {\n array[length] = array[length].value;\n }\n return array;\n}\n\nmodule.exports = baseSortBy;\n","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\nmodule.exports = baseTimes;\n","var Symbol = require('./_Symbol'),\n arrayMap = require('./_arrayMap'),\n isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = baseToString;\n","var trimmedEndIndex = require('./_trimmedEndIndex');\n\n/** Used to match leading whitespace. */\nvar reTrimStart = /^\\s+/;\n\n/**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\nfunction baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n}\n\nmodule.exports = baseTrim;\n","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\nmodule.exports = baseUnary;\n","var SetCache = require('./_SetCache'),\n arrayIncludes = require('./_arrayIncludes'),\n arrayIncludesWith = require('./_arrayIncludesWith'),\n cacheHas = require('./_cacheHas'),\n createSet = require('./_createSet'),\n setToArray = require('./_setToArray');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * The base implementation of `_.uniqBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n */\nfunction baseUniq(array, iteratee, comparator) {\n var index = -1,\n includes = arrayIncludes,\n length = array.length,\n isCommon = true,\n result = [],\n seen = result;\n\n if (comparator) {\n isCommon = false;\n includes = arrayIncludesWith;\n }\n else if (length >= LARGE_ARRAY_SIZE) {\n var set = iteratee ? null : createSet(array);\n if (set) {\n return setToArray(set);\n }\n isCommon = false;\n includes = cacheHas;\n seen = new SetCache;\n }\n else {\n seen = iteratee ? [] : result;\n }\n outer:\n while (++index < length) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n value = (comparator || value !== 0) ? value : 0;\n if (isCommon && computed === computed) {\n var seenIndex = seen.length;\n while (seenIndex--) {\n if (seen[seenIndex] === computed) {\n continue outer;\n }\n }\n if (iteratee) {\n seen.push(computed);\n }\n result.push(value);\n }\n else if (!includes(seen, computed, comparator)) {\n if (seen !== result) {\n seen.push(computed);\n }\n result.push(value);\n }\n }\n return result;\n}\n\nmodule.exports = baseUniq;\n","var arrayMap = require('./_arrayMap');\n\n/**\n * The base implementation of `_.values` and `_.valuesIn` which creates an\n * array of `object` property values corresponding to the property names\n * of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the array of property values.\n */\nfunction baseValues(object, props) {\n return arrayMap(props, function(key) {\n return object[key];\n });\n}\n\nmodule.exports = baseValues;\n","/**\n * This base implementation of `_.zipObject` which assigns values using `assignFunc`.\n *\n * @private\n * @param {Array} props The property identifiers.\n * @param {Array} values The property values.\n * @param {Function} assignFunc The function to assign values.\n * @returns {Object} Returns the new object.\n */\nfunction baseZipObject(props, values, assignFunc) {\n var index = -1,\n length = props.length,\n valsLength = values.length,\n result = {};\n\n while (++index < length) {\n var value = index < valsLength ? values[index] : undefined;\n assignFunc(result, props[index], value);\n }\n return result;\n}\n\nmodule.exports = baseZipObject;\n","/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\nmodule.exports = cacheHas;\n","var identity = require('./identity');\n\n/**\n * Casts `value` to `identity` if it's not a function.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Function} Returns cast function.\n */\nfunction castFunction(value) {\n return typeof value == 'function' ? value : identity;\n}\n\nmodule.exports = castFunction;\n","var isArray = require('./isArray'),\n isKey = require('./_isKey'),\n stringToPath = require('./_stringToPath'),\n toString = require('./toString');\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nmodule.exports = castPath;\n","var Uint8Array = require('./_Uint8Array');\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n return result;\n}\n\nmodule.exports = cloneArrayBuffer;\n","var root = require('./_root');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined;\n\n/**\n * Creates a clone of `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n if (isDeep) {\n return buffer.slice();\n }\n var length = buffer.length,\n result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n buffer.copy(result);\n return result;\n}\n\nmodule.exports = cloneBuffer;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\nfunction cloneDataView(dataView, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n}\n\nmodule.exports = cloneDataView;\n","/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\nfunction cloneRegExp(regexp) {\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n result.lastIndex = regexp.lastIndex;\n return result;\n}\n\nmodule.exports = cloneRegExp;\n","var Symbol = require('./_Symbol');\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\nfunction cloneSymbol(symbol) {\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\nmodule.exports = cloneSymbol;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nmodule.exports = cloneTypedArray;\n","var isSymbol = require('./isSymbol');\n\n/**\n * Compares values to sort them in ascending order.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {number} Returns the sort order indicator for `value`.\n */\nfunction compareAscending(value, other) {\n if (value !== other) {\n var valIsDefined = value !== undefined,\n valIsNull = value === null,\n valIsReflexive = value === value,\n valIsSymbol = isSymbol(value);\n\n var othIsDefined = other !== undefined,\n othIsNull = other === null,\n othIsReflexive = other === other,\n othIsSymbol = isSymbol(other);\n\n if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) ||\n (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) ||\n (valIsNull && othIsDefined && othIsReflexive) ||\n (!valIsDefined && othIsReflexive) ||\n !valIsReflexive) {\n return 1;\n }\n if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) ||\n (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) ||\n (othIsNull && valIsDefined && valIsReflexive) ||\n (!othIsDefined && valIsReflexive) ||\n !othIsReflexive) {\n return -1;\n }\n }\n return 0;\n}\n\nmodule.exports = compareAscending;\n","var compareAscending = require('./_compareAscending');\n\n/**\n * Used by `_.orderBy` to compare multiple properties of a value to another\n * and stable sort them.\n *\n * If `orders` is unspecified, all values are sorted in ascending order. Otherwise,\n * specify an order of \"desc\" for descending or \"asc\" for ascending sort order\n * of corresponding values.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {boolean[]|string[]} orders The order to sort by for each property.\n * @returns {number} Returns the sort order indicator for `object`.\n */\nfunction compareMultiple(object, other, orders) {\n var index = -1,\n objCriteria = object.criteria,\n othCriteria = other.criteria,\n length = objCriteria.length,\n ordersLength = orders.length;\n\n while (++index < length) {\n var result = compareAscending(objCriteria[index], othCriteria[index]);\n if (result) {\n if (index >= ordersLength) {\n return result;\n }\n var order = orders[index];\n return result * (order == 'desc' ? -1 : 1);\n }\n }\n // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications\n // that causes it, under certain circumstances, to provide the same value for\n // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247\n // for more details.\n //\n // This also ensures a stable sort in V8 and other engines.\n // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details.\n return object.index - other.index;\n}\n\nmodule.exports = compareMultiple;\n","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n var index = -1,\n length = source.length;\n\n array || (array = Array(length));\n while (++index < length) {\n array[index] = source[index];\n }\n return array;\n}\n\nmodule.exports = copyArray;\n","var assignValue = require('./_assignValue'),\n baseAssignValue = require('./_baseAssignValue');\n\n/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object, customizer) {\n var isNew = !object;\n object || (object = {});\n\n var index = -1,\n length = props.length;\n\n while (++index < length) {\n var key = props[index];\n\n var newValue = customizer\n ? customizer(object[key], source[key], key, object, source)\n : undefined;\n\n if (newValue === undefined) {\n newValue = source[key];\n }\n if (isNew) {\n baseAssignValue(object, key, newValue);\n } else {\n assignValue(object, key, newValue);\n }\n }\n return object;\n}\n\nmodule.exports = copyObject;\n","var copyObject = require('./_copyObject'),\n getSymbols = require('./_getSymbols');\n\n/**\n * Copies own symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbols(source, object) {\n return copyObject(source, getSymbols(source), object);\n}\n\nmodule.exports = copySymbols;\n","var copyObject = require('./_copyObject'),\n getSymbolsIn = require('./_getSymbolsIn');\n\n/**\n * Copies own and inherited symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbolsIn(source, object) {\n return copyObject(source, getSymbolsIn(source), object);\n}\n\nmodule.exports = copySymbolsIn;\n","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\n","var baseRest = require('./_baseRest'),\n isIterateeCall = require('./_isIterateeCall');\n\n/**\n * Creates a function like `_.assign`.\n *\n * @private\n * @param {Function} assigner The function to assign values.\n * @returns {Function} Returns the new assigner function.\n */\nfunction createAssigner(assigner) {\n return baseRest(function(object, sources) {\n var index = -1,\n length = sources.length,\n customizer = length > 1 ? sources[length - 1] : undefined,\n guard = length > 2 ? sources[2] : undefined;\n\n customizer = (assigner.length > 3 && typeof customizer == 'function')\n ? (length--, customizer)\n : undefined;\n\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n customizer = length < 3 ? undefined : customizer;\n length = 1;\n }\n object = Object(object);\n while (++index < length) {\n var source = sources[index];\n if (source) {\n assigner(object, source, index, customizer);\n }\n }\n return object;\n });\n}\n\nmodule.exports = createAssigner;\n","var isArrayLike = require('./isArrayLike');\n\n/**\n * Creates a `baseEach` or `baseEachRight` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseEach(eachFunc, fromRight) {\n return function(collection, iteratee) {\n if (collection == null) {\n return collection;\n }\n if (!isArrayLike(collection)) {\n return eachFunc(collection, iteratee);\n }\n var length = collection.length,\n index = fromRight ? length : -1,\n iterable = Object(collection);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (iteratee(iterable[index], index, iterable) === false) {\n break;\n }\n }\n return collection;\n };\n}\n\nmodule.exports = createBaseEach;\n","/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n return function(object, iteratee, keysFunc) {\n var index = -1,\n iterable = Object(object),\n props = keysFunc(object),\n length = props.length;\n\n while (length--) {\n var key = props[fromRight ? length : ++index];\n if (iteratee(iterable[key], key, iterable) === false) {\n break;\n }\n }\n return object;\n };\n}\n\nmodule.exports = createBaseFor;\n","var baseIteratee = require('./_baseIteratee'),\n isArrayLike = require('./isArrayLike'),\n keys = require('./keys');\n\n/**\n * Creates a `_.find` or `_.findLast` function.\n *\n * @private\n * @param {Function} findIndexFunc The function to find the collection index.\n * @returns {Function} Returns the new find function.\n */\nfunction createFind(findIndexFunc) {\n return function(collection, predicate, fromIndex) {\n var iterable = Object(collection);\n if (!isArrayLike(collection)) {\n var iteratee = baseIteratee(predicate, 3);\n collection = keys(collection);\n predicate = function(key) { return iteratee(iterable[key], key, iterable); };\n }\n var index = findIndexFunc(collection, predicate, fromIndex);\n return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined;\n };\n}\n\nmodule.exports = createFind;\n","var baseRange = require('./_baseRange'),\n isIterateeCall = require('./_isIterateeCall'),\n toFinite = require('./toFinite');\n\n/**\n * Creates a `_.range` or `_.rangeRight` function.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new range function.\n */\nfunction createRange(fromRight) {\n return function(start, end, step) {\n if (step && typeof step != 'number' && isIterateeCall(start, end, step)) {\n end = step = undefined;\n }\n // Ensure the sign of `-0` is preserved.\n start = toFinite(start);\n if (end === undefined) {\n end = start;\n start = 0;\n } else {\n end = toFinite(end);\n }\n step = step === undefined ? (start < end ? 1 : -1) : toFinite(step);\n return baseRange(start, end, step, fromRight);\n };\n}\n\nmodule.exports = createRange;\n","var Set = require('./_Set'),\n noop = require('./noop'),\n setToArray = require('./_setToArray');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Creates a set object of `values`.\n *\n * @private\n * @param {Array} values The values to add to the set.\n * @returns {Object} Returns the new set.\n */\nvar createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) {\n return new Set(values);\n};\n\nmodule.exports = createSet;\n","var getNative = require('./_getNative');\n\nvar defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n}());\n\nmodule.exports = defineProperty;\n","var SetCache = require('./_SetCache'),\n arraySome = require('./_arraySome'),\n cacheHas = require('./_cacheHas');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Check that cyclic values are equal.\n var arrStacked = stack.get(array);\n var othStacked = stack.get(other);\n if (arrStacked && othStacked) {\n return arrStacked == other && othStacked == array;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\nmodule.exports = equalArrays;\n","var Symbol = require('./_Symbol'),\n Uint8Array = require('./_Uint8Array'),\n eq = require('./eq'),\n equalArrays = require('./_equalArrays'),\n mapToArray = require('./_mapToArray'),\n setToArray = require('./_setToArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\nmodule.exports = equalByTag;\n","var getAllKeys = require('./_getAllKeys');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Check that cyclic values are equal.\n var objStacked = stack.get(object);\n var othStacked = stack.get(other);\n if (objStacked && othStacked) {\n return objStacked == other && othStacked == object;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\nmodule.exports = equalObjects;\n","var flatten = require('./flatten'),\n overRest = require('./_overRest'),\n setToString = require('./_setToString');\n\n/**\n * A specialized version of `baseRest` which flattens the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\nfunction flatRest(func) {\n return setToString(overRest(func, undefined, flatten), func + '');\n}\n\nmodule.exports = flatRest;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbols = require('./_getSymbols'),\n keys = require('./keys');\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\nmodule.exports = getAllKeys;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbolsIn = require('./_getSymbolsIn'),\n keysIn = require('./keysIn');\n\n/**\n * Creates an array of own and inherited enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeysIn(object) {\n return baseGetAllKeys(object, keysIn, getSymbolsIn);\n}\n\nmodule.exports = getAllKeysIn;\n","var isKeyable = require('./_isKeyable');\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\nmodule.exports = getMapData;\n","var isStrictComparable = require('./_isStrictComparable'),\n keys = require('./keys');\n\n/**\n * Gets the property names, values, and compare flags of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the match data of `object`.\n */\nfunction getMatchData(object) {\n var result = keys(object),\n length = result.length;\n\n while (length--) {\n var key = result[length],\n value = object[key];\n\n result[length] = [key, value, isStrictComparable(value)];\n }\n return result;\n}\n\nmodule.exports = getMatchData;\n","var baseIsNative = require('./_baseIsNative'),\n getValue = require('./_getValue');\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n","var overArg = require('./_overArg');\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nmodule.exports = getPrototype;\n","var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nmodule.exports = getRawTag;\n","var arrayFilter = require('./_arrayFilter'),\n stubArray = require('./stubArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\nmodule.exports = getSymbols;\n","var arrayPush = require('./_arrayPush'),\n getPrototype = require('./_getPrototype'),\n getSymbols = require('./_getSymbols'),\n stubArray = require('./stubArray');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own and inherited enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\n var result = [];\n while (object) {\n arrayPush(result, getSymbols(object));\n object = getPrototype(object);\n }\n return result;\n};\n\nmodule.exports = getSymbolsIn;\n","var DataView = require('./_DataView'),\n Map = require('./_Map'),\n Promise = require('./_Promise'),\n Set = require('./_Set'),\n WeakMap = require('./_WeakMap'),\n baseGetTag = require('./_baseGetTag'),\n toSource = require('./_toSource');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n setTag = '[object Set]',\n weakMapTag = '[object WeakMap]';\n\nvar dataViewTag = '[object DataView]';\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\nmodule.exports = getTag;\n","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\nmodule.exports = getValue;\n","var castPath = require('./_castPath'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isIndex = require('./_isIndex'),\n isLength = require('./isLength'),\n toKey = require('./_toKey');\n\n/**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\nfunction hasPath(object, path, hasFunc) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n result = false;\n\n while (++index < length) {\n var key = toKey(path[index]);\n if (!(result = object != null && hasFunc(object, key))) {\n break;\n }\n object = object[key];\n }\n if (result || ++index != length) {\n return result;\n }\n length = object == null ? 0 : object.length;\n return !!length && isLength(length) && isIndex(key, length) &&\n (isArray(object) || isArguments(object));\n}\n\nmodule.exports = hasPath;\n","/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsZWJ = '\\\\u200d';\n\n/** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */\nvar reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboRange + rsVarRange + ']');\n\n/**\n * Checks if `string` contains Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a symbol is found, else `false`.\n */\nfunction hasUnicode(string) {\n return reHasUnicode.test(string);\n}\n\nmodule.exports = hasUnicode;\n","var nativeCreate = require('./_nativeCreate');\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\nmodule.exports = hashClear;\n","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = hashDelete;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nmodule.exports = hashGet;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nmodule.exports = hashHas;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\nmodule.exports = hashSet;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n var length = array.length,\n result = new array.constructor(length);\n\n // Add properties assigned by `RegExp#exec`.\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n result.index = array.index;\n result.input = array.input;\n }\n return result;\n}\n\nmodule.exports = initCloneArray;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer'),\n cloneDataView = require('./_cloneDataView'),\n cloneRegExp = require('./_cloneRegExp'),\n cloneSymbol = require('./_cloneSymbol'),\n cloneTypedArray = require('./_cloneTypedArray');\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, isDeep) {\n var Ctor = object.constructor;\n switch (tag) {\n case arrayBufferTag:\n return cloneArrayBuffer(object);\n\n case boolTag:\n case dateTag:\n return new Ctor(+object);\n\n case dataViewTag:\n return cloneDataView(object, isDeep);\n\n case float32Tag: case float64Tag:\n case int8Tag: case int16Tag: case int32Tag:\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n return cloneTypedArray(object, isDeep);\n\n case mapTag:\n return new Ctor;\n\n case numberTag:\n case stringTag:\n return new Ctor(object);\n\n case regexpTag:\n return cloneRegExp(object);\n\n case setTag:\n return new Ctor;\n\n case symbolTag:\n return cloneSymbol(object);\n }\n}\n\nmodule.exports = initCloneByTag;\n","var baseCreate = require('./_baseCreate'),\n getPrototype = require('./_getPrototype'),\n isPrototype = require('./_isPrototype');\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n}\n\nmodule.exports = initCloneObject;\n","var Symbol = require('./_Symbol'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray');\n\n/** Built-in value references. */\nvar spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined;\n\n/**\n * Checks if `value` is a flattenable `arguments` object or array.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\n */\nfunction isFlattenable(value) {\n return isArray(value) || isArguments(value) ||\n !!(spreadableSymbol && value && value[spreadableSymbol]);\n}\n\nmodule.exports = isFlattenable;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nmodule.exports = isIndex;\n","var eq = require('./eq'),\n isArrayLike = require('./isArrayLike'),\n isIndex = require('./_isIndex'),\n isObject = require('./isObject');\n\n/**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n * else `false`.\n */\nfunction isIterateeCall(value, index, object) {\n if (!isObject(object)) {\n return false;\n }\n var type = typeof index;\n if (type == 'number'\n ? (isArrayLike(object) && isIndex(index, object.length))\n : (type == 'string' && index in object)\n ) {\n return eq(object[index], value);\n }\n return false;\n}\n\nmodule.exports = isIterateeCall;\n","var isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n}\n\nmodule.exports = isKey;\n","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\nmodule.exports = isKeyable;\n","var coreJsData = require('./_coreJsData');\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\nmodule.exports = isMasked;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\nmodule.exports = isPrototype;\n","var isObject = require('./isObject');\n\n/**\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` if suitable for strict\n * equality comparisons, else `false`.\n */\nfunction isStrictComparable(value) {\n return value === value && !isObject(value);\n}\n\nmodule.exports = isStrictComparable;\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\nmodule.exports = listCacheClear;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\nmodule.exports = listCacheDelete;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\nmodule.exports = listCacheGet;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\nmodule.exports = listCacheHas;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\nmodule.exports = listCacheSet;\n","var Hash = require('./_Hash'),\n ListCache = require('./_ListCache'),\n Map = require('./_Map');\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\nmodule.exports = mapCacheClear;\n","var getMapData = require('./_getMapData');\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = mapCacheDelete;\n","var getMapData = require('./_getMapData');\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\nmodule.exports = mapCacheGet;\n","var getMapData = require('./_getMapData');\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\nmodule.exports = mapCacheHas;\n","var getMapData = require('./_getMapData');\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\nmodule.exports = mapCacheSet;\n","/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\nmodule.exports = mapToArray;\n","/**\n * A specialized version of `matchesProperty` for source values suitable\n * for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction matchesStrictComparable(key, srcValue) {\n return function(object) {\n if (object == null) {\n return false;\n }\n return object[key] === srcValue &&\n (srcValue !== undefined || (key in Object(object)));\n };\n}\n\nmodule.exports = matchesStrictComparable;\n","var memoize = require('./memoize');\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n}\n\nmodule.exports = memoizeCapped;\n","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n","var overArg = require('./_overArg');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nmodule.exports = nativeKeys;\n","/**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction nativeKeysIn(object) {\n var result = [];\n if (object != null) {\n for (var key in Object(object)) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = nativeKeysIn;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\nmodule.exports = nodeUtil;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\nmodule.exports = overArg;\n","var apply = require('./_apply');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * A specialized version of `baseRest` which transforms the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @param {Function} transform The rest array transform.\n * @returns {Function} Returns the new function.\n */\nfunction overRest(func, start, transform) {\n start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n return function() {\n var args = arguments,\n index = -1,\n length = nativeMax(args.length - start, 0),\n array = Array(length);\n\n while (++index < length) {\n array[index] = args[start + index];\n }\n index = -1;\n var otherArgs = Array(start + 1);\n while (++index < start) {\n otherArgs[index] = args[index];\n }\n otherArgs[start] = transform(array);\n return apply(func, this, otherArgs);\n };\n}\n\nmodule.exports = overRest;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n","/**\n * Gets the value at `key`, unless `key` is \"__proto__\" or \"constructor\".\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction safeGet(object, key) {\n if (key === 'constructor' && typeof object[key] === 'function') {\n return;\n }\n\n if (key == '__proto__') {\n return;\n }\n\n return object[key];\n}\n\nmodule.exports = safeGet;\n","/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\nmodule.exports = setCacheAdd;\n","/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\nmodule.exports = setCacheHas;\n","/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\nmodule.exports = setToArray;\n","var baseSetToString = require('./_baseSetToString'),\n shortOut = require('./_shortOut');\n\n/**\n * Sets the `toString` method of `func` to return `string`.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar setToString = shortOut(baseSetToString);\n\nmodule.exports = setToString;\n","/** Used to detect hot functions by number of calls within a span of milliseconds. */\nvar HOT_COUNT = 800,\n HOT_SPAN = 16;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeNow = Date.now;\n\n/**\n * Creates a function that'll short out and invoke `identity` instead\n * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`\n * milliseconds.\n *\n * @private\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new shortable function.\n */\nfunction shortOut(func) {\n var count = 0,\n lastCalled = 0;\n\n return function() {\n var stamp = nativeNow(),\n remaining = HOT_SPAN - (stamp - lastCalled);\n\n lastCalled = stamp;\n if (remaining > 0) {\n if (++count >= HOT_COUNT) {\n return arguments[0];\n }\n } else {\n count = 0;\n }\n return func.apply(undefined, arguments);\n };\n}\n\nmodule.exports = shortOut;\n","var ListCache = require('./_ListCache');\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\nmodule.exports = stackClear;\n","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\nmodule.exports = stackDelete;\n","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\nmodule.exports = stackGet;\n","/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\nmodule.exports = stackHas;\n","var ListCache = require('./_ListCache'),\n Map = require('./_Map'),\n MapCache = require('./_MapCache');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\nmodule.exports = stackSet;\n","/**\n * A specialized version of `_.indexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction strictIndexOf(array, value, fromIndex) {\n var index = fromIndex - 1,\n length = array.length;\n\n while (++index < length) {\n if (array[index] === value) {\n return index;\n }\n }\n return -1;\n}\n\nmodule.exports = strictIndexOf;\n","var asciiSize = require('./_asciiSize'),\n hasUnicode = require('./_hasUnicode'),\n unicodeSize = require('./_unicodeSize');\n\n/**\n * Gets the number of symbols in `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the string size.\n */\nfunction stringSize(string) {\n return hasUnicode(string)\n ? unicodeSize(string)\n : asciiSize(string);\n}\n\nmodule.exports = stringSize;\n","var memoizeCapped = require('./_memoizeCapped');\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n});\n\nmodule.exports = stringToPath;\n","var isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = toKey;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\nmodule.exports = toSource;\n","/** Used to match a single whitespace character. */\nvar reWhitespace = /\\s/;\n\n/**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\nfunction trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n}\n\nmodule.exports = trimmedEndIndex;\n","/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsAstral = '[' + rsAstralRange + ']',\n rsCombo = '[' + rsComboRange + ']',\n rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n rsNonAstral = '[^' + rsAstralRange + ']',\n rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n rsZWJ = '\\\\u200d';\n\n/** Used to compose unicode regexes. */\nvar reOptMod = rsModifier + '?',\n rsOptVar = '[' + rsVarRange + ']?',\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\n rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\n/** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\nvar reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n\n/**\n * Gets the size of a Unicode `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\nfunction unicodeSize(string) {\n var result = reUnicode.lastIndex = 0;\n while (reUnicode.test(string)) {\n ++result;\n }\n return result;\n}\n\nmodule.exports = unicodeSize;\n","var baseClone = require('./_baseClone');\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * Creates a shallow clone of `value`.\n *\n * **Note:** This method is loosely based on the\n * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)\n * and supports cloning arrays, array buffers, booleans, date objects, maps,\n * numbers, `Object` objects, regexes, sets, strings, symbols, and typed\n * arrays. The own enumerable properties of `arguments` objects are cloned\n * as plain objects. An empty object is returned for uncloneable values such\n * as error objects, functions, DOM nodes, and WeakMaps.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to clone.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeep\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var shallow = _.clone(objects);\n * console.log(shallow[0] === objects[0]);\n * // => true\n */\nfunction clone(value) {\n return baseClone(value, CLONE_SYMBOLS_FLAG);\n}\n\nmodule.exports = clone;\n","var baseClone = require('./_baseClone');\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * This method is like `_.clone` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @returns {*} Returns the deep cloned value.\n * @see _.clone\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var deep = _.cloneDeep(objects);\n * console.log(deep[0] === objects[0]);\n * // => false\n */\nfunction cloneDeep(value) {\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\n}\n\nmodule.exports = cloneDeep;\n","/**\n * Creates a function that returns `value`.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {*} value The value to return from the new function.\n * @returns {Function} Returns the new constant function.\n * @example\n *\n * var objects = _.times(2, _.constant({ 'a': 1 }));\n *\n * console.log(objects);\n * // => [{ 'a': 1 }, { 'a': 1 }]\n *\n * console.log(objects[0] === objects[1]);\n * // => true\n */\nfunction constant(value) {\n return function() {\n return value;\n };\n}\n\nmodule.exports = constant;\n","var baseRest = require('./_baseRest'),\n eq = require('./eq'),\n isIterateeCall = require('./_isIterateeCall'),\n keysIn = require('./keysIn');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns own and inherited enumerable string keyed properties of source\n * objects to the destination object for all destination properties that\n * resolve to `undefined`. Source objects are applied from left to right.\n * Once a property is set, additional values of the same property are ignored.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.defaultsDeep\n * @example\n *\n * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\nvar defaults = baseRest(function(object, sources) {\n object = Object(object);\n\n var index = -1;\n var length = sources.length;\n var guard = length > 2 ? sources[2] : undefined;\n\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n length = 1;\n }\n\n while (++index < length) {\n var source = sources[index];\n var props = keysIn(source);\n var propsIndex = -1;\n var propsLength = props.length;\n\n while (++propsIndex < propsLength) {\n var key = props[propsIndex];\n var value = object[key];\n\n if (value === undefined ||\n (eq(value, objectProto[key]) && !hasOwnProperty.call(object, key))) {\n object[key] = source[key];\n }\n }\n }\n\n return object;\n});\n\nmodule.exports = defaults;\n","module.exports = require('./forEach');\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n","var arrayFilter = require('./_arrayFilter'),\n baseFilter = require('./_baseFilter'),\n baseIteratee = require('./_baseIteratee'),\n isArray = require('./isArray');\n\n/**\n * Iterates over elements of `collection`, returning an array of all elements\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * **Note:** Unlike `_.remove`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.reject\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false }\n * ];\n *\n * _.filter(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.filter(users, { 'age': 36, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.filter(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.filter(users, 'active');\n * // => objects for ['barney']\n *\n * // Combining several predicates using `_.overEvery` or `_.overSome`.\n * _.filter(users, _.overSome([{ 'age': 36 }, ['age', 40]]));\n * // => objects for ['fred', 'barney']\n */\nfunction filter(collection, predicate) {\n var func = isArray(collection) ? arrayFilter : baseFilter;\n return func(collection, baseIteratee(predicate, 3));\n}\n\nmodule.exports = filter;\n","var createFind = require('./_createFind'),\n findIndex = require('./findIndex');\n\n/**\n * Iterates over elements of `collection`, returning the first element\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false },\n * { 'user': 'pebbles', 'age': 1, 'active': true }\n * ];\n *\n * _.find(users, function(o) { return o.age < 40; });\n * // => object for 'barney'\n *\n * // The `_.matches` iteratee shorthand.\n * _.find(users, { 'age': 1, 'active': true });\n * // => object for 'pebbles'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.find(users, ['active', false]);\n * // => object for 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.find(users, 'active');\n * // => object for 'barney'\n */\nvar find = createFind(findIndex);\n\nmodule.exports = find;\n","var baseFindIndex = require('./_baseFindIndex'),\n baseIteratee = require('./_baseIteratee'),\n toInteger = require('./toInteger');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * This method is like `_.find` except that it returns the index of the first\n * element `predicate` returns truthy for instead of the element itself.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.findIndex(users, function(o) { return o.user == 'barney'; });\n * // => 0\n *\n * // The `_.matches` iteratee shorthand.\n * _.findIndex(users, { 'user': 'fred', 'active': false });\n * // => 1\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findIndex(users, ['active', false]);\n * // => 0\n *\n * // The `_.property` iteratee shorthand.\n * _.findIndex(users, 'active');\n * // => 2\n */\nfunction findIndex(array, predicate, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\n if (index < 0) {\n index = nativeMax(length + index, 0);\n }\n return baseFindIndex(array, baseIteratee(predicate, 3), index);\n}\n\nmodule.exports = findIndex;\n","var baseFlatten = require('./_baseFlatten');\n\n/**\n * Flattens `array` a single level deep.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flatten([1, [2, [3, [4]], 5]]);\n * // => [1, 2, [3, [4]], 5]\n */\nfunction flatten(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseFlatten(array, 1) : [];\n}\n\nmodule.exports = flatten;\n","var arrayEach = require('./_arrayEach'),\n baseEach = require('./_baseEach'),\n castFunction = require('./_castFunction'),\n isArray = require('./isArray');\n\n/**\n * Iterates over elements of `collection` and invokes `iteratee` for each element.\n * The iteratee is invoked with three arguments: (value, index|key, collection).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * **Note:** As with other \"Collections\" methods, objects with a \"length\"\n * property are iterated like arrays. To avoid this behavior use `_.forIn`\n * or `_.forOwn` for object iteration.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @alias each\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n * @see _.forEachRight\n * @example\n *\n * _.forEach([1, 2], function(value) {\n * console.log(value);\n * });\n * // => Logs `1` then `2`.\n *\n * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\n */\nfunction forEach(collection, iteratee) {\n var func = isArray(collection) ? arrayEach : baseEach;\n return func(collection, castFunction(iteratee));\n}\n\nmodule.exports = forEach;\n","var baseFor = require('./_baseFor'),\n castFunction = require('./_castFunction'),\n keysIn = require('./keysIn');\n\n/**\n * Iterates over own and inherited enumerable string keyed properties of an\n * object and invokes `iteratee` for each property. The iteratee is invoked\n * with three arguments: (value, key, object). Iteratee functions may exit\n * iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forInRight\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forIn(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a', 'b', then 'c' (iteration order is not guaranteed).\n */\nfunction forIn(object, iteratee) {\n return object == null\n ? object\n : baseFor(object, castFunction(iteratee), keysIn);\n}\n\nmodule.exports = forIn;\n","var baseGet = require('./_baseGet');\n\n/**\n * Gets the value at `path` of `object`. If the resolved value is\n * `undefined`, the `defaultValue` is returned in its place.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.get(object, 'a[0].b.c');\n * // => 3\n *\n * _.get(object, ['a', '0', 'b', 'c']);\n * // => 3\n *\n * _.get(object, 'a.b.c', 'default');\n * // => 'default'\n */\nfunction get(object, path, defaultValue) {\n var result = object == null ? undefined : baseGet(object, path);\n return result === undefined ? defaultValue : result;\n}\n\nmodule.exports = get;\n","var baseHas = require('./_baseHas'),\n hasPath = require('./_hasPath');\n\n/**\n * Checks if `path` is a direct property of `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = { 'a': { 'b': 2 } };\n * var other = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.has(object, 'a');\n * // => true\n *\n * _.has(object, 'a.b');\n * // => true\n *\n * _.has(object, ['a', 'b']);\n * // => true\n *\n * _.has(other, 'a');\n * // => false\n */\nfunction has(object, path) {\n return object != null && hasPath(object, path, baseHas);\n}\n\nmodule.exports = has;\n","var baseHasIn = require('./_baseHasIn'),\n hasPath = require('./_hasPath');\n\n/**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\nfunction hasIn(object, path) {\n return object != null && hasPath(object, path, baseHasIn);\n}\n\nmodule.exports = hasIn;\n","/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n return value;\n}\n\nmodule.exports = identity;\n","var baseIsArguments = require('./_baseIsArguments'),\n isObjectLike = require('./isObjectLike');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\nmodule.exports = isArguments;\n","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nmodule.exports = isArray;\n","var isFunction = require('./isFunction'),\n isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n","var isArrayLike = require('./isArrayLike'),\n isObjectLike = require('./isObjectLike');\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n * else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\nfunction isArrayLikeObject(value) {\n return isObjectLike(value) && isArrayLike(value);\n}\n\nmodule.exports = isArrayLikeObject;\n","var root = require('./_root'),\n stubFalse = require('./stubFalse');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nmodule.exports = isBuffer;\n","var baseKeys = require('./_baseKeys'),\n getTag = require('./_getTag'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isArrayLike = require('./isArrayLike'),\n isBuffer = require('./isBuffer'),\n isPrototype = require('./_isPrototype'),\n isTypedArray = require('./isTypedArray');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n setTag = '[object Set]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if `value` is an empty object, collection, map, or set.\n *\n * Objects are considered empty if they have no own enumerable string keyed\n * properties.\n *\n * Array-like values such as `arguments` objects, arrays, buffers, strings, or\n * jQuery-like collections are considered empty if they have a `length` of `0`.\n * Similarly, maps and sets are considered empty if they have a `size` of `0`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is empty, else `false`.\n * @example\n *\n * _.isEmpty(null);\n * // => true\n *\n * _.isEmpty(true);\n * // => true\n *\n * _.isEmpty(1);\n * // => true\n *\n * _.isEmpty([1, 2, 3]);\n * // => false\n *\n * _.isEmpty({ 'a': 1 });\n * // => false\n */\nfunction isEmpty(value) {\n if (value == null) {\n return true;\n }\n if (isArrayLike(value) &&\n (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' ||\n isBuffer(value) || isTypedArray(value) || isArguments(value))) {\n return !value.length;\n }\n var tag = getTag(value);\n if (tag == mapTag || tag == setTag) {\n return !value.size;\n }\n if (isPrototype(value)) {\n return !baseKeys(value).length;\n }\n for (var key in value) {\n if (hasOwnProperty.call(value, key)) {\n return false;\n }\n }\n return true;\n}\n\nmodule.exports = isEmpty;\n","var baseGetTag = require('./_baseGetTag'),\n isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nmodule.exports = isFunction;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n","var baseIsMap = require('./_baseIsMap'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsMap = nodeUtil && nodeUtil.isMap;\n\n/**\n * Checks if `value` is classified as a `Map` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n * @example\n *\n * _.isMap(new Map);\n * // => true\n *\n * _.isMap(new WeakMap);\n * // => false\n */\nvar isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\nmodule.exports = isMap;\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","var baseGetTag = require('./_baseGetTag'),\n getPrototype = require('./_getPrototype'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\n return false;\n }\n var proto = getPrototype(value);\n if (proto === null) {\n return true;\n }\n var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n return typeof Ctor == 'function' && Ctor instanceof Ctor &&\n funcToString.call(Ctor) == objectCtorString;\n}\n\nmodule.exports = isPlainObject;\n","var baseIsSet = require('./_baseIsSet'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsSet = nodeUtil && nodeUtil.isSet;\n\n/**\n * Checks if `value` is classified as a `Set` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n * @example\n *\n * _.isSet(new Set);\n * // => true\n *\n * _.isSet(new WeakSet);\n * // => false\n */\nvar isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\n\nmodule.exports = isSet;\n","var baseGetTag = require('./_baseGetTag'),\n isArray = require('./isArray'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar stringTag = '[object String]';\n\n/**\n * Checks if `value` is classified as a `String` primitive or object.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a string, else `false`.\n * @example\n *\n * _.isString('abc');\n * // => true\n *\n * _.isString(1);\n * // => false\n */\nfunction isString(value) {\n return typeof value == 'string' ||\n (!isArray(value) && isObjectLike(value) && baseGetTag(value) == stringTag);\n}\n\nmodule.exports = isString;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n","var baseIsTypedArray = require('./_baseIsTypedArray'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nmodule.exports = isTypedArray;\n","/**\n * Checks if `value` is `undefined`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`.\n * @example\n *\n * _.isUndefined(void 0);\n * // => true\n *\n * _.isUndefined(null);\n * // => false\n */\nfunction isUndefined(value) {\n return value === undefined;\n}\n\nmodule.exports = isUndefined;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeys = require('./_baseKeys'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nmodule.exports = keys;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeysIn = require('./_baseKeysIn'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\nfunction keysIn(object) {\n return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n}\n\nmodule.exports = keysIn;\n","/**\n * Gets the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the last element of `array`.\n * @example\n *\n * _.last([1, 2, 3]);\n * // => 3\n */\nfunction last(array) {\n var length = array == null ? 0 : array.length;\n return length ? array[length - 1] : undefined;\n}\n\nmodule.exports = last;\n","var arrayMap = require('./_arrayMap'),\n baseIteratee = require('./_baseIteratee'),\n baseMap = require('./_baseMap'),\n isArray = require('./isArray');\n\n/**\n * Creates an array of values by running each element in `collection` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.\n *\n * The guarded methods are:\n * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`,\n * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`,\n * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`,\n * `template`, `trim`, `trimEnd`, `trimStart`, and `words`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * _.map([4, 8], square);\n * // => [16, 64]\n *\n * _.map({ 'a': 4, 'b': 8 }, square);\n * // => [16, 64] (iteration order is not guaranteed)\n *\n * var users = [\n * { 'user': 'barney' },\n * { 'user': 'fred' }\n * ];\n *\n * // The `_.property` iteratee shorthand.\n * _.map(users, 'user');\n * // => ['barney', 'fred']\n */\nfunction map(collection, iteratee) {\n var func = isArray(collection) ? arrayMap : baseMap;\n return func(collection, baseIteratee(iteratee, 3));\n}\n\nmodule.exports = map;\n","var baseAssignValue = require('./_baseAssignValue'),\n baseForOwn = require('./_baseForOwn'),\n baseIteratee = require('./_baseIteratee');\n\n/**\n * Creates an object with the same keys as `object` and values generated\n * by running each own enumerable string keyed property of `object` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapKeys\n * @example\n *\n * var users = {\n * 'fred': { 'user': 'fred', 'age': 40 },\n * 'pebbles': { 'user': 'pebbles', 'age': 1 }\n * };\n *\n * _.mapValues(users, function(o) { return o.age; });\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n *\n * // The `_.property` iteratee shorthand.\n * _.mapValues(users, 'age');\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n */\nfunction mapValues(object, iteratee) {\n var result = {};\n iteratee = baseIteratee(iteratee, 3);\n\n baseForOwn(object, function(value, key, object) {\n baseAssignValue(result, key, iteratee(value, key, object));\n });\n return result;\n}\n\nmodule.exports = mapValues;\n","var baseExtremum = require('./_baseExtremum'),\n baseGt = require('./_baseGt'),\n identity = require('./identity');\n\n/**\n * Computes the maximum value of `array`. If `array` is empty or falsey,\n * `undefined` is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Math\n * @param {Array} array The array to iterate over.\n * @returns {*} Returns the maximum value.\n * @example\n *\n * _.max([4, 2, 8, 6]);\n * // => 8\n *\n * _.max([]);\n * // => undefined\n */\nfunction max(array) {\n return (array && array.length)\n ? baseExtremum(array, identity, baseGt)\n : undefined;\n}\n\nmodule.exports = max;\n","var MapCache = require('./_MapCache');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nmodule.exports = memoize;\n","var baseMerge = require('./_baseMerge'),\n createAssigner = require('./_createAssigner');\n\n/**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable string keyed properties of source objects into the\n * destination object. Source properties that resolve to `undefined` are\n * skipped if a destination value exists. Array and plain object properties\n * are merged recursively. Other objects and value types are overridden by\n * assignment. Source objects are applied from left to right. Subsequent\n * sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {\n * 'a': [{ 'b': 2 }, { 'd': 4 }]\n * };\n *\n * var other = {\n * 'a': [{ 'c': 3 }, { 'e': 5 }]\n * };\n *\n * _.merge(object, other);\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\n */\nvar merge = createAssigner(function(object, source, srcIndex) {\n baseMerge(object, source, srcIndex);\n});\n\nmodule.exports = merge;\n","var baseExtremum = require('./_baseExtremum'),\n baseLt = require('./_baseLt'),\n identity = require('./identity');\n\n/**\n * Computes the minimum value of `array`. If `array` is empty or falsey,\n * `undefined` is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Math\n * @param {Array} array The array to iterate over.\n * @returns {*} Returns the minimum value.\n * @example\n *\n * _.min([4, 2, 8, 6]);\n * // => 2\n *\n * _.min([]);\n * // => undefined\n */\nfunction min(array) {\n return (array && array.length)\n ? baseExtremum(array, identity, baseLt)\n : undefined;\n}\n\nmodule.exports = min;\n","var baseExtremum = require('./_baseExtremum'),\n baseIteratee = require('./_baseIteratee'),\n baseLt = require('./_baseLt');\n\n/**\n * This method is like `_.min` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the criterion by which\n * the value is ranked. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {*} Returns the minimum value.\n * @example\n *\n * var objects = [{ 'n': 1 }, { 'n': 2 }];\n *\n * _.minBy(objects, function(o) { return o.n; });\n * // => { 'n': 1 }\n *\n * // The `_.property` iteratee shorthand.\n * _.minBy(objects, 'n');\n * // => { 'n': 1 }\n */\nfunction minBy(array, iteratee) {\n return (array && array.length)\n ? baseExtremum(array, baseIteratee(iteratee, 2), baseLt)\n : undefined;\n}\n\nmodule.exports = minBy;\n","/**\n * This method returns `undefined`.\n *\n * @static\n * @memberOf _\n * @since 2.3.0\n * @category Util\n * @example\n *\n * _.times(2, _.noop);\n * // => [undefined, undefined]\n */\nfunction noop() {\n // No operation performed.\n}\n\nmodule.exports = noop;\n","var root = require('./_root');\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n return root.Date.now();\n};\n\nmodule.exports = now;\n","var basePick = require('./_basePick'),\n flatRest = require('./_flatRest');\n\n/**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pick(object, ['a', 'c']);\n * // => { 'a': 1, 'c': 3 }\n */\nvar pick = flatRest(function(object, paths) {\n return object == null ? {} : basePick(object, paths);\n});\n\nmodule.exports = pick;\n","var baseProperty = require('./_baseProperty'),\n basePropertyDeep = require('./_basePropertyDeep'),\n isKey = require('./_isKey'),\n toKey = require('./_toKey');\n\n/**\n * Creates a function that returns the value at `path` of a given object.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n * @example\n *\n * var objects = [\n * { 'a': { 'b': 2 } },\n * { 'a': { 'b': 1 } }\n * ];\n *\n * _.map(objects, _.property('a.b'));\n * // => [2, 1]\n *\n * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b');\n * // => [1, 2]\n */\nfunction property(path) {\n return isKey(path) ? baseProperty(toKey(path)) : basePropertyDeep(path);\n}\n\nmodule.exports = property;\n","var createRange = require('./_createRange');\n\n/**\n * Creates an array of numbers (positive and/or negative) progressing from\n * `start` up to, but not including, `end`. A step of `-1` is used if a negative\n * `start` is specified without an `end` or `step`. If `end` is not specified,\n * it's set to `start` with `start` then set to `0`.\n *\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\n * floating-point values which can produce unexpected results.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {number} [start=0] The start of the range.\n * @param {number} end The end of the range.\n * @param {number} [step=1] The value to increment or decrement by.\n * @returns {Array} Returns the range of numbers.\n * @see _.inRange, _.rangeRight\n * @example\n *\n * _.range(4);\n * // => [0, 1, 2, 3]\n *\n * _.range(-4);\n * // => [0, -1, -2, -3]\n *\n * _.range(1, 5);\n * // => [1, 2, 3, 4]\n *\n * _.range(0, 20, 5);\n * // => [0, 5, 10, 15]\n *\n * _.range(0, -4, -1);\n * // => [0, -1, -2, -3]\n *\n * _.range(1, 4, 0);\n * // => [1, 1, 1]\n *\n * _.range(0);\n * // => []\n */\nvar range = createRange();\n\nmodule.exports = range;\n","var arrayReduce = require('./_arrayReduce'),\n baseEach = require('./_baseEach'),\n baseIteratee = require('./_baseIteratee'),\n baseReduce = require('./_baseReduce'),\n isArray = require('./isArray');\n\n/**\n * Reduces `collection` to a value which is the accumulated result of running\n * each element in `collection` thru `iteratee`, where each successive\n * invocation is supplied the return value of the previous. If `accumulator`\n * is not given, the first element of `collection` is used as the initial\n * value. The iteratee is invoked with four arguments:\n * (accumulator, value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.reduce`, `_.reduceRight`, and `_.transform`.\n *\n * The guarded methods are:\n * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`,\n * and `sortBy`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @returns {*} Returns the accumulated value.\n * @see _.reduceRight\n * @example\n *\n * _.reduce([1, 2], function(sum, n) {\n * return sum + n;\n * }, 0);\n * // => 3\n *\n * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n * (result[value] || (result[value] = [])).push(key);\n * return result;\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed)\n */\nfunction reduce(collection, iteratee, accumulator) {\n var func = isArray(collection) ? arrayReduce : baseReduce,\n initAccum = arguments.length < 3;\n\n return func(collection, baseIteratee(iteratee, 4), accumulator, initAccum, baseEach);\n}\n\nmodule.exports = reduce;\n","var baseKeys = require('./_baseKeys'),\n getTag = require('./_getTag'),\n isArrayLike = require('./isArrayLike'),\n isString = require('./isString'),\n stringSize = require('./_stringSize');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n setTag = '[object Set]';\n\n/**\n * Gets the size of `collection` by returning its length for array-like\n * values or the number of own enumerable string keyed properties for objects.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @returns {number} Returns the collection size.\n * @example\n *\n * _.size([1, 2, 3]);\n * // => 3\n *\n * _.size({ 'a': 1, 'b': 2 });\n * // => 2\n *\n * _.size('pebbles');\n * // => 7\n */\nfunction size(collection) {\n if (collection == null) {\n return 0;\n }\n if (isArrayLike(collection)) {\n return isString(collection) ? stringSize(collection) : collection.length;\n }\n var tag = getTag(collection);\n if (tag == mapTag || tag == setTag) {\n return collection.size;\n }\n return baseKeys(collection).length;\n}\n\nmodule.exports = size;\n","var baseFlatten = require('./_baseFlatten'),\n baseOrderBy = require('./_baseOrderBy'),\n baseRest = require('./_baseRest'),\n isIterateeCall = require('./_isIterateeCall');\n\n/**\n * Creates an array of elements, sorted in ascending order by the results of\n * running each element in a collection thru each iteratee. This method\n * performs a stable sort, that is, it preserves the original sort order of\n * equal elements. The iteratees are invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {...(Function|Function[])} [iteratees=[_.identity]]\n * The iteratees to sort by.\n * @returns {Array} Returns the new sorted array.\n * @example\n *\n * var users = [\n * { 'user': 'fred', 'age': 48 },\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 30 },\n * { 'user': 'barney', 'age': 34 }\n * ];\n *\n * _.sortBy(users, [function(o) { return o.user; }]);\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 30]]\n *\n * _.sortBy(users, ['user', 'age']);\n * // => objects for [['barney', 34], ['barney', 36], ['fred', 30], ['fred', 48]]\n */\nvar sortBy = baseRest(function(collection, iteratees) {\n if (collection == null) {\n return [];\n }\n var length = iteratees.length;\n if (length > 1 && isIterateeCall(collection, iteratees[0], iteratees[1])) {\n iteratees = [];\n } else if (length > 2 && isIterateeCall(iteratees[0], iteratees[1], iteratees[2])) {\n iteratees = [iteratees[0]];\n }\n return baseOrderBy(collection, baseFlatten(iteratees, 1), []);\n});\n\nmodule.exports = sortBy;\n","/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\nmodule.exports = stubArray;\n","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = stubFalse;\n","var toNumber = require('./toNumber');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n MAX_INTEGER = 1.7976931348623157e+308;\n\n/**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\nfunction toFinite(value) {\n if (!value) {\n return value === 0 ? value : 0;\n }\n value = toNumber(value);\n if (value === INFINITY || value === -INFINITY) {\n var sign = (value < 0 ? -1 : 1);\n return sign * MAX_INTEGER;\n }\n return value === value ? value : 0;\n}\n\nmodule.exports = toFinite;\n","var toFinite = require('./toFinite');\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\nfunction toInteger(value) {\n var result = toFinite(value),\n remainder = result % 1;\n\n return result === result ? (remainder ? result - remainder : result) : 0;\n}\n\nmodule.exports = toInteger;\n","var baseTrim = require('./_baseTrim'),\n isObject = require('./isObject'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = toNumber;\n","var copyObject = require('./_copyObject'),\n keysIn = require('./keysIn');\n\n/**\n * Converts `value` to a plain object flattening inherited enumerable string\n * keyed properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Object} Returns the converted plain object.\n * @example\n *\n * function Foo() {\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.assign({ 'a': 1 }, new Foo);\n * // => { 'a': 1, 'b': 2 }\n *\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\n * // => { 'a': 1, 'b': 2, 'c': 3 }\n */\nfunction toPlainObject(value) {\n return copyObject(value, keysIn(value));\n}\n\nmodule.exports = toPlainObject;\n","var baseToString = require('./_baseToString');\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n return value == null ? '' : baseToString(value);\n}\n\nmodule.exports = toString;\n","var arrayEach = require('./_arrayEach'),\n baseCreate = require('./_baseCreate'),\n baseForOwn = require('./_baseForOwn'),\n baseIteratee = require('./_baseIteratee'),\n getPrototype = require('./_getPrototype'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isFunction = require('./isFunction'),\n isObject = require('./isObject'),\n isTypedArray = require('./isTypedArray');\n\n/**\n * An alternative to `_.reduce`; this method transforms `object` to a new\n * `accumulator` object which is the result of running each of its own\n * enumerable string keyed properties thru `iteratee`, with each invocation\n * potentially mutating the `accumulator` object. If `accumulator` is not\n * provided, a new object with the same `[[Prototype]]` will be used. The\n * iteratee is invoked with four arguments: (accumulator, value, key, object).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 1.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The custom accumulator value.\n * @returns {*} Returns the accumulated value.\n * @example\n *\n * _.transform([2, 3, 4], function(result, n) {\n * result.push(n *= n);\n * return n % 2 == 0;\n * }, []);\n * // => [4, 9]\n *\n * _.transform({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n * (result[value] || (result[value] = [])).push(key);\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] }\n */\nfunction transform(object, iteratee, accumulator) {\n var isArr = isArray(object),\n isArrLike = isArr || isBuffer(object) || isTypedArray(object);\n\n iteratee = baseIteratee(iteratee, 4);\n if (accumulator == null) {\n var Ctor = object && object.constructor;\n if (isArrLike) {\n accumulator = isArr ? new Ctor : [];\n }\n else if (isObject(object)) {\n accumulator = isFunction(Ctor) ? baseCreate(getPrototype(object)) : {};\n }\n else {\n accumulator = {};\n }\n }\n (isArrLike ? arrayEach : baseForOwn)(object, function(value, index, object) {\n return iteratee(accumulator, value, index, object);\n });\n return accumulator;\n}\n\nmodule.exports = transform;\n","var baseFlatten = require('./_baseFlatten'),\n baseRest = require('./_baseRest'),\n baseUniq = require('./_baseUniq'),\n isArrayLikeObject = require('./isArrayLikeObject');\n\n/**\n * Creates an array of unique values, in order, from all given arrays using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * _.union([2], [1, 2]);\n * // => [2, 1]\n */\nvar union = baseRest(function(arrays) {\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true));\n});\n\nmodule.exports = union;\n","var toString = require('./toString');\n\n/** Used to generate unique IDs. */\nvar idCounter = 0;\n\n/**\n * Generates a unique ID. If `prefix` is given, the ID is appended to it.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {string} [prefix=''] The value to prefix the ID with.\n * @returns {string} Returns the unique ID.\n * @example\n *\n * _.uniqueId('contact_');\n * // => 'contact_104'\n *\n * _.uniqueId();\n * // => '105'\n */\nfunction uniqueId(prefix) {\n var id = ++idCounter;\n return toString(prefix) + id;\n}\n\nmodule.exports = uniqueId;\n","var baseValues = require('./_baseValues'),\n keys = require('./keys');\n\n/**\n * Creates an array of the own enumerable string keyed property values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.values(new Foo);\n * // => [1, 2] (iteration order is not guaranteed)\n *\n * _.values('hi');\n * // => ['h', 'i']\n */\nfunction values(object) {\n return object == null ? [] : baseValues(object, keys(object));\n}\n\nmodule.exports = values;\n","var assignValue = require('./_assignValue'),\n baseZipObject = require('./_baseZipObject');\n\n/**\n * This method is like `_.fromPairs` except that it accepts two arrays,\n * one of property identifiers and one of corresponding values.\n *\n * @static\n * @memberOf _\n * @since 0.4.0\n * @category Array\n * @param {Array} [props=[]] The property identifiers.\n * @param {Array} [values=[]] The property values.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.zipObject(['a', 'b'], [1, 2]);\n * // => { 'a': 1, 'b': 2 }\n */\nfunction zipObject(props, values) {\n return baseZipObject(props || [], values || [], assignValue);\n}\n\nmodule.exports = zipObject;\n","var add = require('gl-vec2/add')\nvar set = require('gl-vec2/set')\nvar normalize = require('gl-vec2/normalize')\nvar subtract = require('gl-vec2/subtract')\nvar dot = require('gl-vec2/dot')\n\nvar tmp = [0, 0]\n\nmodule.exports.computeMiter = function computeMiter(tangent, miter, lineA, lineB, halfThick) {\n //get tangent line\n add(tangent, lineA, lineB)\n normalize(tangent, tangent)\n\n //get miter as a unit vector\n set(miter, -tangent[1], tangent[0])\n set(tmp, -lineA[1], lineA[0])\n\n //get the necessary length of our miter\n return halfThick / dot(miter, tmp)\n}\n\nmodule.exports.normal = function normal(out, dir) {\n //get perpendicular\n set(out, -dir[1], dir[0])\n return out\n}\n\nmodule.exports.direction = function direction(out, a, b) {\n //get unit dir of two lines\n subtract(out, a, b)\n normalize(out, out)\n return out\n}","/*! *****************************************************************************\nCopyright (C) Microsoft. All rights reserved.\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\nthis file except in compliance with the License. You may obtain a copy of the\nLicense at http://www.apache.org/licenses/LICENSE-2.0\n\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\nMERCHANTABLITY OR NON-INFRINGEMENT.\n\nSee the Apache Version 2.0 License for specific language governing permissions\nand limitations under the License.\n***************************************************************************** */\nvar Reflect;\n(function (Reflect) {\n // Metadata Proposal\n // https://rbuckton.github.io/reflect-metadata/\n (function (factory) {\n var root = typeof global === \"object\" ? global :\n typeof self === \"object\" ? self :\n typeof this === \"object\" ? this :\n Function(\"return this;\")();\n var exporter = makeExporter(Reflect);\n if (typeof root.Reflect === \"undefined\") {\n root.Reflect = Reflect;\n }\n else {\n exporter = makeExporter(root.Reflect, exporter);\n }\n factory(exporter);\n function makeExporter(target, previous) {\n return function (key, value) {\n if (typeof target[key] !== \"function\") {\n Object.defineProperty(target, key, { configurable: true, writable: true, value: value });\n }\n if (previous)\n previous(key, value);\n };\n }\n })(function (exporter) {\n var hasOwn = Object.prototype.hasOwnProperty;\n // feature test for Symbol support\n var supportsSymbol = typeof Symbol === \"function\";\n var toPrimitiveSymbol = supportsSymbol && typeof Symbol.toPrimitive !== \"undefined\" ? Symbol.toPrimitive : \"@@toPrimitive\";\n var iteratorSymbol = supportsSymbol && typeof Symbol.iterator !== \"undefined\" ? Symbol.iterator : \"@@iterator\";\n var supportsCreate = typeof Object.create === \"function\"; // feature test for Object.create support\n var supportsProto = { __proto__: [] } instanceof Array; // feature test for __proto__ support\n var downLevel = !supportsCreate && !supportsProto;\n var HashMap = {\n // create an object in dictionary mode (a.k.a. \"slow\" mode in v8)\n create: supportsCreate\n ? function () { return MakeDictionary(Object.create(null)); }\n : supportsProto\n ? function () { return MakeDictionary({ __proto__: null }); }\n : function () { return MakeDictionary({}); },\n has: downLevel\n ? function (map, key) { return hasOwn.call(map, key); }\n : function (map, key) { return key in map; },\n get: downLevel\n ? function (map, key) { return hasOwn.call(map, key) ? map[key] : undefined; }\n : function (map, key) { return map[key]; },\n };\n // Load global or shim versions of Map, Set, and WeakMap\n var functionPrototype = Object.getPrototypeOf(Function);\n var usePolyfill = typeof process === \"object\" && process.env && process.env[\"REFLECT_METADATA_USE_MAP_POLYFILL\"] === \"true\";\n var _Map = !usePolyfill && typeof Map === \"function\" && typeof Map.prototype.entries === \"function\" ? Map : CreateMapPolyfill();\n var _Set = !usePolyfill && typeof Set === \"function\" && typeof Set.prototype.entries === \"function\" ? Set : CreateSetPolyfill();\n var _WeakMap = !usePolyfill && typeof WeakMap === \"function\" ? WeakMap : CreateWeakMapPolyfill();\n // [[Metadata]] internal slot\n // https://rbuckton.github.io/reflect-metadata/#ordinary-object-internal-methods-and-internal-slots\n var Metadata = new _WeakMap();\n /**\n * Applies a set of decorators to a property of a target object.\n * @param decorators An array of decorators.\n * @param target The target object.\n * @param propertyKey (Optional) The property key to decorate.\n * @param attributes (Optional) The property descriptor for the target key.\n * @remarks Decorators are applied in reverse order.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * Example = Reflect.decorate(decoratorsArray, Example);\n *\n * // property (on constructor)\n * Reflect.decorate(decoratorsArray, Example, \"staticProperty\");\n *\n * // property (on prototype)\n * Reflect.decorate(decoratorsArray, Example.prototype, \"property\");\n *\n * // method (on constructor)\n * Object.defineProperty(Example, \"staticMethod\",\n * Reflect.decorate(decoratorsArray, Example, \"staticMethod\",\n * Object.getOwnPropertyDescriptor(Example, \"staticMethod\")));\n *\n * // method (on prototype)\n * Object.defineProperty(Example.prototype, \"method\",\n * Reflect.decorate(decoratorsArray, Example.prototype, \"method\",\n * Object.getOwnPropertyDescriptor(Example.prototype, \"method\")));\n *\n */\n function decorate(decorators, target, propertyKey, attributes) {\n if (!IsUndefined(propertyKey)) {\n if (!IsArray(decorators))\n throw new TypeError();\n if (!IsObject(target))\n throw new TypeError();\n if (!IsObject(attributes) && !IsUndefined(attributes) && !IsNull(attributes))\n throw new TypeError();\n if (IsNull(attributes))\n attributes = undefined;\n propertyKey = ToPropertyKey(propertyKey);\n return DecorateProperty(decorators, target, propertyKey, attributes);\n }\n else {\n if (!IsArray(decorators))\n throw new TypeError();\n if (!IsConstructor(target))\n throw new TypeError();\n return DecorateConstructor(decorators, target);\n }\n }\n exporter(\"decorate\", decorate);\n // 4.1.2 Reflect.metadata(metadataKey, metadataValue)\n // https://rbuckton.github.io/reflect-metadata/#reflect.metadata\n /**\n * A default metadata decorator factory that can be used on a class, class member, or parameter.\n * @param metadataKey The key for the metadata entry.\n * @param metadataValue The value for the metadata entry.\n * @returns A decorator function.\n * @remarks\n * If `metadataKey` is already defined for the target and target key, the\n * metadataValue for that key will be overwritten.\n * @example\n *\n * // constructor\n * @Reflect.metadata(key, value)\n * class Example {\n * }\n *\n * // property (on constructor, TypeScript only)\n * class Example {\n * @Reflect.metadata(key, value)\n * static staticProperty;\n * }\n *\n * // property (on prototype, TypeScript only)\n * class Example {\n * @Reflect.metadata(key, value)\n * property;\n * }\n *\n * // method (on constructor)\n * class Example {\n * @Reflect.metadata(key, value)\n * static staticMethod() { }\n * }\n *\n * // method (on prototype)\n * class Example {\n * @Reflect.metadata(key, value)\n * method() { }\n * }\n *\n */\n function metadata(metadataKey, metadataValue) {\n function decorator(target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey) && !IsPropertyKey(propertyKey))\n throw new TypeError();\n OrdinaryDefineOwnMetadata(metadataKey, metadataValue, target, propertyKey);\n }\n return decorator;\n }\n exporter(\"metadata\", metadata);\n /**\n * Define a unique metadata entry on the target.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param metadataValue A value that contains attached metadata.\n * @param target The target object on which to define metadata.\n * @param propertyKey (Optional) The property key for the target.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * Reflect.defineMetadata(\"custom:annotation\", options, Example);\n *\n * // property (on constructor)\n * Reflect.defineMetadata(\"custom:annotation\", options, Example, \"staticProperty\");\n *\n * // property (on prototype)\n * Reflect.defineMetadata(\"custom:annotation\", options, Example.prototype, \"property\");\n *\n * // method (on constructor)\n * Reflect.defineMetadata(\"custom:annotation\", options, Example, \"staticMethod\");\n *\n * // method (on prototype)\n * Reflect.defineMetadata(\"custom:annotation\", options, Example.prototype, \"method\");\n *\n * // decorator factory as metadata-producing annotation.\n * function MyAnnotation(options): Decorator {\n * return (target, key?) => Reflect.defineMetadata(\"custom:annotation\", options, target, key);\n * }\n *\n */\n function defineMetadata(metadataKey, metadataValue, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryDefineOwnMetadata(metadataKey, metadataValue, target, propertyKey);\n }\n exporter(\"defineMetadata\", defineMetadata);\n /**\n * Gets a value indicating whether the target object or its prototype chain has the provided metadata key defined.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns `true` if the metadata key was defined on the target object or its prototype chain; otherwise, `false`.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.hasMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.hasMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.hasMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.hasMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.hasMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function hasMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryHasMetadata(metadataKey, target, propertyKey);\n }\n exporter(\"hasMetadata\", hasMetadata);\n /**\n * Gets a value indicating whether the target object has the provided metadata key defined.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns `true` if the metadata key was defined on the target object; otherwise, `false`.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function hasOwnMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryHasOwnMetadata(metadataKey, target, propertyKey);\n }\n exporter(\"hasOwnMetadata\", hasOwnMetadata);\n /**\n * Gets the metadata value for the provided metadata key on the target object or its prototype chain.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns The metadata value for the metadata key if found; otherwise, `undefined`.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.getMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.getMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.getMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.getMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.getMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function getMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryGetMetadata(metadataKey, target, propertyKey);\n }\n exporter(\"getMetadata\", getMetadata);\n /**\n * Gets the metadata value for the provided metadata key on the target object.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns The metadata value for the metadata key if found; otherwise, `undefined`.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function getOwnMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryGetOwnMetadata(metadataKey, target, propertyKey);\n }\n exporter(\"getOwnMetadata\", getOwnMetadata);\n /**\n * Gets the metadata keys defined on the target object or its prototype chain.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns An array of unique metadata keys.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.getMetadataKeys(Example);\n *\n * // property (on constructor)\n * result = Reflect.getMetadataKeys(Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.getMetadataKeys(Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.getMetadataKeys(Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.getMetadataKeys(Example.prototype, \"method\");\n *\n */\n function getMetadataKeys(target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryMetadataKeys(target, propertyKey);\n }\n exporter(\"getMetadataKeys\", getMetadataKeys);\n /**\n * Gets the unique metadata keys defined on the target object.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns An array of unique metadata keys.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.getOwnMetadataKeys(Example);\n *\n * // property (on constructor)\n * result = Reflect.getOwnMetadataKeys(Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.getOwnMetadataKeys(Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.getOwnMetadataKeys(Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.getOwnMetadataKeys(Example.prototype, \"method\");\n *\n */\n function getOwnMetadataKeys(target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryOwnMetadataKeys(target, propertyKey);\n }\n exporter(\"getOwnMetadataKeys\", getOwnMetadataKeys);\n /**\n * Deletes the metadata entry from the target object with the provided key.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns `true` if the metadata entry was found and deleted; otherwise, false.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function deleteMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n var metadataMap = GetOrCreateMetadataMap(target, propertyKey, /*Create*/ false);\n if (IsUndefined(metadataMap))\n return false;\n if (!metadataMap.delete(metadataKey))\n return false;\n if (metadataMap.size > 0)\n return true;\n var targetMetadata = Metadata.get(target);\n targetMetadata.delete(propertyKey);\n if (targetMetadata.size > 0)\n return true;\n Metadata.delete(target);\n return true;\n }\n exporter(\"deleteMetadata\", deleteMetadata);\n function DecorateConstructor(decorators, target) {\n for (var i = decorators.length - 1; i >= 0; --i) {\n var decorator = decorators[i];\n var decorated = decorator(target);\n if (!IsUndefined(decorated) && !IsNull(decorated)) {\n if (!IsConstructor(decorated))\n throw new TypeError();\n target = decorated;\n }\n }\n return target;\n }\n function DecorateProperty(decorators, target, propertyKey, descriptor) {\n for (var i = decorators.length - 1; i >= 0; --i) {\n var decorator = decorators[i];\n var decorated = decorator(target, propertyKey, descriptor);\n if (!IsUndefined(decorated) && !IsNull(decorated)) {\n if (!IsObject(decorated))\n throw new TypeError();\n descriptor = decorated;\n }\n }\n return descriptor;\n }\n function GetOrCreateMetadataMap(O, P, Create) {\n var targetMetadata = Metadata.get(O);\n if (IsUndefined(targetMetadata)) {\n if (!Create)\n return undefined;\n targetMetadata = new _Map();\n Metadata.set(O, targetMetadata);\n }\n var metadataMap = targetMetadata.get(P);\n if (IsUndefined(metadataMap)) {\n if (!Create)\n return undefined;\n metadataMap = new _Map();\n targetMetadata.set(P, metadataMap);\n }\n return metadataMap;\n }\n // 3.1.1.1 OrdinaryHasMetadata(MetadataKey, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinaryhasmetadata\n function OrdinaryHasMetadata(MetadataKey, O, P) {\n var hasOwn = OrdinaryHasOwnMetadata(MetadataKey, O, P);\n if (hasOwn)\n return true;\n var parent = OrdinaryGetPrototypeOf(O);\n if (!IsNull(parent))\n return OrdinaryHasMetadata(MetadataKey, parent, P);\n return false;\n }\n // 3.1.2.1 OrdinaryHasOwnMetadata(MetadataKey, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinaryhasownmetadata\n function OrdinaryHasOwnMetadata(MetadataKey, O, P) {\n var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false);\n if (IsUndefined(metadataMap))\n return false;\n return ToBoolean(metadataMap.has(MetadataKey));\n }\n // 3.1.3.1 OrdinaryGetMetadata(MetadataKey, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinarygetmetadata\n function OrdinaryGetMetadata(MetadataKey, O, P) {\n var hasOwn = OrdinaryHasOwnMetadata(MetadataKey, O, P);\n if (hasOwn)\n return OrdinaryGetOwnMetadata(MetadataKey, O, P);\n var parent = OrdinaryGetPrototypeOf(O);\n if (!IsNull(parent))\n return OrdinaryGetMetadata(MetadataKey, parent, P);\n return undefined;\n }\n // 3.1.4.1 OrdinaryGetOwnMetadata(MetadataKey, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinarygetownmetadata\n function OrdinaryGetOwnMetadata(MetadataKey, O, P) {\n var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false);\n if (IsUndefined(metadataMap))\n return undefined;\n return metadataMap.get(MetadataKey);\n }\n // 3.1.5.1 OrdinaryDefineOwnMetadata(MetadataKey, MetadataValue, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinarydefineownmetadata\n function OrdinaryDefineOwnMetadata(MetadataKey, MetadataValue, O, P) {\n var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ true);\n metadataMap.set(MetadataKey, MetadataValue);\n }\n // 3.1.6.1 OrdinaryMetadataKeys(O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinarymetadatakeys\n function OrdinaryMetadataKeys(O, P) {\n var ownKeys = OrdinaryOwnMetadataKeys(O, P);\n var parent = OrdinaryGetPrototypeOf(O);\n if (parent === null)\n return ownKeys;\n var parentKeys = OrdinaryMetadataKeys(parent, P);\n if (parentKeys.length <= 0)\n return ownKeys;\n if (ownKeys.length <= 0)\n return parentKeys;\n var set = new _Set();\n var keys = [];\n for (var _i = 0, ownKeys_1 = ownKeys; _i < ownKeys_1.length; _i++) {\n var key = ownKeys_1[_i];\n var hasKey = set.has(key);\n if (!hasKey) {\n set.add(key);\n keys.push(key);\n }\n }\n for (var _a = 0, parentKeys_1 = parentKeys; _a < parentKeys_1.length; _a++) {\n var key = parentKeys_1[_a];\n var hasKey = set.has(key);\n if (!hasKey) {\n set.add(key);\n keys.push(key);\n }\n }\n return keys;\n }\n // 3.1.7.1 OrdinaryOwnMetadataKeys(O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinaryownmetadatakeys\n function OrdinaryOwnMetadataKeys(O, P) {\n var keys = [];\n var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false);\n if (IsUndefined(metadataMap))\n return keys;\n var keysObj = metadataMap.keys();\n var iterator = GetIterator(keysObj);\n var k = 0;\n while (true) {\n var next = IteratorStep(iterator);\n if (!next) {\n keys.length = k;\n return keys;\n }\n var nextValue = IteratorValue(next);\n try {\n keys[k] = nextValue;\n }\n catch (e) {\n try {\n IteratorClose(iterator);\n }\n finally {\n throw e;\n }\n }\n k++;\n }\n }\n // 6 ECMAScript Data Typ0es and Values\n // https://tc39.github.io/ecma262/#sec-ecmascript-data-types-and-values\n function Type(x) {\n if (x === null)\n return 1 /* Null */;\n switch (typeof x) {\n case \"undefined\": return 0 /* Undefined */;\n case \"boolean\": return 2 /* Boolean */;\n case \"string\": return 3 /* String */;\n case \"symbol\": return 4 /* Symbol */;\n case \"number\": return 5 /* Number */;\n case \"object\": return x === null ? 1 /* Null */ : 6 /* Object */;\n default: return 6 /* Object */;\n }\n }\n // 6.1.1 The Undefined Type\n // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-undefined-type\n function IsUndefined(x) {\n return x === undefined;\n }\n // 6.1.2 The Null Type\n // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-null-type\n function IsNull(x) {\n return x === null;\n }\n // 6.1.5 The Symbol Type\n // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-symbol-type\n function IsSymbol(x) {\n return typeof x === \"symbol\";\n }\n // 6.1.7 The Object Type\n // https://tc39.github.io/ecma262/#sec-object-type\n function IsObject(x) {\n return typeof x === \"object\" ? x !== null : typeof x === \"function\";\n }\n // 7.1 Type Conversion\n // https://tc39.github.io/ecma262/#sec-type-conversion\n // 7.1.1 ToPrimitive(input [, PreferredType])\n // https://tc39.github.io/ecma262/#sec-toprimitive\n function ToPrimitive(input, PreferredType) {\n switch (Type(input)) {\n case 0 /* Undefined */: return input;\n case 1 /* Null */: return input;\n case 2 /* Boolean */: return input;\n case 3 /* String */: return input;\n case 4 /* Symbol */: return input;\n case 5 /* Number */: return input;\n }\n var hint = PreferredType === 3 /* String */ ? \"string\" : PreferredType === 5 /* Number */ ? \"number\" : \"default\";\n var exoticToPrim = GetMethod(input, toPrimitiveSymbol);\n if (exoticToPrim !== undefined) {\n var result = exoticToPrim.call(input, hint);\n if (IsObject(result))\n throw new TypeError();\n return result;\n }\n return OrdinaryToPrimitive(input, hint === \"default\" ? \"number\" : hint);\n }\n // 7.1.1.1 OrdinaryToPrimitive(O, hint)\n // https://tc39.github.io/ecma262/#sec-ordinarytoprimitive\n function OrdinaryToPrimitive(O, hint) {\n if (hint === \"string\") {\n var toString_1 = O.toString;\n if (IsCallable(toString_1)) {\n var result = toString_1.call(O);\n if (!IsObject(result))\n return result;\n }\n var valueOf = O.valueOf;\n if (IsCallable(valueOf)) {\n var result = valueOf.call(O);\n if (!IsObject(result))\n return result;\n }\n }\n else {\n var valueOf = O.valueOf;\n if (IsCallable(valueOf)) {\n var result = valueOf.call(O);\n if (!IsObject(result))\n return result;\n }\n var toString_2 = O.toString;\n if (IsCallable(toString_2)) {\n var result = toString_2.call(O);\n if (!IsObject(result))\n return result;\n }\n }\n throw new TypeError();\n }\n // 7.1.2 ToBoolean(argument)\n // https://tc39.github.io/ecma262/2016/#sec-toboolean\n function ToBoolean(argument) {\n return !!argument;\n }\n // 7.1.12 ToString(argument)\n // https://tc39.github.io/ecma262/#sec-tostring\n function ToString(argument) {\n return \"\" + argument;\n }\n // 7.1.14 ToPropertyKey(argument)\n // https://tc39.github.io/ecma262/#sec-topropertykey\n function ToPropertyKey(argument) {\n var key = ToPrimitive(argument, 3 /* String */);\n if (IsSymbol(key))\n return key;\n return ToString(key);\n }\n // 7.2 Testing and Comparison Operations\n // https://tc39.github.io/ecma262/#sec-testing-and-comparison-operations\n // 7.2.2 IsArray(argument)\n // https://tc39.github.io/ecma262/#sec-isarray\n function IsArray(argument) {\n return Array.isArray\n ? Array.isArray(argument)\n : argument instanceof Object\n ? argument instanceof Array\n : Object.prototype.toString.call(argument) === \"[object Array]\";\n }\n // 7.2.3 IsCallable(argument)\n // https://tc39.github.io/ecma262/#sec-iscallable\n function IsCallable(argument) {\n // NOTE: This is an approximation as we cannot check for [[Call]] internal method.\n return typeof argument === \"function\";\n }\n // 7.2.4 IsConstructor(argument)\n // https://tc39.github.io/ecma262/#sec-isconstructor\n function IsConstructor(argument) {\n // NOTE: This is an approximation as we cannot check for [[Construct]] internal method.\n return typeof argument === \"function\";\n }\n // 7.2.7 IsPropertyKey(argument)\n // https://tc39.github.io/ecma262/#sec-ispropertykey\n function IsPropertyKey(argument) {\n switch (Type(argument)) {\n case 3 /* String */: return true;\n case 4 /* Symbol */: return true;\n default: return false;\n }\n }\n // 7.3 Operations on Objects\n // https://tc39.github.io/ecma262/#sec-operations-on-objects\n // 7.3.9 GetMethod(V, P)\n // https://tc39.github.io/ecma262/#sec-getmethod\n function GetMethod(V, P) {\n var func = V[P];\n if (func === undefined || func === null)\n return undefined;\n if (!IsCallable(func))\n throw new TypeError();\n return func;\n }\n // 7.4 Operations on Iterator Objects\n // https://tc39.github.io/ecma262/#sec-operations-on-iterator-objects\n function GetIterator(obj) {\n var method = GetMethod(obj, iteratorSymbol);\n if (!IsCallable(method))\n throw new TypeError(); // from Call\n var iterator = method.call(obj);\n if (!IsObject(iterator))\n throw new TypeError();\n return iterator;\n }\n // 7.4.4 IteratorValue(iterResult)\n // https://tc39.github.io/ecma262/2016/#sec-iteratorvalue\n function IteratorValue(iterResult) {\n return iterResult.value;\n }\n // 7.4.5 IteratorStep(iterator)\n // https://tc39.github.io/ecma262/#sec-iteratorstep\n function IteratorStep(iterator) {\n var result = iterator.next();\n return result.done ? false : result;\n }\n // 7.4.6 IteratorClose(iterator, completion)\n // https://tc39.github.io/ecma262/#sec-iteratorclose\n function IteratorClose(iterator) {\n var f = iterator[\"return\"];\n if (f)\n f.call(iterator);\n }\n // 9.1 Ordinary Object Internal Methods and Internal Slots\n // https://tc39.github.io/ecma262/#sec-ordinary-object-internal-methods-and-internal-slots\n // 9.1.1.1 OrdinaryGetPrototypeOf(O)\n // https://tc39.github.io/ecma262/#sec-ordinarygetprototypeof\n function OrdinaryGetPrototypeOf(O) {\n var proto = Object.getPrototypeOf(O);\n if (typeof O !== \"function\" || O === functionPrototype)\n return proto;\n // TypeScript doesn't set __proto__ in ES5, as it's non-standard.\n // Try to determine the superclass constructor. Compatible implementations\n // must either set __proto__ on a subclass constructor to the superclass constructor,\n // or ensure each class has a valid `constructor` property on its prototype that\n // points back to the constructor.\n // If this is not the same as Function.[[Prototype]], then this is definately inherited.\n // This is the case when in ES6 or when using __proto__ in a compatible browser.\n if (proto !== functionPrototype)\n return proto;\n // If the super prototype is Object.prototype, null, or undefined, then we cannot determine the heritage.\n var prototype = O.prototype;\n var prototypeProto = prototype && Object.getPrototypeOf(prototype);\n if (prototypeProto == null || prototypeProto === Object.prototype)\n return proto;\n // If the constructor was not a function, then we cannot determine the heritage.\n var constructor = prototypeProto.constructor;\n if (typeof constructor !== \"function\")\n return proto;\n // If we have some kind of self-reference, then we cannot determine the heritage.\n if (constructor === O)\n return proto;\n // we have a pretty good guess at the heritage.\n return constructor;\n }\n // naive Map shim\n function CreateMapPolyfill() {\n var cacheSentinel = {};\n var arraySentinel = [];\n var MapIterator = /** @class */ (function () {\n function MapIterator(keys, values, selector) {\n this._index = 0;\n this._keys = keys;\n this._values = values;\n this._selector = selector;\n }\n MapIterator.prototype[\"@@iterator\"] = function () { return this; };\n MapIterator.prototype[iteratorSymbol] = function () { return this; };\n MapIterator.prototype.next = function () {\n var index = this._index;\n if (index >= 0 && index < this._keys.length) {\n var result = this._selector(this._keys[index], this._values[index]);\n if (index + 1 >= this._keys.length) {\n this._index = -1;\n this._keys = arraySentinel;\n this._values = arraySentinel;\n }\n else {\n this._index++;\n }\n return { value: result, done: false };\n }\n return { value: undefined, done: true };\n };\n MapIterator.prototype.throw = function (error) {\n if (this._index >= 0) {\n this._index = -1;\n this._keys = arraySentinel;\n this._values = arraySentinel;\n }\n throw error;\n };\n MapIterator.prototype.return = function (value) {\n if (this._index >= 0) {\n this._index = -1;\n this._keys = arraySentinel;\n this._values = arraySentinel;\n }\n return { value: value, done: true };\n };\n return MapIterator;\n }());\n return /** @class */ (function () {\n function Map() {\n this._keys = [];\n this._values = [];\n this._cacheKey = cacheSentinel;\n this._cacheIndex = -2;\n }\n Object.defineProperty(Map.prototype, \"size\", {\n get: function () { return this._keys.length; },\n enumerable: true,\n configurable: true\n });\n Map.prototype.has = function (key) { return this._find(key, /*insert*/ false) >= 0; };\n Map.prototype.get = function (key) {\n var index = this._find(key, /*insert*/ false);\n return index >= 0 ? this._values[index] : undefined;\n };\n Map.prototype.set = function (key, value) {\n var index = this._find(key, /*insert*/ true);\n this._values[index] = value;\n return this;\n };\n Map.prototype.delete = function (key) {\n var index = this._find(key, /*insert*/ false);\n if (index >= 0) {\n var size = this._keys.length;\n for (var i = index + 1; i < size; i++) {\n this._keys[i - 1] = this._keys[i];\n this._values[i - 1] = this._values[i];\n }\n this._keys.length--;\n this._values.length--;\n if (key === this._cacheKey) {\n this._cacheKey = cacheSentinel;\n this._cacheIndex = -2;\n }\n return true;\n }\n return false;\n };\n Map.prototype.clear = function () {\n this._keys.length = 0;\n this._values.length = 0;\n this._cacheKey = cacheSentinel;\n this._cacheIndex = -2;\n };\n Map.prototype.keys = function () { return new MapIterator(this._keys, this._values, getKey); };\n Map.prototype.values = function () { return new MapIterator(this._keys, this._values, getValue); };\n Map.prototype.entries = function () { return new MapIterator(this._keys, this._values, getEntry); };\n Map.prototype[\"@@iterator\"] = function () { return this.entries(); };\n Map.prototype[iteratorSymbol] = function () { return this.entries(); };\n Map.prototype._find = function (key, insert) {\n if (this._cacheKey !== key) {\n this._cacheIndex = this._keys.indexOf(this._cacheKey = key);\n }\n if (this._cacheIndex < 0 && insert) {\n this._cacheIndex = this._keys.length;\n this._keys.push(key);\n this._values.push(undefined);\n }\n return this._cacheIndex;\n };\n return Map;\n }());\n function getKey(key, _) {\n return key;\n }\n function getValue(_, value) {\n return value;\n }\n function getEntry(key, value) {\n return [key, value];\n }\n }\n // naive Set shim\n function CreateSetPolyfill() {\n return /** @class */ (function () {\n function Set() {\n this._map = new _Map();\n }\n Object.defineProperty(Set.prototype, \"size\", {\n get: function () { return this._map.size; },\n enumerable: true,\n configurable: true\n });\n Set.prototype.has = function (value) { return this._map.has(value); };\n Set.prototype.add = function (value) { return this._map.set(value, value), this; };\n Set.prototype.delete = function (value) { return this._map.delete(value); };\n Set.prototype.clear = function () { this._map.clear(); };\n Set.prototype.keys = function () { return this._map.keys(); };\n Set.prototype.values = function () { return this._map.values(); };\n Set.prototype.entries = function () { return this._map.entries(); };\n Set.prototype[\"@@iterator\"] = function () { return this.keys(); };\n Set.prototype[iteratorSymbol] = function () { return this.keys(); };\n return Set;\n }());\n }\n // naive WeakMap shim\n function CreateWeakMapPolyfill() {\n var UUID_SIZE = 16;\n var keys = HashMap.create();\n var rootKey = CreateUniqueKey();\n return /** @class */ (function () {\n function WeakMap() {\n this._key = CreateUniqueKey();\n }\n WeakMap.prototype.has = function (target) {\n var table = GetOrCreateWeakMapTable(target, /*create*/ false);\n return table !== undefined ? HashMap.has(table, this._key) : false;\n };\n WeakMap.prototype.get = function (target) {\n var table = GetOrCreateWeakMapTable(target, /*create*/ false);\n return table !== undefined ? HashMap.get(table, this._key) : undefined;\n };\n WeakMap.prototype.set = function (target, value) {\n var table = GetOrCreateWeakMapTable(target, /*create*/ true);\n table[this._key] = value;\n return this;\n };\n WeakMap.prototype.delete = function (target) {\n var table = GetOrCreateWeakMapTable(target, /*create*/ false);\n return table !== undefined ? delete table[this._key] : false;\n };\n WeakMap.prototype.clear = function () {\n // NOTE: not a real clear, just makes the previous data unreachable\n this._key = CreateUniqueKey();\n };\n return WeakMap;\n }());\n function CreateUniqueKey() {\n var key;\n do\n key = \"@@WeakMap@@\" + CreateUUID();\n while (HashMap.has(keys, key));\n keys[key] = true;\n return key;\n }\n function GetOrCreateWeakMapTable(target, create) {\n if (!hasOwn.call(target, rootKey)) {\n if (!create)\n return undefined;\n Object.defineProperty(target, rootKey, { value: HashMap.create() });\n }\n return target[rootKey];\n }\n function FillRandomBytes(buffer, size) {\n for (var i = 0; i < size; ++i)\n buffer[i] = Math.random() * 0xff | 0;\n return buffer;\n }\n function GenRandomBytes(size) {\n if (typeof Uint8Array === \"function\") {\n if (typeof crypto !== \"undefined\")\n return crypto.getRandomValues(new Uint8Array(size));\n if (typeof msCrypto !== \"undefined\")\n return msCrypto.getRandomValues(new Uint8Array(size));\n return FillRandomBytes(new Uint8Array(size), size);\n }\n return FillRandomBytes(new Array(size), size);\n }\n function CreateUUID() {\n var data = GenRandomBytes(UUID_SIZE);\n // mark as random - RFC 4122 § 4.4\n data[6] = data[6] & 0x4f | 0x40;\n data[8] = data[8] & 0xbf | 0x80;\n var result = \"\";\n for (var offset = 0; offset < UUID_SIZE; ++offset) {\n var byte = data[offset];\n if (offset === 4 || offset === 6 || offset === 8)\n result += \"-\";\n if (byte < 16)\n result += \"0\";\n result += byte.toString(16).toLowerCase();\n }\n return result;\n }\n }\n // uses a heuristic used by v8 and chakra to force an object into dictionary mode.\n function MakeDictionary(obj) {\n obj.__ = undefined;\n delete obj.__;\n return obj;\n }\n });\n})(Reflect || (Reflect = {}));\n","/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nvar runtime = (function (exports) {\n \"use strict\";\n\n var Op = Object.prototype;\n var hasOwn = Op.hasOwnProperty;\n var undefined; // More compressible than void 0.\n var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n function define(obj, key, value) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n return obj[key];\n }\n try {\n // IE 8 has a broken Object.defineProperty that only works on DOM objects.\n define({}, \"\");\n } catch (err) {\n define = function(obj, key, value) {\n return obj[key] = value;\n };\n }\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n var generator = Object.create(protoGenerator.prototype);\n var context = new Context(tryLocsList || []);\n\n // The ._invoke method unifies the implementations of the .next,\n // .throw, and .return methods.\n generator._invoke = makeInvokeMethod(innerFn, self, context);\n\n return generator;\n }\n exports.wrap = wrap;\n\n // Try/catch helper to minimize deoptimizations. Returns a completion\n // record like context.tryEntries[i].completion. This interface could\n // have been (and was previously) designed to take a closure to be\n // invoked without arguments, but in all the cases we care about we\n // already have an existing method we want to call, so there's no need\n // to create a new function object. We can even get away with assuming\n // the method takes exactly one argument, since that happens to be true\n // in every case, so we don't have to touch the arguments object. The\n // only additional allocation required is the completion record, which\n // has a stable shape and so hopefully should be cheap to allocate.\n function tryCatch(fn, obj, arg) {\n try {\n return { type: \"normal\", arg: fn.call(obj, arg) };\n } catch (err) {\n return { type: \"throw\", arg: err };\n }\n }\n\n var GenStateSuspendedStart = \"suspendedStart\";\n var GenStateSuspendedYield = \"suspendedYield\";\n var GenStateExecuting = \"executing\";\n var GenStateCompleted = \"completed\";\n\n // Returning this object from the innerFn has the same effect as\n // breaking out of the dispatch switch statement.\n var ContinueSentinel = {};\n\n // Dummy constructor functions that we use as the .constructor and\n // .constructor.prototype properties for functions that return Generator\n // objects. For full spec compliance, you may wish to configure your\n // minifier not to mangle the names of these two functions.\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n\n // This is a polyfill for %IteratorPrototype% for environments that\n // don't natively support it.\n var IteratorPrototype = {};\n IteratorPrototype[iteratorSymbol] = function () {\n return this;\n };\n\n var getProto = Object.getPrototypeOf;\n var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n if (NativeIteratorPrototype &&\n NativeIteratorPrototype !== Op &&\n hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n // This environment has a native %IteratorPrototype%; use it instead\n // of the polyfill.\n IteratorPrototype = NativeIteratorPrototype;\n }\n\n var Gp = GeneratorFunctionPrototype.prototype =\n Generator.prototype = Object.create(IteratorPrototype);\n GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n GeneratorFunctionPrototype.constructor = GeneratorFunction;\n GeneratorFunction.displayName = define(\n GeneratorFunctionPrototype,\n toStringTagSymbol,\n \"GeneratorFunction\"\n );\n\n // Helper for defining the .next, .throw, and .return methods of the\n // Iterator interface in terms of a single ._invoke method.\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function(method) {\n define(prototype, method, function(arg) {\n return this._invoke(method, arg);\n });\n });\n }\n\n exports.isGeneratorFunction = function(genFun) {\n var ctor = typeof genFun === \"function\" && genFun.constructor;\n return ctor\n ? ctor === GeneratorFunction ||\n // For the native GeneratorFunction constructor, the best we can\n // do is to check its .name property.\n (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n : false;\n };\n\n exports.mark = function(genFun) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n } else {\n genFun.__proto__ = GeneratorFunctionPrototype;\n define(genFun, toStringTagSymbol, \"GeneratorFunction\");\n }\n genFun.prototype = Object.create(Gp);\n return genFun;\n };\n\n // Within the body of any async function, `await x` is transformed to\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n // meant to be awaited.\n exports.awrap = function(arg) {\n return { __await: arg };\n };\n\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (record.type === \"throw\") {\n reject(record.arg);\n } else {\n var result = record.arg;\n var value = result.value;\n if (value &&\n typeof value === \"object\" &&\n hasOwn.call(value, \"__await\")) {\n return PromiseImpl.resolve(value.__await).then(function(value) {\n invoke(\"next\", value, resolve, reject);\n }, function(err) {\n invoke(\"throw\", err, resolve, reject);\n });\n }\n\n return PromiseImpl.resolve(value).then(function(unwrapped) {\n // When a yielded Promise is resolved, its final value becomes\n // the .value of the Promise<{value,done}> result for the\n // current iteration.\n result.value = unwrapped;\n resolve(result);\n }, function(error) {\n // If a rejected Promise was yielded, throw the rejection back\n // into the async generator function so it can be handled there.\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n }\n\n var previousPromise;\n\n function enqueue(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function(resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n\n return previousPromise =\n // If enqueue has been called before, then we want to wait until\n // all previous Promises have been resolved before calling invoke,\n // so that results are always delivered in the correct order. If\n // enqueue has not been called before, then it is important to\n // call invoke immediately, without waiting on a callback to fire,\n // so that the async generator function has the opportunity to do\n // any necessary setup in a predictable way. This predictability\n // is why the Promise constructor synchronously invokes its\n // executor callback, and why async functions synchronously\n // execute code before the first await. Since we implement simple\n // async functions in terms of async generators, it is especially\n // important to get this right, even though it requires care.\n previousPromise ? previousPromise.then(\n callInvokeWithMethodAndArg,\n // Avoid propagating failures to Promises returned by later\n // invocations of the iterator.\n callInvokeWithMethodAndArg\n ) : callInvokeWithMethodAndArg();\n }\n\n // Define the unified helper method that is used to implement .next,\n // .throw, and .return (see defineIteratorMethods).\n this._invoke = enqueue;\n }\n\n defineIteratorMethods(AsyncIterator.prototype);\n AsyncIterator.prototype[asyncIteratorSymbol] = function () {\n return this;\n };\n exports.AsyncIterator = AsyncIterator;\n\n // Note that simple async functions are implemented on top of\n // AsyncIterator objects; they just return a Promise for the value of\n // the final result produced by the iterator.\n exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n if (PromiseImpl === void 0) PromiseImpl = Promise;\n\n var iter = new AsyncIterator(\n wrap(innerFn, outerFn, self, tryLocsList),\n PromiseImpl\n );\n\n return exports.isGeneratorFunction(outerFn)\n ? iter // If outerFn is a generator, return the full iterator.\n : iter.next().then(function(result) {\n return result.done ? result.value : iter.next();\n });\n };\n\n function makeInvokeMethod(innerFn, self, context) {\n var state = GenStateSuspendedStart;\n\n return function invoke(method, arg) {\n if (state === GenStateExecuting) {\n throw new Error(\"Generator is already running\");\n }\n\n if (state === GenStateCompleted) {\n if (method === \"throw\") {\n throw arg;\n }\n\n // Be forgiving, per 25.3.3.3.3 of the spec:\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n return doneResult();\n }\n\n context.method = method;\n context.arg = arg;\n\n while (true) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n\n if (context.method === \"next\") {\n // Setting context._sent for legacy support of Babel's\n // function.sent implementation.\n context.sent = context._sent = context.arg;\n\n } else if (context.method === \"throw\") {\n if (state === GenStateSuspendedStart) {\n state = GenStateCompleted;\n throw context.arg;\n }\n\n context.dispatchException(context.arg);\n\n } else if (context.method === \"return\") {\n context.abrupt(\"return\", context.arg);\n }\n\n state = GenStateExecuting;\n\n var record = tryCatch(innerFn, self, context);\n if (record.type === \"normal\") {\n // If an exception is thrown from innerFn, we leave state ===\n // GenStateExecuting and loop back for another invocation.\n state = context.done\n ? GenStateCompleted\n : GenStateSuspendedYield;\n\n if (record.arg === ContinueSentinel) {\n continue;\n }\n\n return {\n value: record.arg,\n done: context.done\n };\n\n } else if (record.type === \"throw\") {\n state = GenStateCompleted;\n // Dispatch the exception by looping back around to the\n // context.dispatchException(context.arg) call above.\n context.method = \"throw\";\n context.arg = record.arg;\n }\n }\n };\n }\n\n // Call delegate.iterator[context.method](context.arg) and handle the\n // result, either by returning a { value, done } result from the\n // delegate iterator, or by modifying context.method and context.arg,\n // setting context.delegate to null, and returning the ContinueSentinel.\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n if (method === undefined) {\n // A .throw or .return when the delegate iterator has no .throw\n // method always terminates the yield* loop.\n context.delegate = null;\n\n if (context.method === \"throw\") {\n // Note: [\"return\"] must be used for ES3 parsing compatibility.\n if (delegate.iterator[\"return\"]) {\n // If the delegate iterator has a return method, give it a\n // chance to clean up.\n context.method = \"return\";\n context.arg = undefined;\n maybeInvokeDelegate(delegate, context);\n\n if (context.method === \"throw\") {\n // If maybeInvokeDelegate(context) changed context.method from\n // \"return\" to \"throw\", let that override the TypeError below.\n return ContinueSentinel;\n }\n }\n\n context.method = \"throw\";\n context.arg = new TypeError(\n \"The iterator does not provide a 'throw' method\");\n }\n\n return ContinueSentinel;\n }\n\n var record = tryCatch(method, delegate.iterator, context.arg);\n\n if (record.type === \"throw\") {\n context.method = \"throw\";\n context.arg = record.arg;\n context.delegate = null;\n return ContinueSentinel;\n }\n\n var info = record.arg;\n\n if (! info) {\n context.method = \"throw\";\n context.arg = new TypeError(\"iterator result is not an object\");\n context.delegate = null;\n return ContinueSentinel;\n }\n\n if (info.done) {\n // Assign the result of the finished delegate to the temporary\n // variable specified by delegate.resultName (see delegateYield).\n context[delegate.resultName] = info.value;\n\n // Resume execution at the desired location (see delegateYield).\n context.next = delegate.nextLoc;\n\n // If context.method was \"throw\" but the delegate handled the\n // exception, let the outer generator proceed normally. If\n // context.method was \"next\", forget context.arg since it has been\n // \"consumed\" by the delegate iterator. If context.method was\n // \"return\", allow the original .return call to continue in the\n // outer generator.\n if (context.method !== \"return\") {\n context.method = \"next\";\n context.arg = undefined;\n }\n\n } else {\n // Re-yield the result returned by the delegate method.\n return info;\n }\n\n // The delegate iterator is finished, so forget it and continue with\n // the outer generator.\n context.delegate = null;\n return ContinueSentinel;\n }\n\n // Define Generator.prototype.{next,throw,return} in terms of the\n // unified ._invoke helper method.\n defineIteratorMethods(Gp);\n\n define(Gp, toStringTagSymbol, \"Generator\");\n\n // A Generator should always return itself as the iterator object when the\n // @@iterator function is called on it. Some browsers' implementations of the\n // iterator prototype chain incorrectly implement this, causing the Generator\n // object to not be returned from this call. This ensures that doesn't happen.\n // See https://github.com/facebook/regenerator/issues/274 for more details.\n Gp[iteratorSymbol] = function() {\n return this;\n };\n\n Gp.toString = function() {\n return \"[object Generator]\";\n };\n\n function pushTryEntry(locs) {\n var entry = { tryLoc: locs[0] };\n\n if (1 in locs) {\n entry.catchLoc = locs[1];\n }\n\n if (2 in locs) {\n entry.finallyLoc = locs[2];\n entry.afterLoc = locs[3];\n }\n\n this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\";\n delete record.arg;\n entry.completion = record;\n }\n\n function Context(tryLocsList) {\n // The root entry object (effectively a try statement without a catch\n // or a finally block) gives us a place to store values thrown from\n // locations where there is no enclosing try statement.\n this.tryEntries = [{ tryLoc: \"root\" }];\n tryLocsList.forEach(pushTryEntry, this);\n this.reset(true);\n }\n\n exports.keys = function(object) {\n var keys = [];\n for (var key in object) {\n keys.push(key);\n }\n keys.reverse();\n\n // Rather than returning an object with a next method, we keep\n // things simple and return the next function itself.\n return function next() {\n while (keys.length) {\n var key = keys.pop();\n if (key in object) {\n next.value = key;\n next.done = false;\n return next;\n }\n }\n\n // To avoid creating an additional object, we just hang the .value\n // and .done properties off the next function object itself. This\n // also ensures that the minifier will not anonymize the function.\n next.done = true;\n return next;\n };\n };\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) {\n return iteratorMethod.call(iterable);\n }\n\n if (typeof iterable.next === \"function\") {\n return iterable;\n }\n\n if (!isNaN(iterable.length)) {\n var i = -1, next = function next() {\n while (++i < iterable.length) {\n if (hasOwn.call(iterable, i)) {\n next.value = iterable[i];\n next.done = false;\n return next;\n }\n }\n\n next.value = undefined;\n next.done = true;\n\n return next;\n };\n\n return next.next = next;\n }\n }\n\n // Return an iterator with no values.\n return { next: doneResult };\n }\n exports.values = values;\n\n function doneResult() {\n return { value: undefined, done: true };\n }\n\n Context.prototype = {\n constructor: Context,\n\n reset: function(skipTempReset) {\n this.prev = 0;\n this.next = 0;\n // Resetting context._sent for legacy support of Babel's\n // function.sent implementation.\n this.sent = this._sent = undefined;\n this.done = false;\n this.delegate = null;\n\n this.method = \"next\";\n this.arg = undefined;\n\n this.tryEntries.forEach(resetTryEntry);\n\n if (!skipTempReset) {\n for (var name in this) {\n // Not sure about the optimal order of these conditions:\n if (name.charAt(0) === \"t\" &&\n hasOwn.call(this, name) &&\n !isNaN(+name.slice(1))) {\n this[name] = undefined;\n }\n }\n }\n },\n\n stop: function() {\n this.done = true;\n\n var rootEntry = this.tryEntries[0];\n var rootRecord = rootEntry.completion;\n if (rootRecord.type === \"throw\") {\n throw rootRecord.arg;\n }\n\n return this.rval;\n },\n\n dispatchException: function(exception) {\n if (this.done) {\n throw exception;\n }\n\n var context = this;\n function handle(loc, caught) {\n record.type = \"throw\";\n record.arg = exception;\n context.next = loc;\n\n if (caught) {\n // If the dispatched exception was caught by a catch block,\n // then let that catch block handle the exception normally.\n context.method = \"next\";\n context.arg = undefined;\n }\n\n return !! caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n var record = entry.completion;\n\n if (entry.tryLoc === \"root\") {\n // Exception thrown outside of any try block that could handle\n // it, so set the completion value of the entire function to\n // throw the exception.\n return handle(\"end\");\n }\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n } else if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n }\n\n } else if (hasFinally) {\n if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else {\n throw new Error(\"try statement without catch or finally\");\n }\n }\n }\n },\n\n abrupt: function(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev &&\n hasOwn.call(entry, \"finallyLoc\") &&\n this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n if (finallyEntry &&\n (type === \"break\" ||\n type === \"continue\") &&\n finallyEntry.tryLoc <= arg &&\n arg <= finallyEntry.finallyLoc) {\n // Ignore the finally entry if control is not jumping to a\n // location outside the try/catch block.\n finallyEntry = null;\n }\n\n var record = finallyEntry ? finallyEntry.completion : {};\n record.type = type;\n record.arg = arg;\n\n if (finallyEntry) {\n this.method = \"next\";\n this.next = finallyEntry.finallyLoc;\n return ContinueSentinel;\n }\n\n return this.complete(record);\n },\n\n complete: function(record, afterLoc) {\n if (record.type === \"throw\") {\n throw record.arg;\n }\n\n if (record.type === \"break\" ||\n record.type === \"continue\") {\n this.next = record.arg;\n } else if (record.type === \"return\") {\n this.rval = this.arg = record.arg;\n this.method = \"return\";\n this.next = \"end\";\n } else if (record.type === \"normal\" && afterLoc) {\n this.next = afterLoc;\n }\n\n return ContinueSentinel;\n },\n\n finish: function(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) {\n this.complete(entry.completion, entry.afterLoc);\n resetTryEntry(entry);\n return ContinueSentinel;\n }\n }\n },\n\n \"catch\": function(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (record.type === \"throw\") {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n\n // The context.catch method must only be called with a location\n // argument that corresponds to a known catch block.\n throw new Error(\"illegal catch attempt\");\n },\n\n delegateYield: function(iterable, resultName, nextLoc) {\n this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n };\n\n if (this.method === \"next\") {\n // Deliberately forget the last sent value so that we don't\n // accidentally pass it on to the delegate.\n this.arg = undefined;\n }\n\n return ContinueSentinel;\n }\n };\n\n // Regardless of whether this script is executing as a CommonJS module\n // or not, return the runtime object so that we can declare the variable\n // regeneratorRuntime in the outer scope, which allows this module to be\n // injected easily by `bin/regenerator --include-runtime script.js`.\n return exports;\n\n}(\n // If this script is executing as a CommonJS module, use module.exports\n // as the regeneratorRuntime namespace. Otherwise create a new empty\n // object. Either way, the resulting object will be used to initialize\n // the regeneratorRuntime variable at the top of this file.\n typeof module === \"object\" ? module.exports : {}\n));\n\ntry {\n regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n // This module should not be running in strict mode, so the above\n // assignment should always work unless something is misconfigured. Just\n // in case runtime.js accidentally runs in strict mode, we can escape\n // strict mode using a global Function call. This could conceivably fail\n // if a Content Security Policy forbids using Function, but in that case\n // the proper solution is to fix the accidental strict mode problem. If\n // you've misconfigured your bundler to force strict mode and applied a\n // CSP to forbid Function, and you're not willing to fix either of those\n // problems, please detail your unique predicament in a GitHub issue.\n Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n}\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","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tif(__webpack_module_cache__[moduleId]) {\n\t\treturn __webpack_module_cache__[moduleId].exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.nmd = (module) => {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","\"use strict\";\n\nrequire(\"./noConflict\");\n\nvar _global = _interopRequireDefault(require(\"core-js/library/fn/global\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nif (_global[\"default\"]._babelPolyfill && typeof console !== \"undefined\" && console.warn) {\n console.warn(\"@babel/polyfill is loaded more than once on this page. This is probably not desirable/intended \" + \"and may have consequences if different versions of the polyfills are applied sequentially. \" + \"If you do need to load the polyfill more than once, use @babel/polyfill/noConflict \" + \"instead to bypass the warning.\");\n}\n\n_global[\"default\"]._babelPolyfill = true;","import { Node, Edge, Combo, Model, PointTuple } from './types'\n\nexport class Base {\n public nodes: Node[] | null = []\n public edges: Edge[] | null = []\n public combos: Combo[] | null = []\n public positions: PointTuple[] | null = []\n public destroyed: boolean = false\n public onLayoutEnd: () => void = () => { } \n\n public layout(data: Model): Model {\n this.init(data)\n return this.execute(true)\n }\n\n public init(data: Model) {\n this.nodes = data.nodes || []\n this.edges = data.edges || []\n this.combos = data.combos || []\n }\n\n public execute(reloadData?: boolean): any {}\n public executeWithWorker() {}\n\n public getDefaultCfg() {\n return {}\n }\n\n public updateCfg(cfg: any) {\n if (cfg) {\n Object.assign(this, cfg)\n }\n }\n\n public getType() {\n return 'base'\n }\n\n public destroy() {\n this.nodes = null\n this.edges = null\n this.combos = null\n this.positions = null\n this.destroyed = true\n }\n}\n","export const isString = (val: unknown): val is string => typeof val === 'string'\n\nconst cacheStringFunction = <T extends (str: string) => string>(fn: T): T => {\n const cache: Record<string, string> = Object.create(null)\n return ((str: string) => {\n const hit = cache[str]\n return hit || (cache[str] = fn(str))\n }) as any\n}\n\nconst camelizeRE = /-(\\w)/g\nexport const camelize = cacheStringFunction((str: string): string => {\n return str.replace(camelizeRE, (_, c) => (c ? c.toUpperCase() : ''))\n})\n\n// export const capitalize = cacheStringFunction(\n// (str: string) => str.charAt(0).toUpperCase() + str.slice(1),\n// )\n","export const isArray = Array.isArray\n","export const isNumber = (val: unknown): val is Number => typeof val === 'number'\n\nexport const isNaN = (num: unknown) => Number.isNaN(Number(num))\n\nexport const toNumber = (val: any): any => {\n const n = parseFloat(val)\n return isNaN(n) ? val : n\n}","import { Matrix, Model, IndexMap, Edge } from '../layout/types'\n\nexport const getDegree = (n: number, nodeIdxMap: IndexMap, edges: Edge[] | null) => {\n const degrees: number[] = []\n for (let i = 0; i < n; i++) {\n degrees[i] = 0\n }\n if (!edges) return degrees\n edges.forEach((e) => {\n if (e.source) {\n degrees[nodeIdxMap[e.source]] += 1\n }\n if (e.target) {\n degrees[nodeIdxMap[e.target]] += 1\n }\n })\n return degrees\n}\n\nexport const floydWarshall = (adjMatrix: Matrix[]): Matrix[] => {\n // initialize\n const dist: Matrix[] = []\n const size = adjMatrix.length\n for (let i = 0; i < size; i += 1) {\n dist[i] = []\n for (let j = 0; j < size; j += 1) {\n if (i === j) {\n dist[i][j] = 0\n } else if (adjMatrix[i][j] === 0 || !adjMatrix[i][j]) {\n dist[i][j] = Infinity\n } else {\n dist[i][j] = adjMatrix[i][j]\n }\n }\n }\n // floyd\n for (let k = 0; k < size; k += 1) {\n for (let i = 0; i < size; i += 1) {\n for (let j = 0; j < size; j += 1) {\n if (dist[i][j] > dist[i][k] + dist[k][j]) {\n dist[i][j] = dist[i][k] + dist[k][j]\n }\n }\n }\n }\n return dist\n}\n\nexport const getAdjMatrix = (data: Model, directed: boolean): Matrix[] => {\n const {\n nodes,\n edges\n } = data\n const matrix: Matrix[] = []\n // map node with index in data.nodes\n const nodeMap: {\n [key: string]: number;\n } = {}\n\n if (!nodes) {\n throw new Error('invalid nodes data!')\n }\n if (nodes) {\n nodes.forEach((node, i) => {\n nodeMap[node.id] = i\n const row: number[] = []\n matrix.push(row)\n })\n }\n\n if (edges) {\n edges.forEach((e) => {\n const {\n source,\n target\n } = e\n const sIndex = nodeMap[source as string]\n const tIndex = nodeMap[target as string]\n matrix[sIndex][tIndex] = 1\n if (!directed) {\n matrix[tIndex][sIndex] = 1\n }\n })\n }\n\n return matrix\n}\n\n/**\n * scale matrix\n * @param matrix [ [], [], [] ]\n * @param ratio\n */\nexport const scaleMatrix = (matrix: Matrix[], ratio: number) => {\n const result: Matrix[] = []\n matrix.forEach((row) => {\n const newRow: number[] = []\n row.forEach((v) => {\n newRow.push(v * ratio)\n })\n result.push(newRow)\n })\n return result\n}\n\n/**\n * depth first traverse, from leaves to root, children in inverse order\n * if the fn returns false, terminate the traverse\n */\nconst traverseUp = <T extends { children?: T[] }>(data: T, fn: (param: T) => boolean) => {\n if (data && data.children) {\n for (let i = data.children.length - 1; i >= 0; i--) {\n if (!traverseUp(data.children[i], fn)) return\n }\n }\n\n if (!fn(data)) {\n return false\n }\n return true\n}\n\n/**\n * depth first traverse, from leaves to root, children in inverse order\n * if the fn returns false, terminate the traverse\n */\nexport const traverseTreeUp = <T extends { children?: T[] }>(\n data: T,\n fn: (param: T) => boolean,\n) => {\n if (typeof fn !== 'function') {\n return\n }\n traverseUp(data, fn)\n}\n","export const isObject = (val: unknown): val is Record<any, any> =>\n val !== null && typeof val === 'object'\n\nexport const clone = <T>(target: T): T => {\n if (target === null) {\n return target\n }\n if (target instanceof Date) {\n return new Date(target.getTime()) as any\n }\n if (target instanceof Array) {\n const cp = [] as any[]\n ;(target as any[]).forEach((v) => {\n cp.push(v)\n })\n return cp.map((n: any) => clone<any>(n)) as any\n }\n if (typeof target === 'object' && target !== {}) {\n const cp = { ...(target as { [key: string]: any }) } as {\n [key: string]: any\n }\n Object.keys(cp).forEach((k) => {\n cp[k] = clone<any>(cp[k])\n })\n return cp as T\n }\n return target\n}\n","export const isFunction = (val: unknown): val is Function =>\n typeof val === 'function'\n","import { Base } from \"../layout/base\"\nimport { isObject } from \"../util\"\n\nconst map: Map<string, any> = new Map()\n\nexport const registerLayout = (name: string, layoutOverride: any) => {\n if (map.get(name)) {\n console.warn(`The layout with the name ${name} exists already, it will be overridden`)\n }\n if (isObject(layoutOverride)) {\n // tslint:disable-next-line: max-classes-per-file\n class GLayout extends Base {\n constructor(cfg: any) {\n super()\n const self = this as any\n const props: any = {}\n const defaultCfg = self.getDefaultCfg()\n Object.assign(props, defaultCfg, layoutOverride, cfg as unknown)\n Object.keys(props).forEach((key: string) => {\n const value = props[key]\n self[key] = value\n })\n }\n }\n map.set(name, GLayout)\n } else {\n map.set(name, layoutOverride)\n }\n}\n\nexport const unRegisterLayout = (name: string) => {\n if (map.has(name)) {\n map.delete(name)\n }\n}\n\nexport const getLayoutByName = (name: string) => {\n if (map.has(name)) {\n return map.get(name)\n }\n return null\n}\n","/**\n * @fileOverview grid layout\n * @author shiwu.wyy@antfin.com\n * this algorithm refers to <cytoscape.js> - https://github.com/cytoscape/cytoscape.js/\n */\n\nimport { isString, isArray, isNumber, getDegree, isNaN } from \"../util\";\nimport { Base } from \"./base\";\nimport {\n OutNode,\n Edge,\n PointTuple,\n IndexMap,\n GridLayoutOptions\n} from \"./types\";\n\ntype INode = OutNode & {\n degree: number;\n size: number | PointTuple;\n};\n\n/**\n * 网格布局\n */\nexport class GridLayout extends Base {\n /** 布局起始点 */\n public begin: PointTuple = [0, 0];\n\n /** prevents node overlap, may overflow boundingBox if not enough space */\n public preventOverlap: boolean = true;\n\n /** extra spacing around nodes when preventOverlap: true */\n public preventOverlapPadding: number = 10;\n\n /** uses all available space on false, uses minimal space on true */\n public condense: boolean = false;\n\n /** force num of rows in the grid */\n public rows: number | undefined;\n\n /** force num of columns in the grid */\n public cols: number | undefined;\n\n /** returns { row, col } for element */\n public position:\n | ((node: INode) => { row?: number; col?: number })\n | undefined;\n\n /** a sorting function to order the nodes; e.g. function(a, b){ return a.datapublic ('weight') - b.data('weight') } */\n public sortBy: string = \"degree\";\n\n public nodeSize: number | number[] = 30;\n\n public nodes: INode[] = [];\n\n public edges: Edge[] = [];\n\n public width: number = 300;\n\n public height: number = 300;\n\n private cells: number | undefined;\n\n private row: number = 0;\n\n private col: number = 0;\n\n private splits: number | undefined;\n\n private columns: number | undefined;\n\n private cellWidth: number = 0;\n\n private cellHeight: number = 0;\n\n private cellUsed: {\n [key: string]: boolean;\n } = {};\n\n private id2manPos: {\n [key: string]: {\n row: number;\n col: number;\n };\n } = {};\n\n /** 迭代结束的回调函数 */\n public onLayoutEnd: () => void = () => {};\n\n constructor(options?: GridLayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {\n begin: [0, 0],\n preventOverlap: true,\n preventOverlapPadding: 10,\n condense: false,\n rows: undefined,\n cols: undefined,\n position: undefined,\n sortBy: \"degree\",\n nodeSize: 30\n };\n }\n\n /**\n * 执行布局\n */\n public execute() {\n const self = this;\n const nodes = self.nodes;\n const n = nodes.length;\n const begin = self.begin;\n if (n === 0) {\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n if (n === 1) {\n nodes[0].x = begin[0];\n nodes[0].y = begin[1];\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n\n const edges = self.edges;\n const layoutNodes: INode[] = [];\n nodes.forEach(node => {\n layoutNodes.push(node);\n });\n const nodeIdxMap: IndexMap = {};\n layoutNodes.forEach((node, i) => {\n nodeIdxMap[node.id] = i;\n });\n if (\n self.sortBy === \"degree\" ||\n !isString(self.sortBy) ||\n (layoutNodes[0] as any)[self.sortBy] === undefined\n ) {\n self.sortBy = \"degree\";\n if (isNaN(nodes[0].degree)) {\n const values = getDegree(layoutNodes.length, nodeIdxMap, edges);\n layoutNodes.forEach((node, i) => {\n node.degree = values[i];\n });\n }\n }\n // sort nodes by value\n layoutNodes.sort(\n (n1, n2) => (n2 as any)[self.sortBy] - (n1 as any)[self.sortBy]\n );\n\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n\n const oRows = self.rows;\n const oCols = self.cols != null ? self.cols : self.columns;\n self.cells = n;\n\n // if rows or columns were set in self, use those values\n if (oRows != null && oCols != null) {\n self.rows = oRows;\n self.cols = oCols;\n } else if (oRows != null && oCols == null) {\n self.rows = oRows;\n self.cols = Math.ceil(self.cells / self.rows);\n } else if (oRows == null && oCols != null) {\n self.cols = oCols;\n self.rows = Math.ceil(self.cells / self.cols);\n } else {\n // otherwise use the automatic values and adjust accordingly\t // otherwise use the automatic values and adjust accordingly\n // width/height * splits^2 = cells where splits is number of times to split width\n self.splits = Math.sqrt((self.cells * self.height) / self.width);\n self.rows = Math.round(self.splits);\n self.cols = Math.round((self.width / self.height) * self.splits);\n }\n if (self.cols * self.rows > self.cells) {\n // otherwise use the automatic values and adjust accordingly\n // if rounding was up, see if we can reduce rows or columns\n const sm = self.small() as number;\n const lg = self.large() as number;\n\n // reducing the small side takes away the most cells, so try it first\n if ((sm - 1) * lg >= self.cells) {\n self.small(sm - 1);\n } else if ((lg - 1) * sm >= self.cells) {\n self.large(lg - 1);\n }\n } else {\n // if rounding was too low, add rows or columns\n while (self.cols * self.rows < self.cells) {\n const sm = self.small() as number;\n const lg = self.large() as number;\n\n // try to add to larger side first (adds less in multiplication)\n if ((lg + 1) * sm >= self.cells) {\n self.large(lg + 1);\n } else {\n self.small(sm + 1);\n }\n }\n }\n\n self.cellWidth = self.width / self.cols;\n self.cellHeight = self.height / self.rows;\n\n if (self.condense) {\n self.cellWidth = 0;\n self.cellHeight = 0;\n }\n\n if (self.preventOverlap) {\n layoutNodes.forEach(node => {\n if (!node.x || !node.y) {\n // for bb\n node.x = 0;\n node.y = 0;\n }\n\n let nodew: number | undefined;\n let nodeh: number | undefined;\n if (isArray(node.size)) {\n nodew = (node.size as PointTuple)[0];\n nodeh = (node.size as PointTuple)[1];\n } else if (isNumber(node.size)) {\n nodew = node.size as number;\n nodeh = node.size as number;\n }\n if (nodew === undefined || nodeh === undefined) {\n if (isArray(self.nodeSize)) {\n nodew = (self.nodeSize as number[])[0];\n nodeh = (self.nodeSize as number[])[1];\n } else if (isNumber(self.nodeSize)) {\n nodew = self.nodeSize as number;\n nodeh = self.nodeSize as number;\n } else {\n nodew = 30;\n nodeh = 30;\n }\n }\n\n const p = self.preventOverlapPadding;\n\n const w = nodew + p;\n const h = nodeh + p;\n\n self.cellWidth = Math.max(self.cellWidth, w);\n self.cellHeight = Math.max(self.cellHeight, h);\n });\n }\n\n self.cellUsed = {}; // e.g. 'c-0-2' => true\n\n // to keep track of current cell position\n self.row = 0;\n self.col = 0;\n\n // get a cache of all the manual positions\n self.id2manPos = {};\n for (let i = 0; i < layoutNodes.length; i++) {\n const node = layoutNodes[i];\n let rcPos;\n if (self.position) {\n rcPos = self.position(node);\n }\n\n if (rcPos && (rcPos.row !== undefined || rcPos.col !== undefined)) {\n // must have at least row or col def'd\n const pos = {\n row: rcPos.row,\n col: rcPos.col\n };\n\n if (pos.col === undefined) {\n // find unused col\n pos.col = 0;\n\n while (self.used(pos.row, pos.col)) {\n pos.col++;\n }\n } else if (pos.row === undefined) {\n // find unused row\n pos.row = 0;\n\n while (self.used(pos.row, pos.col)) {\n pos.row++;\n }\n }\n\n self.id2manPos[node.id] = pos as { row: number; col: number };\n self.use(pos.row, pos.col);\n }\n self.getPos(node);\n }\n\n if (self.onLayoutEnd) self.onLayoutEnd();\n\n return {\n edges,\n nodes: layoutNodes\n };\n }\n\n private small(val?: number): number | undefined {\n const self = this;\n let res: number | undefined;\n const rows = self.rows || 5;\n const cols = self.cols || 5;\n if (val == null) {\n res = Math.min(rows, cols);\n } else {\n const min = Math.min(rows, cols);\n if (min === self.rows) {\n self.rows = val;\n } else {\n self.cols = val;\n }\n }\n return res;\n }\n\n private large(val?: number): number | undefined {\n const self = this;\n let res: number | undefined;\n const rows = self.rows || 5;\n const cols = self.cols || 5;\n if (val == null) {\n res = Math.max(rows, cols);\n } else {\n const max = Math.max(rows, cols);\n if (max === self.rows) {\n self.rows = val;\n } else {\n self.cols = val;\n }\n }\n return res;\n }\n\n private used(row: number | undefined, col: number | undefined) {\n const self = this;\n return self.cellUsed[`c-${row}-${col}`] || false;\n }\n\n private use(row: number | undefined, col: number | undefined) {\n const self = this;\n self.cellUsed[`c-${row}-${col}`] = true;\n }\n\n private moveToNextCell() {\n const self = this;\n const cols = self.cols || 5;\n self.col++;\n if (self.col >= cols) {\n self.col = 0;\n self.row++;\n }\n }\n\n private getPos(node: INode) {\n const self = this;\n const begin = self.begin;\n const cellWidth = self.cellWidth;\n const cellHeight = self.cellHeight;\n let x: number;\n let y: number;\n\n // see if we have a manual position set\n const rcPos = self.id2manPos[node.id];\n if (rcPos) {\n x = rcPos.col * cellWidth + cellWidth / 2 + begin[0];\n y = rcPos.row * cellHeight + cellHeight / 2 + begin[1];\n } else {\n // otherwise set automatically\n\n while (self.used(self.row, self.col)) {\n self.moveToNextCell();\n }\n\n x = self.col * cellWidth + cellWidth / 2 + begin[0];\n y = self.row * cellHeight + cellHeight / 2 + begin[1];\n self.use(self.row, self.col);\n\n self.moveToNextCell();\n }\n node.x = x;\n node.y = y;\n }\n\n public getType() {\n return \"grid\";\n }\n}\n","/**\n * @fileOverview random layout\n * @author shiwu.wyy@antfin.com\n */\n\nimport { PointTuple, OutNode, Edge, RandomLayoutOptions } from \"./types\";\nimport { Base } from \"./base\";\n\n/**\n * 随机布局\n */\nexport class RandomLayout extends Base {\n /** 布局中心 */\n public center: PointTuple = [0, 0];\n\n /** 宽度 */\n public width: number = 300;\n\n /** 高度 */\n public height: number = 300;\n\n public nodes: OutNode[] = [];\n\n public edges: Edge[] = [];\n\n /** 迭代结束的回调函数 */\n public onLayoutEnd: () => void = () => {};\n\n constructor(options?: RandomLayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {\n center: [0, 0],\n width: 300,\n height: 300\n };\n }\n\n /**\n * 执行布局\n */\n public execute() {\n const self = this;\n const nodes = self.nodes;\n const layoutScale = 0.9;\n const center = self.center;\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n\n if (nodes) {\n nodes.forEach(node => {\n node.x = (Math.random() - 0.5) * layoutScale * self.width + center[0];\n node.y = (Math.random() - 0.5) * layoutScale * self.height + center[1];\n });\n }\n\n if (self.onLayoutEnd) self.onLayoutEnd();\n\n return {\n nodes,\n edges: this.edges\n };\n }\n\n public getType() {\n return \"random\";\n }\n}\n","/**\n * @fileOverview fruchterman layout\n * @author shiwu.wyy@antfin.com\n */\n\nimport {\n OutNode,\n Edge,\n PointTuple,\n IndexMap,\n Point,\n GForceLayoutOptions\n} from \"./types\";\nimport { Base } from \"./base\";\nimport { isNumber, isFunction, isArray, getDegree } from \"../util\";\n\ntype INode = OutNode & {\n size: number | PointTuple;\n};\n\ntype NodeMap = {\n [key: string]: INode;\n};\n\nconst proccessToFunc = (\n value: number | Function | undefined,\n defaultV?: number\n): ((d: any) => number) => {\n let func;\n if (!value) {\n func = (d: any): number => {\n return defaultV || 1;\n };\n } else if (isNumber(value)) {\n func = (d: any): number => {\n return value;\n };\n } else {\n func = value;\n }\n return func as any;\n};\n\n/**\n * graphin 中的 force 布局\n */\nexport class GForceLayout extends Base {\n /** 布局中心 */\n public center: PointTuple;\n\n /** 停止迭代的最大迭代数 */\n public maxIteration: number = 1000;\n\n /** 弹簧引力系数 */\n public edgeStrength: number | ((d?: any) => number) | undefined = 200;\n\n /** 斥力系数 */\n public nodeStrength: number | ((d?: any) => number) | undefined = 1000;\n\n /** 库伦系数 */\n public coulombDisScale: number = 0.005;\n\n /** 阻尼系数 */\n public damping: number = 0.9;\n\n /** 最大速度 */\n public maxSpeed: number = 1000;\n\n /** 一次迭代的平均移动距离小于该值时停止迭代 */\n public minMovement: number = 0.5;\n\n /** 迭代中衰减 */\n public interval: number = 0.02;\n\n /** 斥力的一个系数 */\n public factor: number = 1;\n\n /** 每个节点质量的回调函数,若不指定,则默认使用度数作为节点质量 */\n public getMass: ((d?: any) => number) | undefined;\n\n /** 每个节点中心力的 x、y、强度的回调函数,若不指定,则没有额外中心力 */\n public getCenter: ((d?: any, degree?: number) => number[]) | undefined;\n\n /** 理想边长 */\n public linkDistance: number | ((d?: any) => number) | undefined = 1;\n\n /** 重力大小 */\n public gravity: number = 10;\n\n /** 是否防止重叠 */\n public preventOverlap: boolean = true;\n\n /** 防止重叠时的节点大小,默认从节点数据中取 size */\n public nodeSize: number | number[] | ((d?: any) => number) | undefined;\n\n /** 防止重叠时的节点之间最小间距 */\n public nodeSpacing: number | number[] | ((d?: any) => number) | undefined;\n\n /** 每次迭代结束的回调函数 */\n public tick: (() => void) | null = () => {};\n\n /** 是否允许每次迭代结束调用回调函数 */\n public enableTick: boolean;\n\n public nodes: INode[] | null = [];\n\n public edges: Edge[] | null = [];\n\n public width: number = 300;\n\n public height: number = 300;\n\n public nodeMap: NodeMap = {};\n\n public nodeIdxMap: IndexMap = {};\n\n public canvasEl: HTMLCanvasElement;\n\n public onLayoutEnd: () => void;\n\n /** 存储节点度数 */\n private degrees: number[];\n\n /** 迭代中的标识 */\n private timeInterval: number;\n\n constructor(options?: GForceLayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {\n maxIteration: 500,\n gravity: 10,\n enableTick: true\n };\n }\n\n /**\n * 执行布局\n */\n public execute() {\n const self = this;\n const nodes = self.nodes;\n\n if (self.timeInterval !== undefined && typeof window !== \"undefined\") {\n window.clearInterval(self.timeInterval);\n }\n\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n const nodeMap: NodeMap = {};\n const nodeIdxMap: IndexMap = {};\n nodes.forEach((node, i) => {\n if (!isNumber(node.x)) node.x = Math.random() * self.width;\n if (!isNumber(node.y)) node.y = Math.random() * self.height;\n nodeMap[node.id] = node;\n nodeIdxMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.nodeIdxMap = nodeIdxMap;\n\n self.linkDistance = proccessToFunc(self.linkDistance, 1);\n self.nodeStrength = proccessToFunc(self.nodeStrength, 1);\n self.edgeStrength = proccessToFunc(self.edgeStrength, 1);\n\n // node size function\n const nodeSize = self.nodeSize;\n let nodeSizeFunc;\n if (self.preventOverlap) {\n const nodeSpacing = self.nodeSpacing;\n let nodeSpacingFunc: (d?: any) => number;\n if (isNumber(nodeSpacing)) {\n nodeSpacingFunc = () => nodeSpacing as number;\n } else if (isFunction(nodeSpacing)) {\n nodeSpacingFunc = nodeSpacing as (d?: any) => number;\n } else {\n nodeSpacingFunc = () => 0;\n }\n if (!nodeSize) {\n nodeSizeFunc = (d: INode) => {\n if (d.size) {\n if (isArray(d.size)) {\n const res = d.size[0] > d.size[1] ? d.size[0] : d.size[1];\n return res + nodeSpacingFunc(d);\n }\n return (d.size as number) + nodeSpacingFunc(d);\n }\n return 10 + nodeSpacingFunc(d);\n };\n } else if (isArray(nodeSize)) {\n nodeSizeFunc = (d: INode) => {\n const res = nodeSize[0] > nodeSize[1] ? nodeSize[0] : nodeSize[1];\n return res + nodeSpacingFunc(d);\n };\n } else {\n nodeSizeFunc = (d: INode) => (nodeSize as number) + nodeSpacingFunc(d);\n }\n }\n self.nodeSize = nodeSizeFunc;\n\n const edges = self.edges;\n self.degrees = getDegree(nodes.length, self.nodeIdxMap, edges);\n if (!self.getMass) {\n self.getMass = d => {\n const mass = self.degrees[self.nodeIdxMap[d.id]] || 1;\n return mass;\n };\n }\n\n // layout\n self.run();\n }\n\n public run() {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n const maxIteration = self.maxIteration;\n\n if (typeof window === \"undefined\") return;\n\n let iter = 0;\n // interval for render the result after each iteration\n this.timeInterval = window.setInterval(() => {\n const accArray: number[] = [];\n const velArray: number[] = [];\n if (!nodes) return;\n nodes.forEach((_, i) => {\n accArray[2 * i] = 0;\n accArray[2 * i + 1] = 0;\n velArray[2 * i] = 0;\n velArray[2 * i + 1] = 0;\n });\n self.calRepulsive(accArray, nodes);\n if (edges) self.calAttractive(accArray, edges);\n self.calGravity(accArray, nodes);\n const stepInterval = Math.max(0.02, self.interval - iter * 0.002);\n self.updateVelocity(accArray, velArray, stepInterval, nodes);\n const previousPos: Point[] = [];\n nodes.forEach(node => {\n previousPos.push({\n x: node.x,\n y: node.y\n });\n });\n self.updatePosition(velArray, stepInterval, nodes);\n if (self.tick) self.tick();\n\n // whether to stop the iteration\n let movement = 0;\n nodes.forEach((node, j) => {\n const vx = node.x - previousPos[j].x;\n const vy = node.y - previousPos[j].y;\n movement += Math.sqrt(vx * vx + vy * vy);\n });\n movement /= nodes.length;\n if (movement < self.minMovement) {\n window.clearInterval(self.timeInterval);\n if (self.onLayoutEnd) self.onLayoutEnd();\n }\n iter++;\n if (iter >= maxIteration) {\n if (self.onLayoutEnd) self.onLayoutEnd();\n window.clearInterval(self.timeInterval);\n }\n }, 0);\n }\n\n public calRepulsive(accArray: number[], nodes: INode[]) {\n const self = this;\n // const nodes = self.nodes;\n const getMass = self.getMass;\n const nodeStrength = self.nodeStrength as Function;\n const factor = self.factor;\n const coulombDisScale = self.coulombDisScale;\n const preventOverlap = self.preventOverlap;\n const nodeSize = self.nodeSize as Function;\n nodes.forEach((ni: INode, i) => {\n const massi = getMass ? getMass(ni) : 1;\n nodes.forEach((nj, j) => {\n if (i >= j) return;\n // if (!accArray[j]) accArray[j] = 0;\n const vecX = ni.x - nj.x;\n const vecY = ni.y - nj.y;\n const vecLength = Math.sqrt(vecX * vecX + vecY * vecY) + 0.01;\n const nVecLength = (vecLength + 0.1) * coulombDisScale;\n const direX = vecX / vecLength;\n const direY = vecY / vecLength;\n const param =\n (((nodeStrength(ni) + nodeStrength(nj)) / 2) * factor) /\n (nVecLength * nVecLength);\n const massj = getMass ? getMass(nj) : 1;\n accArray[2 * i] += (direX * param);\n accArray[2 * i + 1] += (direY * param);\n accArray[2 * j] -= (direX * param);\n accArray[2 * j + 1] -= (direY * param);\n if (preventOverlap && vecLength < (nodeSize(ni) + nodeSize(nj)) / 2) {\n const paramOverlap =\n (nodeStrength(ni) + nodeStrength(nj)) / 2 / (vecLength * vecLength);\n accArray[2 * i] += (direX * paramOverlap) / massi;\n accArray[2 * i + 1] += (direY * paramOverlap) / massi;\n accArray[2 * j] -= (direX * paramOverlap) / massj;\n accArray[2 * j + 1] -= (direY * paramOverlap) / massj;\n }\n });\n });\n }\n\n public calAttractive(accArray: number[], edges: Edge[]) {\n const self = this;\n // const edges = self.edges;\n const nodeMap = self.nodeMap;\n const nodeIdxMap = self.nodeIdxMap;\n const linkDistance = self.linkDistance as Function;\n const edgeStrength = self.edgeStrength as Function;\n const getMass = self.getMass;\n edges.forEach((edge, i) => {\n const sourceNode = nodeMap[edge.source];\n const targetNode = nodeMap[edge.target];\n const vecX = targetNode.x - sourceNode.x;\n const vecY = targetNode.y - sourceNode.y;\n const vecLength = Math.sqrt(vecX * vecX + vecY * vecY) + 0.01;\n const direX = vecX / vecLength;\n const direY = vecY / vecLength;\n const length = linkDistance(edge) || 1;\n const diff = length - vecLength;\n const param = diff * edgeStrength(edge);\n const sourceIdx = nodeIdxMap[edge.source];\n const targetIdx = nodeIdxMap[edge.target];\n const massSource = getMass ? getMass(sourceNode) : 1;\n const massTarget = getMass ? getMass(targetNode) : 1;\n accArray[2 * sourceIdx] -= (direX * param) / massSource;\n accArray[2 * sourceIdx + 1] -= (direY * param) / massSource;\n accArray[2 * targetIdx] += (direX * param) / massTarget;\n accArray[2 * targetIdx + 1] += (direY * param) / massTarget;\n });\n }\n\n public calGravity(accArray: number[], nodes: INode[]) {\n const self = this;\n // const nodes = self.nodes;\n const center = self.center;\n const defaultGravity = self.gravity;\n const degrees = self.degrees;\n const nodeLength = nodes.length;\n for (let i = 0; i < nodeLength; i++) {\n const node = nodes[i];\n let vecX = node.x - center[0];\n let vecY = node.y - center[1];\n let gravity = defaultGravity;\n\n if (self.getCenter) {\n const customCenterOpt = self.getCenter(node, degrees[i]);\n if (\n customCenterOpt &&\n isNumber(customCenterOpt[0]) &&\n isNumber(customCenterOpt[1]) &&\n isNumber(customCenterOpt[2])\n ) {\n vecX = node.x - customCenterOpt[0];\n vecY = node.y - customCenterOpt[1];\n gravity = customCenterOpt[2];\n }\n }\n if (!gravity) continue;\n\n accArray[2 * i] -= gravity * vecX;\n accArray[2 * i + 1] -= gravity * vecY;\n }\n }\n\n public updateVelocity(\n accArray: number[],\n velArray: number[],\n stepInterval: number,\n nodes: INode[]\n ) {\n const self = this;\n const param = stepInterval * self.damping;\n // const nodes = self.nodes;\n nodes.forEach((node, i) => {\n let vx = accArray[2 * i] * param || 0.01;\n let vy = accArray[2 * i + 1] * param || 0.01;\n const vLength = Math.sqrt(vx * vx + vy * vy);\n if (vLength > self.maxSpeed) {\n const param2 = self.maxSpeed / vLength;\n vx = param2 * vx;\n vy = param2 * vy;\n }\n velArray[2 * i] = vx;\n velArray[2 * i + 1] = vy;\n });\n }\n\n public updatePosition(\n velArray: number[],\n stepInterval: number,\n nodes: INode[]\n ) {\n nodes.forEach((node: any, i) => {\n if (isNumber(node.fx) && isNumber(node.fy)) {\n node.x = node.fx;\n node.y = node.fy;\n return;\n }\n const distX = velArray[2 * i] * stepInterval;\n const distY = velArray[2 * i + 1] * stepInterval;\n node.x += distX;\n node.y += distY;\n });\n }\n\n public stop() {\n if (this.timeInterval && typeof window !== \"undefined\") {\n window.clearInterval(this.timeInterval);\n }\n }\n\n public destroy() {\n const self = this;\n self.stop();\n self.tick = null;\n self.nodes = null;\n self.edges = null;\n self.destroyed = true;\n }\n\n public getType() {\n return \"gForce\";\n }\n}\n","export default function(d) {\n const x = +this._x.call(null, d),\n y = +this._y.call(null, d);\n return add(this.cover(x, y), x, y, d);\n}\n\nfunction add(tree, x, y, d) {\n if (isNaN(x) || isNaN(y)) return tree; // ignore invalid points\n\n var parent,\n node = tree._root,\n leaf = {data: d},\n x0 = tree._x0,\n y0 = tree._y0,\n x1 = tree._x1,\n y1 = tree._y1,\n xm,\n ym,\n xp,\n yp,\n right,\n bottom,\n i,\n j;\n\n // If the tree is empty, initialize the root as a leaf.\n if (!node) return tree._root = leaf, tree;\n\n // Find the existing leaf for the new point, or add it.\n while (node.length) {\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n if (parent = node, !(node = node[i = bottom << 1 | right])) return parent[i] = leaf, tree;\n }\n\n // Is the new point is exactly coincident with the existing point?\n xp = +tree._x.call(null, node.data);\n yp = +tree._y.call(null, node.data);\n if (x === xp && y === yp) return leaf.next = node, parent ? parent[i] = leaf : tree._root = leaf, tree;\n\n // Otherwise, split the leaf node until the old and new point are separated.\n do {\n parent = parent ? parent[i] = new Array(4) : tree._root = new Array(4);\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n } while ((i = bottom << 1 | right) === (j = (yp >= ym) << 1 | (xp >= xm)));\n return parent[j] = node, parent[i] = leaf, tree;\n}\n\nexport function addAll(data) {\n var d, i, n = data.length,\n x,\n y,\n xz = new Array(n),\n yz = new Array(n),\n x0 = Infinity,\n y0 = Infinity,\n x1 = -Infinity,\n y1 = -Infinity;\n\n // Compute the points and their extent.\n for (i = 0; i < n; ++i) {\n if (isNaN(x = +this._x.call(null, d = data[i])) || isNaN(y = +this._y.call(null, d))) continue;\n xz[i] = x;\n yz[i] = y;\n if (x < x0) x0 = x;\n if (x > x1) x1 = x;\n if (y < y0) y0 = y;\n if (y > y1) y1 = y;\n }\n\n // If there were no (valid) points, abort.\n if (x0 > x1 || y0 > y1) return this;\n\n // Expand the tree to cover the new points.\n this.cover(x0, y0).cover(x1, y1);\n\n // Add the new points.\n for (i = 0; i < n; ++i) {\n add(this, xz[i], yz[i], data[i]);\n }\n\n return this;\n}\n","export default function(node, x0, y0, x1, y1) {\n this.node = node;\n this.x0 = x0;\n this.y0 = y0;\n this.x1 = x1;\n this.y1 = y1;\n}\n","export function defaultX(d) {\n return d[0];\n}\n\nexport default function(_) {\n return arguments.length ? (this._x = _, this) : this._x;\n}\n","export function defaultY(d) {\n return d[1];\n}\n\nexport default function(_) {\n return arguments.length ? (this._y = _, this) : this._y;\n}\n","import tree_add, {addAll as tree_addAll} from \"./add.js\";\nimport tree_cover from \"./cover.js\";\nimport tree_data from \"./data.js\";\nimport tree_extent from \"./extent.js\";\nimport tree_find from \"./find.js\";\nimport tree_remove, {removeAll as tree_removeAll} from \"./remove.js\";\nimport tree_root from \"./root.js\";\nimport tree_size from \"./size.js\";\nimport tree_visit from \"./visit.js\";\nimport tree_visitAfter from \"./visitAfter.js\";\nimport tree_x, {defaultX} from \"./x.js\";\nimport tree_y, {defaultY} from \"./y.js\";\n\nexport default function quadtree(nodes, x, y) {\n var tree = new Quadtree(x == null ? defaultX : x, y == null ? defaultY : y, NaN, NaN, NaN, NaN);\n return nodes == null ? tree : tree.addAll(nodes);\n}\n\nfunction Quadtree(x, y, x0, y0, x1, y1) {\n this._x = x;\n this._y = y;\n this._x0 = x0;\n this._y0 = y0;\n this._x1 = x1;\n this._y1 = y1;\n this._root = undefined;\n}\n\nfunction leaf_copy(leaf) {\n var copy = {data: leaf.data}, next = copy;\n while (leaf = leaf.next) next = next.next = {data: leaf.data};\n return copy;\n}\n\nvar treeProto = quadtree.prototype = Quadtree.prototype;\n\ntreeProto.copy = function() {\n var copy = new Quadtree(this._x, this._y, this._x0, this._y0, this._x1, this._y1),\n node = this._root,\n nodes,\n child;\n\n if (!node) return copy;\n\n if (!node.length) return copy._root = leaf_copy(node), copy;\n\n nodes = [{source: node, target: copy._root = new Array(4)}];\n while (node = nodes.pop()) {\n for (var i = 0; i < 4; ++i) {\n if (child = node.source[i]) {\n if (child.length) nodes.push({source: child, target: node.target[i] = new Array(4)});\n else node.target[i] = leaf_copy(child);\n }\n }\n }\n\n return copy;\n};\n\ntreeProto.add = tree_add;\ntreeProto.addAll = tree_addAll;\ntreeProto.cover = tree_cover;\ntreeProto.data = tree_data;\ntreeProto.extent = tree_extent;\ntreeProto.find = tree_find;\ntreeProto.remove = tree_remove;\ntreeProto.removeAll = tree_removeAll;\ntreeProto.root = tree_root;\ntreeProto.size = tree_size;\ntreeProto.visit = tree_visit;\ntreeProto.visitAfter = tree_visitAfter;\ntreeProto.x = tree_x;\ntreeProto.y = tree_y;\n","export default function(x) {\n return function() {\n return x;\n };\n}\n","export default function(random) {\n return (random() - 0.5) * 1e-6;\n}\n","export default function(x, y) {\n if (isNaN(x = +x) || isNaN(y = +y)) return this; // ignore invalid points\n\n var x0 = this._x0,\n y0 = this._y0,\n x1 = this._x1,\n y1 = this._y1;\n\n // If the quadtree has no extent, initialize them.\n // Integer extent are necessary so that if we later double the extent,\n // the existing quadrant boundaries don’t change due to floating point error!\n if (isNaN(x0)) {\n x1 = (x0 = Math.floor(x)) + 1;\n y1 = (y0 = Math.floor(y)) + 1;\n }\n\n // Otherwise, double repeatedly to cover.\n else {\n var z = x1 - x0 || 1,\n node = this._root,\n parent,\n i;\n\n while (x0 > x || x >= x1 || y0 > y || y >= y1) {\n i = (y < y0) << 1 | (x < x0);\n parent = new Array(4), parent[i] = node, node = parent, z *= 2;\n switch (i) {\n case 0: x1 = x0 + z, y1 = y0 + z; break;\n case 1: x0 = x1 - z, y1 = y0 + z; break;\n case 2: x1 = x0 + z, y0 = y1 - z; break;\n case 3: x0 = x1 - z, y0 = y1 - z; break;\n }\n }\n\n if (this._root && this._root.length) this._root = node;\n }\n\n this._x0 = x0;\n this._y0 = y0;\n this._x1 = x1;\n this._y1 = y1;\n return this;\n}\n","export default function() {\n var data = [];\n this.visit(function(node) {\n if (!node.length) do data.push(node.data); while (node = node.next)\n });\n return data;\n}\n","export default function(_) {\n return arguments.length\n ? this.cover(+_[0][0], +_[0][1]).cover(+_[1][0], +_[1][1])\n : isNaN(this._x0) ? undefined : [[this._x0, this._y0], [this._x1, this._y1]];\n}\n","import Quad from \"./quad.js\";\n\nexport default function(x, y, radius) {\n var data,\n x0 = this._x0,\n y0 = this._y0,\n x1,\n y1,\n x2,\n y2,\n x3 = this._x1,\n y3 = this._y1,\n quads = [],\n node = this._root,\n q,\n i;\n\n if (node) quads.push(new Quad(node, x0, y0, x3, y3));\n if (radius == null) radius = Infinity;\n else {\n x0 = x - radius, y0 = y - radius;\n x3 = x + radius, y3 = y + radius;\n radius *= radius;\n }\n\n while (q = quads.pop()) {\n\n // Stop searching if this quadrant can’t contain a closer node.\n if (!(node = q.node)\n || (x1 = q.x0) > x3\n || (y1 = q.y0) > y3\n || (x2 = q.x1) < x0\n || (y2 = q.y1) < y0) continue;\n\n // Bisect the current quadrant.\n if (node.length) {\n var xm = (x1 + x2) / 2,\n ym = (y1 + y2) / 2;\n\n quads.push(\n new Quad(node[3], xm, ym, x2, y2),\n new Quad(node[2], x1, ym, xm, y2),\n new Quad(node[1], xm, y1, x2, ym),\n new Quad(node[0], x1, y1, xm, ym)\n );\n\n // Visit the closest quadrant first.\n if (i = (y >= ym) << 1 | (x >= xm)) {\n q = quads[quads.length - 1];\n quads[quads.length - 1] = quads[quads.length - 1 - i];\n quads[quads.length - 1 - i] = q;\n }\n }\n\n // Visit this point. (Visiting coincident points isn’t necessary!)\n else {\n var dx = x - +this._x.call(null, node.data),\n dy = y - +this._y.call(null, node.data),\n d2 = dx * dx + dy * dy;\n if (d2 < radius) {\n var d = Math.sqrt(radius = d2);\n x0 = x - d, y0 = y - d;\n x3 = x + d, y3 = y + d;\n data = node.data;\n }\n }\n }\n\n return data;\n}\n","export default function(d) {\n if (isNaN(x = +this._x.call(null, d)) || isNaN(y = +this._y.call(null, d))) return this; // ignore invalid points\n\n var parent,\n node = this._root,\n retainer,\n previous,\n next,\n x0 = this._x0,\n y0 = this._y0,\n x1 = this._x1,\n y1 = this._y1,\n x,\n y,\n xm,\n ym,\n right,\n bottom,\n i,\n j;\n\n // If the tree is empty, initialize the root as a leaf.\n if (!node) return this;\n\n // Find the leaf node for the point.\n // While descending, also retain the deepest parent with a non-removed sibling.\n if (node.length) while (true) {\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n if (!(parent = node, node = node[i = bottom << 1 | right])) return this;\n if (!node.length) break;\n if (parent[(i + 1) & 3] || parent[(i + 2) & 3] || parent[(i + 3) & 3]) retainer = parent, j = i;\n }\n\n // Find the point to remove.\n while (node.data !== d) if (!(previous = node, node = node.next)) return this;\n if (next = node.next) delete node.next;\n\n // If there are multiple coincident points, remove just the point.\n if (previous) return (next ? previous.next = next : delete previous.next), this;\n\n // If this is the root point, remove it.\n if (!parent) return this._root = next, this;\n\n // Remove this leaf.\n next ? parent[i] = next : delete parent[i];\n\n // If the parent now contains exactly one leaf, collapse superfluous parents.\n if ((node = parent[0] || parent[1] || parent[2] || parent[3])\n && node === (parent[3] || parent[2] || parent[1] || parent[0])\n && !node.length) {\n if (retainer) retainer[j] = node;\n else this._root = node;\n }\n\n return this;\n}\n\nexport function removeAll(data) {\n for (var i = 0, n = data.length; i < n; ++i) this.remove(data[i]);\n return this;\n}\n","export default function() {\n return this._root;\n}\n","export default function() {\n var size = 0;\n this.visit(function(node) {\n if (!node.length) do ++size; while (node = node.next)\n });\n return size;\n}\n","import Quad from \"./quad.js\";\n\nexport default function(callback) {\n var quads = [], q, node = this._root, child, x0, y0, x1, y1;\n if (node) quads.push(new Quad(node, this._x0, this._y0, this._x1, this._y1));\n while (q = quads.pop()) {\n if (!callback(node = q.node, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1) && node.length) {\n var xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n }\n }\n return this;\n}\n","import Quad from \"./quad.js\";\n\nexport default function(callback) {\n var quads = [], next = [], q;\n if (this._root) quads.push(new Quad(this._root, this._x0, this._y0, this._x1, this._y1));\n while (q = quads.pop()) {\n var node = q.node;\n if (node.length) {\n var child, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1, xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n }\n next.push(q);\n }\n while (q = next.pop()) {\n callback(q.node, q.x0, q.y0, q.x1, q.y1);\n }\n return this;\n}\n","var noop = {value: () => {}};\n\nfunction dispatch() {\n for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {\n if (!(t = arguments[i] + \"\") || (t in _) || /[\\s.]/.test(t)) throw new Error(\"illegal type: \" + t);\n _[t] = [];\n }\n return new Dispatch(_);\n}\n\nfunction Dispatch(_) {\n this._ = _;\n}\n\nfunction parseTypenames(typenames, types) {\n return typenames.trim().split(/^|\\s+/).map(function(t) {\n var name = \"\", i = t.indexOf(\".\");\n if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n if (t && !types.hasOwnProperty(t)) throw new Error(\"unknown type: \" + t);\n return {type: t, name: name};\n });\n}\n\nDispatch.prototype = dispatch.prototype = {\n constructor: Dispatch,\n on: function(typename, callback) {\n var _ = this._,\n T = parseTypenames(typename + \"\", _),\n t,\n i = -1,\n n = T.length;\n\n // If no callback was specified, return the callback of the given type and name.\n if (arguments.length < 2) {\n while (++i < n) if ((t = (typename = T[i]).type) && (t = get(_[t], typename.name))) return t;\n return;\n }\n\n // If a type was specified, set the callback for the given type and name.\n // Otherwise, if a null callback was specified, remove callbacks of the given name.\n if (callback != null && typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n while (++i < n) {\n if (t = (typename = T[i]).type) _[t] = set(_[t], typename.name, callback);\n else if (callback == null) for (t in _) _[t] = set(_[t], typename.name, null);\n }\n\n return this;\n },\n copy: function() {\n var copy = {}, _ = this._;\n for (var t in _) copy[t] = _[t].slice();\n return new Dispatch(copy);\n },\n call: function(type, that) {\n if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n },\n apply: function(type, that, args) {\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n }\n};\n\nfunction get(type, name) {\n for (var i = 0, n = type.length, c; i < n; ++i) {\n if ((c = type[i]).name === name) {\n return c.value;\n }\n }\n}\n\nfunction set(type, name, callback) {\n for (var i = 0, n = type.length; i < n; ++i) {\n if (type[i].name === name) {\n type[i] = noop, type = type.slice(0, i).concat(type.slice(i + 1));\n break;\n }\n }\n if (callback != null) type.push({name: name, value: callback});\n return type;\n}\n\nexport default dispatch;\n","var frame = 0, // is an animation frame pending?\n timeout = 0, // is a timeout pending?\n interval = 0, // are any timers active?\n pokeDelay = 1000, // how frequently we check for clock skew\n taskHead,\n taskTail,\n clockLast = 0,\n clockNow = 0,\n clockSkew = 0,\n clock = typeof performance === \"object\" && performance.now ? performance : Date,\n setFrame = typeof window === \"object\" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function(f) { setTimeout(f, 17); };\n\nexport function now() {\n return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);\n}\n\nfunction clearNow() {\n clockNow = 0;\n}\n\nexport function Timer() {\n this._call =\n this._time =\n this._next = null;\n}\n\nTimer.prototype = timer.prototype = {\n constructor: Timer,\n restart: function(callback, delay, time) {\n if (typeof callback !== \"function\") throw new TypeError(\"callback is not a function\");\n time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);\n if (!this._next && taskTail !== this) {\n if (taskTail) taskTail._next = this;\n else taskHead = this;\n taskTail = this;\n }\n this._call = callback;\n this._time = time;\n sleep();\n },\n stop: function() {\n if (this._call) {\n this._call = null;\n this._time = Infinity;\n sleep();\n }\n }\n};\n\nexport function timer(callback, delay, time) {\n var t = new Timer;\n t.restart(callback, delay, time);\n return t;\n}\n\nexport function timerFlush() {\n now(); // Get the current time, if not already set.\n ++frame; // Pretend we’ve set an alarm, if we haven’t already.\n var t = taskHead, e;\n while (t) {\n if ((e = clockNow - t._time) >= 0) t._call.call(null, e);\n t = t._next;\n }\n --frame;\n}\n\nfunction wake() {\n clockNow = (clockLast = clock.now()) + clockSkew;\n frame = timeout = 0;\n try {\n timerFlush();\n } finally {\n frame = 0;\n nap();\n clockNow = 0;\n }\n}\n\nfunction poke() {\n var now = clock.now(), delay = now - clockLast;\n if (delay > pokeDelay) clockSkew -= delay, clockLast = now;\n}\n\nfunction nap() {\n var t0, t1 = taskHead, t2, time = Infinity;\n while (t1) {\n if (t1._call) {\n if (time > t1._time) time = t1._time;\n t0 = t1, t1 = t1._next;\n } else {\n t2 = t1._next, t1._next = null;\n t1 = t0 ? t0._next = t2 : taskHead = t2;\n }\n }\n taskTail = t0;\n sleep(time);\n}\n\nfunction sleep(time) {\n if (frame) return; // Soonest alarm already set, or will be.\n if (timeout) timeout = clearTimeout(timeout);\n var delay = time - clockNow; // Strictly less than if we recomputed clockNow.\n if (delay > 24) {\n if (time < Infinity) timeout = setTimeout(wake, time - clock.now() - clockSkew);\n if (interval) interval = clearInterval(interval);\n } else {\n if (!interval) clockLast = clock.now(), interval = setInterval(poke, pokeDelay);\n frame = 1, setFrame(wake);\n }\n}\n","// https://en.wikipedia.org/wiki/Linear_congruential_generator#Parameters_in_common_use\nconst a = 1664525;\nconst c = 1013904223;\nconst m = 4294967296; // 2^32\n\nexport default function() {\n let s = 1;\n return () => (s = (a * s + c) % m) / m;\n}\n","import {dispatch} from \"d3-dispatch\";\nimport {timer} from \"d3-timer\";\nimport lcg from \"./lcg.js\";\n\nexport function x(d) {\n return d.x;\n}\n\nexport function y(d) {\n return d.y;\n}\n\nvar initialRadius = 10,\n initialAngle = Math.PI * (3 - Math.sqrt(5));\n\nexport default function(nodes) {\n var simulation,\n alpha = 1,\n alphaMin = 0.001,\n alphaDecay = 1 - Math.pow(alphaMin, 1 / 300),\n alphaTarget = 0,\n velocityDecay = 0.6,\n forces = new Map(),\n stepper = timer(step),\n event = dispatch(\"tick\", \"end\"),\n random = lcg();\n\n if (nodes == null) nodes = [];\n\n function step() {\n tick();\n event.call(\"tick\", simulation);\n if (alpha < alphaMin) {\n stepper.stop();\n event.call(\"end\", simulation);\n }\n }\n\n function tick(iterations) {\n var i, n = nodes.length, node;\n\n if (iterations === undefined) iterations = 1;\n\n for (var k = 0; k < iterations; ++k) {\n alpha += (alphaTarget - alpha) * alphaDecay;\n\n forces.forEach(function(force) {\n force(alpha);\n });\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n if (node.fx == null) node.x += node.vx *= velocityDecay;\n else node.x = node.fx, node.vx = 0;\n if (node.fy == null) node.y += node.vy *= velocityDecay;\n else node.y = node.fy, node.vy = 0;\n }\n }\n\n return simulation;\n }\n\n function initializeNodes() {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.index = i;\n if (node.fx != null) node.x = node.fx;\n if (node.fy != null) node.y = node.fy;\n if (isNaN(node.x) || isNaN(node.y)) {\n var radius = initialRadius * Math.sqrt(0.5 + i), angle = i * initialAngle;\n node.x = radius * Math.cos(angle);\n node.y = radius * Math.sin(angle);\n }\n if (isNaN(node.vx) || isNaN(node.vy)) {\n node.vx = node.vy = 0;\n }\n }\n }\n\n function initializeForce(force) {\n if (force.initialize) force.initialize(nodes, random);\n return force;\n }\n\n initializeNodes();\n\n return simulation = {\n tick: tick,\n\n restart: function() {\n return stepper.restart(step), simulation;\n },\n\n stop: function() {\n return stepper.stop(), simulation;\n },\n\n nodes: function(_) {\n return arguments.length ? (nodes = _, initializeNodes(), forces.forEach(initializeForce), simulation) : nodes;\n },\n\n alpha: function(_) {\n return arguments.length ? (alpha = +_, simulation) : alpha;\n },\n\n alphaMin: function(_) {\n return arguments.length ? (alphaMin = +_, simulation) : alphaMin;\n },\n\n alphaDecay: function(_) {\n return arguments.length ? (alphaDecay = +_, simulation) : +alphaDecay;\n },\n\n alphaTarget: function(_) {\n return arguments.length ? (alphaTarget = +_, simulation) : alphaTarget;\n },\n\n velocityDecay: function(_) {\n return arguments.length ? (velocityDecay = 1 - _, simulation) : 1 - velocityDecay;\n },\n\n randomSource: function(_) {\n return arguments.length ? (random = _, forces.forEach(initializeForce), simulation) : random;\n },\n\n force: function(name, _) {\n return arguments.length > 1 ? ((_ == null ? forces.delete(name) : forces.set(name, initializeForce(_))), simulation) : forces.get(name);\n },\n\n find: function(x, y, radius) {\n var i = 0,\n n = nodes.length,\n dx,\n dy,\n d2,\n node,\n closest;\n\n if (radius == null) radius = Infinity;\n else radius *= radius;\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n dx = x - node.x;\n dy = y - node.y;\n d2 = dx * dx + dy * dy;\n if (d2 < radius) closest = node, radius = d2;\n }\n\n return closest;\n },\n\n on: function(name, _) {\n return arguments.length > 1 ? (event.on(name, _), simulation) : event.on(name);\n }\n };\n}\n","import {quadtree} from \"d3-quadtree\";\nimport constant from \"./constant.js\";\nimport jiggle from \"./jiggle.js\";\nimport {x, y} from \"./simulation.js\";\n\nexport default function() {\n var nodes,\n node,\n random,\n alpha,\n strength = constant(-30),\n strengths,\n distanceMin2 = 1,\n distanceMax2 = Infinity,\n theta2 = 0.81;\n\n function force(_) {\n var i, n = nodes.length, tree = quadtree(nodes, x, y).visitAfter(accumulate);\n for (alpha = _, i = 0; i < n; ++i) node = nodes[i], tree.visit(apply);\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length, node;\n strengths = new Array(n);\n for (i = 0; i < n; ++i) node = nodes[i], strengths[node.index] = +strength(node, i, nodes);\n }\n\n function accumulate(quad) {\n var strength = 0, q, c, weight = 0, x, y, i;\n\n // For internal nodes, accumulate forces from child quadrants.\n if (quad.length) {\n for (x = y = i = 0; i < 4; ++i) {\n if ((q = quad[i]) && (c = Math.abs(q.value))) {\n strength += q.value, weight += c, x += c * q.x, y += c * q.y;\n }\n }\n quad.x = x / weight;\n quad.y = y / weight;\n }\n\n // For leaf nodes, accumulate forces from coincident quadrants.\n else {\n q = quad;\n q.x = q.data.x;\n q.y = q.data.y;\n do strength += strengths[q.data.index];\n while (q = q.next);\n }\n\n quad.value = strength;\n }\n\n function apply(quad, x1, _, x2) {\n if (!quad.value) return true;\n\n var x = quad.x - node.x,\n y = quad.y - node.y,\n w = x2 - x1,\n l = x * x + y * y;\n\n // Apply the Barnes-Hut approximation if possible.\n // Limit forces for very close nodes; randomize direction if coincident.\n if (w * w / theta2 < l) {\n if (l < distanceMax2) {\n if (x === 0) x = jiggle(random), l += x * x;\n if (y === 0) y = jiggle(random), l += y * y;\n if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);\n node.vx += x * quad.value * alpha / l;\n node.vy += y * quad.value * alpha / l;\n }\n return true;\n }\n\n // Otherwise, process points directly.\n else if (quad.length || l >= distanceMax2) return;\n\n // Limit forces for very close nodes; randomize direction if coincident.\n if (quad.data !== node || quad.next) {\n if (x === 0) x = jiggle(random), l += x * x;\n if (y === 0) y = jiggle(random), l += y * y;\n if (l < distanceMin2) l = Math.sqrt(distanceMin2 * l);\n }\n\n do if (quad.data !== node) {\n w = strengths[quad.data.index] * alpha / l;\n node.vx += x * w;\n node.vy += y * w;\n } while (quad = quad.next);\n }\n\n force.initialize = function(_nodes, _random) {\n nodes = _nodes;\n random = _random;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : strength;\n };\n\n force.distanceMin = function(_) {\n return arguments.length ? (distanceMin2 = _ * _, force) : Math.sqrt(distanceMin2);\n };\n\n force.distanceMax = function(_) {\n return arguments.length ? (distanceMax2 = _ * _, force) : Math.sqrt(distanceMax2);\n };\n\n force.theta = function(_) {\n return arguments.length ? (theta2 = _ * _, force) : Math.sqrt(theta2);\n };\n\n return force;\n}\n","import constant from \"./constant.js\";\nimport jiggle from \"./jiggle.js\";\n\nfunction index(d) {\n return d.index;\n}\n\nfunction find(nodeById, nodeId) {\n var node = nodeById.get(nodeId);\n if (!node) throw new Error(\"node not found: \" + nodeId);\n return node;\n}\n\nexport default function(links) {\n var id = index,\n strength = defaultStrength,\n strengths,\n distance = constant(30),\n distances,\n nodes,\n count,\n bias,\n random,\n iterations = 1;\n\n if (links == null) links = [];\n\n function defaultStrength(link) {\n return 1 / Math.min(count[link.source.index], count[link.target.index]);\n }\n\n function force(alpha) {\n for (var k = 0, n = links.length; k < iterations; ++k) {\n for (var i = 0, link, source, target, x, y, l, b; i < n; ++i) {\n link = links[i], source = link.source, target = link.target;\n x = target.x + target.vx - source.x - source.vx || jiggle(random);\n y = target.y + target.vy - source.y - source.vy || jiggle(random);\n l = Math.sqrt(x * x + y * y);\n l = (l - distances[i]) / l * alpha * strengths[i];\n x *= l, y *= l;\n target.vx -= x * (b = bias[i]);\n target.vy -= y * b;\n source.vx += x * (b = 1 - b);\n source.vy += y * b;\n }\n }\n }\n\n function initialize() {\n if (!nodes) return;\n\n var i,\n n = nodes.length,\n m = links.length,\n nodeById = new Map(nodes.map((d, i) => [id(d, i, nodes), d])),\n link;\n\n for (i = 0, count = new Array(n); i < m; ++i) {\n link = links[i], link.index = i;\n if (typeof link.source !== \"object\") link.source = find(nodeById, link.source);\n if (typeof link.target !== \"object\") link.target = find(nodeById, link.target);\n count[link.source.index] = (count[link.source.index] || 0) + 1;\n count[link.target.index] = (count[link.target.index] || 0) + 1;\n }\n\n for (i = 0, bias = new Array(m); i < m; ++i) {\n link = links[i], bias[i] = count[link.source.index] / (count[link.source.index] + count[link.target.index]);\n }\n\n strengths = new Array(m), initializeStrength();\n distances = new Array(m), initializeDistance();\n }\n\n function initializeStrength() {\n if (!nodes) return;\n\n for (var i = 0, n = links.length; i < n; ++i) {\n strengths[i] = +strength(links[i], i, links);\n }\n }\n\n function initializeDistance() {\n if (!nodes) return;\n\n for (var i = 0, n = links.length; i < n; ++i) {\n distances[i] = +distance(links[i], i, links);\n }\n }\n\n force.initialize = function(_nodes, _random) {\n nodes = _nodes;\n random = _random;\n initialize();\n };\n\n force.links = function(_) {\n return arguments.length ? (links = _, initialize(), force) : links;\n };\n\n force.id = function(_) {\n return arguments.length ? (id = _, force) : id;\n };\n\n force.iterations = function(_) {\n return arguments.length ? (iterations = +_, force) : iterations;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initializeStrength(), force) : strength;\n };\n\n force.distance = function(_) {\n return arguments.length ? (distance = typeof _ === \"function\" ? _ : constant(+_), initializeDistance(), force) : distance;\n };\n\n return force;\n}\n","import {quadtree} from \"d3-quadtree\";\nimport constant from \"./constant.js\";\nimport jiggle from \"./jiggle.js\";\n\nfunction x(d) {\n return d.x + d.vx;\n}\n\nfunction y(d) {\n return d.y + d.vy;\n}\n\nexport default function(radius) {\n var nodes,\n radii,\n random,\n strength = 1,\n iterations = 1;\n\n if (typeof radius !== \"function\") radius = constant(radius == null ? 1 : +radius);\n\n function force() {\n var i, n = nodes.length,\n tree,\n node,\n xi,\n yi,\n ri,\n ri2;\n\n for (var k = 0; k < iterations; ++k) {\n tree = quadtree(nodes, x, y).visitAfter(prepare);\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n ri = radii[node.index], ri2 = ri * ri;\n xi = node.x + node.vx;\n yi = node.y + node.vy;\n tree.visit(apply);\n }\n }\n\n function apply(quad, x0, y0, x1, y1) {\n var data = quad.data, rj = quad.r, r = ri + rj;\n if (data) {\n if (data.index > node.index) {\n var x = xi - data.x - data.vx,\n y = yi - data.y - data.vy,\n l = x * x + y * y;\n if (l < r * r) {\n if (x === 0) x = jiggle(random), l += x * x;\n if (y === 0) y = jiggle(random), l += y * y;\n l = (r - (l = Math.sqrt(l))) / l * strength;\n node.vx += (x *= l) * (r = (rj *= rj) / (ri2 + rj));\n node.vy += (y *= l) * r;\n data.vx -= x * (r = 1 - r);\n data.vy -= y * r;\n }\n }\n return;\n }\n return x0 > xi + r || x1 < xi - r || y0 > yi + r || y1 < yi - r;\n }\n }\n\n function prepare(quad) {\n if (quad.data) return quad.r = radii[quad.data.index];\n for (var i = quad.r = 0; i < 4; ++i) {\n if (quad[i] && quad[i].r > quad.r) {\n quad.r = quad[i].r;\n }\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length, node;\n radii = new Array(n);\n for (i = 0; i < n; ++i) node = nodes[i], radii[node.index] = +radius(node, i, nodes);\n }\n\n force.initialize = function(_nodes, _random) {\n nodes = _nodes;\n random = _random;\n initialize();\n };\n\n force.iterations = function(_) {\n return arguments.length ? (iterations = +_, force) : iterations;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = +_, force) : strength;\n };\n\n force.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : radius;\n };\n\n return force;\n}\n","import constant from \"./constant.js\";\n\nexport default function(x) {\n var strength = constant(0.1),\n nodes,\n strengths,\n xz;\n\n if (typeof x !== \"function\") x = constant(x == null ? 0 : +x);\n\n function force(alpha) {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.vx += (xz[i] - node.x) * strengths[i] * alpha;\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n xz = new Array(n);\n for (i = 0; i < n; ++i) {\n strengths[i] = isNaN(xz[i] = +x(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : strength;\n };\n\n force.x = function(_) {\n return arguments.length ? (x = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : x;\n };\n\n return force;\n}\n","import constant from \"./constant.js\";\n\nexport default function(y) {\n var strength = constant(0.1),\n nodes,\n strengths,\n yz;\n\n if (typeof y !== \"function\") y = constant(y == null ? 0 : +y);\n\n function force(alpha) {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.vy += (yz[i] - node.y) * strengths[i] * alpha;\n }\n }\n\n function initialize() {\n if (!nodes) return;\n var i, n = nodes.length;\n strengths = new Array(n);\n yz = new Array(n);\n for (i = 0; i < n; ++i) {\n strengths[i] = isNaN(yz[i] = +y(nodes[i], i, nodes)) ? 0 : +strength(nodes[i], i, nodes);\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n initialize();\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : strength;\n };\n\n force.y = function(_) {\n return arguments.length ? (y = typeof _ === \"function\" ? _ : constant(+_), initialize(), force) : y;\n };\n\n return force;\n}\n","/** layout message type */\nexport const LAYOUT_MESSAGE = {\n // run layout\n RUN: \"LAYOUT_RUN\",\n // layout ended with success\n END: \"LAYOUT_END\",\n // layout error\n ERROR: \"LAYOUT_ERROR\",\n // layout tick, used in force directed layout\n TICK: \"LAYOUT_TICK\",\n GPURUN: \"GPU_LAYOUT_RUN\",\n GPUEND: \"GPU_LAYOUT_END\"\n};\n","/**\n * @fileOverview random layout\n * @author shiwu.wyy@antfin.com\n */\n\nimport { Edge, Model, PointTuple, ForceLayoutOptions } from \"../types\";\nimport * as d3Force from \"d3-force\";\nimport forceInABox from \"./force-in-a-box\";\nimport { isArray, isFunction, isNumber } from \"../../util\";\nimport { Base } from \"../base\";\nimport { LAYOUT_MESSAGE } from \"../constants\";\n\n/**\n * 经典力导布局 force-directed\n */\nexport class ForceLayout extends Base {\n /** 向心力作用点 */\n public center: PointTuple = [0, 0];\n\n /** 节点作用力 */\n public nodeStrength: number | null = null;\n\n /** 边的作用力, 默认为根据节点的入度出度自适应 */\n public edgeStrength: number | null = null;\n\n /** 是否防止节点相互覆盖 */\n public preventOverlap: boolean = false;\n\n /** 节点大小 / 直径,用于防止重叠时的碰撞检测 */\n public nodeSize: number | number[] | ((d?: unknown) => number) | undefined;\n\n /** 节点间距,防止节点重叠时节点之间的最小距离(两节点边缘最短距离) */\n public nodeSpacing: ((d?: unknown) => number) | undefined;\n\n /** 是否支持按类聚合 */\n public clustering: boolean;\n\n /** 聚类节点作用力 */\n public clusterNodeStrength: number | null = null;\n\n /** 聚类边作用力 */\n public clusterEdgeStrength: number | null = null;\n\n /** 聚类边长度 */\n public clusterEdgeDistance: number | null = null;\n\n /** 聚类节点大小 / 直径,直径越大,越分散 */\n public clusterNodeSize: number | null = null;\n\n /** 用于 foci 的力 */\n public clusterFociStrength: number | null = null;\n\n /** 默认边长度 */\n public linkDistance: number = 50;\n\n /** 自定义 force 方法 */\n public forceSimulation: any;\n\n /** 迭代阈值的衰减率 [0, 1],0.028 对应最大迭代数为 300 */\n public alphaDecay: number = 0.028;\n\n /** 停止迭代的阈值 */\n public alphaMin: number = 0.001;\n\n /** 当前阈值 */\n public alpha: number = 0.3;\n\n /** 防止重叠的力强度 */\n public collideStrength: number = 1;\n\n /** 是否启用web worker。前提是在web worker里执行布局,否则无效\t*/\n public workerEnabled: boolean = false;\n\n public tick: () => void = () => {};\n\n /** 布局完成回调 */\n public onLayoutEnd: () => void = () => {};\n\n /** 是否正在布局 */\n private ticking: boolean | undefined = undefined;\n\n private edgeForce: any;\n\n private clusterForce: any;\n\n constructor(options?: ForceLayoutOptions) {\n super();\n if (options) {\n this.updateCfg(options);\n }\n }\n\n public getDefaultCfg() {\n return {\n center: [0, 0],\n nodeStrength: null,\n edgeStrength: null,\n preventOverlap: false,\n nodeSize: undefined,\n nodeSpacing: undefined,\n linkDistance: 50,\n forceSimulation: null,\n alphaDecay: 0.028,\n alphaMin: 0.001,\n alpha: 0.3,\n collideStrength: 1,\n clustering: false,\n clusterNodeStrength: -1,\n clusterEdgeStrength: 0.1,\n clusterEdgeDistance: 100,\n clusterFociStrength: 0.8,\n clusterNodeSize: 10,\n tick() {},\n onLayoutEnd() {}, // 布局完成回调\n // 是否启用web worker。前提是在web worker里执行布局,否则无效\n workerEnabled: false\n };\n }\n\n /**\n * 初始化\n * @param {object} data 数据\n */\n public init(data: Model) {\n const self = this;\n self.nodes = data.nodes || [];\n const edges = data.edges || [];\n self.edges = edges.map(edge => {\n const res: any = {};\n const expectKeys = [\"targetNode\", \"sourceNode\", \"startPoint\", \"endPoint\"];\n Object.keys(edge).forEach((key: keyof Edge) => {\n if (!(expectKeys.indexOf(key) > -1)) {\n res[key] = edge[key];\n }\n });\n return res;\n });\n self.ticking = false;\n }\n\n /**\n * 执行布局\n */\n public execute(reloadData?: boolean) {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n // 如果正在布局,忽略布局请求\n if (self.ticking) {\n return;\n }\n let simulation = self.forceSimulation;\n const alphaMin = self.alphaMin;\n const alphaDecay = self.alphaDecay;\n const alpha = self.alpha;\n if (!simulation) {\n try {\n // 定义节点的力\n const nodeForce = d3Force.forceManyBody();\n if (self.nodeStrength) {\n nodeForce.strength(self.nodeStrength);\n }\n simulation = d3Force.forceSimulation().nodes(nodes as any);\n\n if (self.clustering) {\n const clusterForce = forceInABox() as any;\n clusterForce\n .centerX(self.center[0])\n .centerY(self.center[1])\n .template(\"force\")\n .strength(self.clusterFociStrength);\n if (edges) {\n clusterForce.links(edges);\n }\n if (nodes) {\n clusterForce.nodes(nodes);\n }\n clusterForce\n .forceLinkDistance(self.clusterEdgeDistance)\n .forceLinkStrength(self.clusterEdgeStrength)\n .forceCharge(self.clusterNodeStrength)\n .forceNodeSize(self.clusterNodeSize);\n\n self.clusterForce = clusterForce;\n simulation.force(\"group\", clusterForce);\n }\n simulation\n .force(\"center\", d3Force.forceCenter(self.center[0], self.center[1]))\n .force(\"charge\", nodeForce)\n .alpha(alpha)\n .alphaDecay(alphaDecay)\n .alphaMin(alphaMin);\n\n if (self.preventOverlap) {\n self.overlapProcess(simulation);\n }\n // 如果有边,定义边的力\n if (edges) {\n // d3 的 forceLayout 会重新生成边的数据模型,为了避免污染源数据\n const edgeForce = d3Force\n .forceLink()\n .id((d: any) => d.id)\n .links(edges);\n if (self.edgeStrength) {\n edgeForce.strength(self.edgeStrength);\n }\n if (self.linkDistance) {\n edgeForce.distance(self.linkDistance);\n }\n self.edgeForce = edgeForce;\n simulation.force(\"link\", edgeForce);\n }\n if (self.workerEnabled && !isInWorker()) {\n // 如果不是运行在web worker里,不用web worker布局\n self.workerEnabled = false;\n console.warn(\n \"workerEnabled option is only supported when running in web worker.\"\n );\n }\n if (!self.workerEnabled) {\n simulation\n .on(\"tick\", () => {\n self.tick();\n })\n .on(\"end\", () => {\n self.ticking = false;\n if (self.onLayoutEnd) self.onLayoutEnd();\n });\n self.ticking = true;\n } else {\n // worker is enabled\n simulation.stop();\n const totalTicks = getSimulationTicks(simulation);\n for (let currentTick = 1; currentTick <= totalTicks; currentTick++) {\n simulation.tick();\n // currentTick starts from 1.\n postMessage(\n {\n nodes,\n currentTick,\n totalTicks,\n type: LAYOUT_MESSAGE.TICK\n },\n undefined as any\n );\n }\n self.ticking = false;\n }\n\n self.forceSimulation = simulation;\n self.ticking = true;\n } catch (e) {\n self.ticking = false;\n console.warn(e);\n }\n } else {\n if (reloadData) {\n if (self.clustering && self.clusterForce) {\n self.clusterForce.nodes(nodes);\n self.clusterForce.links(edges);\n }\n simulation.nodes(nodes);\n if (edges && self.edgeForce) self.edgeForce.links(edges);\n else if (edges && !self.edgeForce) {\n // d3 的 forceLayout 会重新生成边的数据模型,为了避免污染源数据\n const edgeForce = d3Force\n .forceLink()\n .id((d: any) => d.id)\n .links(edges);\n if (self.edgeStrength) {\n edgeForce.strength(self.edgeStrength);\n }\n if (self.linkDistance) {\n edgeForce.distance(self.linkDistance);\n }\n self.edgeForce = edgeForce;\n simulation.force(\"link\", edgeForce);\n }\n }\n if (self.preventOverlap) {\n self.overlapProcess(simulation);\n }\n simulation.alpha(alpha).restart();\n this.ticking = true;\n }\n }\n\n /**\n * 防止重叠\n * @param {object} simulation 力模拟模型\n */\n public overlapProcess(simulation: any) {\n const self = this;\n const nodeSize = self.nodeSize;\n const nodeSpacing = self.nodeSpacing;\n let nodeSizeFunc: (d: any) => number;\n let nodeSpacingFunc: any;\n const collideStrength = self.collideStrength;\n\n if (isNumber(nodeSpacing)) {\n nodeSpacingFunc = () => nodeSpacing;\n } else if (isFunction(nodeSpacing)) {\n nodeSpacingFunc = nodeSpacing;\n } else {\n nodeSpacingFunc = () => 0;\n }\n\n if (!nodeSize) {\n nodeSizeFunc = d => {\n if (d.size) {\n if (isArray(d.size)) {\n const res = d.size[0] > d.size[1] ? d.size[0] : d.size[1];\n return res / 2 + nodeSpacingFunc(d);\n }\n return d.size / 2 + nodeSpacingFunc(d);\n }\n return 10 + nodeSpacingFunc(d);\n };\n } else if (isFunction(nodeSize)) {\n nodeSizeFunc = d => {\n const size = nodeSize(d);\n return size + nodeSpacingFunc(d);\n };\n } else if (isArray(nodeSize)) {\n const larger = nodeSize[0] > nodeSize[1] ? nodeSize[0] : nodeSize[1];\n const radius = larger / 2;\n nodeSizeFunc = d => radius + nodeSpacingFunc(d);\n } else if (isNumber(nodeSize)) {\n const radius = nodeSize / 2;\n nodeSizeFunc = d => radius + nodeSpacingFunc(d);\n } else {\n nodeSizeFunc = () => 10;\n }\n\n // forceCollide's parameter is a radius\n simulation.force(\n \"collisionForce\",\n d3Force.forceCollide(nodeSizeFunc).strength(collideStrength)\n );\n }\n\n /**\n * 更新布局配置,但不执行布局\n * @param {object} cfg 需要更新的配置项\n */\n public updateCfg(cfg: ForceLayoutOptions) {\n const self = this;\n if (self.ticking) {\n self.forceSimulation.stop();\n self.ticking = false;\n }\n self.forceSimulation = null;\n Object.assign(self, cfg);\n }\n\n public destroy() {\n const self = this;\n if (self.ticking) {\n self.forceSimulation.stop();\n self.ticking = false;\n }\n self.nodes = null;\n self.edges = null;\n self.destroyed = true;\n }\n}\n\n// Return total ticks of d3-force simulation\nfunction getSimulationTicks(simulation: any): number {\n const alphaMin = simulation.alphaMin();\n const alphaTarget = simulation.alphaTarget();\n const alpha = simulation.alpha();\n const totalTicksFloat =\n Math.log((alphaMin - alphaTarget) / (alpha - alphaTarget)) /\n Math.log(1 - simulation.alphaDecay());\n const totalTicks = Math.ceil(totalTicksFloat);\n return totalTicks;\n}\ndeclare const WorkerGlobalScope: any;\n\n// 判断是否运行在web worker里\nfunction isInWorker(): boolean {\n // eslint-disable-next-line no-undef\n return (\n typeof WorkerGlobalScope !== \"undefined\" &&\n self instanceof WorkerGlobalScope\n );\n}\n","import * as d3Force from 'd3-force'\n\ninterface INode {\n id: string\n x: number\n y: number\n vx: number\n vy: number\n cluster: any\n}\n\n// https://github.com/john-guerra/forceInABox/blob/master/src/forceInABox.js\nexport default function forceInABox() {\n function constant(_: any): () => any {\n return () => _\n }\n\n let groupBy = (d: INode) => {\n return d.cluster\n }\n let forceNodeSize: (() => number) | ((d: any) => number) = constant(1)\n let forceCharge: (() => number) | ((d: any) => number) = constant(-1)\n let forceLinkDistance: (() => number) | ((d: any) => number) = constant(100)\n let forceLinkStrength: (() => number) | ((d: any) => number) = constant(0.1)\n let offset = [0, 0]\n\n let nodes: INode[] = []\n let nodesMap: any = {}\n let links: any[] = []\n let centerX = 100\n let centerY = 100\n let foci: any = {\n none: {\n x: 0,\n y: 0,\n },\n }\n let templateNodes: INode[] = []\n let templateForce: any\n let template = 'force'\n let enableGrouping = true\n let strength = 0.1\n\n function force(alpha: number) {\n if (!enableGrouping) {\n return force\n }\n templateForce.tick()\n getFocisFromTemplate()\n\n for (let i = 0, n = nodes.length, node, k = alpha * strength; i < n; ++i) {\n node = nodes[i]\n node.vx += (foci[groupBy(node)].x - node.x) * k\n node.vy += (foci[groupBy(node)].y - node.y) * k\n }\n }\n\n function initialize() {\n if (!nodes) return\n initializeWithForce()\n }\n\n function initializeWithForce() {\n if (!nodes || !nodes.length) {\n return\n }\n\n if (groupBy(nodes[0]) === undefined) {\n throw Error(\n \"Couldnt find the grouping attribute for the nodes. Make sure to set it up with forceInABox.groupBy('clusterAttr') before calling .links()\",\n )\n }\n\n // checkLinksAsObjects();\n\n const net = getGroupsGraph()\n templateForce = d3Force\n .forceSimulation(net.nodes)\n .force('x', d3Force.forceX(centerX).strength(0.1))\n .force('y', d3Force.forceY(centerY).strength(0.1))\n .force('collide', d3Force.forceCollide((d: any) => d.r).iterations(4))\n .force('charge', d3Force.forceManyBody().strength(forceCharge))\n .force(\n 'links',\n d3Force\n .forceLink(net.nodes.length ? net.links : [])\n .distance(forceLinkDistance)\n .strength(forceLinkStrength),\n )\n\n templateNodes = templateForce.nodes()\n\n getFocisFromTemplate()\n }\n\n function getGroupsGraph() {\n const gnodes: any = []\n const glinks: any = []\n const dNodes: any = {}\n let clustersList = []\n let clustersCounts: any = {}\n let clustersLinks: any = []\n\n clustersCounts = computeClustersNodeCounts(nodes)\n clustersLinks = computeClustersLinkCounts(links)\n\n clustersList = Object.keys(clustersCounts)\n\n clustersList.forEach((key, index) => {\n const val = clustersCounts[key]\n // Uses approx meta-node size\n gnodes.push({\n id: key,\n size: val.count,\n r: Math.sqrt(val.sumforceNodeSize / Math.PI),\n })\n dNodes[key] = index\n })\n\n clustersLinks.forEach((l: any) => {\n const source = dNodes[l.source]\n const target = dNodes[l.target]\n if (source !== undefined && target !== undefined) {\n glinks.push({\n source,\n target,\n count: l.count,\n })\n }\n })\n\n return {\n nodes: gnodes,\n links: glinks,\n }\n }\n\n function computeClustersNodeCounts(nodes: any) {\n const clustersCounts: any = {}\n\n nodes.forEach((d: any) => {\n const key = groupBy(d)\n if (!clustersCounts[key]) {\n clustersCounts[key] = {\n count: 0,\n sumforceNodeSize: 0,\n }\n }\n })\n nodes.forEach((d: any) => {\n const key = groupBy(d)\n const nodeSize = forceNodeSize(d)\n const tmpCount = clustersCounts[key]\n tmpCount.count = tmpCount.count + 1\n tmpCount.sumforceNodeSize =\n tmpCount.sumforceNodeSize + Math.PI * (nodeSize * nodeSize) * 1.3\n clustersCounts[key] = tmpCount\n })\n\n return clustersCounts\n }\n\n function computeClustersLinkCounts(links: any) {\n const dClusterLinks: any = {}\n const clusterLinks: any = []\n links.forEach((l: any) => {\n const key = getLinkKey(l)\n let count = 0\n if (dClusterLinks[key] !== undefined) {\n count = dClusterLinks[key]\n }\n count += 1\n dClusterLinks[key] = count\n })\n\n const entries = Object.entries(dClusterLinks)\n\n entries.forEach(([key, count]) => {\n const source = key.split('~')[0]\n const target = key.split('~')[1]\n if (source !== undefined && target !== undefined) {\n clusterLinks.push({\n source,\n target,\n count,\n })\n }\n })\n\n return clusterLinks\n }\n\n function getFocisFromTemplate() {\n foci = {\n none: {\n x: 0,\n y: 0,\n },\n }\n templateNodes.forEach((d) => {\n foci[d.id] = {\n x: d.x - offset[0],\n y: d.y - offset[1],\n }\n })\n return foci\n }\n\n function getLinkKey(l: any) {\n const sourceID = groupBy(nodesMap[l.source])\n const targetID = groupBy(nodesMap[l.target])\n\n return sourceID <= targetID\n ? `${sourceID}~${targetID}`\n : `${targetID}~${sourceID}`\n }\n\n function genNodesMap(nodes: any) {\n nodesMap = {}\n nodes.forEach((node: any) => {\n nodesMap[node.id] = node\n })\n }\n\n function setTemplate(x: any) {\n if (!arguments.length) return template\n template = x\n initialize()\n return force\n }\n\n function setGroupBy(x: any) {\n if (!arguments.length) return groupBy\n if (typeof x === 'string') {\n groupBy = (d: any) => {\n return d[x]\n }\n return force\n }\n groupBy = x\n return force\n }\n\n function setEnableGrouping(x: any) {\n if (!arguments.length) return enableGrouping\n enableGrouping = x\n return force\n }\n\n function setStrength(x: any) {\n if (!arguments.length) return strength\n strength = x\n return force\n }\n\n function setCenterX(_: any) {\n if (arguments.length) {\n centerX = _\n return force\n }\n\n return centerX\n }\n\n function setCenterY(_: any) {\n if (arguments.length) {\n centerY = _\n return force\n }\n\n return centerY\n }\n\n function setNodes(_: any) {\n if (arguments.length) {\n genNodesMap(_ || [])\n nodes = _ || []\n return force\n }\n return nodes\n }\n\n function setLinks(_: any) {\n if (arguments.length) {\n links = _ || []\n initialize()\n return force\n }\n return links\n }\n\n function setForceNodeSize(_: any) {\n if (arguments.length) {\n if (typeof _ === 'function') {\n forceNodeSize = _\n } else {\n forceNodeSize = constant(+_)\n }\n initialize()\n return force\n }\n\n return forceNodeSize\n }\n\n function setForceCharge(_: any) {\n if (arguments.length) {\n if (typeof _ === 'function') {\n forceCharge = _\n } else {\n forceCharge = constant(+_)\n }\n initialize()\n return force\n }\n\n return forceCharge\n }\n\n function setForceLinkDistance(_: any) {\n if (arguments.length) {\n if (typeof _ === 'function') {\n forceLinkDistance = _\n } else {\n forceLinkDistance = constant(+_)\n }\n initialize()\n return force\n }\n\n return forceLinkDistance\n }\n\n function setForceLinkStrength(_: any) {\n if (arguments.length) {\n if (typeof _ === 'function') {\n forceLinkStrength = _\n } else {\n forceLinkStrength = constant(+_)\n }\n initialize()\n return force\n }\n\n return forceLinkStrength\n }\n\n function setOffset(_: any) {\n if (arguments.length) {\n offset = _\n return force\n }\n\n return offset\n }\n\n force.initialize = (_: any) => {\n nodes = _\n initialize()\n }\n\n force.template = setTemplate\n\n force.groupBy = setGroupBy\n\n force.enableGrouping = setEnableGrouping\n\n force.strength = setStrength\n\n force.centerX = setCenterX\n\n force.centerY = setCenterY\n\n force.nodes = setNodes\n\n force.links = setLinks\n\n force.forceNodeSize = setForceNodeSize\n\n // Legacy support\n force.nodeSize = force.forceNodeSize\n\n force.forceCharge = setForceCharge\n\n force.forceLinkDistance = setForceLinkDistance\n\n force.forceLinkStrength = setForceLinkStrength\n\n force.offset = setOffset\n\n force.getFocis = getFocisFromTemplate\n\n return force\n}\n","export default function(x, y) {\n var nodes, strength = 1;\n\n if (x == null) x = 0;\n if (y == null) y = 0;\n\n function force() {\n var i,\n n = nodes.length,\n node,\n sx = 0,\n sy = 0;\n\n for (i = 0; i < n; ++i) {\n node = nodes[i], sx += node.x, sy += node.y;\n }\n\n for (sx = (sx / n - x) * strength, sy = (sy / n - y) * strength, i = 0; i < n; ++i) {\n node = nodes[i], node.x -= sx, node.y -= sy;\n }\n }\n\n force.initialize = function(_) {\n nodes = _;\n };\n\n force.x = function(_) {\n return arguments.length ? (x = +_, force) : x;\n };\n\n force.y = function(_) {\n return arguments.length ? (y = +_, force) : y;\n };\n\n force.strength = function(_) {\n return arguments.length ? (strength = +_, force) : strength;\n };\n\n return force;\n}\n","/**\n * @fileOverview random layout\n * @author shiwu.wyy@antfin.com\n */\n\nimport {\n OutNode,\n Edge,\n PointTuple,\n IndexMap,\n CircularLayoutOptions\n} from \"./types\";\nimport { Base } from \"./base\";\nimport { getDegree, clone } from \"../util\";\n\ntype INode = OutNode & {\n degree: number;\n size: number | PointTuple;\n weight: number;\n children: string[];\n parent: string[];\n};\n\nfunction initHierarchy(\n nodes: INode[],\n edges: Edge[],\n nodeMap: IndexMap,\n directed: boolean\n) {\n nodes.forEach((_, i: number) => {\n nodes[i].children = [];\n nodes[i].parent = [];\n });\n if (directed) {\n edges.forEach(e => {\n let sourceIdx = 0;\n if (e.source) {\n sourceIdx = nodeMap[e.source];\n }\n let targetIdx = 0;\n if (e.target) {\n targetIdx = nodeMap[e.target];\n }\n const child = nodes[sourceIdx].children!;\n const parent = nodes[targetIdx].parent!;\n child.push(nodes[targetIdx].id);\n parent.push(nodes[sourceIdx].id);\n });\n } else {\n edges.forEach(e => {\n let sourceIdx = 0;\n if (e.source) {\n sourceIdx = nodeMap[e.source];\n }\n let targetIdx = 0;\n if (e.target) {\n targetIdx = nodeMap[e.target];\n }\n const sourceChildren = nodes[sourceIdx].children!;\n const targetChildren = nodes[targetIdx].children!;\n sourceChildren.push(nodes[targetIdx].id);\n targetChildren.push(nodes[sourceIdx].id);\n });\n }\n}\n\nfunction connect(a: INode, b: INode, edges: Edge[]) {\n const m = edges.length;\n for (let i = 0; i < m; i++) {\n if (\n (a.id === edges[i].source && b.id === edges[i].target) ||\n (b.id === edges[i].source && a.id === edges[i].target)\n ) {\n return true;\n }\n }\n return false;\n}\n\nfunction compareDegree(a: INode, b: INode) {\n const aDegree = a.degree!;\n const bDegree = b.degree!;\n if (aDegree < bDegree) {\n return -1;\n }\n if (aDegree > bDegree) {\n return 1;\n }\n return 0;\n}\n\n/**\n * 圆形布局\n */\nexport class CircularLayout extends Base {\n /** 布局中心 */\n public center: PointTuple;\n\n /** 固定半径,若设置了 radius,则 startRadius 与 endRadius 不起效 */\n public radius: number | null = null;\n\n /** 起始半径 */\n public startRadius: number | null = null;\n\n /** 终止半径 */\n public endRadius: number | null = null;\n\n /** 起始角度 */\n public startAngle: number = 0;\n\n /** 终止角度 */\n public endAngle: number = 2 * Math.PI;\n\n /** 是否顺时针 */\n public clockwise: boolean = true;\n\n /** 节点在环上分成段数(几个段将均匀分布),在 endRadius - startRadius != 0 时生效 */\n public divisions: number = 1;\n\n /** 节点在环上排序的依据,可选: 'topology', 'degree', 'null' */\n public ordering: \"topology\" | \"topology-directed\" | \"degree\" | null = null;\n\n /** how many 2*pi from first to last nodes */\n public angleRatio = 1;\n\n public nodes: INode[] = [];\n\n public edges: Edge[] = [];\n\n private nodeMap: IndexMap = {};\n\n private degrees: number[] = [];\n\n public width: number = 300;\n\n public height: number = 300;\n\n public onLayoutEnd: () => void;\n\n constructor(options?: CircularLayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {\n radius: null,\n startRadius: null,\n endRadius: null,\n startAngle: 0,\n endAngle: 2 * Math.PI,\n clockwise: true,\n divisions: 1,\n ordering: null,\n angleRatio: 1\n };\n }\n\n /**\n * 执行布局\n */\n public execute() {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n const n = nodes.length;\n if (n === 0) {\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n\n if (n === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n\n let radius = self.radius;\n let startRadius = self.startRadius;\n let endRadius = self.endRadius;\n const divisions = self.divisions;\n const startAngle = self.startAngle;\n const endAngle = self.endAngle;\n const angleStep = (endAngle - startAngle) / n;\n // layout\n const nodeMap: IndexMap = {};\n nodes.forEach((node, i) => {\n nodeMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n const degrees = getDegree(nodes.length, nodeMap, edges);\n self.degrees = degrees;\n if (!radius && !startRadius && !endRadius) {\n radius = self.height > self.width ? self.width / 2 : self.height / 2;\n } else if (!startRadius && endRadius) {\n startRadius = endRadius;\n } else if (startRadius && !endRadius) {\n endRadius = startRadius;\n }\n const angleRatio = self.angleRatio;\n const astep = angleStep * angleRatio;\n\n const ordering = self.ordering;\n let layoutNodes = [];\n if (ordering === \"topology\") {\n // layout according to the topology\n layoutNodes = self.topologyOrdering();\n } else if (ordering === \"topology-directed\") {\n // layout according to the topology\n layoutNodes = self.topologyOrdering(true);\n } else if (ordering === \"degree\") {\n // layout according to the descent order of degrees\n layoutNodes = self.degreeOrdering();\n } else {\n // layout according to the original order in the data.nodes\n layoutNodes = nodes;\n }\n\n const clockwise = self.clockwise;\n const divN = Math.ceil(n / divisions); // node number in each division\n for (let i = 0; i < n; ++i) {\n let r = radius;\n if (!r && startRadius !== null && endRadius !== null) {\n r = startRadius + (i * (endRadius - startRadius)) / (n - 1);\n }\n if (!r) {\n r = 10 + (i * 100) / (n - 1);\n }\n let angle =\n startAngle +\n (i % divN) * astep +\n ((2 * Math.PI) / divisions) * Math.floor(i / divN);\n if (!clockwise) {\n angle =\n endAngle -\n (i % divN) * astep -\n ((2 * Math.PI) / divisions) * Math.floor(i / divN);\n }\n layoutNodes[i].x = center[0] + Math.cos(angle) * r;\n layoutNodes[i].y = center[1] + Math.sin(angle) * r;\n layoutNodes[i].weight = degrees[i];\n }\n\n if (self.onLayoutEnd) self.onLayoutEnd();\n\n return {\n nodes: layoutNodes,\n edges: this.edges\n };\n }\n\n /**\n * 根据节点的拓扑结构排序\n * @return {array} orderedNodes 排序后的结果\n */\n public topologyOrdering(directed: boolean = false) {\n const self = this;\n const degrees = self.degrees;\n const edges = self.edges;\n const nodes = self.nodes;\n const cnodes = clone(nodes);\n const nodeMap = self.nodeMap;\n const orderedCNodes = [cnodes[0]];\n const resNodes = [nodes[0]];\n const pickFlags: boolean[] = [];\n const n = nodes.length;\n pickFlags[0] = true;\n initHierarchy(cnodes, edges, nodeMap, directed);\n let k = 0;\n cnodes.forEach((cnode, i) => {\n if (i !== 0) {\n if (\n (i === n - 1 ||\n degrees[i] !== degrees[i + 1] ||\n connect(\n orderedCNodes[k],\n cnode,\n edges\n )) &&\n !pickFlags[i]\n ) {\n orderedCNodes.push(cnode);\n resNodes.push(nodes[nodeMap[cnode.id]]);\n pickFlags[i] = true;\n k++;\n } else {\n const children = orderedCNodes[k].children!;\n let foundChild = false;\n for (let j = 0; j < children.length; j++) {\n const childIdx = nodeMap[children[j]];\n if (degrees[childIdx] === degrees[i] && !pickFlags[childIdx]) {\n orderedCNodes.push(cnodes[childIdx]);\n resNodes.push(nodes[nodeMap[cnodes[childIdx].id]]);\n pickFlags[childIdx] = true;\n foundChild = true;\n break;\n }\n }\n let ii = 0;\n while (!foundChild) {\n if (!pickFlags[ii]) {\n orderedCNodes.push(cnodes[ii]);\n resNodes.push(nodes[nodeMap[cnodes[ii].id]]);\n pickFlags[ii] = true;\n foundChild = true;\n }\n ii++;\n if (ii === n) {\n break;\n }\n }\n }\n }\n });\n return resNodes;\n }\n\n /**\n * 根据节点度数大小排序\n * @return {array} orderedNodes 排序后的结果\n */\n public degreeOrdering(): INode[] {\n const self = this;\n const nodes = self.nodes;\n const orderedNodes: INode[] = [];\n const degrees = self.degrees;\n nodes.forEach((node, i) => {\n node.degree = degrees[i];\n orderedNodes.push(node);\n });\n orderedNodes.sort(compareDegree);\n return orderedNodes;\n }\n\n public getType() {\n return \"circular\";\n }\n}\n","/**\n * @fileOverview random layout\n * @author shiwu.wyy@antfin.com\n */\n\nimport { Edge, OutNode, DagreLayoutOptions } from \"./types\";\nimport dagre from \"dagre\";\nimport { isArray, isNumber } from \"../util\";\nimport { Base } from \"./base\";\n\n/**\n * 层次布局\n */\nexport class DagreLayout extends Base {\n /** layout 方向, 可选 TB, BT, LR, RL */\n public rankdir: \"TB\" | \"BT\" | \"LR\" | \"RL\" = \"TB\";\n\n /** 节点对齐方式,可选 UL, UR, DL, DR */\n public align: undefined | \"UL\" | \"UR\" | \"DL\" | \"DR\";\n\n /** 节点大小 */\n public nodeSize: number | number[] | undefined;\n\n /** 节点水平间距(px) */\n public nodesepFunc: ((d?: any) => number) | undefined;\n\n /** 每一层节点之间间距 */\n public ranksepFunc: ((d?: any) => number) | undefined;\n\n /** 节点水平间距(px) */\n public nodesep: number = 50;\n\n /** 每一层节点之间间距 */\n public ranksep: number = 50;\n\n /** 是否保留布局连线的控制点 */\n public controlPoints: boolean = false;\n\n /** 每层节点是否根据节点数据中的 comboId 进行排序,以防止同层 combo 重叠 */\n public sortByCombo: boolean = false;\n\n public nodes: OutNode[] = [];\n\n public edges: Edge[] = [];\n\n /** 迭代结束的回调函数 */\n public onLayoutEnd: () => void = () => {};\n\n constructor(options?: DagreLayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {\n rankdir: \"TB\", // layout 方向, 可选 TB, BT, LR, RL\n align: undefined, // 节点对齐方式,可选 UL, UR, DL, DR\n nodeSize: undefined, // 节点大小\n nodesepFunc: undefined, // 节点水平间距(px)\n ranksepFunc: undefined, // 每一层节点之间间距\n nodesep: 50, // 节点水平间距(px)\n ranksep: 50, // 每一层节点之间间距\n controlPoints: false, // 是否保留布局连线的控制点\n };\n }\n\n /**\n * 执行布局\n */\n public execute() {\n const self = this;\n const { nodes, nodeSize, rankdir, combos } = self;\n if (!nodes) return;\n const edges = (self.edges as any[]) || [];\n const g = new dagre.graphlib.Graph({\n multigraph: true,\n compound: true,\n });\n\n let nodeSizeFunc: (d?: any) => number[];\n if (!nodeSize) {\n nodeSizeFunc = (d: any) => {\n if (d.size) {\n if (isArray(d.size)) {\n return d.size;\n }\n return [d.size, d.size];\n }\n return [40, 40];\n };\n } else if (isArray(nodeSize)) {\n nodeSizeFunc = () => nodeSize;\n } else {\n nodeSizeFunc = () => [nodeSize, nodeSize];\n }\n let horisep: Function = getFunc(self.nodesepFunc, self.nodesep, 50);\n let vertisep: Function = getFunc(self.ranksepFunc, self.ranksep, 50);\n\n if (rankdir === \"LR\" || rankdir === \"RL\") {\n horisep = getFunc(self.ranksepFunc, self.ranksep, 50);\n vertisep = getFunc(self.nodesepFunc, self.nodesep, 50);\n }\n g.setDefaultEdgeLabel(() => ({}));\n g.setGraph(self);\n\n const comboMap: { [key: string]: boolean } = {};\n nodes.forEach((node) => {\n const size = nodeSizeFunc(node);\n const verti = vertisep(node);\n const hori = horisep(node);\n const width = size[0] + 2 * hori;\n const height = size[1] + 2 * verti;\n g.setNode(node.id, { width, height });\n\n if (this.sortByCombo && node.comboId) {\n if (!comboMap[node.comboId]) {\n comboMap[node.comboId] = true;\n g.setNode(node.comboId, {});\n }\n g.setParent(node.id, node.comboId);\n }\n });\n \n if (this.sortByCombo && combos) {\n combos.forEach(combo => {\n if (!combo.parentId) return;\n if (!comboMap[combo.parentId]) {\n comboMap[combo.parentId] = true;\n g.setNode(combo.parentId, {});\n }\n g.setParent(combo.id, combo.parentId);\n })\n }\n\n edges.forEach((edge) => {\n // dagrejs Wiki https://github.com/dagrejs/dagre/wiki#configuring-the-layout\n g.setEdge(edge.source, edge.target, {\n weight: edge.weight || 1,\n });\n });\n dagre.layout(g);\n let coord;\n g.nodes().forEach((node: any) => {\n coord = g.node(node);\n const i = nodes.findIndex((it) => it.id === node);\n if (!nodes[i]) return;\n nodes[i].x = coord.x;\n nodes[i].y = coord.y;\n });\n g.edges().forEach((edge: any) => {\n coord = g.edge(edge);\n const i = edges.findIndex(\n (it) => it.source === edge.v && it.target === edge.w\n );\n if (self.controlPoints && edges[i].type !== \"loop\") {\n edges[i].controlPoints = coord.points.slice(1, coord.points.length - 1);\n }\n });\n\n if (self.onLayoutEnd) self.onLayoutEnd();\n\n return {\n nodes,\n edges,\n };\n }\n\n public getType() {\n return \"dagre\";\n }\n}\n\nfunction getFunc(\n func: ((d?: any) => number) | undefined,\n value: number,\n defaultValue: number\n): Function {\n let resultFunc;\n if (func) {\n resultFunc = func;\n } else if (isNumber(value)) {\n resultFunc = () => value;\n } else {\n resultFunc = () => defaultValue;\n }\n return resultFunc;\n}\n","const toString = Object.prototype.toString;\n\nexport default function isAnyArray(object) {\n return toString.call(object).endsWith('Array]');\n}\n","import isArray from 'is-any-array';\n\nfunction max(input) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n if (!isArray(input)) {\n throw new TypeError('input must be an array');\n }\n\n if (input.length === 0) {\n throw new TypeError('input must not be empty');\n }\n\n var _options$fromIndex = options.fromIndex,\n fromIndex = _options$fromIndex === void 0 ? 0 : _options$fromIndex,\n _options$toIndex = options.toIndex,\n toIndex = _options$toIndex === void 0 ? input.length : _options$toIndex;\n\n if (fromIndex < 0 || fromIndex >= input.length || !Number.isInteger(fromIndex)) {\n throw new Error('fromIndex must be a positive integer smaller than length');\n }\n\n if (toIndex <= fromIndex || toIndex > input.length || !Number.isInteger(toIndex)) {\n throw new Error('toIndex must be an integer greater than fromIndex and at most equal to length');\n }\n\n var maxValue = input[fromIndex];\n\n for (var i = fromIndex + 1; i < toIndex; i++) {\n if (input[i] > maxValue) maxValue = input[i];\n }\n\n return maxValue;\n}\n\nexport default max;\n","import isArray from 'is-any-array';\n\nfunction min(input) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n if (!isArray(input)) {\n throw new TypeError('input must be an array');\n }\n\n if (input.length === 0) {\n throw new TypeError('input must not be empty');\n }\n\n var _options$fromIndex = options.fromIndex,\n fromIndex = _options$fromIndex === void 0 ? 0 : _options$fromIndex,\n _options$toIndex = options.toIndex,\n toIndex = _options$toIndex === void 0 ? input.length : _options$toIndex;\n\n if (fromIndex < 0 || fromIndex >= input.length || !Number.isInteger(fromIndex)) {\n throw new Error('fromIndex must be a positive integer smaller than length');\n }\n\n if (toIndex <= fromIndex || toIndex > input.length || !Number.isInteger(toIndex)) {\n throw new Error('toIndex must be an integer greater than fromIndex and at most equal to length');\n }\n\n var minValue = input[fromIndex];\n\n for (var i = fromIndex + 1; i < toIndex; i++) {\n if (input[i] < minValue) minValue = input[i];\n }\n\n return minValue;\n}\n\nexport default min;\n","import isArray from 'is-any-array';\nimport max from 'ml-array-max';\nimport min from 'ml-array-min';\n\nfunction rescale(input) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n if (!isArray(input)) {\n throw new TypeError('input must be an array');\n } else if (input.length === 0) {\n throw new TypeError('input must not be empty');\n }\n\n var output;\n\n if (options.output !== undefined) {\n if (!isArray(options.output)) {\n throw new TypeError('output option must be an array if specified');\n }\n\n output = options.output;\n } else {\n output = new Array(input.length);\n }\n\n var currentMin = min(input);\n var currentMax = max(input);\n\n if (currentMin === currentMax) {\n throw new RangeError('minimum and maximum input values are equal. Cannot rescale a constant array');\n }\n\n var _options$min = options.min,\n minValue = _options$min === void 0 ? options.autoMinMax ? currentMin : 0 : _options$min,\n _options$max = options.max,\n maxValue = _options$max === void 0 ? options.autoMinMax ? currentMax : 1 : _options$max;\n\n if (minValue >= maxValue) {\n throw new RangeError('min option must be smaller than max option');\n }\n\n var factor = (maxValue - minValue) / (currentMax - currentMin);\n\n for (var i = 0; i < input.length; i++) {\n output[i] = (input[i] - currentMin) * factor + minValue;\n }\n\n return output;\n}\n\nexport default rescale;\n","const indent = ' '.repeat(2);\nconst indentData = ' '.repeat(4);\n\nexport function inspectMatrix() {\n return inspectMatrixWithOptions(this);\n}\n\nexport function inspectMatrixWithOptions(matrix, options = {}) {\n const { maxRows = 15, maxColumns = 10, maxNumSize = 8 } = options;\n return `${matrix.constructor.name} {\n${indent}[\n${indentData}${inspectData(matrix, maxRows, maxColumns, maxNumSize)}\n${indent}]\n${indent}rows: ${matrix.rows}\n${indent}columns: ${matrix.columns}\n}`;\n}\n\nfunction inspectData(matrix, maxRows, maxColumns, maxNumSize) {\n const { rows, columns } = matrix;\n const maxI = Math.min(rows, maxRows);\n const maxJ = Math.min(columns, maxColumns);\n const result = [];\n for (let i = 0; i < maxI; i++) {\n let line = [];\n for (let j = 0; j < maxJ; j++) {\n line.push(formatNumber(matrix.get(i, j), maxNumSize));\n }\n result.push(`${line.join(' ')}`);\n }\n if (maxJ !== columns) {\n result[result.length - 1] += ` ... ${columns - maxColumns} more columns`;\n }\n if (maxI !== rows) {\n result.push(`... ${rows - maxRows} more rows`);\n }\n return result.join(`\\n${indentData}`);\n}\n\nfunction formatNumber(num, maxNumSize) {\n const numStr = String(num);\n if (numStr.length <= maxNumSize) {\n return numStr.padEnd(maxNumSize, ' ');\n }\n const precise = num.toPrecision(maxNumSize - 2);\n if (precise.length <= maxNumSize) {\n return precise;\n }\n const exponential = num.toExponential(maxNumSize - 2);\n const eIndex = exponential.indexOf('e');\n const e = exponential.slice(eIndex);\n return exponential.slice(0, maxNumSize - e.length) + e;\n}\n","/**\n * @private\n * Check that a row index is not out of bounds\n * @param {Matrix} matrix\n * @param {number} index\n * @param {boolean} [outer]\n */\nexport function checkRowIndex(matrix, index, outer) {\n let max = outer ? matrix.rows : matrix.rows - 1;\n if (index < 0 || index > max) {\n throw new RangeError('Row index out of range');\n }\n}\n\n/**\n * @private\n * Check that a column index is not out of bounds\n * @param {Matrix} matrix\n * @param {number} index\n * @param {boolean} [outer]\n */\nexport function checkColumnIndex(matrix, index, outer) {\n let max = outer ? matrix.columns : matrix.columns - 1;\n if (index < 0 || index > max) {\n throw new RangeError('Column index out of range');\n }\n}\n\n/**\n * @private\n * Check that the provided vector is an array with the right length\n * @param {Matrix} matrix\n * @param {Array|Matrix} vector\n * @return {Array}\n * @throws {RangeError}\n */\nexport function checkRowVector(matrix, vector) {\n if (vector.to1DArray) {\n vector = vector.to1DArray();\n }\n if (vector.length !== matrix.columns) {\n throw new RangeError(\n 'vector size must be the same as the number of columns',\n );\n }\n return vector;\n}\n\n/**\n * @private\n * Check that the provided vector is an array with the right length\n * @param {Matrix} matrix\n * @param {Array|Matrix} vector\n * @return {Array}\n * @throws {RangeError}\n */\nexport function checkColumnVector(matrix, vector) {\n if (vector.to1DArray) {\n vector = vector.to1DArray();\n }\n if (vector.length !== matrix.rows) {\n throw new RangeError('vector size must be the same as the number of rows');\n }\n return vector;\n}\n\nexport function checkIndices(matrix, rowIndices, columnIndices) {\n return {\n row: checkRowIndices(matrix, rowIndices),\n column: checkColumnIndices(matrix, columnIndices),\n };\n}\n\nexport function checkRowIndices(matrix, rowIndices) {\n if (typeof rowIndices !== 'object') {\n throw new TypeError('unexpected type for row indices');\n }\n\n let rowOut = rowIndices.some((r) => {\n return r < 0 || r >= matrix.rows;\n });\n\n if (rowOut) {\n throw new RangeError('row indices are out of range');\n }\n\n if (!Array.isArray(rowIndices)) rowIndices = Array.from(rowIndices);\n\n return rowIndices;\n}\n\nexport function checkColumnIndices(matrix, columnIndices) {\n if (typeof columnIndices !== 'object') {\n throw new TypeError('unexpected type for column indices');\n }\n\n let columnOut = columnIndices.some((c) => {\n return c < 0 || c >= matrix.columns;\n });\n\n if (columnOut) {\n throw new RangeError('column indices are out of range');\n }\n if (!Array.isArray(columnIndices)) columnIndices = Array.from(columnIndices);\n\n return columnIndices;\n}\n\nexport function checkRange(matrix, startRow, endRow, startColumn, endColumn) {\n if (arguments.length !== 5) {\n throw new RangeError('expected 4 arguments');\n }\n checkNumber('startRow', startRow);\n checkNumber('endRow', endRow);\n checkNumber('startColumn', startColumn);\n checkNumber('endColumn', endColumn);\n if (\n startRow > endRow ||\n startColumn > endColumn ||\n startRow < 0 ||\n startRow >= matrix.rows ||\n endRow < 0 ||\n endRow >= matrix.rows ||\n startColumn < 0 ||\n startColumn >= matrix.columns ||\n endColumn < 0 ||\n endColumn >= matrix.columns\n ) {\n throw new RangeError('Submatrix indices are out of range');\n }\n}\n\nexport function newArray(length, value = 0) {\n let array = [];\n for (let i = 0; i < length; i++) {\n array.push(value);\n }\n return array;\n}\n\nfunction checkNumber(name, value) {\n if (typeof value !== 'number') {\n throw new TypeError(`${name} must be a number`);\n }\n}\n\nexport function checkNonEmpty(matrix) {\n if (matrix.isEmpty()) {\n throw new Error('Empty matrix has no elements to index');\n }\n}\n","import rescale from 'ml-array-rescale';\n\nimport { inspectMatrix, inspectMatrixWithOptions } from './inspect';\nimport { installMathOperations } from './mathOperations';\nimport {\n sumByRow,\n sumByColumn,\n sumAll,\n productByRow,\n productByColumn,\n productAll,\n varianceByRow,\n varianceByColumn,\n varianceAll,\n centerByRow,\n centerByColumn,\n centerAll,\n scaleByRow,\n scaleByColumn,\n scaleAll,\n getScaleByRow,\n getScaleByColumn,\n getScaleAll,\n} from './stat';\nimport {\n checkRowVector,\n checkRowIndex,\n checkColumnIndex,\n checkColumnVector,\n checkRange,\n checkIndices,\n checkNonEmpty,\n} from './util';\n\nexport class AbstractMatrix {\n static from1DArray(newRows, newColumns, newData) {\n let length = newRows * newColumns;\n if (length !== newData.length) {\n throw new RangeError('data length does not match given dimensions');\n }\n let newMatrix = new Matrix(newRows, newColumns);\n for (let row = 0; row < newRows; row++) {\n for (let column = 0; column < newColumns; column++) {\n newMatrix.set(row, column, newData[row * newColumns + column]);\n }\n }\n return newMatrix;\n }\n\n static rowVector(newData) {\n let vector = new Matrix(1, newData.length);\n for (let i = 0; i < newData.length; i++) {\n vector.set(0, i, newData[i]);\n }\n return vector;\n }\n\n static columnVector(newData) {\n let vector = new Matrix(newData.length, 1);\n for (let i = 0; i < newData.length; i++) {\n vector.set(i, 0, newData[i]);\n }\n return vector;\n }\n\n static zeros(rows, columns) {\n return new Matrix(rows, columns);\n }\n\n static ones(rows, columns) {\n return new Matrix(rows, columns).fill(1);\n }\n\n static rand(rows, columns, options = {}) {\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { random = Math.random } = options;\n let matrix = new Matrix(rows, columns);\n for (let i = 0; i < rows; i++) {\n for (let j = 0; j < columns; j++) {\n matrix.set(i, j, random());\n }\n }\n return matrix;\n }\n\n static randInt(rows, columns, options = {}) {\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { min = 0, max = 1000, random = Math.random } = options;\n if (!Number.isInteger(min)) throw new TypeError('min must be an integer');\n if (!Number.isInteger(max)) throw new TypeError('max must be an integer');\n if (min >= max) throw new RangeError('min must be smaller than max');\n let interval = max - min;\n let matrix = new Matrix(rows, columns);\n for (let i = 0; i < rows; i++) {\n for (let j = 0; j < columns; j++) {\n let value = min + Math.round(random() * interval);\n matrix.set(i, j, value);\n }\n }\n return matrix;\n }\n\n static eye(rows, columns, value) {\n if (columns === undefined) columns = rows;\n if (value === undefined) value = 1;\n let min = Math.min(rows, columns);\n let matrix = this.zeros(rows, columns);\n for (let i = 0; i < min; i++) {\n matrix.set(i, i, value);\n }\n return matrix;\n }\n\n static diag(data, rows, columns) {\n let l = data.length;\n if (rows === undefined) rows = l;\n if (columns === undefined) columns = rows;\n let min = Math.min(l, rows, columns);\n let matrix = this.zeros(rows, columns);\n for (let i = 0; i < min; i++) {\n matrix.set(i, i, data[i]);\n }\n return matrix;\n }\n\n static min(matrix1, matrix2) {\n matrix1 = this.checkMatrix(matrix1);\n matrix2 = this.checkMatrix(matrix2);\n let rows = matrix1.rows;\n let columns = matrix1.columns;\n let result = new Matrix(rows, columns);\n for (let i = 0; i < rows; i++) {\n for (let j = 0; j < columns; j++) {\n result.set(i, j, Math.min(matrix1.get(i, j), matrix2.get(i, j)));\n }\n }\n return result;\n }\n\n static max(matrix1, matrix2) {\n matrix1 = this.checkMatrix(matrix1);\n matrix2 = this.checkMatrix(matrix2);\n let rows = matrix1.rows;\n let columns = matrix1.columns;\n let result = new this(rows, columns);\n for (let i = 0; i < rows; i++) {\n for (let j = 0; j < columns; j++) {\n result.set(i, j, Math.max(matrix1.get(i, j), matrix2.get(i, j)));\n }\n }\n return result;\n }\n\n static checkMatrix(value) {\n return AbstractMatrix.isMatrix(value) ? value : new Matrix(value);\n }\n\n static isMatrix(value) {\n return value != null && value.klass === 'Matrix';\n }\n\n get size() {\n return this.rows * this.columns;\n }\n\n apply(callback) {\n if (typeof callback !== 'function') {\n throw new TypeError('callback must be a function');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n callback.call(this, i, j);\n }\n }\n return this;\n }\n\n to1DArray() {\n let array = [];\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n array.push(this.get(i, j));\n }\n }\n return array;\n }\n\n to2DArray() {\n let copy = [];\n for (let i = 0; i < this.rows; i++) {\n copy.push([]);\n for (let j = 0; j < this.columns; j++) {\n copy[i].push(this.get(i, j));\n }\n }\n return copy;\n }\n\n toJSON() {\n return this.to2DArray();\n }\n\n isRowVector() {\n return this.rows === 1;\n }\n\n isColumnVector() {\n return this.columns === 1;\n }\n\n isVector() {\n return this.rows === 1 || this.columns === 1;\n }\n\n isSquare() {\n return this.rows === this.columns;\n }\n\n isEmpty() {\n return this.rows === 0 || this.columns === 0;\n }\n\n isSymmetric() {\n if (this.isSquare()) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j <= i; j++) {\n if (this.get(i, j) !== this.get(j, i)) {\n return false;\n }\n }\n }\n return true;\n }\n return false;\n }\n\n isEchelonForm() {\n let i = 0;\n let j = 0;\n let previousColumn = -1;\n let isEchelonForm = true;\n let checked = false;\n while (i < this.rows && isEchelonForm) {\n j = 0;\n checked = false;\n while (j < this.columns && checked === false) {\n if (this.get(i, j) === 0) {\n j++;\n } else if (this.get(i, j) === 1 && j > previousColumn) {\n checked = true;\n previousColumn = j;\n } else {\n isEchelonForm = false;\n checked = true;\n }\n }\n i++;\n }\n return isEchelonForm;\n }\n\n isReducedEchelonForm() {\n let i = 0;\n let j = 0;\n let previousColumn = -1;\n let isReducedEchelonForm = true;\n let checked = false;\n while (i < this.rows && isReducedEchelonForm) {\n j = 0;\n checked = false;\n while (j < this.columns && checked === false) {\n if (this.get(i, j) === 0) {\n j++;\n } else if (this.get(i, j) === 1 && j > previousColumn) {\n checked = true;\n previousColumn = j;\n } else {\n isReducedEchelonForm = false;\n checked = true;\n }\n }\n for (let k = j + 1; k < this.rows; k++) {\n if (this.get(i, k) !== 0) {\n isReducedEchelonForm = false;\n }\n }\n i++;\n }\n return isReducedEchelonForm;\n }\n\n echelonForm() {\n let result = this.clone();\n let h = 0;\n let k = 0;\n while (h < result.rows && k < result.columns) {\n let iMax = h;\n for (let i = h; i < result.rows; i++) {\n if (result.get(i, k) > result.get(iMax, k)) {\n iMax = i;\n }\n }\n if (result.get(iMax, k) === 0) {\n k++;\n } else {\n result.swapRows(h, iMax);\n let tmp = result.get(h, k);\n for (let j = k; j < result.columns; j++) {\n result.set(h, j, result.get(h, j) / tmp);\n }\n for (let i = h + 1; i < result.rows; i++) {\n let factor = result.get(i, k) / result.get(h, k);\n result.set(i, k, 0);\n for (let j = k + 1; j < result.columns; j++) {\n result.set(i, j, result.get(i, j) - result.get(h, j) * factor);\n }\n }\n h++;\n k++;\n }\n }\n return result;\n }\n\n reducedEchelonForm() {\n let result = this.echelonForm();\n let m = result.columns;\n let n = result.rows;\n let h = n - 1;\n while (h >= 0) {\n if (result.maxRow(h) === 0) {\n h--;\n } else {\n let p = 0;\n let pivot = false;\n while (p < n && pivot === false) {\n if (result.get(h, p) === 1) {\n pivot = true;\n } else {\n p++;\n }\n }\n for (let i = 0; i < h; i++) {\n let factor = result.get(i, p);\n for (let j = p; j < m; j++) {\n let tmp = result.get(i, j) - factor * result.get(h, j);\n result.set(i, j, tmp);\n }\n }\n h--;\n }\n }\n return result;\n }\n\n set() {\n throw new Error('set method is unimplemented');\n }\n\n get() {\n throw new Error('get method is unimplemented');\n }\n\n repeat(options = {}) {\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { rows = 1, columns = 1 } = options;\n if (!Number.isInteger(rows) || rows <= 0) {\n throw new TypeError('rows must be a positive integer');\n }\n if (!Number.isInteger(columns) || columns <= 0) {\n throw new TypeError('columns must be a positive integer');\n }\n let matrix = new Matrix(this.rows * rows, this.columns * columns);\n for (let i = 0; i < rows; i++) {\n for (let j = 0; j < columns; j++) {\n matrix.setSubMatrix(this, this.rows * i, this.columns * j);\n }\n }\n return matrix;\n }\n\n fill(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, value);\n }\n }\n return this;\n }\n\n neg() {\n return this.mulS(-1);\n }\n\n getRow(index) {\n checkRowIndex(this, index);\n let row = [];\n for (let i = 0; i < this.columns; i++) {\n row.push(this.get(index, i));\n }\n return row;\n }\n\n getRowVector(index) {\n return Matrix.rowVector(this.getRow(index));\n }\n\n setRow(index, array) {\n checkRowIndex(this, index);\n array = checkRowVector(this, array);\n for (let i = 0; i < this.columns; i++) {\n this.set(index, i, array[i]);\n }\n return this;\n }\n\n swapRows(row1, row2) {\n checkRowIndex(this, row1);\n checkRowIndex(this, row2);\n for (let i = 0; i < this.columns; i++) {\n let temp = this.get(row1, i);\n this.set(row1, i, this.get(row2, i));\n this.set(row2, i, temp);\n }\n return this;\n }\n\n getColumn(index) {\n checkColumnIndex(this, index);\n let column = [];\n for (let i = 0; i < this.rows; i++) {\n column.push(this.get(i, index));\n }\n return column;\n }\n\n getColumnVector(index) {\n return Matrix.columnVector(this.getColumn(index));\n }\n\n setColumn(index, array) {\n checkColumnIndex(this, index);\n array = checkColumnVector(this, array);\n for (let i = 0; i < this.rows; i++) {\n this.set(i, index, array[i]);\n }\n return this;\n }\n\n swapColumns(column1, column2) {\n checkColumnIndex(this, column1);\n checkColumnIndex(this, column2);\n for (let i = 0; i < this.rows; i++) {\n let temp = this.get(i, column1);\n this.set(i, column1, this.get(i, column2));\n this.set(i, column2, temp);\n }\n return this;\n }\n\n addRowVector(vector) {\n vector = checkRowVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) + vector[j]);\n }\n }\n return this;\n }\n\n subRowVector(vector) {\n vector = checkRowVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) - vector[j]);\n }\n }\n return this;\n }\n\n mulRowVector(vector) {\n vector = checkRowVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) * vector[j]);\n }\n }\n return this;\n }\n\n divRowVector(vector) {\n vector = checkRowVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) / vector[j]);\n }\n }\n return this;\n }\n\n addColumnVector(vector) {\n vector = checkColumnVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) + vector[i]);\n }\n }\n return this;\n }\n\n subColumnVector(vector) {\n vector = checkColumnVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) - vector[i]);\n }\n }\n return this;\n }\n\n mulColumnVector(vector) {\n vector = checkColumnVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) * vector[i]);\n }\n }\n return this;\n }\n\n divColumnVector(vector) {\n vector = checkColumnVector(this, vector);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) / vector[i]);\n }\n }\n return this;\n }\n\n mulRow(index, value) {\n checkRowIndex(this, index);\n for (let i = 0; i < this.columns; i++) {\n this.set(index, i, this.get(index, i) * value);\n }\n return this;\n }\n\n mulColumn(index, value) {\n checkColumnIndex(this, index);\n for (let i = 0; i < this.rows; i++) {\n this.set(i, index, this.get(i, index) * value);\n }\n return this;\n }\n\n max() {\n if (this.isEmpty()) {\n return NaN;\n }\n let v = this.get(0, 0);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n if (this.get(i, j) > v) {\n v = this.get(i, j);\n }\n }\n }\n return v;\n }\n\n maxIndex() {\n checkNonEmpty(this);\n let v = this.get(0, 0);\n let idx = [0, 0];\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n if (this.get(i, j) > v) {\n v = this.get(i, j);\n idx[0] = i;\n idx[1] = j;\n }\n }\n }\n return idx;\n }\n\n min() {\n if (this.isEmpty()) {\n return NaN;\n }\n let v = this.get(0, 0);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n if (this.get(i, j) < v) {\n v = this.get(i, j);\n }\n }\n }\n return v;\n }\n\n minIndex() {\n checkNonEmpty(this);\n let v = this.get(0, 0);\n let idx = [0, 0];\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n if (this.get(i, j) < v) {\n v = this.get(i, j);\n idx[0] = i;\n idx[1] = j;\n }\n }\n }\n return idx;\n }\n\n maxRow(row) {\n checkRowIndex(this, row);\n if (this.isEmpty()) {\n return NaN;\n }\n let v = this.get(row, 0);\n for (let i = 1; i < this.columns; i++) {\n if (this.get(row, i) > v) {\n v = this.get(row, i);\n }\n }\n return v;\n }\n\n maxRowIndex(row) {\n checkRowIndex(this, row);\n checkNonEmpty(this);\n let v = this.get(row, 0);\n let idx = [row, 0];\n for (let i = 1; i < this.columns; i++) {\n if (this.get(row, i) > v) {\n v = this.get(row, i);\n idx[1] = i;\n }\n }\n return idx;\n }\n\n minRow(row) {\n checkRowIndex(this, row);\n if (this.isEmpty()) {\n return NaN;\n }\n let v = this.get(row, 0);\n for (let i = 1; i < this.columns; i++) {\n if (this.get(row, i) < v) {\n v = this.get(row, i);\n }\n }\n return v;\n }\n\n minRowIndex(row) {\n checkRowIndex(this, row);\n checkNonEmpty(this);\n let v = this.get(row, 0);\n let idx = [row, 0];\n for (let i = 1; i < this.columns; i++) {\n if (this.get(row, i) < v) {\n v = this.get(row, i);\n idx[1] = i;\n }\n }\n return idx;\n }\n\n maxColumn(column) {\n checkColumnIndex(this, column);\n if (this.isEmpty()) {\n return NaN;\n }\n let v = this.get(0, column);\n for (let i = 1; i < this.rows; i++) {\n if (this.get(i, column) > v) {\n v = this.get(i, column);\n }\n }\n return v;\n }\n\n maxColumnIndex(column) {\n checkColumnIndex(this, column);\n checkNonEmpty(this);\n let v = this.get(0, column);\n let idx = [0, column];\n for (let i = 1; i < this.rows; i++) {\n if (this.get(i, column) > v) {\n v = this.get(i, column);\n idx[0] = i;\n }\n }\n return idx;\n }\n\n minColumn(column) {\n checkColumnIndex(this, column);\n if (this.isEmpty()) {\n return NaN;\n }\n let v = this.get(0, column);\n for (let i = 1; i < this.rows; i++) {\n if (this.get(i, column) < v) {\n v = this.get(i, column);\n }\n }\n return v;\n }\n\n minColumnIndex(column) {\n checkColumnIndex(this, column);\n checkNonEmpty(this);\n let v = this.get(0, column);\n let idx = [0, column];\n for (let i = 1; i < this.rows; i++) {\n if (this.get(i, column) < v) {\n v = this.get(i, column);\n idx[0] = i;\n }\n }\n return idx;\n }\n\n diag() {\n let min = Math.min(this.rows, this.columns);\n let diag = [];\n for (let i = 0; i < min; i++) {\n diag.push(this.get(i, i));\n }\n return diag;\n }\n\n norm(type = 'frobenius') {\n let result = 0;\n if (type === 'max') {\n return this.max();\n } else if (type === 'frobenius') {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n result = result + this.get(i, j) * this.get(i, j);\n }\n }\n return Math.sqrt(result);\n } else {\n throw new RangeError(`unknown norm type: ${type}`);\n }\n }\n\n cumulativeSum() {\n let sum = 0;\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n sum += this.get(i, j);\n this.set(i, j, sum);\n }\n }\n return this;\n }\n\n dot(vector2) {\n if (AbstractMatrix.isMatrix(vector2)) vector2 = vector2.to1DArray();\n let vector1 = this.to1DArray();\n if (vector1.length !== vector2.length) {\n throw new RangeError('vectors do not have the same size');\n }\n let dot = 0;\n for (let i = 0; i < vector1.length; i++) {\n dot += vector1[i] * vector2[i];\n }\n return dot;\n }\n\n mmul(other) {\n other = Matrix.checkMatrix(other);\n\n let m = this.rows;\n let n = this.columns;\n let p = other.columns;\n\n let result = new Matrix(m, p);\n\n let Bcolj = new Float64Array(n);\n for (let j = 0; j < p; j++) {\n for (let k = 0; k < n; k++) {\n Bcolj[k] = other.get(k, j);\n }\n\n for (let i = 0; i < m; i++) {\n let s = 0;\n for (let k = 0; k < n; k++) {\n s += this.get(i, k) * Bcolj[k];\n }\n\n result.set(i, j, s);\n }\n }\n return result;\n }\n\n strassen2x2(other) {\n other = Matrix.checkMatrix(other);\n let result = new Matrix(2, 2);\n const a11 = this.get(0, 0);\n const b11 = other.get(0, 0);\n const a12 = this.get(0, 1);\n const b12 = other.get(0, 1);\n const a21 = this.get(1, 0);\n const b21 = other.get(1, 0);\n const a22 = this.get(1, 1);\n const b22 = other.get(1, 1);\n\n // Compute intermediate values.\n const m1 = (a11 + a22) * (b11 + b22);\n const m2 = (a21 + a22) * b11;\n const m3 = a11 * (b12 - b22);\n const m4 = a22 * (b21 - b11);\n const m5 = (a11 + a12) * b22;\n const m6 = (a21 - a11) * (b11 + b12);\n const m7 = (a12 - a22) * (b21 + b22);\n\n // Combine intermediate values into the output.\n const c00 = m1 + m4 - m5 + m7;\n const c01 = m3 + m5;\n const c10 = m2 + m4;\n const c11 = m1 - m2 + m3 + m6;\n\n result.set(0, 0, c00);\n result.set(0, 1, c01);\n result.set(1, 0, c10);\n result.set(1, 1, c11);\n return result;\n }\n\n strassen3x3(other) {\n other = Matrix.checkMatrix(other);\n let result = new Matrix(3, 3);\n\n const a00 = this.get(0, 0);\n const a01 = this.get(0, 1);\n const a02 = this.get(0, 2);\n const a10 = this.get(1, 0);\n const a11 = this.get(1, 1);\n const a12 = this.get(1, 2);\n const a20 = this.get(2, 0);\n const a21 = this.get(2, 1);\n const a22 = this.get(2, 2);\n\n const b00 = other.get(0, 0);\n const b01 = other.get(0, 1);\n const b02 = other.get(0, 2);\n const b10 = other.get(1, 0);\n const b11 = other.get(1, 1);\n const b12 = other.get(1, 2);\n const b20 = other.get(2, 0);\n const b21 = other.get(2, 1);\n const b22 = other.get(2, 2);\n\n const m1 = (a00 + a01 + a02 - a10 - a11 - a21 - a22) * b11;\n const m2 = (a00 - a10) * (-b01 + b11);\n const m3 = a11 * (-b00 + b01 + b10 - b11 - b12 - b20 + b22);\n const m4 = (-a00 + a10 + a11) * (b00 - b01 + b11);\n const m5 = (a10 + a11) * (-b00 + b01);\n const m6 = a00 * b00;\n const m7 = (-a00 + a20 + a21) * (b00 - b02 + b12);\n const m8 = (-a00 + a20) * (b02 - b12);\n const m9 = (a20 + a21) * (-b00 + b02);\n const m10 = (a00 + a01 + a02 - a11 - a12 - a20 - a21) * b12;\n const m11 = a21 * (-b00 + b02 + b10 - b11 - b12 - b20 + b21);\n const m12 = (-a02 + a21 + a22) * (b11 + b20 - b21);\n const m13 = (a02 - a22) * (b11 - b21);\n const m14 = a02 * b20;\n const m15 = (a21 + a22) * (-b20 + b21);\n const m16 = (-a02 + a11 + a12) * (b12 + b20 - b22);\n const m17 = (a02 - a12) * (b12 - b22);\n const m18 = (a11 + a12) * (-b20 + b22);\n const m19 = a01 * b10;\n const m20 = a12 * b21;\n const m21 = a10 * b02;\n const m22 = a20 * b01;\n const m23 = a22 * b22;\n\n const c00 = m6 + m14 + m19;\n const c01 = m1 + m4 + m5 + m6 + m12 + m14 + m15;\n const c02 = m6 + m7 + m9 + m10 + m14 + m16 + m18;\n const c10 = m2 + m3 + m4 + m6 + m14 + m16 + m17;\n const c11 = m2 + m4 + m5 + m6 + m20;\n const c12 = m14 + m16 + m17 + m18 + m21;\n const c20 = m6 + m7 + m8 + m11 + m12 + m13 + m14;\n const c21 = m12 + m13 + m14 + m15 + m22;\n const c22 = m6 + m7 + m8 + m9 + m23;\n\n result.set(0, 0, c00);\n result.set(0, 1, c01);\n result.set(0, 2, c02);\n result.set(1, 0, c10);\n result.set(1, 1, c11);\n result.set(1, 2, c12);\n result.set(2, 0, c20);\n result.set(2, 1, c21);\n result.set(2, 2, c22);\n return result;\n }\n\n mmulStrassen(y) {\n y = Matrix.checkMatrix(y);\n let x = this.clone();\n let r1 = x.rows;\n let c1 = x.columns;\n let r2 = y.rows;\n let c2 = y.columns;\n if (c1 !== r2) {\n // eslint-disable-next-line no-console\n console.warn(\n `Multiplying ${r1} x ${c1} and ${r2} x ${c2} matrix: dimensions do not match.`,\n );\n }\n\n // Put a matrix into the top left of a matrix of zeros.\n // `rows` and `cols` are the dimensions of the output matrix.\n function embed(mat, rows, cols) {\n let r = mat.rows;\n let c = mat.columns;\n if (r === rows && c === cols) {\n return mat;\n } else {\n let resultat = AbstractMatrix.zeros(rows, cols);\n resultat = resultat.setSubMatrix(mat, 0, 0);\n return resultat;\n }\n }\n\n // Make sure both matrices are the same size.\n // This is exclusively for simplicity:\n // this algorithm can be implemented with matrices of different sizes.\n\n let r = Math.max(r1, r2);\n let c = Math.max(c1, c2);\n x = embed(x, r, c);\n y = embed(y, r, c);\n\n // Our recursive multiplication function.\n function blockMult(a, b, rows, cols) {\n // For small matrices, resort to naive multiplication.\n if (rows <= 512 || cols <= 512) {\n return a.mmul(b); // a is equivalent to this\n }\n\n // Apply dynamic padding.\n if (rows % 2 === 1 && cols % 2 === 1) {\n a = embed(a, rows + 1, cols + 1);\n b = embed(b, rows + 1, cols + 1);\n } else if (rows % 2 === 1) {\n a = embed(a, rows + 1, cols);\n b = embed(b, rows + 1, cols);\n } else if (cols % 2 === 1) {\n a = embed(a, rows, cols + 1);\n b = embed(b, rows, cols + 1);\n }\n\n let halfRows = parseInt(a.rows / 2, 10);\n let halfCols = parseInt(a.columns / 2, 10);\n // Subdivide input matrices.\n let a11 = a.subMatrix(0, halfRows - 1, 0, halfCols - 1);\n let b11 = b.subMatrix(0, halfRows - 1, 0, halfCols - 1);\n\n let a12 = a.subMatrix(0, halfRows - 1, halfCols, a.columns - 1);\n let b12 = b.subMatrix(0, halfRows - 1, halfCols, b.columns - 1);\n\n let a21 = a.subMatrix(halfRows, a.rows - 1, 0, halfCols - 1);\n let b21 = b.subMatrix(halfRows, b.rows - 1, 0, halfCols - 1);\n\n let a22 = a.subMatrix(halfRows, a.rows - 1, halfCols, a.columns - 1);\n let b22 = b.subMatrix(halfRows, b.rows - 1, halfCols, b.columns - 1);\n\n // Compute intermediate values.\n let m1 = blockMult(\n AbstractMatrix.add(a11, a22),\n AbstractMatrix.add(b11, b22),\n halfRows,\n halfCols,\n );\n let m2 = blockMult(AbstractMatrix.add(a21, a22), b11, halfRows, halfCols);\n let m3 = blockMult(a11, AbstractMatrix.sub(b12, b22), halfRows, halfCols);\n let m4 = blockMult(a22, AbstractMatrix.sub(b21, b11), halfRows, halfCols);\n let m5 = blockMult(AbstractMatrix.add(a11, a12), b22, halfRows, halfCols);\n let m6 = blockMult(\n AbstractMatrix.sub(a21, a11),\n AbstractMatrix.add(b11, b12),\n halfRows,\n halfCols,\n );\n let m7 = blockMult(\n AbstractMatrix.sub(a12, a22),\n AbstractMatrix.add(b21, b22),\n halfRows,\n halfCols,\n );\n\n // Combine intermediate values into the output.\n let c11 = AbstractMatrix.add(m1, m4);\n c11.sub(m5);\n c11.add(m7);\n let c12 = AbstractMatrix.add(m3, m5);\n let c21 = AbstractMatrix.add(m2, m4);\n let c22 = AbstractMatrix.sub(m1, m2);\n c22.add(m3);\n c22.add(m6);\n\n // Crop output to the desired size (undo dynamic padding).\n let resultat = AbstractMatrix.zeros(2 * c11.rows, 2 * c11.columns);\n resultat = resultat.setSubMatrix(c11, 0, 0);\n resultat = resultat.setSubMatrix(c12, c11.rows, 0);\n resultat = resultat.setSubMatrix(c21, 0, c11.columns);\n resultat = resultat.setSubMatrix(c22, c11.rows, c11.columns);\n return resultat.subMatrix(0, rows - 1, 0, cols - 1);\n }\n return blockMult(x, y, r, c);\n }\n\n scaleRows(options = {}) {\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { min = 0, max = 1 } = options;\n if (!Number.isFinite(min)) throw new TypeError('min must be a number');\n if (!Number.isFinite(max)) throw new TypeError('max must be a number');\n if (min >= max) throw new RangeError('min must be smaller than max');\n let newMatrix = new Matrix(this.rows, this.columns);\n for (let i = 0; i < this.rows; i++) {\n const row = this.getRow(i);\n if (row.length > 0) {\n rescale(row, { min, max, output: row });\n }\n newMatrix.setRow(i, row);\n }\n return newMatrix;\n }\n\n scaleColumns(options = {}) {\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { min = 0, max = 1 } = options;\n if (!Number.isFinite(min)) throw new TypeError('min must be a number');\n if (!Number.isFinite(max)) throw new TypeError('max must be a number');\n if (min >= max) throw new RangeError('min must be smaller than max');\n let newMatrix = new Matrix(this.rows, this.columns);\n for (let i = 0; i < this.columns; i++) {\n const column = this.getColumn(i);\n if (column.length) {\n rescale(column, {\n min: min,\n max: max,\n output: column,\n });\n }\n newMatrix.setColumn(i, column);\n }\n return newMatrix;\n }\n\n flipRows() {\n const middle = Math.ceil(this.columns / 2);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < middle; j++) {\n let first = this.get(i, j);\n let last = this.get(i, this.columns - 1 - j);\n this.set(i, j, last);\n this.set(i, this.columns - 1 - j, first);\n }\n }\n return this;\n }\n\n flipColumns() {\n const middle = Math.ceil(this.rows / 2);\n for (let j = 0; j < this.columns; j++) {\n for (let i = 0; i < middle; i++) {\n let first = this.get(i, j);\n let last = this.get(this.rows - 1 - i, j);\n this.set(i, j, last);\n this.set(this.rows - 1 - i, j, first);\n }\n }\n return this;\n }\n\n kroneckerProduct(other) {\n other = Matrix.checkMatrix(other);\n\n let m = this.rows;\n let n = this.columns;\n let p = other.rows;\n let q = other.columns;\n\n let result = new Matrix(m * p, n * q);\n for (let i = 0; i < m; i++) {\n for (let j = 0; j < n; j++) {\n for (let k = 0; k < p; k++) {\n for (let l = 0; l < q; l++) {\n result.set(p * i + k, q * j + l, this.get(i, j) * other.get(k, l));\n }\n }\n }\n }\n return result;\n }\n\n transpose() {\n let result = new Matrix(this.columns, this.rows);\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n result.set(j, i, this.get(i, j));\n }\n }\n return result;\n }\n\n sortRows(compareFunction = compareNumbers) {\n for (let i = 0; i < this.rows; i++) {\n this.setRow(i, this.getRow(i).sort(compareFunction));\n }\n return this;\n }\n\n sortColumns(compareFunction = compareNumbers) {\n for (let i = 0; i < this.columns; i++) {\n this.setColumn(i, this.getColumn(i).sort(compareFunction));\n }\n return this;\n }\n\n subMatrix(startRow, endRow, startColumn, endColumn) {\n checkRange(this, startRow, endRow, startColumn, endColumn);\n let newMatrix = new Matrix(\n endRow - startRow + 1,\n endColumn - startColumn + 1,\n );\n for (let i = startRow; i <= endRow; i++) {\n for (let j = startColumn; j <= endColumn; j++) {\n newMatrix.set(i - startRow, j - startColumn, this.get(i, j));\n }\n }\n return newMatrix;\n }\n\n subMatrixRow(indices, startColumn, endColumn) {\n if (startColumn === undefined) startColumn = 0;\n if (endColumn === undefined) endColumn = this.columns - 1;\n if (\n startColumn > endColumn ||\n startColumn < 0 ||\n startColumn >= this.columns ||\n endColumn < 0 ||\n endColumn >= this.columns\n ) {\n throw new RangeError('Argument out of range');\n }\n\n let newMatrix = new Matrix(indices.length, endColumn - startColumn + 1);\n for (let i = 0; i < indices.length; i++) {\n for (let j = startColumn; j <= endColumn; j++) {\n if (indices[i] < 0 || indices[i] >= this.rows) {\n throw new RangeError(`Row index out of range: ${indices[i]}`);\n }\n newMatrix.set(i, j - startColumn, this.get(indices[i], j));\n }\n }\n return newMatrix;\n }\n\n subMatrixColumn(indices, startRow, endRow) {\n if (startRow === undefined) startRow = 0;\n if (endRow === undefined) endRow = this.rows - 1;\n if (\n startRow > endRow ||\n startRow < 0 ||\n startRow >= this.rows ||\n endRow < 0 ||\n endRow >= this.rows\n ) {\n throw new RangeError('Argument out of range');\n }\n\n let newMatrix = new Matrix(endRow - startRow + 1, indices.length);\n for (let i = 0; i < indices.length; i++) {\n for (let j = startRow; j <= endRow; j++) {\n if (indices[i] < 0 || indices[i] >= this.columns) {\n throw new RangeError(`Column index out of range: ${indices[i]}`);\n }\n newMatrix.set(j - startRow, i, this.get(j, indices[i]));\n }\n }\n return newMatrix;\n }\n\n setSubMatrix(matrix, startRow, startColumn) {\n matrix = Matrix.checkMatrix(matrix);\n if (matrix.isEmpty()) {\n return this;\n }\n let endRow = startRow + matrix.rows - 1;\n let endColumn = startColumn + matrix.columns - 1;\n checkRange(this, startRow, endRow, startColumn, endColumn);\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n this.set(startRow + i, startColumn + j, matrix.get(i, j));\n }\n }\n return this;\n }\n\n selection(rowIndices, columnIndices) {\n let indices = checkIndices(this, rowIndices, columnIndices);\n let newMatrix = new Matrix(rowIndices.length, columnIndices.length);\n for (let i = 0; i < indices.row.length; i++) {\n let rowIndex = indices.row[i];\n for (let j = 0; j < indices.column.length; j++) {\n let columnIndex = indices.column[j];\n newMatrix.set(i, j, this.get(rowIndex, columnIndex));\n }\n }\n return newMatrix;\n }\n\n trace() {\n let min = Math.min(this.rows, this.columns);\n let trace = 0;\n for (let i = 0; i < min; i++) {\n trace += this.get(i, i);\n }\n return trace;\n }\n\n clone() {\n let newMatrix = new Matrix(this.rows, this.columns);\n for (let row = 0; row < this.rows; row++) {\n for (let column = 0; column < this.columns; column++) {\n newMatrix.set(row, column, this.get(row, column));\n }\n }\n return newMatrix;\n }\n\n sum(by) {\n switch (by) {\n case 'row':\n return sumByRow(this);\n case 'column':\n return sumByColumn(this);\n case undefined:\n return sumAll(this);\n default:\n throw new Error(`invalid option: ${by}`);\n }\n }\n\n product(by) {\n switch (by) {\n case 'row':\n return productByRow(this);\n case 'column':\n return productByColumn(this);\n case undefined:\n return productAll(this);\n default:\n throw new Error(`invalid option: ${by}`);\n }\n }\n\n mean(by) {\n const sum = this.sum(by);\n switch (by) {\n case 'row': {\n for (let i = 0; i < this.rows; i++) {\n sum[i] /= this.columns;\n }\n return sum;\n }\n case 'column': {\n for (let i = 0; i < this.columns; i++) {\n sum[i] /= this.rows;\n }\n return sum;\n }\n case undefined:\n return sum / this.size;\n default:\n throw new Error(`invalid option: ${by}`);\n }\n }\n\n variance(by, options = {}) {\n if (typeof by === 'object') {\n options = by;\n by = undefined;\n }\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { unbiased = true, mean = this.mean(by) } = options;\n if (typeof unbiased !== 'boolean') {\n throw new TypeError('unbiased must be a boolean');\n }\n switch (by) {\n case 'row': {\n if (!Array.isArray(mean)) {\n throw new TypeError('mean must be an array');\n }\n return varianceByRow(this, unbiased, mean);\n }\n case 'column': {\n if (!Array.isArray(mean)) {\n throw new TypeError('mean must be an array');\n }\n return varianceByColumn(this, unbiased, mean);\n }\n case undefined: {\n if (typeof mean !== 'number') {\n throw new TypeError('mean must be a number');\n }\n return varianceAll(this, unbiased, mean);\n }\n default:\n throw new Error(`invalid option: ${by}`);\n }\n }\n\n standardDeviation(by, options) {\n if (typeof by === 'object') {\n options = by;\n by = undefined;\n }\n const variance = this.variance(by, options);\n if (by === undefined) {\n return Math.sqrt(variance);\n } else {\n for (let i = 0; i < variance.length; i++) {\n variance[i] = Math.sqrt(variance[i]);\n }\n return variance;\n }\n }\n\n center(by, options = {}) {\n if (typeof by === 'object') {\n options = by;\n by = undefined;\n }\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n const { center = this.mean(by) } = options;\n switch (by) {\n case 'row': {\n if (!Array.isArray(center)) {\n throw new TypeError('center must be an array');\n }\n centerByRow(this, center);\n return this;\n }\n case 'column': {\n if (!Array.isArray(center)) {\n throw new TypeError('center must be an array');\n }\n centerByColumn(this, center);\n return this;\n }\n case undefined: {\n if (typeof center !== 'number') {\n throw new TypeError('center must be a number');\n }\n centerAll(this, center);\n return this;\n }\n default:\n throw new Error(`invalid option: ${by}`);\n }\n }\n\n scale(by, options = {}) {\n if (typeof by === 'object') {\n options = by;\n by = undefined;\n }\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n let scale = options.scale;\n switch (by) {\n case 'row': {\n if (scale === undefined) {\n scale = getScaleByRow(this);\n } else if (!Array.isArray(scale)) {\n throw new TypeError('scale must be an array');\n }\n scaleByRow(this, scale);\n return this;\n }\n case 'column': {\n if (scale === undefined) {\n scale = getScaleByColumn(this);\n } else if (!Array.isArray(scale)) {\n throw new TypeError('scale must be an array');\n }\n scaleByColumn(this, scale);\n return this;\n }\n case undefined: {\n if (scale === undefined) {\n scale = getScaleAll(this);\n } else if (typeof scale !== 'number') {\n throw new TypeError('scale must be a number');\n }\n scaleAll(this, scale);\n return this;\n }\n default:\n throw new Error(`invalid option: ${by}`);\n }\n }\n\n toString(options) {\n return inspectMatrixWithOptions(this, options);\n }\n}\n\nAbstractMatrix.prototype.klass = 'Matrix';\nif (typeof Symbol !== 'undefined') {\n AbstractMatrix.prototype[\n Symbol.for('nodejs.util.inspect.custom')\n ] = inspectMatrix;\n}\n\nfunction compareNumbers(a, b) {\n return a - b;\n}\n\n// Synonyms\nAbstractMatrix.random = AbstractMatrix.rand;\nAbstractMatrix.randomInt = AbstractMatrix.randInt;\nAbstractMatrix.diagonal = AbstractMatrix.diag;\nAbstractMatrix.prototype.diagonal = AbstractMatrix.prototype.diag;\nAbstractMatrix.identity = AbstractMatrix.eye;\nAbstractMatrix.prototype.negate = AbstractMatrix.prototype.neg;\nAbstractMatrix.prototype.tensorProduct =\n AbstractMatrix.prototype.kroneckerProduct;\n\nexport default class Matrix extends AbstractMatrix {\n constructor(nRows, nColumns) {\n super();\n if (Matrix.isMatrix(nRows)) {\n // eslint-disable-next-line no-constructor-return\n return nRows.clone();\n } else if (Number.isInteger(nRows) && nRows >= 0) {\n // Create an empty matrix\n this.data = [];\n if (Number.isInteger(nColumns) && nColumns >= 0) {\n for (let i = 0; i < nRows; i++) {\n this.data.push(new Float64Array(nColumns));\n }\n } else {\n throw new TypeError('nColumns must be a positive integer');\n }\n } else if (Array.isArray(nRows)) {\n // Copy the values from the 2D array\n const arrayData = nRows;\n nRows = arrayData.length;\n nColumns = nRows ? arrayData[0].length : 0;\n if (typeof nColumns !== 'number') {\n throw new TypeError(\n 'Data must be a 2D array with at least one element',\n );\n }\n this.data = [];\n for (let i = 0; i < nRows; i++) {\n if (arrayData[i].length !== nColumns) {\n throw new RangeError('Inconsistent array dimensions');\n }\n this.data.push(Float64Array.from(arrayData[i]));\n }\n } else {\n throw new TypeError(\n 'First argument must be a positive number or an array',\n );\n }\n this.rows = nRows;\n this.columns = nColumns;\n }\n\n set(rowIndex, columnIndex, value) {\n this.data[rowIndex][columnIndex] = value;\n return this;\n }\n\n get(rowIndex, columnIndex) {\n return this.data[rowIndex][columnIndex];\n }\n\n removeRow(index) {\n checkRowIndex(this, index);\n this.data.splice(index, 1);\n this.rows -= 1;\n return this;\n }\n\n addRow(index, array) {\n if (array === undefined) {\n array = index;\n index = this.rows;\n }\n checkRowIndex(this, index, true);\n array = Float64Array.from(checkRowVector(this, array));\n this.data.splice(index, 0, array);\n this.rows += 1;\n return this;\n }\n\n removeColumn(index) {\n checkColumnIndex(this, index);\n for (let i = 0; i < this.rows; i++) {\n const newRow = new Float64Array(this.columns - 1);\n for (let j = 0; j < index; j++) {\n newRow[j] = this.data[i][j];\n }\n for (let j = index + 1; j < this.columns; j++) {\n newRow[j - 1] = this.data[i][j];\n }\n this.data[i] = newRow;\n }\n this.columns -= 1;\n return this;\n }\n\n addColumn(index, array) {\n if (typeof array === 'undefined') {\n array = index;\n index = this.columns;\n }\n checkColumnIndex(this, index, true);\n array = checkColumnVector(this, array);\n for (let i = 0; i < this.rows; i++) {\n const newRow = new Float64Array(this.columns + 1);\n let j = 0;\n for (; j < index; j++) {\n newRow[j] = this.data[i][j];\n }\n newRow[j++] = array[i];\n for (; j < this.columns + 1; j++) {\n newRow[j] = this.data[i][j - 1];\n }\n this.data[i] = newRow;\n }\n this.columns += 1;\n return this;\n }\n}\n\ninstallMathOperations(AbstractMatrix, Matrix);\n","import { newArray } from './util';\n\nexport function sumByRow(matrix) {\n let sum = newArray(matrix.rows);\n for (let i = 0; i < matrix.rows; ++i) {\n for (let j = 0; j < matrix.columns; ++j) {\n sum[i] += matrix.get(i, j);\n }\n }\n return sum;\n}\n\nexport function sumByColumn(matrix) {\n let sum = newArray(matrix.columns);\n for (let i = 0; i < matrix.rows; ++i) {\n for (let j = 0; j < matrix.columns; ++j) {\n sum[j] += matrix.get(i, j);\n }\n }\n return sum;\n}\n\nexport function sumAll(matrix) {\n let v = 0;\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n v += matrix.get(i, j);\n }\n }\n return v;\n}\n\nexport function productByRow(matrix) {\n let sum = newArray(matrix.rows, 1);\n for (let i = 0; i < matrix.rows; ++i) {\n for (let j = 0; j < matrix.columns; ++j) {\n sum[i] *= matrix.get(i, j);\n }\n }\n return sum;\n}\n\nexport function productByColumn(matrix) {\n let sum = newArray(matrix.columns, 1);\n for (let i = 0; i < matrix.rows; ++i) {\n for (let j = 0; j < matrix.columns; ++j) {\n sum[j] *= matrix.get(i, j);\n }\n }\n return sum;\n}\n\nexport function productAll(matrix) {\n let v = 1;\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n v *= matrix.get(i, j);\n }\n }\n return v;\n}\n\nexport function varianceByRow(matrix, unbiased, mean) {\n const rows = matrix.rows;\n const cols = matrix.columns;\n const variance = [];\n\n for (let i = 0; i < rows; i++) {\n let sum1 = 0;\n let sum2 = 0;\n let x = 0;\n for (let j = 0; j < cols; j++) {\n x = matrix.get(i, j) - mean[i];\n sum1 += x;\n sum2 += x * x;\n }\n if (unbiased) {\n variance.push((sum2 - (sum1 * sum1) / cols) / (cols - 1));\n } else {\n variance.push((sum2 - (sum1 * sum1) / cols) / cols);\n }\n }\n return variance;\n}\n\nexport function varianceByColumn(matrix, unbiased, mean) {\n const rows = matrix.rows;\n const cols = matrix.columns;\n const variance = [];\n\n for (let j = 0; j < cols; j++) {\n let sum1 = 0;\n let sum2 = 0;\n let x = 0;\n for (let i = 0; i < rows; i++) {\n x = matrix.get(i, j) - mean[j];\n sum1 += x;\n sum2 += x * x;\n }\n if (unbiased) {\n variance.push((sum2 - (sum1 * sum1) / rows) / (rows - 1));\n } else {\n variance.push((sum2 - (sum1 * sum1) / rows) / rows);\n }\n }\n return variance;\n}\n\nexport function varianceAll(matrix, unbiased, mean) {\n const rows = matrix.rows;\n const cols = matrix.columns;\n const size = rows * cols;\n\n let sum1 = 0;\n let sum2 = 0;\n let x = 0;\n for (let i = 0; i < rows; i++) {\n for (let j = 0; j < cols; j++) {\n x = matrix.get(i, j) - mean;\n sum1 += x;\n sum2 += x * x;\n }\n }\n if (unbiased) {\n return (sum2 - (sum1 * sum1) / size) / (size - 1);\n } else {\n return (sum2 - (sum1 * sum1) / size) / size;\n }\n}\n\nexport function centerByRow(matrix, mean) {\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n matrix.set(i, j, matrix.get(i, j) - mean[i]);\n }\n }\n}\n\nexport function centerByColumn(matrix, mean) {\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n matrix.set(i, j, matrix.get(i, j) - mean[j]);\n }\n }\n}\n\nexport function centerAll(matrix, mean) {\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n matrix.set(i, j, matrix.get(i, j) - mean);\n }\n }\n}\n\nexport function getScaleByRow(matrix) {\n const scale = [];\n for (let i = 0; i < matrix.rows; i++) {\n let sum = 0;\n for (let j = 0; j < matrix.columns; j++) {\n sum += Math.pow(matrix.get(i, j), 2) / (matrix.columns - 1);\n }\n scale.push(Math.sqrt(sum));\n }\n return scale;\n}\n\nexport function scaleByRow(matrix, scale) {\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n matrix.set(i, j, matrix.get(i, j) / scale[i]);\n }\n }\n}\n\nexport function getScaleByColumn(matrix) {\n const scale = [];\n for (let j = 0; j < matrix.columns; j++) {\n let sum = 0;\n for (let i = 0; i < matrix.rows; i++) {\n sum += Math.pow(matrix.get(i, j), 2) / (matrix.rows - 1);\n }\n scale.push(Math.sqrt(sum));\n }\n return scale;\n}\n\nexport function scaleByColumn(matrix, scale) {\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n matrix.set(i, j, matrix.get(i, j) / scale[j]);\n }\n }\n}\n\nexport function getScaleAll(matrix) {\n const divider = matrix.size - 1;\n let sum = 0;\n for (let j = 0; j < matrix.columns; j++) {\n for (let i = 0; i < matrix.rows; i++) {\n sum += Math.pow(matrix.get(i, j), 2) / divider;\n }\n }\n return Math.sqrt(sum);\n}\n\nexport function scaleAll(matrix, scale) {\n for (let i = 0; i < matrix.rows; i++) {\n for (let j = 0; j < matrix.columns; j++) {\n matrix.set(i, j, matrix.get(i, j) / scale);\n }\n }\n}\n","export function installMathOperations(AbstractMatrix, Matrix) {\n AbstractMatrix.prototype.add = function add(value) {\n if (typeof value === 'number') return this.addS(value);\n return this.addM(value);\n };\n\n AbstractMatrix.prototype.addS = function addS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) + value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.addM = function addM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) + matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.add = function add(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.add(value);\n };\n\n AbstractMatrix.prototype.sub = function sub(value) {\n if (typeof value === 'number') return this.subS(value);\n return this.subM(value);\n };\n\n AbstractMatrix.prototype.subS = function subS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) - value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.subM = function subM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) - matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.sub = function sub(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.sub(value);\n };\n AbstractMatrix.prototype.subtract = AbstractMatrix.prototype.sub;\n AbstractMatrix.prototype.subtractS = AbstractMatrix.prototype.subS;\n AbstractMatrix.prototype.subtractM = AbstractMatrix.prototype.subM;\n AbstractMatrix.subtract = AbstractMatrix.sub;\n\n AbstractMatrix.prototype.mul = function mul(value) {\n if (typeof value === 'number') return this.mulS(value);\n return this.mulM(value);\n };\n\n AbstractMatrix.prototype.mulS = function mulS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) * value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.mulM = function mulM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) * matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.mul = function mul(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.mul(value);\n };\n AbstractMatrix.prototype.multiply = AbstractMatrix.prototype.mul;\n AbstractMatrix.prototype.multiplyS = AbstractMatrix.prototype.mulS;\n AbstractMatrix.prototype.multiplyM = AbstractMatrix.prototype.mulM;\n AbstractMatrix.multiply = AbstractMatrix.mul;\n\n AbstractMatrix.prototype.div = function div(value) {\n if (typeof value === 'number') return this.divS(value);\n return this.divM(value);\n };\n\n AbstractMatrix.prototype.divS = function divS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) / value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.divM = function divM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) / matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.div = function div(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.div(value);\n };\n AbstractMatrix.prototype.divide = AbstractMatrix.prototype.div;\n AbstractMatrix.prototype.divideS = AbstractMatrix.prototype.divS;\n AbstractMatrix.prototype.divideM = AbstractMatrix.prototype.divM;\n AbstractMatrix.divide = AbstractMatrix.div;\n\n AbstractMatrix.prototype.mod = function mod(value) {\n if (typeof value === 'number') return this.modS(value);\n return this.modM(value);\n };\n\n AbstractMatrix.prototype.modS = function modS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) % value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.modM = function modM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) % matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.mod = function mod(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.mod(value);\n };\n AbstractMatrix.prototype.modulus = AbstractMatrix.prototype.mod;\n AbstractMatrix.prototype.modulusS = AbstractMatrix.prototype.modS;\n AbstractMatrix.prototype.modulusM = AbstractMatrix.prototype.modM;\n AbstractMatrix.modulus = AbstractMatrix.mod;\n\n AbstractMatrix.prototype.and = function and(value) {\n if (typeof value === 'number') return this.andS(value);\n return this.andM(value);\n };\n\n AbstractMatrix.prototype.andS = function andS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) & value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.andM = function andM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) & matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.and = function and(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.and(value);\n };\n\n AbstractMatrix.prototype.or = function or(value) {\n if (typeof value === 'number') return this.orS(value);\n return this.orM(value);\n };\n\n AbstractMatrix.prototype.orS = function orS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) | value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.orM = function orM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) | matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.or = function or(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.or(value);\n };\n\n AbstractMatrix.prototype.xor = function xor(value) {\n if (typeof value === 'number') return this.xorS(value);\n return this.xorM(value);\n };\n\n AbstractMatrix.prototype.xorS = function xorS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) ^ value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.xorM = function xorM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) ^ matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.xor = function xor(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.xor(value);\n };\n\n AbstractMatrix.prototype.leftShift = function leftShift(value) {\n if (typeof value === 'number') return this.leftShiftS(value);\n return this.leftShiftM(value);\n };\n\n AbstractMatrix.prototype.leftShiftS = function leftShiftS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) << value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.leftShiftM = function leftShiftM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) << matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.leftShift = function leftShift(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.leftShift(value);\n };\n\n AbstractMatrix.prototype.signPropagatingRightShift = function signPropagatingRightShift(value) {\n if (typeof value === 'number') return this.signPropagatingRightShiftS(value);\n return this.signPropagatingRightShiftM(value);\n };\n\n AbstractMatrix.prototype.signPropagatingRightShiftS = function signPropagatingRightShiftS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) >> value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.signPropagatingRightShiftM = function signPropagatingRightShiftM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) >> matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.signPropagatingRightShift = function signPropagatingRightShift(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.signPropagatingRightShift(value);\n };\n\n AbstractMatrix.prototype.rightShift = function rightShift(value) {\n if (typeof value === 'number') return this.rightShiftS(value);\n return this.rightShiftM(value);\n };\n\n AbstractMatrix.prototype.rightShiftS = function rightShiftS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) >>> value);\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.rightShiftM = function rightShiftM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, this.get(i, j) >>> matrix.get(i, j));\n }\n }\n return this;\n };\n\n AbstractMatrix.rightShift = function rightShift(matrix, value) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.rightShift(value);\n };\n AbstractMatrix.prototype.zeroFillRightShift = AbstractMatrix.prototype.rightShift;\n AbstractMatrix.prototype.zeroFillRightShiftS = AbstractMatrix.prototype.rightShiftS;\n AbstractMatrix.prototype.zeroFillRightShiftM = AbstractMatrix.prototype.rightShiftM;\n AbstractMatrix.zeroFillRightShift = AbstractMatrix.rightShift;\n\n AbstractMatrix.prototype.not = function not() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, ~(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.not = function not(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.not();\n };\n\n AbstractMatrix.prototype.abs = function abs() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.abs(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.abs = function abs(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.abs();\n };\n\n AbstractMatrix.prototype.acos = function acos() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.acos(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.acos = function acos(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.acos();\n };\n\n AbstractMatrix.prototype.acosh = function acosh() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.acosh(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.acosh = function acosh(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.acosh();\n };\n\n AbstractMatrix.prototype.asin = function asin() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.asin(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.asin = function asin(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.asin();\n };\n\n AbstractMatrix.prototype.asinh = function asinh() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.asinh(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.asinh = function asinh(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.asinh();\n };\n\n AbstractMatrix.prototype.atan = function atan() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.atan(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.atan = function atan(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.atan();\n };\n\n AbstractMatrix.prototype.atanh = function atanh() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.atanh(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.atanh = function atanh(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.atanh();\n };\n\n AbstractMatrix.prototype.cbrt = function cbrt() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.cbrt(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.cbrt = function cbrt(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.cbrt();\n };\n\n AbstractMatrix.prototype.ceil = function ceil() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.ceil(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.ceil = function ceil(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.ceil();\n };\n\n AbstractMatrix.prototype.clz32 = function clz32() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.clz32(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.clz32 = function clz32(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.clz32();\n };\n\n AbstractMatrix.prototype.cos = function cos() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.cos(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.cos = function cos(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.cos();\n };\n\n AbstractMatrix.prototype.cosh = function cosh() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.cosh(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.cosh = function cosh(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.cosh();\n };\n\n AbstractMatrix.prototype.exp = function exp() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.exp(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.exp = function exp(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.exp();\n };\n\n AbstractMatrix.prototype.expm1 = function expm1() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.expm1(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.expm1 = function expm1(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.expm1();\n };\n\n AbstractMatrix.prototype.floor = function floor() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.floor(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.floor = function floor(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.floor();\n };\n\n AbstractMatrix.prototype.fround = function fround() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.fround(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.fround = function fround(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.fround();\n };\n\n AbstractMatrix.prototype.log = function log() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.log(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.log = function log(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.log();\n };\n\n AbstractMatrix.prototype.log1p = function log1p() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.log1p(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.log1p = function log1p(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.log1p();\n };\n\n AbstractMatrix.prototype.log10 = function log10() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.log10(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.log10 = function log10(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.log10();\n };\n\n AbstractMatrix.prototype.log2 = function log2() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.log2(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.log2 = function log2(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.log2();\n };\n\n AbstractMatrix.prototype.round = function round() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.round(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.round = function round(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.round();\n };\n\n AbstractMatrix.prototype.sign = function sign() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.sign(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.sign = function sign(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.sign();\n };\n\n AbstractMatrix.prototype.sin = function sin() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.sin(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.sin = function sin(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.sin();\n };\n\n AbstractMatrix.prototype.sinh = function sinh() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.sinh(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.sinh = function sinh(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.sinh();\n };\n\n AbstractMatrix.prototype.sqrt = function sqrt() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.sqrt(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.sqrt = function sqrt(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.sqrt();\n };\n\n AbstractMatrix.prototype.tan = function tan() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.tan(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.tan = function tan(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.tan();\n };\n\n AbstractMatrix.prototype.tanh = function tanh() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.tanh(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.tanh = function tanh(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.tanh();\n };\n\n AbstractMatrix.prototype.trunc = function trunc() {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.trunc(this.get(i, j)));\n }\n }\n return this;\n };\n\n AbstractMatrix.trunc = function trunc(matrix) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.trunc();\n };\n\n AbstractMatrix.pow = function pow(matrix, arg0) {\n const newMatrix = new Matrix(matrix);\n return newMatrix.pow(arg0);\n };\n\n AbstractMatrix.prototype.pow = function pow(value) {\n if (typeof value === 'number') return this.powS(value);\n return this.powM(value);\n };\n\n AbstractMatrix.prototype.powS = function powS(value) {\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.pow(this.get(i, j), value));\n }\n }\n return this;\n };\n\n AbstractMatrix.prototype.powM = function powM(matrix) {\n matrix = Matrix.checkMatrix(matrix);\n if (this.rows !== matrix.rows ||\n this.columns !== matrix.columns) {\n throw new RangeError('Matrices dimensions must be equal');\n }\n for (let i = 0; i < this.rows; i++) {\n for (let j = 0; j < this.columns; j++) {\n this.set(i, j, Math.pow(this.get(i, j), matrix.get(i, j)));\n }\n }\n return this;\n };\n}\n","import { AbstractMatrix } from '../matrix';\n\nexport default class WrapperMatrix2D extends AbstractMatrix {\n constructor(data) {\n super();\n this.data = data;\n this.rows = data.length;\n this.columns = data[0].length;\n }\n\n set(rowIndex, columnIndex, value) {\n this.data[rowIndex][columnIndex] = value;\n return this;\n }\n\n get(rowIndex, columnIndex) {\n return this.data[rowIndex][columnIndex];\n }\n}\n","export function hypotenuse(a, b) {\n let r = 0;\n if (Math.abs(a) > Math.abs(b)) {\n r = b / a;\n return Math.abs(a) * Math.sqrt(1 + r * r);\n }\n if (b !== 0) {\n r = a / b;\n return Math.abs(b) * Math.sqrt(1 + r * r);\n }\n return 0;\n}\n","import Matrix from '../matrix';\nimport WrapperMatrix2D from '../wrap/WrapperMatrix2D';\n\nimport { hypotenuse } from './util';\n\nexport default class SingularValueDecomposition {\n constructor(value, options = {}) {\n value = WrapperMatrix2D.checkMatrix(value);\n\n if (value.isEmpty()) {\n throw new Error('Matrix must be non-empty');\n }\n\n let m = value.rows;\n let n = value.columns;\n\n const {\n computeLeftSingularVectors = true,\n computeRightSingularVectors = true,\n autoTranspose = false,\n } = options;\n\n let wantu = Boolean(computeLeftSingularVectors);\n let wantv = Boolean(computeRightSingularVectors);\n\n let swapped = false;\n let a;\n if (m < n) {\n if (!autoTranspose) {\n a = value.clone();\n // eslint-disable-next-line no-console\n console.warn(\n 'Computing SVD on a matrix with more columns than rows. Consider enabling autoTranspose',\n );\n } else {\n a = value.transpose();\n m = a.rows;\n n = a.columns;\n swapped = true;\n let aux = wantu;\n wantu = wantv;\n wantv = aux;\n }\n } else {\n a = value.clone();\n }\n\n let nu = Math.min(m, n);\n let ni = Math.min(m + 1, n);\n let s = new Float64Array(ni);\n let U = new Matrix(m, nu);\n let V = new Matrix(n, n);\n\n let e = new Float64Array(n);\n let work = new Float64Array(m);\n\n let si = new Float64Array(ni);\n for (let i = 0; i < ni; i++) si[i] = i;\n\n let nct = Math.min(m - 1, n);\n let nrt = Math.max(0, Math.min(n - 2, m));\n let mrc = Math.max(nct, nrt);\n\n for (let k = 0; k < mrc; k++) {\n if (k < nct) {\n s[k] = 0;\n for (let i = k; i < m; i++) {\n s[k] = hypotenuse(s[k], a.get(i, k));\n }\n if (s[k] !== 0) {\n if (a.get(k, k) < 0) {\n s[k] = -s[k];\n }\n for (let i = k; i < m; i++) {\n a.set(i, k, a.get(i, k) / s[k]);\n }\n a.set(k, k, a.get(k, k) + 1);\n }\n s[k] = -s[k];\n }\n\n for (let j = k + 1; j < n; j++) {\n if (k < nct && s[k] !== 0) {\n let t = 0;\n for (let i = k; i < m; i++) {\n t += a.get(i, k) * a.get(i, j);\n }\n t = -t / a.get(k, k);\n for (let i = k; i < m; i++) {\n a.set(i, j, a.get(i, j) + t * a.get(i, k));\n }\n }\n e[j] = a.get(k, j);\n }\n\n if (wantu && k < nct) {\n for (let i = k; i < m; i++) {\n U.set(i, k, a.get(i, k));\n }\n }\n\n if (k < nrt) {\n e[k] = 0;\n for (let i = k + 1; i < n; i++) {\n e[k] = hypotenuse(e[k], e[i]);\n }\n if (e[k] !== 0) {\n if (e[k + 1] < 0) {\n e[k] = 0 - e[k];\n }\n for (let i = k + 1; i < n; i++) {\n e[i] /= e[k];\n }\n e[k + 1] += 1;\n }\n e[k] = -e[k];\n if (k + 1 < m && e[k] !== 0) {\n for (let i = k + 1; i < m; i++) {\n work[i] = 0;\n }\n for (let i = k + 1; i < m; i++) {\n for (let j = k + 1; j < n; j++) {\n work[i] += e[j] * a.get(i, j);\n }\n }\n for (let j = k + 1; j < n; j++) {\n let t = -e[j] / e[k + 1];\n for (let i = k + 1; i < m; i++) {\n a.set(i, j, a.get(i, j) + t * work[i]);\n }\n }\n }\n if (wantv) {\n for (let i = k + 1; i < n; i++) {\n V.set(i, k, e[i]);\n }\n }\n }\n }\n\n let p = Math.min(n, m + 1);\n if (nct < n) {\n s[nct] = a.get(nct, nct);\n }\n if (m < p) {\n s[p - 1] = 0;\n }\n if (nrt + 1 < p) {\n e[nrt] = a.get(nrt, p - 1);\n }\n e[p - 1] = 0;\n\n if (wantu) {\n for (let j = nct; j < nu; j++) {\n for (let i = 0; i < m; i++) {\n U.set(i, j, 0);\n }\n U.set(j, j, 1);\n }\n for (let k = nct - 1; k >= 0; k--) {\n if (s[k] !== 0) {\n for (let j = k + 1; j < nu; j++) {\n let t = 0;\n for (let i = k; i < m; i++) {\n t += U.get(i, k) * U.get(i, j);\n }\n t = -t / U.get(k, k);\n for (let i = k; i < m; i++) {\n U.set(i, j, U.get(i, j) + t * U.get(i, k));\n }\n }\n for (let i = k; i < m; i++) {\n U.set(i, k, -U.get(i, k));\n }\n U.set(k, k, 1 + U.get(k, k));\n for (let i = 0; i < k - 1; i++) {\n U.set(i, k, 0);\n }\n } else {\n for (let i = 0; i < m; i++) {\n U.set(i, k, 0);\n }\n U.set(k, k, 1);\n }\n }\n }\n\n if (wantv) {\n for (let k = n - 1; k >= 0; k--) {\n if (k < nrt && e[k] !== 0) {\n for (let j = k + 1; j < n; j++) {\n let t = 0;\n for (let i = k + 1; i < n; i++) {\n t += V.get(i, k) * V.get(i, j);\n }\n t = -t / V.get(k + 1, k);\n for (let i = k + 1; i < n; i++) {\n V.set(i, j, V.get(i, j) + t * V.get(i, k));\n }\n }\n }\n for (let i = 0; i < n; i++) {\n V.set(i, k, 0);\n }\n V.set(k, k, 1);\n }\n }\n\n let pp = p - 1;\n let iter = 0;\n let eps = Number.EPSILON;\n while (p > 0) {\n let k, kase;\n for (k = p - 2; k >= -1; k--) {\n if (k === -1) {\n break;\n }\n const alpha =\n Number.MIN_VALUE + eps * Math.abs(s[k] + Math.abs(s[k + 1]));\n if (Math.abs(e[k]) <= alpha || Number.isNaN(e[k])) {\n e[k] = 0;\n break;\n }\n }\n if (k === p - 2) {\n kase = 4;\n } else {\n let ks;\n for (ks = p - 1; ks >= k; ks--) {\n if (ks === k) {\n break;\n }\n let t =\n (ks !== p ? Math.abs(e[ks]) : 0) +\n (ks !== k + 1 ? Math.abs(e[ks - 1]) : 0);\n if (Math.abs(s[ks]) <= eps * t) {\n s[ks] = 0;\n break;\n }\n }\n if (ks === k) {\n kase = 3;\n } else if (ks === p - 1) {\n kase = 1;\n } else {\n kase = 2;\n k = ks;\n }\n }\n\n k++;\n\n switch (kase) {\n case 1: {\n let f = e[p - 2];\n e[p - 2] = 0;\n for (let j = p - 2; j >= k; j--) {\n let t = hypotenuse(s[j], f);\n let cs = s[j] / t;\n let sn = f / t;\n s[j] = t;\n if (j !== k) {\n f = -sn * e[j - 1];\n e[j - 1] = cs * e[j - 1];\n }\n if (wantv) {\n for (let i = 0; i < n; i++) {\n t = cs * V.get(i, j) + sn * V.get(i, p - 1);\n V.set(i, p - 1, -sn * V.get(i, j) + cs * V.get(i, p - 1));\n V.set(i, j, t);\n }\n }\n }\n break;\n }\n case 2: {\n let f = e[k - 1];\n e[k - 1] = 0;\n for (let j = k; j < p; j++) {\n let t = hypotenuse(s[j], f);\n let cs = s[j] / t;\n let sn = f / t;\n s[j] = t;\n f = -sn * e[j];\n e[j] = cs * e[j];\n if (wantu) {\n for (let i = 0; i < m; i++) {\n t = cs * U.get(i, j) + sn * U.get(i, k - 1);\n U.set(i, k - 1, -sn * U.get(i, j) + cs * U.get(i, k - 1));\n U.set(i, j, t);\n }\n }\n }\n break;\n }\n case 3: {\n const scale = Math.max(\n Math.abs(s[p - 1]),\n Math.abs(s[p - 2]),\n Math.abs(e[p - 2]),\n Math.abs(s[k]),\n Math.abs(e[k]),\n );\n const sp = s[p - 1] / scale;\n const spm1 = s[p - 2] / scale;\n const epm1 = e[p - 2] / scale;\n const sk = s[k] / scale;\n const ek = e[k] / scale;\n const b = ((spm1 + sp) * (spm1 - sp) + epm1 * epm1) / 2;\n const c = sp * epm1 * (sp * epm1);\n let shift = 0;\n if (b !== 0 || c !== 0) {\n if (b < 0) {\n shift = 0 - Math.sqrt(b * b + c);\n } else {\n shift = Math.sqrt(b * b + c);\n }\n shift = c / (b + shift);\n }\n let f = (sk + sp) * (sk - sp) + shift;\n let g = sk * ek;\n for (let j = k; j < p - 1; j++) {\n let t = hypotenuse(f, g);\n if (t === 0) t = Number.MIN_VALUE;\n let cs = f / t;\n let sn = g / t;\n if (j !== k) {\n e[j - 1] = t;\n }\n f = cs * s[j] + sn * e[j];\n e[j] = cs * e[j] - sn * s[j];\n g = sn * s[j + 1];\n s[j + 1] = cs * s[j + 1];\n if (wantv) {\n for (let i = 0; i < n; i++) {\n t = cs * V.get(i, j) + sn * V.get(i, j + 1);\n V.set(i, j + 1, -sn * V.get(i, j) + cs * V.get(i, j + 1));\n V.set(i, j, t);\n }\n }\n t = hypotenuse(f, g);\n if (t === 0) t = Number.MIN_VALUE;\n cs = f / t;\n sn = g / t;\n s[j] = t;\n f = cs * e[j] + sn * s[j + 1];\n s[j + 1] = -sn * e[j] + cs * s[j + 1];\n g = sn * e[j + 1];\n e[j + 1] = cs * e[j + 1];\n if (wantu && j < m - 1) {\n for (let i = 0; i < m; i++) {\n t = cs * U.get(i, j) + sn * U.get(i, j + 1);\n U.set(i, j + 1, -sn * U.get(i, j) + cs * U.get(i, j + 1));\n U.set(i, j, t);\n }\n }\n }\n e[p - 2] = f;\n iter = iter + 1;\n break;\n }\n case 4: {\n if (s[k] <= 0) {\n s[k] = s[k] < 0 ? -s[k] : 0;\n if (wantv) {\n for (let i = 0; i <= pp; i++) {\n V.set(i, k, -V.get(i, k));\n }\n }\n }\n while (k < pp) {\n if (s[k] >= s[k + 1]) {\n break;\n }\n let t = s[k];\n s[k] = s[k + 1];\n s[k + 1] = t;\n if (wantv && k < n - 1) {\n for (let i = 0; i < n; i++) {\n t = V.get(i, k + 1);\n V.set(i, k + 1, V.get(i, k));\n V.set(i, k, t);\n }\n }\n if (wantu && k < m - 1) {\n for (let i = 0; i < m; i++) {\n t = U.get(i, k + 1);\n U.set(i, k + 1, U.get(i, k));\n U.set(i, k, t);\n }\n }\n k++;\n }\n iter = 0;\n p--;\n break;\n }\n // no default\n }\n }\n\n if (swapped) {\n let tmp = V;\n V = U;\n U = tmp;\n }\n\n this.m = m;\n this.n = n;\n this.s = s;\n this.U = U;\n this.V = V;\n }\n\n solve(value) {\n let Y = value;\n let e = this.threshold;\n let scols = this.s.length;\n let Ls = Matrix.zeros(scols, scols);\n\n for (let i = 0; i < scols; i++) {\n if (Math.abs(this.s[i]) <= e) {\n Ls.set(i, i, 0);\n } else {\n Ls.set(i, i, 1 / this.s[i]);\n }\n }\n\n let U = this.U;\n let V = this.rightSingularVectors;\n\n let VL = V.mmul(Ls);\n let vrows = V.rows;\n let urows = U.rows;\n let VLU = Matrix.zeros(vrows, urows);\n\n for (let i = 0; i < vrows; i++) {\n for (let j = 0; j < urows; j++) {\n let sum = 0;\n for (let k = 0; k < scols; k++) {\n sum += VL.get(i, k) * U.get(j, k);\n }\n VLU.set(i, j, sum);\n }\n }\n\n return VLU.mmul(Y);\n }\n\n solveForDiagonal(value) {\n return this.solve(Matrix.diag(value));\n }\n\n inverse() {\n let V = this.V;\n let e = this.threshold;\n let vrows = V.rows;\n let vcols = V.columns;\n let X = new Matrix(vrows, this.s.length);\n\n for (let i = 0; i < vrows; i++) {\n for (let j = 0; j < vcols; j++) {\n if (Math.abs(this.s[j]) > e) {\n X.set(i, j, V.get(i, j) / this.s[j]);\n }\n }\n }\n\n let U = this.U;\n\n let urows = U.rows;\n let ucols = U.columns;\n let Y = new Matrix(vrows, urows);\n\n for (let i = 0; i < vrows; i++) {\n for (let j = 0; j < urows; j++) {\n let sum = 0;\n for (let k = 0; k < ucols; k++) {\n sum += X.get(i, k) * U.get(j, k);\n }\n Y.set(i, j, sum);\n }\n }\n\n return Y;\n }\n\n get condition() {\n return this.s[0] / this.s[Math.min(this.m, this.n) - 1];\n }\n\n get norm2() {\n return this.s[0];\n }\n\n get rank() {\n let tol = Math.max(this.m, this.n) * this.s[0] * Number.EPSILON;\n let r = 0;\n let s = this.s;\n for (let i = 0, ii = s.length; i < ii; i++) {\n if (s[i] > tol) {\n r++;\n }\n }\n return r;\n }\n\n get diagonal() {\n return Array.from(this.s);\n }\n\n get threshold() {\n return (Number.EPSILON / 2) * Math.max(this.m, this.n) * this.s[0];\n }\n\n get leftSingularVectors() {\n return this.U;\n }\n\n get rightSingularVectors() {\n return this.V;\n }\n\n get diagonalMatrix() {\n return Matrix.diag(this.s);\n }\n}\n","import { PointTuple, Matrix } from '../types'\nimport { Matrix as MLMatrix, SingularValueDecomposition } from 'ml-matrix'\n\nexport default class MDS {\n /** distance matrix */\n public distances: Matrix[]\n\n /** dimensions */\n public dimension: number\n\n /** link distance */\n public linkDistance: number\n\n constructor(params: { distances: Matrix[]; dimension?: number; linkDistance: number }) {\n this.distances = params.distances\n this.dimension = params.dimension || 2\n this.linkDistance = params.linkDistance\n }\n\n public layout(): PointTuple[] {\n const self = this\n const { dimension, distances, linkDistance } = self\n\n try {\n // square distances\n const M = MLMatrix.mul(MLMatrix.pow(distances, 2), -0.5)\n\n // double centre the rows/columns\n const rowMeans = M.mean('row')\n const colMeans = M.mean('column')\n const totalMean = M.mean()\n M.add(totalMean).subRowVector(rowMeans).subColumnVector(colMeans)\n\n // take the SVD of the double centred matrix, and return the\n // points from it\n const ret = new SingularValueDecomposition(M)\n const eigenValues = MLMatrix.sqrt(ret.diagonalMatrix).diagonal()\n return ret.leftSingularVectors.toJSON().map((row: number[]) => {\n return MLMatrix.mul([row], [eigenValues]).toJSON()[0].splice(0, dimension) as PointTuple\n })\n } catch {\n const res: PointTuple[] = []\n for (let i = 0; i < distances.length; i++) {\n const x = Math.random() * linkDistance\n const y = Math.random() * linkDistance\n res.push([x, y])\n }\n return res\n }\n }\n}\n","import { Matrix, PointTuple, Point } from '../types'\n\nconst SPEED_DIVISOR = 800\n\nexport type RadialNonoverlapForceParam = {\n positions: PointTuple[];\n adjMatrix: Matrix[];\n focusID: number;\n radii: number[];\n iterations?: number;\n height?: number;\n width?: number;\n speed?: number;\n gravity?: number;\n nodeSizeFunc: (node: any) => number;\n k: number;\n strictRadial: boolean;\n nodes: any[];\n}\n\nexport default class RadialNonoverlapForce {\n /** node positions */\n public positions: PointTuple[]\n\n /** adjacency matrix */\n public adjMatrix: Matrix[]\n\n /** focus node */\n public focusID: number\n\n /** radii */\n public radii: number[]\n\n /** the number of iterations */\n public iterations: number\n\n /** the height of the canvas */\n public height: number\n\n /** the width of the canvas */\n public width: number\n\n /** the moving speed */\n public speed: number\n\n /** the gravity */\n public gravity: number\n\n /** the node size */\n public nodeSizeFunc: (node: any) => number\n\n /** the strength of forces */\n public k: number\n\n /** if each circle can be separated into subcircles to avoid overlappings */\n public strictRadial: boolean\n\n /** the nodes data */\n public nodes: any[]\n\n private maxDisplace: number | undefined\n\n private disp: Point[] = []\n\n constructor(params: RadialNonoverlapForceParam) {\n this.positions = params.positions\n this.adjMatrix = params.adjMatrix\n this.focusID = params.focusID\n this.radii = params.radii\n this.iterations = params.iterations || 10\n this.height = params.height || 10\n this.width = params.width || 10\n this.speed = params.speed || 100\n this.gravity = params.gravity || 10\n this.nodeSizeFunc = params.nodeSizeFunc\n this.k = params.k || 5\n this.strictRadial = params.strictRadial\n this.nodes = params.nodes\n }\n\n public layout(): PointTuple[] {\n const self = this\n const positions = self.positions\n const disp: Point[] = []\n const iterations = self.iterations\n const maxDisplace = self.width / 10\n self.maxDisplace = maxDisplace\n self.disp = disp\n for (let i = 0; i < iterations; i++) {\n positions.forEach((_, k) => {\n disp[k] = { x: 0, y: 0 }\n })\n // 给重叠的节点增加斥力\n self.getRepulsion()\n self.updatePositions()\n }\n return positions\n }\n\n private getRepulsion() {\n const self = this\n const positions = self.positions\n const nodes = self.nodes\n const disp = self.disp\n const k = self.k\n const radii = self.radii || []\n\n positions.forEach((v: PointTuple, i: number) => {\n disp[i] = { x: 0, y: 0 }\n positions.forEach((u: PointTuple, j: number) => {\n if (i === j) {\n return\n }\n // v and u are not on the same circle, return\n if (radii[i] !== radii[j]) {\n return\n }\n let vecx = v[0] - u[0]\n let vecy = v[1] - u[1]\n let vecLength = Math.sqrt(vecx * vecx + vecy * vecy)\n if (vecLength === 0) {\n vecLength = 1\n const sign = i > j ? 1 : -1\n vecx = 0.01 * sign\n vecy = 0.01 * sign\n }\n // these two nodes overlap\n if (vecLength < self.nodeSizeFunc(nodes[i]) / 2 + self.nodeSizeFunc(nodes[j]) / 2) {\n const common = (k * k) / vecLength\n disp[i].x += (vecx / vecLength) * common\n disp[i].y += (vecy / vecLength) * common\n }\n })\n })\n }\n\n private updatePositions() {\n const self = this\n const positions = self.positions\n const disp = self.disp\n const speed = self.speed\n const strictRadial = self.strictRadial\n const f = self.focusID\n const maxDisplace = self.maxDisplace || self.width / 10\n\n if (strictRadial) {\n disp.forEach((di, i) => {\n const vx = positions[i][0] - positions[f][0]\n const vy = positions[i][1] - positions[f][1]\n const vLength = Math.sqrt(vx * vx + vy * vy)\n let vpx = vy / vLength\n let vpy = -vx / vLength\n const diLength = Math.sqrt(di.x * di.x + di.y * di.y)\n let alpha = Math.acos((vpx * di.x + vpy * di.y) / diLength)\n if (alpha > Math.PI / 2) {\n alpha -= Math.PI / 2\n vpx *= -1\n vpy *= -1\n }\n const tdispLength = Math.cos(alpha) * diLength\n di.x = vpx * tdispLength\n di.y = vpy * tdispLength\n })\n }\n\n // move\n const radii = self.radii\n positions.forEach((n, i) => {\n if (i === f) {\n return\n }\n const distLength = Math.sqrt(disp[i].x * disp[i].x + disp[i].y * disp[i].y)\n if (distLength > 0 && i !== f) {\n const limitedDist = Math.min(maxDisplace * (speed / SPEED_DIVISOR), distLength)\n n[0] += (disp[i].x / distLength) * limitedDist\n n[1] += (disp[i].y / distLength) * limitedDist\n if (strictRadial) {\n let vx = n[0] - positions[f][0]\n let vy = n[1] - positions[f][1]\n const nfDis = Math.sqrt(vx * vx + vy * vy)\n vx = (vx / nfDis) * radii[i]\n vy = (vy / nfDis) * radii[i]\n n[0] = positions[f][0] + vx\n n[1] = positions[f][1] + vy\n }\n }\n })\n }\n}\n","/**\n * @fileOverview random layout\n * @author shiwu.wyy@antfin.com\n */\n\nimport {\n PointTuple,\n Node,\n OutNode,\n Edge,\n Matrix,\n RadialLayoutOptions\n} from \"../types\";\nimport {\n isNaN,\n isArray,\n isFunction,\n isNumber,\n isString,\n floydWarshall,\n getAdjMatrix\n} from \"../../util\";\nimport { Base } from \"../base\";\nimport MDS from \"./mds\";\nimport RadialNonoverlapForce, {\n RadialNonoverlapForceParam\n} from \"./radialNonoverlapForce\";\n\ntype INode = OutNode & {\n size?: number | PointTuple;\n};\n\nfunction getWeightMatrix(M: Matrix[]) {\n const rows = M.length;\n const cols = M[0].length;\n const result = [];\n for (let i = 0; i < rows; i++) {\n const row = [];\n for (let j = 0; j < cols; j++) {\n if (M[i][j] !== 0) {\n row.push(1 / (M[i][j] * M[i][j]));\n } else {\n row.push(0);\n }\n }\n result.push(row);\n }\n return result;\n}\n\nfunction getIndexById(array: any[], id: string) {\n let index = -1;\n array.forEach((a, i) => {\n if (a.id === id) {\n index = i;\n }\n });\n return index;\n}\n\nfunction getEDistance(p1: PointTuple, p2: PointTuple) {\n return Math.sqrt(\n (p1[0] - p2[0]) * (p1[0] - p2[0]) + (p1[1] - p2[1]) * (p1[1] - p2[1])\n );\n}\n\n/**\n * 辐射状布局\n */\nexport class RadialLayout extends Base {\n /** 布局中心 */\n public center: PointTuple;\n\n /** 停止迭代的最大迭代数 */\n public maxIteration: number = 1000;\n\n /** 中心点,默认为数据中第一个点 */\n public focusNode: string | Node | null = null;\n\n /** 每一圈半径 */\n public unitRadius: number | null = null;\n\n /** 默认边长度 */\n public linkDistance: number = 50;\n\n /** 是否防止重叠 */\n public preventOverlap: boolean = false;\n\n /** 节点直径 */\n public nodeSize: number | number[] | undefined;\n\n /** 节点间距,防止节点重叠时节点之间的最小距离(两节点边缘最短距离) */\n public nodeSpacing: number | Function | undefined;\n\n /** 是否必须是严格的 radial 布局,即每一层的节点严格布局在一个环上。preventOverlap 为 true 时生效 */\n public strictRadial: boolean = true;\n\n /** 防止重叠步骤的最大迭代次数 */\n public maxPreventOverlapIteration: number = 200;\n\n public sortBy: string | undefined;\n\n public sortStrength: number = 10;\n\n public width: number | undefined;\n\n public height: number | undefined;\n\n private focusIndex: number | undefined;\n\n private distances: Matrix[] | undefined;\n\n private eIdealDistances: Matrix[] | undefined;\n\n private weights: Matrix[] | undefined;\n\n private radii: number[] | undefined;\n\n public nodes: INode[] = [];\n\n public edges: Edge[] = [];\n\n public onLayoutEnd: () => void;\n\n constructor(options?: RadialLayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {\n maxIteration: 1000,\n focusNode: null,\n unitRadius: null,\n linkDistance: 50,\n preventOverlap: false,\n nodeSize: undefined,\n nodeSpacing: undefined,\n strictRadial: true,\n maxPreventOverlapIteration: 200,\n sortBy: undefined,\n sortStrength: 10\n };\n }\n\n /**\n * 执行布局\n */\n public execute() {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges || [];\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width! / 2, self.height! / 2];\n }\n const center = self.center;\n\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n const linkDistance = self.linkDistance;\n // layout\n let focusNode: INode | null = null;\n if (isString(self.focusNode)) {\n let found = false;\n for (let i = 0; i < nodes.length; i++) {\n if (nodes[i].id === self.focusNode) {\n focusNode = nodes[i];\n self.focusNode = focusNode;\n found = true;\n i = nodes.length;\n }\n }\n if (!found) {\n focusNode = null;\n }\n } else {\n focusNode = self.focusNode as INode;\n }\n // default focus node\n if (!focusNode) {\n focusNode = nodes[0];\n self.focusNode = focusNode;\n }\n // the index of the focusNode in data\n const focusIndex = getIndexById(nodes, focusNode.id);\n self.focusIndex = focusIndex;\n\n // the graph-theoretic distance (shortest path distance) matrix\n const adjMatrix = getAdjMatrix({ nodes, edges }, false);\n const D = floydWarshall(adjMatrix);\n const maxDistance = self.maxToFocus(D, focusIndex);\n // replace first node in unconnected component to the circle at (maxDistance + 1)\n self.handleInfinity(D, focusIndex, maxDistance + 1);\n self.distances = D;\n\n // the shortest path distance from each node to focusNode\n const focusNodeD = D[focusIndex];\n const width = self.width || 500;\n const height = self.height || 500;\n let semiWidth =\n width - center[0] > center[0] ? center[0] : width - center[0];\n let semiHeight =\n height - center[1] > center[1] ? center[1] : height - center[1];\n if (semiWidth === 0) {\n semiWidth = width / 2;\n }\n if (semiHeight === 0) {\n semiHeight = height / 2;\n }\n // the maxRadius of the graph\n const maxRadius = semiHeight > semiWidth ? semiWidth : semiHeight;\n const maxD = Math.max(...focusNodeD);\n // the radius for each nodes away from focusNode\n const radii: number[] = [];\n focusNodeD.forEach((value, i) => {\n if (!self.unitRadius) {\n self.unitRadius = maxRadius / maxD;\n }\n radii[i] = value * self.unitRadius;\n });\n self.radii = radii;\n\n const eIdealD = self.eIdealDisMatrix();\n // const eIdealD = scaleMatrix(D, linkDistance);\n self.eIdealDistances = eIdealD;\n // the weight matrix, Wij = 1 / dij^(-2)\n const W = getWeightMatrix(eIdealD);\n self.weights = W;\n\n // the initial positions from mds\n const mds = new MDS({ linkDistance, distances: eIdealD });\n let positions = mds.layout();\n positions.forEach((p: PointTuple) => {\n if (isNaN(p[0])) {\n p[0] = Math.random() * linkDistance;\n }\n if (isNaN(p[1])) {\n p[1] = Math.random() * linkDistance;\n }\n });\n self.positions = positions;\n positions.forEach((p: PointTuple, i: number) => {\n nodes[i].x = p[0] + center[0];\n nodes[i].y = p[1] + center[1];\n });\n // move the graph to origin, centered at focusNode\n positions.forEach((p: PointTuple) => {\n p[0] -= positions[focusIndex][0];\n p[1] -= positions[focusIndex][1];\n });\n self.run();\n const preventOverlap = self.preventOverlap;\n const nodeSize = self.nodeSize;\n let nodeSizeFunc;\n const strictRadial = self.strictRadial;\n // stagger the overlapped nodes\n if (preventOverlap) {\n const nodeSpacing = self.nodeSpacing;\n let nodeSpacingFunc: Function;\n if (isNumber(nodeSpacing)) {\n nodeSpacingFunc = () => nodeSpacing;\n } else if (isFunction(nodeSpacing)) {\n nodeSpacingFunc = nodeSpacing;\n } else {\n nodeSpacingFunc = () => 0;\n }\n if (!nodeSize) {\n nodeSizeFunc = (d: INode) => {\n if (d.size) {\n if (isArray(d.size)) {\n const res = d.size[0] > d.size[1] ? d.size[0] : d.size[1];\n return res + nodeSpacingFunc(d);\n }\n return d.size + nodeSpacingFunc(d);\n }\n return 10 + nodeSpacingFunc(d);\n };\n } else if (isArray(nodeSize)) {\n nodeSizeFunc = (d: INode) => {\n const res = nodeSize[0] > nodeSize[1] ? nodeSize[0] : nodeSize[1];\n return res + nodeSpacingFunc(d);\n };\n } else {\n nodeSizeFunc = (d: INode) => nodeSize + nodeSpacingFunc(d);\n }\n const nonoverlapForceParams: RadialNonoverlapForceParam = {\n nodes,\n nodeSizeFunc,\n adjMatrix,\n positions,\n radii,\n height,\n width,\n strictRadial,\n focusID: focusIndex,\n iterations: self.maxPreventOverlapIteration || 200,\n k: positions.length / 4.5\n };\n const nonoverlapForce = new RadialNonoverlapForce(nonoverlapForceParams);\n positions = nonoverlapForce.layout();\n }\n // move the graph to center\n positions.forEach((p: PointTuple, i: number) => {\n nodes[i].x = p[0] + center[0];\n nodes[i].y = p[1] + center[1];\n });\n\n if (self.onLayoutEnd) self.onLayoutEnd();\n\n return {\n nodes,\n edges\n };\n }\n\n public run() {\n const self = this;\n const maxIteration = self.maxIteration;\n const positions = self.positions || [];\n const W = self.weights || [];\n const eIdealDis = self.eIdealDistances || [];\n const radii = self.radii || [];\n for (let i = 0; i <= maxIteration; i++) {\n const param = i / maxIteration;\n self.oneIteration(param, positions, radii, eIdealDis, W);\n }\n }\n\n private oneIteration(\n param: number,\n positions: PointTuple[],\n radii: number[],\n D: Matrix[],\n W: Matrix[]\n ) {\n const self = this;\n const vparam = 1 - param;\n const focusIndex = self.focusIndex;\n positions.forEach((v: PointTuple, i: number) => {\n // v\n const originDis = getEDistance(v, [0, 0]);\n const reciODis = originDis === 0 ? 0 : 1 / originDis;\n if (i === focusIndex) {\n return;\n }\n let xMolecule = 0;\n let yMolecule = 0;\n let denominator = 0;\n positions.forEach((u, j) => {\n // u\n if (i === j) {\n return;\n }\n // the euclidean distance between v and u\n const edis = getEDistance(v, u);\n const reciEdis = edis === 0 ? 0 : 1 / edis;\n const idealDis = D[j][i];\n // same for x and y\n denominator += W[i][j];\n // x\n xMolecule += W[i][j] * (u[0] + idealDis * (v[0] - u[0]) * reciEdis);\n // y\n yMolecule += W[i][j] * (u[1] + idealDis * (v[1] - u[1]) * reciEdis);\n });\n const reciR = radii[i] === 0 ? 0 : 1 / radii[i];\n denominator *= vparam;\n denominator += param * reciR * reciR;\n // x\n xMolecule *= vparam;\n xMolecule += param * reciR * v[0] * reciODis;\n v[0] = xMolecule / denominator;\n // y\n yMolecule *= vparam;\n yMolecule += param * reciR * v[1] * reciODis;\n v[1] = yMolecule / denominator;\n });\n }\n\n private eIdealDisMatrix(): Matrix[] {\n const self = this;\n const nodes = self.nodes;\n if (!nodes) return [];\n const D = self.distances;\n const linkDis = self.linkDistance;\n const radii = self.radii || [];\n const unitRadius = self.unitRadius || 50;\n const result: Matrix[] = [];\n if (D) {\n D.forEach((row, i) => {\n const newRow: Matrix = [];\n row.forEach((v, j) => {\n if (i === j) {\n newRow.push(0);\n } else if (radii[i] === radii[j]) {\n // i and j are on the same circle\n if (self.sortBy === \"data\") {\n // sort the nodes on the same circle according to the ordering of the data\n newRow.push(\n (v * (Math.abs(i - j) * self.sortStrength)) /\n (radii[i] / unitRadius)\n );\n } else if (self.sortBy) {\n // sort the nodes on the same circle according to the attributes\n let iValue: number | string =\n ((nodes[i] as any)[self.sortBy] as number | string) || 0;\n let jValue: number | string =\n ((nodes[j] as any)[self.sortBy] as number | string) || 0;\n if (isString(iValue)) {\n iValue = iValue.charCodeAt(0);\n }\n if (isString(jValue)) {\n jValue = jValue.charCodeAt(0);\n }\n newRow.push(\n (v * (Math.abs(iValue - jValue) * self.sortStrength)) /\n (radii[i] / unitRadius)\n );\n } else {\n newRow.push((v * linkDis) / (radii[i] / unitRadius));\n }\n } else {\n // i and j are on different circle\n // i and j are on different circle\n const link = (linkDis + unitRadius) / 2;\n newRow.push(v * link);\n }\n });\n result.push(newRow);\n });\n }\n return result;\n }\n\n private handleInfinity(matrix: Matrix[], focusIndex: number, step: number) {\n const length = matrix.length;\n // 遍历 matrix 中遍历 focus 对应行\n for (let i = 0; i < length; i++) {\n // matrix 关注点对应行的 Inf 项\n if (matrix[focusIndex][i] === Infinity) {\n matrix[focusIndex][i] = step;\n matrix[i][focusIndex] = step;\n // 遍历 matrix 中的 i 行,i 行中非 Inf 项若在 focus 行为 Inf,则替换 focus 行的那个 Inf\n for (let j = 0; j < length; j++) {\n if (matrix[i][j] !== Infinity && matrix[focusIndex][j] === Infinity) {\n matrix[focusIndex][j] = step + matrix[i][j];\n matrix[j][focusIndex] = step + matrix[i][j];\n }\n }\n }\n }\n // 处理其他行的 Inf。根据该行对应点与 focus 距离以及 Inf 项点 与 focus 距离,决定替换值\n for (let i = 0; i < length; i++) {\n if (i === focusIndex) {\n continue;\n }\n for (let j = 0; j < length; j++) {\n if (matrix[i][j] === Infinity) {\n let minus = Math.abs(matrix[focusIndex][i] - matrix[focusIndex][j]);\n minus = minus === 0 ? 1 : minus;\n matrix[i][j] = minus;\n }\n }\n }\n }\n\n private maxToFocus(matrix: Matrix[], focusIndex: number): number {\n let max = 0;\n for (let i = 0; i < matrix[focusIndex].length; i++) {\n if (matrix[focusIndex][i] === Infinity) {\n continue;\n }\n max = matrix[focusIndex][i] > max ? matrix[focusIndex][i] : max;\n }\n return max;\n }\n\n public getType() {\n return \"radial\";\n }\n}\n","/**\n * @fileOverview concentric layout\n * @author shiwu.wyy@antfin.com\n * this algorithm refers to <cytoscape.js> - https://github.com/cytoscape/cytoscape.js/\n */\n\nimport {\n OutNode,\n Edge,\n PointTuple,\n IndexMap,\n ConcentricLayoutOptions\n} from \"./types\";\nimport { isString, isArray, isNumber, getDegree } from \"../util\";\nimport { Base } from \"./base\";\n\ntype INode = OutNode & {\n degree: number;\n size: number | PointTuple;\n};\n\ntype NodeMap = {\n [key: string]: INode;\n};\n\n/**\n * 同心圆布局\n */\nexport class ConcentricLayout extends Base {\n /** 布局中心 */\n public center: PointTuple;\n\n public nodeSize: number | PointTuple = 30;\n\n /** min spacing between outside of nodes (used for radius adjustment) */\n public minNodeSpacing: number = 10;\n\n /** prevents node overlap, may overflow boundingBox if not enough space */\n public preventOverlap: boolean = false;\n\n /** how many radians should be between the first and last node (defaults to full circle) */\n public sweep: number | undefined;\n\n /** whether levels have an equal radial distance betwen them, may cause bounding box overflow */\n public equidistant: boolean = false;\n\n /** where nodes start in radians */\n public startAngle: number = (3 / 2) * Math.PI;\n\n /** whether the layout should go clockwise (true) or counterclockwise/anticlockwise (false) */\n public clockwise: boolean = true;\n\n /** the letiation of concentric values in each level */\n public maxLevelDiff: undefined | number;\n\n /** 根据 sortBy 指定的属性进行排布,数值高的放在中心,如果是 sortBy 则会计算节点度数,度数最高的放在中心 */\n public sortBy: string = \"degree\";\n\n public nodes: INode[] = [];\n\n public edges: Edge[] = [];\n\n public width: number = 300;\n\n public height: number = 300;\n\n /** 迭代结束的回调函数 */\n public onLayoutEnd: () => void = () => {};\n\n private maxValueNode: INode | undefined;\n\n private counterclockwise: boolean | undefined;\n\n constructor(options?: ConcentricLayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {\n nodeSize: 30,\n minNodeSpacing: 10,\n preventOverlap: false,\n sweep: undefined,\n equidistant: false,\n startAngle: (3 / 2) * Math.PI,\n clockwise: true,\n maxLevelDiff: undefined,\n sortBy: \"degree\"\n };\n }\n\n /**\n * 执行布局\n */\n public execute() {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n const n = nodes.length;\n if (n === 0) {\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n\n if (n === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n\n const layoutNodes: INode[] = [];\n let maxNodeSize: number;\n if (isArray(self.nodeSize)) {\n maxNodeSize = Math.max(self.nodeSize[0], self.nodeSize[1]);\n } else {\n maxNodeSize = self.nodeSize;\n }\n nodes.forEach(node => {\n layoutNodes.push(node);\n let nodeSize: number = maxNodeSize;\n if (isArray(node.size)) {\n nodeSize = Math.max(node.size[0], node.size[1]);\n } else if (isNumber(node.size)) {\n nodeSize = node.size;\n }\n maxNodeSize = Math.max(maxNodeSize, nodeSize);\n });\n self.clockwise =\n self.counterclockwise !== undefined\n ? !self.counterclockwise\n : self.clockwise;\n\n // layout\n const nodeMap: NodeMap = {};\n const indexMap: IndexMap = {};\n layoutNodes.forEach((node, i) => {\n nodeMap[node.id] = node;\n indexMap[node.id] = i;\n });\n\n // get the node degrees\n if (\n self.sortBy === \"degree\" ||\n !isString(self.sortBy) ||\n (layoutNodes[0] as any)[self.sortBy] === undefined\n ) {\n self.sortBy = \"degree\";\n if (!isNumber(nodes[0].degree)) {\n const values = getDegree(nodes.length, indexMap, edges);\n layoutNodes.forEach((node, i) => {\n node.degree = values[i];\n });\n }\n }\n // sort nodes by value\n layoutNodes.sort(\n (n1: INode, n2: INode) =>\n (n2 as any)[self.sortBy] - (n1 as any)[self.sortBy]\n );\n\n self.maxValueNode = layoutNodes[0];\n\n self.maxLevelDiff =\n self.maxLevelDiff || (self.maxValueNode as any)[self.sortBy] / 4;\n\n // put the values into levels\n const levels: any[] = [[]];\n let currentLevel = levels[0];\n layoutNodes.forEach(node => {\n if (currentLevel.length > 0) {\n const diff = Math.abs(\n currentLevel[0][self.sortBy] - (node as any)[self.sortBy]\n );\n if (self.maxLevelDiff && diff >= self.maxLevelDiff) {\n currentLevel = [];\n levels.push(currentLevel);\n }\n }\n currentLevel.push(node);\n });\n\n // create positions for levels\n let minDist = maxNodeSize + self.minNodeSpacing; // min dist between nodes\n if (!self.preventOverlap) {\n // then strictly constrain to bb\n const firstLvlHasMulti = levels.length > 0 && levels[0].length > 1;\n const maxR = Math.min(self.width, self.height) / 2 - minDist;\n const rStep = maxR / (levels.length + (firstLvlHasMulti ? 1 : 0));\n\n minDist = Math.min(minDist, rStep);\n }\n\n // find the metrics for each level\n let r = 0;\n levels.forEach(level => {\n let sweep = self.sweep;\n if (sweep === undefined) {\n sweep = 2 * Math.PI - (2 * Math.PI) / level.length;\n }\n const dTheta = (level.dTheta = sweep / Math.max(1, level.length - 1));\n\n // calculate the radius\n if (level.length > 1 && self.preventOverlap) {\n // but only if more than one node (can't overlap)\n const dcos = Math.cos(dTheta) - Math.cos(0);\n const dsin = Math.sin(dTheta) - Math.sin(0);\n const rMin = Math.sqrt(\n (minDist * minDist) / (dcos * dcos + dsin * dsin)\n ); // s.t. no nodes overlapping\n\n r = Math.max(rMin, r);\n }\n level.r = r;\n r += minDist;\n });\n\n if (self.equidistant) {\n let rDeltaMax = 0;\n let rr = 0;\n for (let i = 0; i < levels.length; i++) {\n const level = levels[i];\n const rDelta = level.r - rr;\n rDeltaMax = Math.max(rDeltaMax, rDelta);\n }\n rr = 0;\n levels.forEach((level, i) => {\n if (i === 0) {\n rr = level.r;\n }\n level.r = rr;\n rr += rDeltaMax;\n });\n }\n\n // calculate the node positions\n levels.forEach(level => {\n const dTheta = level.dTheta;\n const rr = level.r;\n level.forEach((node: INode, j: number) => {\n const theta = self.startAngle + (self.clockwise ? 1 : -1) * dTheta * j;\n node.x = center[0] + rr * Math.cos(theta);\n node.y = center[1] + rr * Math.sin(theta);\n });\n });\n\n if (self.onLayoutEnd) self.onLayoutEnd();\n\n return {\n nodes,\n edges\n };\n }\n\n public getType() {\n return \"concentric\";\n }\n}\n","/**\n * @fileOverview MDS layout\n * @author shiwu.wyy@antfin.com\n */\n\nimport { Matrix as MLMatrix, SingularValueDecomposition } from \"ml-matrix\";\nimport { PointTuple, OutNode, Edge, Matrix, MDSLayoutOptions } from \"./types\";\nimport { floydWarshall, getAdjMatrix, scaleMatrix } from \"../util\";\nimport { Base } from \"./base\";\n\n/**\n * mds 布局\n */\nexport class MDSLayout extends Base {\n /** 布局中心 */\n public center: PointTuple = [0, 0];\n\n /** 边长度 */\n public linkDistance: number = 50;\n\n private scaledDistances: Matrix[];\n\n public nodes: OutNode[] = [];\n\n public edges: Edge[] = [];\n\n /** 迭代结束的回调函数 */\n public onLayoutEnd: () => void = () => {};\n\n constructor(options?: MDSLayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {\n center: [0, 0],\n linkDistance: 50\n };\n }\n\n /**\n * 执行布局\n */\n public execute() {\n const self = this;\n const { nodes, edges = [] } = self;\n const center = self.center;\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n const linkDistance = self.linkDistance;\n // the graph-theoretic distance (shortest path distance) matrix\n const adjMatrix = getAdjMatrix({ nodes, edges }, false);\n const distances = floydWarshall(adjMatrix);\n self.handleInfinity(distances);\n\n // scale the ideal edge length acoording to linkDistance\n const scaledD = scaleMatrix(distances, linkDistance);\n self.scaledDistances = scaledD;\n\n // get positions by MDS\n const positions = self.runMDS();\n self.positions = positions;\n positions.forEach((p: number[], i: number) => {\n nodes[i].x = p[0] + center[0];\n nodes[i].y = p[1] + center[1];\n });\n\n if (self.onLayoutEnd) self.onLayoutEnd();\n\n return {\n nodes,\n edges\n };\n }\n\n /**\n * mds 算法\n * @return {array} positions 计算后的节点位置数组\n */\n public runMDS(): PointTuple[] {\n const self = this;\n const dimension = 2;\n const distances = self.scaledDistances;\n\n // square distances\n const M = MLMatrix.mul(MLMatrix.pow(distances, 2), -0.5);\n\n // double centre the rows/columns\n const rowMeans = M.mean(\"row\");\n const colMeans = M.mean(\"column\");\n const totalMean = M.mean();\n M.add(totalMean)\n .subRowVector(rowMeans)\n .subColumnVector(colMeans);\n\n // take the SVD of the double centred matrix, and return the\n // points from it\n const ret = new SingularValueDecomposition(M);\n const eigenValues = MLMatrix.sqrt(ret.diagonalMatrix).diagonal();\n return ret.leftSingularVectors.toJSON().map((row: number[]) => {\n return MLMatrix.mul([row], [eigenValues])\n .toJSON()[0]\n .splice(0, dimension) as PointTuple;\n });\n }\n\n public handleInfinity(distances: Matrix[]) {\n let maxDistance = -999999;\n distances.forEach(row => {\n row.forEach(value => {\n if (value === Infinity) {\n return;\n }\n if (maxDistance < value) {\n maxDistance = value;\n }\n });\n });\n distances.forEach((row, i) => {\n row.forEach((value, j) => {\n if (value === Infinity) {\n distances[i][j] = maxDistance;\n }\n });\n });\n }\n\n public getType() {\n return \"mds\";\n }\n}\n","/**\n * @fileOverview fruchterman layout\n * @author shiwu.wyy@antfin.com\n */\n\nimport {\n OutNode,\n Edge,\n PointTuple,\n IndexMap,\n Point,\n FruchtermanLayoutOptions\n} from \"./types\";\nimport { Base } from \"./base\";\nimport { isNumber } from \"../util\";\n\ntype NodeMap = {\n [key: string]: INode;\n};\n\ntype INode = OutNode & {\n cluster: string;\n};\n\nconst SPEED_DIVISOR = 800;\n\n/**\n * fruchterman 布局\n */\nexport class FruchtermanLayout extends Base {\n /** 布局中心 */\n public center: PointTuple;\n\n /** 停止迭代的最大迭代数 */\n public maxIteration: number = 1000;\n\n /** 重力大小,影响图的紧凑程度 */\n public gravity: number = 10;\n\n /** 速度 */\n public speed: number = 5;\n\n /** 是否产生聚类力 */\n public clustering: boolean = false;\n\n /** 聚类力大小 */\n public clusterGravity: number = 10;\n\n public nodes: INode[] | null = [];\n\n public edges: Edge[] | null = [];\n\n public width: number = 300;\n\n public height: number = 300;\n\n public nodeMap: NodeMap = {};\n\n public nodeIdxMap: IndexMap = {};\n\n /** 迭代结束的回调函数 */\n public onLayoutEnd: () => void = () => {};\n\n /** 每次迭代结束的回调函数 */\n public tick: (() => void) | null = () => {};\n\n /** 迭代中的标识 */\n private timeInterval: number;\n\n constructor(options?: FruchtermanLayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {\n maxIteration: 1000,\n gravity: 10,\n speed: 1,\n clustering: false,\n clusterGravity: 10\n };\n }\n\n /**\n * 执行布局\n */\n public execute() {\n const self = this;\n const nodes = self.nodes;\n\n if (self.timeInterval !== undefined && typeof window !== \"undefined\") {\n window.clearInterval(self.timeInterval);\n }\n\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n const nodeMap: NodeMap = {};\n const nodeIdxMap: IndexMap = {};\n nodes.forEach((node, i) => {\n if (!isNumber(node.x)) node.x = Math.random() * this.width;\n if (!isNumber(node.y)) node.y = Math.random() * this.height;\n nodeMap[node.id] = node;\n nodeIdxMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.nodeIdxMap = nodeIdxMap;\n // layout\n return self.run();\n }\n\n public run() {\n const self = this;\n const nodes = self.nodes;\n if (!nodes) return;\n const edges = self.edges;\n const maxIteration = self.maxIteration;\n const center = self.center;\n const area = self.height * self.width;\n const maxDisplace = Math.sqrt(area) / 10;\n const k2 = area / (nodes.length + 1);\n const k = Math.sqrt(k2);\n const gravity = self.gravity;\n const speed = self.speed;\n const clustering = self.clustering;\n const clusterMap: {\n [key: string]: {\n name: string | number;\n cx: number;\n cy: number;\n count: number;\n };\n } = {};\n if (clustering) {\n nodes.forEach(n => {\n if (clusterMap[n.cluster] === undefined) {\n const cluster = {\n name: n.cluster,\n cx: 0,\n cy: 0,\n count: 0\n };\n clusterMap[n.cluster] = cluster;\n }\n const c = clusterMap[n.cluster];\n if (isNumber(n.x)) {\n c.cx += n.x;\n }\n if (isNumber(n.y)) {\n c.cy += n.y;\n }\n c.count++;\n });\n for (const key in clusterMap) {\n clusterMap[key].cx /= clusterMap[key].count;\n clusterMap[key].cy /= clusterMap[key].count;\n }\n }\n\n if (typeof window === \"undefined\") return;\n\n let iter = 0;\n // interval for render the result after each iteration\n this.timeInterval = window.setInterval(() => {\n\n if (!nodes) return;\n\n // for (let i = 0; i < maxIteration; i++) {\n const displacements: Point[] = [];\n nodes.forEach((_, j) => {\n displacements[j] = { x: 0, y: 0 };\n });\n self.applyCalculate(nodes, edges, displacements, k, k2);\n\n // gravity for clusters\n if (clustering) {\n const clusterGravity = self.clusterGravity || gravity;\n nodes.forEach((n, j) => {\n if (!isNumber(n.x) || !isNumber(n.y)) return;\n const c = clusterMap[n.cluster];\n const distLength = Math.sqrt(\n (n.x - c.cx) * (n.x - c.cx) + (n.y - c.cy) * (n.y - c.cy)\n );\n const gravityForce = k * clusterGravity;\n displacements[j].x -= (gravityForce * (n.x - c.cx)) / distLength;\n displacements[j].y -= (gravityForce * (n.y - c.cy)) / distLength;\n });\n\n for (const key in clusterMap) {\n clusterMap[key].cx = 0;\n clusterMap[key].cy = 0;\n clusterMap[key].count = 0;\n }\n\n nodes.forEach(n => {\n const c = clusterMap[n.cluster];\n if (isNumber(n.x)) {\n c.cx += n.x;\n }\n if (isNumber(n.y)) {\n c.cy += n.y;\n }\n c.count++;\n });\n for (const key in clusterMap) {\n clusterMap[key].cx /= clusterMap[key].count;\n clusterMap[key].cy /= clusterMap[key].count;\n }\n }\n\n // gravity\n nodes.forEach((n, j) => {\n if (!isNumber(n.x) || !isNumber(n.y)) return;\n const gravityForce = 0.01 * k * gravity;\n displacements[j].x -= gravityForce * (n.x - center[0]);\n displacements[j].y -= gravityForce * (n.y - center[1]);\n });\n\n // move\n nodes.forEach((n: any, j) => {\n if (isNumber(n.fx) && isNumber(n.fy)) {\n n.x = n.fx;\n n.y = n.fy;\n return;\n }\n if (!isNumber(n.x) || !isNumber(n.y)) return; \n const distLength = Math.sqrt(\n displacements[j].x * displacements[j].x +\n displacements[j].y * displacements[j].y\n );\n if (distLength > 0) {\n // && !n.isFixed()\n const limitedDist = Math.min(\n maxDisplace * (speed / SPEED_DIVISOR),\n distLength\n );\n n.x += (displacements[j].x / distLength) * limitedDist;\n n.y += (displacements[j].y / distLength) * limitedDist;\n }\n });\n\n if (self.tick) self.tick();\n\n iter++;\n if (iter >= maxIteration) {\n if (self.onLayoutEnd) self.onLayoutEnd();\n window.clearInterval(self.timeInterval);\n }\n }, 0);\n\n return {\n nodes,\n edges\n };\n }\n\n private applyCalculate(\n nodes: INode[],\n edges: Edge[] | null,\n displacements: Point[],\n k: number,\n k2: number\n ) {\n const self = this;\n self.calRepulsive(nodes, displacements, k2);\n if (edges) self.calAttractive(edges, displacements, k);\n }\n\n private calRepulsive(nodes: INode[], displacements: Point[], k2: number) {\n nodes.forEach((v, i) => {\n displacements[i] = { x: 0, y: 0 };\n nodes.forEach((u, j) => {\n if (i === j) {\n return;\n }\n if (\n !isNumber(v.x) ||\n !isNumber(u.x) ||\n !isNumber(v.y) ||\n !isNumber(u.y)\n )\n return;\n let vecX = v.x - u.x;\n let vecY = v.y - u.y;\n let vecLengthSqr = vecX * vecX + vecY * vecY;\n if (vecLengthSqr === 0) {\n vecLengthSqr = 1;\n const sign = i > j ? 1 : -1;\n vecX = 0.01 * sign;\n vecY = 0.01 * sign;\n }\n const common = k2 / vecLengthSqr;\n displacements[i].x += vecX * common;\n displacements[i].y += vecY * common;\n });\n });\n }\n\n private calAttractive(edges: Edge[], displacements: Point[], k: number) {\n edges.forEach(e => {\n if (!e.source || !e.target) return;\n const uIndex = this.nodeIdxMap[e.source];\n const vIndex = this.nodeIdxMap[e.target];\n if (uIndex === vIndex) {\n return;\n }\n const u = this.nodeMap[e.source];\n const v = this.nodeMap[e.target];\n if (!isNumber(v.x) || !isNumber(u.x) || !isNumber(v.y) || !isNumber(u.y))\n return;\n const vecX = v.x - u.x;\n const vecY = v.y - u.y;\n const vecLength = Math.sqrt(vecX * vecX + vecY * vecY);\n const common = (vecLength * vecLength) / k;\n displacements[vIndex].x -= (vecX / vecLength) * common;\n displacements[vIndex].y -= (vecY / vecLength) * common;\n displacements[uIndex].x += (vecX / vecLength) * common;\n displacements[uIndex].y += (vecY / vecLength) * common;\n });\n }\n\n public stop() {\n if (this.timeInterval && typeof window !== \"undefined\") {\n window.clearInterval(this.timeInterval);\n }\n }\n\n public destroy() {\n const self = this;\n self.stop();\n self.tick = null;\n self.nodes = null;\n self.edges = null;\n self.destroyed = true;\n }\n\n public getType() {\n return \"fruchterman\";\n }\n}\n","export default function _initializerDefineProperty(target, property, descriptor, context) {\n if (!descriptor) return;\n Object.defineProperty(target, property, {\n enumerable: descriptor.enumerable,\n configurable: descriptor.configurable,\n writable: descriptor.writable,\n value: descriptor.initializer ? descriptor.initializer.call(context) : void 0\n });\n}","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}","export default function _applyDecoratedDescriptor(target, property, decorators, descriptor, context) {\n var desc = {};\n Object.keys(descriptor).forEach(function (key) {\n desc[key] = descriptor[key];\n });\n desc.enumerable = !!desc.enumerable;\n desc.configurable = !!desc.configurable;\n\n if ('value' in desc || desc.initializer) {\n desc.writable = true;\n }\n\n desc = decorators.slice().reverse().reduce(function (desc, decorator) {\n return decorator(target, property, desc) || desc;\n }, desc);\n\n if (context && desc.initializer !== void 0) {\n desc.value = desc.initializer ? desc.initializer.call(context) : void 0;\n desc.initializer = undefined;\n }\n\n if (desc.initializer === void 0) {\n Object.defineProperty(target, property, desc);\n desc = null;\n }\n\n return desc;\n}","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\n\nexport default function _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n\n _next(undefined);\n });\n };\n}","export var EMPTY = -1;\nvar entitySequence = 1;\n/**\n * 类似关系型数据库的主键\n * TODO: 自动生成,考虑序列化\n */\n\nexport function createEntity() {\n return entitySequence++;\n}\n//# sourceMappingURL=Entity.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport { EMPTY } from './Entity';\nexport var Component = function Component(data) {//\n\n _classCallCheck(this, Component);\n};\n/**\n * 管理某一类 Component,尽可能做到 AoS 而非 SoA\n * @see https://wickedengine.net/2019/09/29/entity-component-system/\n * @see https://github.com/turanszkij/WickedEngine/blob/master/WickedEngine/wiECS.h\n */\n// tslint:disable-next-line:max-classes-per-file\n\nexport var ComponentManager = /*#__PURE__*/function () {\n /**\n * 不在 Entity 中维护拥有的 Component 列表,反之亦然\n */\n function ComponentManager(clazz) {\n _classCallCheck(this, ComponentManager);\n\n this.clazz = void 0;\n this.components = [];\n this.entities = [];\n this.lookup = {};\n this.clazz = clazz;\n }\n\n _createClass(ComponentManager, [{\n key: \"clear\",\n value: function clear() {\n this.components = [];\n this.entities = [];\n this.lookup = {};\n }\n }, {\n key: \"contains\",\n value: function contains(entity) {\n return this.lookup[entity] > -1;\n }\n }, {\n key: \"create\",\n value: function create(entity, data) {\n this.lookup[entity] = this.components.length;\n var component = new this.clazz(data || {});\n this.components.push(component);\n this.entities.push(entity);\n return component;\n }\n }, {\n key: \"remove\",\n value: function remove(entity) {\n var componentIndex = this.lookup[entity];\n\n if (componentIndex > -1) {\n if (componentIndex < this.components.length - 1) {\n // 将待删除元素和最后一个元素交换\n // C++ 中有 std::move 这样的操作,避免数据的拷贝\n // @see https://github.com/turanszkij/WickedEngine/blob/master/WickedEngine/wiECS.h#L169\n this.components[componentIndex] = this.components[this.components.length - 1];\n this.entities[componentIndex] = this.entities[this.entities.length - 1];\n this.lookup[this.entities[componentIndex]] = componentIndex;\n }\n } // 待删除元素已经移动到了最后一个\n\n\n this.components.pop();\n this.entities.pop();\n delete this.lookup[entity];\n }\n }, {\n key: \"removeKeepSorted\",\n value: function removeKeepSorted(entity) {\n var componentIndex = this.lookup[entity];\n\n if (componentIndex > -1) {\n var entity2 = this.entities[componentIndex];\n\n if (componentIndex < this.components.length - 1) {\n // Move every component left by one that is after this element:\n for (var _i = componentIndex + 1; _i < this.components.length; ++_i) {\n this.components[_i - 1] = this.components[_i];\n } // Move every entity left by one that is after this element and update lut:\n\n\n for (var _i2 = componentIndex + 1; _i2 < this.entities.length; ++_i2) {\n this.entities[_i2 - 1] = this.entities[_i2];\n this.lookup[this.entities[_i2 - 1]] = _i2 - 1;\n }\n }\n\n this.components.pop();\n this.entities.pop();\n delete this.lookup[entity2];\n }\n }\n }, {\n key: \"moveItem\",\n value: function moveItem(srcIndex, destIndex) {\n if (srcIndex === destIndex) {\n return;\n } // Save the moved component and entity:\n\n\n var srcComponent = this.components[srcIndex];\n var srcEntity = this.entities[srcIndex]; // Every other entity-component that's in the way gets moved by one and lut is kept updated:\n\n var direction = srcIndex < destIndex ? 1 : -1;\n\n for (var _i3 = srcIndex; _i3 !== destIndex; _i3 += direction) {\n var next = _i3 + direction;\n this.components[_i3] = this.components[next];\n this.entities[_i3] = this.entities[next];\n this.lookup[this.entities[_i3]] = _i3;\n } // Saved entity-component moved to the required position:\n\n\n this.components[destIndex] = srcComponent;\n this.entities[destIndex] = srcEntity;\n this.lookup[srcEntity] = destIndex;\n }\n }, {\n key: \"getEntity\",\n value: function getEntity(index) {\n return this.entities[index];\n }\n /**\n * 由于缺少类似 C++ 的重载操作符,没法通过 [下标] 直接访问。因此只能增加该方法用于遍历。\n */\n\n }, {\n key: \"getComponent\",\n value: function getComponent(index) {\n return this.components[index];\n }\n }, {\n key: \"getComponentByEntity\",\n value: function getComponentByEntity(entity) {\n var componentIndex = this.lookup[entity];\n\n if (componentIndex > -1) {\n return this.components[componentIndex];\n }\n\n return null;\n }\n }, {\n key: \"getCount\",\n value: function getCount() {\n return this.components.length;\n }\n }, {\n key: \"getEntityByComponentIndex\",\n value: function getEntityByComponentIndex(componentIdx) {\n for (var _i4 = 0, _Object$keys = Object.keys(this.lookup); _i4 < _Object$keys.length; _i4++) {\n var _entity = _Object$keys[_i4];\n var entityInNum = Number(_entity);\n\n if (this.lookup[entityInNum] === componentIdx) {\n return entityInNum;\n }\n }\n\n return EMPTY;\n }\n }, {\n key: \"find\",\n value: function find(callback) {\n for (var _i5 = 0; _i5 < this.getCount(); _i5++) {\n var _component = this.getComponent(_i5);\n\n if (callback(_component, _i5)) {\n return _component;\n }\n }\n\n return null;\n }\n }, {\n key: \"findIndex\",\n value: function findIndex(callback) {\n for (var _i6 = 0; _i6 < this.getCount(); _i6++) {\n var _component2 = this.getComponent(_i6);\n\n if (callback(_component2, _i6)) {\n return _i6;\n }\n }\n\n return -1;\n }\n }, {\n key: \"forEach\",\n value: function forEach(callback) {\n for (var _i7 = 0, _Object$keys2 = Object.keys(this.lookup); _i7 < _Object$keys2.length; _i7++) {\n var _entity2 = _Object$keys2[_i7];\n var entityInNum = Number(_entity2);\n var componentIndex = this.lookup[entityInNum];\n callback(entityInNum, this.getComponent(componentIndex));\n }\n }\n }, {\n key: \"forEachAsync\",\n value: function () {\n var _forEachAsync = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(callback) {\n var _i8, _Object$keys3, _entity3, entityInNum, componentIndex;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _i8 = 0, _Object$keys3 = Object.keys(this.lookup);\n\n case 1:\n if (!(_i8 < _Object$keys3.length)) {\n _context.next = 10;\n break;\n }\n\n _entity3 = _Object$keys3[_i8];\n entityInNum = Number(_entity3);\n componentIndex = this.lookup[entityInNum];\n _context.next = 7;\n return callback(entityInNum, this.getComponent(componentIndex));\n\n case 7:\n _i8++;\n _context.next = 1;\n break;\n\n case 10:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function forEachAsync(_x) {\n return _forEachAsync.apply(this, arguments);\n }\n\n return forEachAsync;\n }()\n }, {\n key: \"map\",\n value: function map(callback) {\n var result = [];\n\n for (var _i9 = 0, _Object$keys4 = Object.keys(this.lookup); _i9 < _Object$keys4.length; _i9++) {\n var _entity4 = _Object$keys4[_i9];\n var entityInNum = Number(_entity4);\n var componentIndex = this.lookup[entityInNum];\n result.push(callback(entityInNum, this.getComponent(componentIndex)));\n }\n\n return result;\n }\n }]);\n\n return ComponentManager;\n}();\n//# sourceMappingURL=ComponentManager.js.map","export default function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _iterableToArrayLimit(arr, i) {\n if (typeof Symbol === \"undefined\" || !(Symbol.iterator in Object(arr))) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _e = undefined;\n\n try {\n for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","export var IDENTIFIER = {\n // SceneGraph\n HierarchyComponentManager: Symbol('HierarchyComponentManager'),\n TransformComponentManager: Symbol('TransformComponentManager'),\n NameComponentManager: Symbol('NameComponentManager'),\n SceneGraphSystem: Symbol('SceneGraphSystem'),\n // FrameGraph\n FrameGraphSystem: Symbol('FrameGraphSystem'),\n ResourcePool: Symbol('ResourcePool'),\n ResourceHandleComponentManager: Symbol('ResourceHandleComponentManager'),\n PassNodeComponentManager: Symbol('PassNodeComponentManager'),\n // Renderer\n RendererSystem: Symbol('RendererSystem'),\n RenderPass: Symbol('RenderPass'),\n RenderPassFactory: Symbol('Factory<IRenderPass>'),\n Renderable: Symbol('Factory<IRenderPass>'),\n // Mesh\n MeshSystem: Symbol('MeshSystem'),\n MeshComponentManager: Symbol('MeshComponentManager'),\n CullableComponentManager: Symbol('CullableComponentManager'),\n // Geometry\n Geometry: Symbol('Geometry'),\n GeometrySystem: Symbol('GeometrySystem'),\n GeometryComponentManager: Symbol('GeometryComponentManager'),\n // Material\n Material: Symbol('Material'),\n MaterialSystem: Symbol('MaterialSystem'),\n MaterialComponentManager: Symbol('MaterialComponentManager'),\n // RenderPath\n ForwardRenderPath: Symbol('ForwardRenderPath'),\n // ComputeSystem\n ComputeSystem: Symbol('ComputeSystem'),\n ComputeComponentManager: Symbol('ComputeComponentManager'),\n ComputeStrategy: Symbol('ComputeStrategy'),\n Systems: Symbol('Systems'),\n World: Symbol('World'),\n // RenderEngine\n RenderEngine: Symbol('RenderEngine'),\n WebGPUEngine: Symbol('WebGPUEngine'),\n WebGLEngine: Symbol('WebGLEngine'),\n // Shader Module\n ShaderModuleService: Symbol('ShaderModuleService'),\n ConfigService: Symbol('ConfigService'),\n InteractorService: Symbol('InteractorService'),\n IEventEmitter: Symbol('IEventEmitter'),\n // Light\n Light: Symbol('Light')\n};\n//# sourceMappingURL=identifier.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nexport var FrameGraphHandle = function FrameGraphHandle() {\n _classCallCheck(this, FrameGraphHandle);\n\n this.index = void 0;\n};\n//# sourceMappingURL=FrameGraphHandle.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nexport var FrameGraphPass = function FrameGraphPass() {\n _classCallCheck(this, FrameGraphPass);\n\n this.name = void 0;\n this.data = void 0;\n this.execute = void 0;\n this.tearDown = void 0;\n};\n//# sourceMappingURL=FrameGraphPass.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nexport var PassNode = /*#__PURE__*/function () {\n function PassNode() {\n _classCallCheck(this, PassNode);\n\n this.name = void 0;\n this.refCount = 0;\n this.hasSideEffect = false;\n this.devirtualize = [];\n this.destroy = [];\n this.reads = [];\n this.writes = [];\n }\n\n _createClass(PassNode, [{\n key: \"read\",\n value: function read(handle) {\n if (!this.reads.find(function (h) {\n return h.index === handle.index;\n })) {\n this.reads.push(handle);\n }\n\n return handle;\n }\n }, {\n key: \"sample\",\n value: function sample(handle) {\n this.read(handle); // TODO: 记录在 this.samples 中\n\n return handle;\n }\n }, {\n key: \"write\",\n value: function write(fg, handle) {\n var existed = this.writes.find(function (h) {\n return h.index === handle.index;\n });\n\n if (existed) {\n return handle;\n }\n\n var node = fg.getResourceNode(handle);\n node.resource.version++;\n\n if (node.resource.imported) {\n this.hasSideEffect = true;\n }\n\n var r = fg.createResourceNode(node.resource);\n var newNode = fg.getResourceNode(r);\n newNode.writer = this;\n this.writes.push(r);\n return r;\n }\n }]);\n\n return PassNode;\n}();\n//# sourceMappingURL=PassNode.js.map","export default function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n\n return _setPrototypeOf(o, p);\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}","export default function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n _typeof = function _typeof(obj) {\n return typeof obj;\n };\n } else {\n _typeof = function _typeof(obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n }\n\n return _typeof(obj);\n}","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}","import _typeof from \"@babel/runtime/helpers/typeof\";\nimport assertThisInitialized from \"./assertThisInitialized.js\";\nexport default function _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n }\n\n return assertThisInitialized(self);\n}","export default function _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { VirtualResource } from './VirtualResource';\nexport var ResourceEntry = /*#__PURE__*/function (_VirtualResource) {\n _inherits(ResourceEntry, _VirtualResource);\n\n var _super = _createSuper(ResourceEntry);\n\n function ResourceEntry() {\n var _this;\n\n _classCallCheck(this, ResourceEntry);\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _super.call.apply(_super, [this].concat(args));\n _this.version = 0;\n _this.refs = 0;\n _this.name = void 0;\n _this.imported = void 0;\n _this.priority = void 0;\n _this.discardStart = true;\n _this.discardEnd = false;\n _this.descriptor = void 0;\n _this.resource = void 0;\n return _this;\n }\n\n _createClass(ResourceEntry, [{\n key: \"preExecuteDestroy\",\n\n /**\n * Lifecycles in FG's execute\n */\n value: function preExecuteDestroy() {\n this.discardEnd = true;\n }\n }, {\n key: \"postExecuteDestroy\",\n value: function postExecuteDestroy() {\n if (!this.imported) {// TODO: 不需要每一帧结束后都销毁资源,可以增加临时资源标志\n // this.resource.destroy();\n }\n }\n }, {\n key: \"postExecuteDevirtualize\",\n value: function postExecuteDevirtualize() {\n this.discardStart = false;\n }\n }, {\n key: \"preExecuteDevirtualize\",\n value: function preExecuteDevirtualize() {\n if (!this.imported) {//\n }\n }\n }]);\n\n return ResourceEntry;\n}(VirtualResource);\n//# sourceMappingURL=ResourceEntry.js.map","import _slicedToArray from \"@babel/runtime/helpers/slicedToArray\";\nimport _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _class, _class2, _descriptor, _temp;\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === \"undefined\" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nimport { inject, injectable } from 'inversify';\nimport { IDENTIFIER } from '../../identifier';\nimport { FrameGraphHandle } from './FrameGraphHandle';\nimport { FrameGraphPass } from './FrameGraphPass';\nimport { PassNode } from './PassNode';\nimport { ResourceEntry } from './ResourceEntry';\nimport { ResourceNode } from './ResourceNode';\n/**\n * ported from FrameGraph implemented by SakuraRender\n * @see https://zhuanlan.zhihu.com/p/98572442\n * @see https://github.com/SaeruHikari/Sakura/blob/RenderGraph/SakuraCore/Source/Framework/GraphicTypes/FrameGraph/SakuraFrameGraph.cpp\n */\n\nexport var FrameGraphSystem = (_dec = injectable(), _dec2 = inject(IDENTIFIER.RenderEngine), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function () {\n function FrameGraphSystem() {\n _classCallCheck(this, FrameGraphSystem);\n\n this.passNodes = [];\n this.resourceNodes = [];\n this.frameGraphPasses = [];\n\n _initializerDefineProperty(this, \"engine\", _descriptor, this);\n }\n\n _createClass(FrameGraphSystem, [{\n key: \"execute\",\n value: function () {\n var _execute = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(views) {\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n // this.engine.beginFrame();\n this.compile();\n _context.next = 3;\n return this.executePassNodes(views);\n\n case 3:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function execute(_x) {\n return _execute.apply(this, arguments);\n }\n\n return execute;\n }()\n }, {\n key: \"tearDown\",\n value: function tearDown() {\n this.frameGraphPasses.forEach(function (pass) {\n if (pass.tearDown) {\n pass.tearDown();\n }\n });\n this.reset();\n }\n }, {\n key: \"addPass\",\n value: function addPass(name, setup, execute, tearDown) {\n var frameGraphPass = new FrameGraphPass();\n frameGraphPass.execute = execute;\n\n if (tearDown) {\n frameGraphPass.tearDown = tearDown;\n }\n\n frameGraphPass.name = name;\n var passNode = new PassNode();\n passNode.name = name;\n this.passNodes.push(passNode);\n this.frameGraphPasses.push(frameGraphPass);\n setup(this, passNode, frameGraphPass);\n return frameGraphPass;\n }\n }, {\n key: \"getPass\",\n value: function getPass(name) {\n return this.frameGraphPasses.find(function (p) {\n return p.name === name;\n });\n }\n }, {\n key: \"compile\",\n value: function compile() {\n var _this = this;\n\n var _iterator = _createForOfIteratorHelper(this.passNodes),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var _pass = _step.value;\n _pass.refCount = _pass.writes.length + (_pass.hasSideEffect ? 1 : 0);\n\n _pass.reads.forEach(function (handle) {\n _this.resourceNodes[handle.index].readerCount++;\n });\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n var stack = [];\n\n var _iterator2 = _createForOfIteratorHelper(this.resourceNodes),\n _step2;\n\n try {\n for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n var node = _step2.value;\n\n if (node.readerCount === 0) {\n stack.push(node);\n }\n }\n } catch (err) {\n _iterator2.e(err);\n } finally {\n _iterator2.f();\n }\n\n while (stack.length) {\n var pNode = stack.pop();\n var writer = pNode && pNode.writer;\n\n if (writer) {\n if (--writer.refCount === 0) {\n // this pass is culled\n // assert(!writer->hasSideEffect);\n var _iterator3 = _createForOfIteratorHelper(writer.reads),\n _step3;\n\n try {\n for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {\n var resource = _step3.value;\n var r = this.resourceNodes[resource.index];\n\n if (--r.readerCount === 0) {\n stack.push(r);\n }\n }\n } catch (err) {\n _iterator3.e(err);\n } finally {\n _iterator3.f();\n }\n }\n }\n } // update the final reference counts\n\n\n this.resourceNodes.forEach(function (node) {\n node.resource.refs += node.readerCount;\n });\n\n var _iterator4 = _createForOfIteratorHelper(this.passNodes),\n _step4;\n\n try {\n for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {\n var _pass2 = _step4.value;\n\n if (!_pass2.refCount) {\n continue;\n }\n\n var _iterator6 = _createForOfIteratorHelper(_pass2.reads),\n _step6;\n\n try {\n for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) {\n var _resource2 = _step6.value;\n var pResource = this.resourceNodes[_resource2.index].resource;\n pResource.first = pResource.first ? pResource.first : _pass2;\n pResource.last = _pass2;\n }\n } catch (err) {\n _iterator6.e(err);\n } finally {\n _iterator6.f();\n }\n\n var _iterator7 = _createForOfIteratorHelper(_pass2.writes),\n _step7;\n\n try {\n for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) {\n var _resource3 = _step7.value;\n var _pResource = this.resourceNodes[_resource3.index].resource;\n _pResource.first = _pResource.first ? _pResource.first : _pass2;\n _pResource.last = _pass2;\n }\n } catch (err) {\n _iterator7.e(err);\n } finally {\n _iterator7.f();\n }\n }\n } catch (err) {\n _iterator4.e(err);\n } finally {\n _iterator4.f();\n }\n\n for (var priority = 0; priority < 2; priority++) {\n var _iterator5 = _createForOfIteratorHelper(this.resourceNodes),\n _step5;\n\n try {\n for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {\n var resoureNode = _step5.value;\n var _resource = resoureNode.resource;\n\n if (_resource.priority === priority && _resource.refs) {\n var pFirst = _resource.first;\n var pLast = _resource.last;\n\n if (pFirst && pLast) {\n pFirst.devirtualize.push(_resource);\n pLast.destroy.push(_resource);\n }\n }\n }\n } catch (err) {\n _iterator5.e(err);\n } finally {\n _iterator5.f();\n }\n }\n }\n }, {\n key: \"executePassNodes\",\n value: function () {\n var _executePassNodes = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(views) {\n var _iterator8, _step8, _step8$value, index, node, _iterator9, _step9, resource, _iterator10, _step10, _resource4, _iterator11, _step11, _resource5, _iterator12, _step12, _resource6;\n\n return _regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n _iterator8 = _createForOfIteratorHelper(this.passNodes.entries());\n _context2.prev = 1;\n\n _iterator8.s();\n\n case 3:\n if ((_step8 = _iterator8.n()).done) {\n _context2.next = 18;\n break;\n }\n\n _step8$value = _slicedToArray(_step8.value, 2), index = _step8$value[0], node = _step8$value[1];\n\n if (!node.refCount) {\n _context2.next = 16;\n break;\n }\n\n _iterator9 = _createForOfIteratorHelper(node.devirtualize);\n\n try {\n for (_iterator9.s(); !(_step9 = _iterator9.n()).done;) {\n resource = _step9.value;\n resource.preExecuteDevirtualize(this.engine);\n }\n } catch (err) {\n _iterator9.e(err);\n } finally {\n _iterator9.f();\n }\n\n _iterator10 = _createForOfIteratorHelper(node.destroy);\n\n try {\n for (_iterator10.s(); !(_step10 = _iterator10.n()).done;) {\n _resource4 = _step10.value;\n\n _resource4.preExecuteDestroy(this.engine);\n }\n } catch (err) {\n _iterator10.e(err);\n } finally {\n _iterator10.f();\n }\n\n _context2.next = 12;\n return this.frameGraphPasses[index].execute(this, this.frameGraphPasses[index], views);\n\n case 12:\n _iterator11 = _createForOfIteratorHelper(node.devirtualize);\n\n try {\n for (_iterator11.s(); !(_step11 = _iterator11.n()).done;) {\n _resource5 = _step11.value;\n\n _resource5.postExecuteDevirtualize(this.engine);\n }\n } catch (err) {\n _iterator11.e(err);\n } finally {\n _iterator11.f();\n }\n\n _iterator12 = _createForOfIteratorHelper(node.destroy);\n\n try {\n for (_iterator12.s(); !(_step12 = _iterator12.n()).done;) {\n _resource6 = _step12.value;\n\n _resource6.postExecuteDestroy(this.engine);\n }\n } catch (err) {\n _iterator12.e(err);\n } finally {\n _iterator12.f();\n }\n\n case 16:\n _context2.next = 3;\n break;\n\n case 18:\n _context2.next = 23;\n break;\n\n case 20:\n _context2.prev = 20;\n _context2.t0 = _context2[\"catch\"](1);\n\n _iterator8.e(_context2.t0);\n\n case 23:\n _context2.prev = 23;\n\n _iterator8.f();\n\n return _context2.finish(23);\n\n case 26:\n this.reset();\n\n case 27:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this, [[1, 20, 23, 26]]);\n }));\n\n function executePassNodes(_x2) {\n return _executePassNodes.apply(this, arguments);\n }\n\n return executePassNodes;\n }()\n }, {\n key: \"reset\",\n value: function reset() {\n this.passNodes = [];\n this.resourceNodes = [];\n this.frameGraphPasses = [];\n }\n }, {\n key: \"getResourceNode\",\n value: function getResourceNode(r) {\n return this.resourceNodes[r.index];\n }\n }, {\n key: \"createResourceNode\",\n value: function createResourceNode(resourceEntry) {\n var resourceNode = new ResourceNode();\n resourceNode.resource = resourceEntry;\n resourceNode.version = resourceEntry.version;\n this.resourceNodes.push(resourceNode);\n var fgh = new FrameGraphHandle();\n fgh.index = this.resourceNodes.length - 1;\n return fgh;\n }\n }, {\n key: \"createTexture\",\n value: function createTexture(passNode, name, descriptor) {\n var resource = new ResourceEntry();\n resource.name = name;\n resource.descriptor = descriptor;\n return this.createResourceNode(resource);\n }\n }, {\n key: \"createRenderTarget\",\n value: function createRenderTarget(passNode, name, descriptor) {\n var resource = new ResourceEntry();\n resource.name = name;\n resource.descriptor = descriptor;\n return this.createResourceNode(resource);\n }\n }, {\n key: \"present\",\n value: function present(input) {\n this.addPass('Present', function (fg, passNode) {\n passNode.read(input);\n passNode.hasSideEffect = true;\n }, /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee3() {\n return _regeneratorRuntime.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3);\n })));\n }\n }]);\n\n return FrameGraphSystem;\n}(), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"engine\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=System.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\n\n/**\n * ported from filament\n */\nexport var VirtualResource = function VirtualResource() {\n _classCallCheck(this, VirtualResource);\n\n this.first = void 0;\n this.last = void 0;\n};\n//# sourceMappingURL=VirtualResource.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nexport var ResourceNode = function ResourceNode() {\n _classCallCheck(this, ResourceNode);\n\n this.resource = void 0;\n this.writer = void 0;\n this.readerCount = 0;\n this.version = void 0;\n};\n//# sourceMappingURL=ResourceNode.js.map","export default function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}","/**\r\n * Common utilities\r\n * @module glMatrix\r\n */\n// Configuration Constants\nexport var EPSILON = 0.000001;\nexport var ARRAY_TYPE = typeof Float32Array !== 'undefined' ? Float32Array : Array;\nexport var RANDOM = Math.random;\n/**\r\n * Sets the type of array used when creating new vectors and matrices\r\n *\r\n * @param {Float32ArrayConstructor | ArrayConstructor} type Array type, such as Float32Array or Array\r\n */\n\nexport function setMatrixArrayType(type) {\n ARRAY_TYPE = type;\n}\nvar degree = Math.PI / 180;\n/**\r\n * Convert Degree To Radian\r\n *\r\n * @param {Number} a Angle in Degrees\r\n */\n\nexport function toRadian(a) {\n return a * degree;\n}\n/**\r\n * Tests whether or not the arguments have approximately the same value, within an absolute\r\n * or relative tolerance of glMatrix.EPSILON (an absolute tolerance is used for values less\r\n * than or equal to 1.0, and a relative tolerance is used for larger values)\r\n *\r\n * @param {Number} a The first number to test.\r\n * @param {Number} b The second number to test.\r\n * @returns {Boolean} True if the numbers are approximately equal, false otherwise.\r\n */\n\nexport function equals(a, b) {\n return Math.abs(a - b) <= EPSILON * Math.max(1.0, Math.abs(a), Math.abs(b));\n}\nif (!Math.hypot) Math.hypot = function () {\n var y = 0,\n i = arguments.length;\n\n while (i--) {\n y += arguments[i] * arguments[i];\n }\n\n return Math.sqrt(y);\n};","import * as glMatrix from \"./common.js\";\n/**\r\n * 4 Dimensional Vector\r\n * @module vec4\r\n */\n\n/**\r\n * Creates a new, empty vec4\r\n *\r\n * @returns {vec4} a new 4D vector\r\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(4);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n }\n\n return out;\n}\n/**\r\n * Creates a new vec4 initialized with values from an existing vector\r\n *\r\n * @param {ReadonlyVec4} a vector to clone\r\n * @returns {vec4} a new 4D vector\r\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(4);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n/**\r\n * Creates a new vec4 initialized with the given values\r\n *\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @param {Number} z Z component\r\n * @param {Number} w W component\r\n * @returns {vec4} a new 4D vector\r\n */\n\nexport function fromValues(x, y, z, w) {\n var out = new glMatrix.ARRAY_TYPE(4);\n out[0] = x;\n out[1] = y;\n out[2] = z;\n out[3] = w;\n return out;\n}\n/**\r\n * Copy the values from one vec4 to another\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the source vector\r\n * @returns {vec4} out\r\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n return out;\n}\n/**\r\n * Set the components of a vec4 to the given values\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @param {Number} z Z component\r\n * @param {Number} w W component\r\n * @returns {vec4} out\r\n */\n\nexport function set(out, x, y, z, w) {\n out[0] = x;\n out[1] = y;\n out[2] = z;\n out[3] = w;\n return out;\n}\n/**\r\n * Adds two vec4's\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {vec4} out\r\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n return out;\n}\n/**\r\n * Subtracts vector b from vector a\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {vec4} out\r\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n return out;\n}\n/**\r\n * Multiplies two vec4's\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {vec4} out\r\n */\n\nexport function multiply(out, a, b) {\n out[0] = a[0] * b[0];\n out[1] = a[1] * b[1];\n out[2] = a[2] * b[2];\n out[3] = a[3] * b[3];\n return out;\n}\n/**\r\n * Divides two vec4's\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {vec4} out\r\n */\n\nexport function divide(out, a, b) {\n out[0] = a[0] / b[0];\n out[1] = a[1] / b[1];\n out[2] = a[2] / b[2];\n out[3] = a[3] / b[3];\n return out;\n}\n/**\r\n * Math.ceil the components of a vec4\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a vector to ceil\r\n * @returns {vec4} out\r\n */\n\nexport function ceil(out, a) {\n out[0] = Math.ceil(a[0]);\n out[1] = Math.ceil(a[1]);\n out[2] = Math.ceil(a[2]);\n out[3] = Math.ceil(a[3]);\n return out;\n}\n/**\r\n * Math.floor the components of a vec4\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a vector to floor\r\n * @returns {vec4} out\r\n */\n\nexport function floor(out, a) {\n out[0] = Math.floor(a[0]);\n out[1] = Math.floor(a[1]);\n out[2] = Math.floor(a[2]);\n out[3] = Math.floor(a[3]);\n return out;\n}\n/**\r\n * Returns the minimum of two vec4's\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {vec4} out\r\n */\n\nexport function min(out, a, b) {\n out[0] = Math.min(a[0], b[0]);\n out[1] = Math.min(a[1], b[1]);\n out[2] = Math.min(a[2], b[2]);\n out[3] = Math.min(a[3], b[3]);\n return out;\n}\n/**\r\n * Returns the maximum of two vec4's\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {vec4} out\r\n */\n\nexport function max(out, a, b) {\n out[0] = Math.max(a[0], b[0]);\n out[1] = Math.max(a[1], b[1]);\n out[2] = Math.max(a[2], b[2]);\n out[3] = Math.max(a[3], b[3]);\n return out;\n}\n/**\r\n * Math.round the components of a vec4\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a vector to round\r\n * @returns {vec4} out\r\n */\n\nexport function round(out, a) {\n out[0] = Math.round(a[0]);\n out[1] = Math.round(a[1]);\n out[2] = Math.round(a[2]);\n out[3] = Math.round(a[3]);\n return out;\n}\n/**\r\n * Scales a vec4 by a scalar number\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the vector to scale\r\n * @param {Number} b amount to scale the vector by\r\n * @returns {vec4} out\r\n */\n\nexport function scale(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n return out;\n}\n/**\r\n * Adds two vec4's after scaling the second operand by a scalar value\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @param {Number} scale the amount to scale b by before adding\r\n * @returns {vec4} out\r\n */\n\nexport function scaleAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n return out;\n}\n/**\r\n * Calculates the euclidian distance between two vec4's\r\n *\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {Number} distance between a and b\r\n */\n\nexport function distance(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n var w = b[3] - a[3];\n return Math.hypot(x, y, z, w);\n}\n/**\r\n * Calculates the squared euclidian distance between two vec4's\r\n *\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {Number} squared distance between a and b\r\n */\n\nexport function squaredDistance(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n var w = b[3] - a[3];\n return x * x + y * y + z * z + w * w;\n}\n/**\r\n * Calculates the length of a vec4\r\n *\r\n * @param {ReadonlyVec4} a vector to calculate length of\r\n * @returns {Number} length of a\r\n */\n\nexport function length(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var w = a[3];\n return Math.hypot(x, y, z, w);\n}\n/**\r\n * Calculates the squared length of a vec4\r\n *\r\n * @param {ReadonlyVec4} a vector to calculate squared length of\r\n * @returns {Number} squared length of a\r\n */\n\nexport function squaredLength(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var w = a[3];\n return x * x + y * y + z * z + w * w;\n}\n/**\r\n * Negates the components of a vec4\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a vector to negate\r\n * @returns {vec4} out\r\n */\n\nexport function negate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n out[3] = -a[3];\n return out;\n}\n/**\r\n * Returns the inverse of the components of a vec4\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a vector to invert\r\n * @returns {vec4} out\r\n */\n\nexport function inverse(out, a) {\n out[0] = 1.0 / a[0];\n out[1] = 1.0 / a[1];\n out[2] = 1.0 / a[2];\n out[3] = 1.0 / a[3];\n return out;\n}\n/**\r\n * Normalize a vec4\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a vector to normalize\r\n * @returns {vec4} out\r\n */\n\nexport function normalize(out, a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var w = a[3];\n var len = x * x + y * y + z * z + w * w;\n\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n }\n\n out[0] = x * len;\n out[1] = y * len;\n out[2] = z * len;\n out[3] = w * len;\n return out;\n}\n/**\r\n * Calculates the dot product of two vec4's\r\n *\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @returns {Number} dot product of a and b\r\n */\n\nexport function dot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];\n}\n/**\r\n * Returns the cross-product of three vectors in a 4-dimensional space\r\n *\r\n * @param {ReadonlyVec4} result the receiving vector\r\n * @param {ReadonlyVec4} U the first vector\r\n * @param {ReadonlyVec4} V the second vector\r\n * @param {ReadonlyVec4} W the third vector\r\n * @returns {vec4} result\r\n */\n\nexport function cross(out, u, v, w) {\n var A = v[0] * w[1] - v[1] * w[0],\n B = v[0] * w[2] - v[2] * w[0],\n C = v[0] * w[3] - v[3] * w[0],\n D = v[1] * w[2] - v[2] * w[1],\n E = v[1] * w[3] - v[3] * w[1],\n F = v[2] * w[3] - v[3] * w[2];\n var G = u[0];\n var H = u[1];\n var I = u[2];\n var J = u[3];\n out[0] = H * F - I * E + J * D;\n out[1] = -(G * F) + I * C - J * B;\n out[2] = G * E - H * C + J * A;\n out[3] = -(G * D) + H * B - I * A;\n return out;\n}\n/**\r\n * Performs a linear interpolation between two vec4's\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the first operand\r\n * @param {ReadonlyVec4} b the second operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {vec4} out\r\n */\n\nexport function lerp(out, a, b, t) {\n var ax = a[0];\n var ay = a[1];\n var az = a[2];\n var aw = a[3];\n out[0] = ax + t * (b[0] - ax);\n out[1] = ay + t * (b[1] - ay);\n out[2] = az + t * (b[2] - az);\n out[3] = aw + t * (b[3] - aw);\n return out;\n}\n/**\r\n * Generates a random vector with the given scale\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\r\n * @returns {vec4} out\r\n */\n\nexport function random(out, scale) {\n scale = scale || 1.0; // Marsaglia, George. Choosing a Point from the Surface of a\n // Sphere. Ann. Math. Statist. 43 (1972), no. 2, 645--646.\n // http://projecteuclid.org/euclid.aoms/1177692644;\n\n var v1, v2, v3, v4;\n var s1, s2;\n\n do {\n v1 = glMatrix.RANDOM() * 2 - 1;\n v2 = glMatrix.RANDOM() * 2 - 1;\n s1 = v1 * v1 + v2 * v2;\n } while (s1 >= 1);\n\n do {\n v3 = glMatrix.RANDOM() * 2 - 1;\n v4 = glMatrix.RANDOM() * 2 - 1;\n s2 = v3 * v3 + v4 * v4;\n } while (s2 >= 1);\n\n var d = Math.sqrt((1 - s1) / s2);\n out[0] = scale * v1;\n out[1] = scale * v2;\n out[2] = scale * v3 * d;\n out[3] = scale * v4 * d;\n return out;\n}\n/**\r\n * Transforms the vec4 with a mat4.\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the vector to transform\r\n * @param {ReadonlyMat4} m matrix to transform with\r\n * @returns {vec4} out\r\n */\n\nexport function transformMat4(out, a, m) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3];\n out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w;\n out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w;\n out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w;\n out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w;\n return out;\n}\n/**\r\n * Transforms the vec4 with a quat\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @param {ReadonlyVec4} a the vector to transform\r\n * @param {ReadonlyQuat} q quaternion to transform with\r\n * @returns {vec4} out\r\n */\n\nexport function transformQuat(out, a, q) {\n var x = a[0],\n y = a[1],\n z = a[2];\n var qx = q[0],\n qy = q[1],\n qz = q[2],\n qw = q[3]; // calculate quat * vec\n\n var ix = qw * x + qy * z - qz * y;\n var iy = qw * y + qz * x - qx * z;\n var iz = qw * z + qx * y - qy * x;\n var iw = -qx * x - qy * y - qz * z; // calculate result * inverse quat\n\n out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n out[3] = a[3];\n return out;\n}\n/**\r\n * Set the components of a vec4 to zero\r\n *\r\n * @param {vec4} out the receiving vector\r\n * @returns {vec4} out\r\n */\n\nexport function zero(out) {\n out[0] = 0.0;\n out[1] = 0.0;\n out[2] = 0.0;\n out[3] = 0.0;\n return out;\n}\n/**\r\n * Returns a string representation of a vector\r\n *\r\n * @param {ReadonlyVec4} a vector to represent as a string\r\n * @returns {String} string representation of the vector\r\n */\n\nexport function str(a) {\n return \"vec4(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \")\";\n}\n/**\r\n * Returns whether or not the vectors have exactly the same elements in the same position (when compared with ===)\r\n *\r\n * @param {ReadonlyVec4} a The first vector.\r\n * @param {ReadonlyVec4} b The second vector.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3];\n}\n/**\r\n * Returns whether or not the vectors have approximately the same elements in the same position.\r\n *\r\n * @param {ReadonlyVec4} a The first vector.\r\n * @param {ReadonlyVec4} b The second vector.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3));\n}\n/**\r\n * Alias for {@link vec4.subtract}\r\n * @function\r\n */\n\nexport var sub = subtract;\n/**\r\n * Alias for {@link vec4.multiply}\r\n * @function\r\n */\n\nexport var mul = multiply;\n/**\r\n * Alias for {@link vec4.divide}\r\n * @function\r\n */\n\nexport var div = divide;\n/**\r\n * Alias for {@link vec4.distance}\r\n * @function\r\n */\n\nexport var dist = distance;\n/**\r\n * Alias for {@link vec4.squaredDistance}\r\n * @function\r\n */\n\nexport var sqrDist = squaredDistance;\n/**\r\n * Alias for {@link vec4.length}\r\n * @function\r\n */\n\nexport var len = length;\n/**\r\n * Alias for {@link vec4.squaredLength}\r\n * @function\r\n */\n\nexport var sqrLen = squaredLength;\n/**\r\n * Perform some operation over an array of vec4s.\r\n *\r\n * @param {Array} a the array of vectors to iterate over\r\n * @param {Number} stride Number of elements between the start of each vec4. If 0 assumes tightly packed\r\n * @param {Number} offset Number of elements to skip at the beginning of the array\r\n * @param {Number} count Number of vec4s to iterate over. If 0 iterates over entire array\r\n * @param {Function} fn Function to call for each vector in the array\r\n * @param {Object} [arg] additional argument to pass to fn\r\n * @returns {Array} a\r\n * @function\r\n */\n\nexport var forEach = function () {\n var vec = create();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n\n if (!stride) {\n stride = 4;\n }\n\n if (!offset) {\n offset = 0;\n }\n\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n vec[2] = a[i + 2];\n vec[3] = a[i + 3];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n a[i + 2] = vec[2];\n a[i + 3] = vec[3];\n }\n\n return a;\n };\n}();","import * as glMatrix from \"./common.js\";\n/**\r\n * 3x3 Matrix\r\n * @module mat3\r\n */\n\n/**\r\n * Creates a new identity mat3\r\n *\r\n * @returns {mat3} a new 3x3 matrix\r\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(9);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n }\n\n out[0] = 1;\n out[4] = 1;\n out[8] = 1;\n return out;\n}\n/**\r\n * Copies the upper-left 3x3 values into the given mat3.\r\n *\r\n * @param {mat3} out the receiving 3x3 matrix\r\n * @param {ReadonlyMat4} a the source 4x4 matrix\r\n * @returns {mat3} out\r\n */\n\nexport function fromMat4(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[4];\n out[4] = a[5];\n out[5] = a[6];\n out[6] = a[8];\n out[7] = a[9];\n out[8] = a[10];\n return out;\n}\n/**\r\n * Creates a new mat3 initialized with values from an existing matrix\r\n *\r\n * @param {ReadonlyMat3} a matrix to clone\r\n * @returns {mat3} a new 3x3 matrix\r\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(9);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\r\n * Copy the values from one mat3 to another\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the source matrix\r\n * @returns {mat3} out\r\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\r\n * Create a new mat3 with the given values\r\n *\r\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\r\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\r\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\r\n * @param {Number} m10 Component in column 1, row 0 position (index 3)\r\n * @param {Number} m11 Component in column 1, row 1 position (index 4)\r\n * @param {Number} m12 Component in column 1, row 2 position (index 5)\r\n * @param {Number} m20 Component in column 2, row 0 position (index 6)\r\n * @param {Number} m21 Component in column 2, row 1 position (index 7)\r\n * @param {Number} m22 Component in column 2, row 2 position (index 8)\r\n * @returns {mat3} A new mat3\r\n */\n\nexport function fromValues(m00, m01, m02, m10, m11, m12, m20, m21, m22) {\n var out = new glMatrix.ARRAY_TYPE(9);\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m10;\n out[4] = m11;\n out[5] = m12;\n out[6] = m20;\n out[7] = m21;\n out[8] = m22;\n return out;\n}\n/**\r\n * Set the components of a mat3 to the given values\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\r\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\r\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\r\n * @param {Number} m10 Component in column 1, row 0 position (index 3)\r\n * @param {Number} m11 Component in column 1, row 1 position (index 4)\r\n * @param {Number} m12 Component in column 1, row 2 position (index 5)\r\n * @param {Number} m20 Component in column 2, row 0 position (index 6)\r\n * @param {Number} m21 Component in column 2, row 1 position (index 7)\r\n * @param {Number} m22 Component in column 2, row 2 position (index 8)\r\n * @returns {mat3} out\r\n */\n\nexport function set(out, m00, m01, m02, m10, m11, m12, m20, m21, m22) {\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m10;\n out[4] = m11;\n out[5] = m12;\n out[6] = m20;\n out[7] = m21;\n out[8] = m22;\n return out;\n}\n/**\r\n * Set a mat3 to the identity matrix\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @returns {mat3} out\r\n */\n\nexport function identity(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 1;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\r\n * Transpose the values of a mat3\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the source matrix\r\n * @returns {mat3} out\r\n */\n\nexport function transpose(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache some values\n if (out === a) {\n var a01 = a[1],\n a02 = a[2],\n a12 = a[5];\n out[1] = a[3];\n out[2] = a[6];\n out[3] = a01;\n out[5] = a[7];\n out[6] = a02;\n out[7] = a12;\n } else {\n out[0] = a[0];\n out[1] = a[3];\n out[2] = a[6];\n out[3] = a[1];\n out[4] = a[4];\n out[5] = a[7];\n out[6] = a[2];\n out[7] = a[5];\n out[8] = a[8];\n }\n\n return out;\n}\n/**\r\n * Inverts a mat3\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the source matrix\r\n * @returns {mat3} out\r\n */\n\nexport function invert(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n var b01 = a22 * a11 - a12 * a21;\n var b11 = -a22 * a10 + a12 * a20;\n var b21 = a21 * a10 - a11 * a20; // Calculate the determinant\n\n var det = a00 * b01 + a01 * b11 + a02 * b21;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = b01 * det;\n out[1] = (-a22 * a01 + a02 * a21) * det;\n out[2] = (a12 * a01 - a02 * a11) * det;\n out[3] = b11 * det;\n out[4] = (a22 * a00 - a02 * a20) * det;\n out[5] = (-a12 * a00 + a02 * a10) * det;\n out[6] = b21 * det;\n out[7] = (-a21 * a00 + a01 * a20) * det;\n out[8] = (a11 * a00 - a01 * a10) * det;\n return out;\n}\n/**\r\n * Calculates the adjugate of a mat3\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the source matrix\r\n * @returns {mat3} out\r\n */\n\nexport function adjoint(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n out[0] = a11 * a22 - a12 * a21;\n out[1] = a02 * a21 - a01 * a22;\n out[2] = a01 * a12 - a02 * a11;\n out[3] = a12 * a20 - a10 * a22;\n out[4] = a00 * a22 - a02 * a20;\n out[5] = a02 * a10 - a00 * a12;\n out[6] = a10 * a21 - a11 * a20;\n out[7] = a01 * a20 - a00 * a21;\n out[8] = a00 * a11 - a01 * a10;\n return out;\n}\n/**\r\n * Calculates the determinant of a mat3\r\n *\r\n * @param {ReadonlyMat3} a the source matrix\r\n * @returns {Number} determinant of a\r\n */\n\nexport function determinant(a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n return a00 * (a22 * a11 - a12 * a21) + a01 * (-a22 * a10 + a12 * a20) + a02 * (a21 * a10 - a11 * a20);\n}\n/**\r\n * Multiplies two mat3's\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the first operand\r\n * @param {ReadonlyMat3} b the second operand\r\n * @returns {mat3} out\r\n */\n\nexport function multiply(out, a, b) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2];\n var a10 = a[3],\n a11 = a[4],\n a12 = a[5];\n var a20 = a[6],\n a21 = a[7],\n a22 = a[8];\n var b00 = b[0],\n b01 = b[1],\n b02 = b[2];\n var b10 = b[3],\n b11 = b[4],\n b12 = b[5];\n var b20 = b[6],\n b21 = b[7],\n b22 = b[8];\n out[0] = b00 * a00 + b01 * a10 + b02 * a20;\n out[1] = b00 * a01 + b01 * a11 + b02 * a21;\n out[2] = b00 * a02 + b01 * a12 + b02 * a22;\n out[3] = b10 * a00 + b11 * a10 + b12 * a20;\n out[4] = b10 * a01 + b11 * a11 + b12 * a21;\n out[5] = b10 * a02 + b11 * a12 + b12 * a22;\n out[6] = b20 * a00 + b21 * a10 + b22 * a20;\n out[7] = b20 * a01 + b21 * a11 + b22 * a21;\n out[8] = b20 * a02 + b21 * a12 + b22 * a22;\n return out;\n}\n/**\r\n * Translate a mat3 by the given vector\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the matrix to translate\r\n * @param {ReadonlyVec2} v vector to translate by\r\n * @returns {mat3} out\r\n */\n\nexport function translate(out, a, v) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a10 = a[3],\n a11 = a[4],\n a12 = a[5],\n a20 = a[6],\n a21 = a[7],\n a22 = a[8],\n x = v[0],\n y = v[1];\n out[0] = a00;\n out[1] = a01;\n out[2] = a02;\n out[3] = a10;\n out[4] = a11;\n out[5] = a12;\n out[6] = x * a00 + y * a10 + a20;\n out[7] = x * a01 + y * a11 + a21;\n out[8] = x * a02 + y * a12 + a22;\n return out;\n}\n/**\r\n * Rotates a mat3 by the given angle\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the matrix to rotate\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat3} out\r\n */\n\nexport function rotate(out, a, rad) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a10 = a[3],\n a11 = a[4],\n a12 = a[5],\n a20 = a[6],\n a21 = a[7],\n a22 = a[8],\n s = Math.sin(rad),\n c = Math.cos(rad);\n out[0] = c * a00 + s * a10;\n out[1] = c * a01 + s * a11;\n out[2] = c * a02 + s * a12;\n out[3] = c * a10 - s * a00;\n out[4] = c * a11 - s * a01;\n out[5] = c * a12 - s * a02;\n out[6] = a20;\n out[7] = a21;\n out[8] = a22;\n return out;\n}\n/**\r\n * Scales the mat3 by the dimensions in the given vec2\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the matrix to rotate\r\n * @param {ReadonlyVec2} v the vec2 to scale the matrix by\r\n * @returns {mat3} out\r\n **/\n\nexport function scale(out, a, v) {\n var x = v[0],\n y = v[1];\n out[0] = x * a[0];\n out[1] = x * a[1];\n out[2] = x * a[2];\n out[3] = y * a[3];\n out[4] = y * a[4];\n out[5] = y * a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\r\n * Creates a matrix from a vector translation\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat3.identity(dest);\r\n * mat3.translate(dest, dest, vec);\r\n *\r\n * @param {mat3} out mat3 receiving operation result\r\n * @param {ReadonlyVec2} v Translation vector\r\n * @returns {mat3} out\r\n */\n\nexport function fromTranslation(out, v) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 1;\n out[5] = 0;\n out[6] = v[0];\n out[7] = v[1];\n out[8] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from a given angle\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat3.identity(dest);\r\n * mat3.rotate(dest, dest, rad);\r\n *\r\n * @param {mat3} out mat3 receiving operation result\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat3} out\r\n */\n\nexport function fromRotation(out, rad) {\n var s = Math.sin(rad),\n c = Math.cos(rad);\n out[0] = c;\n out[1] = s;\n out[2] = 0;\n out[3] = -s;\n out[4] = c;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from a vector scaling\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat3.identity(dest);\r\n * mat3.scale(dest, dest, vec);\r\n *\r\n * @param {mat3} out mat3 receiving operation result\r\n * @param {ReadonlyVec2} v Scaling vector\r\n * @returns {mat3} out\r\n */\n\nexport function fromScaling(out, v) {\n out[0] = v[0];\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = v[1];\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\r\n * Copies the values from a mat2d into a mat3\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat2d} a the matrix to copy\r\n * @returns {mat3} out\r\n **/\n\nexport function fromMat2d(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = 0;\n out[3] = a[2];\n out[4] = a[3];\n out[5] = 0;\n out[6] = a[4];\n out[7] = a[5];\n out[8] = 1;\n return out;\n}\n/**\r\n * Calculates a 3x3 matrix from the given quaternion\r\n *\r\n * @param {mat3} out mat3 receiving operation result\r\n * @param {ReadonlyQuat} q Quaternion to create matrix from\r\n *\r\n * @returns {mat3} out\r\n */\n\nexport function fromQuat(out, q) {\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var yx = y * x2;\n var yy = y * y2;\n var zx = z * x2;\n var zy = z * y2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n out[0] = 1 - yy - zz;\n out[3] = yx - wz;\n out[6] = zx + wy;\n out[1] = yx + wz;\n out[4] = 1 - xx - zz;\n out[7] = zy - wx;\n out[2] = zx - wy;\n out[5] = zy + wx;\n out[8] = 1 - xx - yy;\n return out;\n}\n/**\r\n * Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\r\n *\r\n * @param {mat3} out mat3 receiving operation result\r\n * @param {ReadonlyMat4} a Mat4 to derive the normal matrix from\r\n *\r\n * @returns {mat3} out\r\n */\n\nexport function normalFromMat4(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32; // Calculate the determinant\n\n var det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n out[1] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n out[2] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n out[3] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n out[4] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n out[5] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n out[6] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n out[7] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n out[8] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n return out;\n}\n/**\r\n * Generates a 2D projection matrix with the given bounds\r\n *\r\n * @param {mat3} out mat3 frustum matrix will be written into\r\n * @param {number} width Width of your gl context\r\n * @param {number} height Height of gl context\r\n * @returns {mat3} out\r\n */\n\nexport function projection(out, width, height) {\n out[0] = 2 / width;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = -2 / height;\n out[5] = 0;\n out[6] = -1;\n out[7] = 1;\n out[8] = 1;\n return out;\n}\n/**\r\n * Returns a string representation of a mat3\r\n *\r\n * @param {ReadonlyMat3} a matrix to represent as a string\r\n * @returns {String} string representation of the matrix\r\n */\n\nexport function str(a) {\n return \"mat3(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \", \" + a[4] + \", \" + a[5] + \", \" + a[6] + \", \" + a[7] + \", \" + a[8] + \")\";\n}\n/**\r\n * Returns Frobenius norm of a mat3\r\n *\r\n * @param {ReadonlyMat3} a the matrix to calculate Frobenius norm of\r\n * @returns {Number} Frobenius norm\r\n */\n\nexport function frob(a) {\n return Math.hypot(a[0], a[1], a[2], a[3], a[4], a[5], a[6], a[7], a[8]);\n}\n/**\r\n * Adds two mat3's\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the first operand\r\n * @param {ReadonlyMat3} b the second operand\r\n * @returns {mat3} out\r\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n out[4] = a[4] + b[4];\n out[5] = a[5] + b[5];\n out[6] = a[6] + b[6];\n out[7] = a[7] + b[7];\n out[8] = a[8] + b[8];\n return out;\n}\n/**\r\n * Subtracts matrix b from matrix a\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the first operand\r\n * @param {ReadonlyMat3} b the second operand\r\n * @returns {mat3} out\r\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n out[4] = a[4] - b[4];\n out[5] = a[5] - b[5];\n out[6] = a[6] - b[6];\n out[7] = a[7] - b[7];\n out[8] = a[8] - b[8];\n return out;\n}\n/**\r\n * Multiply each element of the matrix by a scalar.\r\n *\r\n * @param {mat3} out the receiving matrix\r\n * @param {ReadonlyMat3} a the matrix to scale\r\n * @param {Number} b amount to scale the matrix's elements by\r\n * @returns {mat3} out\r\n */\n\nexport function multiplyScalar(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n out[4] = a[4] * b;\n out[5] = a[5] * b;\n out[6] = a[6] * b;\n out[7] = a[7] * b;\n out[8] = a[8] * b;\n return out;\n}\n/**\r\n * Adds two mat3's after multiplying each element of the second operand by a scalar value.\r\n *\r\n * @param {mat3} out the receiving vector\r\n * @param {ReadonlyMat3} a the first operand\r\n * @param {ReadonlyMat3} b the second operand\r\n * @param {Number} scale the amount to scale b's elements by before adding\r\n * @returns {mat3} out\r\n */\n\nexport function multiplyScalarAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n out[4] = a[4] + b[4] * scale;\n out[5] = a[5] + b[5] * scale;\n out[6] = a[6] + b[6] * scale;\n out[7] = a[7] + b[7] * scale;\n out[8] = a[8] + b[8] * scale;\n return out;\n}\n/**\r\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\r\n *\r\n * @param {ReadonlyMat3} a The first matrix.\r\n * @param {ReadonlyMat3} b The second matrix.\r\n * @returns {Boolean} True if the matrices are equal, false otherwise.\r\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3] && a[4] === b[4] && a[5] === b[5] && a[6] === b[6] && a[7] === b[7] && a[8] === b[8];\n}\n/**\r\n * Returns whether or not the matrices have approximately the same elements in the same position.\r\n *\r\n * @param {ReadonlyMat3} a The first matrix.\r\n * @param {ReadonlyMat3} b The second matrix.\r\n * @returns {Boolean} True if the matrices are equal, false otherwise.\r\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3],\n a4 = a[4],\n a5 = a[5],\n a6 = a[6],\n a7 = a[7],\n a8 = a[8];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7],\n b8 = b[8];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3)) && Math.abs(a4 - b4) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a4), Math.abs(b4)) && Math.abs(a5 - b5) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a5), Math.abs(b5)) && Math.abs(a6 - b6) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a6), Math.abs(b6)) && Math.abs(a7 - b7) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a7), Math.abs(b7)) && Math.abs(a8 - b8) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a8), Math.abs(b8));\n}\n/**\r\n * Alias for {@link mat3.multiply}\r\n * @function\r\n */\n\nexport var mul = multiply;\n/**\r\n * Alias for {@link mat3.subtract}\r\n * @function\r\n */\n\nexport var sub = subtract;","import * as glMatrix from \"./common.js\";\n/**\r\n * 3 Dimensional Vector\r\n * @module vec3\r\n */\n\n/**\r\n * Creates a new, empty vec3\r\n *\r\n * @returns {vec3} a new 3D vector\r\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(3);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n }\n\n return out;\n}\n/**\r\n * Creates a new vec3 initialized with values from an existing vector\r\n *\r\n * @param {ReadonlyVec3} a vector to clone\r\n * @returns {vec3} a new 3D vector\r\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(3);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n return out;\n}\n/**\r\n * Calculates the length of a vec3\r\n *\r\n * @param {ReadonlyVec3} a vector to calculate length of\r\n * @returns {Number} length of a\r\n */\n\nexport function length(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n return Math.hypot(x, y, z);\n}\n/**\r\n * Creates a new vec3 initialized with the given values\r\n *\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @param {Number} z Z component\r\n * @returns {vec3} a new 3D vector\r\n */\n\nexport function fromValues(x, y, z) {\n var out = new glMatrix.ARRAY_TYPE(3);\n out[0] = x;\n out[1] = y;\n out[2] = z;\n return out;\n}\n/**\r\n * Copy the values from one vec3 to another\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the source vector\r\n * @returns {vec3} out\r\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n return out;\n}\n/**\r\n * Set the components of a vec3 to the given values\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @param {Number} z Z component\r\n * @returns {vec3} out\r\n */\n\nexport function set(out, x, y, z) {\n out[0] = x;\n out[1] = y;\n out[2] = z;\n return out;\n}\n/**\r\n * Adds two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n return out;\n}\n/**\r\n * Subtracts vector b from vector a\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n return out;\n}\n/**\r\n * Multiplies two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function multiply(out, a, b) {\n out[0] = a[0] * b[0];\n out[1] = a[1] * b[1];\n out[2] = a[2] * b[2];\n return out;\n}\n/**\r\n * Divides two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function divide(out, a, b) {\n out[0] = a[0] / b[0];\n out[1] = a[1] / b[1];\n out[2] = a[2] / b[2];\n return out;\n}\n/**\r\n * Math.ceil the components of a vec3\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a vector to ceil\r\n * @returns {vec3} out\r\n */\n\nexport function ceil(out, a) {\n out[0] = Math.ceil(a[0]);\n out[1] = Math.ceil(a[1]);\n out[2] = Math.ceil(a[2]);\n return out;\n}\n/**\r\n * Math.floor the components of a vec3\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a vector to floor\r\n * @returns {vec3} out\r\n */\n\nexport function floor(out, a) {\n out[0] = Math.floor(a[0]);\n out[1] = Math.floor(a[1]);\n out[2] = Math.floor(a[2]);\n return out;\n}\n/**\r\n * Returns the minimum of two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function min(out, a, b) {\n out[0] = Math.min(a[0], b[0]);\n out[1] = Math.min(a[1], b[1]);\n out[2] = Math.min(a[2], b[2]);\n return out;\n}\n/**\r\n * Returns the maximum of two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function max(out, a, b) {\n out[0] = Math.max(a[0], b[0]);\n out[1] = Math.max(a[1], b[1]);\n out[2] = Math.max(a[2], b[2]);\n return out;\n}\n/**\r\n * Math.round the components of a vec3\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a vector to round\r\n * @returns {vec3} out\r\n */\n\nexport function round(out, a) {\n out[0] = Math.round(a[0]);\n out[1] = Math.round(a[1]);\n out[2] = Math.round(a[2]);\n return out;\n}\n/**\r\n * Scales a vec3 by a scalar number\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the vector to scale\r\n * @param {Number} b amount to scale the vector by\r\n * @returns {vec3} out\r\n */\n\nexport function scale(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n return out;\n}\n/**\r\n * Adds two vec3's after scaling the second operand by a scalar value\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @param {Number} scale the amount to scale b by before adding\r\n * @returns {vec3} out\r\n */\n\nexport function scaleAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n return out;\n}\n/**\r\n * Calculates the euclidian distance between two vec3's\r\n *\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {Number} distance between a and b\r\n */\n\nexport function distance(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n return Math.hypot(x, y, z);\n}\n/**\r\n * Calculates the squared euclidian distance between two vec3's\r\n *\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {Number} squared distance between a and b\r\n */\n\nexport function squaredDistance(a, b) {\n var x = b[0] - a[0];\n var y = b[1] - a[1];\n var z = b[2] - a[2];\n return x * x + y * y + z * z;\n}\n/**\r\n * Calculates the squared length of a vec3\r\n *\r\n * @param {ReadonlyVec3} a vector to calculate squared length of\r\n * @returns {Number} squared length of a\r\n */\n\nexport function squaredLength(a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n return x * x + y * y + z * z;\n}\n/**\r\n * Negates the components of a vec3\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a vector to negate\r\n * @returns {vec3} out\r\n */\n\nexport function negate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n return out;\n}\n/**\r\n * Returns the inverse of the components of a vec3\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a vector to invert\r\n * @returns {vec3} out\r\n */\n\nexport function inverse(out, a) {\n out[0] = 1.0 / a[0];\n out[1] = 1.0 / a[1];\n out[2] = 1.0 / a[2];\n return out;\n}\n/**\r\n * Normalize a vec3\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a vector to normalize\r\n * @returns {vec3} out\r\n */\n\nexport function normalize(out, a) {\n var x = a[0];\n var y = a[1];\n var z = a[2];\n var len = x * x + y * y + z * z;\n\n if (len > 0) {\n //TODO: evaluate use of glm_invsqrt here?\n len = 1 / Math.sqrt(len);\n }\n\n out[0] = a[0] * len;\n out[1] = a[1] * len;\n out[2] = a[2] * len;\n return out;\n}\n/**\r\n * Calculates the dot product of two vec3's\r\n *\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {Number} dot product of a and b\r\n */\n\nexport function dot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n}\n/**\r\n * Computes the cross product of two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @returns {vec3} out\r\n */\n\nexport function cross(out, a, b) {\n var ax = a[0],\n ay = a[1],\n az = a[2];\n var bx = b[0],\n by = b[1],\n bz = b[2];\n out[0] = ay * bz - az * by;\n out[1] = az * bx - ax * bz;\n out[2] = ax * by - ay * bx;\n return out;\n}\n/**\r\n * Performs a linear interpolation between two vec3's\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {vec3} out\r\n */\n\nexport function lerp(out, a, b, t) {\n var ax = a[0];\n var ay = a[1];\n var az = a[2];\n out[0] = ax + t * (b[0] - ax);\n out[1] = ay + t * (b[1] - ay);\n out[2] = az + t * (b[2] - az);\n return out;\n}\n/**\r\n * Performs a hermite interpolation with two control points\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @param {ReadonlyVec3} c the third operand\r\n * @param {ReadonlyVec3} d the fourth operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {vec3} out\r\n */\n\nexport function hermite(out, a, b, c, d, t) {\n var factorTimes2 = t * t;\n var factor1 = factorTimes2 * (2 * t - 3) + 1;\n var factor2 = factorTimes2 * (t - 2) + t;\n var factor3 = factorTimes2 * (t - 1);\n var factor4 = factorTimes2 * (3 - 2 * t);\n out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4;\n out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4;\n out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4;\n return out;\n}\n/**\r\n * Performs a bezier interpolation with two control points\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the first operand\r\n * @param {ReadonlyVec3} b the second operand\r\n * @param {ReadonlyVec3} c the third operand\r\n * @param {ReadonlyVec3} d the fourth operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {vec3} out\r\n */\n\nexport function bezier(out, a, b, c, d, t) {\n var inverseFactor = 1 - t;\n var inverseFactorTimesTwo = inverseFactor * inverseFactor;\n var factorTimes2 = t * t;\n var factor1 = inverseFactorTimesTwo * inverseFactor;\n var factor2 = 3 * t * inverseFactorTimesTwo;\n var factor3 = 3 * factorTimes2 * inverseFactor;\n var factor4 = factorTimes2 * t;\n out[0] = a[0] * factor1 + b[0] * factor2 + c[0] * factor3 + d[0] * factor4;\n out[1] = a[1] * factor1 + b[1] * factor2 + c[1] * factor3 + d[1] * factor4;\n out[2] = a[2] * factor1 + b[2] * factor2 + c[2] * factor3 + d[2] * factor4;\n return out;\n}\n/**\r\n * Generates a random vector with the given scale\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\r\n * @returns {vec3} out\r\n */\n\nexport function random(out, scale) {\n scale = scale || 1.0;\n var r = glMatrix.RANDOM() * 2.0 * Math.PI;\n var z = glMatrix.RANDOM() * 2.0 - 1.0;\n var zScale = Math.sqrt(1.0 - z * z) * scale;\n out[0] = Math.cos(r) * zScale;\n out[1] = Math.sin(r) * zScale;\n out[2] = z * scale;\n return out;\n}\n/**\r\n * Transforms the vec3 with a mat4.\r\n * 4th vector component is implicitly '1'\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the vector to transform\r\n * @param {ReadonlyMat4} m matrix to transform with\r\n * @returns {vec3} out\r\n */\n\nexport function transformMat4(out, a, m) {\n var x = a[0],\n y = a[1],\n z = a[2];\n var w = m[3] * x + m[7] * y + m[11] * z + m[15];\n w = w || 1.0;\n out[0] = (m[0] * x + m[4] * y + m[8] * z + m[12]) / w;\n out[1] = (m[1] * x + m[5] * y + m[9] * z + m[13]) / w;\n out[2] = (m[2] * x + m[6] * y + m[10] * z + m[14]) / w;\n return out;\n}\n/**\r\n * Transforms the vec3 with a mat3.\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the vector to transform\r\n * @param {ReadonlyMat3} m the 3x3 matrix to transform with\r\n * @returns {vec3} out\r\n */\n\nexport function transformMat3(out, a, m) {\n var x = a[0],\n y = a[1],\n z = a[2];\n out[0] = x * m[0] + y * m[3] + z * m[6];\n out[1] = x * m[1] + y * m[4] + z * m[7];\n out[2] = x * m[2] + y * m[5] + z * m[8];\n return out;\n}\n/**\r\n * Transforms the vec3 with a quat\r\n * Can also be used for dual quaternions. (Multiply it with the real part)\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @param {ReadonlyVec3} a the vector to transform\r\n * @param {ReadonlyQuat} q quaternion to transform with\r\n * @returns {vec3} out\r\n */\n\nexport function transformQuat(out, a, q) {\n // benchmarks: https://jsperf.com/quaternion-transform-vec3-implementations-fixed\n var qx = q[0],\n qy = q[1],\n qz = q[2],\n qw = q[3];\n var x = a[0],\n y = a[1],\n z = a[2]; // var qvec = [qx, qy, qz];\n // var uv = vec3.cross([], qvec, a);\n\n var uvx = qy * z - qz * y,\n uvy = qz * x - qx * z,\n uvz = qx * y - qy * x; // var uuv = vec3.cross([], qvec, uv);\n\n var uuvx = qy * uvz - qz * uvy,\n uuvy = qz * uvx - qx * uvz,\n uuvz = qx * uvy - qy * uvx; // vec3.scale(uv, uv, 2 * w);\n\n var w2 = qw * 2;\n uvx *= w2;\n uvy *= w2;\n uvz *= w2; // vec3.scale(uuv, uuv, 2);\n\n uuvx *= 2;\n uuvy *= 2;\n uuvz *= 2; // return vec3.add(out, a, vec3.add(out, uv, uuv));\n\n out[0] = x + uvx + uuvx;\n out[1] = y + uvy + uuvy;\n out[2] = z + uvz + uuvz;\n return out;\n}\n/**\r\n * Rotate a 3D vector around the x-axis\r\n * @param {vec3} out The receiving vec3\r\n * @param {ReadonlyVec3} a The vec3 point to rotate\r\n * @param {ReadonlyVec3} b The origin of the rotation\r\n * @param {Number} rad The angle of rotation in radians\r\n * @returns {vec3} out\r\n */\n\nexport function rotateX(out, a, b, rad) {\n var p = [],\n r = []; //Translate point to the origin\n\n p[0] = a[0] - b[0];\n p[1] = a[1] - b[1];\n p[2] = a[2] - b[2]; //perform rotation\n\n r[0] = p[0];\n r[1] = p[1] * Math.cos(rad) - p[2] * Math.sin(rad);\n r[2] = p[1] * Math.sin(rad) + p[2] * Math.cos(rad); //translate to correct position\n\n out[0] = r[0] + b[0];\n out[1] = r[1] + b[1];\n out[2] = r[2] + b[2];\n return out;\n}\n/**\r\n * Rotate a 3D vector around the y-axis\r\n * @param {vec3} out The receiving vec3\r\n * @param {ReadonlyVec3} a The vec3 point to rotate\r\n * @param {ReadonlyVec3} b The origin of the rotation\r\n * @param {Number} rad The angle of rotation in radians\r\n * @returns {vec3} out\r\n */\n\nexport function rotateY(out, a, b, rad) {\n var p = [],\n r = []; //Translate point to the origin\n\n p[0] = a[0] - b[0];\n p[1] = a[1] - b[1];\n p[2] = a[2] - b[2]; //perform rotation\n\n r[0] = p[2] * Math.sin(rad) + p[0] * Math.cos(rad);\n r[1] = p[1];\n r[2] = p[2] * Math.cos(rad) - p[0] * Math.sin(rad); //translate to correct position\n\n out[0] = r[0] + b[0];\n out[1] = r[1] + b[1];\n out[2] = r[2] + b[2];\n return out;\n}\n/**\r\n * Rotate a 3D vector around the z-axis\r\n * @param {vec3} out The receiving vec3\r\n * @param {ReadonlyVec3} a The vec3 point to rotate\r\n * @param {ReadonlyVec3} b The origin of the rotation\r\n * @param {Number} rad The angle of rotation in radians\r\n * @returns {vec3} out\r\n */\n\nexport function rotateZ(out, a, b, rad) {\n var p = [],\n r = []; //Translate point to the origin\n\n p[0] = a[0] - b[0];\n p[1] = a[1] - b[1];\n p[2] = a[2] - b[2]; //perform rotation\n\n r[0] = p[0] * Math.cos(rad) - p[1] * Math.sin(rad);\n r[1] = p[0] * Math.sin(rad) + p[1] * Math.cos(rad);\n r[2] = p[2]; //translate to correct position\n\n out[0] = r[0] + b[0];\n out[1] = r[1] + b[1];\n out[2] = r[2] + b[2];\n return out;\n}\n/**\r\n * Get the angle between two 3D vectors\r\n * @param {ReadonlyVec3} a The first operand\r\n * @param {ReadonlyVec3} b The second operand\r\n * @returns {Number} The angle in radians\r\n */\n\nexport function angle(a, b) {\n var ax = a[0],\n ay = a[1],\n az = a[2],\n bx = b[0],\n by = b[1],\n bz = b[2],\n mag1 = Math.sqrt(ax * ax + ay * ay + az * az),\n mag2 = Math.sqrt(bx * bx + by * by + bz * bz),\n mag = mag1 * mag2,\n cosine = mag && dot(a, b) / mag;\n return Math.acos(Math.min(Math.max(cosine, -1), 1));\n}\n/**\r\n * Set the components of a vec3 to zero\r\n *\r\n * @param {vec3} out the receiving vector\r\n * @returns {vec3} out\r\n */\n\nexport function zero(out) {\n out[0] = 0.0;\n out[1] = 0.0;\n out[2] = 0.0;\n return out;\n}\n/**\r\n * Returns a string representation of a vector\r\n *\r\n * @param {ReadonlyVec3} a vector to represent as a string\r\n * @returns {String} string representation of the vector\r\n */\n\nexport function str(a) {\n return \"vec3(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \")\";\n}\n/**\r\n * Returns whether or not the vectors have exactly the same elements in the same position (when compared with ===)\r\n *\r\n * @param {ReadonlyVec3} a The first vector.\r\n * @param {ReadonlyVec3} b The second vector.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2];\n}\n/**\r\n * Returns whether or not the vectors have approximately the same elements in the same position.\r\n *\r\n * @param {ReadonlyVec3} a The first vector.\r\n * @param {ReadonlyVec3} b The second vector.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2));\n}\n/**\r\n * Alias for {@link vec3.subtract}\r\n * @function\r\n */\n\nexport var sub = subtract;\n/**\r\n * Alias for {@link vec3.multiply}\r\n * @function\r\n */\n\nexport var mul = multiply;\n/**\r\n * Alias for {@link vec3.divide}\r\n * @function\r\n */\n\nexport var div = divide;\n/**\r\n * Alias for {@link vec3.distance}\r\n * @function\r\n */\n\nexport var dist = distance;\n/**\r\n * Alias for {@link vec3.squaredDistance}\r\n * @function\r\n */\n\nexport var sqrDist = squaredDistance;\n/**\r\n * Alias for {@link vec3.length}\r\n * @function\r\n */\n\nexport var len = length;\n/**\r\n * Alias for {@link vec3.squaredLength}\r\n * @function\r\n */\n\nexport var sqrLen = squaredLength;\n/**\r\n * Perform some operation over an array of vec3s.\r\n *\r\n * @param {Array} a the array of vectors to iterate over\r\n * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed\r\n * @param {Number} offset Number of elements to skip at the beginning of the array\r\n * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array\r\n * @param {Function} fn Function to call for each vector in the array\r\n * @param {Object} [arg] additional argument to pass to fn\r\n * @returns {Array} a\r\n * @function\r\n */\n\nexport var forEach = function () {\n var vec = create();\n return function (a, stride, offset, count, fn, arg) {\n var i, l;\n\n if (!stride) {\n stride = 3;\n }\n\n if (!offset) {\n offset = 0;\n }\n\n if (count) {\n l = Math.min(count * stride + offset, a.length);\n } else {\n l = a.length;\n }\n\n for (i = offset; i < l; i += stride) {\n vec[0] = a[i];\n vec[1] = a[i + 1];\n vec[2] = a[i + 2];\n fn(vec, vec, arg);\n a[i] = vec[0];\n a[i + 1] = vec[1];\n a[i + 2] = vec[2];\n }\n\n return a;\n };\n}();","import _typeof from \"@babel/runtime/helpers/typeof\";\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n/** `Object#toString` result references. */\n\nvar argsTag = '[object Arguments]';\nvar arrayTag = '[object Array]';\nvar boolTag = '[object Boolean]';\nvar dateTag = '[object Date]';\nvar errorTag = '[object Error]';\nvar funcTag = '[object Function]';\nvar mapTag = '[object Map]';\nvar numberTag = '[object Number]';\nvar objectTag = '[object Object]';\nvar regexpTag = '[object RegExp]';\nvar setTag = '[object Set]';\nvar stringTag = '[object String]';\nvar weakMapTag = '[object WeakMap]';\nvar arrayBufferTag = '[object ArrayBuffer]';\nvar dataViewTag = '[object DataView]';\nvar float32Tag = '[object Float32Array]';\nvar float64Tag = '[object Float64Array]';\nvar int8Tag = '[object Int8Array]';\nvar int16Tag = '[object Int16Array]';\nvar int32Tag = '[object Int32Array]';\nvar uint8Tag = '[object Uint8Array]';\nvar uint8ClampedTag = '[object Uint8ClampedArray]';\nvar uint16Tag = '[object Uint16Array]';\nvar uint32Tag = '[object Uint32Array]';\n/** Used to identify `toStringTag` values of typed arrays. */\n\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] = typedArrayTags[int8Tag] = typedArrayTags[int16Tag] = typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] = typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] = typedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] = typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] = typedArrayTags[dataViewTag] = typedArrayTags[dateTag] = typedArrayTags[errorTag] = typedArrayTags[funcTag] = typedArrayTags[mapTag] = typedArrayTags[numberTag] = typedArrayTags[objectTag] = typedArrayTags[regexpTag] = typedArrayTags[setTag] = typedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false;\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\n\nfunction baseUnary(func) {\n return function (value) {\n return func(value);\n };\n}\n/** Used for built-in method references. */\n\n\nvar objectProto = Object.prototype;\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\n\nvar objectToString = objectProto.toString;\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\n\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[objectToString.call(value)];\n}\n\nfunction isLength(value) {\n return typeof value === 'number' && value > -1 && value % 1 === 0 && value <= MAX_SAFE_INTEGER;\n}\n\nfunction isObjectLike(value) {\n return !!value && _typeof(value) === 'object';\n}\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\n\n\nexport var isTypedArray = baseIsTypedArray;\n//# sourceMappingURL=is-typedarray.js.map","import _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { mat3, vec3, vec4 } from 'gl-matrix';\nimport { Component } from '../..';\nimport { isTypedArray } from '../../utils/is-typedarray';\nexport var GeometryComponent = /*#__PURE__*/function (_Component) {\n _inherits(GeometryComponent, _Component);\n\n var _super = _createSuper(GeometryComponent);\n\n // instanced count\n function GeometryComponent(data) {\n var _this;\n\n _classCallCheck(this, GeometryComponent);\n\n _this = _super.call(this, data);\n _this.dirty = true;\n _this.attributes = [];\n _this.indices = void 0;\n _this.indicesBuffer = void 0;\n _this.vertexCount = 0;\n _this.maxInstancedCount = void 0;\n _this.aabb = void 0;\n _this.entity = void 0;\n Object.assign(_assertThisInitialized(_this), data);\n return _this;\n }\n /**\n * @see https://threejs.org/docs/#api/en/core/BufferAttribute\n */\n\n\n _createClass(GeometryComponent, [{\n key: \"setAttribute\",\n value: function setAttribute(name, data, descriptor, bufferGetter) {\n var existed = this.attributes.find(function (a) {\n return a.name === name;\n });\n\n if (!existed) {\n this.attributes.push(_objectSpread(_objectSpread({\n dirty: true,\n name: name,\n data: data\n }, descriptor), {}, {\n bufferGetter: bufferGetter\n }));\n } else {\n existed.data = data;\n existed.dirty = true;\n }\n\n this.dirty = true;\n return this;\n }\n }, {\n key: \"setIndex\",\n value: function setIndex(data) {\n this.indices = new Uint32Array( // @ts-ignore\n data.buffer ? data.buffer : data);\n this.dirty = true;\n return this;\n }\n /**\n * when merge all the geometries into one, we need to transform every vertex's position\n * and every face's normal\n */\n\n }, {\n key: \"applyMatrix\",\n value: function applyMatrix(matrix) {\n var positionAttribute = this.attributes.find(function (_ref) {\n var name = _ref.name;\n return name === 'position';\n });\n var normalAttribute = this.attributes.find(function (_ref2) {\n var name = _ref2.name;\n return name === 'normal';\n });\n\n if (positionAttribute) {\n positionAttribute.dirty = true; // @ts-ignore\n\n if (positionAttribute.data && positionAttribute.data.length) {\n // @ts-ignore\n for (var i = 0; i < positionAttribute.data.length; i += 3) {\n var position = vec4.fromValues( // @ts-ignore\n positionAttribute.data[i], // @ts-ignore\n positionAttribute.data[i + 1], // @ts-ignore\n positionAttribute.data[i + 2], 1);\n vec4.transformMat4(position, position, matrix);\n\n if (isTypedArray(positionAttribute.data)) {\n // @ts-ignore\n positionAttribute.data.set([position[0], position[1], position[2]], i);\n } else {\n // @ts-ignore\n positionAttribute.data[i] = position[0]; // @ts-ignore\n\n positionAttribute.data[i + 1] = position[1]; // @ts-ignore\n\n positionAttribute.data[i + 2] = position[2];\n }\n }\n }\n }\n\n if (normalAttribute) {\n var normalMatrix = mat3.normalFromMat4(mat3.create(), matrix); // @ts-ignore\n\n if (normalAttribute.data && normalAttribute.data.length) {\n // @ts-ignore\n for (var _i = 0; _i < normalAttribute.data.length; _i += 3) {\n var normal = vec3.fromValues( // @ts-ignore\n normalAttribute.data[_i], // @ts-ignore\n normalAttribute.data[_i + 1], // @ts-ignore\n normalAttribute.data[_i + 2]);\n vec3.transformMat3(normal, normal, normalMatrix);\n vec3.normalize(normal, normal);\n\n if (isTypedArray(normalAttribute.data)) {\n // @ts-ignore\n normalAttribute.data.set([normal[0], normal[1], normal[2]], _i);\n } else {\n // @ts-ignore\n normalAttribute.data[_i] = normal[0]; // @ts-ignore\n\n normalAttribute.data[_i + 1] = normal[1]; // @ts-ignore\n\n normalAttribute.data[_i + 2] = normal[2];\n }\n }\n }\n }\n }\n }]);\n\n return GeometryComponent;\n}(Component);\n//# sourceMappingURL=GeometryComponent.js.map","/**\n * WebGL 枚举值\n * @see http://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14\n * 使用 babel 插件对常量进行内联,以减少最终打包产物大小\n * @see https://github.com/uber/deck.gl/blob/7.1-release/dev-docs/roadmaps/dist-size-roadmap.md#inline-gl-constants\n * 为了支持 WebGPU,新增 TextureUsage\n * @see https://gpuweb.github.io/gpuweb/#gputextureusage\n */\nexport var gl;\n\n(function (gl) {\n gl[gl[\"DEPTH_BUFFER_BIT\"] = 256] = \"DEPTH_BUFFER_BIT\";\n gl[gl[\"STENCIL_BUFFER_BIT\"] = 1024] = \"STENCIL_BUFFER_BIT\";\n gl[gl[\"COLOR_BUFFER_BIT\"] = 16384] = \"COLOR_BUFFER_BIT\";\n gl[gl[\"POINTS\"] = 0] = \"POINTS\";\n gl[gl[\"LINES\"] = 1] = \"LINES\";\n gl[gl[\"LINE_LOOP\"] = 2] = \"LINE_LOOP\";\n gl[gl[\"LINE_STRIP\"] = 3] = \"LINE_STRIP\";\n gl[gl[\"TRIANGLES\"] = 4] = \"TRIANGLES\";\n gl[gl[\"TRIANGLE_STRIP\"] = 5] = \"TRIANGLE_STRIP\";\n gl[gl[\"TRIANGLE_FAN\"] = 6] = \"TRIANGLE_FAN\";\n gl[gl[\"ZERO\"] = 0] = \"ZERO\";\n gl[gl[\"ONE\"] = 1] = \"ONE\";\n gl[gl[\"SRC_COLOR\"] = 768] = \"SRC_COLOR\";\n gl[gl[\"ONE_MINUS_SRC_COLOR\"] = 769] = \"ONE_MINUS_SRC_COLOR\";\n gl[gl[\"SRC_ALPHA\"] = 770] = \"SRC_ALPHA\";\n gl[gl[\"ONE_MINUS_SRC_ALPHA\"] = 771] = \"ONE_MINUS_SRC_ALPHA\";\n gl[gl[\"DST_ALPHA\"] = 772] = \"DST_ALPHA\";\n gl[gl[\"ONE_MINUS_DST_ALPHA\"] = 773] = \"ONE_MINUS_DST_ALPHA\";\n gl[gl[\"DST_COLOR\"] = 774] = \"DST_COLOR\";\n gl[gl[\"ONE_MINUS_DST_COLOR\"] = 775] = \"ONE_MINUS_DST_COLOR\";\n gl[gl[\"SRC_ALPHA_SATURATE\"] = 776] = \"SRC_ALPHA_SATURATE\";\n gl[gl[\"FUNC_ADD\"] = 32774] = \"FUNC_ADD\";\n gl[gl[\"BLEND_EQUATION\"] = 32777] = \"BLEND_EQUATION\";\n gl[gl[\"BLEND_EQUATION_RGB\"] = 32777] = \"BLEND_EQUATION_RGB\";\n gl[gl[\"BLEND_EQUATION_ALPHA\"] = 34877] = \"BLEND_EQUATION_ALPHA\";\n gl[gl[\"FUNC_SUBTRACT\"] = 32778] = \"FUNC_SUBTRACT\";\n gl[gl[\"FUNC_REVERSE_SUBTRACT\"] = 32779] = \"FUNC_REVERSE_SUBTRACT\";\n gl[gl[\"MAX_EXT\"] = 32776] = \"MAX_EXT\";\n gl[gl[\"MIN_EXT\"] = 32775] = \"MIN_EXT\";\n gl[gl[\"BLEND_DST_RGB\"] = 32968] = \"BLEND_DST_RGB\";\n gl[gl[\"BLEND_SRC_RGB\"] = 32969] = \"BLEND_SRC_RGB\";\n gl[gl[\"BLEND_DST_ALPHA\"] = 32970] = \"BLEND_DST_ALPHA\";\n gl[gl[\"BLEND_SRC_ALPHA\"] = 32971] = \"BLEND_SRC_ALPHA\";\n gl[gl[\"CONSTANT_COLOR\"] = 32769] = \"CONSTANT_COLOR\";\n gl[gl[\"ONE_MINUS_CONSTANT_COLOR\"] = 32770] = \"ONE_MINUS_CONSTANT_COLOR\";\n gl[gl[\"CONSTANT_ALPHA\"] = 32771] = \"CONSTANT_ALPHA\";\n gl[gl[\"ONE_MINUS_CONSTANT_ALPHA\"] = 32772] = \"ONE_MINUS_CONSTANT_ALPHA\";\n gl[gl[\"BLEND_COLOR\"] = 32773] = \"BLEND_COLOR\";\n gl[gl[\"ARRAY_BUFFER\"] = 34962] = \"ARRAY_BUFFER\";\n gl[gl[\"ELEMENT_ARRAY_BUFFER\"] = 34963] = \"ELEMENT_ARRAY_BUFFER\";\n gl[gl[\"ARRAY_BUFFER_BINDING\"] = 34964] = \"ARRAY_BUFFER_BINDING\";\n gl[gl[\"ELEMENT_ARRAY_BUFFER_BINDING\"] = 34965] = \"ELEMENT_ARRAY_BUFFER_BINDING\";\n gl[gl[\"STREAM_DRAW\"] = 35040] = \"STREAM_DRAW\";\n gl[gl[\"STATIC_DRAW\"] = 35044] = \"STATIC_DRAW\";\n gl[gl[\"DYNAMIC_DRAW\"] = 35048] = \"DYNAMIC_DRAW\";\n gl[gl[\"BUFFER_SIZE\"] = 34660] = \"BUFFER_SIZE\";\n gl[gl[\"BUFFER_USAGE\"] = 34661] = \"BUFFER_USAGE\";\n gl[gl[\"CURRENT_VERTEX_ATTRIB\"] = 34342] = \"CURRENT_VERTEX_ATTRIB\";\n gl[gl[\"FRONT\"] = 1028] = \"FRONT\";\n gl[gl[\"BACK\"] = 1029] = \"BACK\";\n gl[gl[\"FRONT_AND_BACK\"] = 1032] = \"FRONT_AND_BACK\";\n gl[gl[\"CULL_FACE\"] = 2884] = \"CULL_FACE\";\n gl[gl[\"BLEND\"] = 3042] = \"BLEND\";\n gl[gl[\"DITHER\"] = 3024] = \"DITHER\";\n gl[gl[\"STENCIL_TEST\"] = 2960] = \"STENCIL_TEST\";\n gl[gl[\"DEPTH_TEST\"] = 2929] = \"DEPTH_TEST\";\n gl[gl[\"SCISSOR_TEST\"] = 3089] = \"SCISSOR_TEST\";\n gl[gl[\"POLYGON_OFFSET_FILL\"] = 32823] = \"POLYGON_OFFSET_FILL\";\n gl[gl[\"SAMPLE_ALPHA_TO_COVERAGE\"] = 32926] = \"SAMPLE_ALPHA_TO_COVERAGE\";\n gl[gl[\"SAMPLE_COVERAGE\"] = 32928] = \"SAMPLE_COVERAGE\";\n gl[gl[\"NO_ERROR\"] = 0] = \"NO_ERROR\";\n gl[gl[\"INVALID_ENUM\"] = 1280] = \"INVALID_ENUM\";\n gl[gl[\"INVALID_VALUE\"] = 1281] = \"INVALID_VALUE\";\n gl[gl[\"INVALID_OPERATION\"] = 1282] = \"INVALID_OPERATION\";\n gl[gl[\"OUT_OF_MEMORY\"] = 1285] = \"OUT_OF_MEMORY\";\n gl[gl[\"CW\"] = 2304] = \"CW\";\n gl[gl[\"CCW\"] = 2305] = \"CCW\";\n gl[gl[\"LINE_WIDTH\"] = 2849] = \"LINE_WIDTH\";\n gl[gl[\"ALIASED_POINT_SIZE_RANGE\"] = 33901] = \"ALIASED_POINT_SIZE_RANGE\";\n gl[gl[\"ALIASED_LINE_WIDTH_RANGE\"] = 33902] = \"ALIASED_LINE_WIDTH_RANGE\";\n gl[gl[\"CULL_FACE_MODE\"] = 2885] = \"CULL_FACE_MODE\";\n gl[gl[\"FRONT_FACE\"] = 2886] = \"FRONT_FACE\";\n gl[gl[\"DEPTH_RANGE\"] = 2928] = \"DEPTH_RANGE\";\n gl[gl[\"DEPTH_WRITEMASK\"] = 2930] = \"DEPTH_WRITEMASK\";\n gl[gl[\"DEPTH_CLEAR_VALUE\"] = 2931] = \"DEPTH_CLEAR_VALUE\";\n gl[gl[\"DEPTH_FUNC\"] = 2932] = \"DEPTH_FUNC\";\n gl[gl[\"STENCIL_CLEAR_VALUE\"] = 2961] = \"STENCIL_CLEAR_VALUE\";\n gl[gl[\"STENCIL_FUNC\"] = 2962] = \"STENCIL_FUNC\";\n gl[gl[\"STENCIL_FAIL\"] = 2964] = \"STENCIL_FAIL\";\n gl[gl[\"STENCIL_PASS_DEPTH_FAIL\"] = 2965] = \"STENCIL_PASS_DEPTH_FAIL\";\n gl[gl[\"STENCIL_PASS_DEPTH_PASS\"] = 2966] = \"STENCIL_PASS_DEPTH_PASS\";\n gl[gl[\"STENCIL_REF\"] = 2967] = \"STENCIL_REF\";\n gl[gl[\"STENCIL_VALUE_MASK\"] = 2963] = \"STENCIL_VALUE_MASK\";\n gl[gl[\"STENCIL_WRITEMASK\"] = 2968] = \"STENCIL_WRITEMASK\";\n gl[gl[\"STENCIL_BACK_FUNC\"] = 34816] = \"STENCIL_BACK_FUNC\";\n gl[gl[\"STENCIL_BACK_FAIL\"] = 34817] = \"STENCIL_BACK_FAIL\";\n gl[gl[\"STENCIL_BACK_PASS_DEPTH_FAIL\"] = 34818] = \"STENCIL_BACK_PASS_DEPTH_FAIL\";\n gl[gl[\"STENCIL_BACK_PASS_DEPTH_PASS\"] = 34819] = \"STENCIL_BACK_PASS_DEPTH_PASS\";\n gl[gl[\"STENCIL_BACK_REF\"] = 36003] = \"STENCIL_BACK_REF\";\n gl[gl[\"STENCIL_BACK_VALUE_MASK\"] = 36004] = \"STENCIL_BACK_VALUE_MASK\";\n gl[gl[\"STENCIL_BACK_WRITEMASK\"] = 36005] = \"STENCIL_BACK_WRITEMASK\";\n gl[gl[\"VIEWPORT\"] = 2978] = \"VIEWPORT\";\n gl[gl[\"SCISSOR_BOX\"] = 3088] = \"SCISSOR_BOX\";\n gl[gl[\"COLOR_CLEAR_VALUE\"] = 3106] = \"COLOR_CLEAR_VALUE\";\n gl[gl[\"COLOR_WRITEMASK\"] = 3107] = \"COLOR_WRITEMASK\";\n gl[gl[\"UNPACK_ALIGNMENT\"] = 3317] = \"UNPACK_ALIGNMENT\";\n gl[gl[\"PACK_ALIGNMENT\"] = 3333] = \"PACK_ALIGNMENT\";\n gl[gl[\"MAX_TEXTURE_SIZE\"] = 3379] = \"MAX_TEXTURE_SIZE\";\n gl[gl[\"MAX_VIEWPORT_DIMS\"] = 3386] = \"MAX_VIEWPORT_DIMS\";\n gl[gl[\"SUBPIXEL_BITS\"] = 3408] = \"SUBPIXEL_BITS\";\n gl[gl[\"RED_BITS\"] = 3410] = \"RED_BITS\";\n gl[gl[\"GREEN_BITS\"] = 3411] = \"GREEN_BITS\";\n gl[gl[\"BLUE_BITS\"] = 3412] = \"BLUE_BITS\";\n gl[gl[\"ALPHA_BITS\"] = 3413] = \"ALPHA_BITS\";\n gl[gl[\"DEPTH_BITS\"] = 3414] = \"DEPTH_BITS\";\n gl[gl[\"STENCIL_BITS\"] = 3415] = \"STENCIL_BITS\";\n gl[gl[\"POLYGON_OFFSET_UNITS\"] = 10752] = \"POLYGON_OFFSET_UNITS\";\n gl[gl[\"POLYGON_OFFSET_FACTOR\"] = 32824] = \"POLYGON_OFFSET_FACTOR\";\n gl[gl[\"TEXTURE_BINDING_2D\"] = 32873] = \"TEXTURE_BINDING_2D\";\n gl[gl[\"SAMPLE_BUFFERS\"] = 32936] = \"SAMPLE_BUFFERS\";\n gl[gl[\"SAMPLES\"] = 32937] = \"SAMPLES\";\n gl[gl[\"SAMPLE_COVERAGE_VALUE\"] = 32938] = \"SAMPLE_COVERAGE_VALUE\";\n gl[gl[\"SAMPLE_COVERAGE_INVERT\"] = 32939] = \"SAMPLE_COVERAGE_INVERT\";\n gl[gl[\"COMPRESSED_TEXTURE_FORMATS\"] = 34467] = \"COMPRESSED_TEXTURE_FORMATS\";\n gl[gl[\"DONT_CARE\"] = 4352] = \"DONT_CARE\";\n gl[gl[\"FASTEST\"] = 4353] = \"FASTEST\";\n gl[gl[\"NICEST\"] = 4354] = \"NICEST\";\n gl[gl[\"GENERATE_MIPMAP_HINT\"] = 33170] = \"GENERATE_MIPMAP_HINT\";\n gl[gl[\"BYTE\"] = 5120] = \"BYTE\";\n gl[gl[\"UNSIGNED_BYTE\"] = 5121] = \"UNSIGNED_BYTE\";\n gl[gl[\"SHORT\"] = 5122] = \"SHORT\";\n gl[gl[\"UNSIGNED_SHORT\"] = 5123] = \"UNSIGNED_SHORT\";\n gl[gl[\"INT\"] = 5124] = \"INT\";\n gl[gl[\"UNSIGNED_INT\"] = 5125] = \"UNSIGNED_INT\";\n gl[gl[\"FLOAT\"] = 5126] = \"FLOAT\";\n gl[gl[\"DEPTH_COMPONENT\"] = 6402] = \"DEPTH_COMPONENT\";\n gl[gl[\"ALPHA\"] = 6406] = \"ALPHA\";\n gl[gl[\"RGB\"] = 6407] = \"RGB\";\n gl[gl[\"RGBA\"] = 6408] = \"RGBA\";\n gl[gl[\"LUMINANCE\"] = 6409] = \"LUMINANCE\";\n gl[gl[\"LUMINANCE_ALPHA\"] = 6410] = \"LUMINANCE_ALPHA\";\n gl[gl[\"UNSIGNED_SHORT_4_4_4_4\"] = 32819] = \"UNSIGNED_SHORT_4_4_4_4\";\n gl[gl[\"UNSIGNED_SHORT_5_5_5_1\"] = 32820] = \"UNSIGNED_SHORT_5_5_5_1\";\n gl[gl[\"UNSIGNED_SHORT_5_6_5\"] = 33635] = \"UNSIGNED_SHORT_5_6_5\";\n gl[gl[\"FRAGMENT_SHADER\"] = 35632] = \"FRAGMENT_SHADER\";\n gl[gl[\"VERTEX_SHADER\"] = 35633] = \"VERTEX_SHADER\";\n gl[gl[\"MAX_VERTEX_ATTRIBS\"] = 34921] = \"MAX_VERTEX_ATTRIBS\";\n gl[gl[\"MAX_VERTEX_UNIFORM_VECTORS\"] = 36347] = \"MAX_VERTEX_UNIFORM_VECTORS\";\n gl[gl[\"MAX_VARYING_VECTORS\"] = 36348] = \"MAX_VARYING_VECTORS\";\n gl[gl[\"MAX_COMBINED_TEXTURE_IMAGE_UNITS\"] = 35661] = \"MAX_COMBINED_TEXTURE_IMAGE_UNITS\";\n gl[gl[\"MAX_VERTEX_TEXTURE_IMAGE_UNITS\"] = 35660] = \"MAX_VERTEX_TEXTURE_IMAGE_UNITS\";\n gl[gl[\"MAX_TEXTURE_IMAGE_UNITS\"] = 34930] = \"MAX_TEXTURE_IMAGE_UNITS\";\n gl[gl[\"MAX_FRAGMENT_UNIFORM_VECTORS\"] = 36349] = \"MAX_FRAGMENT_UNIFORM_VECTORS\";\n gl[gl[\"SHADER_TYPE\"] = 35663] = \"SHADER_TYPE\";\n gl[gl[\"DELETE_STATUS\"] = 35712] = \"DELETE_STATUS\";\n gl[gl[\"LINK_STATUS\"] = 35714] = \"LINK_STATUS\";\n gl[gl[\"VALIDATE_STATUS\"] = 35715] = \"VALIDATE_STATUS\";\n gl[gl[\"ATTACHED_SHADERS\"] = 35717] = \"ATTACHED_SHADERS\";\n gl[gl[\"ACTIVE_UNIFORMS\"] = 35718] = \"ACTIVE_UNIFORMS\";\n gl[gl[\"ACTIVE_ATTRIBUTES\"] = 35721] = \"ACTIVE_ATTRIBUTES\";\n gl[gl[\"SHADING_LANGUAGE_VERSION\"] = 35724] = \"SHADING_LANGUAGE_VERSION\";\n gl[gl[\"CURRENT_PROGRAM\"] = 35725] = \"CURRENT_PROGRAM\";\n gl[gl[\"NEVER\"] = 512] = \"NEVER\";\n gl[gl[\"LESS\"] = 513] = \"LESS\";\n gl[gl[\"EQUAL\"] = 514] = \"EQUAL\";\n gl[gl[\"LEQUAL\"] = 515] = \"LEQUAL\";\n gl[gl[\"GREATER\"] = 516] = \"GREATER\";\n gl[gl[\"NOTEQUAL\"] = 517] = \"NOTEQUAL\";\n gl[gl[\"GEQUAL\"] = 518] = \"GEQUAL\";\n gl[gl[\"ALWAYS\"] = 519] = \"ALWAYS\";\n gl[gl[\"KEEP\"] = 7680] = \"KEEP\";\n gl[gl[\"REPLACE\"] = 7681] = \"REPLACE\";\n gl[gl[\"INCR\"] = 7682] = \"INCR\";\n gl[gl[\"DECR\"] = 7683] = \"DECR\";\n gl[gl[\"INVERT\"] = 5386] = \"INVERT\";\n gl[gl[\"INCR_WRAP\"] = 34055] = \"INCR_WRAP\";\n gl[gl[\"DECR_WRAP\"] = 34056] = \"DECR_WRAP\";\n gl[gl[\"VENDOR\"] = 7936] = \"VENDOR\";\n gl[gl[\"RENDERER\"] = 7937] = \"RENDERER\";\n gl[gl[\"VERSION\"] = 7938] = \"VERSION\";\n gl[gl[\"NEAREST\"] = 9728] = \"NEAREST\";\n gl[gl[\"LINEAR\"] = 9729] = \"LINEAR\";\n gl[gl[\"NEAREST_MIPMAP_NEAREST\"] = 9984] = \"NEAREST_MIPMAP_NEAREST\";\n gl[gl[\"LINEAR_MIPMAP_NEAREST\"] = 9985] = \"LINEAR_MIPMAP_NEAREST\";\n gl[gl[\"NEAREST_MIPMAP_LINEAR\"] = 9986] = \"NEAREST_MIPMAP_LINEAR\";\n gl[gl[\"LINEAR_MIPMAP_LINEAR\"] = 9987] = \"LINEAR_MIPMAP_LINEAR\";\n gl[gl[\"TEXTURE_MAG_FILTER\"] = 10240] = \"TEXTURE_MAG_FILTER\";\n gl[gl[\"TEXTURE_MIN_FILTER\"] = 10241] = \"TEXTURE_MIN_FILTER\";\n gl[gl[\"TEXTURE_WRAP_S\"] = 10242] = \"TEXTURE_WRAP_S\";\n gl[gl[\"TEXTURE_WRAP_T\"] = 10243] = \"TEXTURE_WRAP_T\";\n gl[gl[\"TEXTURE_2D\"] = 3553] = \"TEXTURE_2D\";\n gl[gl[\"TEXTURE\"] = 5890] = \"TEXTURE\";\n gl[gl[\"TEXTURE_CUBE_MAP\"] = 34067] = \"TEXTURE_CUBE_MAP\";\n gl[gl[\"TEXTURE_BINDING_CUBE_MAP\"] = 34068] = \"TEXTURE_BINDING_CUBE_MAP\";\n gl[gl[\"TEXTURE_CUBE_MAP_POSITIVE_X\"] = 34069] = \"TEXTURE_CUBE_MAP_POSITIVE_X\";\n gl[gl[\"TEXTURE_CUBE_MAP_NEGATIVE_X\"] = 34070] = \"TEXTURE_CUBE_MAP_NEGATIVE_X\";\n gl[gl[\"TEXTURE_CUBE_MAP_POSITIVE_Y\"] = 34071] = \"TEXTURE_CUBE_MAP_POSITIVE_Y\";\n gl[gl[\"TEXTURE_CUBE_MAP_NEGATIVE_Y\"] = 34072] = \"TEXTURE_CUBE_MAP_NEGATIVE_Y\";\n gl[gl[\"TEXTURE_CUBE_MAP_POSITIVE_Z\"] = 34073] = \"TEXTURE_CUBE_MAP_POSITIVE_Z\";\n gl[gl[\"TEXTURE_CUBE_MAP_NEGATIVE_Z\"] = 34074] = \"TEXTURE_CUBE_MAP_NEGATIVE_Z\";\n gl[gl[\"MAX_CUBE_MAP_TEXTURE_SIZE\"] = 34076] = \"MAX_CUBE_MAP_TEXTURE_SIZE\";\n gl[gl[\"TEXTURE0\"] = 33984] = \"TEXTURE0\";\n gl[gl[\"TEXTURE1\"] = 33985] = \"TEXTURE1\";\n gl[gl[\"TEXTURE2\"] = 33986] = \"TEXTURE2\";\n gl[gl[\"TEXTURE3\"] = 33987] = \"TEXTURE3\";\n gl[gl[\"TEXTURE4\"] = 33988] = \"TEXTURE4\";\n gl[gl[\"TEXTURE5\"] = 33989] = \"TEXTURE5\";\n gl[gl[\"TEXTURE6\"] = 33990] = \"TEXTURE6\";\n gl[gl[\"TEXTURE7\"] = 33991] = \"TEXTURE7\";\n gl[gl[\"TEXTURE8\"] = 33992] = \"TEXTURE8\";\n gl[gl[\"TEXTURE9\"] = 33993] = \"TEXTURE9\";\n gl[gl[\"TEXTURE10\"] = 33994] = \"TEXTURE10\";\n gl[gl[\"TEXTURE11\"] = 33995] = \"TEXTURE11\";\n gl[gl[\"TEXTURE12\"] = 33996] = \"TEXTURE12\";\n gl[gl[\"TEXTURE13\"] = 33997] = \"TEXTURE13\";\n gl[gl[\"TEXTURE14\"] = 33998] = \"TEXTURE14\";\n gl[gl[\"TEXTURE15\"] = 33999] = \"TEXTURE15\";\n gl[gl[\"TEXTURE16\"] = 34000] = \"TEXTURE16\";\n gl[gl[\"TEXTURE17\"] = 34001] = \"TEXTURE17\";\n gl[gl[\"TEXTURE18\"] = 34002] = \"TEXTURE18\";\n gl[gl[\"TEXTURE19\"] = 34003] = \"TEXTURE19\";\n gl[gl[\"TEXTURE20\"] = 34004] = \"TEXTURE20\";\n gl[gl[\"TEXTURE21\"] = 34005] = \"TEXTURE21\";\n gl[gl[\"TEXTURE22\"] = 34006] = \"TEXTURE22\";\n gl[gl[\"TEXTURE23\"] = 34007] = \"TEXTURE23\";\n gl[gl[\"TEXTURE24\"] = 34008] = \"TEXTURE24\";\n gl[gl[\"TEXTURE25\"] = 34009] = \"TEXTURE25\";\n gl[gl[\"TEXTURE26\"] = 34010] = \"TEXTURE26\";\n gl[gl[\"TEXTURE27\"] = 34011] = \"TEXTURE27\";\n gl[gl[\"TEXTURE28\"] = 34012] = \"TEXTURE28\";\n gl[gl[\"TEXTURE29\"] = 34013] = \"TEXTURE29\";\n gl[gl[\"TEXTURE30\"] = 34014] = \"TEXTURE30\";\n gl[gl[\"TEXTURE31\"] = 34015] = \"TEXTURE31\";\n gl[gl[\"ACTIVE_TEXTURE\"] = 34016] = \"ACTIVE_TEXTURE\";\n gl[gl[\"REPEAT\"] = 10497] = \"REPEAT\";\n gl[gl[\"CLAMP_TO_EDGE\"] = 33071] = \"CLAMP_TO_EDGE\";\n gl[gl[\"MIRRORED_REPEAT\"] = 33648] = \"MIRRORED_REPEAT\";\n gl[gl[\"FLOAT_VEC2\"] = 35664] = \"FLOAT_VEC2\";\n gl[gl[\"FLOAT_VEC3\"] = 35665] = \"FLOAT_VEC3\";\n gl[gl[\"FLOAT_VEC4\"] = 35666] = \"FLOAT_VEC4\";\n gl[gl[\"INT_VEC2\"] = 35667] = \"INT_VEC2\";\n gl[gl[\"INT_VEC3\"] = 35668] = \"INT_VEC3\";\n gl[gl[\"INT_VEC4\"] = 35669] = \"INT_VEC4\";\n gl[gl[\"BOOL\"] = 35670] = \"BOOL\";\n gl[gl[\"BOOL_VEC2\"] = 35671] = \"BOOL_VEC2\";\n gl[gl[\"BOOL_VEC3\"] = 35672] = \"BOOL_VEC3\";\n gl[gl[\"BOOL_VEC4\"] = 35673] = \"BOOL_VEC4\";\n gl[gl[\"FLOAT_MAT2\"] = 35674] = \"FLOAT_MAT2\";\n gl[gl[\"FLOAT_MAT3\"] = 35675] = \"FLOAT_MAT3\";\n gl[gl[\"FLOAT_MAT4\"] = 35676] = \"FLOAT_MAT4\";\n gl[gl[\"SAMPLER_2D\"] = 35678] = \"SAMPLER_2D\";\n gl[gl[\"SAMPLER_CUBE\"] = 35680] = \"SAMPLER_CUBE\";\n gl[gl[\"VERTEX_ATTRIB_ARRAY_ENABLED\"] = 34338] = \"VERTEX_ATTRIB_ARRAY_ENABLED\";\n gl[gl[\"VERTEX_ATTRIB_ARRAY_SIZE\"] = 34339] = \"VERTEX_ATTRIB_ARRAY_SIZE\";\n gl[gl[\"VERTEX_ATTRIB_ARRAY_STRIDE\"] = 34340] = \"VERTEX_ATTRIB_ARRAY_STRIDE\";\n gl[gl[\"VERTEX_ATTRIB_ARRAY_TYPE\"] = 34341] = \"VERTEX_ATTRIB_ARRAY_TYPE\";\n gl[gl[\"VERTEX_ATTRIB_ARRAY_NORMALIZED\"] = 34922] = \"VERTEX_ATTRIB_ARRAY_NORMALIZED\";\n gl[gl[\"VERTEX_ATTRIB_ARRAY_POINTER\"] = 34373] = \"VERTEX_ATTRIB_ARRAY_POINTER\";\n gl[gl[\"VERTEX_ATTRIB_ARRAY_BUFFER_BINDING\"] = 34975] = \"VERTEX_ATTRIB_ARRAY_BUFFER_BINDING\";\n gl[gl[\"COMPILE_STATUS\"] = 35713] = \"COMPILE_STATUS\";\n gl[gl[\"LOW_FLOAT\"] = 36336] = \"LOW_FLOAT\";\n gl[gl[\"MEDIUM_FLOAT\"] = 36337] = \"MEDIUM_FLOAT\";\n gl[gl[\"HIGH_FLOAT\"] = 36338] = \"HIGH_FLOAT\";\n gl[gl[\"LOW_INT\"] = 36339] = \"LOW_INT\";\n gl[gl[\"MEDIUM_INT\"] = 36340] = \"MEDIUM_INT\";\n gl[gl[\"HIGH_INT\"] = 36341] = \"HIGH_INT\";\n gl[gl[\"FRAMEBUFFER\"] = 36160] = \"FRAMEBUFFER\";\n gl[gl[\"RENDERBUFFER\"] = 36161] = \"RENDERBUFFER\";\n gl[gl[\"RGBA4\"] = 32854] = \"RGBA4\";\n gl[gl[\"RGB5_A1\"] = 32855] = \"RGB5_A1\";\n gl[gl[\"RGB565\"] = 36194] = \"RGB565\";\n gl[gl[\"DEPTH_COMPONENT16\"] = 33189] = \"DEPTH_COMPONENT16\";\n gl[gl[\"STENCIL_INDEX\"] = 6401] = \"STENCIL_INDEX\";\n gl[gl[\"STENCIL_INDEX8\"] = 36168] = \"STENCIL_INDEX8\";\n gl[gl[\"DEPTH_STENCIL\"] = 34041] = \"DEPTH_STENCIL\";\n gl[gl[\"RENDERBUFFER_WIDTH\"] = 36162] = \"RENDERBUFFER_WIDTH\";\n gl[gl[\"RENDERBUFFER_HEIGHT\"] = 36163] = \"RENDERBUFFER_HEIGHT\";\n gl[gl[\"RENDERBUFFER_INTERNAL_FORMAT\"] = 36164] = \"RENDERBUFFER_INTERNAL_FORMAT\";\n gl[gl[\"RENDERBUFFER_RED_SIZE\"] = 36176] = \"RENDERBUFFER_RED_SIZE\";\n gl[gl[\"RENDERBUFFER_GREEN_SIZE\"] = 36177] = \"RENDERBUFFER_GREEN_SIZE\";\n gl[gl[\"RENDERBUFFER_BLUE_SIZE\"] = 36178] = \"RENDERBUFFER_BLUE_SIZE\";\n gl[gl[\"RENDERBUFFER_ALPHA_SIZE\"] = 36179] = \"RENDERBUFFER_ALPHA_SIZE\";\n gl[gl[\"RENDERBUFFER_DEPTH_SIZE\"] = 36180] = \"RENDERBUFFER_DEPTH_SIZE\";\n gl[gl[\"RENDERBUFFER_STENCIL_SIZE\"] = 36181] = \"RENDERBUFFER_STENCIL_SIZE\";\n gl[gl[\"FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE\"] = 36048] = \"FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE\";\n gl[gl[\"FRAMEBUFFER_ATTACHMENT_OBJECT_NAME\"] = 36049] = \"FRAMEBUFFER_ATTACHMENT_OBJECT_NAME\";\n gl[gl[\"FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL\"] = 36050] = \"FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL\";\n gl[gl[\"FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE\"] = 36051] = \"FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE\";\n gl[gl[\"COLOR_ATTACHMENT0\"] = 36064] = \"COLOR_ATTACHMENT0\";\n gl[gl[\"DEPTH_ATTACHMENT\"] = 36096] = \"DEPTH_ATTACHMENT\";\n gl[gl[\"STENCIL_ATTACHMENT\"] = 36128] = \"STENCIL_ATTACHMENT\";\n gl[gl[\"DEPTH_STENCIL_ATTACHMENT\"] = 33306] = \"DEPTH_STENCIL_ATTACHMENT\";\n gl[gl[\"NONE\"] = 0] = \"NONE\";\n gl[gl[\"FRAMEBUFFER_COMPLETE\"] = 36053] = \"FRAMEBUFFER_COMPLETE\";\n gl[gl[\"FRAMEBUFFER_INCOMPLETE_ATTACHMENT\"] = 36054] = \"FRAMEBUFFER_INCOMPLETE_ATTACHMENT\";\n gl[gl[\"FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT\"] = 36055] = \"FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT\";\n gl[gl[\"FRAMEBUFFER_INCOMPLETE_DIMENSIONS\"] = 36057] = \"FRAMEBUFFER_INCOMPLETE_DIMENSIONS\";\n gl[gl[\"FRAMEBUFFER_UNSUPPORTED\"] = 36061] = \"FRAMEBUFFER_UNSUPPORTED\";\n gl[gl[\"FRAMEBUFFER_BINDING\"] = 36006] = \"FRAMEBUFFER_BINDING\";\n gl[gl[\"RENDERBUFFER_BINDING\"] = 36007] = \"RENDERBUFFER_BINDING\";\n gl[gl[\"MAX_RENDERBUFFER_SIZE\"] = 34024] = \"MAX_RENDERBUFFER_SIZE\";\n gl[gl[\"INVALID_FRAMEBUFFER_OPERATION\"] = 1286] = \"INVALID_FRAMEBUFFER_OPERATION\";\n gl[gl[\"UNPACK_FLIP_Y_WEBGL\"] = 37440] = \"UNPACK_FLIP_Y_WEBGL\";\n gl[gl[\"UNPACK_PREMULTIPLY_ALPHA_WEBGL\"] = 37441] = \"UNPACK_PREMULTIPLY_ALPHA_WEBGL\";\n gl[gl[\"CONTEXT_LOST_WEBGL\"] = 37442] = \"CONTEXT_LOST_WEBGL\";\n gl[gl[\"UNPACK_COLORSPACE_CONVERSION_WEBGL\"] = 37443] = \"UNPACK_COLORSPACE_CONVERSION_WEBGL\";\n gl[gl[\"BROWSER_DEFAULT_WEBGL\"] = 37444] = \"BROWSER_DEFAULT_WEBGL\";\n gl[gl[\"COPY_SRC\"] = 1] = \"COPY_SRC\";\n gl[gl[\"COPY_DST\"] = 2] = \"COPY_DST\";\n gl[gl[\"SAMPLED\"] = 4] = \"SAMPLED\";\n gl[gl[\"STORAGE\"] = 8] = \"STORAGE\";\n gl[gl[\"RENDER_ATTACHMENT\"] = 16] = \"RENDER_ATTACHMENT\";\n})(gl || (gl = {}));\n//# sourceMappingURL=gl.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _class, _class2, _descriptor, _descriptor2, _temp;\n\nimport { inject, injectable } from 'inversify';\nimport { createEntity } from '../..';\nimport { IDENTIFIER } from '../../identifier';\nimport { gl } from '../renderer/gl';\nexport var GeometrySystem = (_dec = injectable(), _dec2 = inject(IDENTIFIER.GeometryComponentManager), _dec3 = inject(IDENTIFIER.RenderEngine), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function () {\n function GeometrySystem() {\n _classCallCheck(this, GeometrySystem);\n\n _initializerDefineProperty(this, \"geometry\", _descriptor, this);\n\n _initializerDefineProperty(this, \"engine\", _descriptor2, this);\n }\n\n _createClass(GeometrySystem, [{\n key: \"execute\",\n value: function () {\n var _execute = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {\n var _this = this;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n this.geometry.forEach(function (entity, component) {\n // build buffers for each geometry\n if (component.dirty) {\n component.attributes.forEach(function (attribute) {\n if (attribute.dirty && attribute.data) {\n if (!attribute.buffer) {\n attribute.buffer = _this.engine.createBuffer({\n data: attribute.data,\n type: gl.FLOAT\n });\n } else {\n var _attribute$buffer;\n\n (_attribute$buffer = attribute.buffer) === null || _attribute$buffer === void 0 ? void 0 : _attribute$buffer.subData({\n data: attribute.data,\n // TODO: support offset in subdata\n offset: 0\n });\n }\n\n attribute.dirty = false;\n }\n }); // create index buffer if needed\n\n if (component.indices) {\n if (!component.indicesBuffer) {\n component.indicesBuffer = _this.engine.createElements({\n data: component.indices,\n count: component.indices.length,\n type: gl.UNSIGNED_INT,\n usage: gl.STATIC_DRAW\n });\n } else {\n component.indicesBuffer.subData({\n data: component.indices,\n offset: 0\n });\n }\n }\n\n component.dirty = false;\n }\n });\n\n case 1:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function execute() {\n return _execute.apply(this, arguments);\n }\n\n return execute;\n }()\n }, {\n key: \"tearDown\",\n value: function tearDown() {\n this.geometry.forEach(function (_, geometry) {\n if (geometry.indicesBuffer) {\n geometry.indicesBuffer.destroy();\n }\n\n geometry.attributes.forEach(function (attribute) {\n if (attribute.buffer) {\n attribute.buffer.destroy();\n }\n });\n });\n this.geometry.clear();\n }\n /**\n * @see https://threejs.org/docs/#api/en/core/BufferGeometry\n */\n\n }, {\n key: \"createBufferGeometry\",\n value: function createBufferGeometry() {\n var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {\n vertexCount: 3\n },\n vertexCount = _ref.vertexCount;\n\n var entity = createEntity();\n return this.geometry.create(entity, {\n vertexCount: vertexCount\n });\n }\n /**\n * @see https://threejs.org/docs/#api/en/core/InstancedBufferGeometry\n */\n\n }, {\n key: \"createInstancedBufferGeometry\",\n value: function createInstancedBufferGeometry(_ref2) {\n var maxInstancedCount = _ref2.maxInstancedCount,\n vertexCount = _ref2.vertexCount;\n var entity = createEntity();\n return this.geometry.create(entity, {\n maxInstancedCount: maxInstancedCount,\n vertexCount: vertexCount\n });\n }\n }]);\n\n return GeometrySystem;\n}(), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"geometry\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"engine\", [_dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=System.js.map","import _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { Component, gl } from '../..';\nexport var MaterialComponent = /*#__PURE__*/function (_Component) {\n _inherits(MaterialComponent, _Component);\n\n var _super = _createSuper(MaterialComponent);\n\n // control flow in shaders, eg. USE_UV, USE_MAP...\n function MaterialComponent(data) {\n var _this;\n\n _classCallCheck(this, MaterialComponent);\n\n _this = _super.call(this, data);\n _this.vertexShaderGLSL = void 0;\n _this.fragmentShaderGLSL = void 0;\n _this.defines = {};\n _this.dirty = true;\n _this.uniforms = [];\n _this.cull = {\n enable: true,\n face: gl.BACK\n };\n _this.depth = {\n enable: true\n };\n _this.blend = void 0;\n _this.entity = void 0;\n _this.type = void 0;\n Object.assign(_assertThisInitialized(_this), data);\n return _this;\n }\n\n _createClass(MaterialComponent, [{\n key: \"setDefines\",\n value: function setDefines(defines) {\n this.defines = _objectSpread(_objectSpread({}, this.defines), defines);\n return this;\n }\n }, {\n key: \"setCull\",\n value: function setCull(cull) {\n this.cull = cull;\n return this;\n }\n }, {\n key: \"setDepth\",\n value: function setDepth(depth) {\n this.depth = depth;\n return this;\n }\n }, {\n key: \"setBlend\",\n value: function setBlend(blend) {\n this.blend = blend;\n return this;\n }\n }, {\n key: \"setUniform\",\n value: function setUniform(name, data) {\n var _this2 = this;\n\n if (typeof name !== 'string') {\n Object.keys(name).forEach(function (key) {\n return _this2.setUniform(key, name[key]);\n });\n return this;\n }\n\n var existedUniform = this.uniforms.find(function (u) {\n return u.name === name;\n });\n\n if (!existedUniform) {\n this.uniforms.push({\n name: name,\n dirty: true,\n data: data\n });\n } else {\n existedUniform.dirty = true;\n existedUniform.data = data;\n }\n\n this.dirty = true;\n return this;\n }\n }]);\n\n return MaterialComponent;\n}(Component);\n//# sourceMappingURL=MaterialComponent.js.map","import _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _dec4, _class, _class2, _descriptor, _descriptor2, _descriptor3, _temp;\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { inject, injectable } from 'inversify';\nimport { createEntity } from '../..';\nimport { IDENTIFIER } from '../../identifier';\nexport var MaterialSystem = (_dec = injectable(), _dec2 = inject(IDENTIFIER.MaterialComponentManager), _dec3 = inject(IDENTIFIER.RenderEngine), _dec4 = inject(IDENTIFIER.ShaderModuleService), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function () {\n function MaterialSystem() {\n _classCallCheck(this, MaterialSystem);\n\n _initializerDefineProperty(this, \"material\", _descriptor, this);\n\n _initializerDefineProperty(this, \"engine\", _descriptor2, this);\n\n _initializerDefineProperty(this, \"shaderModule\", _descriptor3, this);\n }\n\n _createClass(MaterialSystem, [{\n key: \"execute\",\n value: function () {\n var _execute = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }));\n\n function execute() {\n return _execute.apply(this, arguments);\n }\n\n return execute;\n }()\n }, {\n key: \"tearDown\",\n value: function tearDown() {\n this.material.clear();\n }\n /**\n * @see https://threejs.org/docs/#api/en/materials/ShaderMaterial\n */\n\n }, {\n key: \"createShaderMaterial\",\n value: function createShaderMaterial(params) {\n var entity = createEntity();\n var vertexShaderGLSL = params.vertexShader;\n var fragmentShaderGLSL = params.fragmentShader;\n var uniforms = [];\n\n if (!this.engine.supportWebGPU) {\n var moduleName = \"material-\".concat(entity);\n this.shaderModule.registerModule(moduleName, {\n vs: params.vertexShader,\n fs: params.fragmentShader\n });\n var materialModule = this.shaderModule.getModule(moduleName);\n vertexShaderGLSL = materialModule.vs;\n fragmentShaderGLSL = materialModule.fs;\n\n if (materialModule.uniforms) {\n // @ts-ignore\n uniforms = Object.keys(materialModule.uniforms).map(function (uniformName) {\n return {\n dirty: true,\n name: uniformName,\n // @ts-ignore\n data: materialModule.uniforms[uniformName]\n };\n });\n }\n }\n\n return this.material.create(entity, _objectSpread(_objectSpread({\n vertexShaderGLSL: vertexShaderGLSL,\n fragmentShaderGLSL: fragmentShaderGLSL\n }, params), {}, {\n uniforms: uniforms\n }));\n }\n }]);\n\n return MaterialSystem;\n}(), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"material\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"engine\", [_dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, \"shaderModule\", [_dec4], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=System.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { Component } from '../..';\n\n/**\n * @see https://doc.babylonjs.com/how_to/optimizing_your_scene#changing-mesh-culling-strategy\n */\nexport var Strategy;\n\n(function (Strategy) {\n Strategy[Strategy[\"Standard\"] = 0] = \"Standard\";\n})(Strategy || (Strategy = {}));\n\nexport var CullableComponent = /*#__PURE__*/function (_Component) {\n _inherits(CullableComponent, _Component);\n\n var _super = _createSuper(CullableComponent);\n\n function CullableComponent(data) {\n var _this;\n\n _classCallCheck(this, CullableComponent);\n\n _this = _super.call(this, data);\n _this.strategy = Strategy.Standard;\n _this.visibilityPlaneMask = 0;\n _this.visible = false;\n Object.assign(_assertThisInitialized(_this), data);\n return _this;\n }\n\n return CullableComponent;\n}(Component);\n//# sourceMappingURL=CullableComponent.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport { vec3 } from 'gl-matrix';\n\n/**\n * Axis-Aligned Bounding Box\n * 为了便于后续 Frustum Culling,通过查找表定义 p-vertex 和 n-vertex\n * @see https://github.com/antvis/GWebGPUEngine/issues/3\n */\nexport var AABB = /*#__PURE__*/function () {\n function AABB(center, halfExtents) {\n _classCallCheck(this, AABB);\n\n this.center = void 0;\n this.halfExtents = void 0;\n this.min = vec3.create();\n this.max = vec3.create();\n this.update(center, halfExtents);\n }\n\n _createClass(AABB, [{\n key: \"update\",\n value: function update(center, halfExtents) {\n this.center = center || vec3.create();\n this.halfExtents = halfExtents || vec3.fromValues(0.5, 0.5, 0.5);\n this.min = vec3.sub(this.min, this.center, this.halfExtents);\n this.max = vec3.add(this.max, this.center, this.halfExtents);\n }\n }, {\n key: \"setMinMax\",\n value: function setMinMax(min, max) {\n vec3.add(this.center, max, min);\n vec3.scale(this.center, this.center, 0.5);\n vec3.sub(this.halfExtents, max, min);\n vec3.scale(this.halfExtents, this.halfExtents, 0.5);\n vec3.copy(this.min, min);\n vec3.copy(this.max, max);\n }\n }, {\n key: \"getMin\",\n value: function getMin() {\n return this.min;\n }\n }, {\n key: \"getMax\",\n value: function getMax() {\n return this.max;\n }\n }, {\n key: \"add\",\n value: function add(aabb) {\n var tc = this.center;\n var tcx = tc[0];\n var tcy = tc[1];\n var tcz = tc[2];\n var th = this.halfExtents;\n var thx = th[0];\n var thy = th[1];\n var thz = th[2];\n var tminx = tcx - thx;\n var tmaxx = tcx + thx;\n var tminy = tcy - thy;\n var tmaxy = tcy + thy;\n var tminz = tcz - thz;\n var tmaxz = tcz + thz;\n var oc = aabb.center;\n var ocx = oc[0];\n var ocy = oc[1];\n var ocz = oc[2];\n var oh = aabb.halfExtents;\n var ohx = oh[0];\n var ohy = oh[1];\n var ohz = oh[2];\n var ominx = ocx - ohx;\n var omaxx = ocx + ohx;\n var ominy = ocy - ohy;\n var omaxy = ocy + ohy;\n var ominz = ocz - ohz;\n var omaxz = ocz + ohz;\n\n if (ominx < tminx) {\n tminx = ominx;\n }\n\n if (omaxx > tmaxx) {\n tmaxx = omaxx;\n }\n\n if (ominy < tminy) {\n tminy = ominy;\n }\n\n if (omaxy > tmaxy) {\n tmaxy = omaxy;\n }\n\n if (ominz < tminz) {\n tminz = ominz;\n }\n\n if (omaxz > tmaxz) {\n tmaxz = omaxz;\n }\n\n tc[0] = (tminx + tmaxx) * 0.5;\n tc[1] = (tminy + tmaxy) * 0.5;\n tc[2] = (tminz + tmaxz) * 0.5;\n th[0] = (tmaxx - tminx) * 0.5;\n th[1] = (tmaxy - tminy) * 0.5;\n th[2] = (tmaxz - tminz) * 0.5;\n this.min[0] = tminx;\n this.min[1] = tminy;\n this.min[2] = tminz;\n this.max[0] = tmaxx;\n this.max[1] = tmaxy;\n this.max[2] = tmaxz;\n }\n }, {\n key: \"intersects\",\n value: function intersects(aabb) {\n var aMax = this.getMax();\n var aMin = this.getMin();\n var bMax = aabb.getMax();\n var bMin = aabb.getMin();\n return aMin[0] <= bMax[0] && aMax[0] >= bMin[0] && aMin[1] <= bMax[1] && aMax[1] >= bMin[1] && aMin[2] <= bMax[2] && aMax[2] >= bMin[2];\n }\n }, {\n key: \"containsPoint\",\n value: function containsPoint(point) {\n var min = this.getMin();\n var max = this.getMax();\n return !(point[0] < min[0] || point[0] > max[0] || point[1] < min[1] || point[1] > max[1] || point[2] < min[2] || point[2] > max[2]);\n }\n /**\n * get n-vertex\n * @param plane plane of CullingVolume\n */\n\n }, {\n key: \"getNegativeFarPoint\",\n value: function getNegativeFarPoint(plane) {\n if (plane.pnVertexFlag === 0x111) {\n return vec3.copy(vec3.create(), this.min);\n } else if (plane.pnVertexFlag === 0x110) {\n return vec3.fromValues(this.min[0], this.min[1], this.max[2]);\n } else if (plane.pnVertexFlag === 0x101) {\n return vec3.fromValues(this.min[0], this.max[1], this.min[2]);\n } else if (plane.pnVertexFlag === 0x100) {\n return vec3.fromValues(this.min[0], this.max[1], this.max[2]);\n } else if (plane.pnVertexFlag === 0x011) {\n return vec3.fromValues(this.max[0], this.min[1], this.min[2]);\n } else if (plane.pnVertexFlag === 0x010) {\n return vec3.fromValues(this.max[0], this.min[1], this.max[2]);\n } else if (plane.pnVertexFlag === 0x001) {\n return vec3.fromValues(this.max[0], this.max[1], this.min[2]);\n } else {\n return vec3.fromValues(this.max[0], this.max[1], this.max[2]);\n }\n }\n /**\n * get p-vertex\n * @param plane plane of CullingVolume\n */\n\n }, {\n key: \"getPositiveFarPoint\",\n value: function getPositiveFarPoint(plane) {\n if (plane.pnVertexFlag === 0x111) {\n return vec3.copy(vec3.create(), this.max);\n } else if (plane.pnVertexFlag === 0x110) {\n return vec3.fromValues(this.max[0], this.max[1], this.min[2]);\n } else if (plane.pnVertexFlag === 0x101) {\n return vec3.fromValues(this.max[0], this.min[1], this.max[2]);\n } else if (plane.pnVertexFlag === 0x100) {\n return vec3.fromValues(this.max[0], this.min[1], this.min[2]);\n } else if (plane.pnVertexFlag === 0x011) {\n return vec3.fromValues(this.min[0], this.max[1], this.max[2]);\n } else if (plane.pnVertexFlag === 0x010) {\n return vec3.fromValues(this.min[0], this.max[1], this.min[2]);\n } else if (plane.pnVertexFlag === 0x001) {\n return vec3.fromValues(this.min[0], this.min[1], this.max[2]);\n } else {\n return vec3.fromValues(this.min[0], this.min[1], this.min[2]);\n }\n }\n }]);\n\n return AABB;\n}();\n//# sourceMappingURL=AABB.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { Component } from '../..';\nimport { AABB } from '../../shape/AABB';\nexport var MeshComponent = /*#__PURE__*/function (_Component) {\n _inherits(MeshComponent, _Component);\n\n var _super = _createSuper(MeshComponent);\n\n /**\n * aabb 应该存在 Mesh 而非 Geometry 中,原因包括:\n * 1. 包围盒会受 transform 影响。例如每次 transform 之后应该重新计算包围盒(center 发生偏移)。\n * 2. 多个 Mesh 可以共享一个 Geometry,但可以各自拥有不同的 aabb\n */\n\n /**\n * transform 之后需要重新计算包围盒\n */\n\n /**\n * 实际渲染 Model\n */\n function MeshComponent(data) {\n var _this;\n\n _classCallCheck(this, MeshComponent);\n\n _this = _super.call(this, data);\n _this.material = void 0;\n _this.geometry = void 0;\n _this.aabb = new AABB();\n _this.aabbDirty = true;\n _this.model = void 0;\n _this.visible = true;\n _this.children = [];\n Object.assign(_assertThisInitialized(_this), data);\n return _this;\n }\n\n return MeshComponent;\n}(Component);\n//# sourceMappingURL=MeshComponent.js.map","import _slicedToArray from \"@babel/runtime/helpers/slicedToArray\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport { vec3 } from 'gl-matrix';\nimport { Plane } from './Plane';\nexport var Mask;\n\n(function (Mask) {\n Mask[Mask[\"OUTSIDE\"] = 4294967295] = \"OUTSIDE\";\n Mask[Mask[\"INSIDE\"] = 0] = \"INSIDE\";\n Mask[Mask[\"INDETERMINATE\"] = 2147483647] = \"INDETERMINATE\";\n})(Mask || (Mask = {}));\n\nexport var Frustum = /*#__PURE__*/function () {\n function Frustum(planes) {\n _classCallCheck(this, Frustum);\n\n this.planes = [];\n\n if (planes) {\n this.planes = planes;\n } else {\n for (var i = 0; i < 6; i++) {\n this.planes.push(new Plane());\n }\n }\n }\n /**\n * extract 6 planes from vpMatrix\n * @see http://www8.cs.umu.se/kurser/5DV051/HT12/lab/plane_extraction.pdf\n * @param vpMatrix viewProjectionMatrix\n */\n\n\n _createClass(Frustum, [{\n key: \"extractFromVPMatrix\",\n value: function extractFromVPMatrix(vpMatrix) {\n var _vpMatrix = _slicedToArray(vpMatrix, 16),\n m0 = _vpMatrix[0],\n m1 = _vpMatrix[1],\n m2 = _vpMatrix[2],\n m3 = _vpMatrix[3],\n m4 = _vpMatrix[4],\n m5 = _vpMatrix[5],\n m6 = _vpMatrix[6],\n m7 = _vpMatrix[7],\n m8 = _vpMatrix[8],\n m9 = _vpMatrix[9],\n m10 = _vpMatrix[10],\n m11 = _vpMatrix[11],\n m12 = _vpMatrix[12],\n m13 = _vpMatrix[13],\n m14 = _vpMatrix[14],\n m15 = _vpMatrix[15]; // right\n\n\n vec3.set(this.planes[0].normal, m3 - m0, m7 - m4, m11 - m8);\n this.planes[0].distance = -(m15 - m12); // left\n\n vec3.set(this.planes[1].normal, m3 + m0, m7 + m4, m11 + m8);\n this.planes[1].distance = -(m15 + m12); // bottom\n\n vec3.set(this.planes[2].normal, m3 + m1, m7 + m5, m11 + m9);\n this.planes[2].distance = -(m15 + m13); // top\n\n vec3.set(this.planes[3].normal, m3 - m1, m7 - m5, m11 - m9);\n this.planes[3].distance = -(m15 - m13); // far\n\n vec3.set(this.planes[4].normal, m3 - m2, m7 - m6, m11 - m10);\n this.planes[4].distance = -(m15 - m14); // near\n\n vec3.set(this.planes[5].normal, m3 + m2, m7 + m6, m11 + m10);\n this.planes[5].distance = -(m15 + m14);\n this.planes.forEach(function (plane) {\n plane.normalize();\n plane.updatePNVertexFlag();\n });\n }\n }]);\n\n return Frustum;\n}();\n//# sourceMappingURL=Frustum.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport { vec3 } from 'gl-matrix';\nexport var Plane = /*#__PURE__*/function () {\n /**\n * lookup table for p-vertex & n-vertex when doing frustum culling\n */\n function Plane(distance, normal) {\n _classCallCheck(this, Plane);\n\n this.distance = void 0;\n this.normal = void 0;\n this.pnVertexFlag = void 0;\n this.distance = distance || 0;\n this.normal = normal || vec3.fromValues(0, 1, 0);\n this.updatePNVertexFlag();\n }\n\n _createClass(Plane, [{\n key: \"updatePNVertexFlag\",\n value: function updatePNVertexFlag() {\n this.pnVertexFlag = (Number(this.normal[0] >= 0) << 8) + (Number(this.normal[1] >= 0) << 4) + Number(this.normal[2] >= 0);\n }\n }, {\n key: \"distanceToPoint\",\n value: function distanceToPoint(point) {\n return vec3.dot(point, this.normal) - this.distance;\n }\n }, {\n key: \"normalize\",\n value: function normalize() {\n var invLen = 1 / vec3.len(this.normal);\n vec3.scale(this.normal, this.normal, invLen);\n this.distance *= invLen;\n }\n }, {\n key: \"intersectsLine\",\n value: function intersectsLine(start, end, point) {\n var d0 = this.distanceToPoint(start);\n var d1 = this.distanceToPoint(end);\n var t = d0 / (d0 - d1);\n var intersects = t >= 0 && t <= 1;\n\n if (intersects && point) {\n vec3.lerp(point, start, end, t);\n }\n\n return intersects;\n }\n }]);\n\n return Plane;\n}();\n//# sourceMappingURL=Plane.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _dec4, _dec5, _dec6, _class, _class2, _descriptor, _descriptor2, _descriptor3, _descriptor4, _descriptor5, _temp;\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === \"undefined\" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nimport { mat3, vec3 } from 'gl-matrix';\nimport { inject, injectable } from 'inversify';\nimport { IDENTIFIER } from '../../identifier';\nimport { Mask } from '../../shape/Frustum';\nimport { getRotationScale } from '../../utils/math';\nexport var MeshSystem = (_dec = injectable(), _dec2 = inject(IDENTIFIER.MeshComponentManager), _dec3 = inject(IDENTIFIER.CullableComponentManager), _dec4 = inject(IDENTIFIER.GeometryComponentManager), _dec5 = inject(IDENTIFIER.HierarchyComponentManager), _dec6 = inject(IDENTIFIER.TransformComponentManager), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function () {\n function MeshSystem() {\n _classCallCheck(this, MeshSystem);\n\n _initializerDefineProperty(this, \"mesh\", _descriptor, this);\n\n _initializerDefineProperty(this, \"cullable\", _descriptor2, this);\n\n _initializerDefineProperty(this, \"geometry\", _descriptor3, this);\n\n _initializerDefineProperty(this, \"hierarchy\", _descriptor4, this);\n\n _initializerDefineProperty(this, \"transform\", _descriptor5, this);\n\n this.planes = void 0;\n }\n\n _createClass(MeshSystem, [{\n key: \"setFrustumPlanes\",\n value: function setFrustumPlanes(planes) {\n this.planes = planes;\n }\n }, {\n key: \"execute\",\n value: function () {\n var _execute = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(views) {\n var _iterator, _step, view, scene, camera, _iterator2, _step2, entity, component, hierarchyComponent, cullableComponent, geometryComponent, meshTransform, worldTransform, _geometryComponent$aa, center, halfExtents, transformedCenter, rotationScale, transformedHalfExtents, parentCullableComponent;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _iterator = _createForOfIteratorHelper(views);\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n view = _step.value;\n scene = view.getScene();\n camera = view.getCamera(); // get VP matrix from camera\n\n _iterator2 = _createForOfIteratorHelper(scene.getEntities());\n\n try {\n for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n entity = _step2.value;\n component = this.mesh.getComponentByEntity(entity);\n\n if (component) {\n hierarchyComponent = this.hierarchy.getComponentByEntity(entity);\n cullableComponent = this.cullable.getComponentByEntity(entity);\n geometryComponent = component.geometry;\n meshTransform = this.transform.getComponentByEntity(entity); // update mesh.aabb\n\n if (geometryComponent && geometryComponent.aabb && meshTransform && component.aabbDirty) {\n worldTransform = meshTransform.worldTransform; // apply transform to geometry.aabb\n\n _geometryComponent$aa = geometryComponent.aabb, center = _geometryComponent$aa.center, halfExtents = _geometryComponent$aa.halfExtents;\n transformedCenter = vec3.transformMat4(vec3.create(), center, worldTransform);\n rotationScale = getRotationScale(worldTransform, mat3.create());\n transformedHalfExtents = vec3.transformMat3(vec3.create(), halfExtents, rotationScale);\n component.aabb.update(transformedCenter, transformedHalfExtents);\n component.aabbDirty = false;\n } // culling\n\n\n if (cullableComponent && geometryComponent) {\n parentCullableComponent = this.cullable.getComponentByEntity((hierarchyComponent === null || hierarchyComponent === void 0 ? void 0 : hierarchyComponent.parentID) || -1);\n cullableComponent.visibilityPlaneMask = this.computeVisibilityWithPlaneMask(component.aabb, (parentCullableComponent === null || parentCullableComponent === void 0 ? void 0 : parentCullableComponent.visibilityPlaneMask) || Mask.INDETERMINATE, this.planes || camera.getFrustum().planes);\n cullableComponent.visible = cullableComponent.visibilityPlaneMask !== Mask.OUTSIDE;\n }\n }\n }\n } catch (err) {\n _iterator2.e(err);\n } finally {\n _iterator2.f();\n }\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n case 2:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function execute(_x) {\n return _execute.apply(this, arguments);\n }\n\n return execute;\n }()\n }, {\n key: \"tearDown\",\n value: function tearDown() {\n this.cullable.clear();\n this.mesh.clear();\n }\n /**\n *\n * @see「Optimized View Frustum Culling Algorithms for Bounding Boxes」\n * @see https://github.com/antvis/GWebGPUEngine/issues/3\n *\n * * 基础相交测试 the basic intersection test\n * * 标记 masking @see https://cesium.com/blog/2015/08/04/fast-hierarchical-culling/\n * * TODO: 平面一致性测试 the plane-coherency test\n * * TODO: 支持 mesh 指定自身的剔除策略,参考 Babylon.js @see https://doc.babylonjs.com/how_to/optimizing_your_scene#changing-mesh-culling-strategy\n *\n * @param aabb aabb\n * @param parentPlaneMask mask of parent\n * @param planes planes of frustum\n */\n\n }, {\n key: \"computeVisibilityWithPlaneMask\",\n value: function computeVisibilityWithPlaneMask(aabb, parentPlaneMask, planes) {\n if (parentPlaneMask === Mask.OUTSIDE || parentPlaneMask === Mask.INSIDE) {\n // 父节点完全位于视锥内或者外部,直接返回\n return parentPlaneMask;\n } // Start with MASK_INSIDE (all zeros) so that after the loop, the return value can be compared with MASK_INSIDE.\n // (Because if there are fewer than 31 planes, the upper bits wont be changed.)\n\n\n var mask = Mask.INSIDE;\n\n for (var k = 0, len = planes.length; k < len; ++k) {\n // For k greater than 31 (since 31 is the maximum number of INSIDE/INTERSECTING bits we can store), skip the optimization.\n var flag = k < 31 ? 1 << k : 0;\n\n if (k < 31 && (parentPlaneMask & flag) === 0) {\n // 父节点处于当前面内部,可以跳过\n continue;\n } // 使用 p-vertex 和 n-vertex 加速,避免进行平面和 aabb 全部顶点的相交检测\n\n\n var _planes$k = planes[k],\n normal = _planes$k.normal,\n distance = _planes$k.distance;\n\n if (vec3.dot(normal, aabb.getNegativeFarPoint(planes[k])) + distance > 0) {\n return Mask.OUTSIDE;\n }\n\n if (vec3.dot(normal, aabb.getPositiveFarPoint(planes[k])) + distance > 0) {\n // 和当前面相交,对应位置为1,继续检测下一个面\n mask |= flag;\n }\n }\n\n return mask;\n }\n }]);\n\n return MeshSystem;\n}(), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"mesh\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"cullable\", [_dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, \"geometry\", [_dec4], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor4 = _applyDecoratedDescriptor(_class2.prototype, \"hierarchy\", [_dec5], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor5 = _applyDecoratedDescriptor(_class2.prototype, \"transform\", [_dec6], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=System.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _dec4, _dec5, _dec6, _dec7, _dec8, _dec9, _dec10, _dec11, _class, _class2, _descriptor, _descriptor2, _descriptor3, _descriptor4, _descriptor5, _descriptor6, _descriptor7, _descriptor8, _descriptor9, _class3, _temp;\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === \"undefined\" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nimport { mat4 } from 'gl-matrix';\nimport { inject, injectable, named } from 'inversify';\nimport { IDENTIFIER } from '../../../identifier';\nimport { gl } from '../gl';\nexport var RenderPass = (_dec = injectable(), _dec2 = inject(IDENTIFIER.MeshComponentManager), _dec3 = inject(IDENTIFIER.GeometryComponentManager), _dec4 = inject(IDENTIFIER.MaterialComponentManager), _dec5 = inject(IDENTIFIER.CullableComponentManager), _dec6 = inject(IDENTIFIER.TransformComponentManager), _dec7 = inject(IDENTIFIER.HierarchyComponentManager), _dec8 = inject(IDENTIFIER.Systems), _dec9 = named(IDENTIFIER.FrameGraphSystem), _dec10 = inject(IDENTIFIER.RenderEngine), _dec11 = inject(IDENTIFIER.ResourcePool), _dec(_class = (_class2 = (_temp = _class3 = /*#__PURE__*/function () {\n function RenderPass() {\n var _this = this;\n\n _classCallCheck(this, RenderPass);\n\n _initializerDefineProperty(this, \"mesh\", _descriptor, this);\n\n _initializerDefineProperty(this, \"geometry\", _descriptor2, this);\n\n _initializerDefineProperty(this, \"material\", _descriptor3, this);\n\n _initializerDefineProperty(this, \"cullable\", _descriptor4, this);\n\n _initializerDefineProperty(this, \"transform\", _descriptor5, this);\n\n _initializerDefineProperty(this, \"hierarchy\", _descriptor6, this);\n\n _initializerDefineProperty(this, \"frameGraphSystem\", _descriptor7, this);\n\n _initializerDefineProperty(this, \"engine\", _descriptor8, this);\n\n _initializerDefineProperty(this, \"resourcePool\", _descriptor9, this);\n\n this.modelCache = {};\n\n this.setup = function (fg, passNode, pass) {\n var output = fg.createRenderTarget(passNode, 'color buffer', {\n width: 1,\n height: 1,\n usage: gl.RENDER_ATTACHMENT | gl.SAMPLED | gl.COPY_SRC\n });\n pass.data = {\n output: passNode.write(fg, output)\n };\n };\n\n this.execute = /*#__PURE__*/function () {\n var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(fg, pass, views) {\n var resourceNode, framebuffer, _iterator, _step, view, canvas;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n resourceNode = fg.getResourceNode(pass.data.output);\n framebuffer = _this.resourcePool.getOrCreateResource(resourceNode.resource); // initialize model of each mesh\n\n _iterator = _createForOfIteratorHelper(views);\n _context.prev = 3;\n\n _iterator.s();\n\n case 5:\n if ((_step = _iterator.n()).done) {\n _context.next = 11;\n break;\n }\n\n view = _step.value;\n _context.next = 9;\n return _this.initView(view);\n\n case 9:\n _context.next = 5;\n break;\n\n case 11:\n _context.next = 16;\n break;\n\n case 13:\n _context.prev = 13;\n _context.t0 = _context[\"catch\"](3);\n\n _iterator.e(_context.t0);\n\n case 16:\n _context.prev = 16;\n\n _iterator.f();\n\n return _context.finish(16);\n\n case 19:\n canvas = _this.engine.getCanvas();\n framebuffer.resize({\n width: canvas.width,\n height: canvas.height\n });\n\n _this.engine.setScissor({\n enable: false\n });\n\n _this.engine.clear({\n framebuffer: framebuffer,\n color: views[0].getClearColor(),\n // TODO: use clearColor defined in view\n depth: 1\n });\n\n _this.engine.useFramebuffer(framebuffer, function () {\n var _iterator2 = _createForOfIteratorHelper(views),\n _step2;\n\n try {\n for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n var view = _step2.value;\n\n // must do rendering in a sync way\n _this.renderView(view);\n }\n } catch (err) {\n _iterator2.e(err);\n } finally {\n _iterator2.f();\n }\n });\n\n case 24:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, null, [[3, 13, 16, 19]]);\n }));\n\n return function (_x, _x2, _x3) {\n return _ref.apply(this, arguments);\n };\n }();\n }\n\n _createClass(RenderPass, [{\n key: \"renderView\",\n value: function renderView(view) {\n var scene = view.getScene();\n var camera = view.getCamera(); // get VP matrix from camera\n\n var viewMatrix = camera.getViewTransform();\n var viewProjectionMatrix = mat4.multiply(mat4.create(), camera.getPerspective(), viewMatrix); // TODO: use cached planes if camera was not changed\n\n camera.getFrustum().extractFromVPMatrix(viewProjectionMatrix);\n\n var _view$getViewport = view.getViewport(),\n x = _view$getViewport.x,\n y = _view$getViewport.y,\n width = _view$getViewport.width,\n height = _view$getViewport.height;\n\n this.engine.viewport({\n x: x,\n y: y,\n width: width,\n height: height\n }); // this.engine.setScissor({\n // enable: true,\n // box: { x, y, width, height },\n // });\n // this.engine.clear({\n // // framebuffer,\n // color: [1, 1, 1, 1], // TODO: use clearColor defined in view\n // depth: 1,\n // });\n\n var _iterator3 = _createForOfIteratorHelper(scene.getEntities()),\n _step3;\n\n try {\n for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {\n var meshEntity = _step3.value;\n this.renderMesh(meshEntity, {\n camera: camera,\n view: view,\n viewMatrix: viewMatrix\n });\n }\n } catch (err) {\n _iterator3.e(err);\n } finally {\n _iterator3.f();\n }\n }\n }, {\n key: \"renderMesh\",\n value: function renderMesh(meshEntity, _ref2) {\n var camera = _ref2.camera,\n view = _ref2.view,\n viewMatrix = _ref2.viewMatrix;\n var mesh = this.mesh.getComponentByEntity(meshEntity);\n\n if (!mesh || !mesh.visible) {\n return;\n } // filter meshes with frustum culling\n // if (!this.cullable.getComponentByEntity(meshEntity)?.visible) {\n // return;\n // }\n\n\n var material = mesh.material;\n var geometry = mesh.geometry; // geometry 在自己的 System 中完成脏检查后的更新\n\n if (!geometry || geometry.dirty || !material) {\n return;\n } // get model matrix from mesh\n\n\n var transform = this.transform.getComponentByEntity(meshEntity);\n var modelViewMatrix = mat4.multiply(mat4.create(), viewMatrix, transform.worldTransform);\n\n var _view$getViewport2 = view.getViewport(),\n width = _view$getViewport2.width,\n height = _view$getViewport2.height; // set MVP matrix, other builtin uniforms @see https://threejs.org/docs/#api/en/renderers/webgl/WebGLProgram\n\n\n material.setUniform({\n projectionMatrix: camera.getPerspective(),\n modelViewMatrix: modelViewMatrix,\n modelMatrix: transform.worldTransform,\n viewMatrix: viewMatrix,\n cameraPosition: camera.getPosition(),\n u_viewport: [width, height]\n });\n\n if (mesh.model) {\n mesh.model.draw({\n uniforms: material.uniforms.reduce(function (cur, prev) {\n cur[prev.name] = prev.data;\n return cur;\n }, {})\n });\n material.uniforms.forEach(function (u) {\n u.dirty = false;\n });\n material.dirty = false;\n }\n }\n }, {\n key: \"initMesh\",\n value: function () {\n var _initMesh = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(meshEntity, view) {\n var mesh, material, geometry, modelCacheKey, _this$engine, createModel, createAttribute, modelInitializationOptions;\n\n return _regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n mesh = this.mesh.getComponentByEntity(meshEntity);\n\n if (mesh) {\n _context2.next = 3;\n break;\n }\n\n return _context2.abrupt(\"return\");\n\n case 3:\n material = mesh.material;\n geometry = mesh.geometry;\n\n if (!(!geometry || geometry.dirty || !material)) {\n _context2.next = 7;\n break;\n }\n\n return _context2.abrupt(\"return\");\n\n case 7:\n if (mesh.model) {\n _context2.next = 24;\n break;\n }\n\n modelCacheKey = \"m-\".concat(material.entity, \"-g-\").concat(geometry.entity);\n\n if (!this.modelCache[modelCacheKey]) {\n _context2.next = 12;\n break;\n }\n\n mesh.model = this.modelCache[modelCacheKey];\n return _context2.abrupt(\"return\");\n\n case 12:\n material.setUniform({\n projectionMatrix: 1,\n modelViewMatrix: 1,\n modelMatrix: 1,\n viewMatrix: 1,\n cameraPosition: 1,\n u_viewport: 1\n });\n _this$engine = this.engine, createModel = _this$engine.createModel, createAttribute = _this$engine.createAttribute;\n modelInitializationOptions = {\n vs: material.vertexShaderGLSL,\n fs: material.fragmentShaderGLSL,\n defines: material.defines,\n attributes: geometry.attributes.reduce(function (cur, prev) {\n if (prev.data && prev.buffer) {\n cur[prev.name] = createAttribute({\n buffer: prev.buffer,\n attributes: prev.attributes,\n arrayStride: prev.arrayStride,\n stepMode: prev.stepMode,\n divisor: prev.stepMode === 'vertex' ? 0 : 1\n });\n }\n\n return cur;\n }, {}),\n uniforms: material.uniforms.reduce(function (cur, prev) {\n cur[prev.name] = prev.data;\n return cur;\n }, {}),\n scissor: {\n enable: true,\n // @ts-ignore\n box: function box() {\n return view.getViewport();\n }\n }\n };\n\n if (material.cull) {\n modelInitializationOptions.cull = material.cull;\n }\n\n if (material.depth) {\n modelInitializationOptions.depth = material.depth;\n }\n\n if (material.blend) {\n modelInitializationOptions.blend = material.blend;\n }\n\n if (geometry.indicesBuffer) {\n modelInitializationOptions.elements = geometry.indicesBuffer;\n }\n\n if (geometry.maxInstancedCount) {\n modelInitializationOptions.instances = geometry.maxInstancedCount;\n modelInitializationOptions.count = geometry.vertexCount || 3;\n }\n\n _context2.next = 22;\n return createModel(modelInitializationOptions);\n\n case 22:\n mesh.model = _context2.sent;\n this.modelCache[modelCacheKey] = mesh.model;\n\n case 24:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this);\n }));\n\n function initMesh(_x4, _x5) {\n return _initMesh.apply(this, arguments);\n }\n\n return initMesh;\n }()\n }, {\n key: \"initView\",\n value: function () {\n var _initView = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee3(view) {\n var scene, _iterator4, _step4, meshEntity;\n\n return _regeneratorRuntime.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n scene = view.getScene();\n _iterator4 = _createForOfIteratorHelper(scene.getEntities());\n _context3.prev = 2;\n\n _iterator4.s();\n\n case 4:\n if ((_step4 = _iterator4.n()).done) {\n _context3.next = 10;\n break;\n }\n\n meshEntity = _step4.value;\n _context3.next = 8;\n return this.initMesh(meshEntity, view);\n\n case 8:\n _context3.next = 4;\n break;\n\n case 10:\n _context3.next = 15;\n break;\n\n case 12:\n _context3.prev = 12;\n _context3.t0 = _context3[\"catch\"](2);\n\n _iterator4.e(_context3.t0);\n\n case 15:\n _context3.prev = 15;\n\n _iterator4.f();\n\n return _context3.finish(15);\n\n case 18:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, this, [[2, 12, 15, 18]]);\n }));\n\n function initView(_x6) {\n return _initView.apply(this, arguments);\n }\n\n return initView;\n }()\n }]);\n\n return RenderPass;\n}(), _class3.IDENTIFIER = 'Render Pass', _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"mesh\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"geometry\", [_dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, \"material\", [_dec4], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor4 = _applyDecoratedDescriptor(_class2.prototype, \"cullable\", [_dec5], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor5 = _applyDecoratedDescriptor(_class2.prototype, \"transform\", [_dec6], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor6 = _applyDecoratedDescriptor(_class2.prototype, \"hierarchy\", [_dec7], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor7 = _applyDecoratedDescriptor(_class2.prototype, \"frameGraphSystem\", [_dec8, _dec9], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor8 = _applyDecoratedDescriptor(_class2.prototype, \"engine\", [_dec10], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor9 = _applyDecoratedDescriptor(_class2.prototype, \"resourcePool\", [_dec11], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=RenderPass.js.map","import _slicedToArray from \"@babel/runtime/helpers/slicedToArray\";\nimport { vec3 } from 'gl-matrix';\nimport { isNumber } from './is-number';\nexport function getAngle(angle) {\n if (angle === undefined) {\n return 0;\n } else if (angle > 360 || angle < -360) {\n return angle % 360;\n }\n\n return angle;\n}\nexport function createVec3(x, y, z) {\n if (isNumber(x)) {\n return vec3.fromValues(x, y, z);\n }\n\n if (x.length === 3) {\n return vec3.clone(x);\n } // @ts-ignore\n\n\n return vec3.fromValues(x[0], x[1], x[2]);\n}\nexport function getRotationScale(matrix, result) {\n result[0] = matrix[0];\n result[1] = matrix[1];\n result[2] = matrix[2];\n result[3] = matrix[4];\n result[4] = matrix[5];\n result[5] = matrix[6];\n result[6] = matrix[8];\n result[7] = matrix[9];\n result[8] = matrix[10];\n return result;\n}\nexport function decodePickingColor(color) {\n var _color = _slicedToArray(color, 3),\n i1 = _color[0],\n i2 = _color[1],\n i3 = _color[2]; // 1 was added to seperate from no selection\n\n\n var index = i1 + i2 * 256 + i3 * 65536 - 1;\n return index;\n}\nexport function encodePickingColor(featureIdx) {\n return [featureIdx + 1 & 255, featureIdx + 1 >> 8 & 255, featureIdx + 1 >> 8 >> 8 & 255];\n}\n//# sourceMappingURL=math.js.map","import * as glMatrix from \"./common.js\";\n/**\r\n * 4x4 Matrix<br>Format: column-major, when typed out it looks like row-major<br>The matrices are being post multiplied.\r\n * @module mat4\r\n */\n\n/**\r\n * Creates a new identity mat4\r\n *\r\n * @returns {mat4} a new 4x4 matrix\r\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(16);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n }\n\n out[0] = 1;\n out[5] = 1;\n out[10] = 1;\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a new mat4 initialized with values from an existing matrix\r\n *\r\n * @param {ReadonlyMat4} a matrix to clone\r\n * @returns {mat4} a new 4x4 matrix\r\n */\n\nexport function clone(a) {\n var out = new glMatrix.ARRAY_TYPE(16);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\n/**\r\n * Copy the values from one mat4 to another\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the source matrix\r\n * @returns {mat4} out\r\n */\n\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\n/**\r\n * Create a new mat4 with the given values\r\n *\r\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\r\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\r\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\r\n * @param {Number} m03 Component in column 0, row 3 position (index 3)\r\n * @param {Number} m10 Component in column 1, row 0 position (index 4)\r\n * @param {Number} m11 Component in column 1, row 1 position (index 5)\r\n * @param {Number} m12 Component in column 1, row 2 position (index 6)\r\n * @param {Number} m13 Component in column 1, row 3 position (index 7)\r\n * @param {Number} m20 Component in column 2, row 0 position (index 8)\r\n * @param {Number} m21 Component in column 2, row 1 position (index 9)\r\n * @param {Number} m22 Component in column 2, row 2 position (index 10)\r\n * @param {Number} m23 Component in column 2, row 3 position (index 11)\r\n * @param {Number} m30 Component in column 3, row 0 position (index 12)\r\n * @param {Number} m31 Component in column 3, row 1 position (index 13)\r\n * @param {Number} m32 Component in column 3, row 2 position (index 14)\r\n * @param {Number} m33 Component in column 3, row 3 position (index 15)\r\n * @returns {mat4} A new mat4\r\n */\n\nexport function fromValues(m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {\n var out = new glMatrix.ARRAY_TYPE(16);\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m03;\n out[4] = m10;\n out[5] = m11;\n out[6] = m12;\n out[7] = m13;\n out[8] = m20;\n out[9] = m21;\n out[10] = m22;\n out[11] = m23;\n out[12] = m30;\n out[13] = m31;\n out[14] = m32;\n out[15] = m33;\n return out;\n}\n/**\r\n * Set the components of a mat4 to the given values\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\r\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\r\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\r\n * @param {Number} m03 Component in column 0, row 3 position (index 3)\r\n * @param {Number} m10 Component in column 1, row 0 position (index 4)\r\n * @param {Number} m11 Component in column 1, row 1 position (index 5)\r\n * @param {Number} m12 Component in column 1, row 2 position (index 6)\r\n * @param {Number} m13 Component in column 1, row 3 position (index 7)\r\n * @param {Number} m20 Component in column 2, row 0 position (index 8)\r\n * @param {Number} m21 Component in column 2, row 1 position (index 9)\r\n * @param {Number} m22 Component in column 2, row 2 position (index 10)\r\n * @param {Number} m23 Component in column 2, row 3 position (index 11)\r\n * @param {Number} m30 Component in column 3, row 0 position (index 12)\r\n * @param {Number} m31 Component in column 3, row 1 position (index 13)\r\n * @param {Number} m32 Component in column 3, row 2 position (index 14)\r\n * @param {Number} m33 Component in column 3, row 3 position (index 15)\r\n * @returns {mat4} out\r\n */\n\nexport function set(out, m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m03;\n out[4] = m10;\n out[5] = m11;\n out[6] = m12;\n out[7] = m13;\n out[8] = m20;\n out[9] = m21;\n out[10] = m22;\n out[11] = m23;\n out[12] = m30;\n out[13] = m31;\n out[14] = m32;\n out[15] = m33;\n return out;\n}\n/**\r\n * Set a mat4 to the identity matrix\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @returns {mat4} out\r\n */\n\nexport function identity(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Transpose the values of a mat4\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the source matrix\r\n * @returns {mat4} out\r\n */\n\nexport function transpose(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache some values\n if (out === a) {\n var a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a12 = a[6],\n a13 = a[7];\n var a23 = a[11];\n out[1] = a[4];\n out[2] = a[8];\n out[3] = a[12];\n out[4] = a01;\n out[6] = a[9];\n out[7] = a[13];\n out[8] = a02;\n out[9] = a12;\n out[11] = a[14];\n out[12] = a03;\n out[13] = a13;\n out[14] = a23;\n } else {\n out[0] = a[0];\n out[1] = a[4];\n out[2] = a[8];\n out[3] = a[12];\n out[4] = a[1];\n out[5] = a[5];\n out[6] = a[9];\n out[7] = a[13];\n out[8] = a[2];\n out[9] = a[6];\n out[10] = a[10];\n out[11] = a[14];\n out[12] = a[3];\n out[13] = a[7];\n out[14] = a[11];\n out[15] = a[15];\n }\n\n return out;\n}\n/**\r\n * Inverts a mat4\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the source matrix\r\n * @returns {mat4} out\r\n */\n\nexport function invert(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32; // Calculate the determinant\n\n var det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n if (!det) {\n return null;\n }\n\n det = 1.0 / det;\n out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det;\n out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det;\n out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det;\n out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det;\n out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det;\n out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det;\n out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det;\n return out;\n}\n/**\r\n * Calculates the adjugate of a mat4\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the source matrix\r\n * @returns {mat4} out\r\n */\n\nexport function adjoint(out, a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n out[0] = a11 * (a22 * a33 - a23 * a32) - a21 * (a12 * a33 - a13 * a32) + a31 * (a12 * a23 - a13 * a22);\n out[1] = -(a01 * (a22 * a33 - a23 * a32) - a21 * (a02 * a33 - a03 * a32) + a31 * (a02 * a23 - a03 * a22));\n out[2] = a01 * (a12 * a33 - a13 * a32) - a11 * (a02 * a33 - a03 * a32) + a31 * (a02 * a13 - a03 * a12);\n out[3] = -(a01 * (a12 * a23 - a13 * a22) - a11 * (a02 * a23 - a03 * a22) + a21 * (a02 * a13 - a03 * a12));\n out[4] = -(a10 * (a22 * a33 - a23 * a32) - a20 * (a12 * a33 - a13 * a32) + a30 * (a12 * a23 - a13 * a22));\n out[5] = a00 * (a22 * a33 - a23 * a32) - a20 * (a02 * a33 - a03 * a32) + a30 * (a02 * a23 - a03 * a22);\n out[6] = -(a00 * (a12 * a33 - a13 * a32) - a10 * (a02 * a33 - a03 * a32) + a30 * (a02 * a13 - a03 * a12));\n out[7] = a00 * (a12 * a23 - a13 * a22) - a10 * (a02 * a23 - a03 * a22) + a20 * (a02 * a13 - a03 * a12);\n out[8] = a10 * (a21 * a33 - a23 * a31) - a20 * (a11 * a33 - a13 * a31) + a30 * (a11 * a23 - a13 * a21);\n out[9] = -(a00 * (a21 * a33 - a23 * a31) - a20 * (a01 * a33 - a03 * a31) + a30 * (a01 * a23 - a03 * a21));\n out[10] = a00 * (a11 * a33 - a13 * a31) - a10 * (a01 * a33 - a03 * a31) + a30 * (a01 * a13 - a03 * a11);\n out[11] = -(a00 * (a11 * a23 - a13 * a21) - a10 * (a01 * a23 - a03 * a21) + a20 * (a01 * a13 - a03 * a11));\n out[12] = -(a10 * (a21 * a32 - a22 * a31) - a20 * (a11 * a32 - a12 * a31) + a30 * (a11 * a22 - a12 * a21));\n out[13] = a00 * (a21 * a32 - a22 * a31) - a20 * (a01 * a32 - a02 * a31) + a30 * (a01 * a22 - a02 * a21);\n out[14] = -(a00 * (a11 * a32 - a12 * a31) - a10 * (a01 * a32 - a02 * a31) + a30 * (a01 * a12 - a02 * a11));\n out[15] = a00 * (a11 * a22 - a12 * a21) - a10 * (a01 * a22 - a02 * a21) + a20 * (a01 * a12 - a02 * a11);\n return out;\n}\n/**\r\n * Calculates the determinant of a mat4\r\n *\r\n * @param {ReadonlyMat4} a the source matrix\r\n * @returns {Number} determinant of a\r\n */\n\nexport function determinant(a) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15];\n var b00 = a00 * a11 - a01 * a10;\n var b01 = a00 * a12 - a02 * a10;\n var b02 = a00 * a13 - a03 * a10;\n var b03 = a01 * a12 - a02 * a11;\n var b04 = a01 * a13 - a03 * a11;\n var b05 = a02 * a13 - a03 * a12;\n var b06 = a20 * a31 - a21 * a30;\n var b07 = a20 * a32 - a22 * a30;\n var b08 = a20 * a33 - a23 * a30;\n var b09 = a21 * a32 - a22 * a31;\n var b10 = a21 * a33 - a23 * a31;\n var b11 = a22 * a33 - a23 * a32; // Calculate the determinant\n\n return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n}\n/**\r\n * Multiplies two mat4s\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the first operand\r\n * @param {ReadonlyMat4} b the second operand\r\n * @returns {mat4} out\r\n */\n\nexport function multiply(out, a, b) {\n var a00 = a[0],\n a01 = a[1],\n a02 = a[2],\n a03 = a[3];\n var a10 = a[4],\n a11 = a[5],\n a12 = a[6],\n a13 = a[7];\n var a20 = a[8],\n a21 = a[9],\n a22 = a[10],\n a23 = a[11];\n var a30 = a[12],\n a31 = a[13],\n a32 = a[14],\n a33 = a[15]; // Cache only the current line of the second matrix\n\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n out[0] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[1] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[2] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[3] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[4];\n b1 = b[5];\n b2 = b[6];\n b3 = b[7];\n out[4] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[5] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[6] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[7] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[8];\n b1 = b[9];\n b2 = b[10];\n b3 = b[11];\n out[8] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[9] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[10] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[11] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n b0 = b[12];\n b1 = b[13];\n b2 = b[14];\n b3 = b[15];\n out[12] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n out[13] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n out[14] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n out[15] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n return out;\n}\n/**\r\n * Translate a mat4 by the given vector\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to translate\r\n * @param {ReadonlyVec3} v vector to translate by\r\n * @returns {mat4} out\r\n */\n\nexport function translate(out, a, v) {\n var x = v[0],\n y = v[1],\n z = v[2];\n var a00, a01, a02, a03;\n var a10, a11, a12, a13;\n var a20, a21, a22, a23;\n\n if (a === out) {\n out[12] = a[0] * x + a[4] * y + a[8] * z + a[12];\n out[13] = a[1] * x + a[5] * y + a[9] * z + a[13];\n out[14] = a[2] * x + a[6] * y + a[10] * z + a[14];\n out[15] = a[3] * x + a[7] * y + a[11] * z + a[15];\n } else {\n a00 = a[0];\n a01 = a[1];\n a02 = a[2];\n a03 = a[3];\n a10 = a[4];\n a11 = a[5];\n a12 = a[6];\n a13 = a[7];\n a20 = a[8];\n a21 = a[9];\n a22 = a[10];\n a23 = a[11];\n out[0] = a00;\n out[1] = a01;\n out[2] = a02;\n out[3] = a03;\n out[4] = a10;\n out[5] = a11;\n out[6] = a12;\n out[7] = a13;\n out[8] = a20;\n out[9] = a21;\n out[10] = a22;\n out[11] = a23;\n out[12] = a00 * x + a10 * y + a20 * z + a[12];\n out[13] = a01 * x + a11 * y + a21 * z + a[13];\n out[14] = a02 * x + a12 * y + a22 * z + a[14];\n out[15] = a03 * x + a13 * y + a23 * z + a[15];\n }\n\n return out;\n}\n/**\r\n * Scales the mat4 by the dimensions in the given vec3 not using vectorization\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to scale\r\n * @param {ReadonlyVec3} v the vec3 to scale the matrix by\r\n * @returns {mat4} out\r\n **/\n\nexport function scale(out, a, v) {\n var x = v[0],\n y = v[1],\n z = v[2];\n out[0] = a[0] * x;\n out[1] = a[1] * x;\n out[2] = a[2] * x;\n out[3] = a[3] * x;\n out[4] = a[4] * y;\n out[5] = a[5] * y;\n out[6] = a[6] * y;\n out[7] = a[7] * y;\n out[8] = a[8] * z;\n out[9] = a[9] * z;\n out[10] = a[10] * z;\n out[11] = a[11] * z;\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n return out;\n}\n/**\r\n * Rotates a mat4 by the given angle around the given axis\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to rotate\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @param {ReadonlyVec3} axis the axis to rotate around\r\n * @returns {mat4} out\r\n */\n\nexport function rotate(out, a, rad, axis) {\n var x = axis[0],\n y = axis[1],\n z = axis[2];\n var len = Math.hypot(x, y, z);\n var s, c, t;\n var a00, a01, a02, a03;\n var a10, a11, a12, a13;\n var a20, a21, a22, a23;\n var b00, b01, b02;\n var b10, b11, b12;\n var b20, b21, b22;\n\n if (len < glMatrix.EPSILON) {\n return null;\n }\n\n len = 1 / len;\n x *= len;\n y *= len;\n z *= len;\n s = Math.sin(rad);\n c = Math.cos(rad);\n t = 1 - c;\n a00 = a[0];\n a01 = a[1];\n a02 = a[2];\n a03 = a[3];\n a10 = a[4];\n a11 = a[5];\n a12 = a[6];\n a13 = a[7];\n a20 = a[8];\n a21 = a[9];\n a22 = a[10];\n a23 = a[11]; // Construct the elements of the rotation matrix\n\n b00 = x * x * t + c;\n b01 = y * x * t + z * s;\n b02 = z * x * t - y * s;\n b10 = x * y * t - z * s;\n b11 = y * y * t + c;\n b12 = z * y * t + x * s;\n b20 = x * z * t + y * s;\n b21 = y * z * t - x * s;\n b22 = z * z * t + c; // Perform rotation-specific matrix multiplication\n\n out[0] = a00 * b00 + a10 * b01 + a20 * b02;\n out[1] = a01 * b00 + a11 * b01 + a21 * b02;\n out[2] = a02 * b00 + a12 * b01 + a22 * b02;\n out[3] = a03 * b00 + a13 * b01 + a23 * b02;\n out[4] = a00 * b10 + a10 * b11 + a20 * b12;\n out[5] = a01 * b10 + a11 * b11 + a21 * b12;\n out[6] = a02 * b10 + a12 * b11 + a22 * b12;\n out[7] = a03 * b10 + a13 * b11 + a23 * b12;\n out[8] = a00 * b20 + a10 * b21 + a20 * b22;\n out[9] = a01 * b20 + a11 * b21 + a21 * b22;\n out[10] = a02 * b20 + a12 * b21 + a22 * b22;\n out[11] = a03 * b20 + a13 * b21 + a23 * b22;\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged last row\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n }\n\n return out;\n}\n/**\r\n * Rotates a matrix by the given angle around the X axis\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to rotate\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat4} out\r\n */\n\nexport function rotateX(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a10 = a[4];\n var a11 = a[5];\n var a12 = a[6];\n var a13 = a[7];\n var a20 = a[8];\n var a21 = a[9];\n var a22 = a[10];\n var a23 = a[11];\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged rows\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n } // Perform axis-specific matrix multiplication\n\n\n out[4] = a10 * c + a20 * s;\n out[5] = a11 * c + a21 * s;\n out[6] = a12 * c + a22 * s;\n out[7] = a13 * c + a23 * s;\n out[8] = a20 * c - a10 * s;\n out[9] = a21 * c - a11 * s;\n out[10] = a22 * c - a12 * s;\n out[11] = a23 * c - a13 * s;\n return out;\n}\n/**\r\n * Rotates a matrix by the given angle around the Y axis\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to rotate\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat4} out\r\n */\n\nexport function rotateY(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a00 = a[0];\n var a01 = a[1];\n var a02 = a[2];\n var a03 = a[3];\n var a20 = a[8];\n var a21 = a[9];\n var a22 = a[10];\n var a23 = a[11];\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged rows\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n } // Perform axis-specific matrix multiplication\n\n\n out[0] = a00 * c - a20 * s;\n out[1] = a01 * c - a21 * s;\n out[2] = a02 * c - a22 * s;\n out[3] = a03 * c - a23 * s;\n out[8] = a00 * s + a20 * c;\n out[9] = a01 * s + a21 * c;\n out[10] = a02 * s + a22 * c;\n out[11] = a03 * s + a23 * c;\n return out;\n}\n/**\r\n * Rotates a matrix by the given angle around the Z axis\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to rotate\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat4} out\r\n */\n\nexport function rotateZ(out, a, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad);\n var a00 = a[0];\n var a01 = a[1];\n var a02 = a[2];\n var a03 = a[3];\n var a10 = a[4];\n var a11 = a[5];\n var a12 = a[6];\n var a13 = a[7];\n\n if (a !== out) {\n // If the source and destination differ, copy the unchanged last row\n out[8] = a[8];\n out[9] = a[9];\n out[10] = a[10];\n out[11] = a[11];\n out[12] = a[12];\n out[13] = a[13];\n out[14] = a[14];\n out[15] = a[15];\n } // Perform axis-specific matrix multiplication\n\n\n out[0] = a00 * c + a10 * s;\n out[1] = a01 * c + a11 * s;\n out[2] = a02 * c + a12 * s;\n out[3] = a03 * c + a13 * s;\n out[4] = a10 * c - a00 * s;\n out[5] = a11 * c - a01 * s;\n out[6] = a12 * c - a02 * s;\n out[7] = a13 * c - a03 * s;\n return out;\n}\n/**\r\n * Creates a matrix from a vector translation\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.translate(dest, dest, vec);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {ReadonlyVec3} v Translation vector\r\n * @returns {mat4} out\r\n */\n\nexport function fromTranslation(out, v) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from a vector scaling\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.scale(dest, dest, vec);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {ReadonlyVec3} v Scaling vector\r\n * @returns {mat4} out\r\n */\n\nexport function fromScaling(out, v) {\n out[0] = v[0];\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = v[1];\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = v[2];\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from a given angle around a given axis\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.rotate(dest, dest, rad, axis);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @param {ReadonlyVec3} axis the axis to rotate around\r\n * @returns {mat4} out\r\n */\n\nexport function fromRotation(out, rad, axis) {\n var x = axis[0],\n y = axis[1],\n z = axis[2];\n var len = Math.hypot(x, y, z);\n var s, c, t;\n\n if (len < glMatrix.EPSILON) {\n return null;\n }\n\n len = 1 / len;\n x *= len;\n y *= len;\n z *= len;\n s = Math.sin(rad);\n c = Math.cos(rad);\n t = 1 - c; // Perform rotation-specific matrix multiplication\n\n out[0] = x * x * t + c;\n out[1] = y * x * t + z * s;\n out[2] = z * x * t - y * s;\n out[3] = 0;\n out[4] = x * y * t - z * s;\n out[5] = y * y * t + c;\n out[6] = z * y * t + x * s;\n out[7] = 0;\n out[8] = x * z * t + y * s;\n out[9] = y * z * t - x * s;\n out[10] = z * z * t + c;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from the given angle around the X axis\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.rotateX(dest, dest, rad);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat4} out\r\n */\n\nexport function fromXRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad); // Perform axis-specific matrix multiplication\n\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = c;\n out[6] = s;\n out[7] = 0;\n out[8] = 0;\n out[9] = -s;\n out[10] = c;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from the given angle around the Y axis\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.rotateY(dest, dest, rad);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat4} out\r\n */\n\nexport function fromYRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad); // Perform axis-specific matrix multiplication\n\n out[0] = c;\n out[1] = 0;\n out[2] = -s;\n out[3] = 0;\n out[4] = 0;\n out[5] = 1;\n out[6] = 0;\n out[7] = 0;\n out[8] = s;\n out[9] = 0;\n out[10] = c;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from the given angle around the Z axis\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.rotateZ(dest, dest, rad);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {Number} rad the angle to rotate the matrix by\r\n * @returns {mat4} out\r\n */\n\nexport function fromZRotation(out, rad) {\n var s = Math.sin(rad);\n var c = Math.cos(rad); // Perform axis-specific matrix multiplication\n\n out[0] = c;\n out[1] = s;\n out[2] = 0;\n out[3] = 0;\n out[4] = -s;\n out[5] = c;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 1;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from a quaternion rotation and vector translation\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.translate(dest, vec);\r\n * let quatMat = mat4.create();\r\n * quat4.toMat4(quat, quatMat);\r\n * mat4.multiply(dest, quatMat);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {quat4} q Rotation quaternion\r\n * @param {ReadonlyVec3} v Translation vector\r\n * @returns {mat4} out\r\n */\n\nexport function fromRotationTranslation(out, q, v) {\n // Quaternion math\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var xy = x * y2;\n var xz = x * z2;\n var yy = y * y2;\n var yz = y * z2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n out[0] = 1 - (yy + zz);\n out[1] = xy + wz;\n out[2] = xz - wy;\n out[3] = 0;\n out[4] = xy - wz;\n out[5] = 1 - (xx + zz);\n out[6] = yz + wx;\n out[7] = 0;\n out[8] = xz + wy;\n out[9] = yz - wx;\n out[10] = 1 - (xx + yy);\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a new mat4 from a dual quat.\r\n *\r\n * @param {mat4} out Matrix\r\n * @param {ReadonlyQuat2} a Dual Quaternion\r\n * @returns {mat4} mat4 receiving operation result\r\n */\n\nexport function fromQuat2(out, a) {\n var translation = new glMatrix.ARRAY_TYPE(3);\n var bx = -a[0],\n by = -a[1],\n bz = -a[2],\n bw = a[3],\n ax = a[4],\n ay = a[5],\n az = a[6],\n aw = a[7];\n var magnitude = bx * bx + by * by + bz * bz + bw * bw; //Only scale if it makes sense\n\n if (magnitude > 0) {\n translation[0] = (ax * bw + aw * bx + ay * bz - az * by) * 2 / magnitude;\n translation[1] = (ay * bw + aw * by + az * bx - ax * bz) * 2 / magnitude;\n translation[2] = (az * bw + aw * bz + ax * by - ay * bx) * 2 / magnitude;\n } else {\n translation[0] = (ax * bw + aw * bx + ay * bz - az * by) * 2;\n translation[1] = (ay * bw + aw * by + az * bx - ax * bz) * 2;\n translation[2] = (az * bw + aw * bz + ax * by - ay * bx) * 2;\n }\n\n fromRotationTranslation(out, a, translation);\n return out;\n}\n/**\r\n * Returns the translation vector component of a transformation\r\n * matrix. If a matrix is built with fromRotationTranslation,\r\n * the returned vector will be the same as the translation vector\r\n * originally supplied.\r\n * @param {vec3} out Vector to receive translation component\r\n * @param {ReadonlyMat4} mat Matrix to be decomposed (input)\r\n * @return {vec3} out\r\n */\n\nexport function getTranslation(out, mat) {\n out[0] = mat[12];\n out[1] = mat[13];\n out[2] = mat[14];\n return out;\n}\n/**\r\n * Returns the scaling factor component of a transformation\r\n * matrix. If a matrix is built with fromRotationTranslationScale\r\n * with a normalized Quaternion paramter, the returned vector will be\r\n * the same as the scaling vector\r\n * originally supplied.\r\n * @param {vec3} out Vector to receive scaling factor component\r\n * @param {ReadonlyMat4} mat Matrix to be decomposed (input)\r\n * @return {vec3} out\r\n */\n\nexport function getScaling(out, mat) {\n var m11 = mat[0];\n var m12 = mat[1];\n var m13 = mat[2];\n var m21 = mat[4];\n var m22 = mat[5];\n var m23 = mat[6];\n var m31 = mat[8];\n var m32 = mat[9];\n var m33 = mat[10];\n out[0] = Math.hypot(m11, m12, m13);\n out[1] = Math.hypot(m21, m22, m23);\n out[2] = Math.hypot(m31, m32, m33);\n return out;\n}\n/**\r\n * Returns a quaternion representing the rotational component\r\n * of a transformation matrix. If a matrix is built with\r\n * fromRotationTranslation, the returned quaternion will be the\r\n * same as the quaternion originally supplied.\r\n * @param {quat} out Quaternion to receive the rotation component\r\n * @param {ReadonlyMat4} mat Matrix to be decomposed (input)\r\n * @return {quat} out\r\n */\n\nexport function getRotation(out, mat) {\n var scaling = new glMatrix.ARRAY_TYPE(3);\n getScaling(scaling, mat);\n var is1 = 1 / scaling[0];\n var is2 = 1 / scaling[1];\n var is3 = 1 / scaling[2];\n var sm11 = mat[0] * is1;\n var sm12 = mat[1] * is2;\n var sm13 = mat[2] * is3;\n var sm21 = mat[4] * is1;\n var sm22 = mat[5] * is2;\n var sm23 = mat[6] * is3;\n var sm31 = mat[8] * is1;\n var sm32 = mat[9] * is2;\n var sm33 = mat[10] * is3;\n var trace = sm11 + sm22 + sm33;\n var S = 0;\n\n if (trace > 0) {\n S = Math.sqrt(trace + 1.0) * 2;\n out[3] = 0.25 * S;\n out[0] = (sm23 - sm32) / S;\n out[1] = (sm31 - sm13) / S;\n out[2] = (sm12 - sm21) / S;\n } else if (sm11 > sm22 && sm11 > sm33) {\n S = Math.sqrt(1.0 + sm11 - sm22 - sm33) * 2;\n out[3] = (sm23 - sm32) / S;\n out[0] = 0.25 * S;\n out[1] = (sm12 + sm21) / S;\n out[2] = (sm31 + sm13) / S;\n } else if (sm22 > sm33) {\n S = Math.sqrt(1.0 + sm22 - sm11 - sm33) * 2;\n out[3] = (sm31 - sm13) / S;\n out[0] = (sm12 + sm21) / S;\n out[1] = 0.25 * S;\n out[2] = (sm23 + sm32) / S;\n } else {\n S = Math.sqrt(1.0 + sm33 - sm11 - sm22) * 2;\n out[3] = (sm12 - sm21) / S;\n out[0] = (sm31 + sm13) / S;\n out[1] = (sm23 + sm32) / S;\n out[2] = 0.25 * S;\n }\n\n return out;\n}\n/**\r\n * Creates a matrix from a quaternion rotation, vector translation and vector scale\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.translate(dest, vec);\r\n * let quatMat = mat4.create();\r\n * quat4.toMat4(quat, quatMat);\r\n * mat4.multiply(dest, quatMat);\r\n * mat4.scale(dest, scale)\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {quat4} q Rotation quaternion\r\n * @param {ReadonlyVec3} v Translation vector\r\n * @param {ReadonlyVec3} s Scaling vector\r\n * @returns {mat4} out\r\n */\n\nexport function fromRotationTranslationScale(out, q, v, s) {\n // Quaternion math\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var xy = x * y2;\n var xz = x * z2;\n var yy = y * y2;\n var yz = y * z2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n var sx = s[0];\n var sy = s[1];\n var sz = s[2];\n out[0] = (1 - (yy + zz)) * sx;\n out[1] = (xy + wz) * sx;\n out[2] = (xz - wy) * sx;\n out[3] = 0;\n out[4] = (xy - wz) * sy;\n out[5] = (1 - (xx + zz)) * sy;\n out[6] = (yz + wx) * sy;\n out[7] = 0;\n out[8] = (xz + wy) * sz;\n out[9] = (yz - wx) * sz;\n out[10] = (1 - (xx + yy)) * sz;\n out[11] = 0;\n out[12] = v[0];\n out[13] = v[1];\n out[14] = v[2];\n out[15] = 1;\n return out;\n}\n/**\r\n * Creates a matrix from a quaternion rotation, vector translation and vector scale, rotating and scaling around the given origin\r\n * This is equivalent to (but much faster than):\r\n *\r\n * mat4.identity(dest);\r\n * mat4.translate(dest, vec);\r\n * mat4.translate(dest, origin);\r\n * let quatMat = mat4.create();\r\n * quat4.toMat4(quat, quatMat);\r\n * mat4.multiply(dest, quatMat);\r\n * mat4.scale(dest, scale)\r\n * mat4.translate(dest, negativeOrigin);\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {quat4} q Rotation quaternion\r\n * @param {ReadonlyVec3} v Translation vector\r\n * @param {ReadonlyVec3} s Scaling vector\r\n * @param {ReadonlyVec3} o The origin vector around which to scale and rotate\r\n * @returns {mat4} out\r\n */\n\nexport function fromRotationTranslationScaleOrigin(out, q, v, s, o) {\n // Quaternion math\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var xy = x * y2;\n var xz = x * z2;\n var yy = y * y2;\n var yz = y * z2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n var sx = s[0];\n var sy = s[1];\n var sz = s[2];\n var ox = o[0];\n var oy = o[1];\n var oz = o[2];\n var out0 = (1 - (yy + zz)) * sx;\n var out1 = (xy + wz) * sx;\n var out2 = (xz - wy) * sx;\n var out4 = (xy - wz) * sy;\n var out5 = (1 - (xx + zz)) * sy;\n var out6 = (yz + wx) * sy;\n var out8 = (xz + wy) * sz;\n var out9 = (yz - wx) * sz;\n var out10 = (1 - (xx + yy)) * sz;\n out[0] = out0;\n out[1] = out1;\n out[2] = out2;\n out[3] = 0;\n out[4] = out4;\n out[5] = out5;\n out[6] = out6;\n out[7] = 0;\n out[8] = out8;\n out[9] = out9;\n out[10] = out10;\n out[11] = 0;\n out[12] = v[0] + ox - (out0 * ox + out4 * oy + out8 * oz);\n out[13] = v[1] + oy - (out1 * ox + out5 * oy + out9 * oz);\n out[14] = v[2] + oz - (out2 * ox + out6 * oy + out10 * oz);\n out[15] = 1;\n return out;\n}\n/**\r\n * Calculates a 4x4 matrix from the given quaternion\r\n *\r\n * @param {mat4} out mat4 receiving operation result\r\n * @param {ReadonlyQuat} q Quaternion to create matrix from\r\n *\r\n * @returns {mat4} out\r\n */\n\nexport function fromQuat(out, q) {\n var x = q[0],\n y = q[1],\n z = q[2],\n w = q[3];\n var x2 = x + x;\n var y2 = y + y;\n var z2 = z + z;\n var xx = x * x2;\n var yx = y * x2;\n var yy = y * y2;\n var zx = z * x2;\n var zy = z * y2;\n var zz = z * z2;\n var wx = w * x2;\n var wy = w * y2;\n var wz = w * z2;\n out[0] = 1 - yy - zz;\n out[1] = yx + wz;\n out[2] = zx - wy;\n out[3] = 0;\n out[4] = yx - wz;\n out[5] = 1 - xx - zz;\n out[6] = zy + wx;\n out[7] = 0;\n out[8] = zx + wy;\n out[9] = zy - wx;\n out[10] = 1 - xx - yy;\n out[11] = 0;\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n return out;\n}\n/**\r\n * Generates a frustum matrix with the given bounds\r\n *\r\n * @param {mat4} out mat4 frustum matrix will be written into\r\n * @param {Number} left Left bound of the frustum\r\n * @param {Number} right Right bound of the frustum\r\n * @param {Number} bottom Bottom bound of the frustum\r\n * @param {Number} top Top bound of the frustum\r\n * @param {Number} near Near bound of the frustum\r\n * @param {Number} far Far bound of the frustum\r\n * @returns {mat4} out\r\n */\n\nexport function frustum(out, left, right, bottom, top, near, far) {\n var rl = 1 / (right - left);\n var tb = 1 / (top - bottom);\n var nf = 1 / (near - far);\n out[0] = near * 2 * rl;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = near * 2 * tb;\n out[6] = 0;\n out[7] = 0;\n out[8] = (right + left) * rl;\n out[9] = (top + bottom) * tb;\n out[10] = (far + near) * nf;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[14] = far * near * 2 * nf;\n out[15] = 0;\n return out;\n}\n/**\r\n * Generates a perspective projection matrix with the given bounds.\r\n * Passing null/undefined/no value for far will generate infinite projection matrix.\r\n *\r\n * @param {mat4} out mat4 frustum matrix will be written into\r\n * @param {number} fovy Vertical field of view in radians\r\n * @param {number} aspect Aspect ratio. typically viewport width/height\r\n * @param {number} near Near bound of the frustum\r\n * @param {number} far Far bound of the frustum, can be null or Infinity\r\n * @returns {mat4} out\r\n */\n\nexport function perspective(out, fovy, aspect, near, far) {\n var f = 1.0 / Math.tan(fovy / 2),\n nf;\n out[0] = f / aspect;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = f;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[11] = -1;\n out[12] = 0;\n out[13] = 0;\n out[15] = 0;\n\n if (far != null && far !== Infinity) {\n nf = 1 / (near - far);\n out[10] = (far + near) * nf;\n out[14] = 2 * far * near * nf;\n } else {\n out[10] = -1;\n out[14] = -2 * near;\n }\n\n return out;\n}\n/**\r\n * Generates a perspective projection matrix with the given field of view.\r\n * This is primarily useful for generating projection matrices to be used\r\n * with the still experiemental WebVR API.\r\n *\r\n * @param {mat4} out mat4 frustum matrix will be written into\r\n * @param {Object} fov Object containing the following values: upDegrees, downDegrees, leftDegrees, rightDegrees\r\n * @param {number} near Near bound of the frustum\r\n * @param {number} far Far bound of the frustum\r\n * @returns {mat4} out\r\n */\n\nexport function perspectiveFromFieldOfView(out, fov, near, far) {\n var upTan = Math.tan(fov.upDegrees * Math.PI / 180.0);\n var downTan = Math.tan(fov.downDegrees * Math.PI / 180.0);\n var leftTan = Math.tan(fov.leftDegrees * Math.PI / 180.0);\n var rightTan = Math.tan(fov.rightDegrees * Math.PI / 180.0);\n var xScale = 2.0 / (leftTan + rightTan);\n var yScale = 2.0 / (upTan + downTan);\n out[0] = xScale;\n out[1] = 0.0;\n out[2] = 0.0;\n out[3] = 0.0;\n out[4] = 0.0;\n out[5] = yScale;\n out[6] = 0.0;\n out[7] = 0.0;\n out[8] = -((leftTan - rightTan) * xScale * 0.5);\n out[9] = (upTan - downTan) * yScale * 0.5;\n out[10] = far / (near - far);\n out[11] = -1.0;\n out[12] = 0.0;\n out[13] = 0.0;\n out[14] = far * near / (near - far);\n out[15] = 0.0;\n return out;\n}\n/**\r\n * Generates a orthogonal projection matrix with the given bounds\r\n *\r\n * @param {mat4} out mat4 frustum matrix will be written into\r\n * @param {number} left Left bound of the frustum\r\n * @param {number} right Right bound of the frustum\r\n * @param {number} bottom Bottom bound of the frustum\r\n * @param {number} top Top bound of the frustum\r\n * @param {number} near Near bound of the frustum\r\n * @param {number} far Far bound of the frustum\r\n * @returns {mat4} out\r\n */\n\nexport function ortho(out, left, right, bottom, top, near, far) {\n var lr = 1 / (left - right);\n var bt = 1 / (bottom - top);\n var nf = 1 / (near - far);\n out[0] = -2 * lr;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 0;\n out[5] = -2 * bt;\n out[6] = 0;\n out[7] = 0;\n out[8] = 0;\n out[9] = 0;\n out[10] = 2 * nf;\n out[11] = 0;\n out[12] = (left + right) * lr;\n out[13] = (top + bottom) * bt;\n out[14] = (far + near) * nf;\n out[15] = 1;\n return out;\n}\n/**\r\n * Generates a look-at matrix with the given eye position, focal point, and up axis.\r\n * If you want a matrix that actually makes an object look at another object, you should use targetTo instead.\r\n *\r\n * @param {mat4} out mat4 frustum matrix will be written into\r\n * @param {ReadonlyVec3} eye Position of the viewer\r\n * @param {ReadonlyVec3} center Point the viewer is looking at\r\n * @param {ReadonlyVec3} up vec3 pointing up\r\n * @returns {mat4} out\r\n */\n\nexport function lookAt(out, eye, center, up) {\n var x0, x1, x2, y0, y1, y2, z0, z1, z2, len;\n var eyex = eye[0];\n var eyey = eye[1];\n var eyez = eye[2];\n var upx = up[0];\n var upy = up[1];\n var upz = up[2];\n var centerx = center[0];\n var centery = center[1];\n var centerz = center[2];\n\n if (Math.abs(eyex - centerx) < glMatrix.EPSILON && Math.abs(eyey - centery) < glMatrix.EPSILON && Math.abs(eyez - centerz) < glMatrix.EPSILON) {\n return identity(out);\n }\n\n z0 = eyex - centerx;\n z1 = eyey - centery;\n z2 = eyez - centerz;\n len = 1 / Math.hypot(z0, z1, z2);\n z0 *= len;\n z1 *= len;\n z2 *= len;\n x0 = upy * z2 - upz * z1;\n x1 = upz * z0 - upx * z2;\n x2 = upx * z1 - upy * z0;\n len = Math.hypot(x0, x1, x2);\n\n if (!len) {\n x0 = 0;\n x1 = 0;\n x2 = 0;\n } else {\n len = 1 / len;\n x0 *= len;\n x1 *= len;\n x2 *= len;\n }\n\n y0 = z1 * x2 - z2 * x1;\n y1 = z2 * x0 - z0 * x2;\n y2 = z0 * x1 - z1 * x0;\n len = Math.hypot(y0, y1, y2);\n\n if (!len) {\n y0 = 0;\n y1 = 0;\n y2 = 0;\n } else {\n len = 1 / len;\n y0 *= len;\n y1 *= len;\n y2 *= len;\n }\n\n out[0] = x0;\n out[1] = y0;\n out[2] = z0;\n out[3] = 0;\n out[4] = x1;\n out[5] = y1;\n out[6] = z1;\n out[7] = 0;\n out[8] = x2;\n out[9] = y2;\n out[10] = z2;\n out[11] = 0;\n out[12] = -(x0 * eyex + x1 * eyey + x2 * eyez);\n out[13] = -(y0 * eyex + y1 * eyey + y2 * eyez);\n out[14] = -(z0 * eyex + z1 * eyey + z2 * eyez);\n out[15] = 1;\n return out;\n}\n/**\r\n * Generates a matrix that makes something look at something else.\r\n *\r\n * @param {mat4} out mat4 frustum matrix will be written into\r\n * @param {ReadonlyVec3} eye Position of the viewer\r\n * @param {ReadonlyVec3} center Point the viewer is looking at\r\n * @param {ReadonlyVec3} up vec3 pointing up\r\n * @returns {mat4} out\r\n */\n\nexport function targetTo(out, eye, target, up) {\n var eyex = eye[0],\n eyey = eye[1],\n eyez = eye[2],\n upx = up[0],\n upy = up[1],\n upz = up[2];\n var z0 = eyex - target[0],\n z1 = eyey - target[1],\n z2 = eyez - target[2];\n var len = z0 * z0 + z1 * z1 + z2 * z2;\n\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n z0 *= len;\n z1 *= len;\n z2 *= len;\n }\n\n var x0 = upy * z2 - upz * z1,\n x1 = upz * z0 - upx * z2,\n x2 = upx * z1 - upy * z0;\n len = x0 * x0 + x1 * x1 + x2 * x2;\n\n if (len > 0) {\n len = 1 / Math.sqrt(len);\n x0 *= len;\n x1 *= len;\n x2 *= len;\n }\n\n out[0] = x0;\n out[1] = x1;\n out[2] = x2;\n out[3] = 0;\n out[4] = z1 * x2 - z2 * x1;\n out[5] = z2 * x0 - z0 * x2;\n out[6] = z0 * x1 - z1 * x0;\n out[7] = 0;\n out[8] = z0;\n out[9] = z1;\n out[10] = z2;\n out[11] = 0;\n out[12] = eyex;\n out[13] = eyey;\n out[14] = eyez;\n out[15] = 1;\n return out;\n}\n/**\r\n * Returns a string representation of a mat4\r\n *\r\n * @param {ReadonlyMat4} a matrix to represent as a string\r\n * @returns {String} string representation of the matrix\r\n */\n\nexport function str(a) {\n return \"mat4(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \", \" + a[4] + \", \" + a[5] + \", \" + a[6] + \", \" + a[7] + \", \" + a[8] + \", \" + a[9] + \", \" + a[10] + \", \" + a[11] + \", \" + a[12] + \", \" + a[13] + \", \" + a[14] + \", \" + a[15] + \")\";\n}\n/**\r\n * Returns Frobenius norm of a mat4\r\n *\r\n * @param {ReadonlyMat4} a the matrix to calculate Frobenius norm of\r\n * @returns {Number} Frobenius norm\r\n */\n\nexport function frob(a) {\n return Math.hypot(a[0], a[1], a[2], a[3], a[4], a[5], a[6], a[7], a[8], a[9], a[10], a[11], a[12], a[13], a[14], a[15]);\n}\n/**\r\n * Adds two mat4's\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the first operand\r\n * @param {ReadonlyMat4} b the second operand\r\n * @returns {mat4} out\r\n */\n\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n out[4] = a[4] + b[4];\n out[5] = a[5] + b[5];\n out[6] = a[6] + b[6];\n out[7] = a[7] + b[7];\n out[8] = a[8] + b[8];\n out[9] = a[9] + b[9];\n out[10] = a[10] + b[10];\n out[11] = a[11] + b[11];\n out[12] = a[12] + b[12];\n out[13] = a[13] + b[13];\n out[14] = a[14] + b[14];\n out[15] = a[15] + b[15];\n return out;\n}\n/**\r\n * Subtracts matrix b from matrix a\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the first operand\r\n * @param {ReadonlyMat4} b the second operand\r\n * @returns {mat4} out\r\n */\n\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n out[4] = a[4] - b[4];\n out[5] = a[5] - b[5];\n out[6] = a[6] - b[6];\n out[7] = a[7] - b[7];\n out[8] = a[8] - b[8];\n out[9] = a[9] - b[9];\n out[10] = a[10] - b[10];\n out[11] = a[11] - b[11];\n out[12] = a[12] - b[12];\n out[13] = a[13] - b[13];\n out[14] = a[14] - b[14];\n out[15] = a[15] - b[15];\n return out;\n}\n/**\r\n * Multiply each element of the matrix by a scalar.\r\n *\r\n * @param {mat4} out the receiving matrix\r\n * @param {ReadonlyMat4} a the matrix to scale\r\n * @param {Number} b amount to scale the matrix's elements by\r\n * @returns {mat4} out\r\n */\n\nexport function multiplyScalar(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n out[4] = a[4] * b;\n out[5] = a[5] * b;\n out[6] = a[6] * b;\n out[7] = a[7] * b;\n out[8] = a[8] * b;\n out[9] = a[9] * b;\n out[10] = a[10] * b;\n out[11] = a[11] * b;\n out[12] = a[12] * b;\n out[13] = a[13] * b;\n out[14] = a[14] * b;\n out[15] = a[15] * b;\n return out;\n}\n/**\r\n * Adds two mat4's after multiplying each element of the second operand by a scalar value.\r\n *\r\n * @param {mat4} out the receiving vector\r\n * @param {ReadonlyMat4} a the first operand\r\n * @param {ReadonlyMat4} b the second operand\r\n * @param {Number} scale the amount to scale b's elements by before adding\r\n * @returns {mat4} out\r\n */\n\nexport function multiplyScalarAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n out[4] = a[4] + b[4] * scale;\n out[5] = a[5] + b[5] * scale;\n out[6] = a[6] + b[6] * scale;\n out[7] = a[7] + b[7] * scale;\n out[8] = a[8] + b[8] * scale;\n out[9] = a[9] + b[9] * scale;\n out[10] = a[10] + b[10] * scale;\n out[11] = a[11] + b[11] * scale;\n out[12] = a[12] + b[12] * scale;\n out[13] = a[13] + b[13] * scale;\n out[14] = a[14] + b[14] * scale;\n out[15] = a[15] + b[15] * scale;\n return out;\n}\n/**\r\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\r\n *\r\n * @param {ReadonlyMat4} a The first matrix.\r\n * @param {ReadonlyMat4} b The second matrix.\r\n * @returns {Boolean} True if the matrices are equal, false otherwise.\r\n */\n\nexport function exactEquals(a, b) {\n return a[0] === b[0] && a[1] === b[1] && a[2] === b[2] && a[3] === b[3] && a[4] === b[4] && a[5] === b[5] && a[6] === b[6] && a[7] === b[7] && a[8] === b[8] && a[9] === b[9] && a[10] === b[10] && a[11] === b[11] && a[12] === b[12] && a[13] === b[13] && a[14] === b[14] && a[15] === b[15];\n}\n/**\r\n * Returns whether or not the matrices have approximately the same elements in the same position.\r\n *\r\n * @param {ReadonlyMat4} a The first matrix.\r\n * @param {ReadonlyMat4} b The second matrix.\r\n * @returns {Boolean} True if the matrices are equal, false otherwise.\r\n */\n\nexport function equals(a, b) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var a4 = a[4],\n a5 = a[5],\n a6 = a[6],\n a7 = a[7];\n var a8 = a[8],\n a9 = a[9],\n a10 = a[10],\n a11 = a[11];\n var a12 = a[12],\n a13 = a[13],\n a14 = a[14],\n a15 = a[15];\n var b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3];\n var b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7];\n var b8 = b[8],\n b9 = b[9],\n b10 = b[10],\n b11 = b[11];\n var b12 = b[12],\n b13 = b[13],\n b14 = b[14],\n b15 = b[15];\n return Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) && Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) && Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) && Math.abs(a3 - b3) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3)) && Math.abs(a4 - b4) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a4), Math.abs(b4)) && Math.abs(a5 - b5) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a5), Math.abs(b5)) && Math.abs(a6 - b6) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a6), Math.abs(b6)) && Math.abs(a7 - b7) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a7), Math.abs(b7)) && Math.abs(a8 - b8) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a8), Math.abs(b8)) && Math.abs(a9 - b9) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a9), Math.abs(b9)) && Math.abs(a10 - b10) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a10), Math.abs(b10)) && Math.abs(a11 - b11) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a11), Math.abs(b11)) && Math.abs(a12 - b12) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a12), Math.abs(b12)) && Math.abs(a13 - b13) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a13), Math.abs(b13)) && Math.abs(a14 - b14) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a14), Math.abs(b14)) && Math.abs(a15 - b15) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a15), Math.abs(b15));\n}\n/**\r\n * Alias for {@link mat4.multiply}\r\n * @function\r\n */\n\nexport var mul = multiply;\n/**\r\n * Alias for {@link mat4.subtract}\r\n * @function\r\n */\n\nexport var sub = subtract;","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _dec4, _dec5, _class, _class2, _descriptor, _descriptor2, _descriptor3, _descriptor4, _class3, _temp;\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === \"undefined\" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nimport { inject, injectable } from 'inversify';\nimport { IDENTIFIER } from '../../../identifier';\nimport { decodePickingColor } from '../../../utils/math';\nimport { RenderPass } from './RenderPass';\nvar PickingStage = {\n NONE: 0.0,\n ENCODE: 1.0,\n HIGHLIGHT: 2.0\n};\n/**\n * color-based picking\n * @see https://threejsfundamentals.org/threejs/lessons/threejs-picking.html\n */\n\nexport var PixelPickingPass = (_dec = injectable(), _dec2 = inject(IDENTIFIER.RenderEngine), _dec3 = inject(IDENTIFIER.ResourcePool), _dec4 = inject(IDENTIFIER.RenderPassFactory), _dec5 = inject(IDENTIFIER.MeshComponentManager), _dec(_class = (_class2 = (_temp = _class3 = /*#__PURE__*/function () {\n function PixelPickingPass() {\n var _this = this;\n\n _classCallCheck(this, PixelPickingPass);\n\n _initializerDefineProperty(this, \"engine\", _descriptor, this);\n\n _initializerDefineProperty(this, \"resourcePool\", _descriptor2, this);\n\n _initializerDefineProperty(this, \"renderPassFactory\", _descriptor3, this);\n\n _initializerDefineProperty(this, \"mesh\", _descriptor4, this);\n\n this.pickingFBO = void 0;\n this.views = void 0;\n this.highlightEnabled = true;\n this.highlightColor = [255, 0, 0, 255];\n this.alreadyInRendering = false;\n\n this.setup = function (fg, passNode, pass) {\n var output = fg.createRenderTarget(passNode, 'picking fbo', {\n width: 1,\n height: 1\n });\n pass.data = {\n output: passNode.write(fg, output)\n }; // 防止被 FrameGraph 剔除\n\n passNode.hasSideEffect = true;\n };\n\n this.execute = /*#__PURE__*/function () {\n var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(fg, pass, views) {\n var _iterator, _step, _loop;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _this.views = views;\n\n if (!_this.alreadyInRendering) {\n _context.next = 3;\n break;\n }\n\n return _context.abrupt(\"return\");\n\n case 3:\n _iterator = _createForOfIteratorHelper(views);\n\n try {\n _loop = function _loop() {\n var view = _step.value;\n\n var _view$getViewport = view.getViewport(),\n width = _view$getViewport.width,\n height = _view$getViewport.height; // throttled\n\n\n _this.alreadyInRendering = true; // 实例化资源\n\n var resourceNode = fg.getResourceNode(pass.data.output);\n _this.pickingFBO = _this.resourcePool.getOrCreateResource(resourceNode.resource); // TODO: only draw 1x1 quad, with offset camera\n\n _this.pickingFBO.resize({\n width: width,\n height: height\n });\n\n _this.engine.useFramebuffer(_this.pickingFBO, function () {\n _this.engine.clear({\n framebuffer: _this.pickingFBO,\n color: [0, 0, 0, 0],\n stencil: 0,\n depth: 1\n }); // 渲染\n\n\n var renderPass = _this.renderPassFactory(RenderPass.IDENTIFIER); // 修改所有\n\n\n var meshes = [];\n var scene = view.getScene();\n\n var _iterator2 = _createForOfIteratorHelper(scene.getEntities()),\n _step2;\n\n try {\n for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n var meshEntity = _step2.value;\n\n var mesh = _this.mesh.getComponentByEntity(meshEntity);\n\n var material = mesh.material;\n material.setUniform('u_PickingStage', PickingStage.ENCODE);\n meshes.push(mesh);\n } // @ts-ignore\n\n } catch (err) {\n _iterator2.e(err);\n } finally {\n _iterator2.f();\n }\n\n renderPass.renderView(view);\n meshes.forEach(function (mesh) {\n var material = mesh.material;\n material.setUniform('u_PickingStage', PickingStage.HIGHLIGHT);\n });\n _this.alreadyInRendering = false;\n });\n };\n\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n _loop();\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n case 5:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }));\n\n return function (_x, _x2, _x3) {\n return _ref.apply(this, arguments);\n };\n }();\n\n this.pick = function (_ref2, view) {\n var x = _ref2.x,\n y = _ref2.y;\n var _this$engine = _this.engine,\n readPixels = _this$engine.readPixels,\n useFramebuffer = _this$engine.useFramebuffer;\n\n var _view$getViewport2 = view.getViewport(),\n width = _view$getViewport2.width,\n height = _view$getViewport2.height;\n\n var xInDevicePixel = x * window.devicePixelRatio;\n var yInDevicePixel = y * window.devicePixelRatio; // const xInDevicePixel = x;\n // const yInDevicePixel = y;\n\n if (xInDevicePixel > width || xInDevicePixel < 0 || yInDevicePixel > height || yInDevicePixel < 0) {\n return;\n }\n\n var pickedColors;\n var pickedFeatureIdx;\n useFramebuffer(_this.pickingFBO, function () {\n // avoid realloc\n pickedColors = readPixels({\n x: Math.round(xInDevicePixel),\n // 视口坐标系原点在左上,而 WebGL 在左下,需要翻转 Y 轴\n y: Math.round(height - (y + 1) * window.devicePixelRatio),\n // y: Math.round(height - (y + 1)),\n width: 1,\n height: 1,\n data: new Uint8Array(1 * 1 * 4),\n framebuffer: _this.pickingFBO\n });\n\n if (pickedColors[0] !== 0 || pickedColors[1] !== 0 || pickedColors[2] !== 0) {\n pickedFeatureIdx = decodePickingColor(pickedColors);\n\n if (_this.highlightEnabled) {\n // 高亮\n _this.highlightPickedFeature(pickedColors, view);\n }\n }\n });\n return pickedFeatureIdx;\n };\n }\n\n _createClass(PixelPickingPass, [{\n key: \"enableHighlight\",\n value: function enableHighlight(enabled) {\n this.highlightEnabled = enabled;\n }\n }, {\n key: \"setHighlightColor\",\n value: function setHighlightColor(color) {\n this.highlightColor = color;\n }\n }, {\n key: \"highlightPickedFeature\",\n\n /**\n * highlight 如果直接修改选中 feature 的 buffer,存在两个问题:\n * 1. 鼠标移走时无法恢复\n * 2. 无法实现高亮颜色与原始原色的 alpha 混合\n * 因此高亮还是放在 shader 中做比较好\n */\n value: function highlightPickedFeature(pickedColors, view) {\n if (pickedColors) {\n var _iterator3 = _createForOfIteratorHelper(view.getScene().getEntities()),\n _step3;\n\n try {\n for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {\n var meshEntity = _step3.value;\n var mesh = this.mesh.getComponentByEntity(meshEntity);\n var material = mesh.material;\n material.setUniform('u_PickingStage', PickingStage.HIGHLIGHT);\n material.setUniform('u_PickingColor', [pickedColors[0], pickedColors[1], pickedColors[2]]);\n material.setUniform('u_HighlightColor', this.highlightColor);\n }\n } catch (err) {\n _iterator3.e(err);\n } finally {\n _iterator3.f();\n }\n }\n }\n }]);\n\n return PixelPickingPass;\n}(), _class3.IDENTIFIER = 'PixelPicking Pass', _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"engine\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"resourcePool\", [_dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, \"renderPassFactory\", [_dec4], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor4 = _applyDecoratedDescriptor(_class2.prototype, \"mesh\", [_dec5], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=PixelPickingPass.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _class, _class2, _descriptor, _descriptor2, _class3, _temp;\n\nimport { inject, injectable } from 'inversify';\nimport { IDENTIFIER } from '../../../identifier';\n\n/* babel-plugin-inline-import '../../../services/shader-module/shaders/webgl.copy.frag.glsl' */\nvar copyFrag = \"varying vec2 v_UV;\\n\\nuniform sampler2D u_Texture;\\n\\nvoid main() {\\n gl_FragColor = vec4(texture2D(u_Texture, v_UV));\\n}\";\n\n/* babel-plugin-inline-import '../../../services/shader-module/shaders/webgl.copy.vert.glsl' */\nvar copyVert = \"attribute vec2 a_Position;\\n\\nvarying vec2 v_UV;\\n\\nvoid main() {\\n v_UV = 0.5 * (a_Position + 1.0);\\n gl_Position = vec4(a_Position, 0., 1.);\\n}\";\n\n/* babel-plugin-inline-import '../../../services/shader-module/shaders/webgpu.copy.frag.glsl' */\nvar copyFragWebGPU = \"layout(set = 0, binding = 0) uniform sampler u_TextureSampler;\\nlayout(set = 0, binding = 1) uniform texture2D u_Texture;\\n\\nlayout(location = 0) in vec2 v_UV;\\nlayout(location = 0) out vec4 outColor;\\n\\nvoid main() {\\n outColor = texture(sampler2D(u_Texture, u_TextureSampler), v_UV);\\n}\";\n\n/* babel-plugin-inline-import '../../../services/shader-module/shaders/webgpu.copy.vert.glsl' */\nvar copyVertWebGPU = \"layout(location = 0) in vec2 a_Position;\\nlayout(location = 0) out vec2 v_UV;\\n\\nvoid main() {\\n v_UV = 0.5 * (a_Position + 1.0);\\n gl_Position = vec4(a_Position, 0., 1.);\\n}\";\nimport { gl } from '../gl';\nimport { RenderPass } from './RenderPass';\nexport var CopyPass = (_dec = injectable(), _dec2 = inject(IDENTIFIER.RenderEngine), _dec3 = inject(IDENTIFIER.ResourcePool), _dec(_class = (_class2 = (_temp = _class3 = function CopyPass() {\n var _this = this;\n\n _classCallCheck(this, CopyPass);\n\n _initializerDefineProperty(this, \"engine\", _descriptor, this);\n\n _initializerDefineProperty(this, \"resourcePool\", _descriptor2, this);\n\n this.model = void 0;\n\n this.setup = function (fg, passNode, pass) {\n var renderPass = fg.getPass(RenderPass.IDENTIFIER);\n\n if (renderPass) {\n var output = fg.createRenderTarget(passNode, 'render to screen', {\n width: 1,\n height: 1\n });\n pass.data = {\n input: passNode.read(renderPass.data.output),\n output: passNode.write(fg, output)\n };\n }\n };\n\n this.execute = /*#__PURE__*/function () {\n var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(fg, pass) {\n var _this$engine, createModel, createAttribute, createBuffer, model, resourceNode, framebuffer;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _this$engine = _this.engine, createModel = _this$engine.createModel, createAttribute = _this$engine.createAttribute, createBuffer = _this$engine.createBuffer;\n\n if (_this.model) {\n _context.next = 6;\n break;\n }\n\n _context.next = 4;\n return createModel({\n vs: _this.engine.supportWebGPU ? copyVertWebGPU : copyVert,\n fs: _this.engine.supportWebGPU ? copyFragWebGPU : copyFrag,\n attributes: {\n // rendering a fullscreen triangle instead of quad\n // @see https://www.saschawillems.de/blog/2016/08/13/vulkan-tutorial-on-rendering-a-fullscreen-quad-without-buffers/\n a_Position: createAttribute({\n buffer: createBuffer({\n data: [-4, -4, 4, -4, 0, 4],\n type: gl.FLOAT\n }),\n size: 2,\n arrayStride: 2 * 4,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 0,\n offset: 0,\n format: 'float2'\n }]\n })\n },\n uniforms: {\n // @ts-ignore\n u_Texture: null\n },\n depth: {\n enable: false\n },\n count: 3,\n blend: {\n // copy pass 需要混合\n // enable: this.getName() === 'copy',\n enable: true\n }\n });\n\n case 4:\n model = _context.sent;\n _this.model = model;\n\n case 6:\n // 实例化资源\n resourceNode = fg.getResourceNode(pass.data.input);\n framebuffer = _this.resourcePool.getOrCreateResource(resourceNode.resource);\n\n _this.engine.useFramebuffer(null, function () {\n _this.engine.clear({\n framebuffer: null,\n color: [0, 0, 0, 0],\n depth: 1,\n stencil: 0\n });\n\n _this.model.draw({\n uniforms: {\n u_Texture: framebuffer // u_ViewportSize: [width, height],\n\n }\n });\n });\n\n case 9:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }));\n\n return function (_x, _x2) {\n return _ref.apply(this, arguments);\n };\n }();\n\n this.tearDown = function () {\n _this.model = undefined;\n };\n}, _class3.IDENTIFIER = 'Copy Pass', _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"engine\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"resourcePool\", [_dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=CopyPass.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _dec4, _dec5, _dec6, _class, _class2, _descriptor, _descriptor2, _descriptor3, _descriptor4, _temp;\n\nimport { inject, injectable, named } from 'inversify';\nimport { IDENTIFIER } from '../../identifier';\nimport { CopyPass } from './passes/CopyPass';\nimport { PixelPickingPass } from './passes/PixelPickingPass';\nimport { RenderPass } from './passes/RenderPass';\nexport var RendererSystem = (_dec = injectable(), _dec2 = inject(IDENTIFIER.Systems), _dec3 = named(IDENTIFIER.FrameGraphSystem), _dec4 = inject(IDENTIFIER.RenderPassFactory), _dec5 = inject(IDENTIFIER.ConfigService), _dec6 = inject(IDENTIFIER.ResourcePool), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function () {\n function RendererSystem() {\n _classCallCheck(this, RendererSystem);\n\n _initializerDefineProperty(this, \"frameGraphSystem\", _descriptor, this);\n\n _initializerDefineProperty(this, \"renderPassFactory\", _descriptor2, this);\n\n _initializerDefineProperty(this, \"configService\", _descriptor3, this);\n\n _initializerDefineProperty(this, \"resourcePool\", _descriptor4, this);\n }\n\n _createClass(RendererSystem, [{\n key: \"execute\",\n value: function () {\n var _execute = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(views) {\n var _this$renderPassFacto, setupRenderPass, executeRenderPass, renderPass, _this$renderPassFacto2, setupCopyPass, executeCopyPass, tearDownCopyPass, copyPass;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n // const pixelPickingPass = this.renderPassFactory<PixelPickingPassData>(\n // PixelPickingPass.IDENTIFIER,\n // );\n // const {\n // setup: setupPixelPickingPass,\n // execute: executePixelPickingPass,\n // tearDown: tearDownPickingPass,\n // } = pixelPickingPass;\n // this.frameGraphSystem.addPass<PixelPickingPassData>(\n // PixelPickingPass.IDENTIFIER,\n // setupPixelPickingPass,\n // executePixelPickingPass,\n // tearDownPickingPass,\n // );\n _this$renderPassFacto = this.renderPassFactory(RenderPass.IDENTIFIER), setupRenderPass = _this$renderPassFacto.setup, executeRenderPass = _this$renderPassFacto.execute;\n renderPass = this.frameGraphSystem.addPass(RenderPass.IDENTIFIER, setupRenderPass, executeRenderPass);\n _this$renderPassFacto2 = this.renderPassFactory(CopyPass.IDENTIFIER), setupCopyPass = _this$renderPassFacto2.setup, executeCopyPass = _this$renderPassFacto2.execute, tearDownCopyPass = _this$renderPassFacto2.tearDown;\n copyPass = this.frameGraphSystem.addPass(CopyPass.IDENTIFIER, setupCopyPass, executeCopyPass, tearDownCopyPass);\n this.frameGraphSystem.present(copyPass.data.output); // this.frameGraphSystem.present(renderPass.data.output);\n\n case 5:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function execute(_x) {\n return _execute.apply(this, arguments);\n }\n\n return execute;\n }()\n }, {\n key: \"tearDown\",\n value: function tearDown() {\n this.resourcePool.clean();\n }\n }, {\n key: \"pick\",\n value: function pick(position, view) {\n var pickingPass = this.renderPassFactory(PixelPickingPass.IDENTIFIER);\n return pickingPass.pick(position, view);\n }\n }]);\n\n return RendererSystem;\n}(), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"frameGraphSystem\", [_dec2, _dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"renderPassFactory\", [_dec4], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, \"configService\", [_dec5], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor4 = _applyDecoratedDescriptor(_class2.prototype, \"resourcePool\", [_dec6], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=System.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { Component } from '../..';\nexport var HierarchyComponent = /*#__PURE__*/function (_Component) {\n _inherits(HierarchyComponent, _Component);\n\n var _super = _createSuper(HierarchyComponent);\n\n function HierarchyComponent(data) {\n var _this;\n\n _classCallCheck(this, HierarchyComponent);\n\n _this = _super.call(this, data);\n _this.parentID = void 0;\n Object.assign(_assertThisInitialized(_this), data);\n return _this;\n }\n\n return HierarchyComponent;\n}(Component);\n//# sourceMappingURL=HierarchyComponent.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _dec4, _class, _class2, _descriptor, _descriptor2, _descriptor3, _temp;\n\nimport { mat4 } from 'gl-matrix';\nimport { inject, injectable } from 'inversify';\nimport { IDENTIFIER } from '../../identifier';\nexport var SceneGraphSystem = (_dec = injectable(), _dec2 = inject(IDENTIFIER.HierarchyComponentManager), _dec3 = inject(IDENTIFIER.TransformComponentManager), _dec4 = inject(IDENTIFIER.MeshComponentManager), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function () {\n function SceneGraphSystem() {\n _classCallCheck(this, SceneGraphSystem);\n\n _initializerDefineProperty(this, \"hierarchy\", _descriptor, this);\n\n _initializerDefineProperty(this, \"transform\", _descriptor2, this);\n\n _initializerDefineProperty(this, \"mesh\", _descriptor3, this);\n }\n\n _createClass(SceneGraphSystem, [{\n key: \"execute\",\n value: function () {\n var _execute = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n this.runTransformUpdateSystem();\n this.runHierarchyUpdateSystem();\n\n case 2:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function execute() {\n return _execute.apply(this, arguments);\n }\n\n return execute;\n }()\n }, {\n key: \"tearDown\",\n value: function tearDown() {\n this.hierarchy.clear();\n this.transform.clear();\n }\n }, {\n key: \"getHierarchyComponentManager\",\n value: function getHierarchyComponentManager() {\n return this.hierarchy;\n }\n }, {\n key: \"getTransformComponentManager\",\n value: function getTransformComponentManager() {\n return this.transform;\n }\n }, {\n key: \"runTransformUpdateSystem\",\n value: function runTransformUpdateSystem() {\n var _this = this;\n\n // 原版基于 JobSystem 实现\n this.transform.forEach(function (entity, transform) {\n if (transform.isDirty() || transform.isLocalDirty()) {\n _this.setMeshAABBDirty(_this.mesh.getComponentByEntity(entity));\n\n transform.updateTransform();\n }\n });\n }\n }, {\n key: \"runHierarchyUpdateSystem\",\n value: function runHierarchyUpdateSystem() {\n var _this2 = this;\n\n this.hierarchy.forEach(function (entity, parentComponent) {\n var transformChild = _this2.transform.getComponentByEntity(entity);\n\n var transformParent = _this2.transform.getComponentByEntity(parentComponent.parentID);\n\n if (transformChild !== null && transformParent !== null) {\n transformChild.updateTransformWithParent(transformParent);\n }\n });\n }\n }, {\n key: \"attach\",\n value: function attach(entity, parent, isChildAlreadyInLocalSpace) {\n if (this.hierarchy.contains(entity)) {\n this.detach(entity);\n }\n\n this.hierarchy.create(entity, {\n parentID: parent\n });\n var mesh = this.mesh.getComponentByEntity(parent); // inform parent mesh to update its aabb\n\n this.setMeshAABBDirty(mesh);\n\n if (mesh && mesh.children.indexOf(entity) === -1) {\n mesh.children.push(entity);\n }\n\n if (this.hierarchy.getCount() > 1) {\n for (var i = this.hierarchy.getCount() - 1; i > 0; --i) {\n var parentCandidateEntity = this.hierarchy.getEntity(i); // const parentCandidateComponent = this.hierarchy.getComponent(i);\n\n for (var j = 0; j < i; ++j) {\n var childCandidateEntity = this.hierarchy.getComponent(j);\n\n if (childCandidateEntity.parentID === parentCandidateEntity) {\n this.hierarchy.moveItem(i, j);\n ++i; // next outer iteration will check the same index again as parent candidate, however things were moved upwards, so it will be a different entity!\n\n break;\n }\n }\n }\n } // Re-query parent after potential MoveItem(), because it invalidates references:\n\n\n var parentcomponent = this.hierarchy.getComponentByEntity(entity);\n var transformParent = this.transform.getComponentByEntity(parent);\n\n if (transformParent === null) {\n transformParent = this.transform.create(parent);\n }\n\n var transformChild = this.transform.getComponentByEntity(entity);\n\n if (transformChild === null) {\n transformChild = this.transform.create(entity); // after transforms.Create(), transform_parent pointer could have become invalidated!\n\n transformParent = this.transform.getComponentByEntity(parent);\n }\n\n transformChild.parent = transformParent;\n\n if (!isChildAlreadyInLocalSpace && transformParent) {\n transformChild.matrixTransform(mat4.invert(mat4.create(), transformParent.worldTransform));\n transformChild.updateTransform();\n }\n\n if (transformParent) {\n transformChild.updateTransformWithParent(transformParent);\n }\n }\n }, {\n key: \"detach\",\n value: function detach(entity) {\n var self = this.hierarchy.getComponentByEntity(entity);\n\n if (self !== null) {\n var transform = this.transform.getComponentByEntity(entity);\n\n if (transform !== null) {\n transform.parent = null;\n transform.applyTransform();\n }\n\n this.hierarchy.removeKeepSorted(entity); // inform parent mesh to update its aabb\n\n var mesh = this.mesh.getComponentByEntity(self.parentID);\n\n if (mesh) {\n var index = mesh.children.indexOf(entity);\n mesh.children.splice(index, 1);\n }\n\n this.setMeshAABBDirty(mesh);\n }\n }\n }, {\n key: \"detachChildren\",\n value: function detachChildren(parent) {\n var mesh = this.mesh.getComponentByEntity(parent);\n\n if (mesh) {\n mesh.children = [];\n }\n\n for (var i = 0; i < this.hierarchy.getCount();) {\n var _this$hierarchy$getCo;\n\n if (((_this$hierarchy$getCo = this.hierarchy.getComponent(i)) === null || _this$hierarchy$getCo === void 0 ? void 0 : _this$hierarchy$getCo.parentID) === parent) {\n var entity = this.hierarchy.getEntity(i);\n this.detach(entity);\n } else {\n ++i;\n }\n }\n }\n }, {\n key: \"setMeshAABBDirty\",\n value: function setMeshAABBDirty(mesh) {\n if (mesh) {\n mesh.aabbDirty = true;\n }\n }\n }]);\n\n return SceneGraphSystem;\n}(), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"hierarchy\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"transform\", [_dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, \"mesh\", [_dec4], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=System.js.map","import * as glMatrix from \"./common.js\";\nimport * as mat3 from \"./mat3.js\";\nimport * as vec3 from \"./vec3.js\";\nimport * as vec4 from \"./vec4.js\";\n/**\r\n * Quaternion\r\n * @module quat\r\n */\n\n/**\r\n * Creates a new identity quat\r\n *\r\n * @returns {quat} a new quaternion\r\n */\n\nexport function create() {\n var out = new glMatrix.ARRAY_TYPE(4);\n\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n }\n\n out[3] = 1;\n return out;\n}\n/**\r\n * Set a quat to the identity quaternion\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @returns {quat} out\r\n */\n\nexport function identity(out) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n return out;\n}\n/**\r\n * Sets a quat from the given angle and rotation axis,\r\n * then returns it.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyVec3} axis the axis around which to rotate\r\n * @param {Number} rad the angle in radians\r\n * @returns {quat} out\r\n **/\n\nexport function setAxisAngle(out, axis, rad) {\n rad = rad * 0.5;\n var s = Math.sin(rad);\n out[0] = s * axis[0];\n out[1] = s * axis[1];\n out[2] = s * axis[2];\n out[3] = Math.cos(rad);\n return out;\n}\n/**\r\n * Gets the rotation axis and angle for a given\r\n * quaternion. If a quaternion is created with\r\n * setAxisAngle, this method will return the same\r\n * values as providied in the original parameter list\r\n * OR functionally equivalent values.\r\n * Example: The quaternion formed by axis [0, 0, 1] and\r\n * angle -90 is the same as the quaternion formed by\r\n * [0, 0, 1] and 270. This method favors the latter.\r\n * @param {vec3} out_axis Vector receiving the axis of rotation\r\n * @param {ReadonlyQuat} q Quaternion to be decomposed\r\n * @return {Number} Angle, in radians, of the rotation\r\n */\n\nexport function getAxisAngle(out_axis, q) {\n var rad = Math.acos(q[3]) * 2.0;\n var s = Math.sin(rad / 2.0);\n\n if (s > glMatrix.EPSILON) {\n out_axis[0] = q[0] / s;\n out_axis[1] = q[1] / s;\n out_axis[2] = q[2] / s;\n } else {\n // If s is zero, return any axis (no rotation - axis does not matter)\n out_axis[0] = 1;\n out_axis[1] = 0;\n out_axis[2] = 0;\n }\n\n return rad;\n}\n/**\r\n * Gets the angular distance between two unit quaternions\r\n *\r\n * @param {ReadonlyQuat} a Origin unit quaternion\r\n * @param {ReadonlyQuat} b Destination unit quaternion\r\n * @return {Number} Angle, in radians, between the two quaternions\r\n */\n\nexport function getAngle(a, b) {\n var dotproduct = dot(a, b);\n return Math.acos(2 * dotproduct * dotproduct - 1);\n}\n/**\r\n * Multiplies two quat's\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a the first operand\r\n * @param {ReadonlyQuat} b the second operand\r\n * @returns {quat} out\r\n */\n\nexport function multiply(out, a, b) {\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var bx = b[0],\n by = b[1],\n bz = b[2],\n bw = b[3];\n out[0] = ax * bw + aw * bx + ay * bz - az * by;\n out[1] = ay * bw + aw * by + az * bx - ax * bz;\n out[2] = az * bw + aw * bz + ax * by - ay * bx;\n out[3] = aw * bw - ax * bx - ay * by - az * bz;\n return out;\n}\n/**\r\n * Rotates a quaternion by the given angle about the X axis\r\n *\r\n * @param {quat} out quat receiving operation result\r\n * @param {ReadonlyQuat} a quat to rotate\r\n * @param {number} rad angle (in radians) to rotate\r\n * @returns {quat} out\r\n */\n\nexport function rotateX(out, a, rad) {\n rad *= 0.5;\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var bx = Math.sin(rad),\n bw = Math.cos(rad);\n out[0] = ax * bw + aw * bx;\n out[1] = ay * bw + az * bx;\n out[2] = az * bw - ay * bx;\n out[3] = aw * bw - ax * bx;\n return out;\n}\n/**\r\n * Rotates a quaternion by the given angle about the Y axis\r\n *\r\n * @param {quat} out quat receiving operation result\r\n * @param {ReadonlyQuat} a quat to rotate\r\n * @param {number} rad angle (in radians) to rotate\r\n * @returns {quat} out\r\n */\n\nexport function rotateY(out, a, rad) {\n rad *= 0.5;\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var by = Math.sin(rad),\n bw = Math.cos(rad);\n out[0] = ax * bw - az * by;\n out[1] = ay * bw + aw * by;\n out[2] = az * bw + ax * by;\n out[3] = aw * bw - ay * by;\n return out;\n}\n/**\r\n * Rotates a quaternion by the given angle about the Z axis\r\n *\r\n * @param {quat} out quat receiving operation result\r\n * @param {ReadonlyQuat} a quat to rotate\r\n * @param {number} rad angle (in radians) to rotate\r\n * @returns {quat} out\r\n */\n\nexport function rotateZ(out, a, rad) {\n rad *= 0.5;\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var bz = Math.sin(rad),\n bw = Math.cos(rad);\n out[0] = ax * bw + ay * bz;\n out[1] = ay * bw - ax * bz;\n out[2] = az * bw + aw * bz;\n out[3] = aw * bw - az * bz;\n return out;\n}\n/**\r\n * Calculates the W component of a quat from the X, Y, and Z components.\r\n * Assumes that quaternion is 1 unit in length.\r\n * Any existing W component will be ignored.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quat to calculate W component of\r\n * @returns {quat} out\r\n */\n\nexport function calculateW(out, a) {\n var x = a[0],\n y = a[1],\n z = a[2];\n out[0] = x;\n out[1] = y;\n out[2] = z;\n out[3] = Math.sqrt(Math.abs(1.0 - x * x - y * y - z * z));\n return out;\n}\n/**\r\n * Calculate the exponential of a unit quaternion.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quat to calculate the exponential of\r\n * @returns {quat} out\r\n */\n\nexport function exp(out, a) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3];\n var r = Math.sqrt(x * x + y * y + z * z);\n var et = Math.exp(w);\n var s = r > 0 ? et * Math.sin(r) / r : 0;\n out[0] = x * s;\n out[1] = y * s;\n out[2] = z * s;\n out[3] = et * Math.cos(r);\n return out;\n}\n/**\r\n * Calculate the natural logarithm of a unit quaternion.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quat to calculate the exponential of\r\n * @returns {quat} out\r\n */\n\nexport function ln(out, a) {\n var x = a[0],\n y = a[1],\n z = a[2],\n w = a[3];\n var r = Math.sqrt(x * x + y * y + z * z);\n var t = r > 0 ? Math.atan2(r, w) / r : 0;\n out[0] = x * t;\n out[1] = y * t;\n out[2] = z * t;\n out[3] = 0.5 * Math.log(x * x + y * y + z * z + w * w);\n return out;\n}\n/**\r\n * Calculate the scalar power of a unit quaternion.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quat to calculate the exponential of\r\n * @param {Number} b amount to scale the quaternion by\r\n * @returns {quat} out\r\n */\n\nexport function pow(out, a, b) {\n ln(out, a);\n scale(out, out, b);\n exp(out, out);\n return out;\n}\n/**\r\n * Performs a spherical linear interpolation between two quat\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a the first operand\r\n * @param {ReadonlyQuat} b the second operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {quat} out\r\n */\n\nexport function slerp(out, a, b, t) {\n // benchmarks:\n // http://jsperf.com/quaternion-slerp-implementations\n var ax = a[0],\n ay = a[1],\n az = a[2],\n aw = a[3];\n var bx = b[0],\n by = b[1],\n bz = b[2],\n bw = b[3];\n var omega, cosom, sinom, scale0, scale1; // calc cosine\n\n cosom = ax * bx + ay * by + az * bz + aw * bw; // adjust signs (if necessary)\n\n if (cosom < 0.0) {\n cosom = -cosom;\n bx = -bx;\n by = -by;\n bz = -bz;\n bw = -bw;\n } // calculate coefficients\n\n\n if (1.0 - cosom > glMatrix.EPSILON) {\n // standard case (slerp)\n omega = Math.acos(cosom);\n sinom = Math.sin(omega);\n scale0 = Math.sin((1.0 - t) * omega) / sinom;\n scale1 = Math.sin(t * omega) / sinom;\n } else {\n // \"from\" and \"to\" quaternions are very close\n // ... so we can do a linear interpolation\n scale0 = 1.0 - t;\n scale1 = t;\n } // calculate final values\n\n\n out[0] = scale0 * ax + scale1 * bx;\n out[1] = scale0 * ay + scale1 * by;\n out[2] = scale0 * az + scale1 * bz;\n out[3] = scale0 * aw + scale1 * bw;\n return out;\n}\n/**\r\n * Generates a random unit quaternion\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @returns {quat} out\r\n */\n\nexport function random(out) {\n // Implementation of http://planning.cs.uiuc.edu/node198.html\n // TODO: Calling random 3 times is probably not the fastest solution\n var u1 = glMatrix.RANDOM();\n var u2 = glMatrix.RANDOM();\n var u3 = glMatrix.RANDOM();\n var sqrt1MinusU1 = Math.sqrt(1 - u1);\n var sqrtU1 = Math.sqrt(u1);\n out[0] = sqrt1MinusU1 * Math.sin(2.0 * Math.PI * u2);\n out[1] = sqrt1MinusU1 * Math.cos(2.0 * Math.PI * u2);\n out[2] = sqrtU1 * Math.sin(2.0 * Math.PI * u3);\n out[3] = sqrtU1 * Math.cos(2.0 * Math.PI * u3);\n return out;\n}\n/**\r\n * Calculates the inverse of a quat\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quat to calculate inverse of\r\n * @returns {quat} out\r\n */\n\nexport function invert(out, a) {\n var a0 = a[0],\n a1 = a[1],\n a2 = a[2],\n a3 = a[3];\n var dot = a0 * a0 + a1 * a1 + a2 * a2 + a3 * a3;\n var invDot = dot ? 1.0 / dot : 0; // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0\n\n out[0] = -a0 * invDot;\n out[1] = -a1 * invDot;\n out[2] = -a2 * invDot;\n out[3] = a3 * invDot;\n return out;\n}\n/**\r\n * Calculates the conjugate of a quat\r\n * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quat to calculate conjugate of\r\n * @returns {quat} out\r\n */\n\nexport function conjugate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n out[3] = a[3];\n return out;\n}\n/**\r\n * Creates a quaternion from the given 3x3 rotation matrix.\r\n *\r\n * NOTE: The resultant quaternion is not normalized, so you should be sure\r\n * to renormalize the quaternion yourself where necessary.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyMat3} m rotation matrix\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport function fromMat3(out, m) {\n // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes\n // article \"Quaternion Calculus and Fast Animation\".\n var fTrace = m[0] + m[4] + m[8];\n var fRoot;\n\n if (fTrace > 0.0) {\n // |w| > 1/2, may as well choose w > 1/2\n fRoot = Math.sqrt(fTrace + 1.0); // 2w\n\n out[3] = 0.5 * fRoot;\n fRoot = 0.5 / fRoot; // 1/(4w)\n\n out[0] = (m[5] - m[7]) * fRoot;\n out[1] = (m[6] - m[2]) * fRoot;\n out[2] = (m[1] - m[3]) * fRoot;\n } else {\n // |w| <= 1/2\n var i = 0;\n if (m[4] > m[0]) i = 1;\n if (m[8] > m[i * 3 + i]) i = 2;\n var j = (i + 1) % 3;\n var k = (i + 2) % 3;\n fRoot = Math.sqrt(m[i * 3 + i] - m[j * 3 + j] - m[k * 3 + k] + 1.0);\n out[i] = 0.5 * fRoot;\n fRoot = 0.5 / fRoot;\n out[3] = (m[j * 3 + k] - m[k * 3 + j]) * fRoot;\n out[j] = (m[j * 3 + i] + m[i * 3 + j]) * fRoot;\n out[k] = (m[k * 3 + i] + m[i * 3 + k]) * fRoot;\n }\n\n return out;\n}\n/**\r\n * Creates a quaternion from the given euler angle x, y, z.\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {x} Angle to rotate around X axis in degrees.\r\n * @param {y} Angle to rotate around Y axis in degrees.\r\n * @param {z} Angle to rotate around Z axis in degrees.\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport function fromEuler(out, x, y, z) {\n var halfToRad = 0.5 * Math.PI / 180.0;\n x *= halfToRad;\n y *= halfToRad;\n z *= halfToRad;\n var sx = Math.sin(x);\n var cx = Math.cos(x);\n var sy = Math.sin(y);\n var cy = Math.cos(y);\n var sz = Math.sin(z);\n var cz = Math.cos(z);\n out[0] = sx * cy * cz - cx * sy * sz;\n out[1] = cx * sy * cz + sx * cy * sz;\n out[2] = cx * cy * sz - sx * sy * cz;\n out[3] = cx * cy * cz + sx * sy * sz;\n return out;\n}\n/**\r\n * Returns a string representation of a quatenion\r\n *\r\n * @param {ReadonlyQuat} a vector to represent as a string\r\n * @returns {String} string representation of the vector\r\n */\n\nexport function str(a) {\n return \"quat(\" + a[0] + \", \" + a[1] + \", \" + a[2] + \", \" + a[3] + \")\";\n}\n/**\r\n * Creates a new quat initialized with values from an existing quaternion\r\n *\r\n * @param {ReadonlyQuat} a quaternion to clone\r\n * @returns {quat} a new quaternion\r\n * @function\r\n */\n\nexport var clone = vec4.clone;\n/**\r\n * Creates a new quat initialized with the given values\r\n *\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @param {Number} z Z component\r\n * @param {Number} w W component\r\n * @returns {quat} a new quaternion\r\n * @function\r\n */\n\nexport var fromValues = vec4.fromValues;\n/**\r\n * Copy the values from one quat to another\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a the source quaternion\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport var copy = vec4.copy;\n/**\r\n * Set the components of a quat to the given values\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {Number} x X component\r\n * @param {Number} y Y component\r\n * @param {Number} z Z component\r\n * @param {Number} w W component\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport var set = vec4.set;\n/**\r\n * Adds two quat's\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a the first operand\r\n * @param {ReadonlyQuat} b the second operand\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport var add = vec4.add;\n/**\r\n * Alias for {@link quat.multiply}\r\n * @function\r\n */\n\nexport var mul = multiply;\n/**\r\n * Scales a quat by a scalar number\r\n *\r\n * @param {quat} out the receiving vector\r\n * @param {ReadonlyQuat} a the vector to scale\r\n * @param {Number} b amount to scale the vector by\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport var scale = vec4.scale;\n/**\r\n * Calculates the dot product of two quat's\r\n *\r\n * @param {ReadonlyQuat} a the first operand\r\n * @param {ReadonlyQuat} b the second operand\r\n * @returns {Number} dot product of a and b\r\n * @function\r\n */\n\nexport var dot = vec4.dot;\n/**\r\n * Performs a linear interpolation between two quat's\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a the first operand\r\n * @param {ReadonlyQuat} b the second operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport var lerp = vec4.lerp;\n/**\r\n * Calculates the length of a quat\r\n *\r\n * @param {ReadonlyQuat} a vector to calculate length of\r\n * @returns {Number} length of a\r\n */\n\nexport var length = vec4.length;\n/**\r\n * Alias for {@link quat.length}\r\n * @function\r\n */\n\nexport var len = length;\n/**\r\n * Calculates the squared length of a quat\r\n *\r\n * @param {ReadonlyQuat} a vector to calculate squared length of\r\n * @returns {Number} squared length of a\r\n * @function\r\n */\n\nexport var squaredLength = vec4.squaredLength;\n/**\r\n * Alias for {@link quat.squaredLength}\r\n * @function\r\n */\n\nexport var sqrLen = squaredLength;\n/**\r\n * Normalize a quat\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a quaternion to normalize\r\n * @returns {quat} out\r\n * @function\r\n */\n\nexport var normalize = vec4.normalize;\n/**\r\n * Returns whether or not the quaternions have exactly the same elements in the same position (when compared with ===)\r\n *\r\n * @param {ReadonlyQuat} a The first quaternion.\r\n * @param {ReadonlyQuat} b The second quaternion.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport var exactEquals = vec4.exactEquals;\n/**\r\n * Returns whether or not the quaternions have approximately the same elements in the same position.\r\n *\r\n * @param {ReadonlyQuat} a The first vector.\r\n * @param {ReadonlyQuat} b The second vector.\r\n * @returns {Boolean} True if the vectors are equal, false otherwise.\r\n */\n\nexport var equals = vec4.equals;\n/**\r\n * Sets a quaternion to represent the shortest rotation from one\r\n * vector to another.\r\n *\r\n * Both vectors are assumed to be unit length.\r\n *\r\n * @param {quat} out the receiving quaternion.\r\n * @param {ReadonlyVec3} a the initial vector\r\n * @param {ReadonlyVec3} b the destination vector\r\n * @returns {quat} out\r\n */\n\nexport var rotationTo = function () {\n var tmpvec3 = vec3.create();\n var xUnitVec3 = vec3.fromValues(1, 0, 0);\n var yUnitVec3 = vec3.fromValues(0, 1, 0);\n return function (out, a, b) {\n var dot = vec3.dot(a, b);\n\n if (dot < -0.999999) {\n vec3.cross(tmpvec3, xUnitVec3, a);\n if (vec3.len(tmpvec3) < 0.000001) vec3.cross(tmpvec3, yUnitVec3, a);\n vec3.normalize(tmpvec3, tmpvec3);\n setAxisAngle(out, tmpvec3, Math.PI);\n return out;\n } else if (dot > 0.999999) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n return out;\n } else {\n vec3.cross(tmpvec3, a, b);\n out[0] = tmpvec3[0];\n out[1] = tmpvec3[1];\n out[2] = tmpvec3[2];\n out[3] = 1 + dot;\n return normalize(out, out);\n }\n };\n}();\n/**\r\n * Performs a spherical linear interpolation with two control points\r\n *\r\n * @param {quat} out the receiving quaternion\r\n * @param {ReadonlyQuat} a the first operand\r\n * @param {ReadonlyQuat} b the second operand\r\n * @param {ReadonlyQuat} c the third operand\r\n * @param {ReadonlyQuat} d the fourth operand\r\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\r\n * @returns {quat} out\r\n */\n\nexport var sqlerp = function () {\n var temp1 = create();\n var temp2 = create();\n return function (out, a, b, c, d, t) {\n slerp(temp1, a, d, t);\n slerp(temp2, b, c, t);\n slerp(out, temp1, temp2, 2 * t * (1 - t));\n return out;\n };\n}();\n/**\r\n * Sets the specified quaternion with values corresponding to the given\r\n * axes. Each axis is a vec3 and is expected to be unit length and\r\n * perpendicular to all other specified axes.\r\n *\r\n * @param {ReadonlyVec3} view the vector representing the viewing direction\r\n * @param {ReadonlyVec3} right the vector representing the local \"right\" direction\r\n * @param {ReadonlyVec3} up the vector representing the local \"up\" direction\r\n * @returns {quat} out\r\n */\n\nexport var setAxes = function () {\n var matr = mat3.create();\n return function (out, view, right, up) {\n matr[0] = right[0];\n matr[3] = right[1];\n matr[6] = right[2];\n matr[1] = up[0];\n matr[4] = up[1];\n matr[7] = up[2];\n matr[2] = -view[0];\n matr[5] = -view[1];\n matr[8] = -view[2];\n return normalize(out, fromMat3(out, matr));\n };\n}();","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { mat4, quat, vec3 } from 'gl-matrix';\nimport { Component } from '../../ComponentManager';\nexport var TransformComponent = /*#__PURE__*/function (_Component) {\n _inherits(TransformComponent, _Component);\n\n var _super = _createSuper(TransformComponent);\n\n /**\n * local space RTS\n */\n\n /**\n * XMFLOAT4X4._41\n * @see https://docs.microsoft.com/en-us/windows/win32/api/directxmath/nf-directxmath-xmfloat4x4-xmfloat4x4(constfloat)#remarks\n */\n\n /**\n * world space RTS\n */\n // 高阶函数,利用闭包重复利用临时变量\n // @see playcanvas graph node\n\n /**\n * @see https://docs.microsoft.com/en-us/windows/win32/api/directxmath/nf-directxmath-xmquaternionrotationrollpitchyaw\n */\n\n /**\n * @see https://xiaoiver.github.io/coding/2018/12/28/Camera-%E8%AE%BE%E8%AE%A1-%E4%B8%80.html\n */\n\n /**\n * TODO: 支持以下两种:\n * * translate(x, y, z)\n * * translate(vec3(x, y, z))\n */\n\n /**\n * @see https://en.wikipedia.org/wiki/Centripetal_Catmull%E2%80%93Rom_spline\n */\n // public catmullRom = (() => {\n // const aS = vec3.create();\n // const aR = quat.create();\n // const aT = vec3.create();\n // const bS = vec3.create();\n // const bR = quat.create();\n // const bT = vec3.create();\n // const cS = vec3.create();\n // const cR = quat.create();\n // const cT = vec3.create();\n // const dS = vec3.create();\n // const dR = quat.create();\n // const dT = vec3.create();\n // const R = quat.create();\n // return (\n // a: TransformComponent,\n // b: TransformComponent,\n // c: TransformComponent,\n // d: TransformComponent,\n // t: number,\n // ) => {\n // this.setDirty();\n // mat4.getScaling(aS, a.worldTransform);\n // mat4.getTranslation(aT, a.worldTransform);\n // mat4.getRotation(aR, a.worldTransform);\n // mat4.getScaling(bS, b.worldTransform);\n // mat4.getTranslation(bT, b.worldTransform);\n // mat4.getRotation(bR, b.worldTransform);\n // mat4.getScaling(cS, c.worldTransform);\n // mat4.getTranslation(cT, c.worldTransform);\n // mat4.getRotation(cR, c.worldTransform);\n // mat4.getScaling(dS, d.worldTransform);\n // mat4.getTranslation(dT, d.worldTransform);\n // mat4.getRotation(dR, d.worldTransform);\n // vec3.catmullRom(this.localPosition, aT, bT, cT, dT, t);\n // vec3.catmullRom(R, aR, bR, cR, dR, t);\n // quat.normalize(this.localRotation, R);\n // vec3.catmullRom(this.localScale, aS, bS, cS, dS, t);\n // };\n // })();\n function TransformComponent(data) {\n var _this;\n\n _classCallCheck(this, TransformComponent);\n\n _this = _super.call(this, data);\n _this.dirtyFlag = void 0;\n _this.localDirtyFlag = void 0;\n _this.parent = null;\n _this.localPosition = vec3.fromValues(0, 0, 0);\n _this.localRotation = quat.fromValues(0, 0, 0, 1);\n _this.localScale = vec3.fromValues(1, 1, 1);\n _this.localTransform = mat4.create();\n _this.position = vec3.fromValues(0, 0, 0);\n _this.rotation = quat.fromValues(0, 0, 0, 1);\n _this.scaling = vec3.fromValues(1, 1, 1);\n _this.worldTransform = mat4.create();\n\n _this.matrixTransform = function () {\n var transformed = mat4.create();\n return function (mat) {\n mat4.multiply(transformed, _this.getLocalTransform(), mat);\n mat4.getScaling(_this.localScale, transformed);\n mat4.getTranslation(_this.localPosition, transformed);\n mat4.getRotation(_this.localRotation, transformed);\n };\n }();\n\n _this.rotateRollPitchYaw = function () {\n var quatX = quat.create();\n var quatY = quat.create();\n var quatZ = quat.create();\n return function (x, y, z) {\n _this.setDirty();\n\n quat.fromEuler(quatX, x, 0, 0);\n quat.fromEuler(quatY, 0, y, 0);\n quat.fromEuler(quatZ, 0, 0, z);\n quat.multiply(_this.localRotation, quatX, _this.localRotation);\n quat.multiply(_this.localRotation, _this.localRotation, quatY);\n quat.multiply(_this.localRotation, quatZ, _this.localRotation);\n quat.normalize(_this.localRotation, _this.localRotation);\n };\n }();\n\n _this.lerp = function () {\n var aS = vec3.create();\n var aR = quat.create();\n var aT = vec3.create();\n var bS = vec3.create();\n var bR = quat.create();\n var bT = vec3.create();\n return function (a, b, t) {\n _this.setDirty();\n\n mat4.getScaling(aS, a.worldTransform);\n mat4.getTranslation(aT, a.worldTransform);\n mat4.getRotation(aR, a.worldTransform);\n mat4.getScaling(bS, b.worldTransform);\n mat4.getTranslation(bT, b.worldTransform);\n mat4.getRotation(bR, b.worldTransform);\n vec3.lerp(_this.localScale, aS, bS, t);\n quat.slerp(_this.localRotation, aR, bR, t);\n vec3.lerp(_this.localPosition, aT, bT, t);\n };\n }();\n\n _this.translate = function () {\n var tr = vec3.create();\n return function (translation) {\n vec3.add(tr, _this.getPosition(), translation);\n\n _this.setPosition(tr);\n\n _this.setDirty(true);\n\n return _assertThisInitialized(_this);\n };\n }();\n\n _this.translateLocal = function () {\n return function (translation) {\n vec3.transformQuat(translation, translation, _this.localRotation);\n vec3.add(_this.localPosition, _this.localPosition, translation);\n\n _this.setLocalDirty(true);\n\n return _assertThisInitialized(_this);\n };\n }();\n\n _this.setPosition = function () {\n var parentInvertMatrix = mat4.create();\n return function (position) {\n _this.position = position;\n\n _this.setLocalDirty(true);\n\n if (_this.parent === null) {\n vec3.copy(_this.localPosition, position);\n } else {\n mat4.copy(parentInvertMatrix, _this.parent.worldTransform);\n mat4.invert(parentInvertMatrix, parentInvertMatrix);\n vec3.transformMat4(_this.localPosition, position, parentInvertMatrix);\n }\n\n return _assertThisInitialized(_this);\n };\n }();\n\n _this.rotate = function () {\n var parentInvertRotation = quat.create();\n return function (quaternion) {\n if (_this.parent === null) {\n quat.multiply(_this.localRotation, _this.localRotation, quaternion);\n quat.normalize(_this.localRotation, _this.localRotation);\n } else {\n var rot = _this.getRotation();\n\n var parentRot = _this.parent.getRotation();\n\n quat.copy(parentInvertRotation, parentRot);\n quat.invert(parentInvertRotation, parentInvertRotation);\n quat.multiply(parentInvertRotation, parentInvertRotation, quaternion);\n quat.multiply(_this.localRotation, quaternion, rot);\n quat.normalize(_this.localRotation, _this.localRotation);\n }\n\n _this.setLocalDirty();\n\n return _assertThisInitialized(_this);\n };\n }();\n\n _this.rotateLocal = function () {\n return function (quaternion) {\n quat.multiply(_this.localRotation, _this.localRotation, quaternion);\n quat.normalize(_this.localRotation, _this.localRotation);\n\n _this.setLocalDirty(true);\n\n return _assertThisInitialized(_this);\n };\n }();\n\n _this.setRotation = function () {\n var invParentRot = quat.create();\n return function (rotation) {\n if (_this.parent === null) {\n quat.copy(_this.localRotation, rotation);\n } else {\n quat.copy(invParentRot, _this.parent.getRotation());\n quat.invert(invParentRot, invParentRot);\n quat.copy(_this.localRotation, invParentRot);\n quat.mul(_this.localRotation, _this.localRotation, rotation);\n }\n\n _this.setLocalDirty(true);\n\n return _assertThisInitialized(_this);\n };\n }();\n\n return _this;\n }\n\n _createClass(TransformComponent, [{\n key: \"setLocalPosition\",\n value: function setLocalPosition(position) {\n vec3.copy(this.localPosition, position);\n this.setLocalDirty(true);\n }\n }, {\n key: \"setLocalScale\",\n value: function setLocalScale(scale) {\n vec3.copy(this.localScale, scale);\n this.setLocalDirty(true);\n }\n }, {\n key: \"setLocalRotation\",\n value: function setLocalRotation(rotation) {\n quat.copy(this.localRotation, rotation);\n this.setLocalDirty(true);\n return this;\n }\n }, {\n key: \"isDirty\",\n value: function isDirty() {\n return this.dirtyFlag;\n }\n }, {\n key: \"setDirty\",\n value: function setDirty() {\n var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;\n\n if (value) {\n this.dirtyFlag |= TransformComponent.DIRTY;\n } else {\n this.dirtyFlag &= ~TransformComponent.DIRTY;\n }\n }\n }, {\n key: \"isLocalDirty\",\n value: function isLocalDirty() {\n return this.localDirtyFlag;\n }\n }, {\n key: \"setLocalDirty\",\n value: function setLocalDirty() {\n var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;\n\n if (value) {\n this.localDirtyFlag |= TransformComponent.DIRTY;\n this.setDirty(true);\n } else {\n this.localDirtyFlag &= ~TransformComponent.DIRTY;\n }\n }\n }, {\n key: \"updateTransform\",\n value: function updateTransform() {\n if (this.isLocalDirty()) {\n this.getLocalTransform();\n }\n\n if (this.isDirty()) {\n if (this.parent === null) {\n mat4.copy(this.worldTransform, this.getLocalTransform());\n this.setDirty(false);\n }\n }\n }\n }, {\n key: \"updateTransformWithParent\",\n value: function updateTransformWithParent(parent) {\n mat4.multiply(this.worldTransform, parent.worldTransform, this.getLocalTransform());\n }\n }, {\n key: \"applyTransform\",\n value: function applyTransform() {\n this.setDirty();\n mat4.getScaling(this.localScale, this.worldTransform);\n mat4.getTranslation(this.localPosition, this.worldTransform);\n mat4.getRotation(this.localRotation, this.worldTransform);\n }\n }, {\n key: \"clearTransform\",\n value: function clearTransform() {\n this.setDirty();\n this.localPosition = vec3.fromValues(0, 0, 0);\n this.localRotation = quat.fromValues(0, 0, 0, 1);\n this.localScale = vec3.fromValues(1, 1, 1);\n }\n }, {\n key: \"scaleLocal\",\n value: function scaleLocal(scaling) {\n this.setLocalDirty();\n vec3.multiply(this.localScale, this.localScale, scaling);\n return this;\n }\n }, {\n key: \"getLocalPosition\",\n value: function getLocalPosition() {\n return this.localPosition;\n }\n }, {\n key: \"getLocalRotation\",\n value: function getLocalRotation() {\n return this.localRotation;\n }\n }, {\n key: \"getLocalScale\",\n value: function getLocalScale() {\n return this.localScale;\n }\n }, {\n key: \"getLocalTransform\",\n value: function getLocalTransform() {\n if (this.localDirtyFlag) {\n mat4.fromRotationTranslationScale(this.localTransform, this.localRotation, this.localPosition, this.localScale);\n this.setLocalDirty(false);\n }\n\n return this.localTransform;\n }\n }, {\n key: \"getWorldTransform\",\n value: function getWorldTransform() {\n if (!this.isLocalDirty() && !this.isDirty()) {\n return this.worldTransform;\n }\n\n if (this.parent) {\n this.parent.getWorldTransform();\n }\n\n this.updateTransform();\n return this.worldTransform;\n }\n }, {\n key: \"getPosition\",\n value: function getPosition() {\n mat4.getTranslation(this.position, this.worldTransform);\n return this.position;\n }\n }, {\n key: \"getRotation\",\n value: function getRotation() {\n mat4.getRotation(this.rotation, this.worldTransform);\n return this.rotation;\n }\n }, {\n key: \"getScale\",\n value: function getScale() {\n mat4.getScaling(this.scaling, this.worldTransform);\n return this.scaling;\n }\n }]);\n\n return TransformComponent;\n}(Component);\nTransformComponent.DIRTY = 1 << 0;\n//# sourceMappingURL=TransformComponent.js.map","import _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _class, _class2, _descriptor, _temp;\n\nimport { inject, injectable } from 'inversify';\nimport { IDENTIFIER } from '../../identifier';\nimport { gl } from '../renderer/gl';\nexport var ResourcePool = (_dec = injectable(), _dec2 = inject(IDENTIFIER.RenderEngine), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function () {\n function ResourcePool() {\n _classCallCheck(this, ResourcePool);\n\n _initializerDefineProperty(this, \"engine\", _descriptor, this);\n\n this.resourcePool = {};\n }\n\n _createClass(ResourcePool, [{\n key: \"getOrCreateResource\",\n\n /**\n * 负责实例化虚拟资源,通过引擎服务\n * @param resource 虚拟资源\n */\n value: function getOrCreateResource(resource) {\n if (!this.resourcePool[resource.name]) {\n var _resource$descriptor = resource.descriptor,\n width = _resource$descriptor.width,\n height = _resource$descriptor.height,\n usage = _resource$descriptor.usage;\n this.resourcePool[resource.name] = this.engine.createFramebuffer({\n color: this.engine.createTexture2D({\n width: width,\n height: height,\n wrapS: gl.CLAMP_TO_EDGE,\n wrapT: gl.CLAMP_TO_EDGE,\n usage: usage\n })\n });\n }\n\n return this.resourcePool[resource.name];\n }\n }, {\n key: \"clean\",\n value: function clean() {\n this.resourcePool = {};\n }\n }]);\n\n return ResourcePool;\n}(), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"engine\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=ResourcePool.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { Component } from '../..';\nexport var NameComponent = /*#__PURE__*/function (_Component) {\n _inherits(NameComponent, _Component);\n\n var _super = _createSuper(NameComponent);\n\n function NameComponent(data) {\n var _this;\n\n _classCallCheck(this, NameComponent);\n\n _this = _super.call(this, data);\n _this.name = void 0;\n _this.name = data.name || '';\n return _this;\n }\n\n return NameComponent;\n}(Component);\n//# sourceMappingURL=NameComponent.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\nvar _dec, _class, _temp;\n\nimport { injectable } from 'inversify';\nexport var ConfigService = (_dec = injectable(), _dec(_class = (_temp = /*#__PURE__*/function () {\n function ConfigService() {\n _classCallCheck(this, ConfigService);\n\n this.config = void 0;\n }\n\n _createClass(ConfigService, [{\n key: \"get\",\n value: function get() {\n return this.config;\n }\n }, {\n key: \"set\",\n value: function set(config) {\n this.config = config;\n }\n }]);\n\n return ConfigService;\n}(), _temp)) || _class);\n//# sourceMappingURL=ConfigService.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\nvar _dec, _class;\n\nimport { injectable } from 'inversify';\nexport var IInteractorEvent;\n\n(function (IInteractorEvent) {\n IInteractorEvent[\"PANSTART\"] = \"PANSTART\";\n IInteractorEvent[\"PANEND\"] = \"PANEND\";\n IInteractorEvent[\"PANMOVE\"] = \"PANMOVE\";\n IInteractorEvent[\"PINCH\"] = \"PINCH\";\n IInteractorEvent[\"KEYDOWN\"] = \"KEYDOWN\";\n IInteractorEvent[\"KEYUP\"] = \"KEYUP\";\n IInteractorEvent[\"HOVER\"] = \"HOVER\";\n})(IInteractorEvent || (IInteractorEvent = {}));\n\nexport var InteractorService = (_dec = injectable(), _dec(_class = /*#__PURE__*/function () {\n function InteractorService() {\n _classCallCheck(this, InteractorService);\n }\n\n _createClass(InteractorService, [{\n key: \"listen\",\n value: function listen(canvas) {}\n }, {\n key: \"on\",\n value: function on(event, args) {}\n }, {\n key: \"connect\",\n value: function connect() {}\n }, {\n key: \"disconnect\",\n value: function disconnect() {}\n }, {\n key: \"destroy\",\n value: function destroy() {}\n }]);\n\n return InteractorService;\n}()) || _class);\n//# sourceMappingURL=IteractorService.js.map","import _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\nvar _dec, _class, _temp;\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { injectable } from 'inversify';\nimport { extractUniforms } from '../../utils/shader-module';\nimport { uniq } from '../../utils/uniq';\n\n/* babel-plugin-inline-import './shaders/webgl.picking.frag.glsl' */\nvar pickingFrag = \"varying vec4 v_PickingResult;\\nuniform vec4 u_HighlightColor : [0, 0, 0, 0];\\nuniform float u_PickingStage : 0.0;\\n\\n#define PICKING_ENCODE 1.0\\n#define PICKING_HIGHLIGHT 2.0\\n#define COLOR_SCALE 1. / 255.\\n\\n/*\\n * Returns highlight color if this item is selected.\\n */\\nvec4 filterHighlightColor(vec4 color) {\\n bool selected = bool(v_PickingResult.a);\\n\\n if (selected) {\\n vec4 highLightColor = u_HighlightColor * COLOR_SCALE;\\n\\n float highLightAlpha = highLightColor.a;\\n float highLightRatio = highLightAlpha / (highLightAlpha + color.a * (1.0 - highLightAlpha));\\n\\n vec3 resultRGB = mix(color.rgb, highLightColor.rgb, highLightRatio);\\n return vec4(resultRGB, color.a);\\n } else {\\n return color;\\n }\\n}\\n\\n/*\\n * Returns picking color if picking enabled else unmodified argument.\\n */\\nvec4 filterPickingColor(vec4 color) {\\n vec3 pickingColor = v_PickingResult.rgb;\\n if (u_PickingStage == PICKING_ENCODE && length(pickingColor) < 0.001) {\\n discard;\\n }\\n return u_PickingStage == PICKING_ENCODE ? vec4(pickingColor, step(0.001,color.a)): color;\\n}\\n\\n/*\\n * Returns picking color if picking is enabled if not\\n * highlight color if this item is selected, otherwise unmodified argument.\\n */\\nvec4 filterColor(vec4 color) {\\n return filterPickingColor(filterHighlightColor(color));\\n}\\n\";\n\n/* babel-plugin-inline-import './shaders/webgl.picking.vert.glsl' */\nvar pickingVert = \"attribute vec3 a_PickingColor;\\nvarying vec4 v_PickingResult;\\n\\nuniform vec3 u_PickingColor : [0, 0, 0];\\nuniform vec4 u_HighlightColor : [0, 0, 0, 0];\\nuniform float u_PickingStage : 0.0;\\nuniform float u_PickingThreshold : 1.0;\\nuniform float u_PickingBuffer: 0.0;\\n\\n#define PICKING_ENCODE 1.0\\n#define PICKING_HIGHLIGHT 2.0\\n#define COLOR_SCALE 1. / 255.\\n\\nbool isVertexPicked(vec3 vertexColor) {\\n return\\n abs(vertexColor.r - u_PickingColor.r) < u_PickingThreshold &&\\n abs(vertexColor.g - u_PickingColor.g) < u_PickingThreshold &&\\n abs(vertexColor.b - u_PickingColor.b) < u_PickingThreshold;\\n}\\n\\nvoid setPickingColor(vec3 pickingColor) {\\n // compares only in highlight stage\\n v_PickingResult.a = float((u_PickingStage == PICKING_HIGHLIGHT) && isVertexPicked(pickingColor));\\n\\n // Stores the picking color so that the fragment shader can render it during picking\\n v_PickingResult.rgb = pickingColor * COLOR_SCALE;\\n}\\n\\nfloat setPickingSize(float x) {\\n return u_PickingStage == PICKING_ENCODE ? x + u_PickingBuffer : x;\\n}\";\n\n/* babel-plugin-inline-import './shaders/webgl.sdf2d.frag.glsl' */\nvar sdf2dFrag = \"/**\\n * 2D signed distance field functions\\n * @see http://www.iquilezles.org/www/articles/distfunctions2d/distfunctions2d.htm\\n */\\n\\nfloat ndot(vec2 a, vec2 b ) { return a.x*b.x - a.y*b.y; }\\n\\nfloat sdCircle(vec2 p, float r) {\\n return length(p) - r;\\n}\\n\\nfloat sdEquilateralTriangle(vec2 p) {\\n float k = sqrt(3.0);\\n p.x = abs(p.x) - 1.0;\\n p.y = p.y + 1.0/k;\\n if( p.x + k*p.y > 0.0 ) p = vec2(p.x-k*p.y,-k*p.x-p.y)/2.0;\\n p.x -= clamp( p.x, -2.0, 0.0 );\\n return -length(p)*sign(p.y);\\n}\\n\\nfloat sdBox(vec2 p, vec2 b) {\\n vec2 d = abs(p)-b;\\n return length(max(d,vec2(0))) + min(max(d.x,d.y),0.0);\\n}\\n\\nfloat sdPentagon(vec2 p, float r) {\\n vec3 k = vec3(0.809016994,0.587785252,0.726542528);\\n p.x = abs(p.x);\\n p -= 2.0*min(dot(vec2(-k.x,k.y),p),0.0)*vec2(-k.x,k.y);\\n p -= 2.0*min(dot(vec2( k.x,k.y),p),0.0)*vec2( k.x,k.y);\\n p -= vec2(clamp(p.x,-r*k.z,r*k.z),r);\\n return length(p)*sign(p.y);\\n}\\n\\nfloat sdHexagon(vec2 p, float r) {\\n vec3 k = vec3(-0.866025404,0.5,0.577350269);\\n p = abs(p);\\n p -= 2.0*min(dot(k.xy,p),0.0)*k.xy;\\n p -= vec2(clamp(p.x, -k.z*r, k.z*r), r);\\n return length(p)*sign(p.y);\\n}\\n\\nfloat sdOctogon(vec2 p, float r) {\\n vec3 k = vec3(-0.9238795325, 0.3826834323, 0.4142135623 );\\n p = abs(p);\\n p -= 2.0*min(dot(vec2( k.x,k.y),p),0.0)*vec2( k.x,k.y);\\n p -= 2.0*min(dot(vec2(-k.x,k.y),p),0.0)*vec2(-k.x,k.y);\\n p -= vec2(clamp(p.x, -k.z*r, k.z*r), r);\\n return length(p)*sign(p.y);\\n}\\n\\nfloat sdHexagram(vec2 p, float r) {\\n vec4 k=vec4(-0.5,0.8660254038,0.5773502692,1.7320508076);\\n p = abs(p);\\n p -= 2.0*min(dot(k.xy,p),0.0)*k.xy;\\n p -= 2.0*min(dot(k.yx,p),0.0)*k.yx;\\n p -= vec2(clamp(p.x,r*k.z,r*k.w),r);\\n return length(p)*sign(p.y);\\n}\\n\\nfloat sdRhombus(vec2 p, vec2 b) {\\n vec2 q = abs(p);\\n float h = clamp((-2.0*ndot(q,b)+ndot(b,b))/dot(b,b),-1.0,1.0);\\n float d = length( q - 0.5*b*vec2(1.0-h,1.0+h) );\\n return d * sign( q.x*b.y + q.y*b.x - b.x*b.y );\\n}\\n\\nfloat sdVesica(vec2 p, float r, float d) {\\n p = abs(p);\\n float b = sqrt(r*r-d*d); // can delay this sqrt\\n return ((p.y-b)*d>p.x*b)\\n ? length(p-vec2(0.0,b))\\n : length(p-vec2(-d,0.0))-r;\\n}\";\nvar precisionRegExp = /precision\\s+(high|low|medium)p\\s+float/;\nvar globalDefaultprecision = '#ifdef GL_FRAGMENT_PRECISION_HIGH\\n precision highp float;\\n #else\\n precision mediump float;\\n#endif\\n';\nvar includeRegExp = /#pragma include ([\"^+\"]?[\"\\ \"[a-zA-Z_0-9](.*)\"]*?)/g;\nvar ShaderModuleService = (_dec = injectable(), _dec(_class = (_temp = /*#__PURE__*/function () {\n function ShaderModuleService() {\n _classCallCheck(this, ShaderModuleService);\n\n this.moduleCache = {};\n this.rawContentCache = {};\n }\n\n _createClass(ShaderModuleService, [{\n key: \"registerBuiltinModules\",\n value: function registerBuiltinModules() {\n this.destroy();\n this.registerModule('picking', {\n vs: pickingVert,\n fs: pickingFrag\n });\n this.registerModule('sdf2d', {\n vs: '',\n fs: sdf2dFrag\n });\n }\n }, {\n key: \"registerModule\",\n value: function registerModule(moduleName, moduleParams) {\n // prevent registering the same module multiple times\n if (this.rawContentCache[moduleName]) {\n return;\n }\n\n var _moduleParams$vs = moduleParams.vs,\n vs = _moduleParams$vs === void 0 ? '' : _moduleParams$vs,\n _moduleParams$fs = moduleParams.fs,\n fs = _moduleParams$fs === void 0 ? '' : _moduleParams$fs,\n declaredUniforms = moduleParams.uniforms;\n\n var _extractUniforms = extractUniforms(vs),\n extractedVS = _extractUniforms.content,\n vsUniforms = _extractUniforms.uniforms;\n\n var _extractUniforms2 = extractUniforms(fs),\n extractedFS = _extractUniforms2.content,\n fsUniforms = _extractUniforms2.uniforms;\n\n this.rawContentCache[moduleName] = {\n fs: extractedFS,\n uniforms: _objectSpread(_objectSpread(_objectSpread({}, vsUniforms), fsUniforms), declaredUniforms),\n vs: extractedVS\n };\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n this.moduleCache = {};\n this.rawContentCache = {};\n }\n }, {\n key: \"getModule\",\n value: function getModule(moduleName) {\n var _this = this;\n\n if (this.moduleCache[moduleName]) {\n return this.moduleCache[moduleName];\n }\n\n var rawVS = this.rawContentCache[moduleName].vs || '';\n var rawFS = this.rawContentCache[moduleName].fs || '';\n\n var _this$processModule = this.processModule(rawVS, [], 'vs'),\n vs = _this$processModule.content,\n vsIncludeList = _this$processModule.includeList;\n\n var _this$processModule2 = this.processModule(rawFS, [], 'fs'),\n fs = _this$processModule2.content,\n fsIncludeList = _this$processModule2.includeList;\n\n var compiledFs = fs; // TODO: extract uniforms and their default values from GLSL\n\n var uniforms = uniq(vsIncludeList.concat(fsIncludeList).concat(moduleName)).reduce(function (prev, cur) {\n return _objectSpread(_objectSpread({}, prev), _this.rawContentCache[cur].uniforms);\n }, {});\n /**\n * set default precision for fragment shader\n * https://stackoverflow.com/questions/28540290/why-it-is-necessary-to-set-precision-for-the-fragment-shader\n */\n\n if (!precisionRegExp.test(fs)) {\n compiledFs = globalDefaultprecision + fs;\n }\n\n this.moduleCache[moduleName] = {\n fs: compiledFs.trim(),\n uniforms: uniforms,\n vs: vs.trim()\n };\n return this.moduleCache[moduleName];\n }\n }, {\n key: \"processModule\",\n value: function processModule(rawContent, includeList, type) {\n var _this2 = this;\n\n var compiled = rawContent.replace(includeRegExp, function (_, strMatch) {\n var includeOpt = strMatch.split(' ');\n var includeName = includeOpt[0].replace(/\"/g, '');\n\n if (includeList.indexOf(includeName) > -1) {\n return '';\n }\n\n var txt = _this2.rawContentCache[includeName][type];\n includeList.push(includeName);\n\n var _this2$processModule = _this2.processModule(txt || '', includeList, type),\n content = _this2$processModule.content;\n\n return content;\n });\n return {\n content: compiled,\n includeList: includeList\n };\n }\n }]);\n\n return ShaderModuleService;\n}(), _temp)) || _class);\nexport { ShaderModuleService as default };\n//# sourceMappingURL=ShaderModuleService.js.map","export function getUniformLengthByType(type) {\n var arrayLength = 0;\n\n switch (type) {\n case 'vec2':\n case 'ivec2':\n arrayLength = 2;\n break;\n\n case 'vec3':\n case 'ivec3':\n arrayLength = 3;\n break;\n\n case 'vec4':\n case 'ivec4':\n case 'mat2':\n arrayLength = 4;\n break;\n\n case 'mat3':\n arrayLength = 9;\n break;\n\n case 'mat4':\n arrayLength = 16;\n break;\n\n default:\n }\n\n return arrayLength;\n}\nvar uniformRegExp = /uniform\\s+(bool|float|int|vec2|vec3|vec4|ivec2|ivec3|ivec4|mat2|mat3|mat4|sampler2D|samplerCube)\\s+([\\s\\S]*?);/g;\nexport function extractUniforms(content) {\n var uniforms = {};\n content = content.replace(uniformRegExp, function (_, type, c) {\n var defaultValues = c.split(':');\n var uniformName = defaultValues[0].trim();\n var defaultValue = '';\n\n if (defaultValues.length > 1) {\n defaultValue = defaultValues[1].trim();\n } // set default value for uniform according to its type\n // eg. vec2 u -> [0.0, 0.0]\n\n\n switch (type) {\n case 'bool':\n defaultValue = defaultValue === 'true';\n break;\n\n case 'float':\n case 'int':\n defaultValue = Number(defaultValue);\n break;\n\n case 'vec2':\n case 'vec3':\n case 'vec4':\n case 'ivec2':\n case 'ivec3':\n case 'ivec4':\n case 'mat2':\n case 'mat3':\n case 'mat4':\n if (defaultValue) {\n defaultValue = defaultValue.replace('[', '').replace(']', '').split(',').reduce(function (prev, cur) {\n prev.push(Number(cur.trim()));\n return prev;\n }, []);\n } else {\n defaultValue = new Array(getUniformLengthByType(type)).fill(0);\n }\n\n break;\n\n default:\n } // @ts-ignore\n\n\n uniforms[uniformName] = defaultValue;\n return \"uniform \".concat(type, \" \").concat(uniformName, \";\\n\");\n });\n return {\n content: content,\n uniforms: uniforms\n };\n}\n//# sourceMappingURL=shader-module.js.map","export function uniq(array) {\n return array.filter(function (v, i, a) {\n return a.indexOf(v) === i;\n });\n}\n//# sourceMappingURL=uniq.js.map","/**\n * Root Container\n * @see /dev-docs/IoC 容器、依赖注入与服务说明.md\n */\nimport 'reflect-metadata';\nimport { Container } from 'inversify';\nimport getDecorators from 'inversify-inject-decorators';\nimport { ComponentManager } from './ComponentManager';\nimport { ResourcePool } from './components/framegraph/ResourcePool';\nimport { FrameGraphSystem } from './components/framegraph/System';\nimport { GeometryComponent } from './components/geometry/GeometryComponent';\nimport { GeometrySystem } from './components/geometry/System'; // import { InteractionSystem } from './components/interaction/System';\n\nimport { MaterialComponent } from './components/material/MaterialComponent';\nimport { MaterialSystem } from './components/material/System';\nimport { CullableComponent } from './components/mesh/CullableComponent';\nimport { MeshComponent } from './components/mesh/MeshComponent';\nimport { MeshSystem } from './components/mesh/System';\nimport { CopyPass } from './components/renderer/passes/CopyPass';\nimport { PixelPickingPass } from './components/renderer/passes/PixelPickingPass';\nimport { RenderPass } from './components/renderer/passes/RenderPass';\nimport { RendererSystem } from './components/renderer/System';\nimport { HierarchyComponent } from './components/scenegraph/HierarchyComponent';\nimport { NameComponent } from './components/scenegraph/NameComponent';\nimport { SceneGraphSystem } from './components/scenegraph/System';\nimport { TransformComponent } from './components/scenegraph/TransformComponent';\nimport { IDENTIFIER } from './identifier';\nimport { ConfigService } from './services/config/ConfigService';\nimport { InteractorService } from './services/interactor/IteractorService';\nimport ShaderModuleService from './services/shader-module/ShaderModuleService'; // @see https://github.com/inversify/InversifyJS/blob/master/wiki/container_api.md#defaultscope\n\nexport var container = new Container(); // @see https://github.com/inversify/InversifyJS/blob/master/wiki/inheritance.md#what-can-i-do-when-my-base-class-is-provided-by-a-third-party-module\n// decorate(injectable(), EventEmitter);\n// container.bind(IDENTIFIER.IEventEmitter).to(EventEmitter);\n// 支持使用 new 而非容器实例化的场景,同时禁止 lazyInject cache\n// @see https://github.com/inversify/inversify-inject-decorators#caching-vs-non-caching-behaviour\n\nvar DECORATORS = getDecorators(container, false);\n// Add babel legacy decorators support\n// @see https://github.com/inversify/InversifyJS/issues/1050\n// @see https://github.com/inversify/InversifyJS/issues/1026#issuecomment-504936034\nexport var lazyInject = function lazyInject(serviceIdentifier) {\n var original = DECORATORS.lazyInject(serviceIdentifier); // the 'descriptor' parameter is actually always defined for class fields for Babel, but is considered undefined for TSC\n // so we just hack it with ?/! combination to avoid \"TS1240: Unable to resolve signature of property decorator when called as an expression\"\n\n return function (proto, key, descriptor) {\n // make it work as usual\n original.call(this, proto, key); // return link to proto, so own value wont be 'undefined' after component's creation\n\n if (descriptor) {\n descriptor.initializer = function () {\n return proto[key];\n };\n }\n };\n};\nexport var lazyMultiInject = function lazyMultiInject(serviceIdentifier) {\n var original = DECORATORS.lazyMultiInject(serviceIdentifier); // the 'descriptor' parameter is actually always defined for class fields for Babel, but is considered undefined for TSC\n // so we just hack it with ?/! combination to avoid \"TS1240: Unable to resolve signature of property decorator when called as an expression\"\n\n return function (proto, key, descriptor) {\n // make it work as usual\n original.call(this, proto, key);\n\n if (descriptor) {\n // return link to proto, so own value wont be 'undefined' after component's creation\n descriptor.initializer = function () {\n return proto[key];\n };\n }\n };\n};\n/** global services */\n\ncontainer.bind(IDENTIFIER.ShaderModuleService).to(ShaderModuleService).inSingletonScope();\n/**\n * bind global component managers in root container\n */\n\ncontainer.bind(IDENTIFIER.NameComponentManager).toConstantValue(new ComponentManager(NameComponent));\ncontainer.bind(IDENTIFIER.HierarchyComponentManager).toConstantValue(new ComponentManager(HierarchyComponent));\ncontainer.bind(IDENTIFIER.TransformComponentManager).toConstantValue(new ComponentManager(TransformComponent));\ncontainer.bind(IDENTIFIER.MeshComponentManager).toConstantValue(new ComponentManager(MeshComponent));\ncontainer.bind(IDENTIFIER.CullableComponentManager).toConstantValue(new ComponentManager(CullableComponent));\ncontainer.bind(IDENTIFIER.GeometryComponentManager).toConstantValue(new ComponentManager(GeometryComponent));\ncontainer.bind(IDENTIFIER.MaterialComponentManager).toConstantValue(new ComponentManager(MaterialComponent)); // https://github.com/inversify/InversifyJS/blob/master/wiki/hierarchical_di.md#support-for-hierarchical-di-systems\n\nexport function createWorldContainer() {\n var worldContainer = new Container();\n worldContainer.parent = container;\n /**\n * bind systems\n */\n\n worldContainer.bind(IDENTIFIER.Systems).to(SceneGraphSystem).inSingletonScope().whenTargetNamed(IDENTIFIER.SceneGraphSystem);\n worldContainer.bind(IDENTIFIER.Systems).to(FrameGraphSystem).inSingletonScope().whenTargetNamed(IDENTIFIER.FrameGraphSystem);\n worldContainer.bind(IDENTIFIER.Systems).to(MeshSystem).inSingletonScope().whenTargetNamed(IDENTIFIER.MeshSystem);\n worldContainer.bind(IDENTIFIER.Systems).to(GeometrySystem).inSingletonScope().whenTargetNamed(IDENTIFIER.GeometrySystem);\n worldContainer.bind(IDENTIFIER.Systems).to(MaterialSystem).inSingletonScope().whenTargetNamed(IDENTIFIER.MaterialSystem);\n worldContainer.bind(IDENTIFIER.Systems).to(RendererSystem).inSingletonScope().whenTargetNamed(IDENTIFIER.RendererSystem); // 资源池\n\n worldContainer.bind(IDENTIFIER.ResourcePool).to(ResourcePool).inSingletonScope();\n worldContainer.bind(IDENTIFIER.ConfigService).to(ConfigService).inSingletonScope();\n worldContainer.bind(IDENTIFIER.InteractorService).to(InteractorService).inSingletonScope();\n /**\n * bind render passes\n */\n\n worldContainer.bind(IDENTIFIER.RenderPass).to(RenderPass).inSingletonScope().whenTargetNamed(RenderPass.IDENTIFIER);\n worldContainer.bind(IDENTIFIER.RenderPass).to(CopyPass).inSingletonScope().whenTargetNamed(CopyPass.IDENTIFIER);\n worldContainer.bind(IDENTIFIER.RenderPass).to(PixelPickingPass).inSingletonScope().whenTargetNamed(PixelPickingPass.IDENTIFIER);\n worldContainer.bind(IDENTIFIER.RenderPassFactory).toFactory(function (context) {\n return function (name) {\n return context.container.getNamed(IDENTIFIER.RenderPass, name);\n };\n });\n return worldContainer;\n}\n//# sourceMappingURL=inversify.config.js.map","import { vec3 } from 'gl-matrix';\nimport { AABB } from '../shape/AABB';\n/**\n * generate AABB with positions\n * @param positions [x1,y1,z1, x2,y2,z2]\n */\n\nexport function generateAABBFromVertices(positions) {\n var aabb = new AABB();\n var min = vec3.fromValues(positions[0], positions[1], positions[2]);\n var max = vec3.fromValues(positions[0], positions[1], positions[2]);\n\n for (var i = 3; i < positions.length;) {\n var x = positions[i++];\n var y = positions[i++];\n var z = positions[i++];\n\n if (x < min[0]) {\n min[0] = x;\n }\n\n if (y < min[1]) {\n min[1] = y;\n }\n\n if (z < min[2]) {\n min[2] = z;\n }\n\n if (x > max[0]) {\n max[0] = x;\n }\n\n if (y > max[1]) {\n max[1] = y;\n }\n\n if (z > max[2]) {\n max[2] = z;\n }\n }\n\n aabb.setMinMax(min, max);\n return aabb;\n}\n//# sourceMappingURL=aabb.js.map","export var isSafari = typeof navigator !== 'undefined' && /Version\\/[\\d\\.]+.*Safari/.test(navigator.userAgent);\n//# sourceMappingURL=isSafari.js.map","export var PassType;\n/**\n * Pass 分两类:\n * 1. 渲染相关 eg. ClearPass、RenderPass、PickingPass、ShadowPass\n * 2. PostProcessing eg. CopyPass、BlurPass\n * 另外考虑到 Pass 之间严格的执行顺序,render 方法必须是异步的\n */\n\n(function (PassType) {\n PassType[\"Normal\"] = \"normal\";\n PassType[\"PostProcessing\"] = \"post-processing\";\n})(PassType || (PassType = {}));\n//# sourceMappingURL=IMultiPassRenderer.js.map","// tslint:disable-next-line:no-reference\n/// <reference path=\"../../../node_modules/@webgpu/types/dist/index.d.ts\" />\nimport 'reflect-metadata';\nimport { Component, ComponentManager } from './ComponentManager';\nimport { FrameGraphSystem } from './components/framegraph/System';\nimport { GeometryComponent } from './components/geometry/GeometryComponent';\nimport { GeometrySystem } from './components/geometry/System';\nimport { MaterialComponent } from './components/material/MaterialComponent';\nimport { MaterialSystem } from './components/material/System';\nimport { CullableComponent } from './components/mesh/CullableComponent';\nimport { MeshComponent } from './components/mesh/MeshComponent';\nimport { MeshSystem } from './components/mesh/System';\nimport { PixelPickingPass } from './components/renderer/passes/PixelPickingPass';\nimport { RendererSystem } from './components/renderer/System';\nimport { HierarchyComponent } from './components/scenegraph/HierarchyComponent';\nimport { SceneGraphSystem } from './components/scenegraph/System';\nimport { TransformComponent } from './components/scenegraph/TransformComponent';\nimport { createEntity } from './Entity';\nimport { IDENTIFIER } from './identifier';\nimport { container, createWorldContainer, lazyInject, lazyMultiInject } from './inversify.config';\nimport { generateAABBFromVertices } from './utils/aabb';\nimport { isSafari } from './utils/isSafari';\n/**\n * inspired by Entitas' Systems\n * @see https://github.com/sschmid/Entitas-CSharp/wiki/Systems\n */\n\nvar AST_TOKEN_TYPES;\n\n(function (AST_TOKEN_TYPES) {\n AST_TOKEN_TYPES[\"Void\"] = \"Void\";\n AST_TOKEN_TYPES[\"Boolean\"] = \"Boolean\";\n AST_TOKEN_TYPES[\"Float\"] = \"Float\";\n AST_TOKEN_TYPES[\"Uint32\"] = \"Uint32\";\n AST_TOKEN_TYPES[\"Int32\"] = \"Int32\";\n AST_TOKEN_TYPES[\"Vector\"] = \"Vector\";\n AST_TOKEN_TYPES[\"Vector2Float\"] = \"vec2<f32>\";\n AST_TOKEN_TYPES[\"Vector3Float\"] = \"vec3<f32>\";\n AST_TOKEN_TYPES[\"Vector4Float\"] = \"vec4<f32>\";\n AST_TOKEN_TYPES[\"Vector2Boolean\"] = \"vec2<bool>\";\n AST_TOKEN_TYPES[\"Vector3Boolean\"] = \"vec3<bool>\";\n AST_TOKEN_TYPES[\"Vector4Boolean\"] = \"vec4<bool>\";\n AST_TOKEN_TYPES[\"Vector2Uint\"] = \"vec2<u32>\";\n AST_TOKEN_TYPES[\"Vector3Uint\"] = \"vec3<u32>\";\n AST_TOKEN_TYPES[\"Vector4Uint\"] = \"vec4<u32>\";\n AST_TOKEN_TYPES[\"Vector2Int\"] = \"vec2<i32>\";\n AST_TOKEN_TYPES[\"Vector3Int\"] = \"vec3<i32>\";\n AST_TOKEN_TYPES[\"Vector4Int\"] = \"vec4<i32>\";\n AST_TOKEN_TYPES[\"Matrix\"] = \"Matrix\";\n AST_TOKEN_TYPES[\"Matrix3x3Float\"] = \"mat3x3<f32>\";\n AST_TOKEN_TYPES[\"Matrix4x4Float\"] = \"mat4x4<i32>\";\n AST_TOKEN_TYPES[\"Struct\"] = \"Struct\";\n AST_TOKEN_TYPES[\"FloatArray\"] = \"Float[]\";\n AST_TOKEN_TYPES[\"Vector4FloatArray\"] = \"vec4<f32>[]\";\n})(AST_TOKEN_TYPES || (AST_TOKEN_TYPES = {}));\n\nvar AST_NODE_TYPES;\n\n(function (AST_NODE_TYPES) {\n AST_NODE_TYPES[\"Program\"] = \"Program\";\n AST_NODE_TYPES[\"Identifier\"] = \"Identifier\";\n AST_NODE_TYPES[\"VariableDeclaration\"] = \"VariableDeclaration\";\n AST_NODE_TYPES[\"BlockStatement\"] = \"BlockStatement\";\n AST_NODE_TYPES[\"ReturnStatement\"] = \"ReturnStatement\";\n AST_NODE_TYPES[\"FunctionDeclaration\"] = \"FunctionDeclaration\";\n AST_NODE_TYPES[\"VariableDeclarator\"] = \"VariableDeclarator\";\n AST_NODE_TYPES[\"AssignmentExpression\"] = \"AssignmentExpression\";\n AST_NODE_TYPES[\"LogicalExpression\"] = \"LogicalExpression\";\n AST_NODE_TYPES[\"BinaryExpression\"] = \"BinaryExpression\";\n AST_NODE_TYPES[\"ArrayExpression\"] = \"ArrayExpression\";\n AST_NODE_TYPES[\"UnaryExpression\"] = \"UnaryExpression\";\n AST_NODE_TYPES[\"UpdateExpression\"] = \"UpdateExpression\";\n AST_NODE_TYPES[\"FunctionExpression\"] = \"FunctionExpression\";\n AST_NODE_TYPES[\"MemberExpression\"] = \"MemberExpression\";\n AST_NODE_TYPES[\"ConditionalExpression\"] = \"ConditionalExpression\";\n AST_NODE_TYPES[\"ExpressionStatement\"] = \"ExpressionStatement\";\n AST_NODE_TYPES[\"CallExpression\"] = \"CallExpression\";\n AST_NODE_TYPES[\"NumThreadStatement\"] = \"NumThreadStatement\";\n AST_NODE_TYPES[\"StorageStatement\"] = \"StorageStatement\";\n AST_NODE_TYPES[\"DoWhileStatement\"] = \"DoWhileStatement\";\n AST_NODE_TYPES[\"WhileStatement\"] = \"WhileStatement\";\n AST_NODE_TYPES[\"ForStatement\"] = \"ForStatement\";\n AST_NODE_TYPES[\"BreakStatement\"] = \"BreakStatement\";\n AST_NODE_TYPES[\"ContinueStatement\"] = \"ContinueStatement\";\n AST_NODE_TYPES[\"IfStatement\"] = \"IfStatement\";\n AST_NODE_TYPES[\"ImportedFunctionStatement\"] = \"ImportedFunctionStatement\";\n})(AST_NODE_TYPES || (AST_NODE_TYPES = {}));\n\nvar STORAGE_CLASS;\n\n(function (STORAGE_CLASS) {\n STORAGE_CLASS[\"Input\"] = \"Input\";\n STORAGE_CLASS[\"Output\"] = \"Output\";\n STORAGE_CLASS[\"Uniform\"] = \"Uniform\";\n STORAGE_CLASS[\"Workgroup\"] = \"Workgroup\";\n STORAGE_CLASS[\"UniformConstant\"] = \"UniformConstant\";\n STORAGE_CLASS[\"Image\"] = \"Image\";\n STORAGE_CLASS[\"StorageBuffer\"] = \"StorageBuffer\";\n STORAGE_CLASS[\"Private\"] = \"Private\";\n STORAGE_CLASS[\"Function\"] = \"Function\";\n})(STORAGE_CLASS || (STORAGE_CLASS = {}));\n\n/**\n * 根据目标平台生成 Shader 代码\n * * WebGL GLSL 1.0\n * * WebGPU Chrome/Edge GLSL 4.5 & WGSL @see https://gpuweb.github.io/gpuweb/wgsl.html\n * * Safari WHLSL (maybe deprecated)\n */\nvar Target;\n\n(function (Target) {\n Target[\"GLSL100\"] = \"GLSL100\";\n Target[\"GLSL450\"] = \"GLSL450\";\n Target[\"WGSL\"] = \"WGSL\";\n})(Target || (Target = {}));\n\nvar DefineValuePlaceholder = '__DefineValuePlaceholder__';\nexport * from './ComponentManager';\nexport * from './services';\nexport * from './shape';\nexport * from './components/renderer';\nexport * from './components/material/interface';\nexport * from './components/mesh/interface';\nexport * from './components/renderer';\nexport { container, createWorldContainer, lazyInject, lazyMultiInject, createEntity, Component, ComponentManager, IDENTIFIER, FrameGraphSystem, GeometrySystem, RendererSystem // InteractionSystem,\n, MaterialSystem, MeshSystem, SceneGraphSystem, CullableComponent, MeshComponent, TransformComponent, MaterialComponent, GeometryComponent, HierarchyComponent, isSafari, generateAABBFromVertices, PixelPickingPass, AST_TOKEN_TYPES, AST_NODE_TYPES, STORAGE_CLASS, Target, DefineValuePlaceholder };\n//# sourceMappingURL=index.js.map","export function isNumber(value) {\n return typeof value === 'number';\n}\n//# sourceMappingURL=is-number.js.map","import { vec3 } from 'gl-matrix';\nimport { isNumber } from './is-number';\nexport function getAngle(angle) {\n if (angle === undefined) {\n return 0;\n } else if (angle > 360 || angle < -360) {\n return angle % 360;\n }\n\n return angle;\n}\nexport function createVec3(x, y, z) {\n if (isNumber(x)) {\n return vec3.fromValues(x, y, z);\n }\n\n if (x.length === 3) {\n return vec3.clone(x);\n } // @ts-ignore\n\n\n return vec3.fromValues(x[0], x[1], x[2]);\n}\n//# sourceMappingURL=math.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport { vec3 } from 'gl-matrix';\nvar tmpVecA = vec3.create();\nexport var BoundingSphere = /*#__PURE__*/function () {\n function BoundingSphere(center, radius) {\n _classCallCheck(this, BoundingSphere);\n\n this.center = void 0;\n this.radius = void 0;\n this.center = center || vec3.create();\n this.radius = radius || 0.5;\n }\n\n _createClass(BoundingSphere, [{\n key: \"containsPoint\",\n value: function containsPoint(point) {\n vec3.sub(tmpVecA, point, this.center);\n return vec3.length(tmpVecA) < this.radius * this.radius;\n }\n }, {\n key: \"intersects\",\n value: function intersects(sphere) {\n vec3.sub(tmpVecA, sphere.center, this.center);\n var totalRadius = sphere.radius + this.radius;\n\n if (vec3.length(tmpVecA) <= totalRadius * totalRadius) {\n return true;\n }\n\n return false;\n }\n }]);\n\n return BoundingSphere;\n}();\n//# sourceMappingURL=BoundingSphere.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport { vec3 } from 'gl-matrix';\nvar tmpVecA = vec3.create();\nvar tmpVecB = vec3.create();\nvar tmpVecC = vec3.create();\nvar tmpVecD = vec3.create();\nvar tmpVecE = vec3.create();\n/**\n * 包含求交方法:\n * * intersectsShape(Shape, intersection) 返回交点和求交结果\n * @see https://github.com/playcanvas/engine/blob/master/src/shape/bounding-box.js#L161\n * @see https://github.com/mrdoob/three.js/blob/dev/src/math/Ray.js\n */\n\nexport var Ray = /*#__PURE__*/function () {\n function Ray(origin, direction) {\n _classCallCheck(this, Ray);\n\n this.origin = void 0;\n this.direction = void 0;\n this.origin = origin || vec3.create();\n this.direction = direction || vec3.fromValues(0, 0, -1);\n }\n\n _createClass(Ray, [{\n key: \"intersectsAABB\",\n value: function intersectsAABB(aabb, intersection) {\n return intersection ? this.intersectAABBWithIntersection(aabb, intersection) : this.intersectsAABBWithoutIntersection(aabb);\n }\n }, {\n key: \"intersectsSphere\",\n value: function intersectsSphere(sphere, intersection) {\n var m = vec3.sub(tmpVecA, this.origin, sphere.center);\n vec3.normalize(tmpVecB, vec3.copy(tmpVecB, this.direction));\n var b = vec3.dot(m, tmpVecB);\n var c = vec3.dot(m, m) - sphere.radius * sphere.radius; // exit if ray's origin outside of sphere (c > 0) and ray pointing away from s (b > 0)\n\n if (c > 0 && b > 0) {\n return null;\n }\n\n var discr = b * b - c; // a negative discriminant corresponds to ray missing sphere\n\n if (discr < 0) {\n return false;\n } // ray intersects sphere, compute smallest t value of intersection\n\n\n var t = Math.abs(-b - Math.sqrt(discr)); // if t is negative, ray started inside sphere so clamp t to zero\n\n if (intersection) {\n vec3.copy(intersection, this.direction);\n vec3.scaleAndAdd(intersection, this.origin, intersection, t);\n }\n\n return true;\n }\n }, {\n key: \"intersectsPlane\",\n value: function intersectsPlane(plane, intersection) {\n var t = (plane.distance - vec3.dot(plane.normal, this.origin)) / vec3.dot(plane.normal, this.direction);\n var intersects = t >= 0;\n\n if (intersects && intersection) {\n vec3.scaleAndAdd(intersection, this.origin, this.direction, t);\n }\n\n return intersects;\n }\n /**\n * faster than implements like Three.js\n * @see https://github.com/playcanvas/engine/blob/master/src/shape/bounding-box.js#L161\n */\n\n }, {\n key: \"intersectsAABBWithoutIntersection\",\n value: function intersectsAABBWithoutIntersection(aabb) {\n var diff = tmpVecA;\n var cross = tmpVecB;\n var prod = tmpVecC;\n var absDiff = tmpVecD;\n var absDir = tmpVecE;\n var rayDir = this.direction;\n vec3.sub(diff, this.origin, aabb.center);\n vec3.set(absDiff, Math.abs(diff[0]), Math.abs(diff[1]), Math.abs(diff[2]));\n vec3.mul(prod, diff, rayDir);\n\n if (absDiff[0] > aabb.halfExtents[0] && prod[0] >= 0 || absDiff[1] > aabb.halfExtents[1] && prod[1] >= 0 || absDiff[2] > aabb.halfExtents[2] && prod[2] >= 0) {\n return false;\n }\n\n vec3.set(absDir, Math.abs(rayDir[0]), Math.abs(rayDir[1]), Math.abs(rayDir[2]));\n vec3.cross(cross, rayDir, diff);\n vec3.set(cross, Math.abs(cross[0]), Math.abs(cross[1]), Math.abs(cross[2]));\n return !(cross[0] > aabb.halfExtents[1] * absDir[2] + aabb.halfExtents[2] * absDir[1] || cross[1] > aabb.halfExtents[0] * absDir[2] + aabb.halfExtents[2] * absDir[0] || cross[2] > aabb.halfExtents[0] * absDir[1] + aabb.halfExtents[1] * absDir[0]);\n }\n }, {\n key: \"intersectAABBWithIntersection\",\n value: function intersectAABBWithIntersection(aabb, intersection) {\n var tMin = vec3.copy(vec3.create(), aabb.getMin());\n vec3.sub(tMin, tMin, this.origin);\n var tMax = vec3.copy(vec3.create(), aabb.getMax());\n vec3.sub(tMax, tMax, this.origin);\n var dir = this.direction; // Ensure that we are not dividing it by zero\n\n if (dir[0] === 0) {\n tMin[0] = tMin[0] < 0 ? -Number.MAX_VALUE : Number.MAX_VALUE;\n tMax[0] = tMax[0] < 0 ? -Number.MAX_VALUE : Number.MAX_VALUE;\n } else {\n tMin[0] /= dir[0];\n tMax[0] /= dir[0];\n }\n\n if (dir[1] === 0) {\n tMin[1] = tMin[1] < 0 ? -Number.MAX_VALUE : Number.MAX_VALUE;\n tMax[1] = tMax[1] < 0 ? -Number.MAX_VALUE : Number.MAX_VALUE;\n } else {\n tMin[1] /= dir[1];\n tMax[1] /= dir[1];\n }\n\n if (dir[2] === 0) {\n tMin[2] = tMin[2] < 0 ? -Number.MAX_VALUE : Number.MAX_VALUE;\n tMax[2] = tMax[2] < 0 ? -Number.MAX_VALUE : Number.MAX_VALUE;\n } else {\n tMin[2] /= dir[2];\n tMax[2] /= dir[2];\n }\n\n var realMin = vec3.set(tmpVecC, Math.min(tMin[0], tMax[0]), Math.min(tMin[1], tMax[1]), Math.min(tMin[2], tMax[2]));\n var realMax = vec3.set(tmpVecD, Math.max(tMin[0], tMax[0]), Math.max(tMin[1], tMax[1]), Math.max(tMin[2], tMax[2]));\n var minMax = Math.min(Math.min(realMax[0], realMax[1]), realMax[2]);\n var maxMin = Math.max(Math.max(realMin[0], realMin[1]), realMin[2]);\n var intersects = minMax >= maxMin && maxMin >= 0;\n\n if (intersects) {\n vec3.copy(intersection, this.direction);\n vec3.scaleAndAdd(intersection, this.origin, intersection, maxMin);\n }\n\n return intersects;\n }\n }]);\n\n return Ray;\n}();\n//# sourceMappingURL=Ray.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport { mat4, vec3 } from 'gl-matrix';\n\n/**\n * 保存相机状态,便于后续在多个 Landmark 间移动\n */\nvar Landmark = /*#__PURE__*/function () {\n function Landmark(name, c) {\n _classCallCheck(this, Landmark);\n\n this.name = void 0;\n this.matrix = void 0;\n this.right = void 0;\n this.up = void 0;\n this.forward = void 0;\n this.position = void 0;\n this.focalPoint = void 0;\n this.distanceVector = void 0;\n this.distance = void 0;\n this.dollyingStep = void 0;\n this.azimuth = 0;\n this.elevation = 0;\n this.roll = 0;\n this.relAzimuth = 0;\n this.relElevation = 0;\n this.relRoll = 0;\n this.name = name;\n this.matrix = mat4.clone(c.matrix);\n this.right = vec3.clone(c.right);\n this.up = vec3.clone(c.up);\n this.forward = vec3.clone(c.forward);\n this.position = vec3.clone(c.position);\n this.focalPoint = vec3.clone(c.focalPoint);\n this.distanceVector = vec3.clone(c.distanceVector);\n this.azimuth = c.azimuth;\n this.elevation = c.elevation;\n this.roll = c.roll;\n this.relAzimuth = c.relAzimuth;\n this.relElevation = c.relElevation;\n this.relRoll = c.relRoll;\n this.dollyingStep = c.dollyingStep;\n this.distance = c.distance;\n }\n\n _createClass(Landmark, [{\n key: \"getPosition\",\n value: function getPosition() {\n return this.position;\n }\n }, {\n key: \"getFocalPoint\",\n value: function getFocalPoint() {\n return this.focalPoint;\n }\n }, {\n key: \"getRoll\",\n value: function getRoll() {\n return this.roll;\n }\n }, {\n key: \"retrieve\",\n value: function retrieve(c) {\n c.matrix = mat4.copy(c.matrix, this.matrix);\n c.right = vec3.copy(c.right, this.right);\n c.up = vec3.copy(c.up, this.up);\n c.forward = vec3.copy(c.forward, this.forward);\n c.position = vec3.copy(c.position, this.position);\n c.focalPoint = vec3.copy(c.focalPoint, this.focalPoint);\n c.distanceVector = vec3.copy(c.distanceVector, this.distanceVector);\n c.azimuth = this.azimuth;\n c.elevation = this.elevation;\n c.roll = this.roll;\n c.relAzimuth = this.relAzimuth;\n c.relElevation = this.relElevation;\n c.relRoll = this.relRoll;\n c.dollyingStep = this.dollyingStep;\n c.distance = this.distance;\n }\n }]);\n\n return Landmark;\n}();\n\nexport { Landmark as default };\n//# sourceMappingURL=Landmark.js.map","import _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _class, _class2, _descriptor, _class3, _temp;\n\nimport { Frustum, IDENTIFIER } from '@antv/g-webgpu-core';\nimport { mat3, mat4, quat, vec3, vec4 } from 'gl-matrix';\nimport { inject, injectable } from 'inversify';\nimport { createVec3, getAngle } from '../utils/math';\nimport Landmark from './Landmark';\nexport var CAMERA_TYPE;\n\n(function (CAMERA_TYPE) {\n CAMERA_TYPE[\"ORBITING\"] = \"ORBITING\";\n CAMERA_TYPE[\"EXPLORING\"] = \"EXPLORING\";\n CAMERA_TYPE[\"TRACKING\"] = \"TRACKING\";\n})(CAMERA_TYPE || (CAMERA_TYPE = {}));\n\nexport var CAMERA_TRACKING_MODE;\n\n(function (CAMERA_TRACKING_MODE) {\n CAMERA_TRACKING_MODE[\"DEFAULT\"] = \"DEFAULT\";\n CAMERA_TRACKING_MODE[\"ROTATIONAL\"] = \"ROTATIONAL\";\n CAMERA_TRACKING_MODE[\"TRANSLATIONAL\"] = \"TRANSLATIONAL\";\n CAMERA_TRACKING_MODE[\"CINEMATIC\"] = \"CINEMATIC\";\n})(CAMERA_TRACKING_MODE || (CAMERA_TRACKING_MODE = {}));\n\nexport var CAMERA_PROJECTION_MODE;\n\n(function (CAMERA_PROJECTION_MODE) {\n CAMERA_PROJECTION_MODE[\"ORTHOGRAPHIC\"] = \"ORTHOGRAPHIC\";\n CAMERA_PROJECTION_MODE[\"PERSPECTIVE\"] = \"PERSPECTIVE\";\n})(CAMERA_PROJECTION_MODE || (CAMERA_PROJECTION_MODE = {}));\n\nvar DEG_2_RAD = Math.PI / 180;\nvar RAD_2_DEG = 180 / Math.PI;\n/**\n * 参考「WebGL Insights - 23.Designing Cameras for WebGL Applications」,基于 Responsible Camera 思路设计\n * 保存相机参数,定义相机动作:\n * 1. dolly 沿 n 轴移动\n * 2. pan 沿 u v 轴移动\n * 3. rotate 以方位角旋转\n * 4. 移动到 Landmark,具有平滑的动画效果,其间禁止其他用户交互\n */\n\nexport var Camera = (_dec = injectable(), _dec2 = inject(IDENTIFIER.InteractorService), _dec(_class = (_class2 = (_temp = _class3 = /*#__PURE__*/function () {\n function Camera() {\n _classCallCheck(this, Camera);\n\n this.matrix = mat4.create();\n this.right = vec3.fromValues(1, 0, 0);\n this.up = vec3.fromValues(0, 1, 0);\n this.forward = vec3.fromValues(0, 0, 1);\n this.position = vec3.fromValues(0, 0, 1);\n this.focalPoint = vec3.fromValues(0, 0, 0);\n this.distanceVector = vec3.fromValues(0, 0, 0);\n this.distance = 1;\n this.azimuth = 0;\n this.elevation = 0;\n this.roll = 0;\n this.relAzimuth = 0;\n this.relElevation = 0;\n this.relRoll = 0;\n this.dollyingStep = 0;\n this.maxDistance = Infinity;\n this.minDistance = -Infinity;\n this.rotateWorld = false;\n\n _initializerDefineProperty(this, \"interactor\", _descriptor, this);\n\n this.fov = 30;\n this.near = 0.1;\n this.far = 10000;\n this.aspect = 1;\n this.left = void 0;\n this.rright = void 0;\n this.top = void 0;\n this.bottom = void 0;\n this.zoom = 1;\n this.perspective = mat4.create();\n this.view = void 0;\n this.following = undefined;\n this.type = CAMERA_TYPE.EXPLORING;\n this.trackingMode = CAMERA_TRACKING_MODE.DEFAULT;\n this.projectionMode = CAMERA_PROJECTION_MODE.PERSPECTIVE;\n this.frustum = new Frustum();\n this.landmarks = [];\n this.landmarkAnimationID = void 0;\n }\n\n _createClass(Camera, [{\n key: \"clone\",\n value: function clone() {\n var camera = new Camera();\n camera.setType(this.type, undefined);\n camera.interactor = this.interactor;\n return camera;\n }\n }, {\n key: \"getProjectionMode\",\n value: function getProjectionMode() {\n return this.projectionMode;\n }\n }, {\n key: \"getPerspective\",\n value: function getPerspective() {\n return this.perspective;\n }\n }, {\n key: \"getFrustum\",\n value: function getFrustum() {\n return this.frustum;\n }\n }, {\n key: \"getPosition\",\n value: function getPosition() {\n return this.position;\n }\n }, {\n key: \"setType\",\n value: function setType(type, trackingMode) {\n this.type = type;\n\n if (this.type === CAMERA_TYPE.EXPLORING) {\n this.setWorldRotation(true);\n } else {\n this.setWorldRotation(false);\n }\n\n this._getAngles();\n\n if (this.type === CAMERA_TYPE.TRACKING && trackingMode !== undefined) {\n this.setTrackingMode(trackingMode);\n }\n\n return this;\n }\n }, {\n key: \"setProjectionMode\",\n value: function setProjectionMode(projectionMode) {\n this.projectionMode = projectionMode;\n return this;\n }\n }, {\n key: \"setTrackingMode\",\n value: function setTrackingMode(trackingMode) {\n if (this.type !== CAMERA_TYPE.TRACKING) {\n throw new Error('Impossible to set a tracking mode if the camera is not of tracking type');\n }\n\n this.trackingMode = trackingMode;\n return this;\n }\n /**\n * If flag is true, it reverses the azimuth and elevation angles.\n * Subsequent calls to rotate, setAzimuth, setElevation,\n * changeAzimuth or changeElevation will cause the inverted effect.\n * setRoll or changeRoll is not affected by this method.\n *\n * This inversion is useful when one wants to simulate that the world\n * is moving, instead of the camera.\n *\n * By default the camera angles are not reversed.\n * @param {Boolean} flag the boolean flag to reverse the angles.\n */\n\n }, {\n key: \"setWorldRotation\",\n value: function setWorldRotation(flag) {\n this.rotateWorld = flag;\n\n this._getAngles();\n }\n /**\n * 计算 MV 矩阵,为相机矩阵的逆矩阵\n */\n\n }, {\n key: \"getViewTransform\",\n value: function getViewTransform() {\n return mat4.invert(mat4.create(), this.matrix);\n }\n }, {\n key: \"getWorldTransform\",\n value: function getWorldTransform() {\n return this.matrix;\n }\n /**\n * 设置相机矩阵\n */\n\n }, {\n key: \"setMatrix\",\n value: function setMatrix(matrix) {\n this.matrix = matrix;\n\n this._update();\n\n return this;\n }\n }, {\n key: \"setAspect\",\n value: function setAspect(aspect) {\n this.setPerspective(this.near, this.far, this.fov, aspect);\n return this;\n }\n /**\n * Sets an offset in a larger frustum, used in PixelPicking\n */\n\n }, {\n key: \"setViewOffset\",\n value: function setViewOffset(fullWidth, fullHeight, x, y, width, height) {\n this.aspect = fullWidth / fullHeight;\n\n if (this.view === undefined) {\n this.view = {\n enabled: true,\n fullWidth: 1,\n fullHeight: 1,\n offsetX: 0,\n offsetY: 0,\n width: 1,\n height: 1\n };\n }\n\n this.view.enabled = true;\n this.view.fullWidth = fullWidth;\n this.view.fullHeight = fullHeight;\n this.view.offsetX = x;\n this.view.offsetY = y;\n this.view.width = width;\n this.view.height = height;\n\n if (this.projectionMode === CAMERA_PROJECTION_MODE.PERSPECTIVE) {\n this.setPerspective(this.near, this.far, this.fov, this.aspect);\n } else {\n this.setOrthographic(this.left, this.rright, this.top, this.bottom, this.near, this.far);\n }\n\n return this;\n }\n }, {\n key: \"clearViewOffset\",\n value: function clearViewOffset() {\n if (this.view !== undefined) {\n this.view.enabled = false;\n }\n\n if (this.projectionMode === CAMERA_PROJECTION_MODE.PERSPECTIVE) {\n this.setPerspective(this.near, this.far, this.fov, this.aspect);\n } else {\n this.setOrthographic(this.left, this.rright, this.top, this.bottom, this.near, this.far);\n }\n\n return this;\n }\n }, {\n key: \"setPerspective\",\n value: function setPerspective(near, far, fov, aspect) {\n this.projectionMode = CAMERA_PROJECTION_MODE.PERSPECTIVE;\n this.fov = fov;\n this.near = near;\n this.far = far;\n this.aspect = aspect;\n mat4.perspective(this.perspective, this.fov * DEG_2_RAD, this.aspect, this.near, this.far);\n return this;\n }\n }, {\n key: \"setOrthographic\",\n value: function setOrthographic(l, r, t, b, near, far) {\n this.projectionMode = CAMERA_PROJECTION_MODE.ORTHOGRAPHIC;\n this.rright = r;\n this.left = l;\n this.top = t;\n this.bottom = b;\n this.near = near;\n this.far = far;\n var dx = (this.rright - this.left) / (2 * this.zoom);\n var dy = (this.top - this.bottom) / (2 * this.zoom);\n var cx = (this.rright + this.left) / 2;\n var cy = (this.top + this.bottom) / 2;\n var left = cx - dx;\n var right = cx + dx;\n var top = cy + dy;\n var bottom = cy - dy;\n\n if (this.view !== undefined && this.view.enabled) {\n var scaleW = (this.rright - this.left) / this.view.fullWidth / this.zoom;\n var scaleH = (this.top - this.bottom) / this.view.fullHeight / this.zoom;\n left += scaleW * this.view.offsetX;\n right = left + scaleW * this.view.width;\n top -= scaleH * this.view.offsetY;\n bottom = top - scaleH * this.view.height;\n }\n\n mat4.ortho(this.perspective, left, right, top, bottom, near, far);\n return this;\n }\n /**\n * 设置相机位置\n */\n\n }, {\n key: \"setPosition\",\n value: function setPosition(x, y, z) {\n this._setPosition(x, y, z);\n\n this.setFocalPoint(this.focalPoint);\n return this;\n }\n /**\n * 设置视点位置\n */\n\n }, {\n key: \"setFocalPoint\",\n value: function setFocalPoint(x, y, z) {\n var up = vec3.fromValues(0, 1, 0);\n this.focalPoint = createVec3(x, y, z);\n\n if (this.trackingMode === CAMERA_TRACKING_MODE.CINEMATIC) {\n var d = vec3.subtract(vec3.create(), this.focalPoint, this.position);\n x = d[0];\n y = d[1];\n z = d[2];\n var r = vec3.length(d);\n var el = Math.asin(y / r) * RAD_2_DEG;\n var az = 90 + Math.atan2(z, x) * RAD_2_DEG;\n var m = mat4.create();\n mat4.rotateY(m, m, az * DEG_2_RAD);\n mat4.rotateX(m, m, el * DEG_2_RAD);\n up = vec3.transformMat4(vec3.create(), [0, 1, 0], m);\n }\n\n mat4.invert(this.matrix, mat4.lookAt(mat4.create(), this.position, this.focalPoint, up));\n\n this._getAxes();\n\n this._getDistance();\n\n this._getAngles();\n\n return this;\n }\n /**\n * 固定当前视点,按指定距离放置相机\n */\n\n }, {\n key: \"setDistance\",\n value: function setDistance(d) {\n if (this.distance === d || d < 0) {\n return;\n }\n\n this.distance = d;\n\n if (this.distance < 0.0002) {\n this.distance = 0.0002;\n }\n\n this.dollyingStep = this.distance / 100;\n var pos = vec3.create();\n d = this.distance;\n var n = this.forward;\n var f = this.focalPoint;\n pos[0] = d * n[0] + f[0];\n pos[1] = d * n[1] + f[1];\n pos[2] = d * n[2] + f[2];\n\n this._setPosition(pos);\n\n return this;\n }\n }, {\n key: \"setMaxDistance\",\n value: function setMaxDistance(d) {\n this.maxDistance = d;\n return this;\n }\n }, {\n key: \"setMinDistance\",\n value: function setMinDistance(d) {\n this.minDistance = d;\n return this;\n }\n /**\n * Changes the initial azimuth of the camera\n */\n\n }, {\n key: \"changeAzimuth\",\n value: function changeAzimuth(az) {\n this.setAzimuth(this.azimuth + az);\n return this;\n }\n /**\n * Changes the initial elevation of the camera\n */\n\n }, {\n key: \"changeElevation\",\n value: function changeElevation(el) {\n this.setElevation(this.elevation + el);\n return this;\n }\n /**\n * Changes the initial roll of the camera\n */\n\n }, {\n key: \"changeRoll\",\n value: function changeRoll(rl) {\n this.setRoll(this.roll + rl);\n return this;\n }\n /**\n * 设置相机方位角,不同相机模式下需要重新计算相机位置或者是视点位置\n * @param {Number} el the azimuth in degrees\n */\n\n }, {\n key: \"setAzimuth\",\n value: function setAzimuth(az) {\n this.azimuth = getAngle(az);\n this.computeMatrix();\n\n this._getAxes();\n\n if (this.type === CAMERA_TYPE.ORBITING || this.type === CAMERA_TYPE.EXPLORING) {\n this._getPosition();\n } else if (this.type === CAMERA_TYPE.TRACKING) {\n this._getFocalPoint();\n }\n\n return this;\n }\n }, {\n key: \"getAzimuth\",\n value: function getAzimuth() {\n return this.azimuth;\n }\n /**\n * 设置相机方位角,不同相机模式下需要重新计算相机位置或者是视点位置\n * @param {Number} el the elevation in degrees\n */\n\n }, {\n key: \"setElevation\",\n value: function setElevation(el) {\n this.elevation = getAngle(el);\n this.computeMatrix();\n\n this._getAxes();\n\n if (this.type === CAMERA_TYPE.ORBITING || this.type === CAMERA_TYPE.EXPLORING) {\n this._getPosition();\n } else if (this.type === CAMERA_TYPE.TRACKING) {\n this._getFocalPoint();\n }\n\n return this;\n }\n /**\n * 设置相机方位角,不同相机模式下需要重新计算相机位置或者是视点位置\n * @param {Number} angle the roll angle\n */\n\n }, {\n key: \"setRoll\",\n value: function setRoll(angle) {\n this.roll = getAngle(angle);\n this.computeMatrix();\n\n this._getAxes();\n\n if (this.type === CAMERA_TYPE.ORBITING || this.type === CAMERA_TYPE.EXPLORING) {\n this._getPosition();\n } else if (this.type === CAMERA_TYPE.TRACKING) {\n this._getFocalPoint();\n }\n\n return this;\n }\n /**\n * Changes the azimuth and elevation with respect to the current camera axes\n * @param {Number} azimuth the relative azimuth\n * @param {Number} elevation the relative elevation\n * @param {Number} roll the relative roll\n */\n\n }, {\n key: \"rotate\",\n value: function rotate(azimuth, elevation, roll) {\n if (this.type === CAMERA_TYPE.EXPLORING) {\n azimuth = getAngle(azimuth);\n elevation = getAngle(elevation);\n roll = getAngle(roll);\n var rotX = quat.setAxisAngle(quat.create(), [1, 0, 0], (this.rotateWorld ? 1 : -1) * elevation * DEG_2_RAD);\n var rotY = quat.setAxisAngle(quat.create(), [0, 1, 0], (this.rotateWorld ? 1 : -1) * azimuth * DEG_2_RAD);\n var rotZ = quat.setAxisAngle(quat.create(), [0, 0, 1], roll * DEG_2_RAD);\n var rotQ = quat.multiply(quat.create(), rotY, rotX);\n rotQ = quat.multiply(quat.create(), rotQ, rotZ);\n var rotMatrix = mat4.fromQuat(mat4.create(), rotQ);\n mat4.translate(this.matrix, this.matrix, [0, 0, -this.distance]);\n mat4.multiply(this.matrix, this.matrix, rotMatrix);\n mat4.translate(this.matrix, this.matrix, [0, 0, this.distance]);\n } else {\n if (Math.abs(this.elevation + elevation) > 90) {\n return;\n }\n\n this.relElevation = getAngle(elevation);\n this.relAzimuth = getAngle(azimuth);\n this.relRoll = getAngle(roll);\n this.elevation += this.relElevation;\n this.azimuth += this.relAzimuth;\n this.roll += this.relRoll;\n this.computeMatrix();\n }\n\n this._getAxes();\n\n if (this.type === CAMERA_TYPE.ORBITING || this.type === CAMERA_TYPE.EXPLORING) {\n this._getPosition();\n } else if (this.type === CAMERA_TYPE.TRACKING) {\n this._getFocalPoint();\n }\n\n this._update();\n\n return this;\n }\n /**\n * 沿水平(right) & 垂直(up)平移相机\n */\n\n }, {\n key: \"pan\",\n value: function pan(tx, ty) {\n var coords = createVec3(tx, ty, 0);\n var pos = vec3.clone(this.position);\n vec3.add(pos, pos, vec3.scale(vec3.create(), this.right, coords[0]));\n vec3.add(pos, pos, vec3.scale(vec3.create(), this.up, coords[1]));\n\n this._setPosition(pos);\n\n return this;\n }\n /**\n * 沿 n 轴移动,当距离视点远时移动速度较快,离视点越近速度越慢\n */\n\n }, {\n key: \"dolly\",\n value: function dolly(value) {\n var n = this.forward;\n var pos = vec3.clone(this.position);\n var step = value * this.dollyingStep;\n var updatedDistance = this.distance + value * this.dollyingStep; // 限制视点距离范围\n\n step = Math.max(Math.min(updatedDistance, this.maxDistance), this.minDistance) - this.distance;\n pos[0] += step * n[0];\n pos[1] += step * n[1];\n pos[2] += step * n[2];\n\n this._setPosition(pos);\n\n if (this.type === CAMERA_TYPE.ORBITING || this.type === CAMERA_TYPE.EXPLORING) {\n // 重新计算视点距离\n this._getDistance();\n } else if (this.type === CAMERA_TYPE.TRACKING) {\n // 保持视距,移动视点位置\n vec3.add(this.focalPoint, pos, this.distanceVector);\n }\n\n return this;\n }\n }, {\n key: \"createLandmark\",\n value: function createLandmark(name, params) {\n var camera = this.clone();\n camera.setPosition(params.position);\n camera.setFocalPoint(params.focalPoint);\n\n if (params.roll !== undefined) {\n camera.setRoll(params.roll);\n }\n\n var landmark = new Landmark(name, camera);\n this.landmarks.push(landmark);\n return landmark;\n }\n }, {\n key: \"setLandmark\",\n value: function setLandmark(name) {\n var landmark = new Landmark(name, this);\n this.landmarks.push(landmark);\n return this;\n }\n }, {\n key: \"gotoLandmark\",\n value: function gotoLandmark(name) {\n var _this = this;\n\n var duration = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1000;\n var landmark = this.landmarks.find(function (l) {\n return l.name === name;\n });\n\n if (landmark) {\n if (duration === 0) {\n landmark.retrieve(this);\n return;\n }\n\n if (this.landmarkAnimationID !== undefined) {\n window.cancelAnimationFrame(this.landmarkAnimationID);\n } // TODO: do not process events during animation\n\n\n this.interactor.disconnect();\n var destPosition = landmark.getPosition();\n var destFocalPoint = landmark.getFocalPoint();\n var destRoll = landmark.getRoll();\n var timeStart;\n\n var animate = function animate(timestamp) {\n if (timeStart === undefined) {\n timeStart = timestamp;\n }\n\n var elapsed = timestamp - timeStart; // TODO: use better ease function\n\n var t = (1 - Math.cos(elapsed / duration * Math.PI)) / 2;\n var interFocalPoint = vec3.create();\n var interPosition = vec3.create();\n var interRoll = 0;\n vec3.lerp(interFocalPoint, _this.focalPoint, destFocalPoint, t);\n vec3.lerp(interPosition, _this.position, destPosition, t);\n interRoll = _this.roll * (1 - t) + destRoll * t;\n\n _this.setFocalPoint(interFocalPoint);\n\n _this.setPosition(interPosition);\n\n _this.setRoll(interRoll);\n\n _this.computeMatrix();\n\n var dist = vec3.dist(interFocalPoint, destFocalPoint) + vec3.dist(interPosition, destPosition);\n\n if (dist > 0.01) {//\n } else {\n _this.setFocalPoint(interFocalPoint);\n\n _this.setPosition(interPosition);\n\n _this.setRoll(interRoll);\n\n _this.computeMatrix();\n\n _this.interactor.connect();\n\n return;\n }\n\n if (elapsed < duration) {\n _this.landmarkAnimationID = window.requestAnimationFrame(animate);\n }\n };\n\n window.requestAnimationFrame(animate);\n }\n }\n /**\n * 根据相机矩阵重新计算各种相机参数\n */\n\n }, {\n key: \"_update\",\n value: function _update() {\n this._getAxes();\n\n this._getPosition();\n\n this._getDistance();\n\n this._getAngles();\n }\n /**\n * 计算相机矩阵\n */\n\n }, {\n key: \"computeMatrix\",\n value: function computeMatrix() {\n var rotX;\n var rotY; // 使用四元数描述 3D 旋转\n // @see https://xiaoiver.github.io/coding/2018/12/28/Camera-%E8%AE%BE%E8%AE%A1-%E4%B8%80.html\n\n var rotZ = quat.setAxisAngle(quat.create(), [0, 0, 1], this.roll * DEG_2_RAD);\n mat4.identity(this.matrix); // only consider HCS for EXPLORING and ORBITING cameras\n\n rotX = quat.setAxisAngle(quat.create(), [1, 0, 0], (this.rotateWorld && this.type !== CAMERA_TYPE.TRACKING || this.type === CAMERA_TYPE.TRACKING ? 1 : -1) * this.elevation * DEG_2_RAD);\n rotY = quat.setAxisAngle(quat.create(), [0, 1, 0], (this.rotateWorld && this.type !== CAMERA_TYPE.TRACKING || this.type === CAMERA_TYPE.TRACKING ? 1 : -1) * this.azimuth * DEG_2_RAD);\n var rotQ = quat.multiply(quat.create(), rotY, rotX);\n rotQ = quat.multiply(quat.create(), rotQ, rotZ);\n var rotMatrix = mat4.fromQuat(mat4.create(), rotQ);\n\n if (this.type === CAMERA_TYPE.ORBITING || this.type === CAMERA_TYPE.EXPLORING) {\n mat4.translate(this.matrix, this.matrix, this.focalPoint);\n mat4.multiply(this.matrix, this.matrix, rotMatrix);\n mat4.translate(this.matrix, this.matrix, [0, 0, this.distance]);\n } else if (this.type === CAMERA_TYPE.TRACKING) {\n mat4.translate(this.matrix, this.matrix, this.position);\n mat4.multiply(this.matrix, this.matrix, rotMatrix);\n }\n }\n /**\n * Sets the camera position in the camera matrix\n */\n\n }, {\n key: \"_setPosition\",\n value: function _setPosition(x, y, z) {\n this.position = createVec3(x, y, z);\n var m = this.matrix;\n m[12] = this.position[0];\n m[13] = this.position[1];\n m[14] = this.position[2];\n m[15] = 1;\n }\n /**\n * Recalculates axes based on the current matrix\n */\n\n }, {\n key: \"_getAxes\",\n value: function _getAxes() {\n vec3.copy(this.right, createVec3(vec4.transformMat4(vec4.create(), [1, 0, 0, 0], this.matrix)));\n vec3.copy(this.up, createVec3(vec4.transformMat4(vec4.create(), [0, 1, 0, 0], this.matrix)));\n vec3.copy(this.forward, createVec3(vec4.transformMat4(vec4.create(), [0, 0, 1, 0], this.matrix)));\n vec3.normalize(this.right, this.right);\n vec3.normalize(this.up, this.up);\n vec3.normalize(this.forward, this.forward);\n }\n /**\n * Recalculates euler angles based on the current state\n */\n\n }, {\n key: \"_getAngles\",\n value: function _getAngles() {\n // Recalculates angles\n var x = this.distanceVector[0];\n var y = this.distanceVector[1];\n var z = this.distanceVector[2];\n var r = vec3.length(this.distanceVector); // FAST FAIL: If there is no distance we cannot compute angles\n\n if (r === 0) {\n this.elevation = 0;\n this.azimuth = 0;\n return;\n }\n\n if (this.type === CAMERA_TYPE.TRACKING) {\n this.elevation = Math.asin(y / r) * RAD_2_DEG;\n this.azimuth = Math.atan2(-x, -z) * RAD_2_DEG;\n } else {\n if (this.rotateWorld) {\n this.elevation = Math.asin(y / r) * RAD_2_DEG;\n this.azimuth = Math.atan2(-x, -z) * RAD_2_DEG;\n } else {\n this.elevation = -Math.asin(y / r) * RAD_2_DEG;\n this.azimuth = -Math.atan2(-x, -z) * RAD_2_DEG;\n }\n }\n }\n /**\n * 重新计算相机位置,只有 ORBITING 模式相机位置才会发生变化\n */\n\n }, {\n key: \"_getPosition\",\n value: function _getPosition() {\n vec3.copy(this.position, createVec3(vec4.transformMat4(vec4.create(), [0, 0, 0, 1], this.matrix))); // 相机位置变化,需要重新计算视距\n\n this._getDistance();\n }\n /**\n * 重新计算视点,只有 TRACKING 模式视点才会发生变化\n */\n\n }, {\n key: \"_getFocalPoint\",\n value: function _getFocalPoint() {\n vec3.transformMat3(this.distanceVector, [0, 0, -this.distance], mat3.fromMat4(mat3.create(), this.matrix));\n vec3.add(this.focalPoint, this.position, this.distanceVector); // 视点变化,需要重新计算视距\n\n this._getDistance();\n }\n /**\n * 重新计算视距\n */\n\n }, {\n key: \"_getDistance\",\n value: function _getDistance() {\n this.distanceVector = vec3.subtract(vec3.create(), this.focalPoint, this.position);\n this.distance = vec3.length(this.distanceVector);\n this.dollyingStep = this.distance / 100;\n }\n }]);\n\n return Camera;\n}(), _class3.ProjectionMode = {\n ORTHOGRAPHIC: 'ORTHOGRAPHIC',\n PERSPECTIVE: 'PERSPECTIVE'\n}, _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"interactor\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=Camera.js.map","import _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _class, _class2, _descriptor, _class3, _temp;\n\nimport { IDENTIFIER } from '@antv/g-webgpu-core';\nimport { inject, injectable } from 'inversify';\nexport var Geometry = (_dec = injectable(), _dec2 = inject(IDENTIFIER.GeometryComponentManager), _dec(_class = (_class2 = (_temp = _class3 = /*#__PURE__*/function () {\n function Geometry() {\n _classCallCheck(this, Geometry);\n\n this.config = void 0;\n\n _initializerDefineProperty(this, \"geometry\", _descriptor, this);\n\n this.entity = void 0;\n this.component = void 0;\n }\n\n _createClass(Geometry, [{\n key: \"getEntity\",\n value: function getEntity() {\n return this.entity;\n }\n }, {\n key: \"getComponent\",\n value: function getComponent() {\n return this.component;\n }\n }, {\n key: \"setConfig\",\n value: function setConfig(config) {\n this.config = config;\n }\n }, {\n key: \"setEntity\",\n value: function setEntity(entity) {\n this.entity = entity;\n this.component = this.geometry.create(entity);\n this.component.entity = entity;\n this.onEntityCreated();\n }\n }, {\n key: \"onEntityCreated\",\n value: function onEntityCreated() {//\n }\n }]);\n\n return Geometry;\n}(), _class3.BOX = 'box', _class3.SPHERE = 'sphere', _class3.PLANE = 'plane', _class3.MERGED = 'merged', _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"geometry\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=index.js.map","export function createCanvas() {\n if (typeof document !== 'undefined') {\n return document.createElement('canvas');\n } else {\n throw new Error('Cannot create a canvas in this context');\n }\n}\n//# sourceMappingURL=canvas.js.map","var toString = {}.toString;\n\nvar isType = function isType(value, type) {\n return toString.call(value) === '[object ' + type + ']';\n};\n\nexport default isType;\n//# sourceMappingURL=is-type.js.map","import _typeof from \"@babel/runtime/helpers/typeof\";\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n/** `Object#toString` result references. */\n\nvar argsTag = '[object Arguments]';\nvar arrayTag = '[object Array]';\nvar boolTag = '[object Boolean]';\nvar dateTag = '[object Date]';\nvar errorTag = '[object Error]';\nvar funcTag = '[object Function]';\nvar mapTag = '[object Map]';\nvar numberTag = '[object Number]';\nvar objectTag = '[object Object]';\nvar regexpTag = '[object RegExp]';\nvar setTag = '[object Set]';\nvar stringTag = '[object String]';\nvar weakMapTag = '[object WeakMap]';\nvar arrayBufferTag = '[object ArrayBuffer]';\nvar dataViewTag = '[object DataView]';\nvar float32Tag = '[object Float32Array]';\nvar float64Tag = '[object Float64Array]';\nvar int8Tag = '[object Int8Array]';\nvar int16Tag = '[object Int16Array]';\nvar int32Tag = '[object Int32Array]';\nvar uint8Tag = '[object Uint8Array]';\nvar uint8ClampedTag = '[object Uint8ClampedArray]';\nvar uint16Tag = '[object Uint16Array]';\nvar uint32Tag = '[object Uint32Array]';\n/** Used to identify `toStringTag` values of typed arrays. */\n\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] = typedArrayTags[int8Tag] = typedArrayTags[int16Tag] = typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] = typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] = typedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] = typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] = typedArrayTags[dataViewTag] = typedArrayTags[dateTag] = typedArrayTags[errorTag] = typedArrayTags[funcTag] = typedArrayTags[mapTag] = typedArrayTags[numberTag] = typedArrayTags[objectTag] = typedArrayTags[regexpTag] = typedArrayTags[setTag] = typedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false;\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\n\nfunction baseUnary(func) {\n return function (value) {\n return func(value);\n };\n}\n/** Used for built-in method references. */\n\n\nvar objectProto = Object.prototype;\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\n\nvar objectToString = objectProto.toString;\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\n\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[objectToString.call(value)];\n}\n\nfunction isLength(value) {\n return typeof value === 'number' && value > -1 && value % 1 === 0 && value <= MAX_SAFE_INTEGER;\n}\n\nfunction isObjectLike(value) {\n return !!value && _typeof(value) === 'object';\n}\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\n\n\nexport var isTypedArray = baseIsTypedArray;\n//# sourceMappingURL=is-typedarray.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _class, _class2, _descriptor, _descriptor2, _temp;\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { AST_TOKEN_TYPES, createEntity, DefineValuePlaceholder, IDENTIFIER, STORAGE_CLASS, Target } from '@antv/g-webgpu-core'; // tslint:disable-next-line:no-submodule-imports\n\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { inject, injectable } from 'inversify';\nimport { createCanvas } from './utils/canvas';\nimport isArray from './utils/is-array';\nimport { isNumber } from './utils/is-number';\nimport { isTypedArray } from './utils/is-typedarray';\nexport var Kernel = (_dec = injectable(), _dec2 = inject(IDENTIFIER.RenderEngine), _dec3 = inject(IDENTIFIER.ConfigService), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function () {\n function Kernel() {\n _classCallCheck(this, Kernel);\n\n _initializerDefineProperty(this, \"engine\", _descriptor, this);\n\n _initializerDefineProperty(this, \"configService\", _descriptor2, this);\n\n this.entity = createEntity();\n this.model = void 0;\n this.dirty = true;\n this.compiledBundle = void 0;\n this.initPromise = void 0;\n }\n\n _createClass(Kernel, [{\n key: \"init\",\n value: function init() {\n var _this$configService$g = this.configService.get(),\n canvas = _this$configService$g.canvas,\n engineOptions = _this$configService$g.engineOptions;\n\n this.initPromise = this.engine.init(_objectSpread({\n canvas: canvas || createCanvas(),\n swapChainFormat: WebGPUConstants.TextureFormat.BGRA8Unorm,\n antialiasing: false\n }, engineOptions));\n }\n }, {\n key: \"setBundle\",\n value: function setBundle(bundle) {\n // deep clone\n this.compiledBundle = JSON.parse(JSON.stringify(bundle));\n }\n }, {\n key: \"setDispatch\",\n value: function setDispatch(dispatch) {\n if (this.compiledBundle.context) {\n this.compiledBundle.context.dispatch = dispatch;\n }\n\n return this;\n }\n }, {\n key: \"setMaxIteration\",\n value: function setMaxIteration(maxIteration) {\n if (this.compiledBundle.context) {\n this.compiledBundle.context.maxIteration = maxIteration;\n }\n\n return this;\n }\n }, {\n key: \"setBinding\",\n value: function setBinding(name, data) {\n var _this = this;\n\n if (typeof name === 'string') {\n var isNumberLikeData = isNumber(data) || isTypedArray(data) || isArray(data);\n\n if (this.compiledBundle && this.compiledBundle.context) {\n // set define, eg. setBinding('MAX_LENGTH', 10)\n var existedDefine = this.compiledBundle.context.defines.find(function (b) {\n return b.name === name;\n });\n\n if (existedDefine) {\n existedDefine.value = data;\n return this;\n } // set uniform\n\n\n var existedBinding = this.compiledBundle.context.uniforms.find(function (b) {\n return b.name === name;\n });\n\n if (existedBinding) {\n // update uniform or buffer\n if (isNumberLikeData) {\n // @ts-ignore\n existedBinding.data = data;\n existedBinding.isReferer = false;\n\n if (existedBinding.storageClass === STORAGE_CLASS.Uniform) {\n if (this.model) {\n // @ts-ignore\n this.model.updateUniform(name, data);\n }\n } else {\n if (this.model) {\n // @ts-ignore\n this.model.updateBuffer(name, data);\n }\n }\n } else {\n // update with another kernel\n existedBinding.isReferer = true; // @ts-ignore\n\n existedBinding.data = data;\n }\n }\n }\n } else {\n Object.keys(name).forEach(function (key) {\n _this.setBinding(key, name[key]);\n });\n }\n\n return this;\n }\n }, {\n key: \"execute\",\n value: function () {\n var _execute = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {\n var _this2 = this;\n\n var iteration,\n i,\n _args = arguments;\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n iteration = _args.length > 0 && _args[0] !== undefined ? _args[0] : 1;\n\n if (!this.dirty) {\n _context.next = 6;\n break;\n }\n\n if (this.compiledBundle.context) {\n if (iteration > 1) {\n this.compiledBundle.context.maxIteration = iteration;\n } else {\n this.compiledBundle.context.maxIteration++;\n }\n }\n\n _context.next = 5;\n return this.compile();\n\n case 5:\n this.dirty = false;\n\n case 6:\n this.engine.beginFrame(); // 首先开启当前 frame 的 compute pass\n\n this.engine.clear({});\n\n if (this.compiledBundle.context) {\n this.compiledBundle.context.uniforms.filter(function (_ref) {\n var isReferer = _ref.isReferer;\n return isReferer;\n }).forEach(function (_ref2) {\n var data = _ref2.data,\n name = _ref2.name;\n\n // @ts-ignore\n _this2.model.confirmInput(data.model, name);\n });\n }\n\n for (i = 0; i < iteration; i++) {\n this.model.run();\n }\n\n this.engine.endFrame();\n return _context.abrupt(\"return\", this);\n\n case 12:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function execute() {\n return _execute.apply(this, arguments);\n }\n\n return execute;\n }()\n /**\n * read output from GPUBuffer\n */\n\n }, {\n key: \"getOutput\",\n value: function () {\n var _getOutput = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2() {\n return _regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n return _context2.abrupt(\"return\", this.model.readData());\n\n case 1:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this);\n }));\n\n function getOutput() {\n return _getOutput.apply(this, arguments);\n }\n\n return getOutput;\n }()\n }, {\n key: \"compile\",\n value: function () {\n var _compile = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee3() {\n var context, target, shader;\n return _regeneratorRuntime.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n _context3.next = 2;\n return this.initPromise;\n\n case 2:\n context = _objectSpread({}, this.compiledBundle.context);\n target = this.engine.supportWebGPU ? this.engine.useWGSL ? Target.WGSL : Target.GLSL450 : Target.GLSL100;\n shader = this.compiledBundle.shaders[target]; // this.bindings?.forEach(({ name, data }) => {\n // if (name === name.toUpperCase()) {\n // const define = context.defines.find((d) => d.name === name);\n // if (define) {\n // // @ts-ignore\n // define.value = data;\n // }\n // }\n // });\n // 生成运行时 define\n\n context.defines.filter(function (define) {\n return define.runtime;\n }).forEach(function (define) {\n var valuePlaceHolder = \"\".concat(DefineValuePlaceholder).concat(define.name);\n shader = shader.replace(valuePlaceHolder, \"\".concat(define.value));\n });\n context.shader = shader; // 添加 uniform 绑定的数据\n\n context.uniforms.forEach(function (uniform) {\n // const binding = this.bindings.find((b) => b.name === uniform.name);\n // if (binding) {\n // // @ts-ignore\n // uniform.data = binding.referer || binding.data;\n // // @ts-ignore\n // uniform.isReferer = !!binding.referer;\n // }\n // 未指定数据,尝试根据 uniform 类型初始化\n if (!uniform.data) {\n if (uniform.storageClass === STORAGE_CLASS.StorageBuffer) {\n var sizePerElement = 1;\n\n if (uniform.type === AST_TOKEN_TYPES.FloatArray) {\n sizePerElement = 1;\n } else if (uniform.type === AST_TOKEN_TYPES.Vector4FloatArray) {\n sizePerElement = 4;\n }\n\n uniform.data = new Float32Array(context.output.length * sizePerElement).fill(0);\n }\n }\n }); // } else if (uniform.type === 'image2D') {\n // // @ts-ignore\n // buffer.data = new Uint8ClampedArray(context.output.length!).fill(0);\n // }\n\n this.compiledBundle.context = context;\n _context3.next = 11;\n return this.engine.createComputeModel(this.compiledBundle.context);\n\n case 11:\n this.model = _context3.sent;\n\n case 12:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, this);\n }));\n\n function compile() {\n return _compile.apply(this, arguments);\n }\n\n return compile;\n }()\n }]);\n\n return Kernel;\n}(), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"engine\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"configService\", [_dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=Kernel.js.map","import _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _class, _class2, _descriptor, _class3, _temp;\n\nimport { IDENTIFIER } from '@antv/g-webgpu-core';\nimport { inject, injectable } from 'inversify';\nexport var Material = (_dec = injectable(), _dec2 = inject(IDENTIFIER.MaterialComponentManager), _dec(_class = (_class2 = (_temp = _class3 = /*#__PURE__*/function () {\n function Material() {\n _classCallCheck(this, Material);\n\n this.config = void 0;\n\n _initializerDefineProperty(this, \"material\", _descriptor, this);\n\n this.entity = void 0;\n this.component = void 0;\n }\n\n _createClass(Material, [{\n key: \"getEntity\",\n value: function getEntity() {\n return this.entity;\n }\n }, {\n key: \"getComponent\",\n value: function getComponent() {\n return this.component;\n }\n }, {\n key: \"setConfig\",\n value: function setConfig(config) {\n this.config = config;\n }\n }, {\n key: \"setEntity\",\n value: function setEntity(entity, type) {\n this.entity = entity;\n this.component = this.material.create(entity);\n this.component.entity = entity;\n this.component.type = type;\n this.onEntityCreated();\n }\n }, {\n key: \"onEntityCreated\",\n value: function onEntityCreated() {//\n }\n }]);\n\n return Material;\n}(), _class3.BASIC = 'basic', _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"material\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=index.js.map","import _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _dec4, _dec5, _dec6, _class, _class2, _descriptor, _descriptor2, _descriptor3, _descriptor4, _class3, _temp;\n\nimport { IDENTIFIER } from '@antv/g-webgpu-core';\nimport { inject, injectable, named } from 'inversify';\nexport var Renderable = (_dec = injectable(), _dec2 = inject(IDENTIFIER.MeshComponentManager), _dec3 = inject(IDENTIFIER.CullableComponentManager), _dec4 = inject(IDENTIFIER.TransformComponentManager), _dec5 = inject(IDENTIFIER.Systems), _dec6 = named(IDENTIFIER.SceneGraphSystem), _dec(_class = (_class2 = (_temp = _class3 = /*#__PURE__*/function () {\n function Renderable() {\n _classCallCheck(this, Renderable);\n\n this.attributes = {};\n this.config = void 0;\n\n _initializerDefineProperty(this, \"mesh\", _descriptor, this);\n\n _initializerDefineProperty(this, \"cullable\", _descriptor2, this);\n\n _initializerDefineProperty(this, \"transform\", _descriptor3, this);\n\n _initializerDefineProperty(this, \"sceneGraphSystem\", _descriptor4, this);\n\n this.meshComponent = void 0;\n this.transformComponent = void 0;\n this.entity = void 0;\n }\n\n _createClass(Renderable, [{\n key: \"getEntity\",\n value: function getEntity() {\n return this.entity;\n }\n }, {\n key: \"getTransformComponent\",\n value: function getTransformComponent() {\n return this.transformComponent;\n }\n }, {\n key: \"getMeshComponent\",\n value: function getMeshComponent() {\n return this.meshComponent;\n }\n }, {\n key: \"setConfig\",\n value: function setConfig(config) {\n this.config = config;\n }\n }, {\n key: \"setEntity\",\n value: function setEntity(entity) {\n this.entity = entity;\n this.cullable.create(entity);\n this.meshComponent = this.mesh.create(entity);\n this.transformComponent = this.transform.create(entity);\n this.onEntityCreated();\n }\n }, {\n key: \"setMaterial\",\n value: function setMaterial(material) {\n this.meshComponent.material = material;\n return this;\n }\n }, {\n key: \"setGeometry\",\n value: function setGeometry(geometry) {\n this.meshComponent.geometry = geometry;\n return this;\n }\n }, {\n key: \"setAttributes\",\n value: function setAttributes(attributes) {\n var _this = this;\n\n Object.keys(attributes).forEach(function (name) {\n if (attributes[name] !== undefined && attributes[name] !== _this.attributes[name]) {\n _this.onAttributeChanged({\n name: name,\n data: attributes[name]\n });\n\n _this.attributes[name] = attributes[name];\n }\n });\n }\n }, {\n key: \"setVisible\",\n value: function setVisible(visible) {\n var _this2 = this;\n\n this.meshComponent.visible = visible;\n this.meshComponent.children.forEach(function (childEntity) {\n var child = _this2.mesh.getComponentByEntity(childEntity);\n\n if (child) {\n child.visible = visible;\n }\n });\n return this;\n }\n }, {\n key: \"isVisible\",\n value: function isVisible() {\n return this.meshComponent.visible;\n }\n }, {\n key: \"attach\",\n value: function attach(parentRenderable) {\n this.sceneGraphSystem.attach(this.entity, parentRenderable.entity);\n return this;\n }\n }, {\n key: \"detach\",\n value: function detach() {\n this.sceneGraphSystem.detach(this.entity);\n return this;\n }\n }, {\n key: \"detachChildren\",\n value: function detachChildren() {\n this.sceneGraphSystem.detachChildren(this.entity);\n return this;\n }\n }, {\n key: \"onEntityCreated\",\n value: function onEntityCreated() {//\n }\n }, {\n key: \"onAttributeChanged\",\n value: function onAttributeChanged(_ref) {\n var name = _ref.name,\n data = _ref.data;\n\n if (this.meshComponent && this.meshComponent.material) {\n this.meshComponent.material.setUniform(this.convertAttributeName2UniformName(name), data);\n }\n }\n }, {\n key: \"convertAttributeName2UniformName\",\n value: function convertAttributeName2UniformName(attributeName) {\n return attributeName;\n }\n }]);\n\n return Renderable;\n}(), _class3.POINT = 'point', _class3.LINE = 'line', _class3.GRID = 'grid', _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"mesh\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"cullable\", [_dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, \"transform\", [_dec4], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor4 = _applyDecoratedDescriptor(_class2.prototype, \"sceneGraphSystem\", [_dec5, _dec6], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=Renderable.js.map","import _defineProperty from \"@babel/runtime/helpers/defineProperty\";\n\nvar _primitiveMap, _usageMap, _dataTypeMap, _formatMap, _mipmapMap, _filterMap, _wrapModeMap, _colorSpaceMap, _depthFuncMap, _blendEquationMap, _blendFuncMap, _stencilFuncMap, _stencilOpMap, _cullFaceMap;\n\n/**\n * @desc 由于 regl 使用大量字符串而非 WebGL 常量,因此需要映射\n */\nimport { gl } from '@antv/g-webgpu-core';\n// @see https://github.com/regl-project/regl/blob/gh-pages/lib/constants/primitives.json\nexport var primitiveMap = (_primitiveMap = {}, _defineProperty(_primitiveMap, gl.POINTS, 'points'), _defineProperty(_primitiveMap, gl.LINES, 'lines'), _defineProperty(_primitiveMap, gl.LINE_LOOP, 'line loop'), _defineProperty(_primitiveMap, gl.LINE_STRIP, 'line strip'), _defineProperty(_primitiveMap, gl.TRIANGLES, 'triangles'), _defineProperty(_primitiveMap, gl.TRIANGLE_FAN, 'triangle fan'), _defineProperty(_primitiveMap, gl.TRIANGLE_STRIP, 'triangle strip'), _primitiveMap);\nexport var usageMap = (_usageMap = {}, _defineProperty(_usageMap, gl.STATIC_DRAW, 'static'), _defineProperty(_usageMap, gl.DYNAMIC_DRAW, 'dynamic'), _defineProperty(_usageMap, gl.STREAM_DRAW, 'stream'), _usageMap);\nexport var dataTypeMap = (_dataTypeMap = {}, _defineProperty(_dataTypeMap, gl.BYTE, 'int8'), _defineProperty(_dataTypeMap, gl.UNSIGNED_INT, 'int16'), _defineProperty(_dataTypeMap, gl.INT, 'int32'), _defineProperty(_dataTypeMap, gl.UNSIGNED_BYTE, 'uint8'), _defineProperty(_dataTypeMap, gl.UNSIGNED_SHORT, 'uint16'), _defineProperty(_dataTypeMap, gl.UNSIGNED_INT, 'uint32'), _defineProperty(_dataTypeMap, gl.FLOAT, 'float'), _dataTypeMap);\nexport var formatMap = (_formatMap = {}, _defineProperty(_formatMap, gl.ALPHA, 'alpha'), _defineProperty(_formatMap, gl.LUMINANCE, 'luminance'), _defineProperty(_formatMap, gl.LUMINANCE_ALPHA, 'luminance alpha'), _defineProperty(_formatMap, gl.RGB, 'rgb'), _defineProperty(_formatMap, gl.RGBA, 'rgba'), _defineProperty(_formatMap, gl.RGBA4, 'rgba4'), _defineProperty(_formatMap, gl.RGB5_A1, 'rgb5 a1'), _defineProperty(_formatMap, gl.RGB565, 'rgb565'), _defineProperty(_formatMap, gl.DEPTH_COMPONENT, 'depth'), _defineProperty(_formatMap, gl.DEPTH_STENCIL, 'depth stencil'), _formatMap);\nexport var mipmapMap = (_mipmapMap = {}, _defineProperty(_mipmapMap, gl.DONT_CARE, 'dont care'), _defineProperty(_mipmapMap, gl.NICEST, 'nice'), _defineProperty(_mipmapMap, gl.FASTEST, 'fast'), _mipmapMap);\nexport var filterMap = (_filterMap = {}, _defineProperty(_filterMap, gl.NEAREST, 'nearest'), _defineProperty(_filterMap, gl.LINEAR, 'linear'), _defineProperty(_filterMap, gl.LINEAR_MIPMAP_LINEAR, 'mipmap'), _defineProperty(_filterMap, gl.NEAREST_MIPMAP_LINEAR, 'nearest mipmap linear'), _defineProperty(_filterMap, gl.LINEAR_MIPMAP_NEAREST, 'linear mipmap nearest'), _defineProperty(_filterMap, gl.NEAREST_MIPMAP_NEAREST, 'nearest mipmap nearest'), _filterMap);\nexport var wrapModeMap = (_wrapModeMap = {}, _defineProperty(_wrapModeMap, gl.REPEAT, 'repeat'), _defineProperty(_wrapModeMap, gl.CLAMP_TO_EDGE, 'clamp'), _defineProperty(_wrapModeMap, gl.MIRRORED_REPEAT, 'mirror'), _wrapModeMap);\nexport var colorSpaceMap = (_colorSpaceMap = {}, _defineProperty(_colorSpaceMap, gl.NONE, 'none'), _defineProperty(_colorSpaceMap, gl.BROWSER_DEFAULT_WEBGL, 'browser'), _colorSpaceMap);\nexport var depthFuncMap = (_depthFuncMap = {}, _defineProperty(_depthFuncMap, gl.NEVER, 'never'), _defineProperty(_depthFuncMap, gl.ALWAYS, 'always'), _defineProperty(_depthFuncMap, gl.LESS, 'less'), _defineProperty(_depthFuncMap, gl.LEQUAL, 'lequal'), _defineProperty(_depthFuncMap, gl.GREATER, 'greater'), _defineProperty(_depthFuncMap, gl.GEQUAL, 'gequal'), _defineProperty(_depthFuncMap, gl.EQUAL, 'equal'), _defineProperty(_depthFuncMap, gl.NOTEQUAL, 'notequal'), _depthFuncMap);\nexport var blendEquationMap = (_blendEquationMap = {}, _defineProperty(_blendEquationMap, gl.FUNC_ADD, 'add'), _defineProperty(_blendEquationMap, gl.MIN_EXT, 'min'), _defineProperty(_blendEquationMap, gl.MAX_EXT, 'max'), _defineProperty(_blendEquationMap, gl.FUNC_SUBTRACT, 'subtract'), _defineProperty(_blendEquationMap, gl.FUNC_REVERSE_SUBTRACT, 'reverse subtract'), _blendEquationMap);\nexport var blendFuncMap = (_blendFuncMap = {}, _defineProperty(_blendFuncMap, gl.ZERO, 'zero'), _defineProperty(_blendFuncMap, gl.ONE, 'one'), _defineProperty(_blendFuncMap, gl.SRC_COLOR, 'src color'), _defineProperty(_blendFuncMap, gl.ONE_MINUS_SRC_COLOR, 'one minus src color'), _defineProperty(_blendFuncMap, gl.SRC_ALPHA, 'src alpha'), _defineProperty(_blendFuncMap, gl.ONE_MINUS_SRC_ALPHA, 'one minus src alpha'), _defineProperty(_blendFuncMap, gl.DST_COLOR, 'dst color'), _defineProperty(_blendFuncMap, gl.ONE_MINUS_DST_COLOR, 'one minus dst color'), _defineProperty(_blendFuncMap, gl.DST_ALPHA, 'dst alpha'), _defineProperty(_blendFuncMap, gl.ONE_MINUS_DST_ALPHA, 'one minus dst alpha'), _defineProperty(_blendFuncMap, gl.CONSTANT_COLOR, 'constant color'), _defineProperty(_blendFuncMap, gl.ONE_MINUS_CONSTANT_COLOR, 'one minus constant color'), _defineProperty(_blendFuncMap, gl.CONSTANT_ALPHA, 'constant alpha'), _defineProperty(_blendFuncMap, gl.ONE_MINUS_CONSTANT_ALPHA, 'one minus constant alpha'), _defineProperty(_blendFuncMap, gl.SRC_ALPHA_SATURATE, 'src alpha saturate'), _blendFuncMap);\nexport var stencilFuncMap = (_stencilFuncMap = {}, _defineProperty(_stencilFuncMap, gl.NEVER, 'never'), _defineProperty(_stencilFuncMap, gl.ALWAYS, 'always'), _defineProperty(_stencilFuncMap, gl.LESS, 'less'), _defineProperty(_stencilFuncMap, gl.LEQUAL, 'lequal'), _defineProperty(_stencilFuncMap, gl.GREATER, 'greater'), _defineProperty(_stencilFuncMap, gl.GEQUAL, 'gequal'), _defineProperty(_stencilFuncMap, gl.EQUAL, 'equal'), _defineProperty(_stencilFuncMap, gl.NOTEQUAL, 'notequal'), _stencilFuncMap);\nexport var stencilOpMap = (_stencilOpMap = {}, _defineProperty(_stencilOpMap, gl.ZERO, 'zero'), _defineProperty(_stencilOpMap, gl.KEEP, 'keep'), _defineProperty(_stencilOpMap, gl.REPLACE, 'replace'), _defineProperty(_stencilOpMap, gl.INVERT, 'invert'), _defineProperty(_stencilOpMap, gl.INCR, 'increment'), _defineProperty(_stencilOpMap, gl.DECR, 'decrement'), _defineProperty(_stencilOpMap, gl.INCR_WRAP, 'increment wrap'), _defineProperty(_stencilOpMap, gl.DECR_WRAP, 'decrement wrap'), _stencilOpMap);\nexport var cullFaceMap = (_cullFaceMap = {}, _defineProperty(_cullFaceMap, gl.FRONT, 'front'), _defineProperty(_cullFaceMap, gl.BACK, 'back'), _cullFaceMap);\n//# sourceMappingURL=constants.js.map","import isType from './is-type';\nexport default (function (value) {\n return Array.isArray ? Array.isArray(value) : isType(value, 'Array');\n});\n//# sourceMappingURL=is-array.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\n/**\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#attributes\n */\nvar ReglAttribute = /*#__PURE__*/function () {\n function ReglAttribute(gl, options) {\n _classCallCheck(this, ReglAttribute);\n\n this.attribute = void 0;\n this.buffer = void 0;\n var buffer = options.buffer,\n offset = options.offset,\n stride = options.stride,\n normalized = options.normalized,\n size = options.size,\n divisor = options.divisor;\n this.buffer = buffer;\n this.attribute = {\n buffer: buffer.get(),\n offset: offset || 0,\n stride: stride || 0,\n normalized: normalized || false,\n divisor: divisor || 0\n };\n\n if (size) {\n this.attribute.size = size;\n }\n }\n\n _createClass(ReglAttribute, [{\n key: \"get\",\n value: function get() {\n return this.attribute;\n }\n }, {\n key: \"updateBuffer\",\n value: function updateBuffer(options) {\n this.buffer.subData(options);\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n this.buffer.destroy();\n }\n }]);\n\n return ReglAttribute;\n}();\n\nexport { ReglAttribute as default };\n//# sourceMappingURL=ReglAttribute.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport { gl } from '@antv/g-webgpu-core';\nimport { dataTypeMap, usageMap } from './constants';\n/**\n * adaptor for regl.Buffer\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#buffers\n */\n\nvar ReglBuffer = /*#__PURE__*/function () {\n function ReglBuffer(reGl, options) {\n _classCallCheck(this, ReglBuffer);\n\n this.buffer = void 0;\n var data = options.data,\n usage = options.usage,\n type = options.type; // @ts-ignore\n\n this.buffer = reGl.buffer({\n data: data,\n usage: usageMap[usage || gl.STATIC_DRAW],\n type: dataTypeMap[type || gl.UNSIGNED_BYTE] // length: 0,\n\n });\n }\n\n _createClass(ReglBuffer, [{\n key: \"get\",\n value: function get() {\n return this.buffer;\n }\n }, {\n key: \"destroy\",\n value: function destroy() {// this.buffer.destroy();\n }\n }, {\n key: \"subData\",\n value: function subData(_ref) {\n var data = _ref.data,\n offset = _ref.offset;\n // @ts-ignore\n this.buffer.subdata(data, offset);\n }\n }]);\n\n return ReglBuffer;\n}();\n\nexport { ReglBuffer as default };\n//# sourceMappingURL=ReglBuffer.js.map","import arrayWithoutHoles from \"./arrayWithoutHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableSpread from \"./nonIterableSpread.js\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}","export default function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter);\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","import _typeof from \"@babel/runtime/helpers/typeof\";\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n/** `Object#toString` result references. */\n\nvar argsTag = '[object Arguments]';\nvar arrayTag = '[object Array]';\nvar boolTag = '[object Boolean]';\nvar dateTag = '[object Date]';\nvar errorTag = '[object Error]';\nvar funcTag = '[object Function]';\nvar mapTag = '[object Map]';\nvar numberTag = '[object Number]';\nvar objectTag = '[object Object]';\nvar regexpTag = '[object RegExp]';\nvar setTag = '[object Set]';\nvar stringTag = '[object String]';\nvar weakMapTag = '[object WeakMap]';\nvar arrayBufferTag = '[object ArrayBuffer]';\nvar dataViewTag = '[object DataView]';\nvar float32Tag = '[object Float32Array]';\nvar float64Tag = '[object Float64Array]';\nvar int8Tag = '[object Int8Array]';\nvar int16Tag = '[object Int16Array]';\nvar int32Tag = '[object Int32Array]';\nvar uint8Tag = '[object Uint8Array]';\nvar uint8ClampedTag = '[object Uint8ClampedArray]';\nvar uint16Tag = '[object Uint16Array]';\nvar uint32Tag = '[object Uint32Array]';\n/** Used to identify `toStringTag` values of typed arrays. */\n\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] = typedArrayTags[int8Tag] = typedArrayTags[int16Tag] = typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] = typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] = typedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] = typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] = typedArrayTags[dataViewTag] = typedArrayTags[dateTag] = typedArrayTags[errorTag] = typedArrayTags[funcTag] = typedArrayTags[mapTag] = typedArrayTags[numberTag] = typedArrayTags[objectTag] = typedArrayTags[regexpTag] = typedArrayTags[setTag] = typedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false;\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\n\nfunction baseUnary(func) {\n return function (value) {\n return func(value);\n };\n}\n/** Used for built-in method references. */\n\n\nvar objectProto = Object.prototype;\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\n\nvar objectToString = objectProto.toString;\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\n\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[objectToString.call(value)];\n}\n\nfunction isLength(value) {\n return typeof value === 'number' && value > -1 && value % 1 === 0 && value <= MAX_SAFE_INTEGER;\n}\n\nfunction isObjectLike(value) {\n return !!value && _typeof(value) === 'object';\n}\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\n\n\nexport var isTypedArray = baseIsTypedArray;\n//# sourceMappingURL=is-typedarray.js.map","import _toConsumableArray from \"@babel/runtime/helpers/toConsumableArray\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { AST_TOKEN_TYPES, createEntity, STORAGE_CLASS } from '@antv/g-webgpu-core';\nimport { isTypedArray } from '../utils/is-typedarray';\n\n/* babel-plugin-inline-import './shaders/quad.vert.glsl' */\nvar quadVert = \"attribute vec3 a_Position;\\nattribute vec2 a_TexCoord;\\n\\nvarying vec2 v_TexCoord;\\n\\nvoid main() {\\n gl_Position = vec4(a_Position, 1.0);\\n v_TexCoord = a_TexCoord;\\n}\";\nvar textureId = 0;\nvar debug = false;\n/**\n * adaptor for regl.DrawCommand\n */\n\nvar ReglComputeModel = /*#__PURE__*/function () {\n function ReglComputeModel(reGl, context) {\n var _this = this;\n\n _classCallCheck(this, ReglComputeModel);\n\n this.reGl = reGl;\n this.context = context;\n this.entity = createEntity();\n this.texFBO = void 0;\n this.computeCommand = void 0;\n this.textureCache = {};\n this.outputTextureName = void 0;\n this.swapOutputTextureName = void 0;\n this.compiledPingpong = void 0;\n this.dynamicPingpong = void 0;\n var uniforms = {};\n this.context.uniforms.forEach(function (uniform) {\n var name = uniform.name,\n type = uniform.type,\n data = uniform.data,\n isReferer = uniform.isReferer,\n storageClass = uniform.storageClass; // store data with a 2D texture\n\n if (storageClass === STORAGE_CLASS.StorageBuffer) {\n if (!isReferer) {\n _this.textureCache[name] = _this.calcDataTexture(name, type, data);\n var _this$textureCache$na = _this.textureCache[name],\n width = _this$textureCache$na.textureWidth,\n isOutput = _this$textureCache$na.isOutput;\n uniforms[\"\".concat(name, \"Size\")] = [width, width];\n\n if (isOutput) {\n _this.outputTextureName = name;\n\n if (_this.context.needPingpong) {\n _this.outputTextureName = \"\".concat(name, \"Output\");\n _this.textureCache[_this.outputTextureName] = _this.calcDataTexture(name, type, data);\n }\n }\n } else {\n // @ts-ignore\n _this.textureCache[name] = {\n data: undefined\n }; // refer to another kernel's output,\n // the referred kernel may not have been initialized, so we use dynamic way here\n\n uniforms[\"\".concat(name, \"Size\")] = function () {\n return (// @ts-ignore\n data.compiledBundle.context.output.textureSize\n );\n };\n }\n\n uniforms[name] = function () {\n if (debug) {\n console.log(\"[\".concat(_this.entity, \"]: \").concat(name, \" \").concat(_this.textureCache[name].id));\n }\n\n return _this.textureCache[name].texture;\n };\n } else if (storageClass === STORAGE_CLASS.Uniform) {\n if (data && (Array.isArray(data) || isTypedArray(data)) && data.length > 16) {\n // up to mat4 which includes 16 elements\n throw new Error(\"invalid data type \".concat(type));\n } // get uniform dynamically\n\n\n uniforms[name] = function () {\n return uniform.data;\n };\n }\n });\n\n var _this$getOuputDataTex = this.getOuputDataTexture(),\n textureWidth = _this$getOuputDataTex.textureWidth,\n texelCount = _this$getOuputDataTex.texelCount; // 传入 output 纹理尺寸和数据长度,便于多余的 texel 提前退出\n\n\n uniforms.u_OutputTextureSize = [textureWidth, textureWidth];\n uniforms.u_OutputTexelCount = texelCount; // 保存在 Kernel 的上下文中,供其他 Kernel 引用\n\n this.context.output.textureSize = [textureWidth, textureWidth];\n var drawParams = {\n attributes: {\n a_Position: [[-1, 1, 0], [-1, -1, 0], [1, 1, 0], [1, -1, 0]],\n a_TexCoord: [[0, 1], [0, 0], [1, 1], [1, 0]]\n },\n frag: \"#ifdef GL_FRAGMENT_PRECISION_HIGH\\n precision highp float;\\n#else\\n precision mediump float;\\n#endif\\n\".concat(this.context.shader),\n uniforms: uniforms,\n vert: quadVert,\n // TODO: use a fullscreen triangle instead.\n primitive: 'triangle strip',\n count: 4\n };\n this.computeCommand = this.reGl(drawParams);\n }\n\n _createClass(ReglComputeModel, [{\n key: \"run\",\n value: function run() {\n var _this2 = this;\n\n if (this.context.maxIteration > 1 && this.context.needPingpong) {\n this.compiledPingpong = true;\n } // need pingpong when (@in@out and execute(10)) or use `setBinding('out', self)`\n // this.needPingpong =\n // !!(this.context.maxIteration > 1 && this.context.needPingpong);\n // if (this.relativeOutputTextureNames.length) {\n // const { id, texture } = this.getOuputDataTexture();\n // this.relativeOutputTextureNames.forEach((name) => {\n // this.textureCache[name].id = id;\n // this.textureCache[name].texture = texture;\n // });\n // this.swap();\n // }\n\n\n if (this.compiledPingpong || this.dynamicPingpong) {\n this.swap();\n }\n\n this.texFBO = this.reGl.framebuffer({\n color: this.getOuputDataTexture().texture\n });\n this.texFBO.use(function () {\n _this2.computeCommand();\n });\n\n if (debug) {\n console.log(\"[\".concat(this.entity, \"]: output \").concat(this.getOuputDataTexture().id));\n }\n }\n }, {\n key: \"readData\",\n value: function () {\n var _readData = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {\n var _this3 = this;\n\n var pixels, _this$getOuputDataTex2, originalDataLength, elementsPerTexel, _this$getOuputDataTex3, typedArrayConstructor, formattedPixels, i;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n this.reGl({\n framebuffer: this.texFBO\n })(function () {\n pixels = _this3.reGl.read();\n }); // @ts-ignore\n\n if (!pixels) {\n _context.next = 6;\n break;\n }\n\n _this$getOuputDataTex2 = this.getOuputDataTexture(), originalDataLength = _this$getOuputDataTex2.originalDataLength, elementsPerTexel = _this$getOuputDataTex2.elementsPerTexel, _this$getOuputDataTex3 = _this$getOuputDataTex2.typedArrayConstructor, typedArrayConstructor = _this$getOuputDataTex3 === void 0 ? Float32Array : _this$getOuputDataTex3;\n formattedPixels = [];\n\n if (elementsPerTexel !== 4) {\n for (i = 0; i < pixels.length; i += 4) {\n if (elementsPerTexel === 1) {\n formattedPixels.push(pixels[i]);\n } else if (elementsPerTexel === 2) {\n formattedPixels.push(pixels[i], pixels[i + 1]);\n } else {\n formattedPixels.push(pixels[i], pixels[i + 1], pixels[i + 2]);\n }\n }\n } else {\n // @ts-ignore\n formattedPixels = pixels;\n } // 截取多余的部分\n // @ts-ignore\n\n\n return _context.abrupt(\"return\", new typedArrayConstructor(formattedPixels.slice(0, originalDataLength)));\n\n case 6:\n return _context.abrupt(\"return\", new Float32Array());\n\n case 7:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function readData() {\n return _readData.apply(this, arguments);\n }\n\n return readData;\n }()\n }, {\n key: \"confirmInput\",\n value: function confirmInput(model, inputName) {\n var inputModel; // refer to self, same as pingpong\n\n if (this.entity === model.entity) {\n this.dynamicPingpong = true;\n inputModel = this;\n } else {\n inputModel = model;\n }\n\n this.textureCache[inputName].id = inputModel.getOuputDataTexture().id;\n this.textureCache[inputName].texture = inputModel.getOuputDataTexture().texture;\n\n if (debug) {\n console.log(\"[\".concat(this.entity, \"]: confirm input \").concat(inputName, \" from model \").concat(inputModel.entity, \", \").concat(inputModel.getOuputDataTexture().id));\n }\n }\n }, {\n key: \"updateUniform\",\n value: function updateUniform() {// already get uniform's data dynamically when created, do nothing here\n }\n }, {\n key: \"updateBuffer\",\n value: function updateBuffer(bufferName, data) {\n var offset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;\n // regenerate data texture\n var buffer = this.context.uniforms.find(function (_ref) {\n var name = _ref.name;\n return name === bufferName;\n });\n\n if (buffer) {\n var _this$calcDataTexture = this.calcDataTexture(bufferName, buffer.type, data),\n texture = _this$calcDataTexture.texture,\n paddingData = _this$calcDataTexture.data; // TODO: destroy outdated texture\n\n\n this.textureCache[bufferName].data = paddingData;\n this.textureCache[bufferName].texture = texture;\n }\n }\n }, {\n key: \"destroy\",\n value: function destroy() {// regl will destroy all resources\n }\n }, {\n key: \"swap\",\n value: function swap() {\n if (!this.swapOutputTextureName) {\n this.createSwapOutputDataTexture();\n }\n\n if (this.compiledPingpong) {\n var outputTextureUniformName = this.context.output.name;\n this.textureCache[outputTextureUniformName].id = this.getOuputDataTexture().id;\n this.textureCache[outputTextureUniformName].texture = this.getOuputDataTexture().texture;\n }\n\n var tmp = this.outputTextureName;\n this.outputTextureName = this.swapOutputTextureName;\n this.swapOutputTextureName = tmp;\n\n if (debug) {\n console.log(\"[\".concat(this.entity, \"]: after swap, output \").concat(this.getOuputDataTexture().id));\n }\n }\n }, {\n key: \"getOuputDataTexture\",\n value: function getOuputDataTexture() {\n return this.textureCache[this.outputTextureName];\n }\n }, {\n key: \"createSwapOutputDataTexture\",\n value: function createSwapOutputDataTexture() {\n var texture = this.cloneDataTexture(this.getOuputDataTexture());\n this.swapOutputTextureName = \"\".concat(this.entity, \"-swap\");\n this.textureCache[this.swapOutputTextureName] = texture;\n }\n }, {\n key: \"cloneDataTexture\",\n value: function cloneDataTexture(texture) {\n var data = texture.data,\n textureWidth = texture.textureWidth;\n return _objectSpread(_objectSpread({}, texture), {}, {\n id: textureId++,\n // @ts-ignore\n texture: this.reGl.texture({\n width: textureWidth,\n height: textureWidth,\n data: data,\n type: 'float'\n })\n });\n }\n }, {\n key: \"calcDataTexture\",\n value: function calcDataTexture(name, type, data) {\n var elementsPerTexel = 1;\n\n if (type === AST_TOKEN_TYPES.Vector4FloatArray) {\n elementsPerTexel = 4;\n } // 用 0 补全不足 vec4 的部分\n\n\n var paddingData = [];\n\n for (var i = 0; i < data.length; i += elementsPerTexel) {\n if (elementsPerTexel === 1) {\n paddingData.push(data[i], 0, 0, 0);\n } else if (elementsPerTexel === 2) {\n paddingData.push(data[i], data[i + 1], 0, 0);\n } else if (elementsPerTexel === 3) {\n paddingData.push(data[i], data[i + 1], data[i + 2], 0);\n } else if (elementsPerTexel === 4) {\n paddingData.push(data[i], data[i + 1], data[i + 2], data[i + 3]);\n }\n } // 使用纹理存储,例如 Array(8) 使用 3 * 3 纹理,末尾空白使用 0 填充\n\n\n var originalDataLength = data.length;\n var texelCount = Math.ceil(originalDataLength / elementsPerTexel);\n var width = Math.ceil(Math.sqrt(texelCount));\n var paddingTexelCount = width * width;\n\n if (texelCount < paddingTexelCount) {\n paddingData.push.apply(paddingData, _toConsumableArray(new Array((paddingTexelCount - texelCount) * 4).fill(0)));\n }\n\n var texture = this.reGl.texture({\n width: width,\n height: width,\n data: paddingData,\n type: 'float'\n });\n return {\n id: textureId++,\n data: paddingData,\n originalDataLength: originalDataLength,\n typedArrayConstructor: isTypedArray(data) ? data.constructor : undefined,\n textureWidth: width,\n texture: texture,\n texelCount: texelCount,\n elementsPerTexel: elementsPerTexel,\n isOutput: name === this.context.output.name\n };\n }\n }]);\n\n return ReglComputeModel;\n}();\n\nexport { ReglComputeModel as default };\n//# sourceMappingURL=ReglComputeModel.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport { gl } from '@antv/g-webgpu-core';\nimport { dataTypeMap, usageMap } from './constants';\n/**\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#elements\n */\n\nvar ReglElements = /*#__PURE__*/function () {\n function ReglElements(reGl, options) {\n _classCallCheck(this, ReglElements);\n\n this.elements = void 0;\n var data = options.data,\n usage = options.usage,\n type = options.type,\n count = options.count;\n this.elements = reGl.elements({\n data: data,\n usage: usageMap[usage || gl.STATIC_DRAW],\n type: dataTypeMap[type || gl.UNSIGNED_BYTE],\n count: count\n });\n }\n\n _createClass(ReglElements, [{\n key: \"get\",\n value: function get() {\n return this.elements;\n }\n }, {\n key: \"subData\",\n value: function subData(_ref) {\n var data = _ref.data;\n this.elements.subdata(data);\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n this.elements.destroy();\n }\n }]);\n\n return ReglElements;\n}();\n\nexport { ReglElements as default };\n//# sourceMappingURL=ReglElements.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\n/**\n * adaptor for regl.Framebuffer\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#framebuffers\n */\nvar ReglFramebuffer = /*#__PURE__*/function () {\n function ReglFramebuffer(reGl, options) {\n _classCallCheck(this, ReglFramebuffer);\n\n this.framebuffer = void 0;\n var width = options.width,\n height = options.height,\n color = options.color,\n colors = options.colors,\n depth = options.depth,\n stencil = options.stencil;\n var framebufferOptions = {\n width: width,\n height: height\n };\n\n if (Array.isArray(colors)) {\n framebufferOptions.colors = colors.map(function (c) {\n return c.get();\n });\n }\n\n if (color && typeof color !== 'boolean') {\n framebufferOptions.color = color.get();\n } // TODO: depth & stencil\n\n\n this.framebuffer = reGl.framebuffer(framebufferOptions);\n }\n\n _createClass(ReglFramebuffer, [{\n key: \"get\",\n value: function get() {\n return this.framebuffer;\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n this.framebuffer.destroy();\n }\n }, {\n key: \"resize\",\n value: function resize(_ref) {\n var width = _ref.width,\n height = _ref.height;\n this.framebuffer.resize(width, height);\n }\n }]);\n\n return ReglFramebuffer;\n}();\n\nexport { ReglFramebuffer as default };\n//# sourceMappingURL=ReglFramebuffer.js.map","import { isObject } from './is-object';\nimport { isTypedArray } from './is-typedarray';\n/**\n * 考虑结构体命名, eg:\n * a: { b: 1 } -> 'a.b'\n * a: [ { b: 1 } ] -> 'a[0].b'\n */\n\nexport function extractUniforms(uniforms) {\n var extractedUniforms = {};\n Object.keys(uniforms).forEach(function (uniformName) {\n extractUniformsRecursively(uniformName, uniforms[uniformName], extractedUniforms, '');\n });\n return extractedUniforms;\n}\n\nfunction extractUniformsRecursively(uniformName, uniformValue, uniforms, prefix) {\n if (uniformValue === null || typeof uniformValue === 'number' || // u_A: 1\n typeof uniformValue === 'boolean' || // u_A: false\n Array.isArray(uniformValue) && typeof uniformValue[0] === 'number' || // u_A: [1, 2, 3]\n isTypedArray(uniformValue) || // u_A: Float32Array\n // @ts-ignore\n uniformValue === '' || // @ts-ignore\n uniformValue.resize !== undefined) {\n uniforms[\"\".concat(prefix && prefix + '.').concat(uniformName)] = uniformValue;\n return;\n } // u_Struct.a.b.c\n\n\n if (isObject(uniformValue)) {\n Object.keys(uniformValue).forEach(function (childName) {\n extractUniformsRecursively(childName, // @ts-ignore\n uniformValue[childName], uniforms, \"\".concat(prefix && prefix + '.').concat(uniformName));\n });\n } // u_Struct[0].a\n\n\n if (Array.isArray(uniformValue)) {\n // @ts-ignore\n uniformValue.forEach(function (child, idx) {\n Object.keys(child).forEach(function (childName) {\n extractUniformsRecursively(childName, // @ts-ignore\n child[childName], uniforms, \"\".concat(prefix && prefix + '.').concat(uniformName, \"[\").concat(idx, \"]\"));\n });\n });\n }\n}\n//# sourceMappingURL=uniform.js.map","import _typeof from \"@babel/runtime/helpers/typeof\";\nexport function isObject(value) {\n var type = _typeof(value);\n\n return value != null && (type === 'object' || type === 'function');\n}\n//# sourceMappingURL=is-object.js.map","import _typeof from \"@babel/runtime/helpers/typeof\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { gl } from '@antv/g-webgpu-core';\nimport { extractUniforms } from '../utils/uniform';\nimport { blendEquationMap, blendFuncMap, cullFaceMap, depthFuncMap, primitiveMap, stencilFuncMap, stencilOpMap } from './constants';\n\n/**\n * adaptor for regl.DrawCommand\n */\nvar ReglModel = /*#__PURE__*/function () {\n function ReglModel(reGl, options) {\n _classCallCheck(this, ReglModel);\n\n this.reGl = void 0;\n this.drawCommand = void 0;\n this.uniforms = {};\n this.reGl = reGl;\n var vs = options.vs,\n fs = options.fs,\n defines = options.defines,\n attributes = options.attributes,\n uniforms = options.uniforms,\n primitive = options.primitive,\n count = options.count,\n elements = options.elements,\n depth = options.depth,\n blend = options.blend,\n stencil = options.stencil,\n cull = options.cull,\n instances = options.instances,\n scissor = options.scissor,\n viewport = options.viewport;\n var reglUniforms = {};\n\n if (uniforms) {\n this.uniforms = extractUniforms(uniforms);\n Object.keys(uniforms).forEach(function (uniformName) {\n // use regl prop API\n // @ts-ignore\n reglUniforms[uniformName] = reGl.prop(uniformName);\n });\n }\n\n var reglAttributes = {};\n Object.keys(attributes).forEach(function (name) {\n reglAttributes[name] = attributes[name].get();\n });\n var defineStmts = defines && this.generateDefines(defines) || '';\n var drawParams = {\n attributes: reglAttributes,\n frag: \"#ifdef GL_FRAGMENT_PRECISION_HIGH\\n precision highp float;\\n#else\\n precision mediump float;\\n#endif\\n\".concat(defineStmts, \"\\n\").concat(fs),\n uniforms: reglUniforms,\n vert: \"\\n\".concat(defineStmts, \"\\n\").concat(vs),\n primitive: primitiveMap[primitive === undefined ? gl.TRIANGLES : primitive]\n };\n\n if (instances) {\n drawParams.instances = instances;\n } // elements 中可能包含 count,此时不应传入\n\n\n if (count) {\n drawParams.count = count;\n }\n\n if (elements) {\n drawParams.elements = elements.get();\n }\n\n if (scissor) {\n drawParams.scissor = scissor;\n }\n\n if (viewport) {\n drawParams.viewport = viewport;\n }\n\n this.initDepthDrawParams({\n depth: depth\n }, drawParams);\n this.initBlendDrawParams({\n blend: blend\n }, drawParams);\n this.initStencilDrawParams({\n stencil: stencil\n }, drawParams);\n this.initCullDrawParams({\n cull: cull\n }, drawParams);\n this.drawCommand = reGl(drawParams);\n }\n\n _createClass(ReglModel, [{\n key: \"addUniforms\",\n value: function addUniforms(uniforms) {\n this.uniforms = _objectSpread(_objectSpread({}, this.uniforms), extractUniforms(uniforms));\n }\n }, {\n key: \"draw\",\n value: function draw(options) {\n var uniforms = _objectSpread(_objectSpread({}, this.uniforms), extractUniforms(options.uniforms || {}));\n\n var reglDrawProps = {};\n Object.keys(uniforms).forEach(function (uniformName) {\n var type = _typeof(uniforms[uniformName]);\n\n if (type === 'boolean' || type === 'number' || Array.isArray(uniforms[uniformName]) || // @ts-ignore\n uniforms[uniformName].BYTES_PER_ELEMENT) {\n reglDrawProps[uniformName] = uniforms[uniformName];\n } else if (type === 'string') {// TODO: image url\n } else {\n reglDrawProps[uniformName] = uniforms[uniformName].get();\n }\n });\n this.drawCommand(reglDrawProps);\n }\n }, {\n key: \"destroy\",\n value: function destroy() {// don't need do anything since we will call `rendererService.cleanup()`\n }\n /**\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#depth-buffer\n */\n\n }, {\n key: \"initDepthDrawParams\",\n value: function initDepthDrawParams(_ref, drawParams) {\n var depth = _ref.depth;\n\n if (depth) {\n drawParams.depth = {\n enable: depth.enable === undefined ? true : !!depth.enable,\n mask: depth.mask === undefined ? true : !!depth.mask,\n func: depthFuncMap[depth.func || gl.LESS],\n range: depth.range || [0, 1]\n };\n }\n }\n /**\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#blending\n */\n\n }, {\n key: \"initBlendDrawParams\",\n value: function initBlendDrawParams(_ref2, drawParams) {\n var blend = _ref2.blend;\n\n if (blend) {\n var enable = blend.enable,\n func = blend.func,\n equation = blend.equation,\n _blend$color = blend.color,\n color = _blend$color === void 0 ? [0, 0, 0, 0] : _blend$color; // @ts-ignore\n\n drawParams.blend = {\n enable: !!enable,\n func: {\n srcRGB: blendFuncMap[func && func.srcRGB || gl.SRC_ALPHA],\n srcAlpha: blendFuncMap[func && func.srcAlpha || gl.SRC_ALPHA],\n dstRGB: blendFuncMap[func && func.dstRGB || gl.ONE_MINUS_SRC_ALPHA],\n dstAlpha: blendFuncMap[func && func.dstAlpha || gl.ONE_MINUS_SRC_ALPHA]\n },\n equation: {\n rgb: blendEquationMap[equation && equation.rgb || gl.FUNC_ADD],\n alpha: blendEquationMap[equation && equation.alpha || gl.FUNC_ADD]\n },\n color: color\n };\n }\n }\n /**\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#stencil\n */\n\n }, {\n key: \"initStencilDrawParams\",\n value: function initStencilDrawParams(_ref3, drawParams) {\n var stencil = _ref3.stencil;\n\n if (stencil) {\n var enable = stencil.enable,\n _stencil$mask = stencil.mask,\n mask = _stencil$mask === void 0 ? -1 : _stencil$mask,\n _stencil$func = stencil.func,\n func = _stencil$func === void 0 ? {\n cmp: gl.ALWAYS,\n ref: 0,\n mask: -1\n } : _stencil$func,\n _stencil$opFront = stencil.opFront,\n opFront = _stencil$opFront === void 0 ? {\n fail: gl.KEEP,\n zfail: gl.KEEP,\n zpass: gl.KEEP\n } : _stencil$opFront,\n _stencil$opBack = stencil.opBack,\n opBack = _stencil$opBack === void 0 ? {\n fail: gl.KEEP,\n zfail: gl.KEEP,\n zpass: gl.KEEP\n } : _stencil$opBack;\n drawParams.stencil = {\n enable: !!enable,\n mask: mask,\n func: _objectSpread(_objectSpread({}, func), {}, {\n cmp: stencilFuncMap[func.cmp]\n }),\n opFront: {\n fail: stencilOpMap[opFront.fail],\n zfail: stencilOpMap[opFront.zfail],\n zpass: stencilOpMap[opFront.zpass]\n },\n opBack: {\n fail: stencilOpMap[opBack.fail],\n zfail: stencilOpMap[opBack.zfail],\n zpass: stencilOpMap[opBack.zpass]\n }\n };\n }\n }\n /**\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#culling\n */\n\n }, {\n key: \"initCullDrawParams\",\n value: function initCullDrawParams(_ref4, drawParams) {\n var cull = _ref4.cull;\n\n if (cull) {\n var enable = cull.enable,\n _cull$face = cull.face,\n face = _cull$face === void 0 ? gl.BACK : _cull$face;\n drawParams.cull = {\n enable: !!enable,\n face: cullFaceMap[face]\n };\n }\n }\n }, {\n key: \"generateDefines\",\n value: function generateDefines(defines) {\n return Object.keys(defines).map(function (name) {\n return \"#define \".concat(name, \" \").concat(Number(defines[name]));\n }).join('\\n');\n }\n }]);\n\n return ReglModel;\n}();\n\nexport { ReglModel as default };\n//# sourceMappingURL=ReglModel.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\nvar _dec, _class, _temp;\n\n/**\n * render w/ regl\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md\n */\nimport { gl } from '@antv/g-webgpu-core';\nimport { injectable } from 'inversify';\nimport regl from 'regl';\nimport ReglAttribute from './ReglAttribute';\nimport ReglBuffer from './ReglBuffer';\nimport ReglComputeModel from './ReglComputeModel';\nimport ReglElements from './ReglElements';\nimport ReglFramebuffer from './ReglFramebuffer';\nimport ReglModel from './ReglModel';\nimport ReglTexture2D from './ReglTexture2D';\n/**\n * regl renderer\n */\n\nexport var WebGLEngine = (_dec = injectable(), _dec(_class = (_temp = /*#__PURE__*/function () {\n function WebGLEngine() {\n var _this = this;\n\n _classCallCheck(this, WebGLEngine);\n\n this.supportWebGPU = false;\n this.useWGSL = false;\n this.$canvas = void 0;\n this.gl = void 0;\n this.inited = void 0;\n\n this.createModel = /*#__PURE__*/function () {\n var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(options) {\n return _regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n if (!options.uniforms) {\n _context2.next = 3;\n break;\n }\n\n _context2.next = 3;\n return Promise.all(Object.keys(options.uniforms).map( /*#__PURE__*/function () {\n var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(name) {\n var texture;\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (!(options.uniforms[name] && options.uniforms[name].load !== undefined)) {\n _context.next = 5;\n break;\n }\n\n _context.next = 3;\n return options.uniforms[name].load();\n\n case 3:\n texture = _context.sent;\n // @ts-ignore\n options.uniforms[name] = texture;\n\n case 5:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }));\n\n return function (_x2) {\n return _ref2.apply(this, arguments);\n };\n }()));\n\n case 3:\n return _context2.abrupt(\"return\", new ReglModel(_this.gl, options));\n\n case 4:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2);\n }));\n\n return function (_x) {\n return _ref.apply(this, arguments);\n };\n }();\n\n this.createAttribute = function (options) {\n return new ReglAttribute(_this.gl, options);\n };\n\n this.createBuffer = function (options) {\n return new ReglBuffer(_this.gl, options);\n };\n\n this.createElements = function (options) {\n return new ReglElements(_this.gl, options);\n };\n\n this.createTexture2D = function (options) {\n return new ReglTexture2D(_this.gl, options);\n };\n\n this.createFramebuffer = function (options) {\n return new ReglFramebuffer(_this.gl, options);\n };\n\n this.useFramebuffer = function (framebuffer, drawCommands) {\n _this.gl({\n framebuffer: framebuffer ? framebuffer.get() : null\n })(drawCommands);\n };\n\n this.createComputeModel = /*#__PURE__*/function () {\n var _ref3 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee3(context) {\n return _regeneratorRuntime.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n return _context3.abrupt(\"return\", new ReglComputeModel(_this.gl, context));\n\n case 1:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3);\n }));\n\n return function (_x3) {\n return _ref3.apply(this, arguments);\n };\n }();\n\n this.clear = function (options) {\n // @see https://github.com/regl-project/regl/blob/gh-pages/API.md#clear-the-draw-buffer\n var color = options.color,\n depth = options.depth,\n stencil = options.stencil,\n _options$framebuffer = options.framebuffer,\n framebuffer = _options$framebuffer === void 0 ? null : _options$framebuffer;\n var reglClearOptions = {\n color: color,\n depth: depth,\n stencil: stencil\n };\n reglClearOptions.framebuffer = framebuffer === null ? framebuffer : framebuffer.get();\n\n _this.gl.clear(reglClearOptions);\n };\n\n this.setScissor = function (scissor) {\n if (_this.gl && _this.gl._gl) {\n // https://developer.mozilla.org/zh-CN/docs/Web/API/WebGLRenderingContext/scissor\n if (scissor.enable && scissor.box) {\n // console.log(scissor.box);\n _this.gl._gl.enable(gl.SCISSOR_TEST);\n\n _this.gl._gl.scissor(scissor.box.x, scissor.box.y, scissor.box.width, scissor.box.height);\n } else {\n _this.gl._gl.disable(gl.SCISSOR_TEST);\n }\n\n _this.gl._refresh();\n }\n };\n\n this.viewport = function (_ref4) {\n var x = _ref4.x,\n y = _ref4.y,\n width = _ref4.width,\n height = _ref4.height;\n\n if (_this.gl && _this.gl._gl) {\n // use WebGL context directly\n // @see https://github.com/regl-project/regl/blob/gh-pages/API.md#unsafe-escape-hatch\n _this.gl._gl.viewport(x, y, width, height);\n\n _this.gl._refresh();\n }\n };\n\n this.readPixels = function (options) {\n var framebuffer = options.framebuffer,\n x = options.x,\n y = options.y,\n width = options.width,\n height = options.height;\n var readPixelsOptions = {\n x: x,\n y: y,\n width: width,\n height: height\n };\n\n if (framebuffer) {\n readPixelsOptions.framebuffer = framebuffer.get();\n }\n\n return _this.gl.read(readPixelsOptions);\n };\n\n this.getCanvas = function () {\n return _this.$canvas;\n };\n\n this.getGLContext = function () {\n return _this.gl._gl;\n };\n\n this.destroy = function () {\n if (_this.gl) {\n // @see https://github.com/regl-project/regl/blob/gh-pages/API.md#clean-up\n _this.gl.destroy();\n\n _this.inited = false;\n }\n };\n }\n\n _createClass(WebGLEngine, [{\n key: \"init\",\n value: function () {\n var _init = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee4(cfg) {\n return _regeneratorRuntime.wrap(function _callee4$(_context4) {\n while (1) {\n switch (_context4.prev = _context4.next) {\n case 0:\n if (!this.inited) {\n _context4.next = 2;\n break;\n }\n\n return _context4.abrupt(\"return\");\n\n case 2:\n this.$canvas = cfg.canvas; // tslint:disable-next-line:typedef\n\n _context4.next = 5;\n return new Promise(function (resolve, reject) {\n regl({\n canvas: cfg.canvas,\n attributes: {\n alpha: true,\n // use TAA instead of MSAA\n // @see https://www.khronos.org/registry/webgl/specs/1.0/#5.2.1\n antialias: cfg.antialias,\n premultipliedAlpha: true // preserveDrawingBuffer: false,\n\n },\n pixelRatio: 1,\n // TODO: use extensions\n extensions: ['OES_element_index_uint', 'OES_texture_float', 'OES_standard_derivatives', // wireframe\n 'angle_instanced_arrays' // VSM shadow map\n ],\n optionalExtensions: ['EXT_texture_filter_anisotropic', 'EXT_blend_minmax', 'WEBGL_depth_texture'],\n profile: true,\n onDone: function onDone(err, r) {\n if (err || !r) {\n reject(err);\n } // @ts-ignore\n\n\n resolve(r);\n }\n });\n });\n\n case 5:\n this.gl = _context4.sent;\n this.inited = true;\n\n case 7:\n case \"end\":\n return _context4.stop();\n }\n }\n }, _callee4, this);\n }));\n\n function init(_x4) {\n return _init.apply(this, arguments);\n }\n\n return init;\n }()\n }, {\n key: \"isFloatSupported\",\n value: function isFloatSupported() {\n // @see https://github.com/antvis/GWebGPUEngine/issues/26\n // @ts-ignore\n return this.gl.limits.readFloat;\n }\n }, {\n key: \"beginFrame\",\n value: function beginFrame() {//\n }\n }, {\n key: \"endFrame\",\n value: function endFrame() {//\n }\n }]);\n\n return WebGLEngine;\n}(), _temp)) || _class);\n//# sourceMappingURL=index.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport { loadScriptAsync } from '../utils/dom';\nvar glslang;\nexport default function () {\n return _ref.apply(this, arguments);\n}\n\nfunction _ref() {\n _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (!glslang) {\n _context.next = 2;\n break;\n }\n\n return _context.abrupt(\"return\", glslang);\n\n case 2:\n _context.next = 4;\n return loadScriptAsync('https://preview.babylonjs.com/glslang/glslang.js');\n\n case 4:\n glslang = window.glslang('https://preview.babylonjs.com/glslang/glslang.wasm');\n return _context.abrupt(\"return\", glslang);\n\n case 6:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }));\n return _ref.apply(this, arguments);\n}\n//# sourceMappingURL=glslang.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport { gl } from '@antv/g-webgpu-core';\nimport { colorSpaceMap, dataTypeMap, filterMap, formatMap, mipmapMap, wrapModeMap } from './constants';\n/**\n * adaptor for regl.Buffer\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#buffers\n */\n\nvar ReglTexture2D = /*#__PURE__*/function () {\n function ReglTexture2D(reGl, options) {\n _classCallCheck(this, ReglTexture2D);\n\n this.texture = void 0;\n this.width = void 0;\n this.height = void 0;\n var data = options.data,\n _options$type = options.type,\n type = _options$type === void 0 ? gl.UNSIGNED_BYTE : _options$type,\n width = options.width,\n height = options.height,\n _options$flipY = options.flipY,\n flipY = _options$flipY === void 0 ? false : _options$flipY,\n _options$format = options.format,\n format = _options$format === void 0 ? gl.RGBA : _options$format,\n _options$mipmap = options.mipmap,\n mipmap = _options$mipmap === void 0 ? false : _options$mipmap,\n _options$wrapS = options.wrapS,\n wrapS = _options$wrapS === void 0 ? gl.CLAMP_TO_EDGE : _options$wrapS,\n _options$wrapT = options.wrapT,\n wrapT = _options$wrapT === void 0 ? gl.CLAMP_TO_EDGE : _options$wrapT,\n _options$aniso = options.aniso,\n aniso = _options$aniso === void 0 ? 0 : _options$aniso,\n _options$alignment = options.alignment,\n alignment = _options$alignment === void 0 ? 1 : _options$alignment,\n _options$premultiplyA = options.premultiplyAlpha,\n premultiplyAlpha = _options$premultiplyA === void 0 ? false : _options$premultiplyA,\n _options$mag = options.mag,\n mag = _options$mag === void 0 ? gl.NEAREST : _options$mag,\n _options$min = options.min,\n min = _options$min === void 0 ? gl.NEAREST : _options$min,\n _options$colorSpace = options.colorSpace,\n colorSpace = _options$colorSpace === void 0 ? gl.BROWSER_DEFAULT_WEBGL : _options$colorSpace;\n this.width = width;\n this.height = height;\n var textureOptions = {\n width: width,\n height: height,\n // @ts-ignore\n type: dataTypeMap[type],\n format: formatMap[format],\n wrapS: wrapModeMap[wrapS],\n wrapT: wrapModeMap[wrapT],\n // @ts-ignore\n mag: filterMap[mag],\n min: filterMap[min],\n alignment: alignment,\n flipY: flipY,\n colorSpace: colorSpaceMap[colorSpace],\n premultiplyAlpha: premultiplyAlpha,\n aniso: aniso\n };\n\n if (data) {\n textureOptions.data = data;\n }\n\n if (typeof mipmap === 'number') {\n textureOptions.mipmap = mipmapMap[mipmap];\n } else if (typeof mipmap === 'boolean') {\n textureOptions.mipmap = mipmap;\n }\n\n this.texture = reGl.texture(textureOptions);\n }\n\n _createClass(ReglTexture2D, [{\n key: \"get\",\n value: function get() {\n return this.texture;\n }\n }, {\n key: \"update\",\n value: function update() {\n // @ts-ignore\n this.texture._texture.bind();\n }\n }, {\n key: \"resize\",\n value: function resize(_ref) {\n var width = _ref.width,\n height = _ref.height;\n this.texture.resize(width, height);\n this.width = width;\n this.height = height;\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n this.texture.destroy();\n }\n }]);\n\n return ReglTexture2D;\n}();\n\nexport { ReglTexture2D as default };\n//# sourceMappingURL=ReglTexture2D.js.map","export function isWindowObjectExist() {\n return typeof window !== 'undefined';\n}\nexport function loadScript(scriptUrl, onSuccess, onError, scriptId) {\n if (!isWindowObjectExist()) {\n return;\n }\n\n var head = document.getElementsByTagName('head')[0];\n var script = document.createElement('script');\n script.setAttribute('type', 'text/javascript');\n script.setAttribute('src', scriptUrl);\n\n if (scriptId) {\n script.id = scriptId;\n }\n\n script.onload = function () {\n if (onSuccess) {\n onSuccess();\n }\n };\n\n script.onerror = function (e) {\n if (onError) {\n onError(\"Unable to load script '\".concat(scriptUrl, \"'\"), e);\n }\n };\n\n head.appendChild(script);\n}\nexport function loadScriptAsync(scriptUrl, scriptId) {\n return new Promise(function (resolve, reject) {\n loadScript(scriptUrl, function () {\n resolve();\n }, function (message, exception) {\n reject(exception);\n });\n });\n}\n//# sourceMappingURL=dom.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\nvar WebGPUAttribute = /*#__PURE__*/function () {\n function WebGPUAttribute(engine, options) {\n _classCallCheck(this, WebGPUAttribute);\n\n this.engine = engine;\n this.options = options;\n this.attribute = void 0;\n this.buffer = void 0;\n var _options = options,\n buffer = _options.buffer,\n offset = _options.offset,\n stride = _options.stride,\n normalized = _options.normalized,\n size = _options.size,\n divisor = _options.divisor,\n arrayStride = _options.arrayStride,\n attributes = _options.attributes,\n stepMode = _options.stepMode;\n this.buffer = buffer;\n this.attribute = {\n buffer: buffer.get(),\n offset: offset || 0,\n stride: stride || 0,\n normalized: normalized || false,\n divisor: divisor || 0,\n arrayStride: arrayStride || 0,\n // @ts-ignore\n attributes: attributes,\n stepMode: stepMode || 'vertex'\n };\n\n if (size) {\n this.attribute.size = size;\n }\n }\n\n _createClass(WebGPUAttribute, [{\n key: \"get\",\n value: function get() {\n return this.attribute;\n }\n }, {\n key: \"updateBuffer\",\n value: function updateBuffer(options) {\n this.buffer.subData(options);\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n this.buffer.destroy();\n }\n }]);\n\n return WebGPUAttribute;\n}();\n\nexport { WebGPUAttribute as default };\n//# sourceMappingURL=WebGPUAttribute.js.map","import _defineProperty from \"@babel/runtime/helpers/defineProperty\";\n\nvar _primitiveMap, _depthFuncMap, _blendEquationMap, _blendFuncMap, _formatMap, _filterMap, _wrapModeMap;\n\nimport { gl } from '@antv/g-webgpu-core';\nimport * as WebGPUConstants from '@webgpu/types/dist/constants'; // WebGPU 不支持 LINE_LOOP & TRIANGLE_FAN\n\nexport var primitiveMap = (_primitiveMap = {}, _defineProperty(_primitiveMap, gl.POINTS, WebGPUConstants.PrimitiveTopology.PointList), _defineProperty(_primitiveMap, gl.LINES, WebGPUConstants.PrimitiveTopology.LineList), _defineProperty(_primitiveMap, gl.LINE_LOOP, WebGPUConstants.PrimitiveTopology.LineList), _defineProperty(_primitiveMap, gl.LINE_STRIP, WebGPUConstants.PrimitiveTopology.LineStrip), _defineProperty(_primitiveMap, gl.TRIANGLES, WebGPUConstants.PrimitiveTopology.TriangleList), _defineProperty(_primitiveMap, gl.TRIANGLE_FAN, WebGPUConstants.PrimitiveTopology.TriangleList), _defineProperty(_primitiveMap, gl.TRIANGLE_STRIP, WebGPUConstants.PrimitiveTopology.TriangleStrip), _primitiveMap);\nexport var depthFuncMap = (_depthFuncMap = {}, _defineProperty(_depthFuncMap, gl.NEVER, WebGPUConstants.CompareFunction.Never), _defineProperty(_depthFuncMap, gl.ALWAYS, WebGPUConstants.CompareFunction.Always), _defineProperty(_depthFuncMap, gl.LESS, WebGPUConstants.CompareFunction.Less), _defineProperty(_depthFuncMap, gl.LEQUAL, WebGPUConstants.CompareFunction.LessEqual), _defineProperty(_depthFuncMap, gl.GREATER, WebGPUConstants.CompareFunction.Greater), _defineProperty(_depthFuncMap, gl.GEQUAL, WebGPUConstants.CompareFunction.GreaterEqual), _defineProperty(_depthFuncMap, gl.EQUAL, WebGPUConstants.CompareFunction.Equal), _defineProperty(_depthFuncMap, gl.NOTEQUAL, WebGPUConstants.CompareFunction.NotEqual), _depthFuncMap);\nexport var blendEquationMap = (_blendEquationMap = {}, _defineProperty(_blendEquationMap, gl.FUNC_ADD, WebGPUConstants.BlendOperation.Add), _defineProperty(_blendEquationMap, gl.MIN_EXT, WebGPUConstants.BlendOperation.Min), _defineProperty(_blendEquationMap, gl.MAX_EXT, WebGPUConstants.BlendOperation.Max), _defineProperty(_blendEquationMap, gl.FUNC_SUBTRACT, WebGPUConstants.BlendOperation.Subtract), _defineProperty(_blendEquationMap, gl.FUNC_REVERSE_SUBTRACT, WebGPUConstants.BlendOperation.ReverseSubtract), _blendEquationMap); // @see https://gpuweb.github.io/gpuweb/#blend-state\n// 不支持 'constant alpha' 和 'one minus constant alpha'\n\nexport var blendFuncMap = (_blendFuncMap = {}, _defineProperty(_blendFuncMap, gl.ZERO, WebGPUConstants.BlendFactor.Zero), _defineProperty(_blendFuncMap, gl.ONE, WebGPUConstants.BlendFactor.One), _defineProperty(_blendFuncMap, gl.SRC_COLOR, WebGPUConstants.BlendFactor.SrcColor), _defineProperty(_blendFuncMap, gl.ONE_MINUS_SRC_COLOR, WebGPUConstants.BlendFactor.OneMinusSrcColor), _defineProperty(_blendFuncMap, gl.SRC_ALPHA, WebGPUConstants.BlendFactor.SrcAlpha), _defineProperty(_blendFuncMap, gl.ONE_MINUS_SRC_ALPHA, WebGPUConstants.BlendFactor.OneMinusSrcAlpha), _defineProperty(_blendFuncMap, gl.DST_COLOR, WebGPUConstants.BlendFactor.DstColor), _defineProperty(_blendFuncMap, gl.ONE_MINUS_DST_COLOR, WebGPUConstants.BlendFactor.OneMinusDstColor), _defineProperty(_blendFuncMap, gl.DST_ALPHA, WebGPUConstants.BlendFactor.DstAlpha), _defineProperty(_blendFuncMap, gl.ONE_MINUS_DST_ALPHA, WebGPUConstants.BlendFactor.OneMinusDstAlpha), _defineProperty(_blendFuncMap, gl.CONSTANT_COLOR, WebGPUConstants.BlendFactor.BlendColor), _defineProperty(_blendFuncMap, gl.ONE_MINUS_CONSTANT_COLOR, WebGPUConstants.BlendFactor.OneMinusBlendColor), _defineProperty(_blendFuncMap, gl.SRC_ALPHA_SATURATE, WebGPUConstants.BlendFactor.SrcAlphaSaturated), _blendFuncMap); // @see https://gpuweb.github.io/gpuweb/#texture-formats\n\nexport var formatMap = (_formatMap = {}, _defineProperty(_formatMap, gl.ALPHA, 'r8unorm'), _defineProperty(_formatMap, gl.RGBA, 'rgba8unorm'), _defineProperty(_formatMap, gl.DEPTH_COMPONENT, 'depth32float'), _defineProperty(_formatMap, gl.DEPTH_STENCIL, 'depth24plus-stencil8'), _formatMap); // @see https://gpuweb.github.io/gpuweb/#enumdef-gpufiltermode\n\nexport var filterMap = (_filterMap = {}, _defineProperty(_filterMap, gl.NEAREST, 'nearest'), _defineProperty(_filterMap, gl.LINEAR, 'linear'), _filterMap); // @see https://gpuweb.github.io/gpuweb/#enumdef-gpuaddressmode\n\nexport var wrapModeMap = (_wrapModeMap = {}, _defineProperty(_wrapModeMap, gl.REPEAT, 'repeat'), _defineProperty(_wrapModeMap, gl.CLAMP_TO_EDGE, 'clamp-to-edge'), _defineProperty(_wrapModeMap, gl.MIRRORED_REPEAT, 'mirror-repeat'), _wrapModeMap);\nexport function getCullMode(_ref) {\n var cull = _ref.cull;\n\n if (!cull || !cull.enable) {\n return WebGPUConstants.CullMode.None;\n }\n\n if (cull.face) {\n return cull.face === gl.FRONT ? WebGPUConstants.CullMode.Front : WebGPUConstants.CullMode.Back;\n }\n}\nexport function getDepthStencilStateDescriptor(_ref2) {\n var depth = _ref2.depth,\n stencil = _ref2.stencil;\n // TODO: stencil\n var stencilFrontBack = {\n compare: WebGPUConstants.CompareFunction.Always,\n depthFailOp: WebGPUConstants.StencilOperation.Keep,\n failOp: WebGPUConstants.StencilOperation.Keep,\n passOp: WebGPUConstants.StencilOperation.Keep\n };\n return {\n depthWriteEnabled: depth && depth.enable,\n depthCompare: depthFuncMap[(depth === null || depth === void 0 ? void 0 : depth.func) || gl.ALWAYS],\n format: WebGPUConstants.TextureFormat.Depth24PlusStencil8,\n stencilFront: stencilFrontBack,\n stencilBack: stencilFrontBack,\n stencilReadMask: 0xffffffff,\n stencilWriteMask: 0xffffffff\n };\n}\n/**\n * @see https://gpuweb.github.io/gpuweb/#color-state\n */\n\nexport function getColorStateDescriptors(_ref3, swapChainFormat) {\n var blend = _ref3.blend;\n return [{\n format: swapChainFormat,\n // https://gpuweb.github.io/gpuweb/#blend-state\n alphaBlend: {\n srcFactor: blendFuncMap[blend && blend.func && blend.func.srcAlpha || gl.ONE],\n dstFactor: blendFuncMap[blend && blend.func && blend.func.dstAlpha || gl.ZERO],\n operation: blendEquationMap[blend && blend.equation && blend.equation.alpha || gl.FUNC_ADD]\n },\n colorBlend: {\n srcFactor: blendFuncMap[blend && blend.func && blend.func.srcRGB || gl.ONE],\n dstFactor: blendFuncMap[blend && blend.func && blend.func.dstRGB || gl.ZERO],\n operation: blendEquationMap[blend && blend.equation && blend.equation.rgb || gl.FUNC_ADD]\n },\n writeMask: WebGPUConstants.ColorWrite.All\n }];\n}\n//# sourceMappingURL=constants.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport { isSafari } from '@antv/g-webgpu-core';\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\n\nvar WebGPUBuffer = /*#__PURE__*/function () {\n function WebGPUBuffer(engine, options) {\n _classCallCheck(this, WebGPUBuffer);\n\n this.engine = engine;\n this.options = options;\n this.buffer = void 0;\n var _options = options,\n data = _options.data,\n usage = _options.usage,\n type = _options.type;\n this.buffer = this.createBuffer(data instanceof Array ? new Float32Array(data) : data, // TODO: WebGL 和 WebGPU buffer usage 映射关系\n usage || WebGPUConstants.BufferUsage.Vertex | WebGPUConstants.BufferUsage.CopyDst);\n }\n\n _createClass(WebGPUBuffer, [{\n key: \"get\",\n value: function get() {\n return this.buffer;\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n this.buffer.destroy();\n }\n }, {\n key: \"subData\",\n value: function subData(_ref) {\n var data = _ref.data,\n offset = _ref.offset;\n this.setSubData(this.buffer, offset, data instanceof Array ? new Float32Array(data) : data);\n }\n }, {\n key: \"createBuffer\",\n value: function createBuffer(view, flags) {\n // @ts-ignore\n var padding = view.byteLength % 4;\n var verticesBufferDescriptor = {\n // @ts-ignore\n size: view.byteLength + padding,\n usage: flags\n };\n var buffer = this.engine.device.createBuffer(verticesBufferDescriptor);\n this.setSubData(buffer, 0, view);\n return buffer;\n }\n /**\n * 不同于 Babylon.js 的版本,使用最新的 GPUQueue.writeBuffer 方法\n * @see https://gpuweb.github.io/gpuweb/#dom-gpuqueue-writebuffer\n * 已废弃创建一个临时的 mapped buffer 用于拷贝数据 @see https://gpuweb.github.io/gpuweb/#GPUDevice-createBufferMapped\n * @see https://github.com/gpuweb/gpuweb/blob/master/design/BufferOperations.md#updating-data-to-an-existing-buffer-like-webgls-buffersubdata\n */\n\n }, {\n key: \"setSubData\",\n value: function setSubData(destBuffer, destOffset, srcArrayBuffer) {\n // deprecated API setSubData\n // destBuffer.setSubData(0, srcArrayBuffer);\n // deprecated API createBufferMapped\n // use createBuffer & getMappedRange instead\n // const [srcBuffer, arrayBuffer] = this.engine.device.createBufferMapped({\n // size: byteCount,\n // usage: WebGPUConstants.BufferUsage.CopySrc,\n // });\n var queue = isSafari ? // @ts-ignore\n this.engine.device.getQueue() : this.engine.device.defaultQueue; // @ts-ignore\n\n queue.writeBuffer(destBuffer, destOffset, srcArrayBuffer);\n }\n }]);\n\n return WebGPUBuffer;\n}();\n\nexport { WebGPUBuffer as default };\n//# sourceMappingURL=WebGPUBuffer.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _toConsumableArray from \"@babel/runtime/helpers/toConsumableArray\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport { AST_TOKEN_TYPES, createEntity, isSafari, STORAGE_CLASS } from '@antv/g-webgpu-core';\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { isNumber } from '../utils/is-number';\nimport WebGPUBuffer from './WebGPUBuffer';\n\nvar WebGPUComputeModel = /*#__PURE__*/function () {\n /**\n * 用于后续渲染时动态更新\n */\n function WebGPUComputeModel(engine, context) {\n _classCallCheck(this, WebGPUComputeModel);\n\n this.engine = engine;\n this.context = context;\n this.entity = createEntity();\n this.uniformGPUBufferLayout = [];\n this.uniformBuffer = void 0;\n this.vertexBuffers = {};\n this.outputBuffer = void 0;\n this.bindGroupEntries = void 0;\n this.bindGroup = void 0;\n this.computePipeline = void 0;\n }\n\n _createClass(WebGPUComputeModel, [{\n key: \"init\",\n value: function () {\n var _init = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {\n var _this = this;\n\n var _yield$this$compileCo, computeStage, buffers, uniforms, bufferBindingIndex, offset, mergedUniformData;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _context.next = 2;\n return this.compileComputePipelineStageDescriptor(this.context.shader);\n\n case 2:\n _yield$this$compileCo = _context.sent;\n computeStage = _yield$this$compileCo.computeStage;\n buffers = this.context.uniforms.filter(function (uniform) {\n return uniform.storageClass === STORAGE_CLASS.StorageBuffer;\n });\n uniforms = this.context.uniforms.filter(function (uniform) {\n return uniform.storageClass === STORAGE_CLASS.Uniform;\n });\n bufferBindingIndex = uniforms.length ? 1 : 0;\n this.bindGroupEntries = [];\n\n if (bufferBindingIndex) {\n offset = 0; // FIXME: 所有 uniform 合并成一个 buffer,固定使用 Float32Array 存储,确实会造成一些内存的浪费\n // we use std140 layout @see https://www.khronos.org/opengl/wiki/Interface_Block_(GLSL)\n\n mergedUniformData = [];\n uniforms.forEach(function (uniform) {\n if (isNumber(uniform.data)) {\n _this.uniformGPUBufferLayout.push({\n name: uniform.name,\n offset: offset\n });\n\n offset += 4; // @ts-ignore\n\n mergedUniformData.push(uniform.data);\n } else {\n var _uniform$data;\n\n // @ts-ignore\n var originDataLength = ((_uniform$data = uniform.data) === null || _uniform$data === void 0 ? void 0 : _uniform$data.length) || 1;\n\n if (originDataLength === 3) {\n // vec3 -> vec4\n // @see http://ptgmedia.pearsoncmg.com/images/9780321552624/downloads/0321552628_AppL.pdf\n originDataLength = 4; // @ts-ignore\n\n uniform.data.push(0);\n } // 4 elements per block/line\n\n\n var padding = offset / 4 % 4;\n\n if (padding > 0) {\n var space = 4 - padding;\n\n if (originDataLength > 1 && originDataLength <= space) {\n if (originDataLength === 2) {\n if (space === 3) {\n offset += 4;\n mergedUniformData.push(0);\n } // @ts-ignore\n\n\n mergedUniformData.push.apply(mergedUniformData, _toConsumableArray(uniform.data));\n\n _this.uniformGPUBufferLayout.push({\n name: uniform.name,\n offset: offset\n });\n }\n } else {\n for (var i = 0; i < space; i++) {\n offset += 4;\n mergedUniformData.push(0);\n } // @ts-ignore\n\n\n mergedUniformData.push.apply(mergedUniformData, _toConsumableArray(uniform.data));\n\n _this.uniformGPUBufferLayout.push({\n name: uniform.name,\n offset: offset\n });\n }\n }\n\n offset += 4 * originDataLength;\n }\n });\n this.uniformBuffer = new WebGPUBuffer(this.engine, {\n // TODO: 处理 Struct 和 boolean\n // @ts-ignore\n data: mergedUniformData instanceof Array ? // @ts-ignore\n new Float32Array(mergedUniformData) : mergedUniformData,\n usage: WebGPUConstants.BufferUsage.Uniform | WebGPUConstants.BufferUsage.CopyDst\n });\n this.bindGroupEntries.push({\n binding: 0,\n resource: {\n buffer: this.uniformBuffer.get()\n }\n });\n } // create GPUBuffers for storeage buffers\n\n\n buffers.forEach(function (buffer) {\n if (buffer.data !== null) {\n if (buffer.type === AST_TOKEN_TYPES.Vector4FloatArray || buffer.type === AST_TOKEN_TYPES.FloatArray) {\n var gpuBuffer;\n\n if (buffer.name === _this.context.output.name) {\n gpuBuffer = new WebGPUBuffer(_this.engine, {\n // @ts-ignore\n data: isFinite(Number(buffer.data)) ? [buffer.data] : buffer.data,\n usage: WebGPUConstants.BufferUsage.Storage | WebGPUConstants.BufferUsage.CopyDst | WebGPUConstants.BufferUsage.CopySrc\n });\n _this.outputBuffer = gpuBuffer;\n _this.context.output = {\n name: buffer.name,\n // @ts-ignore\n length: isFinite(Number(buffer.data)) ? 1 : buffer.data.length,\n typedArrayConstructor: Float32Array,\n gpuBuffer: gpuBuffer.get()\n };\n } else {\n if (buffer.isReferer) {\n // @ts-ignore\n if (buffer.data.model && buffer.data.model.outputBuffer) {\n // @ts-ignore\n gpuBuffer = buffer.data.model.outputBuffer;\n } else {// referred kernel haven't been executed\n }\n } else {\n gpuBuffer = new WebGPUBuffer(_this.engine, {\n // @ts-ignore\n data: isFinite(Number(buffer.data)) ? [buffer.data] : buffer.data,\n usage: WebGPUConstants.BufferUsage.Storage | WebGPUConstants.BufferUsage.CopyDst | WebGPUConstants.BufferUsage.CopySrc\n });\n }\n } // @ts-ignore\n\n\n _this.vertexBuffers[buffer.name] = gpuBuffer;\n\n _this.bindGroupEntries.push({\n binding: bufferBindingIndex,\n resource: {\n name: buffer.name,\n refer: gpuBuffer ? undefined : buffer.data,\n // @ts-ignore\n buffer: gpuBuffer ? gpuBuffer.get() : undefined\n }\n });\n\n bufferBindingIndex++;\n }\n }\n }); // create compute pipeline layout\n\n this.computePipeline = this.engine.device.createComputePipeline({\n computeStage: computeStage\n });\n console.log(this.bindGroupEntries);\n this.bindGroup = this.engine.device.createBindGroup({\n layout: this.computePipeline.getBindGroupLayout(0),\n entries: this.bindGroupEntries\n });\n\n case 13:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function init() {\n return _init.apply(this, arguments);\n }\n\n return init;\n }()\n }, {\n key: \"destroy\",\n value: function destroy() {\n var _this2 = this;\n\n if (this.uniformBuffer) {\n this.uniformBuffer.destroy();\n }\n\n Object.keys(this.vertexBuffers).forEach(function (bufferName) {\n return _this2.vertexBuffers[bufferName].destroy();\n });\n }\n }, {\n key: \"readData\",\n value: function () {\n var _readData = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2() {\n var output, length, typedArrayConstructor, gpuBuffer, byteCount, gpuReadBuffer, encoder, queue, arraybuffer, typedArray;\n return _regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n output = this.context.output;\n\n if (!output) {\n _context2.next = 16;\n break;\n }\n\n length = output.length, typedArrayConstructor = output.typedArrayConstructor, gpuBuffer = output.gpuBuffer;\n\n if (!gpuBuffer) {\n _context2.next = 16;\n break;\n }\n\n // await gpuBuffer.mapAsync(WebGPUConstants.MapMode.Read);\n // const arraybuffer = gpuBuffer.getMappedRange();\n // let arraybuffer;\n // if (isSafari) {\n // arraybuffer = await gpuBuffer.mapReadAsync();\n // } else {\n byteCount = length * typedArrayConstructor.BYTES_PER_ELEMENT; // @see https://developers.google.com/web/updates/2019/08/get-started-with-gpu-compute-on-the-web\n\n gpuReadBuffer = this.engine.device.createBuffer({\n size: byteCount,\n usage: GPUBufferUsage.COPY_DST | GPUBufferUsage.MAP_READ\n });\n encoder = this.engine.device.createCommandEncoder();\n encoder.copyBufferToBuffer(gpuBuffer, 0, gpuReadBuffer, 0, byteCount);\n queue = isSafari ? // @ts-ignore\n this.engine.device.getQueue() : this.engine.device.defaultQueue;\n queue.submit([encoder.finish()]);\n _context2.next = 12;\n return gpuReadBuffer.mapAsync(WebGPUConstants.MapMode.Read);\n\n case 12:\n arraybuffer = gpuReadBuffer.getMappedRange();\n typedArray = new typedArrayConstructor(arraybuffer.slice(0));\n gpuReadBuffer.unmap();\n return _context2.abrupt(\"return\", typedArray);\n\n case 16:\n return _context2.abrupt(\"return\", new Float32Array());\n\n case 17:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this);\n }));\n\n function readData() {\n return _readData.apply(this, arguments);\n }\n\n return readData;\n }()\n }, {\n key: \"run\",\n value: function run() {\n if (this.engine.currentComputePass) {\n var _this$engine$currentC;\n\n this.engine.currentComputePass.setPipeline(this.computePipeline); // this.bindGroupEntries.forEach((entry) => {\n // if (!entry.resource.buffer) {\n // // get referred kernel's output\n // const gpuBuffer = (entry.resource.refer.model as WebGPUComputeModel)\n // .outputBuffer;\n // this.vertexBuffers[entry.resource.name] = gpuBuffer;\n // entry.resource.buffer = gpuBuffer.get();\n // }\n // });\n // const bindGroup = this.engine.device.createBindGroup({\n // layout: this.computePipeline.getBindGroupLayout(0),\n // entries: this.bindGroupEntries,\n // });\n\n this.engine.currentComputePass.setBindGroup(0, this.bindGroup);\n\n (_this$engine$currentC = this.engine.currentComputePass).dispatch.apply(_this$engine$currentC, _toConsumableArray(this.context.dispatch));\n }\n }\n }, {\n key: \"updateBuffer\",\n value: function updateBuffer(bufferName, data) {\n var offset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;\n var buffer = this.vertexBuffers[bufferName];\n\n if (buffer) {\n buffer.subData({\n data: data,\n offset: offset\n });\n }\n }\n }, {\n key: \"updateUniform\",\n value: function updateUniform(uniformName, data) {\n var layout = this.uniformGPUBufferLayout.find(function (l) {\n return l.name === uniformName;\n });\n\n if (layout) {\n this.uniformBuffer.subData({\n data: Number.isFinite(data) ? new Float32Array([data]) : new Float32Array(data),\n offset: layout.offset\n });\n }\n }\n }, {\n key: \"confirmInput\",\n value: function confirmInput(model, inputName) {\n // copy output GPUBuffer of kernel\n var inputBuffer = this.vertexBuffers[inputName];\n var outputBuffer = model.outputBuffer;\n\n if (inputBuffer && outputBuffer && inputBuffer !== outputBuffer) {\n var encoder = this.engine.device.createCommandEncoder();\n var _context$output = model.context.output,\n length = _context$output.length,\n typedArrayConstructor = _context$output.typedArrayConstructor;\n var byteCount = length * typedArrayConstructor.BYTES_PER_ELEMENT;\n encoder.copyBufferToBuffer(outputBuffer.get(), 0, inputBuffer.get(), 0, byteCount);\n var queue = isSafari ? // @ts-ignore\n this.engine.device.getQueue() : this.engine.device.defaultQueue;\n queue.submit([encoder.finish()]);\n }\n }\n }, {\n key: \"compileShaderToSpirV\",\n value: function compileShaderToSpirV(source, type, shaderVersion) {\n return this.compileRawShaderToSpirV(shaderVersion + source, type);\n }\n }, {\n key: \"compileRawShaderToSpirV\",\n value: function compileRawShaderToSpirV(source, type) {\n return this.engine.glslang.compileGLSL(source, type);\n }\n }, {\n key: \"compileComputePipelineStageDescriptor\",\n value: function () {\n var _compileComputePipelineStageDescriptor = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee3(computeCode) {\n var computeShader, shaderVersion;\n return _regeneratorRuntime.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n computeShader = computeCode;\n shaderVersion = '#version 450\\n';\n\n if (this.engine.options.useWGSL) {\n _context3.next = 6;\n break;\n }\n\n _context3.next = 5;\n return this.compileShaderToSpirV(computeCode, 'compute', shaderVersion);\n\n case 5:\n computeShader = _context3.sent;\n\n case 6:\n return _context3.abrupt(\"return\", {\n computeStage: {\n module: this.engine.device.createShaderModule({\n code: computeShader,\n // @ts-ignore\n isWHLSL: isSafari\n }),\n entryPoint: 'main'\n }\n });\n\n case 7:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, this);\n }));\n\n function compileComputePipelineStageDescriptor(_x) {\n return _compileComputePipelineStageDescriptor.apply(this, arguments);\n }\n\n return compileComputePipelineStageDescriptor;\n }()\n }]);\n\n return WebGPUComputeModel;\n}();\n\nexport { WebGPUComputeModel as default };\n//# sourceMappingURL=WebGPUComputeModel.js.map","export function isNumber(value) {\n return typeof value === 'number';\n}\n//# sourceMappingURL=is-number.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport WebGPUBuffer from './WebGPUBuffer';\n\nvar WebGPUElements = /*#__PURE__*/function () {\n function WebGPUElements(engine, options) {\n _classCallCheck(this, WebGPUElements);\n\n this.engine = engine;\n this.options = options;\n this.indexCount = void 0;\n this.buffer = void 0;\n var _options = options,\n data = _options.data,\n usage = _options.usage,\n type = _options.type,\n count = _options.count;\n this.indexCount = count || 0;\n this.buffer = new WebGPUBuffer(engine, {\n // @ts-ignore\n data: data instanceof Array ? new Uint16Array(data) : data,\n usage: WebGPUConstants.BufferUsage.Index | WebGPUConstants.BufferUsage.CopyDst\n });\n }\n\n _createClass(WebGPUElements, [{\n key: \"get\",\n value: function get() {\n return this.buffer;\n }\n }, {\n key: \"subData\",\n value: function subData(options) {\n this.buffer.subData(options);\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n this.buffer.destroy();\n }\n }]);\n\n return WebGPUElements;\n}();\n\nexport { WebGPUElements as default };\n//# sourceMappingURL=WebGPUElements.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\nvar WebGPUFramebuffer = /*#__PURE__*/function () {\n function WebGPUFramebuffer(engine, options) {\n _classCallCheck(this, WebGPUFramebuffer);\n\n this.engine = engine;\n this.options = options;\n this.colorTexture = void 0;\n this.depthTexture = void 0;\n this.width = 0;\n this.height = 0;\n var _options = options,\n width = _options.width,\n height = _options.height,\n color = _options.color,\n colors = _options.colors,\n depth = _options.depth,\n stencil = _options.stencil;\n\n if (color) {\n this.colorTexture = color;\n }\n\n if (depth) {\n this.depthTexture = depth;\n } // TODO: depth & stencil\n\n }\n\n _createClass(WebGPUFramebuffer, [{\n key: \"get\",\n value: function get() {\n var _this$colorTexture, _this$depthTexture;\n\n return {\n color: (_this$colorTexture = this.colorTexture) === null || _this$colorTexture === void 0 ? void 0 : _this$colorTexture.get(),\n depth: (_this$depthTexture = this.depthTexture) === null || _this$depthTexture === void 0 ? void 0 : _this$depthTexture.get()\n };\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n var _this$colorTexture2, _this$depthTexture2;\n\n (_this$colorTexture2 = this.colorTexture) === null || _this$colorTexture2 === void 0 ? void 0 : _this$colorTexture2.destroy();\n (_this$depthTexture2 = this.depthTexture) === null || _this$depthTexture2 === void 0 ? void 0 : _this$depthTexture2.destroy();\n }\n }, {\n key: \"resize\",\n value: function resize(_ref) {\n var width = _ref.width,\n height = _ref.height;\n\n if (width !== this.width || height !== this.height) {\n var _this$colorTexture3, _this$depthTexture3;\n\n (_this$colorTexture3 = this.colorTexture) === null || _this$colorTexture3 === void 0 ? void 0 : _this$colorTexture3.resize({\n width: width,\n height: height\n });\n (_this$depthTexture3 = this.depthTexture) === null || _this$depthTexture3 === void 0 ? void 0 : _this$depthTexture3.resize({\n width: width,\n height: height\n });\n }\n\n this.width = width;\n this.height = height;\n }\n }]);\n\n return WebGPUFramebuffer;\n}();\n\nexport { WebGPUFramebuffer as default };\n//# sourceMappingURL=WebGPUFramebuffer.js.map","import _toConsumableArray from \"@babel/runtime/helpers/toConsumableArray\";\nimport _typeof from \"@babel/runtime/helpers/typeof\";\nimport _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { gl, isSafari } from '@antv/g-webgpu-core';\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { extractUniforms } from '../utils/uniform';\nimport { getColorStateDescriptors, getCullMode, getDepthStencilStateDescriptor, primitiveMap } from './constants';\nimport WebGPUBuffer from './WebGPUBuffer';\n\n// @ts-ignore\nfunction concatenate(resultConstructor) {\n var totalLength = 0;\n\n for (var _len = arguments.length, arrays = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n arrays[_key - 1] = arguments[_key];\n }\n\n for (var _i = 0, _arrays = arrays; _i < _arrays.length; _i++) {\n var arr = _arrays[_i];\n totalLength += arr.length;\n }\n\n var result = new resultConstructor(totalLength);\n var offset = 0;\n\n for (var _i2 = 0, _arrays2 = arrays; _i2 < _arrays2.length; _i2++) {\n var _arr = _arrays2[_i2];\n result.set(_arr, offset);\n offset += _arr.length;\n }\n\n return result;\n}\n\nvar WebGPUModel = /*#__PURE__*/function () {\n /**\n * 用于后续渲染时动态更新\n */\n\n /**\n * vertex\n */\n\n /**\n * indices's buffer\n */\n function WebGPUModel(engine, options) {\n _classCallCheck(this, WebGPUModel);\n\n this.engine = engine;\n this.options = options;\n this.pipelineLayout = void 0;\n this.renderPipeline = void 0;\n this.uniformsBindGroupLayout = void 0;\n this.uniformBindGroup = void 0;\n this.uniformBuffer = void 0;\n this.uniforms = {};\n this.uniformGPUBufferLayout = [];\n this.attributeCache = {};\n this.indexBuffer = void 0;\n this.indexCount = void 0;\n }\n\n _createClass(WebGPUModel, [{\n key: \"init\",\n value: function () {\n var _init = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {\n var _this = this;\n\n var _this$options, vs, fs, attributes, uniforms, primitive, count, elements, depth, blend, stencil, cull, instances, _yield$this$compilePi, vertexStage, fragmentStage, vertexState, descriptor;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _this$options = this.options, vs = _this$options.vs, fs = _this$options.fs, attributes = _this$options.attributes, uniforms = _this$options.uniforms, primitive = _this$options.primitive, count = _this$options.count, elements = _this$options.elements, depth = _this$options.depth, blend = _this$options.blend, stencil = _this$options.stencil, cull = _this$options.cull, instances = _this$options.instances; // build shaders first\n\n _context.next = 3;\n return this.compilePipelineStageDescriptor(vs, fs, null);\n\n case 3:\n _yield$this$compilePi = _context.sent;\n vertexStage = _yield$this$compilePi.vertexStage;\n fragmentStage = _yield$this$compilePi.fragmentStage;\n\n if (uniforms) {\n // create uniform bind groups & layout\n this.buildUniformBindGroup(uniforms);\n }\n\n if (elements) {\n this.indexBuffer = elements.get();\n this.indexCount = elements.indexCount;\n } // TODO: instanced array\n\n\n vertexState = {\n vertexBuffers: Object.keys(attributes).map(function (attributeName, i) {\n var attribute = attributes[attributeName];\n\n var _attribute$get = attribute.get(),\n arrayStride = _attribute$get.arrayStride,\n stepMode = _attribute$get.stepMode,\n ats = _attribute$get.attributes;\n\n _this.attributeCache[attributeName] = attribute;\n return {\n arrayStride: arrayStride,\n stepMode: stepMode,\n attributes: ats\n };\n })\n };\n descriptor = {\n sampleCount: this.engine.mainPassSampleCount,\n primitiveTopology: primitiveMap[primitive || gl.TRIANGLES],\n rasterizationState: _objectSpread(_objectSpread({}, this.getDefaultRasterizationStateDescriptor()), {}, {\n // TODO: support frontface\n cullMode: getCullMode({\n cull: cull\n })\n }),\n depthStencilState: getDepthStencilStateDescriptor({\n depth: depth,\n stencil: stencil\n }),\n colorStates: getColorStateDescriptors({\n blend: blend\n }, this.engine.options.swapChainFormat),\n layout: this.pipelineLayout,\n vertexStage: vertexStage,\n fragmentStage: fragmentStage,\n vertexState: vertexState\n }; // create pipeline\n\n this.renderPipeline = this.engine.device.createRenderPipeline(descriptor);\n\n case 11:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function init() {\n return _init.apply(this, arguments);\n }\n\n return init;\n }()\n }, {\n key: \"addUniforms\",\n value: function addUniforms(uniforms) {\n this.uniforms = _objectSpread(_objectSpread({}, this.uniforms), extractUniforms(uniforms));\n }\n }, {\n key: \"draw\",\n value: function draw(options) {\n var _this2 = this;\n\n var renderPass = this.engine.getCurrentRenderPass();\n\n var uniforms = _objectSpread(_objectSpread({}, this.uniforms), extractUniforms(options.uniforms || {}));\n\n var bindGroupBindings = []; // TODO: uniform 发生修改\n\n Object.keys(uniforms).forEach(function (uniformName) {\n var type = _typeof(uniforms[uniformName]);\n\n if (type === 'boolean' || type === 'number' || Array.isArray(uniforms[uniformName]) || // @ts-ignore\n uniforms[uniformName].BYTES_PER_ELEMENT) {\n var _this2$uniformGPUBuff;\n\n var offset = (_this2$uniformGPUBuff = _this2.uniformGPUBufferLayout.find(function (_ref) {\n var name = _ref.name;\n return name === uniformName;\n })) === null || _this2$uniformGPUBuff === void 0 ? void 0 : _this2$uniformGPUBuff.offset;\n\n if (offset !== null) {\n _this2.uniformBuffer.subData({\n // @ts-ignore\n data: uniforms[uniformName],\n // @ts-ignore\n offset: offset\n });\n }\n } else {\n var _this2$uniformGPUBuff2;\n\n var _offset = (_this2$uniformGPUBuff2 = _this2.uniformGPUBufferLayout.find(function (_ref2) {\n var name = _ref2.name;\n return name === uniformName;\n })) === null || _this2$uniformGPUBuff2 === void 0 ? void 0 : _this2$uniformGPUBuff2.offset;\n\n if (_offset !== null) {\n var textureOrFramebuffer = uniforms[uniformName].get();\n\n var _ref3 = // @ts-ignore\n textureOrFramebuffer.color || textureOrFramebuffer,\n texture = _ref3.texture,\n sampler = _ref3.sampler;\n\n if (sampler) {\n bindGroupBindings.push({\n // @ts-ignore\n binding: _offset,\n resource: sampler\n }); // @ts-ignore\n\n _offset++;\n }\n\n bindGroupBindings.push({\n // @ts-ignore\n binding: _offset,\n resource: texture.createView()\n });\n }\n }\n });\n\n if (this.uniformBuffer) {\n bindGroupBindings[0] = {\n binding: 0,\n resource: {\n buffer: this.uniformBuffer.get() // 返回 GPUBuffer 原生对象\n\n }\n };\n }\n\n this.uniformBindGroup = this.engine.device.createBindGroup({\n layout: this.uniformsBindGroupLayout,\n entries: bindGroupBindings\n });\n\n if (this.renderPipeline) {\n renderPass.setPipeline(this.renderPipeline);\n }\n\n renderPass.setBindGroup(0, this.uniformBindGroup);\n\n if (this.indexBuffer) {\n renderPass.setIndexBuffer(this.indexBuffer.get(), WebGPUConstants.IndexFormat.Uint32, 0);\n }\n\n Object.keys(this.attributeCache).forEach(function (attributeName, i) {\n renderPass.setVertexBuffer(0 + i, _this2.attributeCache[attributeName].get().buffer, 0);\n }); // renderPass.draw(verticesCount, instancesCount, verticesStart, 0);\n\n if (this.indexBuffer) {\n renderPass.drawIndexed(this.indexCount, this.options.instances || 1, 0, 0, 0);\n } else {\n renderPass.draw(this.options.count || 0, this.options.instances || 0, 0, 0);\n }\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n throw new Error('Method not implemented.');\n }\n }, {\n key: \"compilePipelineStageDescriptor\",\n value: function () {\n var _compilePipelineStageDescriptor = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(vertexCode, fragmentCode, defines) {\n var shaderVersion, vertexShader, fragmentShader;\n return _regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n shaderVersion = '#version 450\\n';\n vertexShader = vertexCode;\n fragmentShader = fragmentCode;\n\n if (this.engine.options.useWGSL) {\n _context2.next = 10;\n break;\n }\n\n _context2.next = 6;\n return this.compileShaderToSpirV(vertexCode, 'vertex', shaderVersion);\n\n case 6:\n vertexShader = _context2.sent;\n _context2.next = 9;\n return this.compileShaderToSpirV(fragmentCode, 'fragment', shaderVersion);\n\n case 9:\n fragmentShader = _context2.sent;\n\n case 10:\n return _context2.abrupt(\"return\", this.createPipelineStageDescriptor(vertexShader, fragmentShader));\n\n case 11:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this);\n }));\n\n function compilePipelineStageDescriptor(_x, _x2, _x3) {\n return _compilePipelineStageDescriptor.apply(this, arguments);\n }\n\n return compilePipelineStageDescriptor;\n }()\n }, {\n key: \"compileShaderToSpirV\",\n value: function compileShaderToSpirV(source, type, shaderVersion) {\n return this.compileRawShaderToSpirV(shaderVersion + source, type);\n }\n }, {\n key: \"compileRawShaderToSpirV\",\n value: function compileRawShaderToSpirV(source, type) {\n return this.engine.glslang.compileGLSL(source, type);\n }\n }, {\n key: \"createPipelineStageDescriptor\",\n value: function createPipelineStageDescriptor(vertexShader, fragmentShader) {\n return {\n vertexStage: {\n module: this.engine.device.createShaderModule({\n code: vertexShader,\n // @ts-ignore\n isWHLSL: isSafari\n }),\n entryPoint: 'main'\n },\n fragmentStage: {\n module: this.engine.device.createShaderModule({\n code: fragmentShader,\n // @ts-ignore\n isWHLSL: isSafari\n }),\n entryPoint: 'main'\n }\n };\n }\n /**\n * @see https://gpuweb.github.io/gpuweb/#rasterization-state\n */\n\n }, {\n key: \"getDefaultRasterizationStateDescriptor\",\n value: function getDefaultRasterizationStateDescriptor() {\n return {\n frontFace: WebGPUConstants.FrontFace.CCW,\n cullMode: WebGPUConstants.CullMode.None,\n depthBias: 0,\n depthBiasSlopeScale: 0,\n depthBiasClamp: 0\n };\n }\n }, {\n key: \"buildUniformBindGroup\",\n value: function buildUniformBindGroup(uniforms) {\n var _this3 = this;\n\n var offset = 0; // FIXME: 所有 uniform 合并成一个 buffer,固定使用 Float32Array 存储,确实会造成一些内存的浪费\n\n var mergedUniformData = concatenate.apply(void 0, [Float32Array].concat(_toConsumableArray(Object.keys(uniforms).map(function (uniformName) {\n if (uniforms[uniformName]) {\n _this3.uniformGPUBufferLayout.push({\n name: uniformName,\n offset: offset\n }); // @ts-ignore\n\n\n offset += (uniforms[uniformName].length || 1) * 4;\n return uniforms[uniformName];\n } else {\n // texture & framebuffer\n return [];\n }\n }))));\n var entries = [];\n var hasUniform = false;\n\n if (mergedUniformData.length) {\n hasUniform = true; // TODO: 所有 uniform 绑定到 slot 0,通过解析 Shader 代码判定可见性\n\n entries.push({\n // TODO: 暂时都绑定到 slot 0\n binding: 0,\n visibility: WebGPUConstants.ShaderStage.Fragment | WebGPUConstants.ShaderStage.Vertex,\n // TODO: 暂时 VS 和 FS 都可见\n type: WebGPUConstants.BindingType.UniformBuffer\n });\n } // 声明 texture & sampler\n\n\n Object.keys(uniforms).filter(function (uniformName) {\n return uniforms[uniformName] === null;\n }).forEach(function (uniformName, i) {\n _this3.uniformGPUBufferLayout.push({\n name: uniformName,\n offset: i * 2 + (hasUniform ? 1 : 0)\n });\n\n entries.push({\n // Sampler\n binding: i * 2 + (hasUniform ? 1 : 0),\n visibility: WebGPUConstants.ShaderStage.Fragment,\n type: WebGPUConstants.BindingType.Sampler\n }, {\n // Texture view\n binding: i * 2 + (hasUniform ? 1 : 0) + 1,\n visibility: WebGPUConstants.ShaderStage.Fragment,\n type: WebGPUConstants.BindingType.SampledTexture\n });\n });\n this.uniformsBindGroupLayout = this.engine.device.createBindGroupLayout({\n // 最新 API 0.0.22 版本使用 entries。Chrome Canary 84.0.4110.0 已实现。\n // 使用 bindings 会报 Warning: GPUBindGroupLayoutDescriptor.bindings is deprecated: renamed to entries\n // @see https://github.com/antvis/GWebGPUEngine/issues/5\n entries: entries\n });\n this.pipelineLayout = this.engine.device.createPipelineLayout({\n bindGroupLayouts: [this.uniformsBindGroupLayout]\n });\n\n if (hasUniform) {\n this.uniformBuffer = new WebGPUBuffer(this.engine, {\n // TODO: 处理 Struct 和 boolean\n // @ts-ignore\n data: mergedUniformData instanceof Array ? // @ts-ignore\n new Float32Array(mergedUniformData) : mergedUniformData,\n usage: WebGPUConstants.BufferUsage.Uniform | WebGPUConstants.BufferUsage.CopyDst\n });\n }\n }\n }]);\n\n return WebGPUModel;\n}();\n\nexport { WebGPUModel as default };\n//# sourceMappingURL=WebGPUModel.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\nvar _dec, _class, _temp;\n\n/**\n * implements renderService with WebGPU API\n * @see https://webgpu.io/\n * @see https://github.com/BabylonJS/Babylon.js/blob/WebGPU/src/Engines/webgpuEngine.ts\n */\nimport { isSafari } from '@antv/g-webgpu-core'; // import { Glslang } from '@webgpu/glslang/dist/web-devel/glslang.onefile';\n\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { injectable } from 'inversify';\nimport glslang from './glslang';\nimport WebGPUAttribute from './WebGPUAttribute';\nimport WebGPUBuffer from './WebGPUBuffer';\nimport WebGPUComputeModel from './WebGPUComputeModel';\nimport WebGPUElements from './WebGPUElements';\nimport WebGPUFramebuffer from './WebGPUFramebuffer';\nimport WebGPUModel from './WebGPUModel';\nimport WebGPUTexture2D from './WebGPUTexture2D';\nexport\n/**\n * regl renderer\n */\nvar WebGPUEngine = (_dec = injectable(), _dec(_class = (_temp = /*#__PURE__*/function () {\n function WebGPUEngine() {\n var _this = this;\n\n _classCallCheck(this, WebGPUEngine);\n\n this.supportWebGPU = true;\n this.useWGSL = false;\n this.options = void 0;\n this.canvas = void 0;\n this.context = void 0;\n this.glslang = void 0;\n this.adapter = void 0;\n this.device = void 0;\n this.swapChain = void 0;\n this.mainPassSampleCount = void 0;\n this.mainTexture = void 0;\n this.depthTexture = void 0;\n this.mainColorAttachments = void 0;\n this.mainTextureExtends = void 0;\n this.mainDepthAttachment = void 0;\n this.uploadEncoder = void 0;\n this.renderEncoder = void 0;\n this.computeEncoder = void 0;\n this.renderTargetEncoder = void 0;\n this.commandBuffers = new Array(4).fill(undefined);\n this.currentRenderPass = null;\n this.mainRenderPass = null;\n this.currentRenderTargetViewDescriptor = void 0;\n this.currentComputePass = null;\n this.bundleEncoder = void 0;\n this.tempBuffers = [];\n this.currentRenderTarget = null;\n this.uploadEncoderDescriptor = {\n label: 'upload'\n };\n this.renderEncoderDescriptor = {\n label: 'render'\n };\n this.renderTargetEncoderDescriptor = {\n label: 'renderTarget'\n };\n this.computeEncoderDescriptor = {\n label: 'compute'\n };\n this.pipelines = {};\n this.computePipelines = {};\n this.defaultSampleCount = 4;\n this.clearDepthValue = 1;\n this.clearStencilValue = 0;\n this.transientViewport = {\n x: Infinity,\n y: 0,\n width: 0,\n height: 0\n };\n this.cachedViewport = {\n x: 0,\n y: 0,\n width: 0,\n height: 0\n };\n\n this.clear = function (options) {\n var framebuffer = options.framebuffer,\n color = options.color,\n depth = options.depth,\n stencil = options.stencil;\n\n if (_this.options.supportCompute) {\n _this.startComputePass();\n } // We need to recreate the render pass so that the new parameters for clear color / depth / stencil are taken into account\n\n\n if (_this.currentRenderTarget) {\n if (_this.currentRenderPass) {\n _this.endRenderTargetRenderPass();\n }\n\n _this.startRenderTargetRenderPass(_this.currentRenderTarget, color ? color : null, !!depth, !!stencil);\n } else {\n // if (this.useReverseDepthBuffer) {\n // this._depthCullingState.depthFunc = Constants.GREATER;\n // }\n _this.mainColorAttachments[0].loadValue = color ? color : WebGPUConstants.LoadOp.Load;\n _this.mainDepthAttachment.depthLoadValue = depth ? depth : WebGPUConstants.LoadOp.Load;\n _this.mainDepthAttachment.stencilLoadValue = stencil ? _this.clearStencilValue : WebGPUConstants.LoadOp.Load;\n\n if (_this.mainRenderPass) {\n _this.endMainRenderPass();\n }\n\n _this.startMainRenderPass();\n }\n };\n\n this.createModel = /*#__PURE__*/function () {\n var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(options) {\n var model;\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n model = new WebGPUModel(_this, options);\n _context.next = 3;\n return model.init();\n\n case 3:\n return _context.abrupt(\"return\", model);\n\n case 4:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }));\n\n return function (_x) {\n return _ref.apply(this, arguments);\n };\n }();\n\n this.createAttribute = function (options) {\n return new WebGPUAttribute(_this, options);\n };\n\n this.createBuffer = function (options) {\n return new WebGPUBuffer(_this, options);\n };\n\n this.createElements = function (options) {\n return new WebGPUElements(_this, options);\n };\n\n this.createTexture2D = function (options) {\n return new WebGPUTexture2D(_this, options);\n };\n\n this.createFramebuffer = function (options) {\n return new WebGPUFramebuffer(_this, options);\n };\n\n this.useFramebuffer = function (framebuffer, drawCommands) {\n // bind\n if (_this.currentRenderTarget) {\n _this.unbindFramebuffer(_this.currentRenderTarget);\n }\n\n _this.currentRenderTarget = framebuffer; // TODO: use mipmap options in framebuffer\n\n _this.currentRenderTargetViewDescriptor = {\n dimension: WebGPUConstants.TextureViewDimension.E2d,\n // mipLevelCount: bindWithMipMaps ? WebGPUTextureHelper.computeNumMipmapLevels(texture.width, texture.height) - lodLevel : 1,\n // baseArrayLayer: faceIndex,\n // baseMipLevel: lodLevel,\n arrayLayerCount: 1,\n aspect: WebGPUConstants.TextureAspect.All\n };\n _this.currentRenderPass = null;\n drawCommands();\n };\n\n this.createComputeModel = /*#__PURE__*/function () {\n var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(context) {\n var model;\n return _regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n model = new WebGPUComputeModel(_this, context);\n _context2.next = 3;\n return model.init();\n\n case 3:\n return _context2.abrupt(\"return\", model);\n\n case 4:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2);\n }));\n\n return function (_x2) {\n return _ref2.apply(this, arguments);\n };\n }();\n\n this.getCanvas = function () {\n return _this.canvas;\n };\n\n this.getGLContext = function () {\n throw new Error('Method not implemented.');\n };\n\n this.viewport = function (_ref3) {\n var x = _ref3.x,\n y = _ref3.y,\n width = _ref3.width,\n height = _ref3.height;\n\n if (!_this.currentRenderPass) {\n // call viewport() before current render pass created\n _this.transientViewport = {\n x: x,\n y: y,\n width: width,\n height: height\n };\n } else if (_this.transientViewport.x !== Infinity) {\n var renderPass = _this.getCurrentRenderPass(); // @see https://gpuweb.github.io/gpuweb/#dom-gpurenderpassencoder-setviewport\n\n\n renderPass.setViewport(_this.transientViewport.x, _this.transientViewport.y, _this.transientViewport.width, _this.transientViewport.height, 0, 1);\n } else if (x !== _this.cachedViewport.x || y !== _this.cachedViewport.y || width !== _this.cachedViewport.width || height !== _this.cachedViewport.height) {\n _this.cachedViewport = {\n x: x,\n y: y,\n width: width,\n height: height\n };\n\n var _renderPass = _this.getCurrentRenderPass();\n\n _renderPass.setViewport(x, y, width, height, 0, 1);\n }\n };\n\n this.readPixels = function (options) {\n throw new Error('Method not implemented.');\n };\n }\n\n _createClass(WebGPUEngine, [{\n key: \"isFloatSupported\",\n value: function isFloatSupported() {\n return true;\n }\n }, {\n key: \"init\",\n value: function () {\n var _init = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee3(config) {\n return _regeneratorRuntime.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n this.canvas = config.canvas;\n this.options = config;\n this.useWGSL = !!config.useWGSL;\n this.mainPassSampleCount = config.antialiasing ? this.defaultSampleCount : 1;\n _context3.next = 6;\n return this.initGlslang();\n\n case 6:\n this.initContextAndSwapChain();\n this.initMainAttachments();\n\n case 8:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, this);\n }));\n\n function init(_x3) {\n return _init.apply(this, arguments);\n }\n\n return init;\n }()\n }, {\n key: \"setScissor\",\n value: function setScissor(scissor) {\n throw new Error('Method not implemented.');\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n if (this.mainTexture) {\n this.mainTexture.destroy();\n }\n\n if (this.depthTexture) {\n this.depthTexture.destroy();\n }\n\n this.tempBuffers.forEach(function (buffer) {\n return buffer.destroy();\n });\n this.tempBuffers = [];\n }\n }, {\n key: \"beginFrame\",\n value: function beginFrame() {\n this.uploadEncoder = this.device.createCommandEncoder(this.uploadEncoderDescriptor);\n this.renderEncoder = this.device.createCommandEncoder(this.renderEncoderDescriptor);\n this.renderTargetEncoder = this.device.createCommandEncoder(this.renderTargetEncoderDescriptor);\n\n if (this.options.supportCompute) {\n this.computeEncoder = this.device.createCommandEncoder(this.computeEncoderDescriptor);\n }\n }\n }, {\n key: \"endFrame\",\n value: function endFrame() {\n if (this.options.supportCompute) {\n this.endComputePass();\n }\n\n this.endMainRenderPass();\n this.commandBuffers[0] = this.uploadEncoder.finish();\n this.commandBuffers[1] = this.renderEncoder.finish();\n\n if (this.options.supportCompute) {\n this.commandBuffers[2] = this.computeEncoder.finish();\n }\n\n this.commandBuffers[3] = this.renderTargetEncoder.finish();\n\n if (isSafari) {\n this.device // @ts-ignore\n .getQueue().submit(this.commandBuffers.filter(function (buffer) {\n return buffer;\n }));\n } else {\n this.device.defaultQueue.submit(this.commandBuffers.filter(function (buffer) {\n return buffer;\n }));\n }\n }\n }, {\n key: \"getCurrentRenderPass\",\n value: function getCurrentRenderPass() {\n if (this.currentRenderTarget && !this.currentRenderPass) {\n this.startRenderTargetRenderPass(this.currentRenderTarget, null, false, false);\n } else if (!this.currentRenderPass) {\n this.startMainRenderPass();\n }\n\n return this.currentRenderPass;\n }\n }, {\n key: \"initGlslang\",\n value: function () {\n var _initGlslang = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee4() {\n var _navigator, _navigator$gpu;\n\n return _regeneratorRuntime.wrap(function _callee4$(_context4) {\n while (1) {\n switch (_context4.prev = _context4.next) {\n case 0:\n _context4.next = 2;\n return glslang();\n\n case 2:\n this.glslang = _context4.sent;\n _context4.next = 5;\n return (_navigator = navigator) === null || _navigator === void 0 ? void 0 : (_navigator$gpu = _navigator.gpu) === null || _navigator$gpu === void 0 ? void 0 : _navigator$gpu.requestAdapter();\n\n case 5:\n this.adapter = _context4.sent;\n _context4.next = 8;\n return this.adapter.requestDevice();\n\n case 8:\n this.device = _context4.sent;\n\n case 9:\n case \"end\":\n return _context4.stop();\n }\n }\n }, _callee4, this);\n }));\n\n function initGlslang() {\n return _initGlslang.apply(this, arguments);\n }\n\n return initGlslang;\n }()\n }, {\n key: \"initContextAndSwapChain\",\n value: function initContextAndSwapChain() {\n this.context = this.canvas.getContext(isSafari ? 'gpu' : 'gpupresent');\n this.swapChain = this.context.configureSwapChain({\n device: this.device,\n format: this.options.swapChainFormat,\n usage: WebGPUConstants.TextureUsage.OutputAttachment | WebGPUConstants.TextureUsage.CopySrc\n });\n }\n }, {\n key: \"initMainAttachments\",\n value: function initMainAttachments() {\n this.mainTextureExtends = {\n width: this.canvas.width,\n height: this.canvas.height,\n depth: 1\n };\n\n if (this.options.antialiasing) {\n var mainTextureDescriptor = {\n size: this.mainTextureExtends,\n // TODO: arrayLayerCount is deprecated: use size.depth\n // arrayLayerCount: 1,\n mipLevelCount: 1,\n sampleCount: this.mainPassSampleCount,\n dimension: WebGPUConstants.TextureDimension.E2d,\n format: WebGPUConstants.TextureFormat.BGRA8Unorm,\n usage: WebGPUConstants.TextureUsage.OutputAttachment\n };\n\n if (this.mainTexture) {\n this.mainTexture.destroy();\n }\n\n this.mainTexture = this.device.createTexture(mainTextureDescriptor);\n this.mainColorAttachments = [{\n attachment: isSafari ? // @ts-ignore\n this.mainTexture.createDefaultView() : this.mainTexture.createView(),\n loadValue: [0, 0, 0, 1],\n storeOp: WebGPUConstants.StoreOp.Store\n }];\n } else {\n this.mainColorAttachments = [{\n attachment: isSafari ? // @ts-ignore\n this.swapChain.getCurrentTexture().createDefaultView() : this.swapChain.getCurrentTexture().createView(),\n loadValue: [0, 0, 0, 1],\n storeOp: WebGPUConstants.StoreOp.Store\n }];\n }\n\n var depthTextureDescriptor = {\n size: this.mainTextureExtends,\n // arrayLayerCount: 1,\n mipLevelCount: 1,\n sampleCount: this.mainPassSampleCount,\n dimension: WebGPUConstants.TextureDimension.E2d,\n format: isSafari ? 'depth32float-stencil8' : WebGPUConstants.TextureFormat.Depth24PlusStencil8,\n usage: WebGPUConstants.TextureUsage.OutputAttachment\n };\n\n if (this.depthTexture) {\n this.depthTexture.destroy();\n }\n\n this.depthTexture = this.device.createTexture( // @ts-ignore\n depthTextureDescriptor);\n this.mainDepthAttachment = {\n attachment: isSafari ? // @ts-ignore\n this.depthTexture.createDefaultView() : this.depthTexture.createView(),\n depthLoadValue: this.clearDepthValue,\n depthStoreOp: WebGPUConstants.StoreOp.Store,\n stencilLoadValue: this.clearStencilValue,\n stencilStoreOp: WebGPUConstants.StoreOp.Store\n };\n }\n }, {\n key: \"startComputePass\",\n value: function startComputePass() {\n if (this.currentComputePass) {\n this.endComputePass();\n }\n\n this.currentComputePass = this.computeEncoder.beginComputePass();\n }\n }, {\n key: \"startMainRenderPass\",\n value: function startMainRenderPass() {\n if (this.currentRenderPass && !this.currentRenderTarget) {\n this.endMainRenderPass();\n } // Resolve in case of MSAA\n\n\n if (this.options.antialiasing) {\n this.mainColorAttachments[0].resolveTarget = isSafari ? // @ts-ignore\n this.swapChain.getCurrentTexture().createDefaultView() : this.swapChain.getCurrentTexture().createView();\n } else {\n this.mainColorAttachments[0].attachment = isSafari ? // @ts-ignore\n this.swapChain.getCurrentTexture().createDefaultView() : this.swapChain.getCurrentTexture().createView();\n }\n\n this.currentRenderPass = this.renderEncoder.beginRenderPass({\n colorAttachments: this.mainColorAttachments,\n depthStencilAttachment: this.mainDepthAttachment // TODO: use framebuffer's depth & stencil\n\n });\n this.mainRenderPass = this.currentRenderPass;\n\n if (this.cachedViewport) {\n this.viewport(this.cachedViewport);\n }\n }\n }, {\n key: \"startRenderTargetRenderPass\",\n value: function startRenderTargetRenderPass(renderTarget, clearColor, clearDepth) {\n var _renderTarget$get$col, _renderTarget$get$dep;\n\n var clearStencil = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;\n var gpuTexture = (_renderTarget$get$col = renderTarget.get().color) === null || _renderTarget$get$col === void 0 ? void 0 : _renderTarget$get$col.texture;\n var colorTextureView;\n\n if (gpuTexture) {\n colorTextureView = gpuTexture.createView(this.currentRenderTargetViewDescriptor);\n }\n\n var depthStencilTexture = (_renderTarget$get$dep = renderTarget.get().depth) === null || _renderTarget$get$dep === void 0 ? void 0 : _renderTarget$get$dep.texture;\n var depthStencilTextureView;\n\n if (depthStencilTexture) {\n depthStencilTextureView = depthStencilTexture.createView();\n }\n\n var renderPass = this.renderTargetEncoder.beginRenderPass({\n colorAttachments: [{\n attachment: colorTextureView,\n loadValue: clearColor !== null ? clearColor : WebGPUConstants.LoadOp.Load,\n storeOp: WebGPUConstants.StoreOp.Store\n }],\n depthStencilAttachment: depthStencilTexture && depthStencilTextureView ? {\n attachment: depthStencilTextureView,\n depthLoadValue: clearDepth ? this.clearDepthValue : WebGPUConstants.LoadOp.Load,\n depthStoreOp: WebGPUConstants.StoreOp.Store,\n stencilLoadValue: clearStencil ? this.clearStencilValue : WebGPUConstants.LoadOp.Load,\n stencilStoreOp: WebGPUConstants.StoreOp.Store\n } : undefined\n });\n this.currentRenderPass = renderPass;\n\n if (this.cachedViewport) {\n this.viewport(this.cachedViewport);\n } // TODO WEBGPU set the scissor rect and the stencil reference value\n\n }\n }, {\n key: \"endMainRenderPass\",\n value: function endMainRenderPass() {\n if (this.currentRenderPass === this.mainRenderPass && this.currentRenderPass !== null) {\n this.currentRenderPass.endPass();\n this.resetCachedViewport();\n this.currentRenderPass = null;\n this.mainRenderPass = null;\n }\n }\n }, {\n key: \"endComputePass\",\n value: function endComputePass() {\n if (this.currentComputePass) {\n this.currentComputePass.endPass();\n this.currentComputePass = null;\n }\n }\n }, {\n key: \"endRenderTargetRenderPass\",\n value: function endRenderTargetRenderPass() {\n if (this.currentRenderPass) {\n this.currentRenderPass.endPass();\n this.resetCachedViewport();\n }\n }\n }, {\n key: \"resetCachedViewport\",\n value: function resetCachedViewport() {\n this.cachedViewport = {\n x: 0,\n y: 0,\n width: 0,\n height: 0\n };\n }\n }, {\n key: \"unbindFramebuffer\",\n value: function unbindFramebuffer(framebuffer) {\n // unbind\n if (this.currentRenderPass && this.currentRenderPass !== this.mainRenderPass) {\n this.endRenderTargetRenderPass();\n }\n\n this.transientViewport.x = Infinity;\n this.currentRenderTarget = null; // if (texture.generateMipMaps && !disableGenerateMipMaps && !texture.isCube) {\n // this._generateMipmaps(texture);\n // }\n\n this.currentRenderPass = this.mainRenderPass;\n }\n }]);\n\n return WebGPUEngine;\n}(), _temp)) || _class);\n//# sourceMappingURL=index.js.map","import _slicedToArray from \"@babel/runtime/helpers/slicedToArray\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\n\nvar _dec, _class;\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { generateAABBFromVertices } from '@antv/g-webgpu-core';\nimport { vec3 } from 'gl-matrix';\nimport { injectable } from 'inversify';\nimport { Geometry } from '.';\nvar primitiveUv1Padding = 4.0 / 64;\nvar primitiveUv1PaddingScale = 1.0 - primitiveUv1Padding * 2;\nexport var\n/**\n * borrow from playcanvas:\n * Creates a procedural box-shaped mesh\n */\nBox = (_dec = injectable(), _dec(_class = /*#__PURE__*/function (_Geometry) {\n _inherits(Box, _Geometry);\n\n var _super = _createSuper(Box);\n\n function Box() {\n _classCallCheck(this, Box);\n\n return _super.apply(this, arguments);\n }\n\n _createClass(Box, [{\n key: \"onEntityCreated\",\n value: function onEntityCreated() {\n var _this$config = this.config,\n _this$config$widthSeg = _this$config.widthSegments,\n widthSegments = _this$config$widthSeg === void 0 ? 1 : _this$config$widthSeg,\n _this$config$heightSe = _this$config.heightSegments,\n heightSegments = _this$config$heightSe === void 0 ? 1 : _this$config$heightSe,\n _this$config$depthSeg = _this$config.depthSegments,\n depthSegments = _this$config$depthSeg === void 0 ? 1 : _this$config$depthSeg,\n _this$config$halfExte = _this$config.halfExtents,\n halfExtents = _this$config$halfExte === void 0 ? vec3.fromValues(0.5, 0.5, 0.5) : _this$config$halfExte;\n var ws = widthSegments;\n var hs = heightSegments;\n var ds = depthSegments;\n\n var _halfExtents = _slicedToArray(halfExtents, 3),\n hex = _halfExtents[0],\n hey = _halfExtents[1],\n hez = _halfExtents[2];\n\n var corners = [vec3.fromValues(-hex, -hey, hez), vec3.fromValues(hex, -hey, hez), vec3.fromValues(hex, hey, hez), vec3.fromValues(-hex, hey, hez), vec3.fromValues(hex, -hey, -hez), vec3.fromValues(-hex, -hey, -hez), vec3.fromValues(-hex, hey, -hez), vec3.fromValues(hex, hey, -hez)];\n var faceAxes = [[0, 1, 3], // FRONT\n [4, 5, 7], // BACK\n [3, 2, 6], // TOP\n [1, 0, 4], // BOTTOM\n [1, 4, 2], // RIGHT\n [5, 0, 6] // LEFT\n ];\n var faceNormals = [[0, 0, 1], // FRONT\n [0, 0, -1], // BACK\n [0, 1, 0], // TOP\n [0, -1, 0], // BOTTOM\n [1, 0, 0], // RIGHT\n [-1, 0, 0] // LEFT\n ];\n var sides = {\n FRONT: 0,\n BACK: 1,\n TOP: 2,\n BOTTOM: 3,\n RIGHT: 4,\n LEFT: 5\n };\n var positions = [];\n var normals = [];\n var uvs = [];\n var uvs1 = [];\n var indices = [];\n var vcounter = 0;\n\n var generateFace = function generateFace(side, uSegments, vSegments) {\n var u;\n var v;\n var i;\n var j;\n\n for (i = 0; i <= uSegments; i++) {\n for (j = 0; j <= vSegments; j++) {\n var temp1 = vec3.create();\n var temp2 = vec3.create();\n var temp3 = vec3.create();\n var r = vec3.create();\n vec3.lerp(temp1, corners[faceAxes[side][0]], corners[faceAxes[side][1]], i / uSegments);\n vec3.lerp(temp2, corners[faceAxes[side][0]], corners[faceAxes[side][2]], j / vSegments);\n vec3.sub(temp3, temp2, corners[faceAxes[side][0]]);\n vec3.add(r, temp1, temp3);\n u = i / uSegments;\n v = j / vSegments;\n positions.push(r[0], r[1], r[2]);\n normals.push(faceNormals[side][0], faceNormals[side][1], faceNormals[side][2]);\n uvs.push(u, v); // pack as 3x2\n // 1/3 will be empty, but it's either that or stretched pixels\n // TODO: generate non-rectangular lightMaps, so we could use space without stretching\n\n u /= 3;\n v /= 3;\n u = u * primitiveUv1PaddingScale + primitiveUv1Padding;\n v = v * primitiveUv1PaddingScale + primitiveUv1Padding;\n u += side % 3 / 3;\n v += Math.floor(side / 3) / 3;\n uvs1.push(u, v);\n\n if (i < uSegments && j < vSegments) {\n indices.push(vcounter + vSegments + 1, vcounter + 1, vcounter);\n indices.push(vcounter + vSegments + 1, vcounter + vSegments + 2, vcounter + 1);\n }\n\n vcounter++;\n }\n }\n };\n\n generateFace(sides.FRONT, ws, hs);\n generateFace(sides.BACK, ws, hs);\n generateFace(sides.TOP, ws, ds);\n generateFace(sides.BOTTOM, ws, ds);\n generateFace(sides.RIGHT, ds, hs);\n generateFace(sides.LEFT, ds, hs); // generate AABB\n\n var aabb = generateAABBFromVertices(positions);\n var component = this.getComponent();\n component.indices = Uint32Array.from(indices);\n component.aabb = aabb;\n component.vertexCount = vcounter;\n component.attributes = [{\n dirty: true,\n name: 'position',\n data: Float32Array.from(positions),\n arrayStride: 4 * 3,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 0,\n offset: 0,\n format: 'float3'\n }]\n }, {\n dirty: true,\n name: 'normal',\n data: Float32Array.from(normals),\n arrayStride: 4 * 3,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 1,\n offset: 0,\n format: 'float3'\n }]\n }, {\n dirty: true,\n name: 'uv',\n data: Float32Array.from(uvs),\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 2,\n offset: 0,\n format: 'float2'\n }]\n }]; // TODO: barycentric & tangent\n }\n }]);\n\n return Box;\n}(Geometry)) || _class);\n//# sourceMappingURL=Box.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport { gl } from '@antv/g-webgpu-core';\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { filterMap, formatMap, wrapModeMap } from './constants';\n/**\n * adaptor for regl.Buffer\n * @see https://github.com/regl-project/regl/blob/gh-pages/API.md#buffers\n */\n\nvar WebGPUTexture2D = /*#__PURE__*/function () {\n function WebGPUTexture2D(engine, options) {\n _classCallCheck(this, WebGPUTexture2D);\n\n this.engine = engine;\n this.options = options;\n this.texture = void 0;\n this.sampler = void 0;\n this.width = void 0;\n this.height = void 0;\n this.createTexture();\n }\n\n _createClass(WebGPUTexture2D, [{\n key: \"get\",\n value: function get() {\n return {\n texture: this.texture,\n sampler: this.sampler\n };\n }\n }, {\n key: \"update\",\n value: function update() {// TODO\n }\n }, {\n key: \"resize\",\n value: function resize(_ref) {\n var width = _ref.width,\n height = _ref.height;\n\n // TODO: it seems that Texture doesn't support `resize`\n if (width !== this.width || height !== this.height) {\n this.destroy();\n this.createTexture();\n }\n\n this.width = width;\n this.height = height;\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n if (this.texture) {\n this.texture.destroy();\n }\n }\n }, {\n key: \"createTexture\",\n value: function createTexture() {\n var _this$options = this.options,\n data = _this$options.data,\n _this$options$type = _this$options.type,\n type = _this$options$type === void 0 ? gl.UNSIGNED_BYTE : _this$options$type,\n width = _this$options.width,\n height = _this$options.height,\n _this$options$flipY = _this$options.flipY,\n flipY = _this$options$flipY === void 0 ? false : _this$options$flipY,\n _this$options$format = _this$options.format,\n format = _this$options$format === void 0 ? gl.RGBA : _this$options$format,\n _this$options$mipmap = _this$options.mipmap,\n mipmap = _this$options$mipmap === void 0 ? false : _this$options$mipmap,\n _this$options$wrapS = _this$options.wrapS,\n wrapS = _this$options$wrapS === void 0 ? gl.CLAMP_TO_EDGE : _this$options$wrapS,\n _this$options$wrapT = _this$options.wrapT,\n wrapT = _this$options$wrapT === void 0 ? gl.CLAMP_TO_EDGE : _this$options$wrapT,\n _this$options$aniso = _this$options.aniso,\n aniso = _this$options$aniso === void 0 ? 0 : _this$options$aniso,\n _this$options$alignme = _this$options.alignment,\n alignment = _this$options$alignme === void 0 ? 1 : _this$options$alignme,\n _this$options$premult = _this$options.premultiplyAlpha,\n premultiplyAlpha = _this$options$premult === void 0 ? false : _this$options$premult,\n _this$options$mag = _this$options.mag,\n mag = _this$options$mag === void 0 ? gl.NEAREST : _this$options$mag,\n _this$options$min = _this$options.min,\n min = _this$options$min === void 0 ? gl.NEAREST : _this$options$min,\n _this$options$colorSp = _this$options.colorSpace,\n colorSpace = _this$options$colorSp === void 0 ? gl.BROWSER_DEFAULT_WEBGL : _this$options$colorSp,\n usage = _this$options.usage;\n this.width = width;\n this.height = height;\n this.texture = this.engine.device.createTexture({\n size: [width, height, 1],\n // TODO: arrayLayerCount is deprecated: use size.depth\n // arrayLayerCount: 1,\n mipLevelCount: 1,\n // TODO: https://gpuweb.github.io/gpuweb/#dom-gputextureviewdescriptor-miplevelcount\n sampleCount: 1,\n dimension: WebGPUConstants.TextureDimension.E2d,\n format: formatMap[format],\n // could throw texture binding usage mismatch\n usage: usage || WebGPUConstants.TextureUsage.Sampled | WebGPUConstants.TextureUsage.CopyDst\n });\n\n if (!usage || usage & WebGPUConstants.TextureUsage.Sampled) {\n this.sampler = this.engine.device.createSampler({\n addressModeU: wrapModeMap[wrapS],\n addressModeV: wrapModeMap[wrapT],\n addressModeW: wrapModeMap[wrapS],\n // TODO: same as addressModeU\n magFilter: filterMap[mag],\n minFilter: filterMap[min],\n maxAnisotropy: aniso // @see https://gpuweb.github.io/gpuweb/#dom-gpusamplerdescriptor-maxanisotropy\n\n });\n }\n }\n }]);\n\n return WebGPUTexture2D;\n}();\n\nexport { WebGPUTexture2D as default };\n//# sourceMappingURL=WebGPUTexture2D.js.map","import _toConsumableArray from \"@babel/runtime/helpers/toConsumableArray\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\n\nvar _dec, _class;\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { AABB } from '@antv/g-webgpu-core';\nimport { injectable } from 'inversify';\nimport { Geometry } from '.';\nimport { isNumber } from '../utils/is-number';\nimport { isTypedArray } from '../utils/is-typedarray';\nimport { merge } from '../utils/typedarray';\nexport var\n/**\n * merge many geometries into one, use a batch of draw calls\n */\nMerged = (_dec = injectable(), _dec(_class = /*#__PURE__*/function (_Geometry) {\n _inherits(Merged, _Geometry);\n\n var _super = _createSuper(Merged);\n\n function Merged() {\n _classCallCheck(this, Merged);\n\n return _super.apply(this, arguments);\n }\n\n _createClass(Merged, [{\n key: \"onEntityCreated\",\n value: function onEntityCreated() {\n var _this$config$geometri = this.config.geometries,\n geometries = _this$config$geometri === void 0 ? [] : _this$config$geometri;\n var mergedComponent = this.getComponent();\n mergedComponent.aabb = new AABB();\n var mergedAttributes = [];\n var mergedIndices = [];\n var indexOffset = 0;\n geometries.forEach(function (geometry) {\n var aabb = geometry.aabb,\n indices = geometry.indices,\n vertexCount = geometry.vertexCount,\n attributes = geometry.attributes; // merge aabb\n\n mergedComponent.aabb.add(aabb);\n mergedComponent.vertexCount += vertexCount; // merge indices\n\n if (indices) {\n mergedIndices.push.apply(mergedIndices, _toConsumableArray(indices.map(function (index) {\n return index + indexOffset;\n })));\n }\n\n indexOffset += vertexCount; // merge attributes\n\n attributes.forEach(function (attribute, i) {\n if (!mergedAttributes[i]) {\n mergedAttributes[i] = attribute;\n mergedAttributes[i].dirty = true;\n } else {\n if (attribute.data) {\n if (isNumber(attribute.data)) {\n // @ts-ignore\n mergedAttributes[i].push(attribute.data);\n } else if (isTypedArray(attribute.data)) {\n // @ts-ignore\n mergedAttributes[i].data = merge( // @ts-ignore\n mergedAttributes[i].data, attribute.data);\n } else {\n // @ts-ignore\n mergedAttributes[i].data = mergedAttributes[i].data.concat(attribute.data);\n }\n }\n }\n });\n });\n mergedComponent.attributes = mergedAttributes;\n mergedComponent.indices = Uint32Array.from(mergedIndices);\n mergedComponent.dirty = true;\n }\n }]);\n\n return Merged;\n}(Geometry)) || _class);\n//# sourceMappingURL=Merged.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\n\nvar _dec, _class;\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { generateAABBFromVertices } from '@antv/g-webgpu-core';\nimport { injectable } from 'inversify';\nimport { Geometry } from '.';\nexport var\n/**\n * borrow from playcanvas\n */\nPlane = (_dec = injectable(), _dec(_class = /*#__PURE__*/function (_Geometry) {\n _inherits(Plane, _Geometry);\n\n var _super = _createSuper(Plane);\n\n function Plane() {\n _classCallCheck(this, Plane);\n\n return _super.apply(this, arguments);\n }\n\n _createClass(Plane, [{\n key: \"onEntityCreated\",\n value: function onEntityCreated() {\n var _this$config = this.config,\n _this$config$halfExte = _this$config.halfExtents,\n halfExtents = _this$config$halfExte === void 0 ? [0.5, 0.5] : _this$config$halfExte,\n _this$config$widthSeg = _this$config.widthSegments,\n widthSegments = _this$config$widthSeg === void 0 ? 5 : _this$config$widthSeg,\n _this$config$lengthSe = _this$config.lengthSegments,\n lengthSegments = _this$config$lengthSe === void 0 ? 5 : _this$config$lengthSe;\n var positions = [];\n var normals = [];\n var uvs = [];\n var indices = [];\n var vcounter = 0;\n\n for (var i = 0; i <= widthSegments; i++) {\n for (var j = 0; j <= lengthSegments; j++) {\n var x = -halfExtents[0] + 2.0 * halfExtents[0] * i / widthSegments;\n var y = 0.0;\n var z = -(-halfExtents[1] + 2.0 * halfExtents[1] * j / lengthSegments);\n var u = i / widthSegments;\n var v = j / lengthSegments;\n positions.push(x, y, z);\n normals.push(0.0, 1.0, 0.0);\n uvs.push(u, v);\n\n if (i < widthSegments && j < lengthSegments) {\n indices.push(vcounter + lengthSegments + 1, vcounter + 1, vcounter);\n indices.push(vcounter + lengthSegments + 1, vcounter + lengthSegments + 2, vcounter + 1);\n }\n\n vcounter++;\n }\n } // generate AABB\n\n\n var aabb = generateAABBFromVertices(positions);\n var component = this.getComponent();\n component.indices = Uint32Array.from(indices);\n component.aabb = aabb;\n component.vertexCount = vcounter;\n component.attributes = [{\n dirty: true,\n name: 'position',\n data: Float32Array.from(positions),\n arrayStride: 4 * 3,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 0,\n offset: 0,\n format: 'float3'\n }]\n }, {\n dirty: true,\n name: 'normal',\n data: Float32Array.from(normals),\n arrayStride: 4 * 3,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 1,\n offset: 0,\n format: 'float3'\n }]\n }, {\n dirty: true,\n name: 'uv',\n data: Float32Array.from(uvs),\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 2,\n offset: 0,\n format: 'float2'\n }]\n }]; // TODO: barycentric & tangent\n }\n }]);\n\n return Plane;\n}(Geometry)) || _class);\n//# sourceMappingURL=Plane.js.map","export function merge(a, b) {\n // Checks for truthy values on both arrays\n if (!a && !b) {\n throw new Error('Please specify valid arguments for parameters a and b.');\n } // Checks for truthy values or empty arrays on each argument\n // to avoid the unnecessary construction of a new array and\n // the type comparison\n\n\n if (!b || b.length === 0) {\n return a;\n }\n\n if (!a || a.length === 0) {\n return b;\n } // Make sure that both typed arrays are of the same type\n\n\n if (Object.prototype.toString.call(a) !== Object.prototype.toString.call(b)) {\n throw new Error('The types of the two arguments passed for parameters a and b do not match.');\n } // @ts-ignore\n\n\n var c = new a.constructor(a.length + b.length);\n c.set(a);\n c.set(b, a.length);\n return c;\n}\n//# sourceMappingURL=typedarray.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\n\nvar _dec, _class;\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { generateAABBFromVertices } from '@antv/g-webgpu-core';\nimport { injectable } from 'inversify';\nimport { Geometry } from '.';\nexport var\n/**\n * borrow from playcanvas\n */\nSphere = (_dec = injectable(), _dec(_class = /*#__PURE__*/function (_Geometry) {\n _inherits(Sphere, _Geometry);\n\n var _super = _createSuper(Sphere);\n\n function Sphere() {\n _classCallCheck(this, Sphere);\n\n return _super.apply(this, arguments);\n }\n\n _createClass(Sphere, [{\n key: \"onEntityCreated\",\n value: function onEntityCreated() {\n var _this$config = this.config,\n _this$config$radius = _this$config.radius,\n radius = _this$config$radius === void 0 ? 0.5 : _this$config$radius,\n _this$config$latitude = _this$config.latitudeBands,\n latitudeBands = _this$config$latitude === void 0 ? 16 : _this$config$latitude,\n _this$config$longitud = _this$config.longitudeBands,\n longitudeBands = _this$config$longitud === void 0 ? 16 : _this$config$longitud;\n var positions = [];\n var normals = [];\n var uvs = [];\n var indices = [];\n\n for (var lat = 0; lat <= latitudeBands; lat++) {\n var theta = lat * Math.PI / latitudeBands;\n var sinTheta = Math.sin(theta);\n var cosTheta = Math.cos(theta);\n\n for (var lon = 0; lon <= longitudeBands; lon++) {\n // Sweep the sphere from the positive Z axis to match a 3DS Max sphere\n var phi = lon * 2 * Math.PI / longitudeBands - Math.PI / 2.0;\n var sinPhi = Math.sin(phi);\n var cosPhi = Math.cos(phi);\n var x = cosPhi * sinTheta;\n var y = cosTheta;\n var z = sinPhi * sinTheta;\n var u = 1.0 - lon / longitudeBands;\n var v = 1.0 - lat / latitudeBands;\n positions.push(x * radius, y * radius, z * radius);\n normals.push(x, y, z);\n uvs.push(u, v);\n }\n }\n\n for (var _lat = 0; _lat < latitudeBands; ++_lat) {\n for (var _lon = 0; _lon < longitudeBands; ++_lon) {\n var first = _lat * (longitudeBands + 1) + _lon;\n var second = first + longitudeBands + 1;\n indices.push(first + 1, second, first);\n indices.push(first + 1, second + 1, second);\n }\n } // generate AABB\n\n\n var aabb = generateAABBFromVertices(positions);\n var component = this.getComponent();\n component.indices = Uint32Array.from(indices);\n component.aabb = aabb;\n component.vertexCount = positions.length / 3;\n component.attributes = [{\n dirty: true,\n name: 'position',\n data: Float32Array.from(positions),\n arrayStride: 4 * 3,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 0,\n offset: 0,\n format: 'float3'\n }]\n }, {\n dirty: true,\n name: 'normal',\n data: Float32Array.from(normals),\n arrayStride: 4 * 3,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 1,\n offset: 0,\n format: 'float3'\n }]\n }, {\n dirty: true,\n name: 'uv',\n data: Float32Array.from(uvs),\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 2,\n offset: 0,\n format: 'float2'\n }]\n }]; // TODO: barycentric & tangent\n }\n }]);\n\n return Sphere;\n}(Geometry)) || _class);\n//# sourceMappingURL=Sphere.js.map","import _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _class, _class2, _descriptor, _descriptor2, _temp;\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { IDENTIFIER } from '@antv/g-webgpu-core';\nimport { mat3 } from 'gl-matrix';\nimport { inject, injectable } from 'inversify';\nimport { Material } from '..';\n\n/* babel-plugin-inline-import './shaders/webgl.basic.frag.glsl' */\nvar webglFragmentShaderGLSL = \"varying vec4 fragColor;\\n\\n#pragma include \\\"uv.frag.declaration\\\"\\n#pragma include \\\"map.frag.declaration\\\"\\n\\nvoid main() {\\n vec4 diffuseColor = fragColor;\\n\\n #pragma include \\\"map.frag.main\\\"\\n\\n gl_FragColor = diffuseColor;\\n}\";\n\n/* babel-plugin-inline-import './shaders/webgl.basic.vert.glsl' */\nvar webglVertexShaderGLSL = \"attribute vec3 position;\\nattribute vec3 normal;\\n\\nuniform mat4 projectionMatrix;\\nuniform mat4 modelViewMatrix;\\nuniform vec4 color;\\n\\nvarying vec4 fragColor;\\n\\n#pragma include \\\"uv.vert.declaration\\\"\\n\\nvoid main() {\\n gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\\n fragColor = color;\\n\\n #pragma include \\\"uv.vert.main\\\"\\n}\";\n\n/* babel-plugin-inline-import './shaders/webgpu.basic.frag.glsl' */\nvar webgpuFragmentShaderGLSL = \"// layout(set = 0, binding = 1) uniform WireframeUniforms {\\n// float lineWidth;\\n// vec4 lineColor;\\n// } wireframe;\\n\\nlayout(location = 0) in vec4 fragColor;\\n// layout(location = 1) in vec3 v_Barycentric;\\n\\nlayout(location = 0) out vec4 outColor;\\n\\n// wireframe\\n// float edgeFactor() {\\n// vec3 d = fwidth(v_Barycentric);\\n// vec3 a3 = smoothstep(vec3(0.0), d * wireframe.lineWidth, v_Barycentric);\\n// return min(min(a3.x, a3.y), a3.z);\\n// }\\n\\nvoid main() {\\n // outColor = mix(fragColor, wireframe.lineColor, (1.0 - edgeFactor()));\\n outColor = fragColor;\\n}\";\n\n/* babel-plugin-inline-import './shaders/webgpu.basic.vert.glsl' */\nvar webgpuVertexShaderGLSL = \"layout(set = 0, binding = 0) uniform Uniforms {\\n vec4 color;\\n mat4 projectionMatrix;\\n mat4 modelViewMatrix;\\n} uniforms;\\n\\nlayout(location = 0) in vec3 position;\\n// layout(location = 1) in vec3 barycentric;\\n\\nlayout(location = 0) out vec4 fragColor;\\n// layout(location = 1) out vec3 v_Barycentric;\\n\\nvoid main() {\\n gl_Position = uniforms.projectionMatrix * uniforms.modelViewMatrix * vec4(position, 1.0);\\n fragColor = uniforms.color;\\n // v_Barycentric = barycentric;\\n}\";\nexport var\n/**\n * This material is not affected by lights.\n * @see https://threejs.org/docs/#api/en/materials/MeshBasicMaterial\n */\nBasic = (_dec = injectable(), _dec2 = inject(IDENTIFIER.RenderEngine), _dec3 = inject(IDENTIFIER.ShaderModuleService), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function (_Material) {\n _inherits(Basic, _Material);\n\n var _super = _createSuper(Basic);\n\n function Basic() {\n var _this;\n\n _classCallCheck(this, Basic);\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _super.call.apply(_super, [this].concat(args));\n\n _initializerDefineProperty(_this, \"engine\", _descriptor, _assertThisInitialized(_this));\n\n _initializerDefineProperty(_this, \"shaderModuleService\", _descriptor2, _assertThisInitialized(_this));\n\n return _this;\n }\n\n _createClass(Basic, [{\n key: \"onEntityCreated\",\n value: function onEntityCreated() {\n var component = this.getComponent();\n var vertexShaderGLSL = this.engine.supportWebGPU ? webgpuVertexShaderGLSL : webglVertexShaderGLSL;\n var fragmentShaderGLSL = this.engine.supportWebGPU ? webgpuFragmentShaderGLSL : webglFragmentShaderGLSL;\n this.shaderModuleService.registerModule('material-basic', {\n vs: vertexShaderGLSL,\n fs: fragmentShaderGLSL\n });\n\n var _this$shaderModuleSer = this.shaderModuleService.getModule('material-basic'),\n vs = _this$shaderModuleSer.vs,\n fs = _this$shaderModuleSer.fs,\n extractedUniforms = _this$shaderModuleSer.uniforms;\n\n component.vertexShaderGLSL = vs;\n component.fragmentShaderGLSL = fs; // @ts-ignore\n\n component.setUniform(extractedUniforms);\n\n if (this.config.map) {\n component.setDefines({\n USE_UV: 1,\n USE_MAP: 1\n });\n component.setUniform({\n // @ts-ignore\n map: this.config.map,\n uvTransform: mat3.create()\n });\n }\n }\n }]);\n\n return Basic;\n}(Material), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"engine\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"shaderModuleService\", [_dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=index.js.map","import _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _dec4, _dec5, _dec6, _class, _class2, _descriptor, _descriptor2, _descriptor3, _temp;\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { gl, IDENTIFIER } from '@antv/g-webgpu-core';\nimport { inject, injectable, named } from 'inversify';\nimport { Renderable } from '../Renderable';\n\n/* babel-plugin-inline-import './shaders/webgl.grid.frag.glsl' */\nvar gridFrag = \"// generate grid, borrow from clay.gl viewer\\n// @see https://github.com/pissang/clay-viewer/blob/master/src/graphic/ground.glsl\\n#extension GL_OES_standard_derivatives : enable\\n\\nvarying vec3 v_Position;\\n// varying vec3 v_Normal;\\n\\nuniform float u_GridSize : 5;\\nuniform float u_GridSize2 : .5;\\nuniform vec4 u_GridColor : [0, 0, 0, 1];\\nuniform vec4 u_GridColor2 : [0.3, 0.3, 0.3, 1];\\nuniform bool u_GridEnabled : true;\\n\\n// uniform vec3 u_LightDirection;\\n// uniform vec3 u_LightColor;\\n// uniform vec3 u_Camera;\\n\\nvoid main() {\\n // vec3 n = v_Normal;\\n // vec3 l = normalize(u_LightDirection);\\n // float NdotL = clamp(dot(n, l), 0.001, 1.0);\\n\\n gl_FragColor = vec4(1.);\\n\\n if (u_GridEnabled) {\\n float wx = v_Position.x;\\n float wz = v_Position.z;\\n // float x0 = abs(fract(wx / u_GridSize - 0.5) - 0.5) / fwidth(wx) * u_GridSize / 2.0;\\n // float z0 = abs(fract(wz / u_GridSize - 0.5) - 0.5) / fwidth(wz) * u_GridSize / 2.0;\\n\\n float x1 = abs(fract(wx / u_GridSize2 - 0.5) - 0.5) / fwidth(wx) * u_GridSize2;\\n float z1 = abs(fract(wz / u_GridSize2 - 0.5) - 0.5) / fwidth(wz) * u_GridSize2;\\n\\n // float v0 = 1.0 - clamp(min(x0, z0), 0.0, 1.0);\\n float v1 = 1.0 - clamp(min(x1, z1), 0.0, 1.0);\\n // if (v0 > 0.1) {\\n // gl_FragColor = mix(gl_FragColor, u_GridColor, v0);\\n // }\\n // else {\\n gl_FragColor = mix(gl_FragColor, u_GridColor2, v1);\\n // }\\n }\\n\\n // float shadowFactor = calcShadow(u_ShadowMap, v_PositionFromLight, l, n);\\n // vec3 diffuseColor = u_LightColor * NdotL * shadowFactor;\\n\\n // gl_FragColor.rgb *= diffuseColor;\\n}\";\n\n/* babel-plugin-inline-import './shaders/webgl.grid.vert.glsl' */\nvar gridVert = \"attribute vec3 a_Position;\\n\\nvarying vec3 v_Position;\\n\\nuniform mat4 projectionMatrix;\\nuniform mat4 modelViewMatrix;\\n\\nvoid main() {\\n v_Position = a_Position;\\n gl_Position = projectionMatrix * modelViewMatrix * vec4(a_Position, 1.);\\n}\";\nexport var Grid = (_dec = injectable(), _dec2 = inject(IDENTIFIER.Systems), _dec3 = named(IDENTIFIER.MaterialSystem), _dec4 = inject(IDENTIFIER.Systems), _dec5 = named(IDENTIFIER.GeometrySystem), _dec6 = inject(IDENTIFIER.ShaderModuleService), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function (_Renderable) {\n _inherits(Grid, _Renderable);\n\n var _super = _createSuper(Grid);\n\n function Grid() {\n var _this;\n\n _classCallCheck(this, Grid);\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _super.call.apply(_super, [this].concat(args));\n\n _initializerDefineProperty(_this, \"materialSystem\", _descriptor, _assertThisInitialized(_this));\n\n _initializerDefineProperty(_this, \"geometrySystem\", _descriptor2, _assertThisInitialized(_this));\n\n _initializerDefineProperty(_this, \"shaderModuleService\", _descriptor3, _assertThisInitialized(_this));\n\n return _this;\n }\n\n _createClass(Grid, [{\n key: \"onAttributeChanged\",\n value: function onAttributeChanged(_ref) {\n var name = _ref.name,\n data = _ref.data;\n var mesh = this.getMeshComponent();\n\n if (mesh && mesh.material) {\n if (name === 'gridColor') {\n mesh.material.setUniform('u_GridColor', data);\n mesh.material.setUniform('u_GridColor2', data);\n } else if (name === 'gridSize') {\n mesh.material.setUniform('u_GridSize', data);\n mesh.material.setUniform('u_GridSize2', data);\n }\n }\n }\n }, {\n key: \"onEntityCreated\",\n value: function onEntityCreated() {\n this.shaderModuleService.registerModule('grid', {\n vs: gridVert,\n fs: gridFrag\n });\n\n var _this$shaderModuleSer = this.shaderModuleService.getModule('grid'),\n vs = _this$shaderModuleSer.vs,\n fs = _this$shaderModuleSer.fs,\n extractedUniforms = _this$shaderModuleSer.uniforms;\n\n var material = this.materialSystem.createShaderMaterial({\n vertexShader: vs,\n fragmentShader: fs\n });\n this.setMaterial(material);\n var geometry = this.geometrySystem.createBufferGeometry({\n vertexCount: 4\n });\n this.setGeometry(geometry);\n material.setCull({\n enable: false,\n face: gl.BACK\n }).setDepth({\n enable: true,\n func: gl.LESS\n }); // @ts-ignore\n\n material.setUniform(extractedUniforms);\n this.setAttributes({\n gridColor: this.config.gridColor,\n gridSize: this.config.gridSize\n });\n geometry.setIndex([0, 3, 2, 2, 1, 0]);\n geometry.setAttribute('a_Position', Float32Array.from([-4, -1, -4, 4, -1, -4, 4, -1, 4, -4, -1, 4]), {\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 0,\n offset: 0,\n format: 'float2'\n }]\n });\n }\n }]);\n\n return Grid;\n}(Renderable), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"materialSystem\", [_dec2, _dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"geometrySystem\", [_dec4, _dec5], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, \"shaderModuleService\", [_dec6], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=index.js.map","import _toConsumableArray from \"@babel/runtime/helpers/toConsumableArray\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _dec4, _dec5, _dec6, _class, _class2, _descriptor, _descriptor2, _descriptor3, _temp;\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { gl, IDENTIFIER } from '@antv/g-webgpu-core';\nimport { inject, injectable, named } from 'inversify';\nimport getNormals from '../../utils/polyline-normals';\nimport { Renderable } from '../Renderable';\n\n/* babel-plugin-inline-import './shaders/webgl.line.frag.glsl' */\nvar lineFrag = \"uniform float u_dash_array : 0.02;\\nuniform float u_dash_offset : 0;\\nuniform float u_dash_ratio : 0;\\nuniform float u_thickness : 0.02;\\n\\nvarying vec4 v_color;\\nvarying vec2 v_normal;\\nvarying float v_counters;\\n\\nvoid main() {\\n float blur = 1. - smoothstep(0.98, 1., length(v_normal));\\n\\n gl_FragColor = v_color;\\n gl_FragColor.a *= blur * ceil(mod(v_counters + u_dash_offset, u_dash_array) - (u_dash_array * u_dash_ratio));\\n}\";\n\n/* babel-plugin-inline-import './shaders/webgl.line.vert.glsl' */\nvar lineVert = \"attribute vec2 a_pos;\\nattribute vec4 a_color;\\nattribute float a_line_miter;\\nattribute vec2 a_line_normal;\\nattribute float a_counters;\\n\\nuniform mat4 projectionMatrix;\\nuniform mat4 modelViewMatrix;\\nuniform float u_thickness : 0.02;\\nuniform vec2 u_viewport;\\n\\nvarying vec4 v_color;\\nvarying vec2 v_normal;\\nvarying float v_counters;\\n\\nvoid main() {\\n v_color = a_color;\\n v_counters = a_counters;\\n\\n vec3 normal = normalize(vec3(a_line_normal, 0.0));\\n\\n vec4 offset = vec4(normal * u_thickness / 2.0 * a_line_miter, 0.0);\\n\\n v_normal = vec2(normal * sign(a_line_miter));\\n\\n gl_Position = projectionMatrix * modelViewMatrix * vec4(a_pos, 0.0, 1.0) + offset;\\n}\\n\";\nexport var Line = (_dec = injectable(), _dec2 = inject(IDENTIFIER.Systems), _dec3 = named(IDENTIFIER.MaterialSystem), _dec4 = inject(IDENTIFIER.Systems), _dec5 = named(IDENTIFIER.GeometrySystem), _dec6 = inject(IDENTIFIER.ShaderModuleService), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function (_Renderable) {\n _inherits(Line, _Renderable);\n\n var _super = _createSuper(Line);\n\n function Line() {\n var _this;\n\n _classCallCheck(this, Line);\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _super.call.apply(_super, [this].concat(args));\n\n _initializerDefineProperty(_this, \"materialSystem\", _descriptor, _assertThisInitialized(_this));\n\n _initializerDefineProperty(_this, \"geometrySystem\", _descriptor2, _assertThisInitialized(_this));\n\n _initializerDefineProperty(_this, \"shaderModuleService\", _descriptor3, _assertThisInitialized(_this));\n\n _this.vertexCount = void 0;\n return _this;\n }\n\n _createClass(Line, [{\n key: \"onAttributeChanged\",\n value: function onAttributeChanged(_ref) {\n var name = _ref.name,\n data = _ref.data;\n var mesh = this.getMeshComponent();\n\n if (mesh && mesh.material) {\n switch (name) {\n case 'dashArray':\n mesh.material.setUniform('u_dash_array', data);\n break;\n\n case 'dashOffset':\n mesh.material.setUniform('u_dash_offset', data);\n break;\n\n case 'dashRatio':\n mesh.material.setUniform('u_dash_ratio', data);\n break;\n\n case 'thickness':\n mesh.material.setUniform('u_thickness', data);\n break;\n\n case 'color':\n var colors = new Array(this.vertexCount).fill(undefined).map(function () {\n return data;\n }).reduce(function (prev, cur) {\n // @ts-ignore\n return [].concat(_toConsumableArray(prev), _toConsumableArray(cur));\n }, []); // @ts-ignore\n\n mesh.geometry.setAttribute('a_color', Float32Array.from(colors), {\n arrayStride: 4 * 4,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 1,\n offset: 0,\n format: 'float4'\n }]\n });\n break;\n }\n }\n }\n }, {\n key: \"onEntityCreated\",\n value: function onEntityCreated() {\n var _this2 = this;\n\n this.shaderModuleService.registerModule('line', {\n vs: lineVert,\n fs: lineFrag\n });\n\n var _this$shaderModuleSer = this.shaderModuleService.getModule('line'),\n vs = _this$shaderModuleSer.vs,\n fs = _this$shaderModuleSer.fs,\n extractedUniforms = _this$shaderModuleSer.uniforms;\n\n var material = this.materialSystem.createShaderMaterial({\n vertexShader: vs,\n fragmentShader: fs\n });\n\n var _getNormals = getNormals(this.config.points, false),\n normals = _getNormals.normals,\n attrIndex = _getNormals.attrIndex,\n attrPos = _getNormals.attrPos,\n attrCounters = _getNormals.attrCounters;\n\n var vertexCount = attrPos.length;\n this.vertexCount = vertexCount;\n var geometry = this.geometrySystem.createBufferGeometry({\n vertexCount: vertexCount\n });\n this.setMaterial(material);\n this.setGeometry(geometry);\n material.setCull({\n enable: false,\n face: gl.BACK\n }) // @ts-ignore\n .setUniform(extractedUniforms);\n this.setAttributes({\n dashArray: this.config.dashArray,\n dashOffset: this.config.dashOffset,\n dashRatio: this.config.dashRatio,\n thickness: this.config.thickness\n });\n var attrNormal = [];\n var attrMiter = [];\n normals.forEach(function (n) {\n var norm = n[0];\n var miter = n[1];\n attrNormal.push([norm[0], norm[1]]); // @ts-ignore\n\n attrMiter.push(miter);\n }); // [[0,1,2], [2,1,3]]\n\n geometry.setIndex(attrIndex.reduce(function (prev, cur) {\n return [].concat(_toConsumableArray(prev), _toConsumableArray(cur));\n }, []));\n geometry.setAttribute('a_pos', Float32Array.from(attrPos.reduce(function (prev, cur) {\n return [].concat(_toConsumableArray(prev), _toConsumableArray(cur));\n }, [])), {\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 0,\n offset: 0,\n format: 'float2'\n }]\n });\n var colors = new Array(vertexCount).fill(undefined).map(function () {\n return _toConsumableArray(_this2.config.color);\n }).reduce(function (prev, cur) {\n return [].concat(_toConsumableArray(prev), _toConsumableArray(cur));\n }, []);\n geometry.setAttribute('a_color', Float32Array.from(colors), {\n arrayStride: 4 * 4,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 1,\n offset: 0,\n format: 'float4'\n }]\n });\n geometry.setAttribute('a_line_miter', Float32Array.from(attrMiter), {\n arrayStride: 4 * 1,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 2,\n offset: 0,\n format: 'float'\n }]\n });\n geometry.setAttribute('a_line_normal', Float32Array.from(attrNormal.reduce(function (prev, cur) {\n return [].concat(_toConsumableArray(prev), _toConsumableArray(cur));\n }, [])), {\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 3,\n offset: 0,\n format: 'float2'\n }]\n });\n geometry.setAttribute('a_counters', Float32Array.from(attrCounters), {\n arrayStride: 4 * 1,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 4,\n offset: 0,\n format: 'float'\n }]\n });\n }\n }]);\n\n return Line;\n}(Renderable), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"materialSystem\", [_dec2, _dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"geometrySystem\", [_dec4, _dec5], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, \"shaderModuleService\", [_dec6], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=index.js.map","// @ts-ignore\nimport { copy, create, dot } from 'gl-vec2'; // @ts-ignore\n\nimport { computeMiter, direction, normal } from 'polyline-miter-util';\n\nfunction extrusions(positions, out, point, normal, scale) {\n addNext(out, normal, -scale);\n addNext(out, normal, scale);\n positions.push(point);\n positions.push(point);\n}\n\nfunction addNext(out, normal, length) {\n out.push([[normal[0], normal[1]], length]);\n}\n\nexport default function (points, closed, indexOffset) {\n var lineA = [0, 0];\n var lineB = [0, 0];\n var tangent = [0, 0];\n var miter = [0, 0];\n\n var _lastFlip = -1;\n\n var _started = false;\n var _normal = null;\n var tmp = create();\n var count = indexOffset || 0;\n var miterLimit = 3;\n var out = [];\n var attrPos = [];\n var attrIndex = [];\n var attrCounters = [0, 0];\n\n if (closed) {\n points = points.slice();\n points.push(points[0]);\n }\n\n var total = points.length;\n\n for (var i = 1; i < total; i++) {\n var index = count;\n var last = points[i - 1];\n var cur = points[i];\n var next = i < points.length - 1 ? points[i + 1] : null;\n attrCounters.push(i / total, i / total);\n direction(lineA, cur, last);\n\n if (!_normal) {\n _normal = [0, 0];\n normal(_normal, lineA);\n }\n\n if (!_started) {\n _started = true;\n extrusions(attrPos, out, last, _normal, 1);\n }\n\n attrIndex.push([index + 0, index + 1, index + 2]);\n\n if (!next) {\n // no miter, simple segment\n normal(_normal, lineA); // reset normal\n\n extrusions(attrPos, out, cur, _normal, 1);\n attrIndex.push(_lastFlip === 1 ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3]);\n count += 2;\n } else {\n // miter with last\n // get unit dir of next line\n direction(lineB, next, cur); // stores tangent & miter\n\n var miterLen = computeMiter(tangent, miter, lineA, lineB, 1); // get orientation\n\n var flip = dot(tangent, _normal) < 0 ? -1 : 1;\n var bevel = miterLen > miterLimit; // 处理相邻线段重叠的情况\n\n if (!isFinite(miterLen)) {\n normal(_normal, lineA); // reset normal\n\n extrusions(attrPos, out, cur, _normal, 1);\n attrIndex.push(_lastFlip === 1 ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3]);\n count += 2;\n _lastFlip = flip;\n continue;\n }\n\n if (bevel) {\n miterLen = miterLimit;\n attrCounters.push(i / total); // next two points in our first segment\n\n addNext(out, _normal, -flip);\n attrPos.push(cur);\n addNext(out, miter, miterLen * flip);\n attrPos.push(cur);\n attrIndex.push(_lastFlip !== -flip ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3]); // now add the bevel triangle\n\n attrIndex.push([index + 2, index + 3, index + 4]);\n normal(tmp, lineB);\n copy(_normal, tmp); // store normal for next round\n\n addNext(out, _normal, -flip);\n attrPos.push(cur); // the miter is now the normal for our next join\n\n count += 3;\n } else {\n // miter\n // next two points for our miter join\n extrusions(attrPos, out, cur, miter, miterLen);\n attrIndex.push(_lastFlip === 1 ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3]);\n flip = -1; // the miter is now the normal for our next join\n\n copy(_normal, miter);\n count += 2;\n }\n\n _lastFlip = flip;\n }\n }\n\n return {\n normals: out,\n attrIndex: attrIndex,\n attrPos: attrPos,\n attrCounters: attrCounters\n };\n}\n//# sourceMappingURL=polyline-normals.js.map","import _toConsumableArray from \"@babel/runtime/helpers/toConsumableArray\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _inherits from \"@babel/runtime/helpers/inherits\";\nimport _possibleConstructorReturn from \"@babel/runtime/helpers/possibleConstructorReturn\";\nimport _getPrototypeOf from \"@babel/runtime/helpers/getPrototypeOf\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _dec4, _dec5, _dec6, _class, _class2, _descriptor, _descriptor2, _descriptor3, _temp;\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nimport { gl, IDENTIFIER } from '@antv/g-webgpu-core';\nimport { inject, injectable, named } from 'inversify';\nimport { encodePickingColor } from '../../utils/picking';\nimport { Renderable } from '../Renderable';\n\n/* babel-plugin-inline-import './shaders/webgl.point.frag.glsl' */\nvar pointFrag = \"uniform float u_blur : 0.05;\\nuniform float u_opacity : 0.7;\\nuniform float u_stroke_width : 0.01;\\nuniform vec4 u_stroke_color : [0, 0, 0, 0];\\nuniform float u_stroke_opacity : 1;\\n\\nvarying vec4 v_color;\\nvarying vec4 v_data;\\nvarying float v_radius;\\n\\n#pragma include \\\"sdf2d\\\"\\n#pragma include \\\"picking\\\"\\n\\nvoid main() {\\n int shape = int(floor(v_data.w + 0.5));\\n\\n float antialiasblur = v_data.z;\\n float antialiased_blur = -max(u_blur, antialiasblur);\\n float r = v_radius / (v_radius + u_stroke_width);\\n\\n float outer_df;\\n float inner_df;\\n // 'circle', 'triangle', 'square', 'pentagon', 'hexagon', 'octogon', 'hexagram', 'rhombus', 'vesica'\\n // if (shape == 0) {\\n outer_df = sdCircle(v_data.xy, 1.0);\\n inner_df = sdCircle(v_data.xy, r);\\n // } else if (shape == 1) {\\n // outer_df = sdEquilateralTriangle(1.1 * v_data.xy);\\n // inner_df = sdEquilateralTriangle(1.1 / r * v_data.xy);\\n // } else if (shape == 2) {\\n // outer_df = sdBox(v_data.xy, vec2(1.));\\n // inner_df = sdBox(v_data.xy, vec2(r));\\n // } else if (shape == 3) {\\n // outer_df = sdPentagon(v_data.xy, 0.8);\\n // inner_df = sdPentagon(v_data.xy, r * 0.8);\\n // } else if (shape == 4) {\\n // outer_df = sdHexagon(v_data.xy, 0.8);\\n // inner_df = sdHexagon(v_data.xy, r * 0.8);\\n // } else if (shape == 5) {\\n // outer_df = sdOctogon(v_data.xy, 1.0);\\n // inner_df = sdOctogon(v_data.xy, r);\\n // } else if (shape == 6) {\\n // outer_df = sdHexagram(v_data.xy, 0.52);\\n // inner_df = sdHexagram(v_data.xy, r * 0.52);\\n // } else if (shape == 7) {\\n // outer_df = sdRhombus(v_data.xy, vec2(1.0));\\n // inner_df = sdRhombus(v_data.xy, vec2(r));\\n // } else if (shape == 8) {\\n // outer_df = sdVesica(v_data.xy, 1.1, 0.8);\\n // inner_df = sdVesica(v_data.xy, r * 1.1, r * 0.8);\\n // }\\n\\n float opacity_t = smoothstep(0.0, antialiased_blur, outer_df);\\n\\n float color_t = u_stroke_width < 0.01 ? 0.0 : smoothstep(\\n antialiased_blur,\\n 0.0,\\n inner_df\\n );\\n vec4 strokeColor = u_stroke_color == vec4(0) ? v_color : u_stroke_color;\\n\\n gl_FragColor = mix(vec4(v_color.rgb, v_color.a * u_opacity), strokeColor * u_stroke_opacity, color_t);\\n gl_FragColor.a = gl_FragColor.a * opacity_t;\\n\\n gl_FragColor = filterColor(gl_FragColor);\\n}\";\n\n/* babel-plugin-inline-import './shaders/webgl.point.vert.glsl' */\nvar pointVert = \"attribute vec2 position;\\nattribute vec4 color;\\nattribute float shape;\\nattribute vec2 offset;\\nattribute float size;\\n\\nuniform mat4 projectionMatrix;\\nuniform mat4 modelViewMatrix;\\n\\nuniform float u_stroke_width : 0.01;\\nuniform float u_device_pixel_ratio;\\nuniform vec2 u_viewport;\\n\\nvarying vec4 v_color;\\nvarying vec4 v_data;\\nvarying float v_radius;\\n\\n#pragma include \\\"picking\\\"\\n\\nvoid main() {\\n v_color = color;\\n v_radius = size;\\n\\n lowp float antialiasblur = 1.0 / u_device_pixel_ratio * (size + u_stroke_width);\\n\\n // construct point coords\\n v_data = vec4(position, antialiasblur, shape);\\n\\n gl_Position = projectionMatrix * modelViewMatrix\\n * vec4(position * size + offset, 0.0, 1.0);\\n\\n setPickingColor(a_PickingColor);\\n}\";\nvar pointShapes = ['circle', 'triangle', 'square', 'pentagon', 'hexagon', 'octogon', 'hexagram', 'rhombus', 'vesica'];\nexport\n/**\n * Use SDF to draw 2D point with stroke.\n */\nvar Point = (_dec = injectable(), _dec2 = inject(IDENTIFIER.Systems), _dec3 = named(IDENTIFIER.MaterialSystem), _dec4 = inject(IDENTIFIER.Systems), _dec5 = named(IDENTIFIER.GeometrySystem), _dec6 = inject(IDENTIFIER.ShaderModuleService), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function (_Renderable) {\n _inherits(Point, _Renderable);\n\n var _super = _createSuper(Point);\n\n function Point() {\n var _this;\n\n _classCallCheck(this, Point);\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _super.call.apply(_super, [this].concat(args));\n\n _initializerDefineProperty(_this, \"materialSystem\", _descriptor, _assertThisInitialized(_this));\n\n _initializerDefineProperty(_this, \"geometrySystem\", _descriptor2, _assertThisInitialized(_this));\n\n _initializerDefineProperty(_this, \"shaderModuleService\", _descriptor3, _assertThisInitialized(_this));\n\n return _this;\n }\n\n _createClass(Point, [{\n key: \"onAttributeChanged\",\n value: function onAttributeChanged(_ref) {\n var name = _ref.name,\n data = _ref.data;\n var mesh = this.getMeshComponent();\n\n if (mesh && mesh.material) {\n if (name === 'strokeWidth') {\n mesh.material.setUniform('u_stroke_width', data);\n } else if (name === 'strokeColor') {\n mesh.material.setUniform('u_stroke_color', data);\n } else if (name === 'strokeOpacity') {\n mesh.material.setUniform('u_stroke_opacity', data);\n } else if (name === 'opacity') {\n mesh.material.setUniform('u_opacity', data);\n } else if (name === 'blur') {\n mesh.material.setUniform('u_blur', data);\n }\n }\n }\n }, {\n key: \"onEntityCreated\",\n value: function onEntityCreated() {\n this.shaderModuleService.registerModule('grid', {\n vs: pointVert,\n fs: pointFrag\n });\n\n var _this$shaderModuleSer = this.shaderModuleService.getModule('grid'),\n vs = _this$shaderModuleSer.vs,\n fs = _this$shaderModuleSer.fs,\n extractedUniforms = _this$shaderModuleSer.uniforms;\n\n var material = this.materialSystem.createShaderMaterial({\n vertexShader: vs,\n fragmentShader: fs,\n cull: {\n enable: false\n },\n depth: {\n enable: false\n },\n blend: {\n enable: true,\n func: {\n srcRGB: gl.SRC_ALPHA,\n dstRGB: gl.ONE_MINUS_SRC_ALPHA,\n srcAlpha: 1,\n dstAlpha: 1\n }\n }\n }); // TODO: support define stroke-relative props per point\n\n material.setUniform(_objectSpread({\n u_device_pixel_ratio: window.devicePixelRatio\n }, extractedUniforms));\n var attributes = this.buildAttributes();\n var geometry = this.geometrySystem.createInstancedBufferGeometry({\n maxInstancedCount: attributes.instancedOffsets.length / 2,\n vertexCount: 6\n });\n geometry.setIndex([0, 2, 1, 0, 3, 2]);\n geometry.setAttribute('position', Float32Array.from(attributes.positions), {\n arrayStride: 4 * 2,\n stepMode: 'vertex',\n attributes: [{\n shaderLocation: 0,\n offset: 0,\n format: 'float2'\n }]\n });\n geometry.setAttribute('offset', Float32Array.from(attributes.instancedOffsets), {\n arrayStride: 4 * 2,\n stepMode: 'instance',\n attributes: [{\n shaderLocation: 1,\n offset: 0,\n format: 'float2'\n }]\n });\n geometry.setAttribute('color', Float32Array.from(attributes.instancedColors), {\n arrayStride: 4 * 4,\n stepMode: 'instance',\n attributes: [{\n shaderLocation: 2,\n offset: 0,\n format: 'float4'\n }]\n });\n geometry.setAttribute('size', Float32Array.from(attributes.instancedSizes), {\n arrayStride: 4,\n stepMode: 'instance',\n attributes: [{\n shaderLocation: 3,\n offset: 0,\n format: 'float'\n }]\n });\n geometry.setAttribute('shape', Float32Array.from(attributes.instancedShapes), {\n arrayStride: 4,\n stepMode: 'instance',\n attributes: [{\n shaderLocation: 4,\n offset: 0,\n format: 'float'\n }]\n });\n geometry.setAttribute('a_PickingColor', Float32Array.from(attributes.instancedPickingColors), {\n arrayStride: 4 * 3,\n stepMode: 'instance',\n attributes: [{\n shaderLocation: 6,\n offset: 0,\n format: 'float3'\n }]\n });\n this.setMaterial(material);\n this.setGeometry(geometry);\n }\n }, {\n key: \"buildAttribute\",\n value: function buildAttribute(config, attributes, index) {\n var _attributes$instanced, _attributes$instanced2, _attributes$instanced3, _attributes$instanced4;\n\n (_attributes$instanced = attributes.instancedPickingColors).push.apply(_attributes$instanced, _toConsumableArray(encodePickingColor(config.id || index)));\n\n attributes.instancedShapes.push(pointShapes.indexOf(config.shape || 'circle'));\n\n (_attributes$instanced2 = attributes.instancedColors).push.apply(_attributes$instanced2, _toConsumableArray(config.color || [1, 0, 0, 1]));\n\n (_attributes$instanced3 = attributes.instancedOffsets).push.apply(_attributes$instanced3, _toConsumableArray(config.position || [0, 0]));\n\n (_attributes$instanced4 = attributes.instancedSizes).push.apply(_attributes$instanced4, _toConsumableArray(config.size || [0.2, 0.2]));\n }\n }, {\n key: \"buildAttributes\",\n value: function buildAttributes() {\n var _this2 = this;\n\n var attributes = {\n positions: [1, 1, 1, -1, -1, -1, -1, 1],\n instancedOffsets: [],\n instancedColors: [],\n instancedSizes: [],\n instancedShapes: [],\n instancedPickingColors: []\n };\n\n if (Array.isArray(this.config)) {\n this.config.forEach(function (config, i) {\n _this2.buildAttribute(config, attributes, i);\n });\n } else {\n this.buildAttribute(this.config, attributes, 0);\n }\n\n return attributes;\n }\n }]);\n\n return Point;\n}(Renderable), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"materialSystem\", [_dec2, _dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"geometrySystem\", [_dec4, _dec5], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, \"shaderModuleService\", [_dec6], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=index.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _dec4, _class, _class2, _descriptor, _descriptor2, _descriptor3, _temp;\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === \"undefined\" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nimport { IDENTIFIER } from '@antv/g-webgpu-core'; // tslint:disable-next-line:no-submodule-imports\n\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { inject, injectable } from 'inversify';\n\n/* babel-plugin-inline-import './material/shaders/map.frag.declaration.glsl' */\nvar mapFragDeclaration = \"#ifdef USE_MAP\\n uniform sampler2D map;\\n#endif\";\n\n/* babel-plugin-inline-import './material/shaders/map.frag.main.glsl' */\nvar mapFragMain = \"#ifdef USE_MAP\\n vec4 texelColor = texture2D(map, vUv);\\n // texelColor = mapTexelToLinear(texelColor);\\n diffuseColor *= texelColor;\\n#endif\";\n\n/* babel-plugin-inline-import './material/shaders/uv.frag.declaration.glsl' */\nvar uvFragDeclaration = \"#if (defined( USE_UV ) && ! defined( UVS_VERTEX_ONLY ))\\n varying vec2 vUv;\\n#endif\";\n\n/* babel-plugin-inline-import './material/shaders/uv.vert.declaration.glsl' */\nvar uvVertDeclaration = \"#ifdef USE_UV\\n attribute vec2 uv;\\n\\t#ifdef UVS_VERTEX_ONLY\\n vec2 vUv;\\n\\t#else\\n\\t\\tvarying vec2 vUv;\\n\\t#endif\\n\\tuniform mat3 uvTransform;\\n#endif\";\n\n/* babel-plugin-inline-import './material/shaders/uv.vert.main.glsl' */\nvar uvVertMain = \"#ifdef USE_UV\\n vUv = (uvTransform * vec3(uv, 1)).xy;\\n#endif\";\nexport var Renderer = (_dec = injectable(), _dec2 = inject(IDENTIFIER.RenderEngine), _dec3 = inject(IDENTIFIER.ShaderModuleService), _dec4 = inject(IDENTIFIER.ConfigService), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function () {\n function Renderer() {\n _classCallCheck(this, Renderer);\n\n this.container = void 0;\n\n _initializerDefineProperty(this, \"engine\", _descriptor, this);\n\n _initializerDefineProperty(this, \"shaderModule\", _descriptor2, this);\n\n _initializerDefineProperty(this, \"configService\", _descriptor3, this);\n\n this.inited = false;\n this.rendering = false;\n this.pendings = [];\n this.views = [];\n this.size = void 0;\n }\n\n _createClass(Renderer, [{\n key: \"init\",\n value: function () {\n var _init = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {\n var systems, config, _iterator, _step, system;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n // 模块化处理\n this.shaderModule.registerBuiltinModules();\n this.shaderModule.registerModule('uv.vert.declaration', {\n vs: uvVertDeclaration\n });\n this.shaderModule.registerModule('uv.vert.main', {\n vs: uvVertMain\n });\n this.shaderModule.registerModule('uv.frag.declaration', {\n fs: uvFragDeclaration\n });\n this.shaderModule.registerModule('map.frag.declaration', {\n fs: mapFragDeclaration\n });\n this.shaderModule.registerModule('map.frag.main', {\n fs: mapFragMain\n });\n systems = this.container.getAll(IDENTIFIER.Systems);\n config = this.configService.get();\n\n if (!config.canvas) {\n _context.next = 30;\n break;\n }\n\n _context.next = 11;\n return this.engine.init({\n canvas: config.canvas,\n swapChainFormat: WebGPUConstants.TextureFormat.BGRA8Unorm,\n antialiasing: false\n });\n\n case 11:\n _iterator = _createForOfIteratorHelper(systems);\n _context.prev = 12;\n\n _iterator.s();\n\n case 14:\n if ((_step = _iterator.n()).done) {\n _context.next = 21;\n break;\n }\n\n system = _step.value;\n\n if (!system.initialize) {\n _context.next = 19;\n break;\n }\n\n _context.next = 19;\n return system.initialize();\n\n case 19:\n _context.next = 14;\n break;\n\n case 21:\n _context.next = 26;\n break;\n\n case 23:\n _context.prev = 23;\n _context.t0 = _context[\"catch\"](12);\n\n _iterator.e(_context.t0);\n\n case 26:\n _context.prev = 26;\n\n _iterator.f();\n\n return _context.finish(26);\n\n case 29:\n this.inited = true;\n\n case 30:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this, [[12, 23, 26, 29]]);\n }));\n\n function init() {\n return _init.apply(this, arguments);\n }\n\n return init;\n }()\n }, {\n key: \"render\",\n value: function () {\n var _render = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2() {\n var systems,\n _len,\n views,\n _key,\n _iterator2,\n _step2,\n system,\n _args2 = arguments;\n\n return _regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n if (!(!this.inited || this.rendering)) {\n _context2.next = 2;\n break;\n }\n\n return _context2.abrupt(\"return\");\n\n case 2:\n if (this.pendings.length) {\n this.pendings.forEach(function (pending) {\n pending();\n });\n }\n\n this.rendering = true;\n this.engine.beginFrame();\n systems = this.container.getAll(IDENTIFIER.Systems);\n\n for (_len = _args2.length, views = new Array(_len), _key = 0; _key < _len; _key++) {\n views[_key] = _args2[_key];\n }\n\n _iterator2 = _createForOfIteratorHelper(systems);\n _context2.prev = 8;\n\n _iterator2.s();\n\n case 10:\n if ((_step2 = _iterator2.n()).done) {\n _context2.next = 17;\n break;\n }\n\n system = _step2.value;\n\n if (!system.execute) {\n _context2.next = 15;\n break;\n }\n\n _context2.next = 15;\n return system.execute(views);\n\n case 15:\n _context2.next = 10;\n break;\n\n case 17:\n _context2.next = 22;\n break;\n\n case 19:\n _context2.prev = 19;\n _context2.t0 = _context2[\"catch\"](8);\n\n _iterator2.e(_context2.t0);\n\n case 22:\n _context2.prev = 22;\n\n _iterator2.f();\n\n return _context2.finish(22);\n\n case 25:\n // 录制一遍绘制命令,后续直接播放\n // if (this.useRenderBundle) {\n // if (!this.renderBundleRecorded) {\n // this.engine.startRecordBundle();\n // if (this.onUpdate) {\n // await this.onUpdate(this.engine);\n // }\n // this.renderBundle = this.engine.stopRecordBundle();\n // this.renderBundleRecorded = true;\n // }\n // this.engine.executeBundles([this.renderBundle]);\n // } else {\n // if (this.onUpdate) {\n // await this.onUpdate(this.engine);\n // }\n // }\n this.engine.endFrame();\n this.rendering = false;\n\n case 27:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this, [[8, 19, 22, 25]]);\n }));\n\n function render() {\n return _render.apply(this, arguments);\n }\n\n return render;\n }()\n }, {\n key: \"clear\",\n value: function clear(options) {\n var _this = this;\n\n if (this.inited) {\n this.engine.clear(options);\n } else {\n this.pendings.unshift(function () {\n _this.engine.clear(options);\n\n _this.pendings.shift();\n });\n }\n\n return this;\n } // public setScissor(\n // scissor: Partial<{\n // enable: boolean;\n // box: {\n // x: number;\n // y: number;\n // width: number;\n // height: number;\n // };\n // }>,\n // ) {\n // this.engine.setScissor(scissor);\n // return this;\n // }\n\n }, {\n key: \"setSize\",\n value: function setSize(_ref) {\n var width = _ref.width,\n height = _ref.height;\n var canvas = this.engine.getCanvas();\n this.size = {\n width: width,\n height: height\n };\n canvas.width = width;\n canvas.height = height;\n return this;\n }\n }, {\n key: \"getSize\",\n value: function getSize() {\n return this.size;\n }\n }]);\n\n return Renderer;\n}(), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"engine\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"shaderModule\", [_dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, \"configService\", [_dec4], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=Renderer.js.map","export function encodePickingColor(featureIdx) {\n return [featureIdx + 1 & 255, featureIdx + 1 >> 8 & 255, featureIdx + 1 >> 8 >> 8 & 255];\n}\n//# sourceMappingURL=picking.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\nvar _dec, _class, _temp;\n\nimport { injectable } from 'inversify';\nexport var Scene = (_dec = injectable(), _dec(_class = (_temp = /*#__PURE__*/function () {\n function Scene() {\n _classCallCheck(this, Scene);\n\n this.entities = [];\n }\n\n _createClass(Scene, [{\n key: \"getEntities\",\n value: function getEntities() {\n return this.entities;\n }\n }, {\n key: \"addRenderable\",\n value: function addRenderable(renderable) {\n this.addEntity(renderable.getEntity());\n return this;\n }\n }, {\n key: \"removeRenderable\",\n value: function removeRenderable(renderable) {\n this.removeEntity(renderable.getEntity());\n return this;\n }\n }, {\n key: \"addLight\",\n value: function addLight() {}\n }, {\n key: \"addEntity\",\n value: function addEntity(entity) {\n if (this.entities.indexOf(entity) === -1) {\n this.entities.push(entity);\n }\n\n return this;\n }\n }, {\n key: \"removeEntity\",\n value: function removeEntity(entity) {\n var index = this.entities.indexOf(entity);\n this.entities.splice(index, 1);\n return this;\n }\n }]);\n\n return Scene;\n}(), _temp)) || _class);\n//# sourceMappingURL=Scene.js.map","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\n\nvar _dec, _class, _temp;\n\nimport { injectable } from 'inversify';\nexport var TextureCache = (_dec = injectable(), _dec(_class = (_temp = /*#__PURE__*/function () {\n function TextureCache() {\n _classCallCheck(this, TextureCache);\n\n this.cache = {};\n }\n\n _createClass(TextureCache, [{\n key: \"get\",\n value: function get(name) {\n return this.cache[name];\n }\n }, {\n key: \"set\",\n value: function set(name, texture) {\n this.cache[name] = texture;\n }\n }]);\n\n return TextureCache;\n}(), _temp)) || _class);\n//# sourceMappingURL=Cache.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _class, _class2, _descriptor, _descriptor2, _temp;\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { IDENTIFIER } from '@antv/g-webgpu-core';\nimport { inject, injectable } from 'inversify';\nimport { TextureCache } from './Cache';\nexport var Texture2D = (_dec = injectable(), _dec2 = inject(TextureCache), _dec3 = inject(IDENTIFIER.RenderEngine), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function () {\n function Texture2D() {\n _classCallCheck(this, Texture2D);\n\n _initializerDefineProperty(this, \"textureCache\", _descriptor, this);\n\n _initializerDefineProperty(this, \"engine\", _descriptor2, this);\n\n this.config = void 0;\n this.loaded = false;\n this.texture = void 0;\n }\n\n _createClass(Texture2D, [{\n key: \"setConfig\",\n value: function setConfig(config) {\n this.config = config;\n }\n }, {\n key: \"isLoaded\",\n value: function isLoaded() {\n return this.loaded;\n } // public update(config: ITexture2DInitializationOptions) {\n // if (this.loaded && this.texture) {\n // const t = this.texture.get();\n // }\n // }\n\n }, {\n key: \"load\",\n value: function () {\n var _load = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {\n var _this = this;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (!this.config.url) {\n _context.next = 4;\n break;\n }\n\n return _context.abrupt(\"return\", new Promise(function (resolve, reject) {\n var existed = _this.textureCache.get(_this.config.url);\n\n if (existed) {\n resolve(existed);\n } else {\n var image = new Image();\n image.crossOrigin = 'Anonymous';\n image.src = _this.config.url;\n\n image.onload = function () {\n var texture = _this.engine.createTexture2D(_objectSpread(_objectSpread({}, _this.config), {}, {\n data: image,\n width: image.width,\n height: image.height,\n flipY: true\n }));\n\n _this.textureCache.set(_this.config.url, texture);\n\n _this.texture = texture;\n _this.loaded = true;\n resolve(texture);\n };\n\n image.onerror = function () {\n reject();\n };\n }\n }));\n\n case 4:\n this.loaded = true;\n this.texture = this.engine.createTexture2D(this.config);\n return _context.abrupt(\"return\", this.texture);\n\n case 7:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function load() {\n return _load.apply(this, arguments);\n }\n\n return load;\n }()\n }]);\n\n return Texture2D;\n}(), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"textureCache\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n}), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, \"engine\", [_dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=Texture2D.js.map","import _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _dec3, _class, _class2, _descriptor, _temp;\n\nimport { IDENTIFIER } from '@antv/g-webgpu-core';\nimport { inject, injectable, named } from 'inversify';\nexport var View = (_dec = injectable(), _dec2 = inject(IDENTIFIER.Systems), _dec3 = named(IDENTIFIER.RendererSystem), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function () {\n function View() {\n _classCallCheck(this, View);\n\n _initializerDefineProperty(this, \"rendererSystem\", _descriptor, this);\n\n this.camera = void 0;\n this.scene = void 0;\n this.viewport = {\n x: 0,\n y: 0,\n width: 0,\n height: 0\n };\n this.clearColor = [1, 1, 1, 1];\n }\n\n _createClass(View, [{\n key: \"getCamera\",\n value: function getCamera() {\n return this.camera;\n }\n }, {\n key: \"getScene\",\n value: function getScene() {\n return this.scene;\n }\n }, {\n key: \"getViewport\",\n value: function getViewport() {\n return this.viewport;\n }\n }, {\n key: \"getClearColor\",\n value: function getClearColor() {\n return this.clearColor;\n }\n }, {\n key: \"setCamera\",\n value: function setCamera(camera) {\n this.camera = camera;\n return this;\n }\n }, {\n key: \"setScene\",\n value: function setScene(scene) {\n this.scene = scene;\n return this;\n }\n }, {\n key: \"setViewport\",\n value: function setViewport(viewport) {\n this.viewport = viewport;\n return this;\n }\n }, {\n key: \"setClearColor\",\n value: function setClearColor(clearColor) {\n this.clearColor = clearColor;\n return this;\n }\n }, {\n key: \"pick\",\n value: function pick(position) {\n return this.rendererSystem.pick(position, this);\n }\n }]);\n\n return View;\n}(), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"rendererSystem\", [_dec2, _dec3], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=View.js.map","import _regeneratorRuntime from \"@babel/runtime/regenerator\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _initializerDefineProperty from \"@babel/runtime/helpers/initializerDefineProperty\";\nimport _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _applyDecoratedDescriptor from \"@babel/runtime/helpers/applyDecoratedDescriptor\";\nimport _initializerWarningHelper from \"@babel/runtime/helpers/initializerWarningHelper\";\n\nvar _dec, _dec2, _class, _class2, _descriptor, _temp;\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\n// tslint:disable-next-line:no-reference\n/// <reference path=\"../../../node_modules/@webgpu/types/dist/index.d.ts\" />\nimport { createEntity as _createEntity, createWorldContainer, IDENTIFIER } from '@antv/g-webgpu-core';\nimport { WebGLEngine, WebGPUEngine } from '@antv/g-webgpu-engine'; // tslint:disable-next-line:no-submodule-imports\n\nimport * as WebGPUConstants from '@webgpu/types/dist/constants';\nimport { inject, injectable } from 'inversify';\nimport { Camera } from './camera/Camera';\nimport { Geometry } from './geometry';\nimport { Box } from './geometry/Box';\nimport { Merged } from './geometry/Merged';\nimport { Plane } from './geometry/Plane';\nimport { Sphere } from './geometry/Sphere';\nimport { Kernel } from './Kernel';\nimport { Material } from './material';\nimport { Basic } from './material/basic';\nimport { Grid } from './renderable/grid';\nimport { Line } from './renderable/line';\nimport { Point } from './renderable/point';\nimport { Renderable } from './renderable/Renderable';\nimport { Renderer } from './Renderer';\nimport { Scene } from './Scene';\nimport { TextureCache } from './texture/Cache';\nimport { Texture2D } from './texture/Texture2D';\nimport { createCanvas } from './utils/canvas';\nimport { View } from './View';\nexport var World = (_dec = injectable(), _dec2 = inject(IDENTIFIER.ConfigService), _dec(_class = (_class2 = (_temp = /*#__PURE__*/function () {\n function World() {\n _classCallCheck(this, World);\n\n _initializerDefineProperty(this, \"configService\", _descriptor, this);\n\n this.container = void 0;\n }\n\n _createClass(World, [{\n key: \"getEngine\",\n value: function () {\n var _getEngine = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {\n var engine, _this$configService$g, canvas, engineOptions;\n\n return _regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n engine = this.container.get(IDENTIFIER.RenderEngine);\n _this$configService$g = this.configService.get(), canvas = _this$configService$g.canvas, engineOptions = _this$configService$g.engineOptions;\n _context.next = 4;\n return engine.init(_objectSpread({\n canvas: canvas || createCanvas(),\n swapChainFormat: WebGPUConstants.TextureFormat.BGRA8Unorm,\n antialiasing: false\n }, engineOptions));\n\n case 4:\n return _context.abrupt(\"return\", engine);\n\n case 5:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function getEngine() {\n return _getEngine.apply(this, arguments);\n }\n\n return getEngine;\n }()\n /**\n * get transform component\n * @param entity\n */\n\n }, {\n key: \"getTransformComponent\",\n value: function getTransformComponent(entity) {\n var manager = this.container.get(IDENTIFIER.TransformComponentManager);\n return manager.getComponentByEntity(entity);\n }\n }, {\n key: \"getMeshComponent\",\n value: function getMeshComponent(entity) {\n var manager = this.container.get(IDENTIFIER.MeshComponentManager);\n return manager.getComponentByEntity(entity);\n }\n }, {\n key: \"setConfig\",\n value: function setConfig(config) {\n this.configService.set(config);\n }\n }, {\n key: \"setContainer\",\n value: function setContainer(container) {\n this.container = container;\n }\n }, {\n key: \"getContainer\",\n value: function getContainer() {\n return this.container;\n }\n }, {\n key: \"createEntity\",\n value: function createEntity() {\n return _createEntity();\n }\n }, {\n key: \"createScene\",\n value: function createScene() {\n return this.container.get(Scene);\n }\n }, {\n key: \"createCamera\",\n value: function createCamera() {\n return this.container.get(Camera);\n }\n }, {\n key: \"createView\",\n value: function createView() {\n return this.container.get(View);\n } // public createLight(type: string,) {\n // return this.container.getNamed(IDENTIFIER.Light, type)\n // }\n\n }, {\n key: \"createRenderable\",\n value: function createRenderable(type, config) {\n var renderable = type ? this.container.getNamed(IDENTIFIER.Renderable, type) : this.container.get(Renderable);\n\n var entity = _createEntity();\n\n renderable.setConfig(config || {});\n renderable.setEntity(entity);\n return renderable;\n }\n }, {\n key: \"createGeometry\",\n value: function createGeometry(type, config) {\n var geometry = this.container.getNamed(IDENTIFIER.Geometry, type);\n\n var entity = _createEntity();\n\n geometry.setConfig(config || {});\n geometry.setEntity(entity);\n return geometry.getComponent();\n }\n }, {\n key: \"createMaterial\",\n value: function createMaterial(type, config) {\n var material = this.container.getNamed(IDENTIFIER.Material, type);\n\n var entity = _createEntity();\n\n material.setConfig(config || {});\n material.setEntity(entity, type);\n return material.getComponent();\n }\n }, {\n key: \"createTexture2D\",\n value: function createTexture2D(config) {\n var texture = this.container.get(Texture2D);\n texture.setConfig(config);\n return texture;\n }\n }, {\n key: \"createBufferGeometry\",\n value: function createBufferGeometry(params) {\n var geometrySystem = this.container.getNamed(IDENTIFIER.Systems, IDENTIFIER.GeometrySystem);\n return geometrySystem.createBufferGeometry(params);\n }\n }, {\n key: \"createInstancedBufferGeometry\",\n value: function createInstancedBufferGeometry(params) {\n var geometrySystem = this.container.getNamed(IDENTIFIER.Systems, IDENTIFIER.GeometrySystem);\n return geometrySystem.createInstancedBufferGeometry(params);\n }\n }, {\n key: \"createShaderMaterial\",\n value: function createShaderMaterial(params) {\n var materialSystem = this.container.getNamed(IDENTIFIER.Systems, IDENTIFIER.MaterialSystem);\n return materialSystem.createShaderMaterial(params);\n }\n }, {\n key: \"createKernel\",\n value: function createKernel(precompiledBundle) {\n var kernel = this.container.get(Kernel);\n\n if (typeof precompiledBundle === 'string') {\n kernel.setBundle(JSON.parse(precompiledBundle));\n } else {\n kernel.setBundle(precompiledBundle);\n }\n\n kernel.init();\n return kernel;\n }\n }, {\n key: \"createRenderer\",\n value: function createRenderer() {\n var renderer = this.container.get(Renderer);\n renderer.container = this.container;\n renderer.init();\n return renderer;\n }\n }, {\n key: \"destroy\",\n value: function destroy() {\n var systems = this.container.getAll(IDENTIFIER.Systems);\n systems.forEach(function (system) {\n if (system.tearDown) {\n system.tearDown();\n }\n });\n var engine = this.container.get(IDENTIFIER.RenderEngine);\n engine.destroy();\n var interactor = this.container.get(IDENTIFIER.InteractorService);\n interactor.destroy();\n }\n }], [{\n key: \"create\",\n value: function create() {\n var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var worldContainer = createWorldContainer(); // bind render engine, fallback to WebGL\n\n var engineClazz = !navigator.gpu ? WebGLEngine : WebGPUEngine;\n\n if (!worldContainer.isBound(IDENTIFIER.RenderEngine)) {\n worldContainer.bind(IDENTIFIER.RenderEngine) // @ts-ignore\n .to(engineClazz).inSingletonScope();\n }\n\n worldContainer.bind(Renderer).toSelf();\n worldContainer.bind(Kernel).toSelf();\n worldContainer.bind(Renderable).toSelf();\n worldContainer.bind(View).toSelf();\n worldContainer.bind(Camera).toSelf();\n worldContainer.bind(Scene).toSelf();\n worldContainer.bind(World).toSelf();\n worldContainer.bind(TextureCache).toSelf();\n worldContainer.bind(Texture2D).toSelf(); // bind geometries\n\n worldContainer.bind(IDENTIFIER.Geometry).to(Box).whenTargetNamed(Geometry.BOX);\n worldContainer.bind(IDENTIFIER.Geometry).to(Sphere).whenTargetNamed(Geometry.SPHERE);\n worldContainer.bind(IDENTIFIER.Geometry).to(Plane).whenTargetNamed(Geometry.PLANE);\n worldContainer.bind(IDENTIFIER.Geometry).to(Merged).whenTargetNamed(Geometry.MERGED); // bind materials\n\n worldContainer.bind(IDENTIFIER.Material).to(Basic).whenTargetNamed(Material.BASIC); // bind renderables\n\n worldContainer.bind(IDENTIFIER.Renderable).to(Point).whenTargetNamed(Renderable.POINT);\n worldContainer.bind(IDENTIFIER.Renderable).to(Line).whenTargetNamed(Renderable.LINE);\n worldContainer.bind(IDENTIFIER.Renderable).to(Grid).whenTargetNamed(Renderable.GRID);\n var world = worldContainer.get(World);\n world.setContainer(worldContainer);\n world.setConfig(config);\n return world;\n }\n }]);\n\n return World;\n}(), _temp), (_descriptor = _applyDecoratedDescriptor(_class2.prototype, \"configService\", [_dec2], {\n configurable: true,\n enumerable: true,\n writable: true,\n initializer: null\n})), _class2)) || _class);\n//# sourceMappingURL=World.js.map","import { OutNode, Edge, IndexMap } from '../layout/types'\nimport { isNumber } from './'\n\n\n/**\n * 将 number | Function 类型的参数转换为 return number 的 Function\n * @param {number | Function} value 需要被转换的值\n * @param {number} defaultV 返回函数的默认返回值\n * @return {Function} 转换后的函数 \n */\nexport const proccessToFunc = (value: number | Function | undefined, defaultV?: number): ((d?: any) => number) => {\n let func\n if (!value) {\n func = () => {\n return defaultV || 1\n }\n } else if (isNumber(value)) {\n func = () => {\n return value\n }\n } else {\n func = value\n }\n return func as ((d?: any) => number)\n}\n\n/**\n * 将节点和边数据转换为 GPU 可读的数组。并返回 maxEdgePerVetex,每个节点上最多的边数\n * @param {NodeConfig[]} nodes 需要被转换的值\n * @param {EdgeConfig[]} edges 返回函数的默认返回值\n * @return {Object} 转换后的数组及 maxEdgePerVetex 组成的对象\n */\nexport const buildTextureData = (nodes: OutNode[], edges: Edge[]): {\n array: Float32Array,\n maxEdgePerVetex: number\n} => {\n const dataArray = []\n const nodeDict: any = []\n const mapIdPos: IndexMap = {}\n let i = 0\n for (i = 0; i < nodes.length; i++) {\n const n = nodes[i]\n mapIdPos[n.id] = i\n dataArray.push(n.x)\n dataArray.push(n.y)\n dataArray.push(0)\n dataArray.push(0)\n nodeDict.push([])\n }\n for (i = 0; i < edges.length; i++) {\n const e = edges[i]\n nodeDict[mapIdPos[e.source]].push(mapIdPos[e.target])\n nodeDict[mapIdPos[e.target]].push(mapIdPos[e.source])\n }\n\n let maxEdgePerVetex = 0\n for (i = 0; i < nodes.length; i++) {\n const offset: number = dataArray.length\n const dests = nodeDict[i]\n const len = dests.length\n dataArray[i * 4 + 2] = offset\n dataArray[i * 4 + 3] = dests.length\n maxEdgePerVetex = Math.max(maxEdgePerVetex, dests.length)\n for (let j = 0; j < len; ++j) {\n const dest = dests[j]\n dataArray.push(+dest)\n }\n }\n\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0)\n }\n return {\n maxEdgePerVetex,\n array: new Float32Array(dataArray),\n }\n}\n\n/**\n* 将节点和边数据转换为 GPU 可读的数组,每条边带有一个属性。并返回 maxEdgePerVetex,每个节点上最多的边数\n* @param {NodeConfig[]} nodes 节点数组\n* @param {EdgeConfig[]} edges 边数组\n* @param {Function} attrs 读取边属性的函数\n* @return {Object} 转换后的数组及 maxEdgePerVetex 组成的对象\n*/\n// export const buildTextureDataWithOneEdgeAttr = (nodes: OutNode[], edges: Edge[], attrs: Function): {\n// array: Float32Array,\n// maxEdgePerVetex: number\n// } => {\n// const dataArray = [];\n// const nodeDict: any = [];\n// const mapIdPos: IndexMap = {};\n// let i = 0;\n// for (i = 0; i < nodes.length; i++) {\n// const n = nodes[i];\n// mapIdPos[n.id] = i;\n// dataArray.push(n.x);\n// dataArray.push(n.y);\n// dataArray.push(0);\n// dataArray.push(0);\n// nodeDict.push([]);\n// }\n// for (i = 0; i < edges.length; i++) {\n// const e = edges[i];\n// nodeDict[mapIdPos[e.source]].push(mapIdPos[e.target]);\n// nodeDict[mapIdPos[e.source]].push(attrs(e)); // 理想边长,后续可以改成每条边不同\n// nodeDict[mapIdPos[e.target]].push(mapIdPos[e.source]);\n// nodeDict[mapIdPos[e.target]].push(attrs(e)); // 理想边长,后续可以改成每条边不同\n// }\n\n// let maxEdgePerVetex = 0;\n// for (i = 0; i < nodes.length; i++) {\n// const offset: number = dataArray.length;\n// const dests = nodeDict[i]; // dest 中节点 id 与边长间隔存储,即一位节点 id,一位边长……\n// const len = dests.length;\n// dataArray[i * 4 + 2] = offset;\n// dataArray[i * 4 + 3] = len / 2; // 第四位存储与该节点相关的所有节点个数\n// maxEdgePerVetex = Math.max(maxEdgePerVetex, len / 2);\n// for (let j = 0; j < len; ++j) {\n// const dest = dests[j];\n// dataArray.push(+dest);\n// }\n// }\n\n// // 不是 4 的倍数,填充 0\n// while (dataArray.length % 4 !== 0) {\n// dataArray.push(0);\n// }\n// return {\n// array: new Float32Array(dataArray),\n// maxEdgePerVetex\n// }\n// }\n\n/**\n* 将节点和边数据转换为 GPU 可读的数组,每条边带有一个以上属性。并返回 maxEdgePerVetex,每个节点上最多的边数\n* @param {NodeConfig[]} nodes 节点数组\n* @param {EdgeConfig[]} edges 边数组\n* @param {Function} attrs 读取边属性的函数\n* @return {Object} 转换后的数组及 maxEdgePerVetex 组成的对象\n*/\nexport const buildTextureDataWithTwoEdgeAttr = (nodes: OutNode[], edges: Edge[], attrs1: Function, attrs2: Function): {\n array: Float32Array,\n maxEdgePerVetex: number\n} => {\n const dataArray = []\n const nodeDict: any = []\n const mapIdPos: IndexMap = {}\n let i = 0\n for (i = 0; i < nodes.length; i++) {\n const n = nodes[i]\n mapIdPos[n.id] = i\n dataArray.push(n.x)\n dataArray.push(n.y)\n dataArray.push(0)\n dataArray.push(0)\n nodeDict.push([])\n }\n for (i = 0; i < edges.length; i++) {\n const e = edges[i]\n nodeDict[mapIdPos[e.source]].push(mapIdPos[e.target])\n nodeDict[mapIdPos[e.source]].push(attrs1(e))\n nodeDict[mapIdPos[e.source]].push(attrs2(e))\n nodeDict[mapIdPos[e.source]].push(0)\n nodeDict[mapIdPos[e.target]].push(mapIdPos[e.source])\n nodeDict[mapIdPos[e.target]].push(attrs1(e))\n nodeDict[mapIdPos[e.target]].push(attrs2(e))\n nodeDict[mapIdPos[e.target]].push(0)\n }\n\n let maxEdgePerVetex = 0\n for (i = 0; i < nodes.length; i++) {\n const offset: number = dataArray.length\n const dests = nodeDict[i] // dest 中节点 id 与边长间隔存储,即一位节点 id,一位边长……\n const len = dests.length\n // dataArray[i * 4 + 2] = offset;\n // dataArray[i * 4 + 3] = len / 4; // 第四位存储与该节点相关的所有节点个数\n // pack offset & length into float32: offset 20bit, length 12bit\n dataArray[i * 4 + 2] = offset + 1048576 * len / 4\n dataArray[i * 4 + 3] = 0 // 第四位存储与上一次的距离差值\n maxEdgePerVetex = Math.max(maxEdgePerVetex, len / 4)\n for (let j = 0; j < len; ++j) {\n const dest = dests[j]\n dataArray.push(+dest)\n }\n }\n\n // 不是 4 的倍数,填充 0\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0)\n }\n return {\n maxEdgePerVetex,\n array: new Float32Array(dataArray),\n }\n}\n/**\n* transform the extended attributes of nodes or edges to a texture array\n* @param {string[]} attributeNames attributes' name to be read from items and put into output array\n* @param {ModelConfig[]} items the items to be read\n* @return {Float32Array} the attributes' value array to be read by GPU\n*/\nexport const attributesToTextureData = (attributeNames: string[], items: any[]): { array: Float32Array, count: number } => {\n const dataArray: any[] = []\n const attributeNum = attributeNames.length\n const attributteStringMap: any = {}\n items.forEach((item: any) => {\n attributeNames.forEach((name: string, i) => {\n if (attributteStringMap[item[name]] === undefined) {\n attributteStringMap[item[name]] = Object.keys(attributteStringMap).length\n }\n dataArray.push(attributteStringMap[item[name]])\n // insure each node's attributes take inter number of grids\n if (i === attributeNum - 1) {\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0)\n }\n }\n })\n })\n return {\n array: new Float32Array(dataArray),\n count: Object.keys(attributteStringMap).length\n }\n}\n\n/**\n* transform the number array format of extended attributes of nodes or edges to a texture array\n* @param {string[]} attributeNames attributes' name to be read from items and put into output array\n* @return {Float32Array} the attributes' value array to be read by GPU\n*/\nexport const arrayToTextureData = (valueArrays: number[][]): Float32Array => {\n const dataArray: any[] = []\n const attributeNum = valueArrays.length\n const itemNum = valueArrays[0].length\n for (let j = 0; j < itemNum; j++) {\n valueArrays.forEach((valueArray, i) => {\n dataArray.push(valueArray[j])\n // insure each node's attributes take inter number of grids\n if (i === attributeNum - 1) {\n while (dataArray.length % 4 !== 0) {\n dataArray.push(0)\n }\n }\n })\n }\n\n return new Float32Array(dataArray)\n}\n","// @ts-nocheck\n/**\n * @fileOverview fruchterman layout\n * @author shiwu.wyy@antfin.com\n */\n\nimport {\n OutNode,\n Edge,\n PointTuple,\n IndexMap,\n FruchtermanGPULayoutOptions\n} from \"../types\";\nimport { Base } from \"../base\";\nimport { isNumber } from \"../../util\";\n// @ts-ignore\nimport { World } from \"@antv/g-webgpu\";\n// compile at runtime in dev mode\nimport { buildTextureData, attributesToTextureData } from \"../../util/gpu\";\n// use compiled bundle in prod mode\nimport { fruchtermanBundle, clusterBundle } from \"./fruchtermanShader\";\nimport { LAYOUT_MESSAGE } from \"../constants\";\n// @ts-ignore\n// import { Compiler } from '@antv/g-webgpu-compiler'\n// import { fruchtermanCode, clusterCode } from './fruchtermanShader'\n\ntype INode = OutNode & {\n cluster: string | number;\n};\n\ntype NodeMap = {\n [key: string]: INode;\n};\n\n/**\n * fruchterman 布局\n */\nexport class FruchtermanGPULayout extends Base {\n /** 布局中心 */\n public center: PointTuple;\n\n /** 停止迭代的最大迭代数 */\n public maxIteration: number = 1000;\n\n /** 重力大小,影响图的紧凑程度 */\n public gravity: number = 10;\n\n /** 速度 */\n public speed: number = 1;\n\n /** 是否产生聚类力 */\n public clustering: boolean = false;\n\n /** 根据哪个字段聚类 */\n public clusterField: string = \"cluster\";\n\n /** 聚类力大小 */\n public clusterGravity: number = 10;\n\n /** 是否启用web worker。前提是在web worker里执行布局,否则无效\t*/\n public workerEnabled: boolean = false;\n\n public nodes: INode[] = [];\n\n public edges: Edge[] = [];\n\n public width: number = 300;\n\n public height: number = 300;\n\n public nodeMap: NodeMap = {};\n\n public nodeIdxMap: IndexMap = {};\n\n public canvasEl: HTMLCanvasElement;\n\n public onLayoutEnd: () => void;\n\n constructor(options?: FruchtermanGPULayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {\n maxIteration: 1000,\n gravity: 10,\n speed: 1,\n clustering: false,\n clusterGravity: 10\n };\n }\n\n /**\n * 执行布局\n */\n public async execute() {\n const self = this;\n const nodes = self.nodes;\n\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n const nodeMap: NodeMap = {};\n const nodeIdxMap: IndexMap = {};\n nodes.forEach((node, i) => {\n if (!isNumber(node.x)) node.x = Math.random() * this.width;\n if (!isNumber(node.y)) node.y = Math.random() * this.height;\n nodeMap[node.id] = node;\n nodeIdxMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.nodeIdxMap = nodeIdxMap;\n // layout\n await self.run();\n }\n\n public async executeWithWorker(canvas?: HTMLCanvasElement, ctx?: any) {\n const self = this;\n const nodes = self.nodes;\n const center = self.center;\n\n if (!nodes || nodes.length === 0) {\n return;\n }\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n return;\n }\n const nodeMap: NodeMap = {};\n const nodeIdxMap: IndexMap = {};\n nodes.forEach((node, i) => {\n if (!isNumber(node.x)) node.x = Math.random() * this.width;\n if (!isNumber(node.y)) node.y = Math.random() * this.height;\n nodeMap[node.id] = node;\n nodeIdxMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.nodeIdxMap = nodeIdxMap;\n // layout\n await self.run(canvas, ctx);\n }\n\n public async run(canvas?: HTMLCanvasElement, ctx?: any) {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n const maxIteration = self.maxIteration;\n const center = self.center;\n const area = self.height * self.width;\n let maxDisplace = Math.sqrt(area) / 10;\n const k2 = area / (nodes.length + 1);\n const k = Math.sqrt(k2);\n const speed = self.speed;\n const clustering = self.clustering;\n\n const {\n array: attributeArray,\n count: clusterCount\n } = attributesToTextureData([self.clusterField], nodes);\n\n // pushing the fx and fy\n nodes.forEach((node, i) => {\n let fx = 0, fy = 0;\n if (isNumber(node.fx) && isNumber(node.fy)) {\n fx = node.fx || 0.001;\n fy = node.fy || 0.001;\n }\n attributeArray[4 * i + 1] = fx;\n attributeArray[4 * i + 2] = fy;\n })\n\n\n const numParticles = nodes.length;\n const { maxEdgePerVetex, array: nodesEdgesArray } = buildTextureData(\n nodes,\n edges\n );\n\n const workerEnabled = self.workerEnabled;\n\n let world;\n\n if (workerEnabled) {\n world = World.create({\n canvas,\n engineOptions: {\n supportCompute: true\n }\n });\n } else {\n world = World.create({\n engineOptions: {\n supportCompute: true\n }\n });\n }\n\n // compile at runtime in dev mode\n // const compiler = new Compiler()\n // const fruchtermanBundle = compiler.compileBundle(fruchtermanCode)\n // const clusterBundle = compiler.compileBundle(clusterCode)\n\n // use compiled bundle in prod mode\n // console.log(fruchtermanBundle.toString())\n // console.log(clusterBundle.toString())\n\n const onLayoutEnd = self.onLayoutEnd;\n\n const clusterCenters = [];\n for (let i = 0; i < clusterCount; i++) {\n clusterCenters.push(0, 0, 0, 0);\n }\n\n const kernelFruchterman = world\n .createKernel(fruchtermanBundle)\n .setDispatch([numParticles, 1, 1])\n .setBinding({\n u_Data: nodesEdgesArray,\n u_K: k,\n u_K2: k2,\n u_Gravity: self.gravity,\n u_ClusterGravity: self.clusterGravity || self.gravity || 1,\n u_Speed: speed,\n u_MaxDisplace: maxDisplace,\n u_Clustering: clustering ? 1 : 0,\n u_Center: center,\n u_AttributeArray: attributeArray,\n u_ClusterCenters: clusterCenters,\n MAX_EDGE_PER_VERTEX: maxEdgePerVetex,\n VERTEX_COUNT: numParticles\n });\n\n let kernelCluster: any;\n if (clustering) {\n kernelCluster = world\n .createKernel(clusterBundle)\n .setDispatch([clusterCount, 1, 1])\n .setBinding({\n u_Data: nodesEdgesArray,\n u_NodeAttributes: attributeArray,\n u_ClusterCenters: clusterCenters,\n VERTEX_COUNT: numParticles,\n CLUSTER_COUNT: clusterCount\n });\n }\n\n const execute = async () => {\n for (let i = 0; i < maxIteration; i++) {\n // eslint-disable-next-line no-await-in-loop\n await kernelFruchterman.execute();\n\n if (clustering) {\n kernelCluster.setBinding({\n u_Data: kernelFruchterman\n });\n // eslint-disable-next-line no-await-in-loop\n await kernelCluster.execute();\n kernelFruchterman.setBinding({\n u_ClusterCenters: kernelCluster\n });\n }\n\n kernelFruchterman.setBinding({\n u_MaxDisplace: maxDisplace *= 0.99\n });\n }\n\n const finalParticleData = await kernelFruchterman.getOutput();\n\n if (canvas) {\n // 传递数据给主线程\n ctx.postMessage({\n type: LAYOUT_MESSAGE.GPUEND,\n vertexEdgeData: finalParticleData\n // edgeIndexBufferData,\n });\n } else {\n nodes.forEach((node, i) => {\n const x = finalParticleData[4 * i];\n const y = finalParticleData[4 * i + 1];\n node.x = x;\n node.y = y;\n });\n }\n if (onLayoutEnd) onLayoutEnd();\n };\n\n await execute();\n }\n\n public getType() {\n return \"fruchterman-gpu\";\n }\n}\n","export\n const fruchtermanCode = `\nimport { globalInvocationID } from 'g-webgpu';\nconst MAX_EDGE_PER_VERTEX;\nconst VERTEX_COUNT;\n@numthreads(1, 1, 1)\nclass Fruchterman {\n @in @out\n u_Data: vec4[];\n @in\n u_K: float;\n @in\n u_K2: float;\n \n @in\n u_Center: vec2;\n @in\n u_Gravity: float;\n @in\n u_ClusterGravity: float;\n @in\n u_Speed: float;\n @in\n u_MaxDisplace: float;\n @in\n u_Clustering: float;\n @in\n u_AttributeArray: vec4[];\n @in\n u_ClusterCenters: vec4[];\n calcRepulsive(i: int, currentNode: vec4): vec2 {\n let dx = 0, dy = 0;\n for (let j = 0; j < VERTEX_COUNT; j++) {\n if (i != j) {\n const nextNode = this.u_Data[j];\n const xDist = currentNode[0] - nextNode[0];\n const yDist = currentNode[1] - nextNode[1];\n const dist = (xDist * xDist + yDist * yDist) + 0.01;\n let param = this.u_K2 / dist;\n \n if (dist > 0.0) {\n dx += param * xDist;\n dy += param * yDist;\n if (xDist == 0 && yDist == 0) {\n const sign = i < j ? 1 : -1;\n dx += param * sign;\n dy += param * sign;\n }\n }\n }\n }\n return [dx, dy];\n }\n calcGravity(currentNode: vec4, nodeAttributes: vec4): vec2 { // \n let dx = 0, dy = 0;\n const vx = currentNode[0] - this.u_Center[0];\n const vy = currentNode[1] - this.u_Center[1];\n const gf = 0.01 * this.u_K * this.u_Gravity;\n dx = gf * vx;\n dy = gf * vy;\n if (this.u_Clustering == 1) {\n const clusterIdx = int(nodeAttributes[0]);\n const center = this.u_ClusterCenters[clusterIdx];\n const cvx = currentNode[0] - center[0];\n const cvy = currentNode[1] - center[1];\n const dist = sqrt(cvx * cvx + cvy * cvy) + 0.01;\n const parma = this.u_K * this.u_ClusterGravity / dist;\n dx += parma * cvx;\n dy += parma * cvy;\n }\n return [dx, dy];\n }\n calcAttractive(i: int, currentNode: vec4): vec2 {\n let dx = 0, dy = 0;\n const arr_offset = int(floor(currentNode[2] + 0.5));\n const length = int(floor(currentNode[3] + 0.5));\n const node_buffer: vec4;\n for (let p = 0; p < MAX_EDGE_PER_VERTEX; p++) {\n if (p >= length) break;\n const arr_idx = arr_offset + p;\n // when arr_idx % 4 == 0 update currentNodedx_buffer\n const buf_offset = arr_idx - arr_idx / 4 * 4;\n if (p == 0 || buf_offset == 0) {\n node_buffer = this.u_Data[int(arr_idx / 4)];\n }\n const float_j = buf_offset == 0 ? node_buffer[0] :\n buf_offset == 1 ? node_buffer[1] :\n buf_offset == 2 ? node_buffer[2] :\n node_buffer[3];\n const nextNode = this.u_Data[int(float_j)];\n const xDist = currentNode[0] - nextNode[0];\n const yDist = currentNode[1] - nextNode[1];\n const dist = sqrt(xDist * xDist + yDist * yDist) + 0.01;\n let attractiveF = dist / this.u_K;\n \n if (dist > 0.0) {\n dx -= xDist * attractiveF;\n dy -= yDist * attractiveF;\n if (xDist == 0 && yDist == 0) {\n const sign = i < int(float_j) ? 1 : -1;\n dx -= sign * attractiveF;\n dy -= sign * attractiveF;\n }\n }\n }\n return [dx, dy];\n }\n @main\n compute() {\n const i = globalInvocationID.x;\n const currentNode = this.u_Data[i];\n let dx = 0, dy = 0;\n if (i >= VERTEX_COUNT) {\n this.u_Data[i] = currentNode;\n return;\n }\n\n // [gravity, fx, fy, 0]\n const nodeAttributes = this.u_AttributeArray[i];\n\n if (nodeAttributes[1] != 0 && nodeAttributes[2] != 0) {\n // the node is fixed\n this.u_Data[i] = [\n nodeAttributes[1],\n nodeAttributes[2],\n currentNode[2],\n currentNode[3]\n ];\n return;\n }\n\n // repulsive\n const repulsive = this.calcRepulsive(i, currentNode);\n dx += repulsive[0];\n dy += repulsive[1];\n // attractive\n const attractive = this.calcAttractive(i, currentNode);\n dx += attractive[0];\n dy += attractive[1];\n // gravity\n const gravity = this.calcGravity(currentNode, nodeAttributes);\n dx -= gravity[0];\n dy -= gravity[1];\n // speed\n dx *= this.u_Speed;\n dy *= this.u_Speed;\n\n // move\n const distLength = sqrt(dx * dx + dy * dy);\n if (distLength > 0.0) {\n const limitedDist = min(this.u_MaxDisplace * this.u_Speed, distLength);\n this.u_Data[i] = [\n currentNode[0] + dx / distLength * limitedDist,\n currentNode[1] + dy / distLength * limitedDist,\n currentNode[2],\n currentNode[3]\n ];\n }\n }\n}\n`\n\nexport const fruchtermanBundle = `{\"shaders\":{\"WGSL\":\"import \\\\\"GLSL.std.450\\\\\" as std;\\\\n\\\\n\\\\n# var gWebGPUDebug : bool = false;\\\\n# var gWebGPUDebugOutput : vec4<f32> = vec4<f32>(0.0);\\\\n\\\\n[[builtin global_invocation_id]] var<in> globalInvocationID : vec3<u32>;\\\\n# [[builtin work_group_size]] var<in> workGroupSize : vec3<u32>;\\\\n# [[builtin work_group_id]] var<in> workGroupID : vec3<u32>;\\\\n[[builtin local_invocation_id]] var<in> localInvocationID : vec3<u32>;\\\\n# [[builtin num_work_groups]] var<in> numWorkGroups : vec3<u32>;\\\\n[[builtin local_invocation_idx]] var<in> localInvocationIndex : u32;\\\\n\\\\ntype GWebGPUParams = [[block]] struct {\\\\n [[offset 0]] u_K : f32;\\\\n [[offset 4]] u_K2 : f32;\\\\n [[offset 8]] u_Center : vec2<f32>;\\\\n [[offset 16]] u_Gravity : f32;\\\\n [[offset 20]] u_ClusterGravity : f32;\\\\n [[offset 24]] u_Speed : f32;\\\\n [[offset 28]] u_MaxDisplace : f32;\\\\n [[offset 32]] u_Clustering : f32;\\\\n};\\\\n[[binding 0, set 0]] var<uniform> gWebGPUUniformParams : GWebGPUParams;\\\\ntype GWebGPUBuffer0 = [[block]] struct {\\\\n [[offset 0]] u_Data : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 1, set 0]] var<storage_buffer> gWebGPUBuffer0 : GWebGPUBuffer0;\\\\ntype GWebGPUBuffer1 = [[block]] struct {\\\\n [[offset 0]] u_AttributeArray : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 2, set 0]] var<storage_buffer> gWebGPUBuffer1 : GWebGPUBuffer1;\\\\ntype GWebGPUBuffer2 = [[block]] struct {\\\\n [[offset 0]] u_ClusterCenters : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 3, set 0]] var<storage_buffer> gWebGPUBuffer2 : GWebGPUBuffer2;\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\nfn calcRepulsive(i : i32, currentNode : vec4<f32>) -> vec2<f32> {var dx : f32 = 0.0;\\\\nvar dy : f32 = 0.0;\\\\nfor (var j : i32 = 0; j < __DefineValuePlaceholder__VERTEX_COUNT; j = j + 1) {if (i != j) {var nextNode : vec4<f32> = gWebGPUBuffer0.u_Data[j];\\\\nvar xDist : f32 = currentNode.x - nextNode.x;\\\\nvar yDist : f32 = currentNode.y - nextNode.y;\\\\nvar dist : f32 = ((xDist * xDist) + (yDist * yDist)) + 0.01;\\\\nvar param : f32 = gWebGPUUniformParams.u_K2 / dist;\\\\nif (dist > 0.0) {dx = dx + param * xDist;\\\\ndy = dy + param * yDist;\\\\nif ((xDist == 0.0) && (yDist == 0.0)) {var sign : f32 = select(1.0, -1.0, i < j);\\\\ndx = dx + param * std::sign;\\\\ndy = dy + param * std::sign;}}}}\\\\nreturn vec2<f32>(dx, dy);}\\\\nfn calcGravity(currentNode : vec4<f32>, nodeAttributes : vec4<f32>) -> vec2<f32> {var dx : f32 = 0.0;\\\\nvar dy : f32 = 0.0;\\\\nvar vx : f32 = currentNode.x - gWebGPUUniformParams.u_Center.x;\\\\nvar vy : f32 = currentNode.y - gWebGPUUniformParams.u_Center.y;\\\\nvar gf : f32 = (0.01 * gWebGPUUniformParams.u_K) * gWebGPUUniformParams.u_Gravity;\\\\ndx = gf * vx;\\\\ndy = gf * vy;\\\\nif (gWebGPUUniformParams.u_Clustering == 1.0) {var clusterIdx : i32 = i32(nodeAttributes.x);\\\\nvar center : vec4<f32> = gWebGPUBuffer2.u_ClusterCenters[clusterIdx];\\\\nvar cvx : f32 = currentNode.x - center.x;\\\\nvar cvy : f32 = currentNode.y - center.y;\\\\nvar dist : f32 = std::sqrt((cvx * cvx) + (cvy * cvy)) + 0.01;\\\\nvar parma : f32 = (gWebGPUUniformParams.u_K * gWebGPUUniformParams.u_ClusterGravity) / dist;\\\\ndx = dx + parma * cvx;\\\\ndy = dy + parma * cvy;}\\\\nreturn vec2<f32>(dx, dy);}\\\\nfn calcAttractive(i : i32, currentNode : vec4<f32>) -> vec2<f32> {var dx : f32 = 0.0;\\\\nvar dy : f32 = 0.0;\\\\nvar arr_offset : i32 = i32(std::floor(currentNode.z + 0.5));\\\\nvar length : i32 = i32(std::floor(currentNode.w + 0.5));\\\\nvar node_buffer : vec4<f32>;\\\\nfor (var p : i32 = 0; p < __DefineValuePlaceholder__MAX_EDGE_PER_VERTEX; p = p + 1) {if (p >= length) {break;}\\\\nvar arr_idx : i32 = arr_offset + i32(p);\\\\nvar buf_offset : i32 = arr_idx - ((arr_idx / 4) * 4);\\\\nif ((p == 0) || (buf_offset == 0)) {node_buffer = gWebGPUBuffer0.u_Data[i32(arr_idx / 4)];}\\\\nvar float_j : f32 = select(node_buffer.x, select(node_buffer.y, select(node_buffer.z, node_buffer.w, buf_offset == 2), buf_offset == 1), buf_offset == 0);\\\\nvar nextNode : vec4<f32> = gWebGPUBuffer0.u_Data[i32(float_j)];\\\\nvar xDist : f32 = currentNode.x - nextNode.x;\\\\nvar yDist : f32 = currentNode.y - nextNode.y;\\\\nvar dist : f32 = std::sqrt((xDist * xDist) + (yDist * yDist)) + 0.01;\\\\nvar attractiveF : f32 = dist / gWebGPUUniformParams.u_K;\\\\nif (dist > 0.0) {dx = dx - xDist * attractiveF;\\\\ndy = dy - yDist * attractiveF;\\\\nif ((xDist == 0.0) && (yDist == 0.0)) {var sign : f32 = select(1.0, -1.0, i < i32(float_j));\\\\ndx = dx - std::sign * attractiveF;\\\\ndy = dy - std::sign * attractiveF;}}}\\\\nreturn vec2<f32>(dx, dy);}\\\\nfn main() -> void {var i : i32 = globalInvocationID.x;\\\\nvar currentNode : vec4<f32> = gWebGPUBuffer0.u_Data[i];\\\\nvar dx : f32 = 0.0;\\\\nvar dy : f32 = 0.0;\\\\nif (i >= __DefineValuePlaceholder__VERTEX_COUNT) {gWebGPUBuffer0.u_Data[i] = currentNode;\\\\nreturn ;}\\\\nvar nodeAttributes : vec4<f32> = gWebGPUBuffer1.u_AttributeArray[i];\\\\nif ((nodeAttributes.y != 0.0) && (nodeAttributes.z != 0.0)) {gWebGPUBuffer0.u_Data[i] = vec4<f32>(nodeAttributes.y, nodeAttributes.z, currentNode.z, currentNode.w);\\\\nreturn ;}\\\\nvar repulsive : vec2<f32> = calcRepulsive(i, currentNode);\\\\ndx = dx + repulsive.x;\\\\ndy = dy + repulsive.y;\\\\nvar attractive : vec2<f32> = calcAttractive(i, currentNode);\\\\ndx = dx + attractive.x;\\\\ndy = dy + attractive.y;\\\\nvar gravity : vec2<f32> = calcGravity(currentNode, nodeAttributes);\\\\ndx = dx - gravity.x;\\\\ndy = dy - gravity.y;\\\\ndx = dx * gWebGPUUniformParams.u_Speed;\\\\ndy = dy * gWebGPUUniformParams.u_Speed;\\\\nvar distLength : f32 = std::sqrt((dx * dx) + (dy * dy));\\\\nif (distLength > 0.0) {var limitedDist : f32 = std::min(gWebGPUUniformParams.u_MaxDisplace * gWebGPUUniformParams.u_Speed, distLength);\\\\ngWebGPUBuffer0.u_Data[i] = vec4<f32>(currentNode.x + ((dx / distLength) * limitedDist), currentNode.y + ((dy / distLength) * limitedDist), currentNode.z, currentNode.w);}\\\\nreturn;}\\\\n\\\\nentry_point compute as \\\\\"main\\\\\" = main;\\\\n\",\"GLSL450\":\"\\\\n\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\nivec3 globalInvocationID = ivec3(gl_GlobalInvocationID);\\\\nivec3 workGroupSize = ivec3(1,1,1);\\\\nivec3 workGroupID = ivec3(gl_WorkGroupID);\\\\nivec3 localInvocationID = ivec3(gl_LocalInvocationID);\\\\nivec3 numWorkGroups = ivec3(gl_NumWorkGroups);\\\\nint localInvocationIndex = int(gl_LocalInvocationIndex);\\\\n\\\\nlayout(std140, set = 0, binding = 0) uniform GWebGPUParams {\\\\n float u_K;\\\\n float u_K2;\\\\n vec2 u_Center;\\\\n float u_Gravity;\\\\n float u_ClusterGravity;\\\\n float u_Speed;\\\\n float u_MaxDisplace;\\\\n float u_Clustering;\\\\n} gWebGPUUniformParams;\\\\nlayout(std430, set = 0, binding = 1) buffer GWebGPUBuffer0 {\\\\n vec4 u_Data[];\\\\n} gWebGPUBuffer0;\\\\n\\\\nlayout(std430, set = 0, binding = 2) buffer readonly GWebGPUBuffer1 {\\\\n vec4 u_AttributeArray[];\\\\n} gWebGPUBuffer1;\\\\n\\\\nlayout(std430, set = 0, binding = 3) buffer readonly GWebGPUBuffer2 {\\\\n vec4 u_ClusterCenters[];\\\\n} gWebGPUBuffer2;\\\\n\\\\n\\\\n\\\\n#define MAX_EDGE_PER_VERTEX __DefineValuePlaceholder__MAX_EDGE_PER_VERTEX\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\nlayout (\\\\n local_size_x = 1,\\\\n local_size_y = 1,\\\\n local_size_z = 1\\\\n) in;\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\nvec2 calcRepulsive(int i, vec4 currentNode) {float dx = 0.0;\\\\nfloat dy = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {if (i != j) {vec4 nextNode = gWebGPUBuffer0.u_Data[j];\\\\nfloat xDist = currentNode.x - nextNode.x;\\\\nfloat yDist = currentNode.y - nextNode.y;\\\\nfloat dist = ((xDist * xDist) + (yDist * yDist)) + 0.01;\\\\nfloat param = gWebGPUUniformParams.u_K2 / dist;\\\\nif (dist > 0.0) {dx += param * xDist;\\\\ndy += param * yDist;\\\\nif ((xDist == 0.0) && (yDist == 0.0)) {float sign = (i < j) ? (1.0) : (-1.0);\\\\ndx += param * sign;\\\\ndy += param * sign;}}}}\\\\nreturn vec2(dx, dy);}\\\\nvec2 calcGravity(vec4 currentNode, vec4 nodeAttributes) {float dx = 0.0;\\\\nfloat dy = 0.0;\\\\nfloat vx = currentNode.x - gWebGPUUniformParams.u_Center.x;\\\\nfloat vy = currentNode.y - gWebGPUUniformParams.u_Center.y;\\\\nfloat gf = (0.01 * gWebGPUUniformParams.u_K) * gWebGPUUniformParams.u_Gravity;\\\\ndx = gf * vx;\\\\ndy = gf * vy;\\\\nif (gWebGPUUniformParams.u_Clustering == 1.0) {int clusterIdx = int(nodeAttributes.x);\\\\nvec4 center = gWebGPUBuffer2.u_ClusterCenters[clusterIdx];\\\\nfloat cvx = currentNode.x - center.x;\\\\nfloat cvy = currentNode.y - center.y;\\\\nfloat dist = sqrt((cvx * cvx) + (cvy * cvy)) + 0.01;\\\\nfloat parma = (gWebGPUUniformParams.u_K * gWebGPUUniformParams.u_ClusterGravity) / dist;\\\\ndx += parma * cvx;\\\\ndy += parma * cvy;}\\\\nreturn vec2(dx, dy);}\\\\nvec2 calcAttractive(int i, vec4 currentNode) {float dx = 0.0;\\\\nfloat dy = 0.0;\\\\nint arr_offset = int(floor(currentNode.z + 0.5));\\\\nint length = int(floor(currentNode.w + 0.5));\\\\nvec4 node_buffer;\\\\nfor (int p = 0; p < MAX_EDGE_PER_VERTEX; p++) {if (p >= length) {break;}\\\\nint arr_idx = arr_offset + int(p);\\\\nint buf_offset = arr_idx - ((arr_idx / 4) * 4);\\\\nif ((p == 0) || (buf_offset == 0)) {node_buffer = gWebGPUBuffer0.u_Data[int(arr_idx / 4)];}\\\\nfloat float_j = (buf_offset == 0) ? (node_buffer.x) : ((buf_offset == 1) ? (node_buffer.y) : ((buf_offset == 2) ? (node_buffer.z) : (node_buffer.w)));\\\\nvec4 nextNode = gWebGPUBuffer0.u_Data[int(float_j)];\\\\nfloat xDist = currentNode.x - nextNode.x;\\\\nfloat yDist = currentNode.y - nextNode.y;\\\\nfloat dist = sqrt((xDist * xDist) + (yDist * yDist)) + 0.01;\\\\nfloat attractiveF = dist / gWebGPUUniformParams.u_K;\\\\nif (dist > 0.0) {dx -= xDist * attractiveF;\\\\ndy -= yDist * attractiveF;\\\\nif ((xDist == 0.0) && (yDist == 0.0)) {float sign = (i < int(float_j)) ? (1.0) : (-1.0);\\\\ndx -= sign * attractiveF;\\\\ndy -= sign * attractiveF;}}}\\\\nreturn vec2(dx, dy);}\\\\nvoid main() {int i = globalInvocationID.x;\\\\nvec4 currentNode = gWebGPUBuffer0.u_Data[i];\\\\nfloat dx = 0.0;\\\\nfloat dy = 0.0;\\\\nif (i >= VERTEX_COUNT) {gWebGPUBuffer0.u_Data[i] = currentNode;\\\\nreturn ;}\\\\nvec4 nodeAttributes = gWebGPUBuffer1.u_AttributeArray[i];\\\\nif ((nodeAttributes.y != 0.0) && (nodeAttributes.z != 0.0)) {gWebGPUBuffer0.u_Data[i] = vec4(nodeAttributes.y, nodeAttributes.z, currentNode.z, currentNode.w);\\\\nreturn ;}\\\\nvec2 repulsive = calcRepulsive(i, currentNode);\\\\ndx += repulsive.x;\\\\ndy += repulsive.y;\\\\nvec2 attractive = calcAttractive(i, currentNode);\\\\ndx += attractive.x;\\\\ndy += attractive.y;\\\\nvec2 gravity = calcGravity(currentNode, nodeAttributes);\\\\ndx -= gravity.x;\\\\ndy -= gravity.y;\\\\ndx *= gWebGPUUniformParams.u_Speed;\\\\ndy *= gWebGPUUniformParams.u_Speed;\\\\nfloat distLength = sqrt((dx * dx) + (dy * dy));\\\\nif (distLength > 0.0) {float limitedDist = min(gWebGPUUniformParams.u_MaxDisplace * gWebGPUUniformParams.u_Speed, distLength);\\\\ngWebGPUBuffer0.u_Data[i] = vec4(currentNode.x + ((dx / distLength) * limitedDist), currentNode.y + ((dy / distLength) * limitedDist), currentNode.z, currentNode.w);}}\\\\n\",\"GLSL100\":\"\\\\n\\\\nfloat epsilon = 0.00001;\\\\nvec2 addrTranslation_1Dto2D(float address1D, vec2 texSize) {\\\\n vec2 conv_const = vec2(1.0 / texSize.x, 1.0 / (texSize.x * texSize.y));\\\\n vec2 normAddr2D = float(address1D) * conv_const;\\\\n return vec2(fract(normAddr2D.x + epsilon), normAddr2D.y);\\\\n}\\\\n\\\\nvoid barrier() {}\\\\n \\\\n\\\\nuniform vec2 u_OutputTextureSize;\\\\nuniform int u_OutputTexelCount;\\\\nvarying vec2 v_TexCoord;\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\n#define MAX_EDGE_PER_VERTEX __DefineValuePlaceholder__MAX_EDGE_PER_VERTEX\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\n\\\\nuniform sampler2D u_Data;\\\\nuniform vec2 u_DataSize;\\\\nvec4 getDatau_Data(vec2 address2D) {\\\\n return vec4(texture2D(u_Data, address2D).rgba);\\\\n}\\\\nvec4 getDatau_Data(float address1D) {\\\\n return getDatau_Data(addrTranslation_1Dto2D(address1D, u_DataSize));\\\\n}\\\\nvec4 getDatau_Data(int address1D) {\\\\n return getDatau_Data(float(address1D));\\\\n}\\\\nuniform float u_K;\\\\nuniform float u_K2;\\\\nuniform vec2 u_Center;\\\\nuniform float u_Gravity;\\\\nuniform float u_ClusterGravity;\\\\nuniform float u_Speed;\\\\nuniform float u_MaxDisplace;\\\\nuniform float u_Clustering;\\\\nuniform sampler2D u_AttributeArray;\\\\nuniform vec2 u_AttributeArraySize;\\\\nvec4 getDatau_AttributeArray(vec2 address2D) {\\\\n return vec4(texture2D(u_AttributeArray, address2D).rgba);\\\\n}\\\\nvec4 getDatau_AttributeArray(float address1D) {\\\\n return getDatau_AttributeArray(addrTranslation_1Dto2D(address1D, u_AttributeArraySize));\\\\n}\\\\nvec4 getDatau_AttributeArray(int address1D) {\\\\n return getDatau_AttributeArray(float(address1D));\\\\n}\\\\nuniform sampler2D u_ClusterCenters;\\\\nuniform vec2 u_ClusterCentersSize;\\\\nvec4 getDatau_ClusterCenters(vec2 address2D) {\\\\n return vec4(texture2D(u_ClusterCenters, address2D).rgba);\\\\n}\\\\nvec4 getDatau_ClusterCenters(float address1D) {\\\\n return getDatau_ClusterCenters(addrTranslation_1Dto2D(address1D, u_ClusterCentersSize));\\\\n}\\\\nvec4 getDatau_ClusterCenters(int address1D) {\\\\n return getDatau_ClusterCenters(float(address1D));\\\\n}\\\\nvec2 calcRepulsive(int i, vec4 currentNode) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat dx = 0.0;\\\\nfloat dy = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {if (i != j) {vec4 nextNode = getDatau_Data(j);\\\\nfloat xDist = currentNode.x - nextNode.x;\\\\nfloat yDist = currentNode.y - nextNode.y;\\\\nfloat dist = ((xDist * xDist) + (yDist * yDist)) + 0.01;\\\\nfloat param = u_K2 / dist;\\\\nif (dist > 0.0) {dx += param * xDist;\\\\ndy += param * yDist;\\\\nif ((xDist == 0.0) && (yDist == 0.0)) {float sign = (i < j) ? (1.0) : (-1.0);\\\\ndx += param * sign;\\\\ndy += param * sign;}}}}\\\\nreturn vec2(dx, dy);}\\\\nvec2 calcGravity(vec4 currentNode, vec4 nodeAttributes) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat dx = 0.0;\\\\nfloat dy = 0.0;\\\\nfloat vx = currentNode.x - u_Center.x;\\\\nfloat vy = currentNode.y - u_Center.y;\\\\nfloat gf = (0.01 * u_K) * u_Gravity;\\\\ndx = gf * vx;\\\\ndy = gf * vy;\\\\nif (u_Clustering == 1.0) {int clusterIdx = int(nodeAttributes.x);\\\\nvec4 center = getDatau_ClusterCenters(clusterIdx);\\\\nfloat cvx = currentNode.x - center.x;\\\\nfloat cvy = currentNode.y - center.y;\\\\nfloat dist = sqrt((cvx * cvx) + (cvy * cvy)) + 0.01;\\\\nfloat parma = (u_K * u_ClusterGravity) / dist;\\\\ndx += parma * cvx;\\\\ndy += parma * cvy;}\\\\nreturn vec2(dx, dy);}\\\\nvec2 calcAttractive(int i, vec4 currentNode) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat dx = 0.0;\\\\nfloat dy = 0.0;\\\\nint arr_offset = int(floor(currentNode.z + 0.5));\\\\nint length = int(floor(currentNode.w + 0.5));\\\\nvec4 node_buffer;\\\\nfor (int p = 0; p < MAX_EDGE_PER_VERTEX; p++) {if (p >= length) {break;}\\\\nint arr_idx = arr_offset + int(p);\\\\nint buf_offset = arr_idx - ((arr_idx / 4) * 4);\\\\nif ((p == 0) || (buf_offset == 0)) {node_buffer = getDatau_Data(int(arr_idx / 4));}\\\\nfloat float_j = (buf_offset == 0) ? (node_buffer.x) : ((buf_offset == 1) ? (node_buffer.y) : ((buf_offset == 2) ? (node_buffer.z) : (node_buffer.w)));\\\\nvec4 nextNode = getDatau_Data(int(float_j));\\\\nfloat xDist = currentNode.x - nextNode.x;\\\\nfloat yDist = currentNode.y - nextNode.y;\\\\nfloat dist = sqrt((xDist * xDist) + (yDist * yDist)) + 0.01;\\\\nfloat attractiveF = dist / u_K;\\\\nif (dist > 0.0) {dx -= xDist * attractiveF;\\\\ndy -= yDist * attractiveF;\\\\nif ((xDist == 0.0) && (yDist == 0.0)) {float sign = (i < int(float_j)) ? (1.0) : (-1.0);\\\\ndx -= sign * attractiveF;\\\\ndy -= sign * attractiveF;}}}\\\\nreturn vec2(dx, dy);}\\\\nvoid main() {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nint i = globalInvocationID.x;\\\\nvec4 currentNode = getDatau_Data(i);\\\\nfloat dx = 0.0;\\\\nfloat dy = 0.0;\\\\nif (i >= VERTEX_COUNT) {gl_FragColor = vec4(currentNode);\\\\nreturn ;}\\\\nvec4 nodeAttributes = getDatau_AttributeArray(i);\\\\nif ((nodeAttributes.y != 0.0) && (nodeAttributes.z != 0.0)) {gl_FragColor = vec4(vec4(nodeAttributes.y, nodeAttributes.z, currentNode.z, currentNode.w));\\\\nreturn ;}\\\\nvec2 repulsive = calcRepulsive(i, currentNode);\\\\ndx += repulsive.x;\\\\ndy += repulsive.y;\\\\nvec2 attractive = calcAttractive(i, currentNode);\\\\ndx += attractive.x;\\\\ndy += attractive.y;\\\\nvec2 gravity = calcGravity(currentNode, nodeAttributes);\\\\ndx -= gravity.x;\\\\ndy -= gravity.y;\\\\ndx *= u_Speed;\\\\ndy *= u_Speed;\\\\nfloat distLength = sqrt((dx * dx) + (dy * dy));\\\\nif (distLength > 0.0) {float limitedDist = min(u_MaxDisplace * u_Speed, distLength);\\\\ngl_FragColor = vec4(vec4(currentNode.x + ((dx / distLength) * limitedDist), currentNode.y + ((dy / distLength) * limitedDist), currentNode.z, currentNode.w));}if (gWebGPUDebug) {\\\\n gl_FragColor = gWebGPUDebugOutput;\\\\n}}\\\\n\"},\"context\":{\"name\":\"\",\"dispatch\":[1,1,1],\"threadGroupSize\":[1,1,1],\"maxIteration\":1,\"defines\":[{\"name\":\"MAX_EDGE_PER_VERTEX\",\"type\":\"Float\",\"runtime\":true},{\"name\":\"VERTEX_COUNT\",\"type\":\"Float\",\"runtime\":true}],\"uniforms\":[{\"name\":\"u_Data\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":false,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_K\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_K2\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_Center\",\"type\":\"vec2<f32>\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_Gravity\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_ClusterGravity\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_Speed\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_MaxDisplace\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_Clustering\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_AttributeArray\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_ClusterCenters\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]}],\"globalDeclarations\":[],\"output\":{\"name\":\"u_Data\",\"size\":[1,1],\"length\":1},\"needPingpong\":true}}`\n\nexport const clusterCode = `\nimport { globalInvocationID } from 'g-webgpu';\nconst VERTEX_COUNT;\nconst CLUSTER_COUNT;\n@numthreads(1, 1, 1)\nclass CalcCenter {\n @in\n u_Data: vec4[];\n @in\n u_NodeAttributes: vec4[]; // [[clusterIdx, 0, 0, 0], ...]\n @in @out\n u_ClusterCenters: vec4[]; // [[cx, cy, nodeCount, clusterIdx], ...]\n @main\n compute() {\n const i = globalInvocationID.x;\n const center = this.u_ClusterCenters[i];\n let sumx = 0;\n let sumy = 0;\n let count = 0;\n for (let j = 0; j < VERTEX_COUNT; j++) {\n const attributes = this.u_NodeAttributes[j];\n const clusterIdx = int(attributes[0]);\n const vertex = this.u_Data[j];\n if (clusterIdx == i) {\n sumx += vertex.x;\n sumy += vertex.y;\n count += 1;\n }\n }\n this.u_ClusterCenters[i] = [\n sumx / count,\n sumy / count,\n count,\n i\n ];\n }\n}\n`\n\nexport const clusterBundle = `{\"shaders\":{\"WGSL\":\"import \\\\\"GLSL.std.450\\\\\" as std;\\\\n\\\\n\\\\n# var gWebGPUDebug : bool = false;\\\\n# var gWebGPUDebugOutput : vec4<f32> = vec4<f32>(0.0);\\\\n\\\\n[[builtin global_invocation_id]] var<in> globalInvocationID : vec3<u32>;\\\\n# [[builtin work_group_size]] var<in> workGroupSize : vec3<u32>;\\\\n# [[builtin work_group_id]] var<in> workGroupID : vec3<u32>;\\\\n[[builtin local_invocation_id]] var<in> localInvocationID : vec3<u32>;\\\\n# [[builtin num_work_groups]] var<in> numWorkGroups : vec3<u32>;\\\\n[[builtin local_invocation_idx]] var<in> localInvocationIndex : u32;\\\\n\\\\n\\\\ntype GWebGPUBuffer0 = [[block]] struct {\\\\n [[offset 0]] u_Data : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 0, set 0]] var<storage_buffer> gWebGPUBuffer0 : GWebGPUBuffer0;\\\\ntype GWebGPUBuffer1 = [[block]] struct {\\\\n [[offset 0]] u_NodeAttributes : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 1, set 0]] var<storage_buffer> gWebGPUBuffer1 : GWebGPUBuffer1;\\\\ntype GWebGPUBuffer2 = [[block]] struct {\\\\n [[offset 0]] u_ClusterCenters : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 2, set 0]] var<storage_buffer> gWebGPUBuffer2 : GWebGPUBuffer2;\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\nfn main() -> void {var i : i32 = globalInvocationID.x;\\\\nvar center : vec4<f32> = gWebGPUBuffer2.u_ClusterCenters[i];\\\\nvar sumx : f32 = 0.0;\\\\nvar sumy : f32 = 0.0;\\\\nvar count : f32 = 0.0;\\\\nfor (var j : i32 = 0; j < __DefineValuePlaceholder__VERTEX_COUNT; j = j + 1) {var attributes : vec4<f32> = gWebGPUBuffer1.u_NodeAttributes[j];\\\\nvar clusterIdx : i32 = i32(attributes.x);\\\\nvar vertex : vec4<f32> = gWebGPUBuffer0.u_Data[j];\\\\nif (clusterIdx == i) {sumx = sumx + vertex.x;\\\\nsumy = sumy + vertex.y;\\\\ncount = count + 1.0;}}\\\\ngWebGPUBuffer2.u_ClusterCenters[i] = vec4<f32>(sumx / count, sumy / count, count, i);\\\\nreturn;}\\\\n\\\\nentry_point compute as \\\\\"main\\\\\" = main;\\\\n\",\"GLSL450\":\"\\\\n\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\nivec3 globalInvocationID = ivec3(gl_GlobalInvocationID);\\\\nivec3 workGroupSize = ivec3(1,1,1);\\\\nivec3 workGroupID = ivec3(gl_WorkGroupID);\\\\nivec3 localInvocationID = ivec3(gl_LocalInvocationID);\\\\nivec3 numWorkGroups = ivec3(gl_NumWorkGroups);\\\\nint localInvocationIndex = int(gl_LocalInvocationIndex);\\\\n\\\\n\\\\nlayout(std430, set = 0, binding = 0) buffer readonly GWebGPUBuffer0 {\\\\n vec4 u_Data[];\\\\n} gWebGPUBuffer0;\\\\n\\\\nlayout(std430, set = 0, binding = 1) buffer readonly GWebGPUBuffer1 {\\\\n vec4 u_NodeAttributes[];\\\\n} gWebGPUBuffer1;\\\\n\\\\nlayout(std430, set = 0, binding = 2) buffer GWebGPUBuffer2 {\\\\n vec4 u_ClusterCenters[];\\\\n} gWebGPUBuffer2;\\\\n\\\\n\\\\n\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\n#define CLUSTER_COUNT __DefineValuePlaceholder__CLUSTER_COUNT\\\\nlayout (\\\\n local_size_x = 1,\\\\n local_size_y = 1,\\\\n local_size_z = 1\\\\n) in;\\\\n\\\\n\\\\n\\\\nvoid main() {int i = globalInvocationID.x;\\\\nvec4 center = gWebGPUBuffer2.u_ClusterCenters[i];\\\\nfloat sumx = 0.0;\\\\nfloat sumy = 0.0;\\\\nfloat count = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {vec4 attributes = gWebGPUBuffer1.u_NodeAttributes[j];\\\\nint clusterIdx = int(attributes.x);\\\\nvec4 vertex = gWebGPUBuffer0.u_Data[j];\\\\nif (clusterIdx == i) {sumx += vertex.x;\\\\nsumy += vertex.y;\\\\ncount += 1.0;}}\\\\ngWebGPUBuffer2.u_ClusterCenters[i] = vec4(sumx / count, sumy / count, count, i);}\\\\n\",\"GLSL100\":\"\\\\n\\\\nfloat epsilon = 0.00001;\\\\nvec2 addrTranslation_1Dto2D(float address1D, vec2 texSize) {\\\\n vec2 conv_const = vec2(1.0 / texSize.x, 1.0 / (texSize.x * texSize.y));\\\\n vec2 normAddr2D = float(address1D) * conv_const;\\\\n return vec2(fract(normAddr2D.x + epsilon), normAddr2D.y);\\\\n}\\\\n\\\\nvoid barrier() {}\\\\n \\\\n\\\\nuniform vec2 u_OutputTextureSize;\\\\nuniform int u_OutputTexelCount;\\\\nvarying vec2 v_TexCoord;\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\n#define CLUSTER_COUNT __DefineValuePlaceholder__CLUSTER_COUNT\\\\n\\\\nuniform sampler2D u_Data;\\\\nuniform vec2 u_DataSize;\\\\nvec4 getDatau_Data(vec2 address2D) {\\\\n return vec4(texture2D(u_Data, address2D).rgba);\\\\n}\\\\nvec4 getDatau_Data(float address1D) {\\\\n return getDatau_Data(addrTranslation_1Dto2D(address1D, u_DataSize));\\\\n}\\\\nvec4 getDatau_Data(int address1D) {\\\\n return getDatau_Data(float(address1D));\\\\n}\\\\nuniform sampler2D u_NodeAttributes;\\\\nuniform vec2 u_NodeAttributesSize;\\\\nvec4 getDatau_NodeAttributes(vec2 address2D) {\\\\n return vec4(texture2D(u_NodeAttributes, address2D).rgba);\\\\n}\\\\nvec4 getDatau_NodeAttributes(float address1D) {\\\\n return getDatau_NodeAttributes(addrTranslation_1Dto2D(address1D, u_NodeAttributesSize));\\\\n}\\\\nvec4 getDatau_NodeAttributes(int address1D) {\\\\n return getDatau_NodeAttributes(float(address1D));\\\\n}\\\\nuniform sampler2D u_ClusterCenters;\\\\nuniform vec2 u_ClusterCentersSize;\\\\nvec4 getDatau_ClusterCenters(vec2 address2D) {\\\\n return vec4(texture2D(u_ClusterCenters, address2D).rgba);\\\\n}\\\\nvec4 getDatau_ClusterCenters(float address1D) {\\\\n return getDatau_ClusterCenters(addrTranslation_1Dto2D(address1D, u_ClusterCentersSize));\\\\n}\\\\nvec4 getDatau_ClusterCenters(int address1D) {\\\\n return getDatau_ClusterCenters(float(address1D));\\\\n}\\\\nvoid main() {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nint i = globalInvocationID.x;\\\\nvec4 center = getDatau_ClusterCenters(i);\\\\nfloat sumx = 0.0;\\\\nfloat sumy = 0.0;\\\\nfloat count = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {vec4 attributes = getDatau_NodeAttributes(j);\\\\nint clusterIdx = int(attributes.x);\\\\nvec4 vertex = getDatau_Data(j);\\\\nif (clusterIdx == i) {sumx += vertex.x;\\\\nsumy += vertex.y;\\\\ncount += 1.0;}}\\\\ngl_FragColor = vec4(vec4(sumx / count, sumy / count, count, i));if (gWebGPUDebug) {\\\\n gl_FragColor = gWebGPUDebugOutput;\\\\n}}\\\\n\"},\"context\":{\"name\":\"\",\"dispatch\":[1,1,1],\"threadGroupSize\":[1,1,1],\"maxIteration\":1,\"defines\":[{\"name\":\"VERTEX_COUNT\",\"type\":\"Float\",\"runtime\":true},{\"name\":\"CLUSTER_COUNT\",\"type\":\"Float\",\"runtime\":true}],\"uniforms\":[{\"name\":\"u_Data\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_NodeAttributes\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_ClusterCenters\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":false,\"writeonly\":false,\"size\":[1,1]}],\"globalDeclarations\":[],\"output\":{\"name\":\"u_ClusterCenters\",\"size\":[1,1],\"length\":1},\"needPingpong\":true}}`","// @ts-nocheck\n/**\n * @fileOverview fruchterman layout\n * @author shiwu.wyy@antfin.com\n */\n\nimport {\n IndexMap,\n OutNode,\n PointTuple,\n Edge,\n GForceGPULayoutOptions\n} from \"../types\";\nimport { Base } from \"../base\";\nimport { isNumber } from \"../../util\";\n// @ts-ignore\nimport { World } from \"@antv/g-webgpu\";\nimport {\n proccessToFunc,\n buildTextureDataWithTwoEdgeAttr,\n arrayToTextureData\n} from \"../../util/gpu\";\nimport { getDegree } from \"../../util/math\";\nimport { gForceBundle, aveMovementBundle } from \"./gForceShader\";\nimport { LAYOUT_MESSAGE } from \"../constants\";\n// @ts-ignore\n// import { Compiler } from '@antv/g-webgpu-compiler';\n// import { gForceCode, aveMovementCode } from './gForceShader';\n\ntype NodeMap = {\n [key: string]: OutNode;\n};\n\n/**\n * graphin 中的 force 布局\n */\nexport class GForceGPULayout extends Base {\n /** 布局中心 */\n public center: PointTuple;\n\n /** 停止迭代的最大迭代数 */\n public maxIteration: number = 1000;\n\n /** 弹簧引力系数 */\n public edgeStrength: number | ((d?: any) => number) | undefined = 200;\n\n /** 斥力系数 */\n public nodeStrength: number | ((d?: any) => number) | undefined = 1000;\n\n /** 库伦系数 */\n public coulombDisScale: number = 0.005;\n\n /** 阻尼系数 */\n public damping: number = 0.9;\n\n /** 最大速度 */\n public maxSpeed: number = 1000;\n\n /** 一次迭代的平均移动距离小于该值时停止迭代 */\n public minMovement: number = 0.5;\n\n /** 迭代中衰减 */\n public interval: number = 0.02;\n\n /** 斥力的一个系数 */\n public factor: number = 1;\n\n /** 每个节点质量的回调函数,若不指定,则默认使用度数作为节点质量 */\n public getMass: ((d?: any) => number) | undefined;\n\n /** 理想边长 */\n public linkDistance: number | ((d?: any) => number) | undefined = 1;\n\n /** 重力大小 */\n public gravity: number = 10;\n\n /** 每个节点中心力的 x、y、强度的回调函数,若不指定,则没有额外中心力 */\n public getCenter: ((d?: any, degree?: number) => number[]) | undefined;\n\n /** 是否启用web worker。前提是在web worker里执行布局,否则无效\t*/\n public workerEnabled: boolean = false;\n\n public nodes: OutNode[] = [];\n\n public edges: Edge[] = [];\n\n public width: number = 300;\n\n public height: number = 300;\n\n public nodeMap: NodeMap = {};\n\n public nodeIdxMap: IndexMap = {};\n\n public onLayoutEnd: () => void;\n\n /** 存储节点度数 */\n private degrees: number[];\n\n constructor(options?: GForceGPULayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {\n maxIteration: 2000,\n gravity: 10,\n clustering: false,\n clusterGravity: 10\n };\n }\n\n /**\n * 执行布局\n */\n public async execute() {\n const self = this;\n const nodes = self.nodes;\n\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n if (!self.center) {\n self.center = [self.width / 2, self.height / 2];\n }\n const center = self.center;\n\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n const nodeMap: NodeMap = {};\n const nodeIdxMap: IndexMap = {};\n nodes.forEach((node, i) => {\n if (!isNumber(node.x)) node.x = Math.random() * self.width;\n if (!isNumber(node.y)) node.y = Math.random() * self.height;\n nodeMap[node.id] = node;\n nodeIdxMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.nodeIdxMap = nodeIdxMap;\n\n self.nodeStrength = proccessToFunc(self.nodeStrength, 1);\n self.edgeStrength = proccessToFunc(self.edgeStrength, 1);\n\n // layout\n await self.run();\n }\n\n public executeWithWorker(canvas?: HTMLCanvasElement, ctx?: any) {\n const self = this;\n const nodes = self.nodes;\n const center = self.center;\n\n if (!nodes || nodes.length === 0) {\n return;\n }\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n return;\n }\n const nodeMap: NodeMap = {};\n const nodeIdxMap: IndexMap = {};\n nodes.forEach((node, i) => {\n if (!isNumber(node.x)) node.x = Math.random() * self.width;\n if (!isNumber(node.y)) node.y = Math.random() * self.height;\n nodeMap[node.id] = node;\n nodeIdxMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.nodeIdxMap = nodeIdxMap;\n\n self.nodeStrength = proccessToFunc(self.nodeStrength, 1);\n self.edgeStrength = proccessToFunc(self.edgeStrength, 1);\n\n // layout\n self.run(canvas, ctx);\n }\n\n public async run(canvas?: HTMLCanvasElement, ctx?: any) {\n const self = this;\n const nodes = self.nodes;\n const edges = self.edges;\n const maxIteration = self.maxIteration;\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n\n const numParticles = nodes.length;\n\n self.linkDistance = proccessToFunc(self.linkDistance) as ((\n d?: any\n ) => number);\n self.edgeStrength = proccessToFunc(self.edgeStrength) as ((\n d?: any\n ) => number);\n const {\n maxEdgePerVetex,\n array: nodesEdgesArray\n } = buildTextureDataWithTwoEdgeAttr(\n nodes,\n edges,\n self.linkDistance,\n self.edgeStrength\n );\n\n // init degree for mass\n self.degrees = getDegree(nodes.length, self.nodeIdxMap, edges);\n const masses: number[] = [];\n const nodeStrengths: number[] = [];\n const centerXs: number[] = [];\n const centerYs: number[] = [];\n const centerGravities: number[] = [];\n const fxs: number[] = [];\n const fys: number[] = [];\n\n if (!self.getMass) {\n self.getMass = d => {\n return self.degrees[self.nodeIdxMap[d.id]] || 1;\n };\n }\n const gravity = self.gravity;\n const center = self.center;\n nodes.forEach((node, i) => {\n masses.push((self.getMass as (d?: any) => number)(node));\n nodeStrengths.push((self.nodeStrength as Function)(node));\n if (!self.degrees[i]) self.degrees[i] = 0;\n let nodeGravity = [center[0], center[1], gravity];\n if (self.getCenter) {\n const customCenter = self.getCenter(node, self.degrees[i]);\n if (\n customCenter &&\n isNumber(customCenter[0]) &&\n isNumber(customCenter[1]) &&\n isNumber(customCenter[2])\n ) {\n nodeGravity = customCenter;\n }\n }\n centerXs.push(nodeGravity[0]);\n centerYs.push(nodeGravity[1]);\n centerGravities.push(nodeGravity[2]);\n if (isNumber(node.fx) && isNumber(node.fy)) {\n fxs.push(node.fx || 0.001);\n fys.push(node.fy || 0.001);\n } else {\n fxs.push(0);\n fys.push(0);\n }\n });\n\n // 每个节点的额外属性占两个数组各一格,nodeAttributeArray1 中是:mass, degree, nodeSterngth, 0\n const nodeAttributeArray1 = arrayToTextureData([\n masses,\n self.degrees,\n nodeStrengths,\n fxs\n ]);\n // nodeAttributeArray2 中是:centerX, centerY, gravity, 0,\n const nodeAttributeArray2 = arrayToTextureData([\n centerXs,\n centerYs,\n centerGravities,\n fys\n ]);\n\n const workerEnabled = self.workerEnabled;\n let world;\n\n if (workerEnabled) {\n world = World.create({\n canvas,\n engineOptions: {\n supportCompute: true\n }\n });\n } else {\n world = World.create({\n engineOptions: {\n supportCompute: true\n }\n });\n }\n\n // TODO: 最终的预编译代码放入到 gForceShader.ts 中直接引入,不再需要下面三行\n // const compiler = new Compiler();\n // const gForceBundle = compiler.compileBundle(gForceCode);\n // console.log(gForceBundle.toString());\n\n const onLayoutEnd = self.onLayoutEnd;\n\n const initPreviousData = [];\n nodesEdgesArray.forEach(value => {\n initPreviousData.push(value);\n });\n for (let i = 0; i < 4; i++) {\n initPreviousData.push(0);\n }\n\n const kernelGForce = world\n .createKernel(gForceBundle)\n .setDispatch([numParticles, 1, 1])\n .setBinding({\n u_Data: nodesEdgesArray, // 节点边输入输出\n u_damping: self.damping,\n u_maxSpeed: self.maxSpeed,\n u_minMovement: self.minMovement,\n u_coulombDisScale: self.coulombDisScale,\n u_factor: self.factor,\n u_NodeAttributeArray1: nodeAttributeArray1,\n u_NodeAttributeArray2: nodeAttributeArray2,\n MAX_EDGE_PER_VERTEX: maxEdgePerVetex,\n VERTEX_COUNT: numParticles,\n u_AveMovement: initPreviousData,\n u_interval: self.interval // 每次迭代更新,首次设置为 interval,在 onIterationCompleted 中更新\n });\n\n // const aveMovementBundle = compiler.compileBundle(aveMovementCode);\n // console.log(aveMovementBundle.toString());\n\n const kernelAveMovement = world\n .createKernel(aveMovementBundle)\n .setDispatch([1, 1, 1])\n .setBinding({\n u_Data: nodesEdgesArray,\n VERTEX_COUNT: numParticles,\n u_AveMovement: [0, 0, 0, 0]\n });\n\n // 执行迭代\n // let midRes = nodesEdgesArray;\n const execute = async () => {\n for (let i = 0; i < maxIteration; i++) {\n // TODO: 似乎都来自 kernelGForce 是一个引用\n // 当前坐标作为下一次迭代的 PreviousData\n // if (i > 0) {\n // kernelAveMovement.setBinding({\n // u_PreviousData: kernelGForce\n // });\n // }\n\n // eslint-disable-next-line no-await-in-loop\n await kernelGForce.execute();\n\n // midRes = await kernelGForce.getOutput();\n\n // 每次迭代完成后\n // 计算平均位移,用于提前终止迭代\n kernelAveMovement.setBinding({\n u_Data: kernelGForce\n });\n\n // eslint-disable-next-line no-await-in-loop\n await kernelAveMovement.execute();\n\n // 更新衰减函数\n const stepInterval = Math.max(0.02, self.interval - i * 0.002);\n kernelGForce.setBinding({\n u_interval: stepInterval,\n u_AveMovement: kernelAveMovement\n });\n }\n const finalParticleData = await kernelGForce.getOutput();\n\n // 所有迭代完成后\n if (canvas) {\n // 传递数据给主线程\n ctx.postMessage({\n type: LAYOUT_MESSAGE.GPUEND,\n vertexEdgeData: finalParticleData\n // edgeIndexBufferData,\n });\n } else {\n nodes.forEach((node, i) => {\n const x = finalParticleData[4 * i];\n const y = finalParticleData[4 * i + 1];\n node.x = x;\n node.y = y;\n });\n }\n\n if (onLayoutEnd) onLayoutEnd();\n };\n\n await execute();\n }\n\n public getType() {\n return \"gForce-gpu\";\n }\n}\n","export const gForceCode = `\nimport { globalInvocationID } from 'g-webgpu';\n\nconst MAX_EDGE_PER_VERTEX;\nconst VERTEX_COUNT;\nconst SHIFT_20 = 1048576;\n\n@numthreads(1, 1, 1)\nclass GGForce {\n @in @out\n u_Data: vec4[];\n\n @in\n u_damping: float;\n \n @in\n u_maxSpeed: float;\n\n @in\n u_minMovement: float;\n\n @in\n u_AveMovement: vec4[];\n\n @in\n u_coulombDisScale: float;\n\n @in\n u_factor: float;\n\n @in\n u_NodeAttributeArray1: vec4[];\n\n @in\n u_NodeAttributeArray2: vec4[];\n\n @in\n u_interval: float;\n\n unpack_float(packedValue: float): ivec2 {\n const packedIntValue = int(packedValue);\n const v0 = packedIntValue / SHIFT_20;\n return [v0, packedIntValue - v0 * SHIFT_20];\n }\n\n calcRepulsive(i: int, currentNode: vec4): vec2 {\n let ax = 0, ay = 0;\n for (let j: int = 0; j < VERTEX_COUNT; j++) {\n if (i != j) {\n const nextNode = this.u_Data[j];\n const vx = currentNode[0] - nextNode[0];\n const vy = currentNode[1] - nextNode[1];\n const dist = sqrt(vx * vx + vy * vy) + 0.01;\n const n_dist = (dist + 0.1) * this.u_coulombDisScale;\n const direx = vx / dist;\n const direy = vy / dist;\n const attributesi = this.u_NodeAttributeArray1[i];\n const attributesj = this.u_NodeAttributeArray1[j];\n const massi = attributesi[0];\n const nodeStrengthi = attributesi[2];\n const nodeStrengthj = attributesj[2];\n const nodeStrength = (nodeStrengthi + nodeStrengthj) / 2;\n // const param = nodeStrength * this.u_factor / (n_dist * n_dist * massi);\n const param = nodeStrength * this.u_factor / (n_dist * n_dist);\n ax += direx * param;\n ay += direy * param;\n }\n }\n return [ax, ay];\n }\n\n calcGravity(i: int, currentNode: vec4, attributes2: vec4): vec2 {\n // note: attributes2 = [centerX, centerY, gravity, 0]\n\n const vx = currentNode[0] - attributes2[0];\n const vy = currentNode[1] - attributes2[1];\n \n const ax = vx * attributes2[2];\n const ay = vy * attributes2[2];\n \n return [ax, ay];\n }\n\n calcAttractive(i: int, currentNode: vec4, attributes1: vec4): vec2 {\n // note: attributes1 = [mass, degree, nodeSterngth, 0]\n\n const mass = attributes1[0];\n let ax = 0, ay = 0;\n // const arr_offset = int(floor(currentNode[2] + 0.5));\n // const length = int(floor(currentNode[3] + 0.5));\n\n const compressed = this.unpack_float(currentNode[2]);\n const length = compressed[0];\n const arr_offset = compressed[1];\n\n const node_buffer: vec4;\n for (let p: int = 0; p < MAX_EDGE_PER_VERTEX; p++) {\n if (p >= length) break;\n const arr_idx = arr_offset + 4 * p; // i 节点的第 p 条边开始的小格子位置\n const buf_offset = arr_idx - arr_idx / 4 * 4;\n if (p == 0 || buf_offset == 0) {\n node_buffer = this.u_Data[int(arr_idx / 4)]; // 大格子,大格子位置=小个子位置 / 4,\n }\n\n let float_j: float = node_buffer[0];\n\n const nextNode = this.u_Data[int(float_j)];\n const vx = nextNode[0] - currentNode[0];\n const vy = nextNode[1] - currentNode[1];\n const dist = sqrt(vx * vx + vy * vy) + 0.01;\n const direx = vx / dist;\n const direy = vy / dist;\n const edgeLength = node_buffer[1];\n const edgeStrength = node_buffer[2];\n const diff: float = edgeLength - dist;//edgeLength\n // const param = diff * this.u_stiffness / mass; //\n const param = diff * edgeStrength / mass; // \n ax -= direx * param;\n ay -= direy * param;\n }\n return [ax, ay];\n }\n\n @main\n compute() {\n const i = globalInvocationID.x;\n const currentNode = this.u_Data[i];\n const movement = u_AveMovement[0];\n let ax = 0, ay = 0;\n\n if (i >= VERTEX_COUNT || movement.x < u_minMovement) {\n this.u_Data[i] = currentNode;\n return;\n }\n\n // 每个节点属性占两个数组中各一格\n // [mass, degree, nodeStrength, fx]\n const nodeAttributes1 = this.u_NodeAttributeArray1[i];\n // [centerX, centerY, centerGravity, fy]\n const nodeAttributes2 = this.u_NodeAttributeArray2[i];\n\n // repulsive\n const repulsive = this.calcRepulsive(i, currentNode);\n ax += repulsive[0];\n ay += repulsive[1];\n\n // attractive\n const attractive = this.calcAttractive(i, currentNode, nodeAttributes1);\n ax += attractive[0];\n ay += attractive[1];\n\n // gravity\n const gravity = this.calcGravity(i, currentNode, nodeAttributes2);\n ax -= gravity[0];\n ay -= gravity[1];\n\n // speed\n const param = this.u_interval * this.u_damping;\n let vx = ax * param;\n let vy = ay * param;\n const vlength = sqrt(vx * vx + vy * vy) + 0.0001;\n if (vlength > this.u_maxSpeed) {\n const param2 = this.u_maxSpeed / vlength;\n vx = param2 * vx;\n vy = param2 * vy;\n }\n\n // move\n if (nodeAttributes1[3] != 0 && nodeAttributes2[3] != 0) {\n this.u_Data[i] = [\n nodeAttributes1[3],\n nodeAttributes2[3],\n currentNode[2],\n 0\n ];\n } else {\n const distx = vx * this.u_interval;\n const disty = vy * this.u_interval;\n const distLength = sqrt(distx * distx + disty * disty);\n this.u_Data[i] = [\n currentNode[0] + distx,\n currentNode[1] + disty,\n currentNode[2],\n distLength\n ];\n }\n \n // the avarage move distance\n // need to share memory\n \n }\n}\n`\n\nexport const gForceBundle = `{\"shaders\":{\"WGSL\":\"import \\\\\"GLSL.std.450\\\\\" as std;\\\\n\\\\n\\\\n# var gWebGPUDebug : bool = false;\\\\n# var gWebGPUDebugOutput : vec4<f32> = vec4<f32>(0.0);\\\\n\\\\n[[builtin global_invocation_id]] var<in> globalInvocationID : vec3<u32>;\\\\n# [[builtin work_group_size]] var<in> workGroupSize : vec3<u32>;\\\\n# [[builtin work_group_id]] var<in> workGroupID : vec3<u32>;\\\\n[[builtin local_invocation_id]] var<in> localInvocationID : vec3<u32>;\\\\n# [[builtin num_work_groups]] var<in> numWorkGroups : vec3<u32>;\\\\n[[builtin local_invocation_idx]] var<in> localInvocationIndex : u32;\\\\n\\\\ntype GWebGPUParams = [[block]] struct {\\\\n [[offset 0]] u_damping : f32;\\\\n [[offset 4]] u_maxSpeed : f32;\\\\n [[offset 8]] u_minMovement : f32;\\\\n \\\\n [[offset 12]] u_coulombDisScale : f32;\\\\n [[offset 16]] u_factor : f32;\\\\n \\\\n \\\\n [[offset 20]] u_interval : f32;\\\\n};\\\\n[[binding 0, set 0]] var<uniform> gWebGPUUniformParams : GWebGPUParams;\\\\ntype GWebGPUBuffer0 = [[block]] struct {\\\\n [[offset 0]] u_Data : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 1, set 0]] var<storage_buffer> gWebGPUBuffer0 : GWebGPUBuffer0;\\\\ntype GWebGPUBuffer1 = [[block]] struct {\\\\n [[offset 0]] u_AveMovement : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 2, set 0]] var<storage_buffer> gWebGPUBuffer1 : GWebGPUBuffer1;\\\\ntype GWebGPUBuffer2 = [[block]] struct {\\\\n [[offset 0]] u_NodeAttributeArray1 : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 3, set 0]] var<storage_buffer> gWebGPUBuffer2 : GWebGPUBuffer2;\\\\ntype GWebGPUBuffer3 = [[block]] struct {\\\\n [[offset 0]] u_NodeAttributeArray2 : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 4, set 0]] var<storage_buffer> gWebGPUBuffer3 : GWebGPUBuffer3;\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\nfn unpack_float(packedValue : f32) -> vec2<i32> {var packedIntValue : i32 = i32(packedValue);\\\\nvar v0 : i32 = packedIntValue / 1048576;\\\\nreturn vec2<i32>(v0, packedIntValue - (v0 * 1048576));}\\\\nfn calcRepulsive(i : i32, currentNode : vec4<f32>) -> vec2<f32> {var ax : f32 = 0.0;\\\\nvar ay : f32 = 0.0;\\\\nfor (var j : i32 = 0; j < __DefineValuePlaceholder__VERTEX_COUNT; j = j + 1) {if (i != j) {var nextNode : vec4<f32> = gWebGPUBuffer0.u_Data[j];\\\\nvar vx : f32 = currentNode.x - nextNode.x;\\\\nvar vy : f32 = currentNode.y - nextNode.y;\\\\nvar dist : f32 = std::sqrt((vx * vx) + (vy * vy)) + 0.01;\\\\nvar n_dist : f32 = (dist + 0.1) * gWebGPUUniformParams.u_coulombDisScale;\\\\nvar direx : f32 = vx / dist;\\\\nvar direy : f32 = vy / dist;\\\\nvar attributesi : vec4<f32> = gWebGPUBuffer2.u_NodeAttributeArray1[i];\\\\nvar attributesj : vec4<f32> = gWebGPUBuffer2.u_NodeAttributeArray1[j];\\\\nvar massi : f32 = attributesi.x;\\\\nvar nodeStrengthi : f32 = attributesi.z;\\\\nvar nodeStrengthj : f32 = attributesj.z;\\\\nvar nodeStrength : f32 = (nodeStrengthi + nodeStrengthj) / 2.0;\\\\nvar param : f32 = (nodeStrength * gWebGPUUniformParams.u_factor) / (n_dist * n_dist);\\\\nax = ax + direx * param;\\\\nay = ay + direy * param;}}\\\\nreturn vec2<f32>(ax, ay);}\\\\nfn calcGravity(i : i32, currentNode : vec4<f32>, attributes2 : vec4<f32>) -> vec2<f32> {var vx : f32 = currentNode.x - attributes2.x;\\\\nvar vy : f32 = currentNode.y - attributes2.y;\\\\nvar ax : f32 = vx * attributes2.z;\\\\nvar ay : f32 = vy * attributes2.z;\\\\nreturn vec2<f32>(ax, ay);}\\\\nfn calcAttractive(i : i32, currentNode : vec4<f32>, attributes1 : vec4<f32>) -> vec2<f32> {var mass : f32 = attributes1.x;\\\\nvar ax : f32 = 0.0;\\\\nvar ay : f32 = 0.0;\\\\nvar compressed : vec2<i32> = unpack_float(currentNode.z);\\\\nvar length : i32 = compressed.x;\\\\nvar arr_offset : i32 = compressed.y;\\\\nvar node_buffer : vec4<f32>;\\\\nfor (var p : i32 = 0; p < __DefineValuePlaceholder__MAX_EDGE_PER_VERTEX; p = p + 1) {if (p >= length) {break;}\\\\nvar arr_idx : i32 = arr_offset + (4 * p);\\\\nvar buf_offset : i32 = arr_idx - ((arr_idx / 4) * 4);\\\\nif ((p == 0) || (buf_offset == 0)) {node_buffer = gWebGPUBuffer0.u_Data[i32(arr_idx / 4)];}\\\\nvar float_j : f32 = node_buffer.x;\\\\nvar nextNode : vec4<f32> = gWebGPUBuffer0.u_Data[i32(float_j)];\\\\nvar vx : f32 = nextNode.x - currentNode.x;\\\\nvar vy : f32 = nextNode.y - currentNode.y;\\\\nvar dist : f32 = std::sqrt((vx * vx) + (vy * vy)) + 0.01;\\\\nvar direx : f32 = vx / dist;\\\\nvar direy : f32 = vy / dist;\\\\nvar edgeLength : f32 = node_buffer.y;\\\\nvar edgeStrength : f32 = node_buffer.z;\\\\nvar diff : f32 = edgeLength - dist;\\\\nvar param : f32 = (diff * edgeStrength) / mass;\\\\nax = ax - direx * param;\\\\nay = ay - direy * param;}\\\\nreturn vec2<f32>(ax, ay);}\\\\nfn main() -> void {var i : i32 = globalInvocationID.x;\\\\nvar currentNode : vec4<f32> = gWebGPUBuffer0.u_Data[i];\\\\nvar movement : vec4<f32> = gWebGPUBuffer1.u_AveMovement[0];\\\\nvar ax : f32 = 0.0;\\\\nvar ay : f32 = 0.0;\\\\nif ((i >= __DefineValuePlaceholder__VERTEX_COUNT) || (movement.x < gWebGPUUniformParams.u_minMovement)) {gWebGPUBuffer0.u_Data[i] = currentNode;\\\\nreturn ;}\\\\nvar nodeAttributes1 : vec4<f32> = gWebGPUBuffer2.u_NodeAttributeArray1[i];\\\\nvar nodeAttributes2 : vec4<f32> = gWebGPUBuffer3.u_NodeAttributeArray2[i];\\\\nvar repulsive : vec2<f32> = calcRepulsive(i, currentNode);\\\\nax = ax + repulsive.x;\\\\nay = ay + repulsive.y;\\\\nvar attractive : vec2<f32> = calcAttractive(i, currentNode, nodeAttributes1);\\\\nax = ax + attractive.x;\\\\nay = ay + attractive.y;\\\\nvar gravity : vec2<f32> = calcGravity(i, currentNode, nodeAttributes2);\\\\nax = ax - gravity.x;\\\\nay = ay - gravity.y;\\\\nvar param : f32 = gWebGPUUniformParams.u_interval * gWebGPUUniformParams.u_damping;\\\\nvar vx : f32 = ax * param;\\\\nvar vy : f32 = ay * param;\\\\nvar vlength : f32 = std::sqrt((vx * vx) + (vy * vy)) + 0.0001;\\\\nif (vlength > gWebGPUUniformParams.u_maxSpeed) {var param2 : f32 = gWebGPUUniformParams.u_maxSpeed / vlength;\\\\nvx = param2 * vx;\\\\nvy = param2 * vy;}\\\\nvar distx : f32 = vx * gWebGPUUniformParams.u_interval;\\\\nvar disty : f32 = vy * gWebGPUUniformParams.u_interval;\\\\nvar distLength : f32 = std::sqrt((distx * distx) + (disty * disty));\\\\nif ((nodeAttributes1.w != 0.0) && (nodeAttributes2.w != 0.0)) {gWebGPUBuffer0.u_Data[i] = vec4<f32>(nodeAttributes1.w, nodeAttributes2.w, currentNode.z, 0.0);}else {gWebGPUBuffer0.u_Data[i] = vec4<f32>(currentNode.x + distx, currentNode.y + disty, currentNode.z, distLength);}\\\\nreturn;}\\\\n\\\\nentry_point compute as \\\\\"main\\\\\" = main;\\\\n\",\"GLSL450\":\"\\\\n\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\nivec3 globalInvocationID = ivec3(gl_GlobalInvocationID);\\\\nivec3 workGroupSize = ivec3(1,1,1);\\\\nivec3 workGroupID = ivec3(gl_WorkGroupID);\\\\nivec3 localInvocationID = ivec3(gl_LocalInvocationID);\\\\nivec3 numWorkGroups = ivec3(gl_NumWorkGroups);\\\\nint localInvocationIndex = int(gl_LocalInvocationIndex);\\\\n\\\\nlayout(std140, set = 0, binding = 0) uniform GWebGPUParams {\\\\n float u_damping;\\\\n float u_maxSpeed;\\\\n float u_minMovement;\\\\n \\\\n float u_coulombDisScale;\\\\n float u_factor;\\\\n \\\\n \\\\n float u_interval;\\\\n} gWebGPUUniformParams;\\\\nlayout(std430, set = 0, binding = 1) buffer GWebGPUBuffer0 {\\\\n vec4 u_Data[];\\\\n} gWebGPUBuffer0;\\\\n\\\\nlayout(std430, set = 0, binding = 2) buffer readonly GWebGPUBuffer1 {\\\\n vec4 u_AveMovement[];\\\\n} gWebGPUBuffer1;\\\\n\\\\nlayout(std430, set = 0, binding = 3) buffer readonly GWebGPUBuffer2 {\\\\n vec4 u_NodeAttributeArray1[];\\\\n} gWebGPUBuffer2;\\\\n\\\\nlayout(std430, set = 0, binding = 4) buffer readonly GWebGPUBuffer3 {\\\\n vec4 u_NodeAttributeArray2[];\\\\n} gWebGPUBuffer3;\\\\n\\\\n\\\\n\\\\n#define MAX_EDGE_PER_VERTEX __DefineValuePlaceholder__MAX_EDGE_PER_VERTEX\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\n#define SHIFT_20 1048576.0\\\\nlayout (\\\\n local_size_x = 1,\\\\n local_size_y = 1,\\\\n local_size_z = 1\\\\n) in;\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\nivec2 unpack_float(float packedValue) {int packedIntValue = int(packedValue);\\\\nint v0 = packedIntValue / int(SHIFT_20);\\\\nreturn ivec2(v0, packedIntValue - (v0 * int(SHIFT_20)));}\\\\nvec2 calcRepulsive(int i, vec4 currentNode) {float ax = 0.0;\\\\nfloat ay = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {if (i != j) {vec4 nextNode = gWebGPUBuffer0.u_Data[j];\\\\nfloat vx = currentNode.x - nextNode.x;\\\\nfloat vy = currentNode.y - nextNode.y;\\\\nfloat dist = sqrt((vx * vx) + (vy * vy)) + 0.01;\\\\nfloat n_dist = (dist + 0.1) * gWebGPUUniformParams.u_coulombDisScale;\\\\nfloat direx = vx / dist;\\\\nfloat direy = vy / dist;\\\\nvec4 attributesi = gWebGPUBuffer2.u_NodeAttributeArray1[i];\\\\nvec4 attributesj = gWebGPUBuffer2.u_NodeAttributeArray1[j];\\\\nfloat massi = attributesi.x;\\\\nfloat nodeStrengthi = attributesi.z;\\\\nfloat nodeStrengthj = attributesj.z;\\\\nfloat nodeStrength = (nodeStrengthi + nodeStrengthj) / 2.0;\\\\nfloat param = (nodeStrength * gWebGPUUniformParams.u_factor) / (n_dist * n_dist);\\\\nax += direx * param;\\\\nay += direy * param;}}\\\\nreturn vec2(ax, ay);}\\\\nvec2 calcGravity(int i, vec4 currentNode, vec4 attributes2) {float vx = currentNode.x - attributes2.x;\\\\nfloat vy = currentNode.y - attributes2.y;\\\\nfloat ax = vx * attributes2.z;\\\\nfloat ay = vy * attributes2.z;\\\\nreturn vec2(ax, ay);}\\\\nvec2 calcAttractive(int i, vec4 currentNode, vec4 attributes1) {float mass = attributes1.x;\\\\nfloat ax = 0.0;\\\\nfloat ay = 0.0;\\\\nivec2 compressed = unpack_float(currentNode.z);\\\\nint length = compressed.x;\\\\nint arr_offset = compressed.y;\\\\nvec4 node_buffer;\\\\nfor (int p = 0; p < MAX_EDGE_PER_VERTEX; p++) {if (p >= length) {break;}\\\\nint arr_idx = arr_offset + (4 * p);\\\\nint buf_offset = arr_idx - ((arr_idx / 4) * 4);\\\\nif ((p == 0) || (buf_offset == 0)) {node_buffer = gWebGPUBuffer0.u_Data[int(arr_idx / 4)];}\\\\nfloat float_j = node_buffer.x;\\\\nvec4 nextNode = gWebGPUBuffer0.u_Data[int(float_j)];\\\\nfloat vx = nextNode.x - currentNode.x;\\\\nfloat vy = nextNode.y - currentNode.y;\\\\nfloat dist = sqrt((vx * vx) + (vy * vy)) + 0.01;\\\\nfloat direx = vx / dist;\\\\nfloat direy = vy / dist;\\\\nfloat edgeLength = node_buffer.y;\\\\nfloat edgeStrength = node_buffer.z;\\\\nfloat diff = edgeLength - dist;\\\\nfloat param = (diff * edgeStrength) / mass;\\\\nax -= direx * param;\\\\nay -= direy * param;}\\\\nreturn vec2(ax, ay);}\\\\nvoid main() {int i = globalInvocationID.x;\\\\nvec4 currentNode = gWebGPUBuffer0.u_Data[i];\\\\nvec4 movement = gWebGPUBuffer1.u_AveMovement[0];\\\\nfloat ax = 0.0;\\\\nfloat ay = 0.0;\\\\nif ((i >= VERTEX_COUNT) || (movement.x < gWebGPUUniformParams.u_minMovement)) {gWebGPUBuffer0.u_Data[i] = currentNode;\\\\nreturn ;}\\\\nvec4 nodeAttributes1 = gWebGPUBuffer2.u_NodeAttributeArray1[i];\\\\nvec4 nodeAttributes2 = gWebGPUBuffer3.u_NodeAttributeArray2[i];\\\\nvec2 repulsive = calcRepulsive(i, currentNode);\\\\nax += repulsive.x;\\\\nay += repulsive.y;\\\\nvec2 attractive = calcAttractive(i, currentNode, nodeAttributes1);\\\\nax += attractive.x;\\\\nay += attractive.y;\\\\nvec2 gravity = calcGravity(i, currentNode, nodeAttributes2);\\\\nax -= gravity.x;\\\\nay -= gravity.y;\\\\nfloat param = gWebGPUUniformParams.u_interval * gWebGPUUniformParams.u_damping;\\\\nfloat vx = ax * param;\\\\nfloat vy = ay * param;\\\\nfloat vlength = sqrt((vx * vx) + (vy * vy)) + 0.0001;\\\\nif (vlength > gWebGPUUniformParams.u_maxSpeed) {float param2 = gWebGPUUniformParams.u_maxSpeed / vlength;\\\\nvx = param2 * vx;\\\\nvy = param2 * vy;}\\\\nfloat distx = vx * gWebGPUUniformParams.u_interval;\\\\nfloat disty = vy * gWebGPUUniformParams.u_interval;\\\\nfloat distLength = sqrt((distx * distx) + (disty * disty));\\\\nif ((nodeAttributes1.w != 0.0) && (nodeAttributes2.w != 0.0)) {gWebGPUBuffer0.u_Data[i] = vec4(nodeAttributes1.w, nodeAttributes2.w, currentNode.z, 0.0);}else {gWebGPUBuffer0.u_Data[i] = vec4(currentNode.x + distx, currentNode.y + disty, currentNode.z, distLength);}}\\\\n\",\"GLSL100\":\"\\\\n\\\\nfloat epsilon = 0.00001;\\\\nvec2 addrTranslation_1Dto2D(float address1D, vec2 texSize) {\\\\n vec2 conv_const = vec2(1.0 / texSize.x, 1.0 / (texSize.x * texSize.y));\\\\n vec2 normAddr2D = float(address1D) * conv_const;\\\\n return vec2(fract(normAddr2D.x + epsilon), normAddr2D.y);\\\\n}\\\\n\\\\nvoid barrier() {}\\\\n \\\\n\\\\nuniform vec2 u_OutputTextureSize;\\\\nuniform int u_OutputTexelCount;\\\\nvarying vec2 v_TexCoord;\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\n#define MAX_EDGE_PER_VERTEX __DefineValuePlaceholder__MAX_EDGE_PER_VERTEX\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\n#define SHIFT_20 1048576.0\\\\n\\\\nuniform sampler2D u_Data;\\\\nuniform vec2 u_DataSize;\\\\nvec4 getDatau_Data(vec2 address2D) {\\\\n return vec4(texture2D(u_Data, address2D).rgba);\\\\n}\\\\nvec4 getDatau_Data(float address1D) {\\\\n return getDatau_Data(addrTranslation_1Dto2D(address1D, u_DataSize));\\\\n}\\\\nvec4 getDatau_Data(int address1D) {\\\\n return getDatau_Data(float(address1D));\\\\n}\\\\nuniform float u_damping;\\\\nuniform float u_maxSpeed;\\\\nuniform float u_minMovement;\\\\nuniform sampler2D u_AveMovement;\\\\nuniform vec2 u_AveMovementSize;\\\\nvec4 getDatau_AveMovement(vec2 address2D) {\\\\n return vec4(texture2D(u_AveMovement, address2D).rgba);\\\\n}\\\\nvec4 getDatau_AveMovement(float address1D) {\\\\n return getDatau_AveMovement(addrTranslation_1Dto2D(address1D, u_AveMovementSize));\\\\n}\\\\nvec4 getDatau_AveMovement(int address1D) {\\\\n return getDatau_AveMovement(float(address1D));\\\\n}\\\\nuniform float u_coulombDisScale;\\\\nuniform float u_factor;\\\\nuniform sampler2D u_NodeAttributeArray1;\\\\nuniform vec2 u_NodeAttributeArray1Size;\\\\nvec4 getDatau_NodeAttributeArray1(vec2 address2D) {\\\\n return vec4(texture2D(u_NodeAttributeArray1, address2D).rgba);\\\\n}\\\\nvec4 getDatau_NodeAttributeArray1(float address1D) {\\\\n return getDatau_NodeAttributeArray1(addrTranslation_1Dto2D(address1D, u_NodeAttributeArray1Size));\\\\n}\\\\nvec4 getDatau_NodeAttributeArray1(int address1D) {\\\\n return getDatau_NodeAttributeArray1(float(address1D));\\\\n}\\\\nuniform sampler2D u_NodeAttributeArray2;\\\\nuniform vec2 u_NodeAttributeArray2Size;\\\\nvec4 getDatau_NodeAttributeArray2(vec2 address2D) {\\\\n return vec4(texture2D(u_NodeAttributeArray2, address2D).rgba);\\\\n}\\\\nvec4 getDatau_NodeAttributeArray2(float address1D) {\\\\n return getDatau_NodeAttributeArray2(addrTranslation_1Dto2D(address1D, u_NodeAttributeArray2Size));\\\\n}\\\\nvec4 getDatau_NodeAttributeArray2(int address1D) {\\\\n return getDatau_NodeAttributeArray2(float(address1D));\\\\n}\\\\nuniform float u_interval;\\\\nivec2 unpack_float(float packedValue) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nint packedIntValue = int(packedValue);\\\\nint v0 = packedIntValue / int(SHIFT_20);\\\\nreturn ivec2(v0, packedIntValue - (v0 * int(SHIFT_20)));}\\\\nvec2 calcRepulsive(int i, vec4 currentNode) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat ax = 0.0;\\\\nfloat ay = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {if (i != j) {vec4 nextNode = getDatau_Data(j);\\\\nfloat vx = currentNode.x - nextNode.x;\\\\nfloat vy = currentNode.y - nextNode.y;\\\\nfloat dist = sqrt((vx * vx) + (vy * vy)) + 0.01;\\\\nfloat n_dist = (dist + 0.1) * u_coulombDisScale;\\\\nfloat direx = vx / dist;\\\\nfloat direy = vy / dist;\\\\nvec4 attributesi = getDatau_NodeAttributeArray1(i);\\\\nvec4 attributesj = getDatau_NodeAttributeArray1(j);\\\\nfloat massi = attributesi.x;\\\\nfloat nodeStrengthi = attributesi.z;\\\\nfloat nodeStrengthj = attributesj.z;\\\\nfloat nodeStrength = (nodeStrengthi + nodeStrengthj) / 2.0;\\\\nfloat param = (nodeStrength * u_factor) / (n_dist * n_dist);\\\\nax += direx * param;\\\\nay += direy * param;}}\\\\nreturn vec2(ax, ay);}\\\\nvec2 calcGravity(int i, vec4 currentNode, vec4 attributes2) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat vx = currentNode.x - attributes2.x;\\\\nfloat vy = currentNode.y - attributes2.y;\\\\nfloat ax = vx * attributes2.z;\\\\nfloat ay = vy * attributes2.z;\\\\nreturn vec2(ax, ay);}\\\\nvec2 calcAttractive(int i, vec4 currentNode, vec4 attributes1) {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat mass = attributes1.x;\\\\nfloat ax = 0.0;\\\\nfloat ay = 0.0;\\\\nivec2 compressed = unpack_float(currentNode.z);\\\\nint length = compressed.x;\\\\nint arr_offset = compressed.y;\\\\nvec4 node_buffer;\\\\nfor (int p = 0; p < MAX_EDGE_PER_VERTEX; p++) {if (p >= length) {break;}\\\\nint arr_idx = arr_offset + (4 * p);\\\\nint buf_offset = arr_idx - ((arr_idx / 4) * 4);\\\\nif ((p == 0) || (buf_offset == 0)) {node_buffer = getDatau_Data(int(arr_idx / 4));}\\\\nfloat float_j = node_buffer.x;\\\\nvec4 nextNode = getDatau_Data(int(float_j));\\\\nfloat vx = nextNode.x - currentNode.x;\\\\nfloat vy = nextNode.y - currentNode.y;\\\\nfloat dist = sqrt((vx * vx) + (vy * vy)) + 0.01;\\\\nfloat direx = vx / dist;\\\\nfloat direy = vy / dist;\\\\nfloat edgeLength = node_buffer.y;\\\\nfloat edgeStrength = node_buffer.z;\\\\nfloat diff = edgeLength - dist;\\\\nfloat param = (diff * edgeStrength) / mass;\\\\nax -= direx * param;\\\\nay -= direy * param;}\\\\nreturn vec2(ax, ay);}\\\\nvoid main() {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nint i = globalInvocationID.x;\\\\nvec4 currentNode = getDatau_Data(i);\\\\nvec4 movement = getDatau_AveMovement(0.0);\\\\nfloat ax = 0.0;\\\\nfloat ay = 0.0;\\\\nif ((i >= VERTEX_COUNT) || (movement.x < u_minMovement)) {gl_FragColor = vec4(currentNode);\\\\nreturn ;}\\\\nvec4 nodeAttributes1 = getDatau_NodeAttributeArray1(i);\\\\nvec4 nodeAttributes2 = getDatau_NodeAttributeArray2(i);\\\\nvec2 repulsive = calcRepulsive(i, currentNode);\\\\nax += repulsive.x;\\\\nay += repulsive.y;\\\\nvec2 attractive = calcAttractive(i, currentNode, nodeAttributes1);\\\\nax += attractive.x;\\\\nay += attractive.y;\\\\nvec2 gravity = calcGravity(i, currentNode, nodeAttributes2);\\\\nax -= gravity.x;\\\\nay -= gravity.y;\\\\nfloat param = u_interval * u_damping;\\\\nfloat vx = ax * param;\\\\nfloat vy = ay * param;\\\\nfloat vlength = sqrt((vx * vx) + (vy * vy)) + 0.0001;\\\\nif (vlength > u_maxSpeed) {float param2 = u_maxSpeed / vlength;\\\\nvx = param2 * vx;\\\\nvy = param2 * vy;}\\\\nfloat distx = vx * u_interval;\\\\nfloat disty = vy * u_interval;\\\\nfloat distLength = sqrt((distx * distx) + (disty * disty));\\\\nif ((nodeAttributes1.w != 0.0) && (nodeAttributes2.w != 0.0)) {gl_FragColor = vec4(vec4(nodeAttributes1.w, nodeAttributes2.w, currentNode.z, 0.0));}else {gl_FragColor = vec4(vec4(currentNode.x + distx, currentNode.y + disty, currentNode.z, distLength));}if (gWebGPUDebug) {\\\\n gl_FragColor = gWebGPUDebugOutput;\\\\n}}\\\\n\"},\"context\":{\"name\":\"\",\"dispatch\":[1,1,1],\"threadGroupSize\":[1,1,1],\"maxIteration\":1,\"defines\":[{\"name\":\"MAX_EDGE_PER_VERTEX\",\"type\":\"Float\",\"runtime\":true},{\"name\":\"VERTEX_COUNT\",\"type\":\"Float\",\"runtime\":true},{\"name\":\"SHIFT_20\",\"type\":\"Float\",\"value\":1048576,\"runtime\":false}],\"uniforms\":[{\"name\":\"u_Data\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":false,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_damping\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_maxSpeed\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_minMovement\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_AveMovement\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_coulombDisScale\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_factor\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_NodeAttributeArray1\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_NodeAttributeArray2\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_interval\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]}],\"globalDeclarations\":[],\"output\":{\"name\":\"u_Data\",\"size\":[1,1],\"length\":1},\"needPingpong\":true}}`\n\n\nexport const aveMovementCode = `\nconst VERTEX_COUNT;\n@numthreads(1, 1, 1)\nclass CalcAveMovement {\n @in\n u_Data: vec4[];\n @in\n u_iter: float;\n @in @out\n u_AveMovement: vec4[];\n @main\n compute() {\n let movement = 0;\n for (let j: int = 0; j < VERTEX_COUNT; j++) {\n const vertex = this.u_Data[j];\n movement += vertex[3];\n }\n movement = movement / float(VERTEX_COUNT);\n this.u_AveMovement[0] = [movement, 0, 0, 0];\n }\n}\n`\n\nexport const aveMovementBundle = `{\"shaders\":{\"WGSL\":\"import \\\\\"GLSL.std.450\\\\\" as std;\\\\n\\\\n\\\\n# var gWebGPUDebug : bool = false;\\\\n# var gWebGPUDebugOutput : vec4<f32> = vec4<f32>(0.0);\\\\n\\\\n[[builtin global_invocation_id]] var<in> globalInvocationID : vec3<u32>;\\\\n# [[builtin work_group_size]] var<in> workGroupSize : vec3<u32>;\\\\n# [[builtin work_group_id]] var<in> workGroupID : vec3<u32>;\\\\n[[builtin local_invocation_id]] var<in> localInvocationID : vec3<u32>;\\\\n# [[builtin num_work_groups]] var<in> numWorkGroups : vec3<u32>;\\\\n[[builtin local_invocation_idx]] var<in> localInvocationIndex : u32;\\\\n\\\\ntype GWebGPUParams = [[block]] struct {\\\\n [[offset 0]] u_iter : f32;\\\\n};\\\\n[[binding 0, set 0]] var<uniform> gWebGPUUniformParams : GWebGPUParams;\\\\ntype GWebGPUBuffer0 = [[block]] struct {\\\\n [[offset 0]] u_Data : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 1, set 0]] var<storage_buffer> gWebGPUBuffer0 : GWebGPUBuffer0;\\\\ntype GWebGPUBuffer1 = [[block]] struct {\\\\n [[offset 0]] u_AveMovement : [[stride 16]] array<vec4<f32>>;\\\\n};\\\\n[[binding 2, set 0]] var<storage_buffer> gWebGPUBuffer1 : GWebGPUBuffer1;\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\n\\\\nfn main() -> void {var movement : f32 = 0.0;\\\\nfor (var j : i32 = 0; j < __DefineValuePlaceholder__VERTEX_COUNT; j = j + 1) {var vertex : vec4<f32> = gWebGPUBuffer0.u_Data[j];\\\\nmovement = movement + vertex.w;}\\\\nmovement = movement / f32(__DefineValuePlaceholder__VERTEX_COUNT);\\\\ngWebGPUBuffer1.u_AveMovement[0] = vec4<f32>(movement, 0.0, 0.0, 0.0);\\\\nreturn;}\\\\n\\\\nentry_point compute as \\\\\"main\\\\\" = main;\\\\n\",\"GLSL450\":\"\\\\n\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\nivec3 globalInvocationID = ivec3(gl_GlobalInvocationID);\\\\nivec3 workGroupSize = ivec3(1,1,1);\\\\nivec3 workGroupID = ivec3(gl_WorkGroupID);\\\\nivec3 localInvocationID = ivec3(gl_LocalInvocationID);\\\\nivec3 numWorkGroups = ivec3(gl_NumWorkGroups);\\\\nint localInvocationIndex = int(gl_LocalInvocationIndex);\\\\n\\\\nlayout(std140, set = 0, binding = 0) uniform GWebGPUParams {\\\\n float u_iter;\\\\n} gWebGPUUniformParams;\\\\nlayout(std430, set = 0, binding = 1) buffer readonly GWebGPUBuffer0 {\\\\n vec4 u_Data[];\\\\n} gWebGPUBuffer0;\\\\n\\\\nlayout(std430, set = 0, binding = 2) buffer GWebGPUBuffer1 {\\\\n vec4 u_AveMovement[];\\\\n} gWebGPUBuffer1;\\\\n\\\\n\\\\n\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\nlayout (\\\\n local_size_x = 1,\\\\n local_size_y = 1,\\\\n local_size_z = 1\\\\n) in;\\\\n\\\\n\\\\n\\\\nvoid main() {float movement = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {vec4 vertex = gWebGPUBuffer0.u_Data[j];\\\\nmovement += vertex.w;}\\\\nmovement = movement / float(VERTEX_COUNT);\\\\ngWebGPUBuffer1.u_AveMovement[0] = vec4(movement, 0.0, 0.0, 0.0);}\\\\n\",\"GLSL100\":\"\\\\n\\\\nfloat epsilon = 0.00001;\\\\nvec2 addrTranslation_1Dto2D(float address1D, vec2 texSize) {\\\\n vec2 conv_const = vec2(1.0 / texSize.x, 1.0 / (texSize.x * texSize.y));\\\\n vec2 normAddr2D = float(address1D) * conv_const;\\\\n return vec2(fract(normAddr2D.x + epsilon), normAddr2D.y);\\\\n}\\\\n\\\\nvoid barrier() {}\\\\n \\\\n\\\\nuniform vec2 u_OutputTextureSize;\\\\nuniform int u_OutputTexelCount;\\\\nvarying vec2 v_TexCoord;\\\\n\\\\nbool gWebGPUDebug = false;\\\\nvec4 gWebGPUDebugOutput = vec4(0.0);\\\\n\\\\n#define VERTEX_COUNT __DefineValuePlaceholder__VERTEX_COUNT\\\\n\\\\nuniform sampler2D u_Data;\\\\nuniform vec2 u_DataSize;\\\\nvec4 getDatau_Data(vec2 address2D) {\\\\n return vec4(texture2D(u_Data, address2D).rgba);\\\\n}\\\\nvec4 getDatau_Data(float address1D) {\\\\n return getDatau_Data(addrTranslation_1Dto2D(address1D, u_DataSize));\\\\n}\\\\nvec4 getDatau_Data(int address1D) {\\\\n return getDatau_Data(float(address1D));\\\\n}\\\\nuniform float u_iter;\\\\nuniform sampler2D u_AveMovement;\\\\nuniform vec2 u_AveMovementSize;\\\\nvec4 getDatau_AveMovement(vec2 address2D) {\\\\n return vec4(texture2D(u_AveMovement, address2D).rgba);\\\\n}\\\\nvec4 getDatau_AveMovement(float address1D) {\\\\n return getDatau_AveMovement(addrTranslation_1Dto2D(address1D, u_AveMovementSize));\\\\n}\\\\nvec4 getDatau_AveMovement(int address1D) {\\\\n return getDatau_AveMovement(float(address1D));\\\\n}\\\\nvoid main() {\\\\nivec3 workGroupSize = ivec3(1, 1, 1);\\\\nivec3 numWorkGroups = ivec3(1, 1, 1); \\\\nint globalInvocationIndex = int(floor(v_TexCoord.x * u_OutputTextureSize.x))\\\\n + int(floor(v_TexCoord.y * u_OutputTextureSize.y)) * int(u_OutputTextureSize.x);\\\\nint workGroupIDLength = globalInvocationIndex / (workGroupSize.x * workGroupSize.y * workGroupSize.z);\\\\nivec3 workGroupID = ivec3(workGroupIDLength / numWorkGroups.y / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.z, workGroupIDLength / numWorkGroups.x / numWorkGroups.y);\\\\nint localInvocationIDZ = globalInvocationIndex / (workGroupSize.x * workGroupSize.y);\\\\nint localInvocationIDY = (globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y) / workGroupSize.x;\\\\nint localInvocationIDX = globalInvocationIndex - localInvocationIDZ * workGroupSize.x * workGroupSize.y - localInvocationIDY * workGroupSize.x;\\\\nivec3 localInvocationID = ivec3(localInvocationIDX, localInvocationIDY, localInvocationIDZ);\\\\nivec3 globalInvocationID = workGroupID * workGroupSize + localInvocationID;\\\\nint localInvocationIndex = localInvocationID.z * workGroupSize.x * workGroupSize.y\\\\n + localInvocationID.y * workGroupSize.x + localInvocationID.x;\\\\nfloat movement = 0.0;\\\\nfor (int j = 0; j < VERTEX_COUNT; j++) {vec4 vertex = getDatau_Data(j);\\\\nmovement += vertex.w;}\\\\nmovement = movement / float(VERTEX_COUNT);\\\\ngl_FragColor = vec4(vec4(movement, 0.0, 0.0, 0.0));if (gWebGPUDebug) {\\\\n gl_FragColor = gWebGPUDebugOutput;\\\\n}}\\\\n\"},\"context\":{\"name\":\"\",\"dispatch\":[1,1,1],\"threadGroupSize\":[1,1,1],\"maxIteration\":1,\"defines\":[{\"name\":\"VERTEX_COUNT\",\"type\":\"Float\",\"runtime\":true}],\"uniforms\":[{\"name\":\"u_Data\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_iter\",\"type\":\"Float\",\"storageClass\":\"Uniform\",\"readonly\":true,\"writeonly\":false,\"size\":[1,1]},{\"name\":\"u_AveMovement\",\"type\":\"vec4<f32>[]\",\"storageClass\":\"StorageBuffer\",\"readonly\":false,\"writeonly\":false,\"size\":[1,1]}],\"globalDeclarations\":[],\"output\":{\"name\":\"u_AveMovement\",\"size\":[1,1],\"length\":1},\"needPingpong\":true}}`","/**\n * @fileOverview Combo force layout\n * @author shiwu.wyy@antfin.com\n */\n\nimport {\n Edge,\n OutNode,\n PointTuple,\n IndexMap,\n ComboConfig,\n ComboTree,\n Point,\n ComboForceLayoutOptions\n} from \"./types\";\nimport { Base } from \"./base\";\nimport { isArray, isNumber, isFunction, traverseTreeUp } from \"../util\";\n\ntype Combo = ComboConfig & {\n x?: number;\n y?: number;\n name?: string | number;\n cx: number;\n cy: number;\n count?: number;\n depth?: number;\n children?: any[];\n empty?: boolean;\n minX?: number;\n maxX?: number;\n minY?: number;\n maxY?: number;\n size?: number;\n r?: number;\n itemType?: string;\n};\n\ntype Node = OutNode & {\n depth: number;\n itemType?: string;\n comboId?: string;\n};\n\ntype NodeMap = {\n [key: string]: Node;\n};\n\ntype ComboMap = {\n [key: string]: Combo;\n};\n\n/**\n * force layout for graph with combos\n */\nexport class ComboForceLayout extends Base {\n /** 布局中心 */\n public center: PointTuple = [0, 0];\n\n /** 停止迭代的最大迭代数 */\n public maxIteration: number = 100;\n\n /** 重力大小,影响图的紧凑程度 */\n public gravity: number = 10;\n\n /** 群组中心力大小 */\n public comboGravity: number = 10;\n\n /** 默认边长度 */\n public linkDistance: number | ((d?: unknown) => number) = 10;\n\n /** 每次迭代位移的衰减相关参数 */\n public alpha: number = 1;\n\n public alphaMin: number = 0.001;\n\n public alphaDecay: number = 1 - this.alphaMin ** (1 / 300);\n\n public alphaTarget: number = 0;\n\n /** 节点运动速度衰减参数 */\n public velocityDecay: number = 0.6;\n\n /** 边引力大小 */\n public edgeStrength: number | ((d?: unknown) => number) = 0.6;\n\n /** 节点引力大小 */\n public nodeStrength: number | ((d?: unknown) => number) = 30;\n\n /** 是否开启防止重叠 */\n public preventOverlap: boolean = false;\n\n /** 是否开启节点之间的防止重叠 */\n public preventNodeOverlap: boolean = false;\n\n /** 是否开启 Combo 之间的防止重叠 */\n public preventComboOverlap: boolean = false;\n\n /** 防止重叠的碰撞力大小 */\n public collideStrength: number | undefined = undefined;\n\n /** 防止重叠的碰撞力大小 */\n public nodeCollideStrength: number | undefined = 0.5;\n\n /** 防止重叠的碰撞力大小 */\n public comboCollideStrength: number | undefined = 0.5;\n\n /** 节点大小,用于防止重叠 */\n public nodeSize: number | number[] | ((d?: unknown) => number) | undefined;\n\n /** 节点最小间距,防止重叠时的间隙 */\n public nodeSpacing: ((d?: unknown) => number) | number | undefined;\n\n /** Combo 最小间距,防止重叠时的间隙 */\n public comboSpacing: ((d?: unknown) => number) | number | undefined = 20;\n\n /** Combo 内部的 padding */\n public comboPadding:\n | ((d?: unknown) => number)\n | number\n | number[]\n | undefined = 10;\n\n /** 优化计算斥力的速度,两节点间距超过 optimizeRangeFactor * width 则不再计算斥力和重叠斥力 */\n public optimizeRangeFactor: number = 1;\n\n /** 每次迭代的回调函数 */\n public onTick: () => void = () => {};\n\n /** 迭代结束的回调函数 */\n public onLayoutEnd: () => void = () => {};\n\n /** 根据边两端节点层级差距的调整引力系数的因子,取值范围 [0, 1]。层级差距越大,引力越小 */\n public depthAttractiveForceScale: number = 1;\n\n /** 根据边两端节点层级差距的调整斥力系数的因子,取值范围 [1, Infinity]。层级差距越大,斥力越大 */\n public depthRepulsiveForceScale: number = 2;\n\n /** 内部计算参数 */\n public nodes: Node[] = [];\n\n public edges: Edge[] = [];\n\n public combos: Combo[] = [];\n\n private comboTrees: ComboTree[] = [];\n\n // add a virtual root to comboTrees\n private comboTree: ComboTree;\n\n private width: number = 300;\n\n private height: number = 300;\n\n private bias: number[] = [];\n\n private nodeMap: NodeMap = {};\n\n private oriComboMap: ComboMap = {};\n\n private indexMap: IndexMap = {};\n\n private comboMap: ComboMap = {};\n\n private previousLayouted: boolean = false;\n\n constructor(options?: ComboForceLayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {\n maxIteration: 100,\n center: [0, 0],\n gravity: 10,\n speed: 1,\n comboGravity: 30,\n preventOverlap: false,\n preventComboOverlap: true,\n preventNodeOverlap: true,\n nodeSpacing: undefined,\n collideStrength: undefined,\n nodeCollideStrength: 0.5,\n comboCollideStrength: 0.5,\n comboSpacing: 20,\n comboPadding: 10,\n edgeStrength: 0.6,\n nodeStrength: 30,\n linkDistance: 10\n };\n }\n\n /**\n * 执行布局\n */\n public execute() {\n const self = this;\n const nodes = self.nodes;\n const center = self.center;\n self.comboTree = {\n id: \"comboTreeRoot\",\n depth: -1,\n children: self.comboTrees\n };\n\n if (!nodes || nodes.length === 0) {\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n if (nodes.length === 1) {\n nodes[0].x = center[0];\n nodes[0].y = center[1];\n if (self.onLayoutEnd) self.onLayoutEnd();\n return;\n }\n\n self.initVals();\n\n // layout\n self.run();\n if (self.onLayoutEnd) self.onLayoutEnd();\n }\n\n public run() {\n const self = this;\n const nodes = self.nodes;\n const maxIteration = self.previousLayouted\n ? self.maxIteration / 5\n : self.maxIteration;\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n const center = self.center;\n const velocityDecay = self.velocityDecay;\n\n // init the positions to make the nodes with same combo gather around the combo\n const comboMap = self.comboMap;\n if (!self.previousLayouted) self.initPos(comboMap);\n\n // iterate\n for (let i = 0; i < maxIteration; i++) {\n const displacements: Point[] = [];\n nodes.forEach((_, j) => {\n displacements[j] = { x: 0, y: 0 };\n });\n self.applyCalculate(displacements);\n\n // gravity for combos\n self.applyComboCenterForce(displacements);\n\n // move\n nodes.forEach((n, j) => {\n if (!isNumber(n.x) || !isNumber(n.y)) return;\n n.x += displacements[j].x * velocityDecay;\n n.y += displacements[j].y * velocityDecay;\n });\n self.alpha += (self.alphaTarget - self.alpha) * self.alphaDecay;\n self.onTick();\n }\n\n // move to center\n const meanCenter = [0, 0];\n nodes.forEach(n => {\n if (!isNumber(n.x) || !isNumber(n.y)) return;\n meanCenter[0] += n.x;\n meanCenter[1] += n.y;\n });\n meanCenter[0] /= nodes.length;\n meanCenter[1] /= nodes.length;\n const centerOffset = [center[0] - meanCenter[0], center[1] - meanCenter[1]];\n nodes.forEach((n, j) => {\n if (!isNumber(n.x) || !isNumber(n.y)) return;\n n.x += centerOffset[0];\n n.y += centerOffset[1];\n });\n\n // arrange the empty combo\n self.combos.forEach(combo => {\n const mapped = comboMap[combo.id];\n if (mapped && mapped.empty) {\n combo.x = mapped.cx || combo.x;\n combo.y = mapped.cy || combo.y;\n }\n });\n\n self.previousLayouted = true;\n }\n\n private initVals() {\n const self = this;\n const edges = self.edges;\n const nodes = self.nodes;\n const combos = self.combos;\n const count: any = {};\n\n const nodeMap: NodeMap = {};\n const indexMap: IndexMap = {};\n nodes.forEach((node, i) => {\n nodeMap[node.id] = node;\n indexMap[node.id] = i;\n });\n self.nodeMap = nodeMap;\n self.indexMap = indexMap;\n\n const oriComboMap: ComboMap = {};\n combos.forEach(combo => {\n oriComboMap[combo.id] = combo;\n });\n self.oriComboMap = oriComboMap;\n self.comboMap = self.getComboMap();\n\n const preventOverlap = self.preventOverlap;\n self.preventComboOverlap = self.preventComboOverlap || preventOverlap;\n self.preventNodeOverlap = self.preventNodeOverlap || preventOverlap;\n\n const collideStrength = self.collideStrength;\n if (collideStrength) {\n self.comboCollideStrength = collideStrength;\n self.nodeCollideStrength = collideStrength;\n }\n self.comboCollideStrength = self.comboCollideStrength\n ? self.comboCollideStrength\n : 0;\n self.nodeCollideStrength = self.nodeCollideStrength\n ? self.nodeCollideStrength\n : 0;\n\n // get edge bias\n for (let i = 0; i < edges.length; ++i) {\n if (count[edges[i].source]) count[edges[i].source]++;\n else count[edges[i].source] = 1;\n if (count[edges[i].target]) count[edges[i].target]++;\n else count[edges[i].target] = 1;\n }\n const bias = [];\n for (let i = 0; i < edges.length; ++i) {\n bias[i] =\n count[edges[i].source] /\n (count[edges[i].source] + count[edges[i].target]);\n }\n this.bias = bias;\n\n const nodeSize = self.nodeSize;\n const nodeSpacing = self.nodeSpacing;\n let nodeSizeFunc: (d: any) => number;\n let nodeSpacingFunc: (d: any) => number;\n\n // nodeSpacing to function\n if (isNumber(nodeSpacing)) {\n nodeSpacingFunc = () => nodeSpacing as any;\n } else if (isFunction(nodeSpacing)) {\n nodeSpacingFunc = nodeSpacing;\n } else {\n nodeSpacingFunc = () => 0;\n }\n this.nodeSpacing = nodeSpacingFunc;\n\n // nodeSize to function\n if (!nodeSize) {\n nodeSizeFunc = d => {\n if (d.size) {\n if (isArray(d.size)) {\n const res = d.size[0] > d.size[1] ? d.size[0] : d.size[1];\n return res / 2;\n }\n return d.size / 2;\n }\n return 10;\n };\n } else if (isFunction(nodeSize)) {\n nodeSizeFunc = d => {\n return nodeSize(d);\n };\n } else if (isArray(nodeSize)) {\n const larger = nodeSize[0] > nodeSize[1] ? nodeSize[0] : nodeSize[1];\n const radius = larger / 2;\n nodeSizeFunc = d => radius;\n } else {\n // number type\n const radius = nodeSize / 2;\n nodeSizeFunc = d => radius;\n }\n this.nodeSize = nodeSizeFunc;\n\n // comboSpacing to function\n const comboSpacing = self.comboSpacing;\n let comboSpacingFunc: (d: any) => number;\n if (isNumber(comboSpacing)) {\n comboSpacingFunc = () => comboSpacing as any;\n } else if (isFunction(comboSpacing)) {\n comboSpacingFunc = comboSpacing;\n } else {\n // null type\n comboSpacingFunc = () => 0;\n }\n this.comboSpacing = comboSpacingFunc;\n\n // comboPadding to function\n const comboPadding = self.comboPadding;\n let comboPaddingFunc: (d: any) => number;\n if (isNumber(comboPadding)) {\n comboPaddingFunc = () => comboPadding as any;\n } else if (isArray(comboPadding)) {\n comboPaddingFunc = () => Math.max.apply(null, comboPadding);\n } else if (isFunction(comboPadding)) {\n comboPaddingFunc = comboPadding;\n } else {\n // null type\n comboPaddingFunc = () => 0;\n }\n this.comboPadding = comboPaddingFunc;\n\n // linkDistance to function\n let linkDistance = this.linkDistance;\n let linkDistanceFunc;\n if (!linkDistance) {\n linkDistance = 10;\n }\n if (isNumber(linkDistance)) {\n linkDistanceFunc = (d: any) => {\n return linkDistance;\n };\n } else {\n linkDistanceFunc = linkDistance;\n }\n this.linkDistance = linkDistanceFunc as ((d?: unknown) => number);\n\n // linkStrength to function\n let edgeStrength = this.edgeStrength;\n let edgeStrengthFunc;\n if (!edgeStrength) {\n edgeStrength = 1;\n }\n if (isNumber(edgeStrength)) {\n edgeStrengthFunc = (d: any) => {\n return edgeStrength;\n };\n } else {\n edgeStrengthFunc = edgeStrength;\n }\n this.edgeStrength = edgeStrengthFunc as ((d?: unknown) => number);\n\n // nodeStrength to function\n let nodeStrength = this.nodeStrength;\n let nodeStrengthFunc;\n if (!nodeStrength) {\n nodeStrength = 30;\n }\n if (isNumber(nodeStrength)) {\n nodeStrengthFunc = (d: any) => {\n return nodeStrength;\n };\n } else {\n nodeStrengthFunc = nodeStrength;\n }\n this.nodeStrength = nodeStrengthFunc as ((d?: unknown) => number);\n }\n\n private initPos(comboMap: ComboMap) {\n const self = this;\n const nodes = self.nodes;\n nodes.forEach((node, i) => {\n const comboId = (node as any).comboId;\n const combo = comboMap[comboId];\n if (comboId && combo) {\n node.x = combo.cx + 100 / (i + 1);\n node.y = combo.cy + 100 / (i + 1);\n } else {\n node.x = 100 / (i + 1);\n node.y = 100 / (i + 1);\n }\n });\n }\n\n private getComboMap() {\n const self = this;\n const nodeMap = self.nodeMap;\n const indexMap = self.indexMap;\n const comboTrees = self.comboTrees;\n const oriComboMap = self.oriComboMap;\n const comboMap: ComboMap = {};\n\n (comboTrees || []).forEach((ctree: any) => {\n const treeChildren: Combo[] | Node[] = [];\n traverseTreeUp<ComboTree>(ctree, treeNode => {\n if (treeNode.itemType === \"node\") return true; // skip it\n if (!oriComboMap[treeNode.id]) return true; // means it is hidden, skip it\n if (comboMap[treeNode.id] === undefined) {\n const combo = {\n id: treeNode.id,\n name: treeNode.id,\n cx: 0,\n cy: 0,\n count: 0,\n depth: self.oriComboMap[treeNode.id].depth as number || 0,\n children: [] as any\n };\n comboMap[treeNode.id] = combo;\n }\n const children = treeNode.children;\n if (children) {\n children.forEach((child: any) => {\n if (!comboMap[child.id] && !nodeMap[child.id]) return true; // means it is hidden\n treeChildren.push(child);\n });\n }\n const c = comboMap[treeNode.id];\n c.cx = 0;\n c.cy = 0;\n\n // In order to layout the empty combo, add a virtual node to it\n if (treeChildren.length === 0) {\n c.empty = true;\n const oriCombo = oriComboMap[treeNode.id];\n const idx = Object.keys(nodeMap).length;\n const virtualNodeId = `${treeNode.id}-visual-child-${idx}`;\n const vnode: any = {\n id: virtualNodeId,\n x: oriCombo.x as number,\n y: oriCombo.y as number,\n depth: (c.depth as number) + 1,\n itemType: \"node\"\n };\n self.nodes.push(vnode);\n nodeMap[virtualNodeId] = vnode;\n indexMap[virtualNodeId] = idx;\n c.cx = oriCombo.x as number;\n c.cy = oriCombo.y as number;\n treeChildren.push(vnode);\n }\n\n treeChildren.forEach((child: Combo | Node) => {\n (c.count as number)++;\n if (child.itemType !== \"node\") {\n const childCombo = comboMap[child.id];\n if (isNumber(childCombo.cx)) c.cx += childCombo.cx;\n if (isNumber(childCombo.cy)) c.cy += childCombo.cy;\n return;\n }\n const node = nodeMap[child.id];\n // means the node is hidden, skip it\n if (!node) return;\n\n if (isNumber(node.x)) {\n c.cx += node.x;\n }\n if (isNumber(node.y)) {\n c.cy += node.y;\n }\n });\n c.cx /= c.count as number;\n c.cy /= c.count as number;\n\n c.children = treeChildren as any;\n\n return true;\n });\n });\n\n return comboMap;\n }\n\n private applyComboCenterForce(displacements: Point[]) {\n const self = this;\n const gravity = self.gravity;\n const comboGravity = self.comboGravity || gravity;\n const alpha = this.alpha;\n const comboTrees = self.comboTrees;\n const indexMap = self.indexMap;\n const nodeMap = self.nodeMap;\n const comboMap = self.comboMap;\n\n (comboTrees || []).forEach(ctree => {\n traverseTreeUp<ComboTree>(ctree, treeNode => {\n if (treeNode.itemType === \"node\") return true; // skip it\n const combo = comboMap[treeNode.id];\n // means the combo is hidden, skip it\n if (!combo) return true;\n const c = comboMap[treeNode.id];\n\n // higher depth the combo, larger the gravity\n const gravityScale = (((c.depth as number) + 1) / 10) * 0.5;\n // apply combo center force for all the descend nodes in this combo\n // and update the center position and count for this combo\n const comboX = c.cx;\n const comboY = c.cy;\n c.cx = 0;\n c.cy = 0;\n c.children!.forEach(child => {\n if (child.itemType !== \"node\") {\n const childCombo = comboMap[child.id];\n if (childCombo && isNumber(childCombo.cx)) c.cx += childCombo.cx;\n if (childCombo && isNumber(childCombo.cy)) c.cy += childCombo.cy;\n return;\n }\n const node = nodeMap[child.id];\n const vecX = (node.x - comboX) || 0.005;\n const vecY = (node.y - comboY) || 0.005;\n const l = Math.sqrt(vecX * vecX + vecY * vecY);\n const childIdx = indexMap[node.id];\n const params = ((comboGravity * alpha) / l) * gravityScale;\n displacements[childIdx].x -= vecX * params;\n displacements[childIdx].y -= vecY * params;\n\n if (isNumber(node.x)) c.cx += node.x;\n if (isNumber(node.y)) c.cy += node.y;\n });\n c.cx /= c.count as number;\n c.cy /= c.count as number;\n return true;\n });\n });\n }\n\n private applyCalculate(displacements: Point[]) {\n const self = this;\n const comboMap = self.comboMap;\n const nodes = self.nodes;\n // store the vx, vy, and distance to reduce dulplicate calculation\n const vecMap: any = {};\n nodes.forEach((v, i) => {\n nodes.forEach((u, j) => {\n if (i < j) return;\n const vx = (v.x - u.x) || 0.005;\n const vy = (v.y - u.y) || 0.005;\n let vl2 = vx * vx + vy * vy;\n const vl = Math.sqrt(vl2);\n if (vl2 < 1) vl2 = vl;\n vecMap[`${v.id}-${u.id}`] = { vx, vy, vl2, vl };\n vecMap[`${u.id}-${v.id}`] = { vl2, vl, vx: -vx, vy: -vy };\n });\n });\n // get the sizes of the combos\n self.updateComboSizes(comboMap);\n self.calRepulsive(displacements, vecMap);\n self.calAttractive(displacements, vecMap);\n\n const preventComboOverlap = self.preventComboOverlap;\n if (preventComboOverlap) self.comboNonOverlapping(displacements, comboMap);\n }\n\n /**\n * Update the sizes of the combos according to their children\n * Used for combos nonoverlap, but not re-render the combo shapes\n */\n private updateComboSizes(comboMap: ComboMap) {\n const self = this;\n const comboTrees = self.comboTrees;\n const nodeMap = self.nodeMap;\n const nodeSize = self.nodeSize as ((d?: unknown) => number);\n const comboSpacing = self.comboSpacing as ((d?: unknown) => number);\n const comboPadding = self.comboPadding as ((d?: unknown) => number);\n (comboTrees || []).forEach(ctree => {\n const treeChildren: Combo[] | Node[] = [];\n traverseTreeUp<ComboTree>(ctree, (treeNode: ComboTree) => {\n if (treeNode.itemType === \"node\") return true; // skip it\n const c = comboMap[treeNode.id];\n // means the combo is hidden, skip it\n if (!c) return false;\n const children = treeNode.children;\n if (children) {\n children.forEach((child: any) => {\n // means the combo is hidden.\n if (!comboMap[child.id] && !nodeMap[child.id]) return;\n treeChildren.push(child);\n });\n }\n\n c.minX = Infinity;\n c.minY = Infinity;\n c.maxX = -Infinity;\n c.maxY = -Infinity;\n treeChildren.forEach((child: any) => {\n if (child.itemType !== \"node\") return true; // skip it\n const node = nodeMap[child.id];\n if (!node) return true; // means it is hidden\n const r = nodeSize(node);\n const nodeMinX = node.x - r;\n const nodeMinY = node.y - r;\n const nodeMaxX = node.x + r;\n const nodeMaxY = node.y + r;\n if (c.minX! > nodeMinX) c.minX = nodeMinX;\n if (c.minY! > nodeMinY) c.minY = nodeMinY;\n if (c.maxX! < nodeMaxX) c.maxX = nodeMaxX;\n if (c.maxY! < nodeMaxY) c.maxY = nodeMaxY;\n });\n let minSize = self.oriComboMap[treeNode.id].size || 10;\n if (isArray(minSize)) minSize = minSize[0];\n const maxLength = Math.max(\n c.maxX - c.minX,\n c.maxY - c.minY,\n minSize as number\n );\n c.r = maxLength / 2 + comboSpacing(c) / 2 + comboPadding(c);\n\n return true;\n });\n });\n }\n\n /**\n * prevent the overlappings among combos\n */\n private comboNonOverlapping(displacements: Point[], comboMap: ComboMap) {\n const self = this;\n const comboTree = self.comboTree;\n const comboCollideStrength = self.comboCollideStrength as number;\n const indexMap = self.indexMap;\n const nodeMap = self.nodeMap;\n\n traverseTreeUp<ComboTree>(comboTree, treeNode => {\n if (\n !comboMap[treeNode.id] &&\n !nodeMap[treeNode.id] &&\n treeNode.id !== \"comboTreeRoot\"\n ) {\n return false;\n } // means it is hidden\n const children = treeNode.children;\n // 同个子树下的子 combo 间两两对比\n if (children && children.length > 1) {\n children.forEach((v, i) => {\n if (v.itemType === \"node\") return false; // skip it\n const cv = comboMap[v.id];\n if (!cv) return; // means it is hidden, skip it\n children.forEach((u, j) => {\n if (i <= j) return false;\n if (u.itemType === \"node\") return false; // skip it\n const cu = comboMap[u.id];\n if (!cu) return false; // means it is hidden, skip it\n const vx = (cv.cx - cu.cx) || 0.005;\n const vy = (cv.cy - cu.cy) || 0.005;\n const l = vx * vx + vy * vy;\n const rv = cv.r as number || 1;\n const ru = cu.r as number || 1;\n const r = rv + ru;\n const ru2 = ru * ru;\n const rv2 = rv * rv;\n // overlapping\n if (l < r * r) {\n const vnodes = v.children;\n if (!vnodes || vnodes.length === 0) return false; // skip it\n const unodes = u.children;\n if (!unodes || unodes.length === 0) return false; // skip it\n const sqrtl = Math.sqrt(l);\n const ll = ((r - sqrtl) / sqrtl) * comboCollideStrength;\n const xl = vx * ll;\n const yl = vy * ll;\n const rratio = ru2 / (rv2 + ru2);\n const irratio = 1 - rratio;\n // 两兄弟 combo 的子节点上施加斥力\n vnodes.forEach(vn => {\n if (vn.itemType !== \"node\") return false; // skip it\n if (!nodeMap[vn.id]) return; // means it is hidden, skip it\n const vindex = indexMap[vn.id];\n unodes.forEach(un => {\n if (un.itemType !== \"node\") return false;\n if (!nodeMap[un.id]) return false; // means it is hidden, skip it\n const uindex = indexMap[un.id];\n displacements[vindex].x += xl * rratio;\n displacements[vindex].y += yl * rratio;\n displacements[uindex].x -= xl * irratio;\n displacements[uindex].y -= yl * irratio;\n });\n });\n }\n });\n });\n }\n return true;\n });\n }\n\n /**\n * Calculate the repulsive force between each node pair\n * @param displacements The array stores the displacements for nodes\n * @param vecMap The map stores vector between each node pair\n */\n private calRepulsive(displacements: Point[], vecMap: any) {\n const self = this;\n const nodes = self.nodes;\n const max = self.width * self.optimizeRangeFactor;\n const nodeStrength = self.nodeStrength as (d?: unknown) => number;\n const alpha = self.alpha;\n const nodeCollideStrength = self.nodeCollideStrength as number;\n const preventNodeOverlap = self.preventNodeOverlap;\n const nodeSizeFunc = self.nodeSize as ((d?: unknown) => number);\n const nodeSpacingFunc = self.nodeSpacing as ((d?: unknown) => number);\n const scale = self.depthRepulsiveForceScale;\n const center = self.center;\n nodes.forEach((v, i) => {\n if (!v.x || !v.y) return;\n\n // center gravity\n if (center) {\n const gravity = self.gravity;\n const vecX = (v.x - center[0]) || 0.005;\n const vecY = (v.y - center[1]) || 0.005;\n const l = Math.sqrt(vecX * vecX + vecY * vecY);\n displacements[i].x -= (vecX * gravity * alpha) / l;\n displacements[i].y -= (vecY * gravity * alpha) / l;\n }\n\n nodes.forEach((u, j) => {\n if (i === j) {\n return;\n }\n if (!u.x || !u.y) return;\n const { vl2, vl } = vecMap[`${v.id}-${u.id}`];\n if (vl > max) return;\n\n const { vx, vy } = vecMap[`${v.id}-${u.id}`];\n\n let depthDiff = Math.log(Math.abs(u.depth - v.depth) / 10) + 1 || 1;\n depthDiff = depthDiff < 1 ? 1 : depthDiff;\n if (u.comboId !== v.comboId) depthDiff += 1;\n const depthParam = depthDiff ? scale ** depthDiff : 1;\n\n const params = ((nodeStrength(u) * alpha) / vl2) * depthParam;\n displacements[i].x += vx * params;\n displacements[i].y += vy * params;\n\n // prevent node overlappings\n if (i < j && preventNodeOverlap) {\n const ri = (nodeSizeFunc(v) + nodeSpacingFunc(v)) || 1;\n const rj = (nodeSizeFunc(u) + nodeSpacingFunc(u)) || 1;\n const r = ri + rj;\n if (vl2 < r * r) {\n const ll = ((r - vl) / vl) * nodeCollideStrength;\n const rj2 = rj * rj;\n let rratio = rj2 / (ri * ri + rj2);\n const xl = vx * ll;\n const yl = vy * ll;\n displacements[i].x += xl * rratio;\n displacements[i].y += yl * rratio;\n rratio = 1 - rratio;\n displacements[j].x -= xl * rratio;\n displacements[j].y -= yl * rratio;\n }\n }\n });\n });\n }\n\n /**\n * Calculate the attractive force between the node pair with edge\n * @param displacements The array stores the displacements for nodes\n * @param vecMap The map stores vector between each node pair\n */\n private calAttractive(displacements: Point[], vecMap: any) {\n const self = this;\n const edges = self.edges;\n const linkDistance = self.linkDistance as (d?: unknown) => number;\n const alpha = self.alpha;\n const edgeStrength = self.edgeStrength as (d?: unknown) => number;\n const bias = self.bias;\n const scale = self.depthAttractiveForceScale;\n edges.forEach((e, i) => {\n if (!e.source || !e.target || e.source === e.target) return;\n const uIndex = self.indexMap[e.source];\n const vIndex = self.indexMap[e.target];\n const u: Node = self.nodeMap[e.source];\n const v: Node = self.nodeMap[e.target];\n if (!u || !v) return;\n\n let depthDiff = u.depth === v.depth ? 0 : Math.log(Math.abs(u.depth - v.depth) / 10);\n if (u.comboId === v.comboId) {\n depthDiff = depthDiff / 2;\n }\n let depthParam = depthDiff ? scale ** depthDiff : 1;\n if (u.comboId !== v.comboId && depthParam === 1) {\n depthParam = scale / 2;\n } else if (u.comboId === v.comboId) {\n depthParam = 2;\n }\n\n if (!isNumber(v.x) || !isNumber(u.x) || !isNumber(v.y) || !isNumber(u.y))\n return;\n const { vl, vx, vy } = vecMap[`${e.target}-${e.source}`];\n const l =\n ((vl - linkDistance(e)) / vl) * alpha * edgeStrength(e) * depthParam;\n const vecX = vx * l;\n const vecY = vy * l;\n\n const b = bias[i];\n displacements[vIndex].x -= vecX * b;\n displacements[vIndex].y -= vecY * b;\n displacements[uIndex].x += vecX * (1 - b);\n displacements[uIndex].y += vecY * (1 - b);\n });\n }\n\n public getType() {\n return \"comboForce\";\n }\n}\n","import Quad from './quad';\n\n/**\n * @fileOverview body\n * @author shiwu.wyy@antfin.com\n */\n\ntype BodyProps = {\n id?: Number;\n rx: number;\n ry: number;\n fx?: number;\n fy?: number;\n mass: number;\n degree: number;\n g?: number;\n}\n\n// represents a body(a point mass) and its position\nexport default class Body {\n public id: Number;\n public rx: number;\n public ry: number;\n public fx: number;\n public fy: number;\n public mass: number;\n public degree: number;\n public g: number;\n \n constructor(params: BodyProps) {\n /**\n * the id of this body, the same with the node id\n * @type {number}\n */\n this.id = params.id || 0;\n /**\n * the position of this body\n * @type {number}\n */\n this.rx = params.rx;\n /**\n * the position of this body\n * @type {number}\n */\n this.ry = params.ry;\n /**\n * the force acting on this body\n * @type {number}\n */\n this.fx = 0;\n /**\n * the force acting on this body\n * @type {number}\n */\n this.fy = 0;\n /**\n * the mass of this body, =1 for a node\n * @type {number}\n */\n this.mass = params.mass;\n /**\n * the degree of the node represented by this body\n * @type {number}\n */\n this.degree = params.degree;\n /**\n * the parameter for repulsive force, = kr\n * @type {number}\n */\n this.g = params.g || 0;\n }\n // returns the euclidean distance\n distanceTo(bo: Body) {\n const dx = this.rx - bo.rx;\n const dy = this.ry - bo.ry;\n return Math.hypot(dx, dy);\n }\n setPos(x: number, y: number) {\n this.rx = x;\n this.ry = y;\n }\n // resets the forces\n resetForce() {\n this.fx = 0;\n this.fy = 0;\n }\n addForce(b: Body) {\n const dx = b.rx - this.rx;\n const dy = b.ry - this.ry;\n let dist = Math.hypot(dx, dy);\n dist = dist < 0.0001 ? 0.0001 : dist;\n // the repulsive defined by force atlas 2\n const F = (this.g * (this.degree + 1) * (b.degree + 1)) / dist;\n this.fx += F * dx / dist;\n this.fy += F * dy / dist;\n }\n // if quad contains this body\n in(quad: Quad) {\n return quad.contains(this.rx, this.ry);\n }\n // returns a new body\n add(bo: Body) {\n const nenwMass = this.mass + bo.mass;\n const x = (this.rx * this.mass + bo.rx * bo.mass) / nenwMass;\n const y = (this.ry * this.mass + bo.ry * bo.mass) / nenwMass;\n const dg = this.degree + bo.degree;\n const params: BodyProps = {\n rx: x,\n ry: y,\n mass: nenwMass,\n degree: dg\n };\n return new Body(params);\n }\n}","import { PointTuple } from \"../types\";\n\n/**\n * @fileOverview quad\n * @author shiwu.wyy@antfin.com\n */\n\ntype QuadProps = {\n xmid: number;\n ymid: number;\n length: number;\n massCenter?: PointTuple;\n mass?: number;\n}\n\nexport default class Quad {\n public xmid: number;\n public ymid: number;\n public length: number;\n public massCenter: PointTuple;\n public mass: number;\n constructor(params: QuadProps) {\n /**\n * the center position of this quad\n * @type {number}\n */\n this.xmid = params.xmid;\n /**\n * the center position of this quad\n * @type {number}\n */\n this.ymid = params.ymid;\n /**\n * the length of this quad\n * @type {number}\n */\n this.length = params.length;\n /**\n * the mass center of this quad\n * @type {number}\n */\n this.massCenter = params.massCenter || [0, 0];\n /**\n * the mass of this quad\n * @type {number}\n */\n this.mass = params.mass || 1;\n }\n getLength() {\n return this.length;\n }\n contains(x: number, y: number) {\n const halfLen = this.length / 2;\n return (x <= this.xmid + halfLen &&\n x >= this.xmid - halfLen &&\n y <= this.ymid + halfLen &&\n y >= this.ymid - halfLen);\n }\n // northwest quadrant\n NW() {\n const x = this.xmid - this.length / 4;\n const y = this.ymid + this.length / 4;\n const len = this.length / 2;\n const params: QuadProps = {\n xmid: x,\n ymid: y,\n length: len\n };\n const NW = new Quad(params);\n return NW;\n }\n // northeast\n NE() {\n const x = this.xmid + this.length / 4;\n const y = this.ymid + this.length / 4;\n const len = this.length / 2;\n const params = {\n xmid: x,\n ymid: y,\n length: len\n };\n const NE = new Quad(params);\n return NE;\n }\n // southwest\n SW() {\n const x = this.xmid - this.length / 4;\n const y = this.ymid - this.length / 4;\n const len = this.length / 2;\n const params = {\n xmid: x,\n ymid: y,\n length: len\n };\n const SW = new Quad(params);\n return SW;\n }\n // southeast\n SE() {\n const x = this.xmid + this.length / 4;\n const y = this.ymid - this.length / 4;\n const len = this.length / 2;\n const params = {\n xmid: x,\n ymid: y,\n length: len\n };\n const SE = new Quad(params);\n return SE;\n }\n}\n","import Body from './body';\nimport Quad from './quad';\n\n/**\n * @fileOverview quadTree\n * @author shiwu.wyy@antfin.com\n */\n\nexport default class QuadTree {\n public body: Body | null;\n public quad: Quad | null;\n public theta: number;\n public NW: QuadTree | null;\n public NE: QuadTree | null;\n public SW: QuadTree | null;\n public SE: QuadTree | null;\n\n // each quadtree represents a quadrant and an aggregate body\n // that represents all bodies inside the quadrant\n constructor(param: Quad | null) {\n /**\n * (aggregated) body in this quad\n * @type {object}\n */\n this.body = null;\n /**\n * tree representing the northwest quadrant\n * @type {object}\n */\n this.quad = null;\n this.NW = null;\n this.NE = null;\n this.SW = null;\n this.SE = null;\n /**\n * threshold\n * @type {number}\n */\n this.theta = 0.5;\n if (param != null) this.quad = param;\n }\n // insert a body(node) into the tree\n insert(bo: Body) {\n // if this node does not contain a body, put the new body bo here\n if (this.body == null) {\n this.body = bo;\n return;\n }\n // internal node\n if (!this._isExternal()) {\n // update mass info\n this.body = this.body.add(bo);\n // insert body into quadrant\n this._putBody(bo);\n } else { // external node\n // divide this region into four children\n if (this.quad) {\n this.NW = new QuadTree(this.quad.NW());\n this.NE = new QuadTree(this.quad.NE());\n this.SW = new QuadTree(this.quad.SW());\n this.SE = new QuadTree(this.quad.SE());\n }\n\n // insert this body and bo\n this._putBody(this.body);\n this._putBody(bo);\n // update the mass info\n this.body = this.body.add(bo);\n\n }\n }\n // inserts bo into a quad\n _putBody(bo: Body) {\n if (!this.quad) return;\n if (bo.in(this.quad.NW()) && this.NW) this.NW.insert(bo);\n else if (bo.in(this.quad.NE()) && this.NE) this.NE.insert(bo);\n else if (bo.in(this.quad.SW()) && this.SW )this.SW.insert(bo);\n else if (bo.in(this.quad.SE()) && this.SE) this.SE.insert(bo);\n }\n _isExternal() {\n // four children are null\n return (this.NW == null && this.NE == null && this.SW == null && this.SE == null);\n }\n // update the forces\n updateForce(bo: Body) {\n if (this.body == null || bo === this.body) {\n return;\n }\n // if the current node is external\n if (this._isExternal()) bo.addForce(this.body);\n // internal nodes\n else {\n const s = this.quad ? this.quad.getLength() : 0;\n const d = this.body.distanceTo(bo);\n // b is far enough\n if ((s / d) < this.theta) bo.addForce(this.body);\n else {\n this.NW && this.NW.updateForce(bo);\n this.NE && this.NE.updateForce(bo);\n this.SW && this.SW.updateForce(bo);\n this.SE && this.SE.updateForce(bo);\n }\n }\n }\n}\n","/**\n * @fileOverview force atlas 2\n * @author shiwu.wyy@antfin.com\n */\nimport { PointTuple, OutNode, Edge, ForceAtlas2LayoutOptions } from \"../types\";\nimport { Base } from \"../base\";\nimport { isArray, isNumber } from \"../../util\";\nimport Body from './body';\nimport Quad from './quad';\nimport QuadTree from './quadTree';\n\nexport class ForceAtlas2Layout extends Base {\n /** 布局中心 */\n public center: PointTuple = [0, 0];\n\n /** 宽度 */\n public width: number = 300;\n\n /** 高度 */\n public height: number = 300;\n\n public nodes: OutNode[] = [];\n\n public edges: Edge[] = [];\n\n /**\n * the parameter for repulsive forces,\n * it will scale the layout but won't change the layout\n * larger the kr, looser the layout\n * @type {number}\n */\n public kr: number = 5;\n\n /**\n * the parameter for gravity forces\n * @type {number}\n */\n public kg: number = 1;\n\n /**\n * modes:\n * 'normal' for normal using\n * 'linlog' for compact clusters.\n * @type {string}\n */\n public mode: 'normal' | 'linlog' = 'normal';\n\n /**\n * whether preventing the node overlapping\n * @type {boolean}\n */\n public preventOverlap: boolean = false;\n\n /**\n * whether active the dissuade hub mode\n * true: grant authorities (nodes with a high indegree)\n * a more central position than hubs (nodes with a high outdegree)\n * @type {boolean}\n */\n public dissuadeHubs: boolean = false;\n\n /**\n * whether active the barnes hut optimization on computing repulsive forces\n * @type {boolean}\n */\n public barnesHut: boolean = false;\n\n /**\n * the max iteration number\n * @type {number}\n */\n public maxIteration: number = 0;\n\n /**\n * control the global velocity\n * defualt: 0.1(gephi)\n * @type {number}\n */\n public ks: number = 0.1;\n\n /**\n * the max global velocity\n * @type {number}\n */\n public ksmax: number = 10;\n\n /**\n * the tolerance for the global swinging\n * @type {number}\n */\n public tao: number = 0.1;\n\n /**\n * the function of layout complete listener, display the legend and minimap after layout\n * @type {function}\n */\n public onLayoutEnd: () => void = () => {};\n\n public tick: () => void;\n\n /**\n * activate prune or not.\n * prune the leaves during most iterations, layout the leaves in the last 50 iteraitons.\n * if prune === '', it will be activated when the nodes number > 100\n * note that it will reduce the quality of the layout\n * @type {boolean}\n */\n public prune: boolean = false;\n\n public getWidth: (node: any) => number;\n public getHeight: (node: any) => number;\n\n constructor(options?: ForceAtlas2LayoutOptions) {\n super();\n this.updateCfg(options);\n }\n\n public getDefaultCfg() {\n return {};\n }\n\n // execute the layout\n public execute() {\n const self = this;\n let {\n nodes,\n maxIteration,\n onLayoutEnd,\n prune,\n } = self;\n\n if (!self.width && typeof window !== \"undefined\") {\n self.width = window.innerWidth;\n }\n if (!self.height && typeof window !== \"undefined\") {\n self.height = window.innerHeight;\n }\n\n // the whidth of each nodes\n const sizes = [];\n const nodeNum = nodes.length;\n for (let i = 0; i < nodeNum; i += 1) {\n const node = nodes[i] as any;\n let nodeWidth = 10;\n let nodeHeight = 10\n if (isNumber(node.size)) {\n nodeWidth = node.size;\n nodeHeight = node.size;\n }\n if (isArray(node.size)) {\n if (!isNaN(node.size[0])) nodeWidth = node.size[0];\n if (!isNaN(node.size[1])) nodeHeight = node.size[1];\n }\n if (self.getWidth && !isNaN(self.getWidth(node))) nodeHeight = self.getWidth(node);\n if (self.getHeight && !isNaN(self.getHeight(node))) nodeWidth = self.getHeight(node);\n\n const maxSize = Math.max(nodeWidth, nodeHeight);\n sizes.push(maxSize);\n }\n\n if (!self.barnesHut && nodeNum > 250) self.barnesHut = true;\n if (!self.prune && nodeNum > 100) self.prune = true;\n if (this.maxIteration === 0 && !self.prune) {\n maxIteration = 250;\n if (nodeNum <= 200 && nodeNum > 100) maxIteration = 1000;\n else if (nodeNum > 200) maxIteration = 1200;\n this.maxIteration = maxIteration;\n } else if (this.maxIteration === 0 && prune) {\n maxIteration = 100;\n if (nodeNum <= 200 && nodeNum > 100) maxIteration = 500;\n else if (nodeNum > 200) maxIteration = 950;\n this.maxIteration = maxIteration;\n }\n\n if (!self.kr) {\n self.kr = 50;\n if (nodeNum > 100 && nodeNum <= 500) self.kr = 20;\n else if (nodeNum > 500) self.kr = 1;\n }\n if (!self.kg) {\n self.kg = 20;\n if (nodeNum > 100 && nodeNum <= 500) self.kg = 10;\n else if (nodeNum > 500) self.kg = 1;\n }\n this.nodes = self.updateNodesByForces(sizes);\n onLayoutEnd();\n }\n\n\n updateNodesByForces(sizes: number[]) {\n const self = this;\n let {\n nodes,\n edges,\n maxIteration,\n } = self;\n\n const nonLoopEdges = edges.filter((edge: any) => {\n return edge.source !== edge.target;\n });\n const size = nodes.length;\n const esize = nonLoopEdges.length;\n\n const degrees = [];\n const idMap: {[key: string]: number} = {};\n const edgeEndsIdMap: {[key: number]: {sourceIdx: number, targetIdx: number}} = {};\n\n const Es = [];\n for (let i = 0; i < size; i += 1) {\n idMap[nodes[i].id] = i;\n degrees[i] = 0;\n if (nodes[i].x === undefined || isNaN(nodes[i].x)) { nodes[i].x = Math.random() * 1000; }\n if (nodes[i].y === undefined || isNaN(nodes[i].y)) { nodes[i].y = Math.random() * 1000; }\n Es.push({ x: nodes[i].x, y: nodes[i].y });\n }\n for (let i = 0; i < esize; i += 1) {\n let node1;\n let node2;\n let sIdx = 0,\n tIdx = 0;\n\n for (let j = 0; j < size; j += 1) {\n if (nodes[j].id === nonLoopEdges[i].source) {\n node1 = nodes[j];\n sIdx = j;\n } else if (nodes[j].id === nonLoopEdges[i].target) {\n node2 = nodes[j];\n tIdx = j;\n }\n edgeEndsIdMap[i] = { sourceIdx: sIdx, targetIdx: tIdx };\n }\n if (node1) degrees[idMap[node1.id]] += 1;\n if (node2) degrees[idMap[node2.id]] += 1;\n }\n\n let iteration = maxIteration;\n nodes = this.iterate(iteration, idMap, edgeEndsIdMap, esize, degrees, sizes);\n\n // if prune, place the leaves around their parents, and then re-layout for several iterations.\n if (self.prune) {\n for (let j = 0; j < esize; j += 1) {\n if (degrees[edgeEndsIdMap[j].sourceIdx] <= 1) {\n nodes[edgeEndsIdMap[j].sourceIdx].x = nodes[edgeEndsIdMap[j].targetIdx].x;\n nodes[edgeEndsIdMap[j].sourceIdx].y = nodes[edgeEndsIdMap[j].targetIdx].y;\n\n } else if (degrees[edgeEndsIdMap[j].targetIdx] <= 1) {\n nodes[edgeEndsIdMap[j].targetIdx].x = nodes[edgeEndsIdMap[j].sourceIdx].x;\n nodes[edgeEndsIdMap[j].targetIdx].y = nodes[edgeEndsIdMap[j].sourceIdx].y;\n }\n }\n self.prune = false;\n self.barnesHut = false;\n iteration = 100;\n nodes = this.iterate(\n iteration,\n idMap,\n edgeEndsIdMap,\n esize,\n degrees,\n sizes\n );\n }\n return nodes;\n }\n iterate(\n iteration: number,\n idMap: {[key: string]: number},\n edgeEndsIdMap: {[key: number]: {sourceIdx: number, targetIdx: number}},\n esize: number,\n degrees: number[],\n sizes: number[],\n ) {\n\n const self = this;\n let { nodes, kr, preventOverlap, barnesHut } = self;\n\n const nodeNum = nodes.length;\n let sg = 0;\n const krPrime = 100;\n let iter = iteration;\n const prevoIter = 50;\n let forces = [];\n const preForces = [];\n const bodies = [];\n\n for (let i = 0; i < nodeNum; i += 1) {\n forces[2 * i] = 0;\n forces[2 * i + 1] = 0;\n\n if (barnesHut) {\n let params = {\n id: i,\n rx: nodes[i].x,\n ry: nodes[i].y,\n mass: 1,\n g: kr,\n degree: degrees[i]\n };\n bodies[i] = new Body(params);\n }\n }\n\n while (iter > 0) {\n for (let i = 0; i < nodeNum; i += 1) {\n preForces[2 * i] = forces[2 * i];\n preForces[2 * i + 1] = forces[2 * i + 1];\n forces[2 * i] = 0;\n forces[2 * i + 1] = 0;\n }\n // attractive forces, existing on every actual edge\n forces = this.getAttrForces(\n iter,\n prevoIter,\n esize, \n idMap,\n edgeEndsIdMap,\n degrees,\n sizes,\n forces\n );\n\n // repulsive forces and Gravity, existing on every node pair\n // if preventOverlap, using the no-optimized method in the last prevoIter instead.\n if (barnesHut && ((preventOverlap && iter > prevoIter) || !preventOverlap)) {\n forces = this.getOptRepGraForces(forces, bodies, degrees);\n } else {\n forces = this.getRepGraForces(iter, prevoIter, forces, krPrime, sizes, degrees);\n }\n // update the positions\n const res = this.updatePos(forces, preForces, sg, degrees);\n nodes = res.nodes;\n sg = res.sg;\n iter --;\n if (self.tick) self.tick();\n };\n\n return nodes;\n }\n getAttrForces(\n iter: number,\n prevoIter: number,\n esize: number, \n idMap: {[key: string]: number},\n edgeEndsIdMap: {[key: number]: {sourceIdx: number, targetIdx: number}},\n degrees: number[],\n sizes: number[],\n forces: number[],\n ): number[] {\n const self = this;\n const { nodes, preventOverlap, dissuadeHubs, mode, prune } = self;\n for (let i = 0; i < esize; i += 1) {\n const sourceNode = nodes[edgeEndsIdMap[i].sourceIdx];\n const sourceIdx = edgeEndsIdMap[i].sourceIdx;\n const targetNode = nodes[edgeEndsIdMap[i].targetIdx];\n const targetIdx = edgeEndsIdMap[i].targetIdx;\n\n if (prune && (degrees[sourceIdx] <= 1 || degrees[targetIdx] <= 1)) continue;\n\n let dir = [ targetNode.x - sourceNode.x, targetNode.y - sourceNode.y ];\n let eucliDis = Math.hypot(dir[0], dir[1]);\n eucliDis = eucliDis < 0.0001 ? 0.0001 : eucliDis;\n dir[0] = dir[0] / eucliDis;\n dir[1] = dir[1] / eucliDis;\n\n if (preventOverlap && iter < prevoIter) eucliDis = eucliDis - sizes[sourceIdx] - sizes[targetIdx];\n let Fa1 = eucliDis;\n let Fa2 = Fa1;\n if (mode === 'linlog') {\n Fa1 = Math.log(1 + eucliDis);\n Fa2 = Fa1;\n }\n if (dissuadeHubs) {\n Fa1 = eucliDis / degrees[sourceIdx];\n Fa2 = eucliDis / degrees[targetIdx];\n }\n if (preventOverlap && iter < prevoIter && eucliDis <= 0) {\n Fa1 = 0;\n Fa2 = 0;\n } else if (preventOverlap && iter < prevoIter && eucliDis > 0) {\n Fa1 = eucliDis;\n Fa2 = eucliDis;\n }\n forces[2 * idMap[sourceNode.id]] += Fa1 * dir[0];\n forces[2 * idMap[targetNode.id]] -= Fa2 * dir[0];\n forces[2 * idMap[sourceNode.id] + 1] += Fa1 * dir[1];\n forces[2 * idMap[targetNode.id] + 1] -= Fa2 * dir[1];\n }\n return forces;\n }\n getRepGraForces(iter: number, prevoIter: number, forces: number[], krPrime: number, sizes: number[], degrees: number[]) {\n const self = this;\n const { nodes, preventOverlap, kr, kg, center, prune } = self;\n const nodeNum = nodes.length;\n for (let i = 0; i < nodeNum; i += 1) {\n for (let j = i + 1; j < nodeNum; j += 1) {\n\n if (prune && (degrees[i] <= 1 || degrees[j] <= 1)) continue;\n\n let dir = [ nodes[j].x - nodes[i].x, nodes[j].y - nodes[i].y ];\n let eucliDis = Math.hypot(dir[0], dir[1]);\n eucliDis = eucliDis < 0.0001 ? 0.0001 : eucliDis;\n dir[0] = dir[0] / eucliDis;\n dir[1] = dir[1] / eucliDis;\n\n if (preventOverlap && iter < prevoIter) eucliDis = eucliDis - sizes[i] - sizes[j];\n\n let Fr = kr * (degrees[i] + 1) * (degrees[j] + 1) / eucliDis;\n\n if (preventOverlap && iter < prevoIter && eucliDis < 0) {\n Fr = krPrime * (degrees[i] + 1) * (degrees[j] + 1);\n } else if (preventOverlap && iter < prevoIter && eucliDis === 0) {\n Fr = 0;\n } else if (preventOverlap && iter < prevoIter && eucliDis > 0) {\n Fr = kr * (degrees[i] + 1) * (degrees[j] + 1) / eucliDis;\n }\n forces[2 * i] -= Fr * dir[0];\n forces[2 * j] += Fr * dir[0];\n forces[2 * i + 1] -= Fr * dir[1];\n forces[2 * j + 1] += Fr * dir[1];\n }\n\n // gravity\n let dir = [ nodes[i].x - center[0], nodes[i].y - center[1] ];\n const eucliDis = Math.hypot(dir[0], dir[1]);\n dir[0] = dir[0] / eucliDis;\n dir[1] = dir[1] / eucliDis;\n const Fg = kg * (degrees[i] + 1);\n forces[2 * i] -= Fg * dir[0];\n forces[2 * i + 1] -= Fg * dir[1];\n }\n return forces;\n }\n\n getOptRepGraForces(forces: number[], bodies: any, degrees: number[]) {\n const self = this;\n const { nodes, kg, center, prune } = self;\n const nodeNum = nodes.length;\n let minx = 9e10,\n maxx = -9e10,\n miny = 9e10,\n maxy = -9e10;\n for (let i = 0; i < nodeNum; i += 1) {\n if (prune && (degrees[i] <= 1)) continue;\n bodies[i].setPos(nodes[i].x, nodes[i].y);\n if (nodes[i].x >= maxx) maxx = nodes[i].x;\n if (nodes[i].x <= minx) minx = nodes[i].x;\n if (nodes[i].y >= maxy) maxy = nodes[i].y;\n if (nodes[i].y <= miny) miny = nodes[i].y;\n }\n\n let width = Math.max(maxx - minx, maxy - miny);\n\n let quadParams = {\n xmid: (maxx + minx) / 2,\n ymid: (maxy + miny) / 2,\n length: width,\n massCenter: center,\n mass: nodeNum\n };\n let quad = new Quad(quadParams);\n let quadTree = new QuadTree(quad);\n\n // build the tree, insert the nodes(quads) into the tree\n for (let i = 0; i < nodeNum; i += 1) {\n\n if (prune && (degrees[i] <= 1)) continue;\n\n if (bodies[i].in(quad)) quadTree.insert(bodies[i]);\n }\n // update the repulsive forces and the gravity.\n for (let i = 0; i < nodeNum; i += 1) {\n\n if (prune && (degrees[i] <= 1)) continue;\n\n bodies[i].resetForce();\n quadTree.updateForce(bodies[i]);\n forces[2 * i] -= bodies[i].fx;\n forces[2 * i + 1] -= bodies[i].fy;\n\n // gravity\n let dir = [ nodes[i].x - center[0], nodes[i].y - center[1] ];\n let eucliDis = Math.hypot(dir[0], dir[1]);\n eucliDis = eucliDis < 0.0001 ? 0.0001 : eucliDis;\n dir[0] = dir[0] / eucliDis;\n dir[1] = dir[1] / eucliDis;\n let Fg = kg * (degrees[i] + 1);\n forces[2 * i] -= Fg * dir[0];\n forces[2 * i + 1] -= Fg * dir[1];\n }\n return forces;\n }\n\n updatePos(\n forces: number[],\n preForces: number[],\n sg: number,\n degrees: number[]\n ): { nodes: any, sg: number } {\n const self = this;\n let { nodes, ks, tao, prune, ksmax } = self;\n const nodeNum = nodes.length;\n let swgns = [];\n let trans = [];\n // swg(G) and tra(G)\n let swgG = 0;\n let traG = 0;\n for (let i = 0; i < nodeNum; i += 1) {\n\n if (prune && (degrees[i] <= 1)) continue;\n\n const minus = [ forces[2 * i] - preForces[2 * i],\n forces[2 * i + 1] - preForces[2 * i + 1]\n ];\n const minusNorm = Math.hypot(minus[0], minus[1]);\n const add = [ forces[2 * i] + preForces[2 * i],\n forces[2 * i + 1] + preForces[2 * i + 1]\n ];\n const addNorm = Math.hypot(add[0], add[1]);\n\n swgns[i] = minusNorm;\n trans[i] = addNorm / 2;\n\n swgG += (degrees[i] + 1) * swgns[i];\n traG += (degrees[i] + 1) * trans[i];\n }\n\n let preSG = sg;\n sg = tao * traG / swgG;\n if (preSG !== 0) {\n sg = sg > (1.5 * preSG) ? (1.5 * preSG) : sg;\n }\n // update the node positions\n for (let i = 0; i < nodeNum; i += 1) {\n\n if (prune && (degrees[i] <= 1)) continue;\n\n let sn = ks * sg / (1 + sg * Math.sqrt(swgns[i]));\n let absForce = Math.hypot(forces[2 * i], forces[2 * i + 1]);\n absForce = absForce < 0.0001 ? 0.0001 : absForce;\n const max = ksmax / absForce;\n sn = sn > max ? max : sn;\n const dnx = sn * forces[2 * i];\n const dny = sn * forces[2 * i + 1];\n nodes[i].x += dnx;\n nodes[i].y += dny;\n }\n return { nodes, sg };\n }\n}\n","import { Base } from \"./base\";\nimport { Model, ILayout } from \"./types\";\nimport { registerLayout, getLayoutByName } from \"../registy\";\n\nexport class Layout {\n public readonly layoutInstance: Base;\n\n constructor(options: ILayout.LayoutOptions) {\n const layoutClass = getLayoutByName(options.type as string);\n this.layoutInstance = new layoutClass(options);\n }\n\n layout(data: Model) {\n return this.layoutInstance.layout(data);\n }\n\n updateCfg(cfg: ILayout.LayoutOptions) {\n this.layoutInstance.updateCfg(cfg);\n }\n\n init(data: Model) {\n this.layoutInstance.init(data);\n }\n\n execute() {\n this.layoutInstance.execute();\n }\n\n getDefaultCfg() {\n return this.layoutInstance.getDefaultCfg();\n }\n\n destroy() {\n return this.layoutInstance.destroy();\n }\n}\n\n// FIXME\n// FOR G6\nexport const Layouts: { [key: string]: any } = new Proxy(\n {},\n {\n // tslint:disable-line\n get: (target, propKey) => {\n return getLayoutByName(propKey as string);\n },\n set: (target, propKey, value) => {\n registerLayout(propKey as string, value);\n return true;\n }\n }\n);\n"],"sourceRoot":""}
\No newline at end of file