{"version":3,"file":"shipSelection.bundle.js","mappings":"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","sources":["webpack://spacegame/./node_modules/complex.js/complex.js","webpack://spacegame/./node_modules/decimal.js/decimal.js","webpack://spacegame/./node_modules/detect-browser/es/index.js","webpack://spacegame/./node_modules/detect-gpu/dist/detect-gpu.esm.js","webpack://spacegame/./node_modules/escape-latex/dist/index.js","webpack://spacegame/./node_modules/fraction.js/fraction.js","webpack://spacegame/./node_modules/javascript-natural-sort/naturalSort.js","webpack://spacegame/./node_modules/seedrandom/index.js","webpack://spacegame/./node_modules/seedrandom/lib/alea.js","webpack://spacegame/./node_modules/seedrandom/lib/tychei.js","webpack://spacegame/./node_modules/seedrandom/lib/xor128.js","webpack://spacegame/./node_modules/seedrandom/lib/xor4096.js","webpack://spacegame/./node_modules/seedrandom/lib/xorshift7.js","webpack://spacegame/./node_modules/seedrandom/lib/xorwow.js","webpack://spacegame/./node_modules/seedrandom/seedrandom.js","webpack://spacegame/./node_modules/tiny-emitter/index.js","webpack://spacegame/./source/frontend/Browser.ts","webpack://spacegame/./source/home.ts","webpack://spacegame/./source/profile/Loadout.ts","webpack://spacegame/./source/resources.ts","webpack://spacegame/./source/utils.ts","webpack://spacegame/./node_modules/typed-function/typed-function.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/arrayLikeToArray.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/arrayWithHoles.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/arrayWithoutHoles.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/classCallCheck.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/createClass.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/defineProperty.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/extends.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/interopRequireDefault.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/iterableToArray.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/iterableToArrayLimit.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/nonIterableRest.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/nonIterableSpread.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/regeneratorRuntime.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/slicedToArray.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/toConsumableArray.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/typeof.js","webpack://spacegame/./node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js","webpack://spacegame/./node_modules/@babel/runtime/regenerator/index.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/constants.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/core/config.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/core/create.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/core/function/config.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/core/function/import.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/core/function/typed.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/allFactoriesAny.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/configReadonly.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAbs.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAccessorNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcos.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcosh.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcot.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcoth.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcsc.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAcsch.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAdd.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAddScalar.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAnd.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesApply.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesApplyTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesArg.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesArrayNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsec.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsech.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsin.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAsinh.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAssignmentNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtan.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtan2.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtanh.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAtomicMass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesAvogadro.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBellNumbers.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBigNumberClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBignumber.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBin.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitAnd.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitNot.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitOr.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBitXor.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBlockNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBohrMagneton.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBohrRadius.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBoltzmann.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesBoolean.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCatalan.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCbrt.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCeil.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesChain.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesChainClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesClassicalElectronRadius.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesClone.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesColumn.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesColumnTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCombinations.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCombinationsWithRep.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompare.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompareNatural.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompareText.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCompile.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesComplex.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesComplexClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesComposition.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConcat.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConcatTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConditionalNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConductanceQuantum.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConj.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesConstantNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCos.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCosh.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCot.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCoth.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCoulomb.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCount.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCreateUnit.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCross.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCsc.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCsch.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCtranspose.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCube.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCumSum.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesCumSumTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDeepEqual.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDenseMatrixClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDerivative.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDet.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDeuteronMass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDiag.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDiff.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDiffTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDistance.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDivide.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDivideScalar.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDot.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDotDivide.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDotMultiply.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesDotPow.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesE.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEfimovFactor.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEigs.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesElectricConstant.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesElectronMass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesElementaryCharge.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEqual.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEqualScalar.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEqualText.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesErf.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesEvaluate.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesExp.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesExpm.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesExpm1.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFactorial.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFalse.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFaraday.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFermiCoupling.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFft.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFibonacciHeapClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFilter.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFilterTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFineStructure.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFirstRadiation.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFix.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFlatten.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFloor.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesForEach.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesForEachTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFormat.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFraction.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFractionClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFunctionAssignmentNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesFunctionNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGamma.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGasConstant.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGcd.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGetMatrixDataType.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGravitationConstant.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesGravity.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHartreeEnergy.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHasNumericValue.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHelp.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHelpClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHex.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesHypot.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesI.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIdentity.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIfft.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIm.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesImmutableDenseMatrixClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndex.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndexClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndexNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIndexTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInfinity.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIntersect.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInv.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInverseConductanceQuantum.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesInvmod.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsInteger.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsNaN.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsNegative.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsNumeric.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsPositive.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsPrime.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesIsZero.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesKldivergence.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesKlitzing.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesKron.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLN10.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLN2.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLOG10E.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLOG2E.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLarger.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLargerEq.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLcm.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLeafCount.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLeftShift.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLgamma.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog10.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog1p.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLog2.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLoschmidt.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLsolve.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLsolveAll.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLup.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesLusolve.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMad.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMagneticConstant.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMagneticFluxQuantum.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMap.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMapTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrix.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixFromColumns.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixFromFunction.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMatrixFromRows.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMax.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMaxTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMean.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMeanTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMedian.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMin.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMinTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMod.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarMass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarMassC12.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarPlanckConstant.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMolarVolume.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMultinomial.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMultiply.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesMultiplyScalar.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNaN.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNeutronMass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNorm.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNot.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNthRoot.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNthRoots.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNuclearMagneton.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNull.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNumber.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesNumeric.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesObjectNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOct.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOnes.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOperatorNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesOr.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParenthesisNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParse.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParser.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesParserClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPartitionSelect.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPermutations.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPhi.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPi.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPickRandom.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPinv.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckCharge.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckConstant.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckLength.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckMass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckTemperature.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPlanckTime.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPow.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesPrint.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesProd.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesProtonMass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQr.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQuantileSeq.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesQuantumOfCirculation.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRandom.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRandomInt.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRange.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRangeClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRangeNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRangeTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRationalize.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRe.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReducedPlanckConstant.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRelationalNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReplacer.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReshape.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesResize.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesResolve.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesResultSet.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesReviver.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRightArithShift.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRightLogShift.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRotate.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRotationMatrix.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRound.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRow.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRowTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesRydberg.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSQRT1_2.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSQRT2.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSackurTetrode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSec.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSech.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSecondRadiation.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetCartesian.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetDifference.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetDistinct.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetIntersect.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetIsSubset.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetMultiplicity.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetPowerset.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetSize.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetSymDifference.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSetUnion.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSign.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSimplify.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSimplifyCore.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSin.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSinh.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSize.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSlu.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSmaller.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSmallerEq.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSort.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSpaClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSparse.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSparseMatrixClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSpeedOfLight.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSplitUnit.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSqrt.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSqrtm.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSquare.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSqueeze.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStd.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStdTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStefanBoltzmann.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesStirlingS2.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesString.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubset.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubsetTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSubtract.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSum.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSumTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSymbolNode.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesSymbolicEqual.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTan.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTanh.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTau.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesThomsonCrossSection.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTo.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTrace.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTranspose.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTrue.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTypeOf.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesTyped.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnaryMinus.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnaryPlus.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnequal.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnitClass.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUnitFunction.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUppercaseE.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUppercasePi.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUsolve.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesUsolveAll.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVacuumImpedance.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVariance.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVarianceTransform.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesVersion.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesWeakMixingAngle.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesWienDisplacement.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesXgcd.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesXor.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/dependenciesAny/dependenciesZeros.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/impureFunctionsAny.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/mainAny.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/pureFunctionsAny.generated.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/entry/typeChecks.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/error/ArgumentsError.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/error/DimensionError.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/error/IndexError.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/Help.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/Parser.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/Infinity.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LN10.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LN2.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LOG10E.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/LOG2E.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/NaN.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/SQRT1_2.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/SQRT2.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/e.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/false.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/i.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/null.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/phi.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/pi.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/tau.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/true.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/constants/version.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/bignumber.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/boolean.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/complex.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/createUnit.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/fraction.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/index.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/matrix.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/number.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/sparse.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/splitUnit.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/string.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/construction/unit.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/core/config.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/core/import.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/core/typed.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/embeddedDocs.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/derivative.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/leafCount.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lsolve.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lsolveAll.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lup.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/lusolve.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/qr.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/rationalize.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/resolve.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/simplify.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/simplifyCore.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/slu.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/symbolicEqual.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/usolve.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/algebra/usolveAll.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/abs.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/add.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/cbrt.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/ceil.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/cube.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/divide.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/dotDivide.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/dotMultiply.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/dotPow.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/exp.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/expm.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/expm1.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/fix.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/floor.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/gcd.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/hypot.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/invmod.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/lcm.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log10.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log1p.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/log2.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/mod.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/multiply.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/norm.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/nthRoot.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/nthRoots.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/pow.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/round.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/sign.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/sqrt.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/sqrtm.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/square.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/subtract.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/unaryMinus.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/unaryPlus.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/arithmetic/xgcd.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitAnd.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitNot.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitOr.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/bitXor.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/leftShift.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/rightArithShift.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/bitwise/rightLogShift.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/bellNumbers.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/catalan.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/composition.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/combinatorics/stirlingS2.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/arg.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/conj.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/im.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/complex/re.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/expression/evaluate.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/expression/help.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/geometry/distance.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/geometry/intersect.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/and.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/not.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/or.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/logical/xor.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/column.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/concat.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/count.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/cross.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/ctranspose.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/det.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/diag.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/diff.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/dot.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/eigs.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/fft.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/filter.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/flatten.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/forEach.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/getMatrixDataType.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/identity.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/ifft.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/inv.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/kron.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/map.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/matrixFromColumns.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/matrixFromFunction.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/matrixFromRows.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/ones.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/partitionSelect.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/pinv.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/range.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/reshape.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/resize.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/rotate.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/rotationMatrix.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/row.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/size.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/sort.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/squeeze.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/subset.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/trace.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/transpose.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/matrix/zeros.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/combinations.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/combinationsWithRep.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/factorial.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/gamma.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/kldivergence.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/lgamma.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/multinomial.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/permutations.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/pickRandom.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/random.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/probability/randomInt.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/compare.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/compareNatural.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/compareText.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/deepEqual.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/equal.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/equalText.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/larger.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/largerEq.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/smaller.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/smallerEq.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/relational/unequal.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setCartesian.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setDifference.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setDistinct.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setIntersect.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setIsSubset.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setMultiplicity.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setPowerset.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setSize.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setSymDifference.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/set/setUnion.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/special/erf.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/cumsum.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/mad.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/max.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/mean.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/median.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/min.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/mode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/prod.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/quantileSeq.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/std.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/sum.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/statistics/variance.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acos.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acosh.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acot.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acoth.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acsc.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/acsch.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asec.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asech.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asin.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/asinh.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/atan.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/atan2.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/atanh.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/cos.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/cosh.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/cot.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/coth.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/csc.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/csch.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sec.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sech.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sin.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/sinh.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/tan.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/trigonometry/tanh.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/units/to.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/bin.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/clone.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/format.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/hasNumericValue.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/hex.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isInteger.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isNaN.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isNegative.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isNumeric.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isPositive.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isPrime.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/isZero.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/numeric.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/oct.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/print.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/embeddedDocs/function/utils/typeOf.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/function/compile.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/function/evaluate.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/function/help.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/function/parser.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/keywords.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/AccessorNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/ArrayNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/AssignmentNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/BlockNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/ConditionalNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/ConstantNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/FunctionAssignmentNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/FunctionNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/IndexNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/Node.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/ObjectNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/OperatorNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/ParenthesisNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/RangeNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/RelationalNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/SymbolNode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/utils/access.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/node/utils/assign.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/operators.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/parse.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/apply.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/column.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/concat.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/cumsum.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/diff.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/filter.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/forEach.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/index.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/map.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/max.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/mean.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/min.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/range.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/row.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/std.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/subset.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/sum.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/utils/compileInlineExpression.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/utils/errorTransform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/utils/lastDimToZeroBase.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/expression/transform/variance.transform.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/factoriesAny.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/decomposition/lup.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/decomposition/qr.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/decomposition/slu.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/derivative.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/leafCount.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/rationalize.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/resolve.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/simplify.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/simplify/simplifyConstant.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/simplify/util.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/simplifyCore.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/solver/lsolve.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/solver/lsolveAll.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/solver/lusolve.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/solver/usolve.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/solver/usolveAll.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/solver/utils/solveValidation.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csAmd.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csCounts.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csDfs.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csEtree.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csFkeep.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csFlip.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csIpvec.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csLeaf.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csLu.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csMark.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csMarked.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csPermute.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csPost.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csReach.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csSpsolve.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csSqr.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csTdfs.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/sparse/csUnflip.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/algebra/symbolicEqual.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/abs.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/add.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/addScalar.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/cbrt.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/ceil.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/cube.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/divide.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/divideScalar.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/dotDivide.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/dotMultiply.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/dotPow.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/exp.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/expm1.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/fix.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/floor.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/gcd.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/hypot.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/invmod.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/lcm.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/log.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/log10.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/log1p.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/log2.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/mod.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/multiply.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/multiplyScalar.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/norm.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/nthRoot.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/nthRoots.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/pow.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/round.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/sign.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/sqrt.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/square.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/subtract.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/unaryMinus.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/unaryPlus.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/arithmetic/xgcd.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/bitwise/bitAnd.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/bitwise/bitNot.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/bitwise/bitOr.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/bitwise/bitXor.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/bitwise/leftShift.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/bitwise/rightArithShift.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/bitwise/rightLogShift.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/combinatorics/bellNumbers.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/combinatorics/catalan.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/combinatorics/composition.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/combinatorics/stirlingS2.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/complex/arg.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/complex/conj.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/complex/im.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/complex/re.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/geometry/distance.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/geometry/intersect.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/logical/and.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/logical/not.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/logical/or.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/logical/xor.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/apply.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/column.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/concat.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/count.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/cross.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/ctranspose.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/det.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/diag.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/diff.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/dot.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/eigs.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/eigs/complexEigs.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/eigs/realSymetric.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/expm.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/fft.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/filter.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/flatten.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/forEach.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/getMatrixDataType.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/identity.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/ifft.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/inv.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/kron.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/map.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/matrixFromColumns.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/matrixFromFunction.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/matrixFromRows.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/ones.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/partitionSelect.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/pinv.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/range.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/reshape.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/resize.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/rotate.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/rotationMatrix.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/row.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/size.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/sort.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/sqrtm.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/squeeze.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/subset.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/trace.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/transpose.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/matrix/zeros.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/combinations.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/combinationsWithRep.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/factorial.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/gamma.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/kldivergence.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/lgamma.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/multinomial.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/permutations.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/pickRandom.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/random.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/randomInt.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/util/randomMatrix.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/probability/util/seededRNG.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/relational/compare.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/relational/compareNatural.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/relational/compareText.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/relational/deepEqual.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/relational/equal.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/relational/equalScalar.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/relational/equalText.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/relational/larger.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/relational/largerEq.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/relational/smaller.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/relational/smallerEq.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/relational/unequal.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/set/setCartesian.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/set/setDifference.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/set/setDistinct.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/set/setIntersect.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/set/setIsSubset.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/set/setMultiplicity.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/set/setPowerset.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/set/setSize.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/set/setSymDifference.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/set/setUnion.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/special/erf.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/cumsum.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/mad.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/max.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/mean.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/median.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/min.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/mode.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/prod.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/quantileSeq.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/std.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/sum.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/utils/improveErrorMessage.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/statistics/variance.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/string/bin.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/string/format.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/string/hex.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/string/oct.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/string/print.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/acos.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/acosh.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/acot.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/acoth.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/acsc.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/acsch.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/asec.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/asech.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/asin.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/asinh.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/atan.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/atan2.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/atanh.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/cos.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/cosh.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/cot.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/coth.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/csc.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/csch.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/sec.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/sech.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/sin.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/sinh.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/tan.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/trigonometry/tanh.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/unit/to.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/utils/clone.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/utils/hasNumericValue.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/utils/isInteger.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/utils/isNaN.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/utils/isNegative.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/utils/isNumeric.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/utils/isPositive.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/utils/isPrime.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/utils/isZero.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/utils/numeric.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/function/utils/typeOf.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/index.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/json/replacer.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/json/reviver.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/plain/number/arithmetic.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/plain/number/bitwise.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/plain/number/combinations.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/plain/number/constants.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/plain/number/index.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/plain/number/logical.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/plain/number/probability.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/plain/number/trigonometry.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/plain/number/utils.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/bignumber/BigNumber.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/bignumber/function/bignumber.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/boolean.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/chain/Chain.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/chain/function/chain.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/complex/Complex.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/complex/function/complex.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/fraction/Fraction.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/fraction/function/fraction.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/DenseMatrix.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/FibonacciHeap.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/ImmutableDenseMatrix.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/Matrix.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/MatrixIndex.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/Range.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/Spa.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/SparseMatrix.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/function/index.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/function/matrix.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/function/sparse.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm01.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm02.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm03.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm04.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm05.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm06.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm07.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm08.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm09.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm10.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm11.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm12.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm13.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/matrix/utils/algorithm14.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/number.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/resultset/ResultSet.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/string.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/unit/Unit.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/unit/function/createUnit.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/unit/function/splitUnit.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/unit/function/unit.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/type/unit/physicalConstants.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/array.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/bignumber/bitwise.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/bignumber/constants.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/bignumber/formatter.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/bignumber/nearlyEqual.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/collection.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/complex.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/customs.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/emitter.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/factory.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/function.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/is.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/latex.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/lruQueue.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/map.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/noop.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/number.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/object.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/polyfills.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/product.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/scope.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/string.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/utils/switch.js","webpack://spacegame/./node_modules/mathjs/lib/cjs/version.js","webpack://spacegame/./node_modules/three/build/three.cjs","webpack://spacegame/./node_modules/three/build/three.module.js","webpack://spacegame/./node_modules/three/examples/jsm/loaders/FontLoader.js","webpack://spacegame/./node_modules/three/examples/jsm/loaders/GLTFLoader.js","webpack://spacegame/webpack/bootstrap","webpack://spacegame/webpack/runtime/amd define","webpack://spacegame/webpack/runtime/amd options","webpack://spacegame/webpack/runtime/define property getters","webpack://spacegame/webpack/runtime/hasOwnProperty shorthand","webpack://spacegame/webpack/runtime/make namespace object","webpack://spacegame/webpack/runtime/node module decorator","webpack://spacegame/webpack/startup"],"sourcesContent":["/**\n * @license Complex.js v2.1.1 12/05/2020\n *\n * Copyright (c) 2020, Robert Eisele (robert@xarg.org)\n * Dual licensed under the MIT or GPL Version 2 licenses.\n **/\n\n/**\n *\n * This class allows the manipulation of complex numbers.\n * You can pass a complex number in different formats. Either as object, double, string or two integer parameters.\n *\n * Object form\n * { re: , im: }\n * { arg: , abs: }\n * { phi: , r: }\n *\n * Array / Vector form\n * [ real, imaginary ]\n *\n * Double form\n * 99.3 - Single double value\n *\n * String form\n * '23.1337' - Simple real number\n * '15+3i' - a simple complex number\n * '3-i' - a simple complex number\n *\n * Example:\n *\n * var c = new Complex('99.3+8i');\n * c.mul({r: 3, i: 9}).div(4.9).sub(3, 2);\n *\n */\n\n(function(root) {\n\n 'use strict';\n\n var cosh = Math.cosh || function(x) {\n return Math.abs(x) < 1e-9 ? 1 - x : (Math.exp(x) + Math.exp(-x)) * 0.5;\n };\n\n var sinh = Math.sinh || function(x) {\n return Math.abs(x) < 1e-9 ? x : (Math.exp(x) - Math.exp(-x)) * 0.5;\n };\n\n /**\n * Calculates cos(x) - 1 using Taylor series if x is small (-¼π ≤ x ≤ ¼π).\n *\n * @param {number} x\n * @returns {number} cos(x) - 1\n */\n var cosm1 = function(x) {\n\n var b = Math.PI / 4;\n if (-b > x || x > b) {\n return Math.cos(x) - 1.0;\n }\n\n /* Calculate horner form of polynomial of taylor series in Q\n var fac = 1, alt = 1, pol = {};\n for (var i = 0; i <= 16; i++) {\n fac*= i || 1;\n if (i % 2 == 0) {\n pol[i] = new Fraction(1, alt * fac);\n alt = -alt;\n }\n }\n console.log(new Polynomial(pol).toHorner()); // (((((((1/20922789888000x^2-1/87178291200)x^2+1/479001600)x^2-1/3628800)x^2+1/40320)x^2-1/720)x^2+1/24)x^2-1/2)x^2+1\n */\n\n var xx = x * x;\n return xx * (\n xx * (\n xx * (\n xx * (\n xx * (\n xx * (\n xx * (\n xx / 20922789888000\n - 1 / 87178291200)\n + 1 / 479001600)\n - 1 / 3628800)\n + 1 / 40320)\n - 1 / 720)\n + 1 / 24)\n - 1 / 2);\n };\n\n var hypot = function(x, y) {\n\n var a = Math.abs(x);\n var b = Math.abs(y);\n\n if (a < 3000 && b < 3000) {\n return Math.sqrt(a * a + b * b);\n }\n\n if (a < b) {\n a = b;\n b = x / y;\n } else {\n b = y / x;\n }\n return a * Math.sqrt(1 + b * b);\n };\n\n var parser_exit = function() {\n throw SyntaxError('Invalid Param');\n };\n\n /**\n * Calculates log(sqrt(a^2+b^2)) in a way to avoid overflows\n *\n * @param {number} a\n * @param {number} b\n * @returns {number}\n */\n function logHypot(a, b) {\n\n var _a = Math.abs(a);\n var _b = Math.abs(b);\n\n if (a === 0) {\n return Math.log(_b);\n }\n\n if (b === 0) {\n return Math.log(_a);\n }\n\n if (_a < 3000 && _b < 3000) {\n return Math.log(a * a + b * b) * 0.5;\n }\n\n /* I got 4 ideas to compute this property without overflow:\n *\n * Testing 1000000 times with random samples for a,b ∈ [1, 1000000000] against a big decimal library to get an error estimate\n *\n * 1. Only eliminate the square root: (OVERALL ERROR: 3.9122483030951116e-11)\n\n Math.log(a * a + b * b) / 2\n\n *\n *\n * 2. Try to use the non-overflowing pythagoras: (OVERALL ERROR: 8.889760039210159e-10)\n\n var fn = function(a, b) {\n a = Math.abs(a);\n b = Math.abs(b);\n var t = Math.min(a, b);\n a = Math.max(a, b);\n t = t / a;\n\n return Math.log(a) + Math.log(1 + t * t) / 2;\n };\n\n * 3. Abuse the identity cos(atan(y/x) = x / sqrt(x^2+y^2): (OVERALL ERROR: 3.4780178737037204e-10)\n\n Math.log(a / Math.cos(Math.atan2(b, a)))\n\n * 4. Use 3. and apply log rules: (OVERALL ERROR: 1.2014087502620896e-9)\n\n Math.log(a) - Math.log(Math.cos(Math.atan2(b, a)))\n\n */\n\n a = a / 2;\n b = b / 2;\n\n return 0.5 * Math.log(a * a + b * b) + Math.LN2;\n }\n\n var parse = function(a, b) {\n\n var z = { 're': 0, 'im': 0 };\n\n if (a === undefined || a === null) {\n z['re'] =\n z['im'] = 0;\n } else if (b !== undefined) {\n z['re'] = a;\n z['im'] = b;\n } else\n switch (typeof a) {\n\n case 'object':\n\n if ('im' in a && 're' in a) {\n z['re'] = a['re'];\n z['im'] = a['im'];\n } else if ('abs' in a && 'arg' in a) {\n if (!Number.isFinite(a['abs']) && Number.isFinite(a['arg'])) {\n return Complex['INFINITY'];\n }\n z['re'] = a['abs'] * Math.cos(a['arg']);\n z['im'] = a['abs'] * Math.sin(a['arg']);\n } else if ('r' in a && 'phi' in a) {\n if (!Number.isFinite(a['r']) && Number.isFinite(a['phi'])) {\n return Complex['INFINITY'];\n }\n z['re'] = a['r'] * Math.cos(a['phi']);\n z['im'] = a['r'] * Math.sin(a['phi']);\n } else if (a.length === 2) { // Quick array check\n z['re'] = a[0];\n z['im'] = a[1];\n } else {\n parser_exit();\n }\n break;\n\n case 'string':\n\n z['im'] = /* void */\n z['re'] = 0;\n\n var tokens = a.match(/\\d+\\.?\\d*e[+-]?\\d+|\\d+\\.?\\d*|\\.\\d+|./g);\n var plus = 1;\n var minus = 0;\n\n if (tokens === null) {\n parser_exit();\n }\n\n for (var i = 0; i < tokens.length; i++) {\n\n var c = tokens[i];\n\n if (c === ' ' || c === '\\t' || c === '\\n') {\n /* void */\n } else if (c === '+') {\n plus++;\n } else if (c === '-') {\n minus++;\n } else if (c === 'i' || c === 'I') {\n\n if (plus + minus === 0) {\n parser_exit();\n }\n\n if (tokens[i + 1] !== ' ' && !isNaN(tokens[i + 1])) {\n z['im'] += parseFloat((minus % 2 ? '-' : '') + tokens[i + 1]);\n i++;\n } else {\n z['im'] += parseFloat((minus % 2 ? '-' : '') + '1');\n }\n plus = minus = 0;\n\n } else {\n\n if (plus + minus === 0 || isNaN(c)) {\n parser_exit();\n }\n\n if (tokens[i + 1] === 'i' || tokens[i + 1] === 'I') {\n z['im'] += parseFloat((minus % 2 ? '-' : '') + c);\n i++;\n } else {\n z['re'] += parseFloat((minus % 2 ? '-' : '') + c);\n }\n plus = minus = 0;\n }\n }\n\n // Still something on the stack\n if (plus + minus > 0) {\n parser_exit();\n }\n break;\n\n case 'number':\n z['im'] = 0;\n z['re'] = a;\n break;\n\n default:\n parser_exit();\n }\n\n if (isNaN(z['re']) || isNaN(z['im'])) {\n // If a calculation is NaN, we treat it as NaN and don't throw\n //parser_exit();\n }\n\n return z;\n };\n\n /**\n * @constructor\n * @returns {Complex}\n */\n function Complex(a, b) {\n\n if (!(this instanceof Complex)) {\n return new Complex(a, b);\n }\n\n var z = parse(a, b);\n\n this['re'] = z['re'];\n this['im'] = z['im'];\n }\n\n Complex.prototype = {\n\n 're': 0,\n 'im': 0,\n\n /**\n * Calculates the sign of a complex number, which is a normalized complex\n *\n * @returns {Complex}\n */\n 'sign': function() {\n\n var abs = this['abs']();\n\n return new Complex(\n this['re'] / abs,\n this['im'] / abs);\n },\n\n /**\n * Adds two complex numbers\n *\n * @returns {Complex}\n */\n 'add': function(a, b) {\n\n var z = new Complex(a, b);\n\n // Infinity + Infinity = NaN\n if (this['isInfinite']() && z['isInfinite']()) {\n return Complex['NAN'];\n }\n\n // Infinity + z = Infinity { where z != Infinity }\n if (this['isInfinite']() || z['isInfinite']()) {\n return Complex['INFINITY'];\n }\n\n return new Complex(\n this['re'] + z['re'],\n this['im'] + z['im']);\n },\n\n /**\n * Subtracts two complex numbers\n *\n * @returns {Complex}\n */\n 'sub': function(a, b) {\n\n var z = new Complex(a, b);\n\n // Infinity - Infinity = NaN\n if (this['isInfinite']() && z['isInfinite']()) {\n return Complex['NAN'];\n }\n\n // Infinity - z = Infinity { where z != Infinity }\n if (this['isInfinite']() || z['isInfinite']()) {\n return Complex['INFINITY'];\n }\n\n return new Complex(\n this['re'] - z['re'],\n this['im'] - z['im']);\n },\n\n /**\n * Multiplies two complex numbers\n *\n * @returns {Complex}\n */\n 'mul': function(a, b) {\n\n var z = new Complex(a, b);\n\n // Infinity * 0 = NaN\n if ((this['isInfinite']() && z['isZero']()) || (this['isZero']() && z['isInfinite']())) {\n return Complex['NAN'];\n }\n\n // Infinity * z = Infinity { where z != 0 }\n if (this['isInfinite']() || z['isInfinite']()) {\n return Complex['INFINITY'];\n }\n\n // Short circuit for real values\n if (z['im'] === 0 && this['im'] === 0) {\n return new Complex(this['re'] * z['re'], 0);\n }\n\n return new Complex(\n this['re'] * z['re'] - this['im'] * z['im'],\n this['re'] * z['im'] + this['im'] * z['re']);\n },\n\n /**\n * Divides two complex numbers\n *\n * @returns {Complex}\n */\n 'div': function(a, b) {\n\n var z = new Complex(a, b);\n\n // 0 / 0 = NaN and Infinity / Infinity = NaN\n if ((this['isZero']() && z['isZero']()) || (this['isInfinite']() && z['isInfinite']())) {\n return Complex['NAN'];\n }\n\n // Infinity / 0 = Infinity\n if (this['isInfinite']() || z['isZero']()) {\n return Complex['INFINITY'];\n }\n\n // 0 / Infinity = 0\n if (this['isZero']() || z['isInfinite']()) {\n return Complex['ZERO'];\n }\n\n a = this['re'];\n b = this['im'];\n\n var c = z['re'];\n var d = z['im'];\n var t, x;\n\n if (0 === d) {\n // Divisor is real\n return new Complex(a / c, b / c);\n }\n\n if (Math.abs(c) < Math.abs(d)) {\n\n x = c / d;\n t = c * x + d;\n\n return new Complex(\n (a * x + b) / t,\n (b * x - a) / t);\n\n } else {\n\n x = d / c;\n t = d * x + c;\n\n return new Complex(\n (a + b * x) / t,\n (b - a * x) / t);\n }\n },\n\n /**\n * Calculate the power of two complex numbers\n *\n * @returns {Complex}\n */\n 'pow': function(a, b) {\n\n var z = new Complex(a, b);\n\n a = this['re'];\n b = this['im'];\n\n if (z['isZero']()) {\n return Complex['ONE'];\n }\n\n // If the exponent is real\n if (z['im'] === 0) {\n\n if (b === 0 && a > 0) {\n\n return new Complex(Math.pow(a, z['re']), 0);\n\n } else if (a === 0) { // If base is fully imaginary\n\n switch ((z['re'] % 4 + 4) % 4) {\n case 0:\n return new Complex(Math.pow(b, z['re']), 0);\n case 1:\n return new Complex(0, Math.pow(b, z['re']));\n case 2:\n return new Complex(-Math.pow(b, z['re']), 0);\n case 3:\n return new Complex(0, -Math.pow(b, z['re']));\n }\n }\n }\n\n /* I couldn't find a good formula, so here is a derivation and optimization\n *\n * z_1^z_2 = (a + bi)^(c + di)\n * = exp((c + di) * log(a + bi)\n * = pow(a^2 + b^2, (c + di) / 2) * exp(i(c + di)atan2(b, a))\n * =>...\n * Re = (pow(a^2 + b^2, c / 2) * exp(-d * atan2(b, a))) * cos(d * log(a^2 + b^2) / 2 + c * atan2(b, a))\n * Im = (pow(a^2 + b^2, c / 2) * exp(-d * atan2(b, a))) * sin(d * log(a^2 + b^2) / 2 + c * atan2(b, a))\n *\n * =>...\n * Re = exp(c * log(sqrt(a^2 + b^2)) - d * atan2(b, a)) * cos(d * log(sqrt(a^2 + b^2)) + c * atan2(b, a))\n * Im = exp(c * log(sqrt(a^2 + b^2)) - d * atan2(b, a)) * sin(d * log(sqrt(a^2 + b^2)) + c * atan2(b, a))\n *\n * =>\n * Re = exp(c * logsq2 - d * arg(z_1)) * cos(d * logsq2 + c * arg(z_1))\n * Im = exp(c * logsq2 - d * arg(z_1)) * sin(d * logsq2 + c * arg(z_1))\n *\n */\n\n if (a === 0 && b === 0 && z['re'] > 0 && z['im'] >= 0) {\n return Complex['ZERO'];\n }\n\n var arg = Math.atan2(b, a);\n var loh = logHypot(a, b);\n\n a = Math.exp(z['re'] * loh - z['im'] * arg);\n b = z['im'] * loh + z['re'] * arg;\n return new Complex(\n a * Math.cos(b),\n a * Math.sin(b));\n },\n\n /**\n * Calculate the complex square root\n *\n * @returns {Complex}\n */\n 'sqrt': function() {\n\n var a = this['re'];\n var b = this['im'];\n var r = this['abs']();\n\n var re, im;\n\n if (a >= 0) {\n\n if (b === 0) {\n return new Complex(Math.sqrt(a), 0);\n }\n\n re = 0.5 * Math.sqrt(2.0 * (r + a));\n } else {\n re = Math.abs(b) / Math.sqrt(2 * (r - a));\n }\n\n if (a <= 0) {\n im = 0.5 * Math.sqrt(2.0 * (r - a));\n } else {\n im = Math.abs(b) / Math.sqrt(2 * (r + a));\n }\n\n return new Complex(re, b < 0 ? -im : im);\n },\n\n /**\n * Calculate the complex exponent\n *\n * @returns {Complex}\n */\n 'exp': function() {\n\n var tmp = Math.exp(this['re']);\n\n if (this['im'] === 0) {\n //return new Complex(tmp, 0);\n }\n return new Complex(\n tmp * Math.cos(this['im']),\n tmp * Math.sin(this['im']));\n },\n\n /**\n * Calculate the complex exponent and subtracts one.\n *\n * This may be more accurate than `Complex(x).exp().sub(1)` if\n * `x` is small.\n *\n * @returns {Complex}\n */\n 'expm1': function() {\n\n /**\n * exp(a + i*b) - 1\n = exp(a) * (cos(b) + j*sin(b)) - 1\n = expm1(a)*cos(b) + cosm1(b) + j*exp(a)*sin(b)\n */\n\n var a = this['re'];\n var b = this['im'];\n\n return new Complex(\n Math.expm1(a) * Math.cos(b) + cosm1(b),\n Math.exp(a) * Math.sin(b));\n },\n\n /**\n * Calculate the natural log\n *\n * @returns {Complex}\n */\n 'log': function() {\n\n var a = this['re'];\n var b = this['im'];\n\n if (b === 0 && a > 0) {\n //return new Complex(Math.log(a), 0);\n }\n\n return new Complex(\n logHypot(a, b),\n Math.atan2(b, a));\n },\n\n /**\n * Calculate the magnitude of the complex number\n *\n * @returns {number}\n */\n 'abs': function() {\n\n return hypot(this['re'], this['im']);\n },\n\n /**\n * Calculate the angle of the complex number\n *\n * @returns {number}\n */\n 'arg': function() {\n\n return Math.atan2(this['im'], this['re']);\n },\n\n /**\n * Calculate the sine of the complex number\n *\n * @returns {Complex}\n */\n 'sin': function() {\n\n // sin(z) = ( e^iz - e^-iz ) / 2i \n // = sin(a)cosh(b) + i cos(a)sinh(b)\n\n var a = this['re'];\n var b = this['im'];\n\n return new Complex(\n Math.sin(a) * cosh(b),\n Math.cos(a) * sinh(b));\n },\n\n /**\n * Calculate the cosine\n *\n * @returns {Complex}\n */\n 'cos': function() {\n\n // cos(z) = ( e^iz + e^-iz ) / 2 \n // = cos(a)cosh(b) - i sin(a)sinh(b)\n\n var a = this['re'];\n var b = this['im'];\n\n return new Complex(\n Math.cos(a) * cosh(b),\n -Math.sin(a) * sinh(b));\n },\n\n /**\n * Calculate the tangent\n *\n * @returns {Complex}\n */\n 'tan': function() {\n\n // tan(z) = sin(z) / cos(z) \n // = ( e^iz - e^-iz ) / ( i( e^iz + e^-iz ) )\n // = ( e^2iz - 1 ) / i( e^2iz + 1 )\n // = ( sin(2a) + i sinh(2b) ) / ( cos(2a) + cosh(2b) )\n\n var a = 2 * this['re'];\n var b = 2 * this['im'];\n var d = Math.cos(a) + cosh(b);\n\n return new Complex(\n Math.sin(a) / d,\n sinh(b) / d);\n },\n\n /**\n * Calculate the cotangent\n *\n * @returns {Complex}\n */\n 'cot': function() {\n\n // cot(c) = i(e^(ci) + e^(-ci)) / (e^(ci) - e^(-ci))\n\n var a = 2 * this['re'];\n var b = 2 * this['im'];\n var d = Math.cos(a) - cosh(b);\n\n return new Complex(\n -Math.sin(a) / d,\n sinh(b) / d);\n },\n\n /**\n * Calculate the secant\n *\n * @returns {Complex}\n */\n 'sec': function() {\n\n // sec(c) = 2 / (e^(ci) + e^(-ci))\n\n var a = this['re'];\n var b = this['im'];\n var d = 0.5 * cosh(2 * b) + 0.5 * Math.cos(2 * a);\n\n return new Complex(\n Math.cos(a) * cosh(b) / d,\n Math.sin(a) * sinh(b) / d);\n },\n\n /**\n * Calculate the cosecans\n *\n * @returns {Complex}\n */\n 'csc': function() {\n\n // csc(c) = 2i / (e^(ci) - e^(-ci))\n\n var a = this['re'];\n var b = this['im'];\n var d = 0.5 * cosh(2 * b) - 0.5 * Math.cos(2 * a);\n\n return new Complex(\n Math.sin(a) * cosh(b) / d,\n -Math.cos(a) * sinh(b) / d);\n },\n\n /**\n * Calculate the complex arcus sinus\n *\n * @returns {Complex}\n */\n 'asin': function() {\n\n // asin(c) = -i * log(ci + sqrt(1 - c^2))\n\n var a = this['re'];\n var b = this['im'];\n\n var t1 = new Complex(\n b * b - a * a + 1,\n -2 * a * b)['sqrt']();\n\n var t2 = new Complex(\n t1['re'] - b,\n t1['im'] + a)['log']();\n\n return new Complex(t2['im'], -t2['re']);\n },\n\n /**\n * Calculate the complex arcus cosinus\n *\n * @returns {Complex}\n */\n 'acos': function() {\n\n // acos(c) = i * log(c - i * sqrt(1 - c^2))\n\n var a = this['re'];\n var b = this['im'];\n\n var t1 = new Complex(\n b * b - a * a + 1,\n -2 * a * b)['sqrt']();\n\n var t2 = new Complex(\n t1['re'] - b,\n t1['im'] + a)['log']();\n\n return new Complex(Math.PI / 2 - t2['im'], t2['re']);\n },\n\n /**\n * Calculate the complex arcus tangent\n *\n * @returns {Complex}\n */\n 'atan': function() {\n\n // atan(c) = i / 2 log((i + x) / (i - x))\n\n var a = this['re'];\n var b = this['im'];\n\n if (a === 0) {\n\n if (b === 1) {\n return new Complex(0, Infinity);\n }\n\n if (b === -1) {\n return new Complex(0, -Infinity);\n }\n }\n\n var d = a * a + (1.0 - b) * (1.0 - b);\n\n var t1 = new Complex(\n (1 - b * b - a * a) / d,\n -2 * a / d).log();\n\n return new Complex(-0.5 * t1['im'], 0.5 * t1['re']);\n },\n\n /**\n * Calculate the complex arcus cotangent\n *\n * @returns {Complex}\n */\n 'acot': function() {\n\n // acot(c) = i / 2 log((c - i) / (c + i))\n\n var a = this['re'];\n var b = this['im'];\n\n if (b === 0) {\n return new Complex(Math.atan2(1, a), 0);\n }\n\n var d = a * a + b * b;\n return (d !== 0)\n ? new Complex(\n a / d,\n -b / d).atan()\n : new Complex(\n (a !== 0) ? a / 0 : 0,\n (b !== 0) ? -b / 0 : 0).atan();\n },\n\n /**\n * Calculate the complex arcus secant\n *\n * @returns {Complex}\n */\n 'asec': function() {\n\n // asec(c) = -i * log(1 / c + sqrt(1 - i / c^2))\n\n var a = this['re'];\n var b = this['im'];\n\n if (a === 0 && b === 0) {\n return new Complex(0, Infinity);\n }\n\n var d = a * a + b * b;\n return (d !== 0)\n ? new Complex(\n a / d,\n -b / d).acos()\n : new Complex(\n (a !== 0) ? a / 0 : 0,\n (b !== 0) ? -b / 0 : 0).acos();\n },\n\n /**\n * Calculate the complex arcus cosecans\n *\n * @returns {Complex}\n */\n 'acsc': function() {\n\n // acsc(c) = -i * log(i / c + sqrt(1 - 1 / c^2))\n\n var a = this['re'];\n var b = this['im'];\n\n if (a === 0 && b === 0) {\n return new Complex(Math.PI / 2, Infinity);\n }\n\n var d = a * a + b * b;\n return (d !== 0)\n ? new Complex(\n a / d,\n -b / d).asin()\n : new Complex(\n (a !== 0) ? a / 0 : 0,\n (b !== 0) ? -b / 0 : 0).asin();\n },\n\n /**\n * Calculate the complex sinh\n *\n * @returns {Complex}\n */\n 'sinh': function() {\n\n // sinh(c) = (e^c - e^-c) / 2\n\n var a = this['re'];\n var b = this['im'];\n\n return new Complex(\n sinh(a) * Math.cos(b),\n cosh(a) * Math.sin(b));\n },\n\n /**\n * Calculate the complex cosh\n *\n * @returns {Complex}\n */\n 'cosh': function() {\n\n // cosh(c) = (e^c + e^-c) / 2\n\n var a = this['re'];\n var b = this['im'];\n\n return new Complex(\n cosh(a) * Math.cos(b),\n sinh(a) * Math.sin(b));\n },\n\n /**\n * Calculate the complex tanh\n *\n * @returns {Complex}\n */\n 'tanh': function() {\n\n // tanh(c) = (e^c - e^-c) / (e^c + e^-c)\n\n var a = 2 * this['re'];\n var b = 2 * this['im'];\n var d = cosh(a) + Math.cos(b);\n\n return new Complex(\n sinh(a) / d,\n Math.sin(b) / d);\n },\n\n /**\n * Calculate the complex coth\n *\n * @returns {Complex}\n */\n 'coth': function() {\n\n // coth(c) = (e^c + e^-c) / (e^c - e^-c)\n\n var a = 2 * this['re'];\n var b = 2 * this['im'];\n var d = cosh(a) - Math.cos(b);\n\n return new Complex(\n sinh(a) / d,\n -Math.sin(b) / d);\n },\n\n /**\n * Calculate the complex coth\n *\n * @returns {Complex}\n */\n 'csch': function() {\n\n // csch(c) = 2 / (e^c - e^-c)\n\n var a = this['re'];\n var b = this['im'];\n var d = Math.cos(2 * b) - cosh(2 * a);\n\n return new Complex(\n -2 * sinh(a) * Math.cos(b) / d,\n 2 * cosh(a) * Math.sin(b) / d);\n },\n\n /**\n * Calculate the complex sech\n *\n * @returns {Complex}\n */\n 'sech': function() {\n\n // sech(c) = 2 / (e^c + e^-c)\n\n var a = this['re'];\n var b = this['im'];\n var d = Math.cos(2 * b) + cosh(2 * a);\n\n return new Complex(\n 2 * cosh(a) * Math.cos(b) / d,\n -2 * sinh(a) * Math.sin(b) / d);\n },\n\n /**\n * Calculate the complex asinh\n *\n * @returns {Complex}\n */\n 'asinh': function() {\n\n // asinh(c) = log(c + sqrt(c^2 + 1))\n\n var tmp = this['im'];\n this['im'] = -this['re'];\n this['re'] = tmp;\n var res = this['asin']();\n\n this['re'] = -this['im'];\n this['im'] = tmp;\n tmp = res['re'];\n\n res['re'] = -res['im'];\n res['im'] = tmp;\n return res;\n },\n\n /**\n * Calculate the complex acosh\n *\n * @returns {Complex}\n */\n 'acosh': function() {\n\n // acosh(c) = log(c + sqrt(c^2 - 1))\n\n var res = this['acos']();\n if (res['im'] <= 0) {\n var tmp = res['re'];\n res['re'] = -res['im'];\n res['im'] = tmp;\n } else {\n var tmp = res['im'];\n res['im'] = -res['re'];\n res['re'] = tmp;\n }\n return res;\n },\n\n /**\n * Calculate the complex atanh\n *\n * @returns {Complex}\n */\n 'atanh': function() {\n\n // atanh(c) = log((1+c) / (1-c)) / 2\n\n var a = this['re'];\n var b = this['im'];\n\n var noIM = a > 1 && b === 0;\n var oneMinus = 1 - a;\n var onePlus = 1 + a;\n var d = oneMinus * oneMinus + b * b;\n\n var x = (d !== 0)\n ? new Complex(\n (onePlus * oneMinus - b * b) / d,\n (b * oneMinus + onePlus * b) / d)\n : new Complex(\n (a !== -1) ? (a / 0) : 0,\n (b !== 0) ? (b / 0) : 0);\n\n var temp = x['re'];\n x['re'] = logHypot(x['re'], x['im']) / 2;\n x['im'] = Math.atan2(x['im'], temp) / 2;\n if (noIM) {\n x['im'] = -x['im'];\n }\n return x;\n },\n\n /**\n * Calculate the complex acoth\n *\n * @returns {Complex}\n */\n 'acoth': function() {\n\n // acoth(c) = log((c+1) / (c-1)) / 2\n\n var a = this['re'];\n var b = this['im'];\n\n if (a === 0 && b === 0) {\n return new Complex(0, Math.PI / 2);\n }\n\n var d = a * a + b * b;\n return (d !== 0)\n ? new Complex(\n a / d,\n -b / d).atanh()\n : new Complex(\n (a !== 0) ? a / 0 : 0,\n (b !== 0) ? -b / 0 : 0).atanh();\n },\n\n /**\n * Calculate the complex acsch\n *\n * @returns {Complex}\n */\n 'acsch': function() {\n\n // acsch(c) = log((1+sqrt(1+c^2))/c)\n\n var a = this['re'];\n var b = this['im'];\n\n if (b === 0) {\n\n return new Complex(\n (a !== 0)\n ? Math.log(a + Math.sqrt(a * a + 1))\n : Infinity, 0);\n }\n\n var d = a * a + b * b;\n return (d !== 0)\n ? new Complex(\n a / d,\n -b / d).asinh()\n : new Complex(\n (a !== 0) ? a / 0 : 0,\n (b !== 0) ? -b / 0 : 0).asinh();\n },\n\n /**\n * Calculate the complex asech\n *\n * @returns {Complex}\n */\n 'asech': function() {\n\n // asech(c) = log((1+sqrt(1-c^2))/c)\n\n var a = this['re'];\n var b = this['im'];\n\n if (this['isZero']()) {\n return Complex['INFINITY'];\n }\n\n var d = a * a + b * b;\n return (d !== 0)\n ? new Complex(\n a / d,\n -b / d).acosh()\n : new Complex(\n (a !== 0) ? a / 0 : 0,\n (b !== 0) ? -b / 0 : 0).acosh();\n },\n\n /**\n * Calculate the complex inverse 1/z\n *\n * @returns {Complex}\n */\n 'inverse': function() {\n\n // 1 / 0 = Infinity and 1 / Infinity = 0\n if (this['isZero']()) {\n return Complex['INFINITY'];\n }\n\n if (this['isInfinite']()) {\n return Complex['ZERO'];\n }\n\n var a = this['re'];\n var b = this['im'];\n\n var d = a * a + b * b;\n\n return new Complex(a / d, -b / d);\n },\n\n /**\n * Returns the complex conjugate\n *\n * @returns {Complex}\n */\n 'conjugate': function() {\n\n return new Complex(this['re'], -this['im']);\n },\n\n /**\n * Gets the negated complex number\n *\n * @returns {Complex}\n */\n 'neg': function() {\n\n return new Complex(-this['re'], -this['im']);\n },\n\n /**\n * Ceils the actual complex number\n *\n * @returns {Complex}\n */\n 'ceil': function(places) {\n\n places = Math.pow(10, places || 0);\n\n return new Complex(\n Math.ceil(this['re'] * places) / places,\n Math.ceil(this['im'] * places) / places);\n },\n\n /**\n * Floors the actual complex number\n *\n * @returns {Complex}\n */\n 'floor': function(places) {\n\n places = Math.pow(10, places || 0);\n\n return new Complex(\n Math.floor(this['re'] * places) / places,\n Math.floor(this['im'] * places) / places);\n },\n\n /**\n * Ceils the actual complex number\n *\n * @returns {Complex}\n */\n 'round': function(places) {\n\n places = Math.pow(10, places || 0);\n\n return new Complex(\n Math.round(this['re'] * places) / places,\n Math.round(this['im'] * places) / places);\n },\n\n /**\n * Compares two complex numbers\n *\n * **Note:** new Complex(Infinity).equals(Infinity) === false\n *\n * @returns {boolean}\n */\n 'equals': function(a, b) {\n\n var z = new Complex(a, b);\n\n return Math.abs(z['re'] - this['re']) <= Complex['EPSILON'] &&\n Math.abs(z['im'] - this['im']) <= Complex['EPSILON'];\n },\n\n /**\n * Clones the actual object\n *\n * @returns {Complex}\n */\n 'clone': function() {\n\n return new Complex(this['re'], this['im']);\n },\n\n /**\n * Gets a string of the actual complex number\n *\n * @returns {string}\n */\n 'toString': function() {\n\n var a = this['re'];\n var b = this['im'];\n var ret = \"\";\n\n if (this['isNaN']()) {\n return 'NaN';\n }\n\n if (this['isInfinite']()) {\n return 'Infinity';\n }\n\n if (Math.abs(a) < Complex['EPSILON']) {\n a = 0;\n }\n\n if (Math.abs(b) < Complex['EPSILON']) {\n b = 0;\n }\n\n // If is real number\n if (b === 0) {\n return ret + a;\n }\n\n if (a !== 0) {\n ret += a;\n ret += \" \";\n if (b < 0) {\n b = -b;\n ret += \"-\";\n } else {\n ret += \"+\";\n }\n ret += \" \";\n } else if (b < 0) {\n b = -b;\n ret += \"-\";\n }\n\n if (1 !== b) { // b is the absolute imaginary part\n ret += b;\n }\n return ret + \"i\";\n },\n\n /**\n * Returns the actual number as a vector\n *\n * @returns {Array}\n */\n 'toVector': function() {\n\n return [this['re'], this['im']];\n },\n\n /**\n * Returns the actual real value of the current object\n *\n * @returns {number|null}\n */\n 'valueOf': function() {\n\n if (this['im'] === 0) {\n return this['re'];\n }\n return null;\n },\n\n /**\n * Determines whether a complex number is not on the Riemann sphere.\n *\n * @returns {boolean}\n */\n 'isNaN': function() {\n return isNaN(this['re']) || isNaN(this['im']);\n },\n\n /**\n * Determines whether or not a complex number is at the zero pole of the\n * Riemann sphere.\n *\n * @returns {boolean}\n */\n 'isZero': function() {\n return this['im'] === 0 && this['re'] === 0;\n },\n\n /**\n * Determines whether a complex number is not at the infinity pole of the\n * Riemann sphere.\n *\n * @returns {boolean}\n */\n 'isFinite': function() {\n return isFinite(this['re']) && isFinite(this['im']);\n },\n\n /**\n * Determines whether or not a complex number is at the infinity pole of the\n * Riemann sphere.\n *\n * @returns {boolean}\n */\n 'isInfinite': function() {\n return !(this['isNaN']() || this['isFinite']());\n }\n };\n\n Complex['ZERO'] = new Complex(0, 0);\n Complex['ONE'] = new Complex(1, 0);\n Complex['I'] = new Complex(0, 1);\n Complex['PI'] = new Complex(Math.PI, 0);\n Complex['E'] = new Complex(Math.E, 0);\n Complex['INFINITY'] = new Complex(Infinity, Infinity);\n Complex['NAN'] = new Complex(NaN, NaN);\n Complex['EPSILON'] = 1e-15;\n\n if (typeof define === 'function' && define['amd']) {\n define([], function() {\n return Complex;\n });\n } else if (typeof exports === 'object') {\n Object.defineProperty(Complex, \"__esModule\", { 'value': true });\n Complex['default'] = Complex;\n Complex['Complex'] = Complex;\n module['exports'] = Complex;\n } else {\n root['Complex'] = Complex;\n }\n\n})(this);\n",";(function (globalScope) {\r\n 'use strict';\r\n\r\n\r\n /*\r\n * decimal.js v10.3.1\r\n * An arbitrary-precision Decimal type for JavaScript.\r\n * https://github.com/MikeMcl/decimal.js\r\n * Copyright (c) 2021 Michael Mclaughlin \r\n * MIT Licence\r\n */\r\n\r\n\r\n // ----------------------------------- EDITABLE DEFAULTS ------------------------------------ //\r\n\r\n\r\n // The maximum exponent magnitude.\r\n // The limit on the value of `toExpNeg`, `toExpPos`, `minE` and `maxE`.\r\n var EXP_LIMIT = 9e15, // 0 to 9e15\r\n\r\n // The limit on the value of `precision`, and on the value of the first argument to\r\n // `toDecimalPlaces`, `toExponential`, `toFixed`, `toPrecision` and `toSignificantDigits`.\r\n MAX_DIGITS = 1e9, // 0 to 1e9\r\n\r\n // Base conversion alphabet.\r\n NUMERALS = '0123456789abcdef',\r\n\r\n // The natural logarithm of 10 (1025 digits).\r\n LN10 = '2.3025850929940456840179914546843642076011014886287729760333279009675726096773524802359972050895982983419677840422862486334095254650828067566662873690987816894829072083255546808437998948262331985283935053089653777326288461633662222876982198867465436674744042432743651550489343149393914796194044002221051017141748003688084012647080685567743216228355220114804663715659121373450747856947683463616792101806445070648000277502684916746550586856935673420670581136429224554405758925724208241314695689016758940256776311356919292033376587141660230105703089634572075440370847469940168269282808481184289314848524948644871927809676271275775397027668605952496716674183485704422507197965004714951050492214776567636938662976979522110718264549734772662425709429322582798502585509785265383207606726317164309505995087807523710333101197857547331541421808427543863591778117054309827482385045648019095610299291824318237525357709750539565187697510374970888692180205189339507238539205144634197265287286965110862571492198849978748873771345686209167058',\r\n\r\n // Pi (1025 digits).\r\n PI = '3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113305305488204665213841469519415116094330572703657595919530921861173819326117931051185480744623799627495673518857527248912279381830119491298336733624406566430860213949463952247371907021798609437027705392171762931767523846748184676694051320005681271452635608277857713427577896091736371787214684409012249534301465495853710507922796892589235420199561121290219608640344181598136297747713099605187072113499999983729780499510597317328160963185950244594553469083026425223082533446850352619311881710100031378387528865875332083814206171776691473035982534904287554687311595628638823537875937519577818577805321712268066130019278766111959092164201989380952572010654858632789',\r\n\r\n\r\n // The initial configuration properties of the Decimal constructor.\r\n DEFAULTS = {\r\n\r\n // These values must be integers within the stated ranges (inclusive).\r\n // Most of these values can be changed at run-time using the `Decimal.config` method.\r\n\r\n // The maximum number of significant digits of the result of a calculation or base conversion.\r\n // E.g. `Decimal.config({ precision: 20 });`\r\n precision: 20, // 1 to MAX_DIGITS\r\n\r\n // The rounding mode used when rounding to `precision`.\r\n //\r\n // ROUND_UP 0 Away from zero.\r\n // ROUND_DOWN 1 Towards zero.\r\n // ROUND_CEIL 2 Towards +Infinity.\r\n // ROUND_FLOOR 3 Towards -Infinity.\r\n // ROUND_HALF_UP 4 Towards nearest neighbour. If equidistant, up.\r\n // ROUND_HALF_DOWN 5 Towards nearest neighbour. If equidistant, down.\r\n // ROUND_HALF_EVEN 6 Towards nearest neighbour. If equidistant, towards even neighbour.\r\n // ROUND_HALF_CEIL 7 Towards nearest neighbour. If equidistant, towards +Infinity.\r\n // ROUND_HALF_FLOOR 8 Towards nearest neighbour. If equidistant, towards -Infinity.\r\n //\r\n // E.g.\r\n // `Decimal.rounding = 4;`\r\n // `Decimal.rounding = Decimal.ROUND_HALF_UP;`\r\n rounding: 4, // 0 to 8\r\n\r\n // The modulo mode used when calculating the modulus: a mod n.\r\n // The quotient (q = a / n) is calculated according to the corresponding rounding mode.\r\n // The remainder (r) is calculated as: r = a - n * q.\r\n //\r\n // UP 0 The remainder is positive if the dividend is negative, else is negative.\r\n // DOWN 1 The remainder has the same sign as the dividend (JavaScript %).\r\n // FLOOR 3 The remainder has the same sign as the divisor (Python %).\r\n // HALF_EVEN 6 The IEEE 754 remainder function.\r\n // EUCLID 9 Euclidian division. q = sign(n) * floor(a / abs(n)). Always positive.\r\n //\r\n // Truncated division (1), floored division (3), the IEEE 754 remainder (6), and Euclidian\r\n // division (9) are commonly used for the modulus operation. The other rounding modes can also\r\n // be used, but they may not give useful results.\r\n modulo: 1, // 0 to 9\r\n\r\n // The exponent value at and beneath which `toString` returns exponential notation.\r\n // JavaScript numbers: -7\r\n toExpNeg: -7, // 0 to -EXP_LIMIT\r\n\r\n // The exponent value at and above which `toString` returns exponential notation.\r\n // JavaScript numbers: 21\r\n toExpPos: 21, // 0 to EXP_LIMIT\r\n\r\n // The minimum exponent value, beneath which underflow to zero occurs.\r\n // JavaScript numbers: -324 (5e-324)\r\n minE: -EXP_LIMIT, // -1 to -EXP_LIMIT\r\n\r\n // The maximum exponent value, above which overflow to Infinity occurs.\r\n // JavaScript numbers: 308 (1.7976931348623157e+308)\r\n maxE: EXP_LIMIT, // 1 to EXP_LIMIT\r\n\r\n // Whether to use cryptographically-secure random number generation, if available.\r\n crypto: false // true/false\r\n },\r\n\r\n\r\n // ----------------------------------- END OF EDITABLE DEFAULTS ------------------------------- //\r\n\r\n\r\n Decimal, inexact, noConflict, quadrant,\r\n external = true,\r\n\r\n decimalError = '[DecimalError] ',\r\n invalidArgument = decimalError + 'Invalid argument: ',\r\n precisionLimitExceeded = decimalError + 'Precision limit exceeded',\r\n cryptoUnavailable = decimalError + 'crypto unavailable',\r\n tag = '[object Decimal]',\r\n\r\n mathfloor = Math.floor,\r\n mathpow = Math.pow,\r\n\r\n isBinary = /^0b([01]+(\\.[01]*)?|\\.[01]+)(p[+-]?\\d+)?$/i,\r\n isHex = /^0x([0-9a-f]+(\\.[0-9a-f]*)?|\\.[0-9a-f]+)(p[+-]?\\d+)?$/i,\r\n isOctal = /^0o([0-7]+(\\.[0-7]*)?|\\.[0-7]+)(p[+-]?\\d+)?$/i,\r\n isDecimal = /^(\\d+(\\.\\d*)?|\\.\\d+)(e[+-]?\\d+)?$/i,\r\n\r\n BASE = 1e7,\r\n LOG_BASE = 7,\r\n MAX_SAFE_INTEGER = 9007199254740991,\r\n\r\n LN10_PRECISION = LN10.length - 1,\r\n PI_PRECISION = PI.length - 1,\r\n\r\n // Decimal.prototype object\r\n P = { toStringTag: tag };\r\n\r\n\r\n // Decimal prototype methods\r\n\r\n\r\n /*\r\n * absoluteValue abs\r\n * ceil\r\n * clampedTo clamp\r\n * comparedTo cmp\r\n * cosine cos\r\n * cubeRoot cbrt\r\n * decimalPlaces dp\r\n * dividedBy div\r\n * dividedToIntegerBy divToInt\r\n * equals eq\r\n * floor\r\n * greaterThan gt\r\n * greaterThanOrEqualTo gte\r\n * hyperbolicCosine cosh\r\n * hyperbolicSine sinh\r\n * hyperbolicTangent tanh\r\n * inverseCosine acos\r\n * inverseHyperbolicCosine acosh\r\n * inverseHyperbolicSine asinh\r\n * inverseHyperbolicTangent atanh\r\n * inverseSine asin\r\n * inverseTangent atan\r\n * isFinite\r\n * isInteger isInt\r\n * isNaN\r\n * isNegative isNeg\r\n * isPositive isPos\r\n * isZero\r\n * lessThan lt\r\n * lessThanOrEqualTo lte\r\n * logarithm log\r\n * [maximum] [max]\r\n * [minimum] [min]\r\n * minus sub\r\n * modulo mod\r\n * naturalExponential exp\r\n * naturalLogarithm ln\r\n * negated neg\r\n * plus add\r\n * precision sd\r\n * round\r\n * sine sin\r\n * squareRoot sqrt\r\n * tangent tan\r\n * times mul\r\n * toBinary\r\n * toDecimalPlaces toDP\r\n * toExponential\r\n * toFixed\r\n * toFraction\r\n * toHexadecimal toHex\r\n * toNearest\r\n * toNumber\r\n * toOctal\r\n * toPower pow\r\n * toPrecision\r\n * toSignificantDigits toSD\r\n * toString\r\n * truncated trunc\r\n * valueOf toJSON\r\n */\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the absolute value of this Decimal.\r\n *\r\n */\r\n P.absoluteValue = P.abs = function () {\r\n var x = new this.constructor(this);\r\n if (x.s < 0) x.s = 1;\r\n return finalise(x);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a whole number in the\r\n * direction of positive Infinity.\r\n *\r\n */\r\n P.ceil = function () {\r\n return finalise(new this.constructor(this), this.e + 1, 2);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the value of this Decimal clamped to the range\r\n * delineated by `min` and `max`.\r\n *\r\n * min {number|string|Decimal}\r\n * max {number|string|Decimal}\r\n *\r\n */\r\n P.clampedTo = P.clamp = function (min, max) {\r\n var k,\r\n x = this,\r\n Ctor = x.constructor;\r\n min = new Ctor(min);\r\n max = new Ctor(max);\r\n if (!min.s || !max.s) return new Ctor(NaN);\r\n if (min.gt(max)) throw Error(invalidArgument + max);\r\n k = x.cmp(min);\r\n return k < 0 ? min : x.cmp(max) > 0 ? max : new Ctor(x);\r\n };\r\n\r\n\r\n /*\r\n * Return\r\n * 1 if the value of this Decimal is greater than the value of `y`,\r\n * -1 if the value of this Decimal is less than the value of `y`,\r\n * 0 if they have the same value,\r\n * NaN if the value of either Decimal is NaN.\r\n *\r\n */\r\n P.comparedTo = P.cmp = function (y) {\r\n var i, j, xdL, ydL,\r\n x = this,\r\n xd = x.d,\r\n yd = (y = new x.constructor(y)).d,\r\n xs = x.s,\r\n ys = y.s;\r\n\r\n // Either NaN or ±Infinity?\r\n if (!xd || !yd) {\r\n return !xs || !ys ? NaN : xs !== ys ? xs : xd === yd ? 0 : !xd ^ xs < 0 ? 1 : -1;\r\n }\r\n\r\n // Either zero?\r\n if (!xd[0] || !yd[0]) return xd[0] ? xs : yd[0] ? -ys : 0;\r\n\r\n // Signs differ?\r\n if (xs !== ys) return xs;\r\n\r\n // Compare exponents.\r\n if (x.e !== y.e) return x.e > y.e ^ xs < 0 ? 1 : -1;\r\n\r\n xdL = xd.length;\r\n ydL = yd.length;\r\n\r\n // Compare digit by digit.\r\n for (i = 0, j = xdL < ydL ? xdL : ydL; i < j; ++i) {\r\n if (xd[i] !== yd[i]) return xd[i] > yd[i] ^ xs < 0 ? 1 : -1;\r\n }\r\n\r\n // Compare lengths.\r\n return xdL === ydL ? 0 : xdL > ydL ^ xs < 0 ? 1 : -1;\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the cosine of the value in radians of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-1, 1]\r\n *\r\n * cos(0) = 1\r\n * cos(-0) = 1\r\n * cos(Infinity) = NaN\r\n * cos(-Infinity) = NaN\r\n * cos(NaN) = NaN\r\n *\r\n */\r\n P.cosine = P.cos = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.d) return new Ctor(NaN);\r\n\r\n // cos(0) = cos(-0) = 1\r\n if (!x.d[0]) return new Ctor(1);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(x.e, x.sd()) + LOG_BASE;\r\n Ctor.rounding = 1;\r\n\r\n x = cosine(Ctor, toLessThanHalfPi(Ctor, x));\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(quadrant == 2 || quadrant == 3 ? x.neg() : x, pr, rm, true);\r\n };\r\n\r\n\r\n /*\r\n *\r\n * Return a new Decimal whose value is the cube root of the value of this Decimal, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * cbrt(0) = 0\r\n * cbrt(-0) = -0\r\n * cbrt(1) = 1\r\n * cbrt(-1) = -1\r\n * cbrt(N) = N\r\n * cbrt(-I) = -I\r\n * cbrt(I) = I\r\n *\r\n * Math.cbrt(x) = (x < 0 ? -Math.pow(-x, 1/3) : Math.pow(x, 1/3))\r\n *\r\n */\r\n P.cubeRoot = P.cbrt = function () {\r\n var e, m, n, r, rep, s, sd, t, t3, t3plusx,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite() || x.isZero()) return new Ctor(x);\r\n external = false;\r\n\r\n // Initial estimate.\r\n s = x.s * mathpow(x.s * x, 1 / 3);\r\n\r\n // Math.cbrt underflow/overflow?\r\n // Pass x to Math.pow as integer, then adjust the exponent of the result.\r\n if (!s || Math.abs(s) == 1 / 0) {\r\n n = digitsToString(x.d);\r\n e = x.e;\r\n\r\n // Adjust n exponent so it is a multiple of 3 away from x exponent.\r\n if (s = (e - n.length + 1) % 3) n += (s == 1 || s == -2 ? '0' : '00');\r\n s = mathpow(n, 1 / 3);\r\n\r\n // Rarely, e may be one less than the result exponent value.\r\n e = mathfloor((e + 1) / 3) - (e % 3 == (e < 0 ? -1 : 2));\r\n\r\n if (s == 1 / 0) {\r\n n = '5e' + e;\r\n } else {\r\n n = s.toExponential();\r\n n = n.slice(0, n.indexOf('e') + 1) + e;\r\n }\r\n\r\n r = new Ctor(n);\r\n r.s = x.s;\r\n } else {\r\n r = new Ctor(s.toString());\r\n }\r\n\r\n sd = (e = Ctor.precision) + 3;\r\n\r\n // Halley's method.\r\n // TODO? Compare Newton's method.\r\n for (;;) {\r\n t = r;\r\n t3 = t.times(t).times(t);\r\n t3plusx = t3.plus(x);\r\n r = divide(t3plusx.plus(x).times(t), t3plusx.plus(t3), sd + 2, 1);\r\n\r\n // TODO? Replace with for-loop and checkRoundingDigits.\r\n if (digitsToString(t.d).slice(0, sd) === (n = digitsToString(r.d)).slice(0, sd)) {\r\n n = n.slice(sd - 3, sd + 1);\r\n\r\n // The 4th rounding digit may be in error by -1 so if the 4 rounding digits are 9999 or 4999\r\n // , i.e. approaching a rounding boundary, continue the iteration.\r\n if (n == '9999' || !rep && n == '4999') {\r\n\r\n // On the first iteration only, check to see if rounding up gives the exact result as the\r\n // nines may infinitely repeat.\r\n if (!rep) {\r\n finalise(t, e + 1, 0);\r\n\r\n if (t.times(t).times(t).eq(x)) {\r\n r = t;\r\n break;\r\n }\r\n }\r\n\r\n sd += 4;\r\n rep = 1;\r\n } else {\r\n\r\n // If the rounding digits are null, 0{0,4} or 50{0,3}, check for an exact result.\r\n // If not, then there are further digits and m will be truthy.\r\n if (!+n || !+n.slice(1) && n.charAt(0) == '5') {\r\n\r\n // Truncate to the first rounding digit.\r\n finalise(r, e + 1, 1);\r\n m = !r.times(r).times(r).eq(x);\r\n }\r\n\r\n break;\r\n }\r\n }\r\n }\r\n\r\n external = true;\r\n\r\n return finalise(r, e, Ctor.rounding, m);\r\n };\r\n\r\n\r\n /*\r\n * Return the number of decimal places of the value of this Decimal.\r\n *\r\n */\r\n P.decimalPlaces = P.dp = function () {\r\n var w,\r\n d = this.d,\r\n n = NaN;\r\n\r\n if (d) {\r\n w = d.length - 1;\r\n n = (w - mathfloor(this.e / LOG_BASE)) * LOG_BASE;\r\n\r\n // Subtract the number of trailing zeros of the last word.\r\n w = d[w];\r\n if (w) for (; w % 10 == 0; w /= 10) n--;\r\n if (n < 0) n = 0;\r\n }\r\n\r\n return n;\r\n };\r\n\r\n\r\n /*\r\n * n / 0 = I\r\n * n / N = N\r\n * n / I = 0\r\n * 0 / n = 0\r\n * 0 / 0 = N\r\n * 0 / N = N\r\n * 0 / I = 0\r\n * N / n = N\r\n * N / 0 = N\r\n * N / N = N\r\n * N / I = N\r\n * I / n = I\r\n * I / 0 = I\r\n * I / N = N\r\n * I / I = N\r\n *\r\n * Return a new Decimal whose value is the value of this Decimal divided by `y`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n */\r\n P.dividedBy = P.div = function (y) {\r\n return divide(this, new this.constructor(y));\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the integer part of dividing the value of this Decimal\r\n * by the value of `y`, rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n */\r\n P.dividedToIntegerBy = P.divToInt = function (y) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n return finalise(divide(x, new Ctor(y), 0, 1, 1), Ctor.precision, Ctor.rounding);\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this Decimal is equal to the value of `y`, otherwise return false.\r\n *\r\n */\r\n P.equals = P.eq = function (y) {\r\n return this.cmp(y) === 0;\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a whole number in the\r\n * direction of negative Infinity.\r\n *\r\n */\r\n P.floor = function () {\r\n return finalise(new this.constructor(this), this.e + 1, 3);\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this Decimal is greater than the value of `y`, otherwise return\r\n * false.\r\n *\r\n */\r\n P.greaterThan = P.gt = function (y) {\r\n return this.cmp(y) > 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this Decimal is greater than or equal to the value of `y`,\r\n * otherwise return false.\r\n *\r\n */\r\n P.greaterThanOrEqualTo = P.gte = function (y) {\r\n var k = this.cmp(y);\r\n return k == 1 || k === 0;\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the hyperbolic cosine of the value in radians of this\r\n * Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [1, Infinity]\r\n *\r\n * cosh(x) = 1 + x^2/2! + x^4/4! + x^6/6! + ...\r\n *\r\n * cosh(0) = 1\r\n * cosh(-0) = 1\r\n * cosh(Infinity) = Infinity\r\n * cosh(-Infinity) = Infinity\r\n * cosh(NaN) = NaN\r\n *\r\n * x time taken (ms) result\r\n * 1000 9 9.8503555700852349694e+433\r\n * 10000 25 4.4034091128314607936e+4342\r\n * 100000 171 1.4033316802130615897e+43429\r\n * 1000000 3817 1.5166076984010437725e+434294\r\n * 10000000 abandoned after 2 minute wait\r\n *\r\n * TODO? Compare performance of cosh(x) = 0.5 * (exp(x) + exp(-x))\r\n *\r\n */\r\n P.hyperbolicCosine = P.cosh = function () {\r\n var k, n, pr, rm, len,\r\n x = this,\r\n Ctor = x.constructor,\r\n one = new Ctor(1);\r\n\r\n if (!x.isFinite()) return new Ctor(x.s ? 1 / 0 : NaN);\r\n if (x.isZero()) return one;\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(x.e, x.sd()) + 4;\r\n Ctor.rounding = 1;\r\n len = x.d.length;\r\n\r\n // Argument reduction: cos(4x) = 1 - 8cos^2(x) + 8cos^4(x) + 1\r\n // i.e. cos(x) = 1 - cos^2(x/4)(8 - 8cos^2(x/4))\r\n\r\n // Estimate the optimum number of times to use the argument reduction.\r\n // TODO? Estimation reused from cosine() and may not be optimal here.\r\n if (len < 32) {\r\n k = Math.ceil(len / 3);\r\n n = (1 / tinyPow(4, k)).toString();\r\n } else {\r\n k = 16;\r\n n = '2.3283064365386962890625e-10';\r\n }\r\n\r\n x = taylorSeries(Ctor, 1, x.times(n), new Ctor(1), true);\r\n\r\n // Reverse argument reduction\r\n var cosh2_x,\r\n i = k,\r\n d8 = new Ctor(8);\r\n for (; i--;) {\r\n cosh2_x = x.times(x);\r\n x = one.minus(cosh2_x.times(d8.minus(cosh2_x.times(d8))));\r\n }\r\n\r\n return finalise(x, Ctor.precision = pr, Ctor.rounding = rm, true);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the hyperbolic sine of the value in radians of this\r\n * Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-Infinity, Infinity]\r\n *\r\n * sinh(x) = x + x^3/3! + x^5/5! + x^7/7! + ...\r\n *\r\n * sinh(0) = 0\r\n * sinh(-0) = -0\r\n * sinh(Infinity) = Infinity\r\n * sinh(-Infinity) = -Infinity\r\n * sinh(NaN) = NaN\r\n *\r\n * x time taken (ms)\r\n * 10 2 ms\r\n * 100 5 ms\r\n * 1000 14 ms\r\n * 10000 82 ms\r\n * 100000 886 ms 1.4033316802130615897e+43429\r\n * 200000 2613 ms\r\n * 300000 5407 ms\r\n * 400000 8824 ms\r\n * 500000 13026 ms 8.7080643612718084129e+217146\r\n * 1000000 48543 ms\r\n *\r\n * TODO? Compare performance of sinh(x) = 0.5 * (exp(x) - exp(-x))\r\n *\r\n */\r\n P.hyperbolicSine = P.sinh = function () {\r\n var k, pr, rm, len,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite() || x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(x.e, x.sd()) + 4;\r\n Ctor.rounding = 1;\r\n len = x.d.length;\r\n\r\n if (len < 3) {\r\n x = taylorSeries(Ctor, 2, x, x, true);\r\n } else {\r\n\r\n // Alternative argument reduction: sinh(3x) = sinh(x)(3 + 4sinh^2(x))\r\n // i.e. sinh(x) = sinh(x/3)(3 + 4sinh^2(x/3))\r\n // 3 multiplications and 1 addition\r\n\r\n // Argument reduction: sinh(5x) = sinh(x)(5 + sinh^2(x)(20 + 16sinh^2(x)))\r\n // i.e. sinh(x) = sinh(x/5)(5 + sinh^2(x/5)(20 + 16sinh^2(x/5)))\r\n // 4 multiplications and 2 additions\r\n\r\n // Estimate the optimum number of times to use the argument reduction.\r\n k = 1.4 * Math.sqrt(len);\r\n k = k > 16 ? 16 : k | 0;\r\n\r\n x = x.times(1 / tinyPow(5, k));\r\n x = taylorSeries(Ctor, 2, x, x, true);\r\n\r\n // Reverse argument reduction\r\n var sinh2_x,\r\n d5 = new Ctor(5),\r\n d16 = new Ctor(16),\r\n d20 = new Ctor(20);\r\n for (; k--;) {\r\n sinh2_x = x.times(x);\r\n x = x.times(d5.plus(sinh2_x.times(d16.times(sinh2_x).plus(d20))));\r\n }\r\n }\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(x, pr, rm, true);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the hyperbolic tangent of the value in radians of this\r\n * Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-1, 1]\r\n *\r\n * tanh(x) = sinh(x) / cosh(x)\r\n *\r\n * tanh(0) = 0\r\n * tanh(-0) = -0\r\n * tanh(Infinity) = 1\r\n * tanh(-Infinity) = -1\r\n * tanh(NaN) = NaN\r\n *\r\n */\r\n P.hyperbolicTangent = P.tanh = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite()) return new Ctor(x.s);\r\n if (x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + 7;\r\n Ctor.rounding = 1;\r\n\r\n return divide(x.sinh(), x.cosh(), Ctor.precision = pr, Ctor.rounding = rm);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the arccosine (inverse cosine) in radians of the value of\r\n * this Decimal.\r\n *\r\n * Domain: [-1, 1]\r\n * Range: [0, pi]\r\n *\r\n * acos(x) = pi/2 - asin(x)\r\n *\r\n * acos(0) = pi/2\r\n * acos(-0) = pi/2\r\n * acos(1) = 0\r\n * acos(-1) = pi\r\n * acos(1/2) = pi/3\r\n * acos(-1/2) = 2*pi/3\r\n * acos(|x| > 1) = NaN\r\n * acos(NaN) = NaN\r\n *\r\n */\r\n P.inverseCosine = P.acos = function () {\r\n var halfPi,\r\n x = this,\r\n Ctor = x.constructor,\r\n k = x.abs().cmp(1),\r\n pr = Ctor.precision,\r\n rm = Ctor.rounding;\r\n\r\n if (k !== -1) {\r\n return k === 0\r\n // |x| is 1\r\n ? x.isNeg() ? getPi(Ctor, pr, rm) : new Ctor(0)\r\n // |x| > 1 or x is NaN\r\n : new Ctor(NaN);\r\n }\r\n\r\n if (x.isZero()) return getPi(Ctor, pr + 4, rm).times(0.5);\r\n\r\n // TODO? Special case acos(0.5) = pi/3 and acos(-0.5) = 2*pi/3\r\n\r\n Ctor.precision = pr + 6;\r\n Ctor.rounding = 1;\r\n\r\n x = x.asin();\r\n halfPi = getPi(Ctor, pr + 4, rm).times(0.5);\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return halfPi.minus(x);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic cosine in radians of the\r\n * value of this Decimal.\r\n *\r\n * Domain: [1, Infinity]\r\n * Range: [0, Infinity]\r\n *\r\n * acosh(x) = ln(x + sqrt(x^2 - 1))\r\n *\r\n * acosh(x < 1) = NaN\r\n * acosh(NaN) = NaN\r\n * acosh(Infinity) = Infinity\r\n * acosh(-Infinity) = NaN\r\n * acosh(0) = NaN\r\n * acosh(-0) = NaN\r\n * acosh(1) = 0\r\n * acosh(-1) = NaN\r\n *\r\n */\r\n P.inverseHyperbolicCosine = P.acosh = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (x.lte(1)) return new Ctor(x.eq(1) ? 0 : NaN);\r\n if (!x.isFinite()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(Math.abs(x.e), x.sd()) + 4;\r\n Ctor.rounding = 1;\r\n external = false;\r\n\r\n x = x.times(x).minus(1).sqrt().plus(x);\r\n\r\n external = true;\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return x.ln();\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic sine in radians of the value\r\n * of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-Infinity, Infinity]\r\n *\r\n * asinh(x) = ln(x + sqrt(x^2 + 1))\r\n *\r\n * asinh(NaN) = NaN\r\n * asinh(Infinity) = Infinity\r\n * asinh(-Infinity) = -Infinity\r\n * asinh(0) = 0\r\n * asinh(-0) = -0\r\n *\r\n */\r\n P.inverseHyperbolicSine = P.asinh = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite() || x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + 2 * Math.max(Math.abs(x.e), x.sd()) + 6;\r\n Ctor.rounding = 1;\r\n external = false;\r\n\r\n x = x.times(x).plus(1).sqrt().plus(x);\r\n\r\n external = true;\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return x.ln();\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic tangent in radians of the\r\n * value of this Decimal.\r\n *\r\n * Domain: [-1, 1]\r\n * Range: [-Infinity, Infinity]\r\n *\r\n * atanh(x) = 0.5 * ln((1 + x) / (1 - x))\r\n *\r\n * atanh(|x| > 1) = NaN\r\n * atanh(NaN) = NaN\r\n * atanh(Infinity) = NaN\r\n * atanh(-Infinity) = NaN\r\n * atanh(0) = 0\r\n * atanh(-0) = -0\r\n * atanh(1) = Infinity\r\n * atanh(-1) = -Infinity\r\n *\r\n */\r\n P.inverseHyperbolicTangent = P.atanh = function () {\r\n var pr, rm, wpr, xsd,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite()) return new Ctor(NaN);\r\n if (x.e >= 0) return new Ctor(x.abs().eq(1) ? x.s / 0 : x.isZero() ? x : NaN);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n xsd = x.sd();\r\n\r\n if (Math.max(xsd, pr) < 2 * -x.e - 1) return finalise(new Ctor(x), pr, rm, true);\r\n\r\n Ctor.precision = wpr = xsd - x.e;\r\n\r\n x = divide(x.plus(1), new Ctor(1).minus(x), wpr + pr, 1);\r\n\r\n Ctor.precision = pr + 4;\r\n Ctor.rounding = 1;\r\n\r\n x = x.ln();\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return x.times(0.5);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the arcsine (inverse sine) in radians of the value of this\r\n * Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-pi/2, pi/2]\r\n *\r\n * asin(x) = 2*atan(x/(1 + sqrt(1 - x^2)))\r\n *\r\n * asin(0) = 0\r\n * asin(-0) = -0\r\n * asin(1/2) = pi/6\r\n * asin(-1/2) = -pi/6\r\n * asin(1) = pi/2\r\n * asin(-1) = -pi/2\r\n * asin(|x| > 1) = NaN\r\n * asin(NaN) = NaN\r\n *\r\n * TODO? Compare performance of Taylor series.\r\n *\r\n */\r\n P.inverseSine = P.asin = function () {\r\n var halfPi, k,\r\n pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (x.isZero()) return new Ctor(x);\r\n\r\n k = x.abs().cmp(1);\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n\r\n if (k !== -1) {\r\n\r\n // |x| is 1\r\n if (k === 0) {\r\n halfPi = getPi(Ctor, pr + 4, rm).times(0.5);\r\n halfPi.s = x.s;\r\n return halfPi;\r\n }\r\n\r\n // |x| > 1 or x is NaN\r\n return new Ctor(NaN);\r\n }\r\n\r\n // TODO? Special case asin(1/2) = pi/6 and asin(-1/2) = -pi/6\r\n\r\n Ctor.precision = pr + 6;\r\n Ctor.rounding = 1;\r\n\r\n x = x.div(new Ctor(1).minus(x.times(x)).sqrt().plus(1)).atan();\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return x.times(2);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the arctangent (inverse tangent) in radians of the value\r\n * of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-pi/2, pi/2]\r\n *\r\n * atan(x) = x - x^3/3 + x^5/5 - x^7/7 + ...\r\n *\r\n * atan(0) = 0\r\n * atan(-0) = -0\r\n * atan(1) = pi/4\r\n * atan(-1) = -pi/4\r\n * atan(Infinity) = pi/2\r\n * atan(-Infinity) = -pi/2\r\n * atan(NaN) = NaN\r\n *\r\n */\r\n P.inverseTangent = P.atan = function () {\r\n var i, j, k, n, px, t, r, wpr, x2,\r\n x = this,\r\n Ctor = x.constructor,\r\n pr = Ctor.precision,\r\n rm = Ctor.rounding;\r\n\r\n if (!x.isFinite()) {\r\n if (!x.s) return new Ctor(NaN);\r\n if (pr + 4 <= PI_PRECISION) {\r\n r = getPi(Ctor, pr + 4, rm).times(0.5);\r\n r.s = x.s;\r\n return r;\r\n }\r\n } else if (x.isZero()) {\r\n return new Ctor(x);\r\n } else if (x.abs().eq(1) && pr + 4 <= PI_PRECISION) {\r\n r = getPi(Ctor, pr + 4, rm).times(0.25);\r\n r.s = x.s;\r\n return r;\r\n }\r\n\r\n Ctor.precision = wpr = pr + 10;\r\n Ctor.rounding = 1;\r\n\r\n // TODO? if (x >= 1 && pr <= PI_PRECISION) atan(x) = halfPi * x.s - atan(1 / x);\r\n\r\n // Argument reduction\r\n // Ensure |x| < 0.42\r\n // atan(x) = 2 * atan(x / (1 + sqrt(1 + x^2)))\r\n\r\n k = Math.min(28, wpr / LOG_BASE + 2 | 0);\r\n\r\n for (i = k; i; --i) x = x.div(x.times(x).plus(1).sqrt().plus(1));\r\n\r\n external = false;\r\n\r\n j = Math.ceil(wpr / LOG_BASE);\r\n n = 1;\r\n x2 = x.times(x);\r\n r = new Ctor(x);\r\n px = x;\r\n\r\n // atan(x) = x - x^3/3 + x^5/5 - x^7/7 + ...\r\n for (; i !== -1;) {\r\n px = px.times(x2);\r\n t = r.minus(px.div(n += 2));\r\n\r\n px = px.times(x2);\r\n r = t.plus(px.div(n += 2));\r\n\r\n if (r.d[j] !== void 0) for (i = j; r.d[i] === t.d[i] && i--;);\r\n }\r\n\r\n if (k) r = r.times(2 << (k - 1));\r\n\r\n external = true;\r\n\r\n return finalise(r, Ctor.precision = pr, Ctor.rounding = rm, true);\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this Decimal is a finite number, otherwise return false.\r\n *\r\n */\r\n P.isFinite = function () {\r\n return !!this.d;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this Decimal is an integer, otherwise return false.\r\n *\r\n */\r\n P.isInteger = P.isInt = function () {\r\n return !!this.d && mathfloor(this.e / LOG_BASE) > this.d.length - 2;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this Decimal is NaN, otherwise return false.\r\n *\r\n */\r\n P.isNaN = function () {\r\n return !this.s;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this Decimal is negative, otherwise return false.\r\n *\r\n */\r\n P.isNegative = P.isNeg = function () {\r\n return this.s < 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this Decimal is positive, otherwise return false.\r\n *\r\n */\r\n P.isPositive = P.isPos = function () {\r\n return this.s > 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this Decimal is 0 or -0, otherwise return false.\r\n *\r\n */\r\n P.isZero = function () {\r\n return !!this.d && this.d[0] === 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this Decimal is less than `y`, otherwise return false.\r\n *\r\n */\r\n P.lessThan = P.lt = function (y) {\r\n return this.cmp(y) < 0;\r\n };\r\n\r\n\r\n /*\r\n * Return true if the value of this Decimal is less than or equal to `y`, otherwise return false.\r\n *\r\n */\r\n P.lessThanOrEqualTo = P.lte = function (y) {\r\n return this.cmp(y) < 1;\r\n };\r\n\r\n\r\n /*\r\n * Return the logarithm of the value of this Decimal to the specified base, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * If no base is specified, return log[10](arg).\r\n *\r\n * log[base](arg) = ln(arg) / ln(base)\r\n *\r\n * The result will always be correctly rounded if the base of the log is 10, and 'almost always'\r\n * otherwise:\r\n *\r\n * Depending on the rounding mode, the result may be incorrectly rounded if the first fifteen\r\n * rounding digits are [49]99999999999999 or [50]00000000000000. In that case, the maximum error\r\n * between the result and the correctly rounded result will be one ulp (unit in the last place).\r\n *\r\n * log[-b](a) = NaN\r\n * log[0](a) = NaN\r\n * log[1](a) = NaN\r\n * log[NaN](a) = NaN\r\n * log[Infinity](a) = NaN\r\n * log[b](0) = -Infinity\r\n * log[b](-0) = -Infinity\r\n * log[b](-a) = NaN\r\n * log[b](1) = 0\r\n * log[b](Infinity) = Infinity\r\n * log[b](NaN) = NaN\r\n *\r\n * [base] {number|string|Decimal} The base of the logarithm.\r\n *\r\n */\r\n P.logarithm = P.log = function (base) {\r\n var isBase10, d, denominator, k, inf, num, sd, r,\r\n arg = this,\r\n Ctor = arg.constructor,\r\n pr = Ctor.precision,\r\n rm = Ctor.rounding,\r\n guard = 5;\r\n\r\n // Default base is 10.\r\n if (base == null) {\r\n base = new Ctor(10);\r\n isBase10 = true;\r\n } else {\r\n base = new Ctor(base);\r\n d = base.d;\r\n\r\n // Return NaN if base is negative, or non-finite, or is 0 or 1.\r\n if (base.s < 0 || !d || !d[0] || base.eq(1)) return new Ctor(NaN);\r\n\r\n isBase10 = base.eq(10);\r\n }\r\n\r\n d = arg.d;\r\n\r\n // Is arg negative, non-finite, 0 or 1?\r\n if (arg.s < 0 || !d || !d[0] || arg.eq(1)) {\r\n return new Ctor(d && !d[0] ? -1 / 0 : arg.s != 1 ? NaN : d ? 0 : 1 / 0);\r\n }\r\n\r\n // The result will have a non-terminating decimal expansion if base is 10 and arg is not an\r\n // integer power of 10.\r\n if (isBase10) {\r\n if (d.length > 1) {\r\n inf = true;\r\n } else {\r\n for (k = d[0]; k % 10 === 0;) k /= 10;\r\n inf = k !== 1;\r\n }\r\n }\r\n\r\n external = false;\r\n sd = pr + guard;\r\n num = naturalLogarithm(arg, sd);\r\n denominator = isBase10 ? getLn10(Ctor, sd + 10) : naturalLogarithm(base, sd);\r\n\r\n // The result will have 5 rounding digits.\r\n r = divide(num, denominator, sd, 1);\r\n\r\n // If at a rounding boundary, i.e. the result's rounding digits are [49]9999 or [50]0000,\r\n // calculate 10 further digits.\r\n //\r\n // If the result is known to have an infinite decimal expansion, repeat this until it is clear\r\n // that the result is above or below the boundary. Otherwise, if after calculating the 10\r\n // further digits, the last 14 are nines, round up and assume the result is exact.\r\n // Also assume the result is exact if the last 14 are zero.\r\n //\r\n // Example of a result that will be incorrectly rounded:\r\n // log[1048576](4503599627370502) = 2.60000000000000009610279511444746...\r\n // The above result correctly rounded using ROUND_CEIL to 1 decimal place should be 2.7, but it\r\n // will be given as 2.6 as there are 15 zeros immediately after the requested decimal place, so\r\n // the exact result would be assumed to be 2.6, which rounded using ROUND_CEIL to 1 decimal\r\n // place is still 2.6.\r\n if (checkRoundingDigits(r.d, k = pr, rm)) {\r\n\r\n do {\r\n sd += 10;\r\n num = naturalLogarithm(arg, sd);\r\n denominator = isBase10 ? getLn10(Ctor, sd + 10) : naturalLogarithm(base, sd);\r\n r = divide(num, denominator, sd, 1);\r\n\r\n if (!inf) {\r\n\r\n // Check for 14 nines from the 2nd rounding digit, as the first may be 4.\r\n if (+digitsToString(r.d).slice(k + 1, k + 15) + 1 == 1e14) {\r\n r = finalise(r, pr + 1, 0);\r\n }\r\n\r\n break;\r\n }\r\n } while (checkRoundingDigits(r.d, k += 10, rm));\r\n }\r\n\r\n external = true;\r\n\r\n return finalise(r, pr, rm);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the maximum of the arguments and the value of this Decimal.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n P.max = function () {\r\n Array.prototype.push.call(arguments, this);\r\n return maxOrMin(this.constructor, arguments, 'lt');\r\n };\r\n */\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the minimum of the arguments and the value of this Decimal.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n P.min = function () {\r\n Array.prototype.push.call(arguments, this);\r\n return maxOrMin(this.constructor, arguments, 'gt');\r\n };\r\n */\r\n\r\n\r\n /*\r\n * n - 0 = n\r\n * n - N = N\r\n * n - I = -I\r\n * 0 - n = -n\r\n * 0 - 0 = 0\r\n * 0 - N = N\r\n * 0 - I = -I\r\n * N - n = N\r\n * N - 0 = N\r\n * N - N = N\r\n * N - I = N\r\n * I - n = I\r\n * I - 0 = I\r\n * I - N = N\r\n * I - I = N\r\n *\r\n * Return a new Decimal whose value is the value of this Decimal minus `y`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n */\r\n P.minus = P.sub = function (y) {\r\n var d, e, i, j, k, len, pr, rm, xd, xe, xLTy, yd,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n y = new Ctor(y);\r\n\r\n // If either is not finite...\r\n if (!x.d || !y.d) {\r\n\r\n // Return NaN if either is NaN.\r\n if (!x.s || !y.s) y = new Ctor(NaN);\r\n\r\n // Return y negated if x is finite and y is ±Infinity.\r\n else if (x.d) y.s = -y.s;\r\n\r\n // Return x if y is finite and x is ±Infinity.\r\n // Return x if both are ±Infinity with different signs.\r\n // Return NaN if both are ±Infinity with the same sign.\r\n else y = new Ctor(y.d || x.s !== y.s ? x : NaN);\r\n\r\n return y;\r\n }\r\n\r\n // If signs differ...\r\n if (x.s != y.s) {\r\n y.s = -y.s;\r\n return x.plus(y);\r\n }\r\n\r\n xd = x.d;\r\n yd = y.d;\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n\r\n // If either is zero...\r\n if (!xd[0] || !yd[0]) {\r\n\r\n // Return y negated if x is zero and y is non-zero.\r\n if (yd[0]) y.s = -y.s;\r\n\r\n // Return x if y is zero and x is non-zero.\r\n else if (xd[0]) y = new Ctor(x);\r\n\r\n // Return zero if both are zero.\r\n // From IEEE 754 (2008) 6.3: 0 - 0 = -0 - -0 = -0 when rounding to -Infinity.\r\n else return new Ctor(rm === 3 ? -0 : 0);\r\n\r\n return external ? finalise(y, pr, rm) : y;\r\n }\r\n\r\n // x and y are finite, non-zero numbers with the same sign.\r\n\r\n // Calculate base 1e7 exponents.\r\n e = mathfloor(y.e / LOG_BASE);\r\n xe = mathfloor(x.e / LOG_BASE);\r\n\r\n xd = xd.slice();\r\n k = xe - e;\r\n\r\n // If base 1e7 exponents differ...\r\n if (k) {\r\n xLTy = k < 0;\r\n\r\n if (xLTy) {\r\n d = xd;\r\n k = -k;\r\n len = yd.length;\r\n } else {\r\n d = yd;\r\n e = xe;\r\n len = xd.length;\r\n }\r\n\r\n // Numbers with massively different exponents would result in a very high number of\r\n // zeros needing to be prepended, but this can be avoided while still ensuring correct\r\n // rounding by limiting the number of zeros to `Math.ceil(pr / LOG_BASE) + 2`.\r\n i = Math.max(Math.ceil(pr / LOG_BASE), len) + 2;\r\n\r\n if (k > i) {\r\n k = i;\r\n d.length = 1;\r\n }\r\n\r\n // Prepend zeros to equalise exponents.\r\n d.reverse();\r\n for (i = k; i--;) d.push(0);\r\n d.reverse();\r\n\r\n // Base 1e7 exponents equal.\r\n } else {\r\n\r\n // Check digits to determine which is the bigger number.\r\n\r\n i = xd.length;\r\n len = yd.length;\r\n xLTy = i < len;\r\n if (xLTy) len = i;\r\n\r\n for (i = 0; i < len; i++) {\r\n if (xd[i] != yd[i]) {\r\n xLTy = xd[i] < yd[i];\r\n break;\r\n }\r\n }\r\n\r\n k = 0;\r\n }\r\n\r\n if (xLTy) {\r\n d = xd;\r\n xd = yd;\r\n yd = d;\r\n y.s = -y.s;\r\n }\r\n\r\n len = xd.length;\r\n\r\n // Append zeros to `xd` if shorter.\r\n // Don't add zeros to `yd` if shorter as subtraction only needs to start at `yd` length.\r\n for (i = yd.length - len; i > 0; --i) xd[len++] = 0;\r\n\r\n // Subtract yd from xd.\r\n for (i = yd.length; i > k;) {\r\n\r\n if (xd[--i] < yd[i]) {\r\n for (j = i; j && xd[--j] === 0;) xd[j] = BASE - 1;\r\n --xd[j];\r\n xd[i] += BASE;\r\n }\r\n\r\n xd[i] -= yd[i];\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (; xd[--len] === 0;) xd.pop();\r\n\r\n // Remove leading zeros and adjust exponent accordingly.\r\n for (; xd[0] === 0; xd.shift()) --e;\r\n\r\n // Zero?\r\n if (!xd[0]) return new Ctor(rm === 3 ? -0 : 0);\r\n\r\n y.d = xd;\r\n y.e = getBase10Exponent(xd, e);\r\n\r\n return external ? finalise(y, pr, rm) : y;\r\n };\r\n\r\n\r\n /*\r\n * n % 0 = N\r\n * n % N = N\r\n * n % I = n\r\n * 0 % n = 0\r\n * -0 % n = -0\r\n * 0 % 0 = N\r\n * 0 % N = N\r\n * 0 % I = 0\r\n * N % n = N\r\n * N % 0 = N\r\n * N % N = N\r\n * N % I = N\r\n * I % n = N\r\n * I % 0 = N\r\n * I % N = N\r\n * I % I = N\r\n *\r\n * Return a new Decimal whose value is the value of this Decimal modulo `y`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * The result depends on the modulo mode.\r\n *\r\n */\r\n P.modulo = P.mod = function (y) {\r\n var q,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n y = new Ctor(y);\r\n\r\n // Return NaN if x is ±Infinity or NaN, or y is NaN or ±0.\r\n if (!x.d || !y.s || y.d && !y.d[0]) return new Ctor(NaN);\r\n\r\n // Return x if y is ±Infinity or x is ±0.\r\n if (!y.d || x.d && !x.d[0]) {\r\n return finalise(new Ctor(x), Ctor.precision, Ctor.rounding);\r\n }\r\n\r\n // Prevent rounding of intermediate calculations.\r\n external = false;\r\n\r\n if (Ctor.modulo == 9) {\r\n\r\n // Euclidian division: q = sign(y) * floor(x / abs(y))\r\n // result = x - q * y where 0 <= result < abs(y)\r\n q = divide(x, y.abs(), 0, 3, 1);\r\n q.s *= y.s;\r\n } else {\r\n q = divide(x, y, 0, Ctor.modulo, 1);\r\n }\r\n\r\n q = q.times(y);\r\n\r\n external = true;\r\n\r\n return x.minus(q);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the natural exponential of the value of this Decimal,\r\n * i.e. the base e raised to the power the value of this Decimal, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n */\r\n P.naturalExponential = P.exp = function () {\r\n return naturalExponential(this);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the natural logarithm of the value of this Decimal,\r\n * rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n */\r\n P.naturalLogarithm = P.ln = function () {\r\n return naturalLogarithm(this);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the value of this Decimal negated, i.e. as if multiplied by\r\n * -1.\r\n *\r\n */\r\n P.negated = P.neg = function () {\r\n var x = new this.constructor(this);\r\n x.s = -x.s;\r\n return finalise(x);\r\n };\r\n\r\n\r\n /*\r\n * n + 0 = n\r\n * n + N = N\r\n * n + I = I\r\n * 0 + n = n\r\n * 0 + 0 = 0\r\n * 0 + N = N\r\n * 0 + I = I\r\n * N + n = N\r\n * N + 0 = N\r\n * N + N = N\r\n * N + I = N\r\n * I + n = I\r\n * I + 0 = I\r\n * I + N = N\r\n * I + I = I\r\n *\r\n * Return a new Decimal whose value is the value of this Decimal plus `y`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n */\r\n P.plus = P.add = function (y) {\r\n var carry, d, e, i, k, len, pr, rm, xd, yd,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n y = new Ctor(y);\r\n\r\n // If either is not finite...\r\n if (!x.d || !y.d) {\r\n\r\n // Return NaN if either is NaN.\r\n if (!x.s || !y.s) y = new Ctor(NaN);\r\n\r\n // Return x if y is finite and x is ±Infinity.\r\n // Return x if both are ±Infinity with the same sign.\r\n // Return NaN if both are ±Infinity with different signs.\r\n // Return y if x is finite and y is ±Infinity.\r\n else if (!x.d) y = new Ctor(y.d || x.s === y.s ? x : NaN);\r\n\r\n return y;\r\n }\r\n\r\n // If signs differ...\r\n if (x.s != y.s) {\r\n y.s = -y.s;\r\n return x.minus(y);\r\n }\r\n\r\n xd = x.d;\r\n yd = y.d;\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n\r\n // If either is zero...\r\n if (!xd[0] || !yd[0]) {\r\n\r\n // Return x if y is zero.\r\n // Return y if y is non-zero.\r\n if (!yd[0]) y = new Ctor(x);\r\n\r\n return external ? finalise(y, pr, rm) : y;\r\n }\r\n\r\n // x and y are finite, non-zero numbers with the same sign.\r\n\r\n // Calculate base 1e7 exponents.\r\n k = mathfloor(x.e / LOG_BASE);\r\n e = mathfloor(y.e / LOG_BASE);\r\n\r\n xd = xd.slice();\r\n i = k - e;\r\n\r\n // If base 1e7 exponents differ...\r\n if (i) {\r\n\r\n if (i < 0) {\r\n d = xd;\r\n i = -i;\r\n len = yd.length;\r\n } else {\r\n d = yd;\r\n e = k;\r\n len = xd.length;\r\n }\r\n\r\n // Limit number of zeros prepended to max(ceil(pr / LOG_BASE), len) + 1.\r\n k = Math.ceil(pr / LOG_BASE);\r\n len = k > len ? k + 1 : len + 1;\r\n\r\n if (i > len) {\r\n i = len;\r\n d.length = 1;\r\n }\r\n\r\n // Prepend zeros to equalise exponents. Note: Faster to use reverse then do unshifts.\r\n d.reverse();\r\n for (; i--;) d.push(0);\r\n d.reverse();\r\n }\r\n\r\n len = xd.length;\r\n i = yd.length;\r\n\r\n // If yd is longer than xd, swap xd and yd so xd points to the longer array.\r\n if (len - i < 0) {\r\n i = len;\r\n d = yd;\r\n yd = xd;\r\n xd = d;\r\n }\r\n\r\n // Only start adding at yd.length - 1 as the further digits of xd can be left as they are.\r\n for (carry = 0; i;) {\r\n carry = (xd[--i] = xd[i] + yd[i] + carry) / BASE | 0;\r\n xd[i] %= BASE;\r\n }\r\n\r\n if (carry) {\r\n xd.unshift(carry);\r\n ++e;\r\n }\r\n\r\n // Remove trailing zeros.\r\n // No need to check for zero, as +x + +y != 0 && -x + -y != 0\r\n for (len = xd.length; xd[--len] == 0;) xd.pop();\r\n\r\n y.d = xd;\r\n y.e = getBase10Exponent(xd, e);\r\n\r\n return external ? finalise(y, pr, rm) : y;\r\n };\r\n\r\n\r\n /*\r\n * Return the number of significant digits of the value of this Decimal.\r\n *\r\n * [z] {boolean|number} Whether to count integer-part trailing zeros: true, false, 1 or 0.\r\n *\r\n */\r\n P.precision = P.sd = function (z) {\r\n var k,\r\n x = this;\r\n\r\n if (z !== void 0 && z !== !!z && z !== 1 && z !== 0) throw Error(invalidArgument + z);\r\n\r\n if (x.d) {\r\n k = getPrecision(x.d);\r\n if (z && x.e + 1 > k) k = x.e + 1;\r\n } else {\r\n k = NaN;\r\n }\r\n\r\n return k;\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a whole number using\r\n * rounding mode `rounding`.\r\n *\r\n */\r\n P.round = function () {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n return finalise(new Ctor(x), x.e + 1, Ctor.rounding);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the sine of the value in radians of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-1, 1]\r\n *\r\n * sin(x) = x - x^3/3! + x^5/5! - ...\r\n *\r\n * sin(0) = 0\r\n * sin(-0) = -0\r\n * sin(Infinity) = NaN\r\n * sin(-Infinity) = NaN\r\n * sin(NaN) = NaN\r\n *\r\n */\r\n P.sine = P.sin = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite()) return new Ctor(NaN);\r\n if (x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(x.e, x.sd()) + LOG_BASE;\r\n Ctor.rounding = 1;\r\n\r\n x = sine(Ctor, toLessThanHalfPi(Ctor, x));\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(quadrant > 2 ? x.neg() : x, pr, rm, true);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the square root of this Decimal, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * sqrt(-n) = N\r\n * sqrt(N) = N\r\n * sqrt(-I) = N\r\n * sqrt(I) = I\r\n * sqrt(0) = 0\r\n * sqrt(-0) = -0\r\n *\r\n */\r\n P.squareRoot = P.sqrt = function () {\r\n var m, n, sd, r, rep, t,\r\n x = this,\r\n d = x.d,\r\n e = x.e,\r\n s = x.s,\r\n Ctor = x.constructor;\r\n\r\n // Negative/NaN/Infinity/zero?\r\n if (s !== 1 || !d || !d[0]) {\r\n return new Ctor(!s || s < 0 && (!d || d[0]) ? NaN : d ? x : 1 / 0);\r\n }\r\n\r\n external = false;\r\n\r\n // Initial estimate.\r\n s = Math.sqrt(+x);\r\n\r\n // Math.sqrt underflow/overflow?\r\n // Pass x to Math.sqrt as integer, then adjust the exponent of the result.\r\n if (s == 0 || s == 1 / 0) {\r\n n = digitsToString(d);\r\n\r\n if ((n.length + e) % 2 == 0) n += '0';\r\n s = Math.sqrt(n);\r\n e = mathfloor((e + 1) / 2) - (e < 0 || e % 2);\r\n\r\n if (s == 1 / 0) {\r\n n = '5e' + e;\r\n } else {\r\n n = s.toExponential();\r\n n = n.slice(0, n.indexOf('e') + 1) + e;\r\n }\r\n\r\n r = new Ctor(n);\r\n } else {\r\n r = new Ctor(s.toString());\r\n }\r\n\r\n sd = (e = Ctor.precision) + 3;\r\n\r\n // Newton-Raphson iteration.\r\n for (;;) {\r\n t = r;\r\n r = t.plus(divide(x, t, sd + 2, 1)).times(0.5);\r\n\r\n // TODO? Replace with for-loop and checkRoundingDigits.\r\n if (digitsToString(t.d).slice(0, sd) === (n = digitsToString(r.d)).slice(0, sd)) {\r\n n = n.slice(sd - 3, sd + 1);\r\n\r\n // The 4th rounding digit may be in error by -1 so if the 4 rounding digits are 9999 or\r\n // 4999, i.e. approaching a rounding boundary, continue the iteration.\r\n if (n == '9999' || !rep && n == '4999') {\r\n\r\n // On the first iteration only, check to see if rounding up gives the exact result as the\r\n // nines may infinitely repeat.\r\n if (!rep) {\r\n finalise(t, e + 1, 0);\r\n\r\n if (t.times(t).eq(x)) {\r\n r = t;\r\n break;\r\n }\r\n }\r\n\r\n sd += 4;\r\n rep = 1;\r\n } else {\r\n\r\n // If the rounding digits are null, 0{0,4} or 50{0,3}, check for an exact result.\r\n // If not, then there are further digits and m will be truthy.\r\n if (!+n || !+n.slice(1) && n.charAt(0) == '5') {\r\n\r\n // Truncate to the first rounding digit.\r\n finalise(r, e + 1, 1);\r\n m = !r.times(r).eq(x);\r\n }\r\n\r\n break;\r\n }\r\n }\r\n }\r\n\r\n external = true;\r\n\r\n return finalise(r, e, Ctor.rounding, m);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the tangent of the value in radians of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-Infinity, Infinity]\r\n *\r\n * tan(0) = 0\r\n * tan(-0) = -0\r\n * tan(Infinity) = NaN\r\n * tan(-Infinity) = NaN\r\n * tan(NaN) = NaN\r\n *\r\n */\r\n P.tangent = P.tan = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite()) return new Ctor(NaN);\r\n if (x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + 10;\r\n Ctor.rounding = 1;\r\n\r\n x = x.sin();\r\n x.s = 1;\r\n x = divide(x, new Ctor(1).minus(x.times(x)).sqrt(), pr + 10, 0);\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(quadrant == 2 || quadrant == 4 ? x.neg() : x, pr, rm, true);\r\n };\r\n\r\n\r\n /*\r\n * n * 0 = 0\r\n * n * N = N\r\n * n * I = I\r\n * 0 * n = 0\r\n * 0 * 0 = 0\r\n * 0 * N = N\r\n * 0 * I = N\r\n * N * n = N\r\n * N * 0 = N\r\n * N * N = N\r\n * N * I = N\r\n * I * n = I\r\n * I * 0 = N\r\n * I * N = N\r\n * I * I = I\r\n *\r\n * Return a new Decimal whose value is this Decimal times `y`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n */\r\n P.times = P.mul = function (y) {\r\n var carry, e, i, k, r, rL, t, xdL, ydL,\r\n x = this,\r\n Ctor = x.constructor,\r\n xd = x.d,\r\n yd = (y = new Ctor(y)).d;\r\n\r\n y.s *= x.s;\r\n\r\n // If either is NaN, ±Infinity or ±0...\r\n if (!xd || !xd[0] || !yd || !yd[0]) {\r\n\r\n return new Ctor(!y.s || xd && !xd[0] && !yd || yd && !yd[0] && !xd\r\n\r\n // Return NaN if either is NaN.\r\n // Return NaN if x is ±0 and y is ±Infinity, or y is ±0 and x is ±Infinity.\r\n ? NaN\r\n\r\n // Return ±Infinity if either is ±Infinity.\r\n // Return ±0 if either is ±0.\r\n : !xd || !yd ? y.s / 0 : y.s * 0);\r\n }\r\n\r\n e = mathfloor(x.e / LOG_BASE) + mathfloor(y.e / LOG_BASE);\r\n xdL = xd.length;\r\n ydL = yd.length;\r\n\r\n // Ensure xd points to the longer array.\r\n if (xdL < ydL) {\r\n r = xd;\r\n xd = yd;\r\n yd = r;\r\n rL = xdL;\r\n xdL = ydL;\r\n ydL = rL;\r\n }\r\n\r\n // Initialise the result array with zeros.\r\n r = [];\r\n rL = xdL + ydL;\r\n for (i = rL; i--;) r.push(0);\r\n\r\n // Multiply!\r\n for (i = ydL; --i >= 0;) {\r\n carry = 0;\r\n for (k = xdL + i; k > i;) {\r\n t = r[k] + yd[i] * xd[k - i - 1] + carry;\r\n r[k--] = t % BASE | 0;\r\n carry = t / BASE | 0;\r\n }\r\n\r\n r[k] = (r[k] + carry) % BASE | 0;\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (; !r[--rL];) r.pop();\r\n\r\n if (carry) ++e;\r\n else r.shift();\r\n\r\n y.d = r;\r\n y.e = getBase10Exponent(r, e);\r\n\r\n return external ? finalise(y, Ctor.precision, Ctor.rounding) : y;\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this Decimal in base 2, round to `sd` significant\r\n * digits using rounding mode `rm`.\r\n *\r\n * If the optional `sd` argument is present then return binary exponential notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\n P.toBinary = function (sd, rm) {\r\n return toStringBinary(this, 2, sd, rm);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a maximum of `dp`\r\n * decimal places using rounding mode `rm` or `rounding` if `rm` is omitted.\r\n *\r\n * If `dp` is omitted, return a new Decimal whose value is the value of this Decimal.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\n P.toDecimalPlaces = P.toDP = function (dp, rm) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n x = new Ctor(x);\r\n if (dp === void 0) return x;\r\n\r\n checkInt32(dp, 0, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n return finalise(x, dp + x.e + 1, rm);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this Decimal in exponential notation rounded to\r\n * `dp` fixed decimal places using rounding mode `rounding`.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\n P.toExponential = function (dp, rm) {\r\n var str,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (dp === void 0) {\r\n str = finiteToString(x, true);\r\n } else {\r\n checkInt32(dp, 0, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n x = finalise(new Ctor(x), dp + 1, rm);\r\n str = finiteToString(x, true, dp + 1);\r\n }\r\n\r\n return x.isNeg() && !x.isZero() ? '-' + str : str;\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this Decimal in normal (fixed-point) notation to\r\n * `dp` fixed decimal places and rounded using rounding mode `rm` or `rounding` if `rm` is\r\n * omitted.\r\n *\r\n * As with JavaScript numbers, (-0).toFixed(0) is '0', but e.g. (-0.00001).toFixed(0) is '-0'.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * (-0).toFixed(0) is '0', but (-0.1).toFixed(0) is '-0'.\r\n * (-0).toFixed(1) is '0.0', but (-0.01).toFixed(1) is '-0.0'.\r\n * (-0).toFixed(3) is '0.000'.\r\n * (-0.5).toFixed(0) is '-0'.\r\n *\r\n */\r\n P.toFixed = function (dp, rm) {\r\n var str, y,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (dp === void 0) {\r\n str = finiteToString(x);\r\n } else {\r\n checkInt32(dp, 0, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n y = finalise(new Ctor(x), dp + x.e + 1, rm);\r\n str = finiteToString(y, false, dp + y.e + 1);\r\n }\r\n\r\n // To determine whether to add the minus sign look at the value before it was rounded,\r\n // i.e. look at `x` rather than `y`.\r\n return x.isNeg() && !x.isZero() ? '-' + str : str;\r\n };\r\n\r\n\r\n /*\r\n * Return an array representing the value of this Decimal as a simple fraction with an integer\r\n * numerator and an integer denominator.\r\n *\r\n * The denominator will be a positive non-zero value less than or equal to the specified maximum\r\n * denominator. If a maximum denominator is not specified, the denominator will be the lowest\r\n * value necessary to represent the number exactly.\r\n *\r\n * [maxD] {number|string|Decimal} Maximum denominator. Integer >= 1 and < Infinity.\r\n *\r\n */\r\n P.toFraction = function (maxD) {\r\n var d, d0, d1, d2, e, k, n, n0, n1, pr, q, r,\r\n x = this,\r\n xd = x.d,\r\n Ctor = x.constructor;\r\n\r\n if (!xd) return new Ctor(x);\r\n\r\n n1 = d0 = new Ctor(1);\r\n d1 = n0 = new Ctor(0);\r\n\r\n d = new Ctor(d1);\r\n e = d.e = getPrecision(xd) - x.e - 1;\r\n k = e % LOG_BASE;\r\n d.d[0] = mathpow(10, k < 0 ? LOG_BASE + k : k);\r\n\r\n if (maxD == null) {\r\n\r\n // d is 10**e, the minimum max-denominator needed.\r\n maxD = e > 0 ? d : n1;\r\n } else {\r\n n = new Ctor(maxD);\r\n if (!n.isInt() || n.lt(n1)) throw Error(invalidArgument + n);\r\n maxD = n.gt(d) ? (e > 0 ? d : n1) : n;\r\n }\r\n\r\n external = false;\r\n n = new Ctor(digitsToString(xd));\r\n pr = Ctor.precision;\r\n Ctor.precision = e = xd.length * LOG_BASE * 2;\r\n\r\n for (;;) {\r\n q = divide(n, d, 0, 1, 1);\r\n d2 = d0.plus(q.times(d1));\r\n if (d2.cmp(maxD) == 1) break;\r\n d0 = d1;\r\n d1 = d2;\r\n d2 = n1;\r\n n1 = n0.plus(q.times(d2));\r\n n0 = d2;\r\n d2 = d;\r\n d = n.minus(q.times(d2));\r\n n = d2;\r\n }\r\n\r\n d2 = divide(maxD.minus(d0), d1, 0, 1, 1);\r\n n0 = n0.plus(d2.times(n1));\r\n d0 = d0.plus(d2.times(d1));\r\n n0.s = n1.s = x.s;\r\n\r\n // Determine which fraction is closer to x, n0/d0 or n1/d1?\r\n r = divide(n1, d1, e, 1).minus(x).abs().cmp(divide(n0, d0, e, 1).minus(x).abs()) < 1\r\n ? [n1, d1] : [n0, d0];\r\n\r\n Ctor.precision = pr;\r\n external = true;\r\n\r\n return r;\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this Decimal in base 16, round to `sd` significant\r\n * digits using rounding mode `rm`.\r\n *\r\n * If the optional `sd` argument is present then return binary exponential notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\n P.toHexadecimal = P.toHex = function (sd, rm) {\r\n return toStringBinary(this, 16, sd, rm);\r\n };\r\n\r\n\r\n /*\r\n * Returns a new Decimal whose value is the nearest multiple of `y` in the direction of rounding\r\n * mode `rm`, or `Decimal.rounding` if `rm` is omitted, to the value of this Decimal.\r\n *\r\n * The return value will always have the same sign as this Decimal, unless either this Decimal\r\n * or `y` is NaN, in which case the return value will be also be NaN.\r\n *\r\n * The return value is not affected by the value of `precision`.\r\n *\r\n * y {number|string|Decimal} The magnitude to round to a multiple of.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * 'toNearest() rounding mode not an integer: {rm}'\r\n * 'toNearest() rounding mode out of range: {rm}'\r\n *\r\n */\r\n P.toNearest = function (y, rm) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n x = new Ctor(x);\r\n\r\n if (y == null) {\r\n\r\n // If x is not finite, return x.\r\n if (!x.d) return x;\r\n\r\n y = new Ctor(1);\r\n rm = Ctor.rounding;\r\n } else {\r\n y = new Ctor(y);\r\n if (rm === void 0) {\r\n rm = Ctor.rounding;\r\n } else {\r\n checkInt32(rm, 0, 8);\r\n }\r\n\r\n // If x is not finite, return x if y is not NaN, else NaN.\r\n if (!x.d) return y.s ? x : y;\r\n\r\n // If y is not finite, return Infinity with the sign of x if y is Infinity, else NaN.\r\n if (!y.d) {\r\n if (y.s) y.s = x.s;\r\n return y;\r\n }\r\n }\r\n\r\n // If y is not zero, calculate the nearest multiple of y to x.\r\n if (y.d[0]) {\r\n external = false;\r\n x = divide(x, y, 0, rm, 1).times(y);\r\n external = true;\r\n finalise(x);\r\n\r\n // If y is zero, return zero with the sign of x.\r\n } else {\r\n y.s = x.s;\r\n x = y;\r\n }\r\n\r\n return x;\r\n };\r\n\r\n\r\n /*\r\n * Return the value of this Decimal converted to a number primitive.\r\n * Zero keeps its sign.\r\n *\r\n */\r\n P.toNumber = function () {\r\n return +this;\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this Decimal in base 8, round to `sd` significant\r\n * digits using rounding mode `rm`.\r\n *\r\n * If the optional `sd` argument is present then return binary exponential notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\n P.toOctal = function (sd, rm) {\r\n return toStringBinary(this, 8, sd, rm);\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the value of this Decimal raised to the power `y`, rounded\r\n * to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * ECMAScript compliant.\r\n *\r\n * pow(x, NaN) = NaN\r\n * pow(x, ±0) = 1\r\n\r\n * pow(NaN, non-zero) = NaN\r\n * pow(abs(x) > 1, +Infinity) = +Infinity\r\n * pow(abs(x) > 1, -Infinity) = +0\r\n * pow(abs(x) == 1, ±Infinity) = NaN\r\n * pow(abs(x) < 1, +Infinity) = +0\r\n * pow(abs(x) < 1, -Infinity) = +Infinity\r\n * pow(+Infinity, y > 0) = +Infinity\r\n * pow(+Infinity, y < 0) = +0\r\n * pow(-Infinity, odd integer > 0) = -Infinity\r\n * pow(-Infinity, even integer > 0) = +Infinity\r\n * pow(-Infinity, odd integer < 0) = -0\r\n * pow(-Infinity, even integer < 0) = +0\r\n * pow(+0, y > 0) = +0\r\n * pow(+0, y < 0) = +Infinity\r\n * pow(-0, odd integer > 0) = -0\r\n * pow(-0, even integer > 0) = +0\r\n * pow(-0, odd integer < 0) = -Infinity\r\n * pow(-0, even integer < 0) = +Infinity\r\n * pow(finite x < 0, finite non-integer) = NaN\r\n *\r\n * For non-integer or very large exponents pow(x, y) is calculated using\r\n *\r\n * x^y = exp(y*ln(x))\r\n *\r\n * Assuming the first 15 rounding digits are each equally likely to be any digit 0-9, the\r\n * probability of an incorrectly rounded result\r\n * P([49]9{14} | [50]0{14}) = 2 * 0.2 * 10^-14 = 4e-15 = 1/2.5e+14\r\n * i.e. 1 in 250,000,000,000,000\r\n *\r\n * If a result is incorrectly rounded the maximum error will be 1 ulp (unit in last place).\r\n *\r\n * y {number|string|Decimal} The power to which to raise this Decimal.\r\n *\r\n */\r\n P.toPower = P.pow = function (y) {\r\n var e, k, pr, r, rm, s,\r\n x = this,\r\n Ctor = x.constructor,\r\n yn = +(y = new Ctor(y));\r\n\r\n // Either ±Infinity, NaN or ±0?\r\n if (!x.d || !y.d || !x.d[0] || !y.d[0]) return new Ctor(mathpow(+x, yn));\r\n\r\n x = new Ctor(x);\r\n\r\n if (x.eq(1)) return x;\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n\r\n if (y.eq(1)) return finalise(x, pr, rm);\r\n\r\n // y exponent\r\n e = mathfloor(y.e / LOG_BASE);\r\n\r\n // If y is a small integer use the 'exponentiation by squaring' algorithm.\r\n if (e >= y.d.length - 1 && (k = yn < 0 ? -yn : yn) <= MAX_SAFE_INTEGER) {\r\n r = intPow(Ctor, x, k, pr);\r\n return y.s < 0 ? new Ctor(1).div(r) : finalise(r, pr, rm);\r\n }\r\n\r\n s = x.s;\r\n\r\n // if x is negative\r\n if (s < 0) {\r\n\r\n // if y is not an integer\r\n if (e < y.d.length - 1) return new Ctor(NaN);\r\n\r\n // Result is positive if x is negative and the last digit of integer y is even.\r\n if ((y.d[e] & 1) == 0) s = 1;\r\n\r\n // if x.eq(-1)\r\n if (x.e == 0 && x.d[0] == 1 && x.d.length == 1) {\r\n x.s = s;\r\n return x;\r\n }\r\n }\r\n\r\n // Estimate result exponent.\r\n // x^y = 10^e, where e = y * log10(x)\r\n // log10(x) = log10(x_significand) + x_exponent\r\n // log10(x_significand) = ln(x_significand) / ln(10)\r\n k = mathpow(+x, yn);\r\n e = k == 0 || !isFinite(k)\r\n ? mathfloor(yn * (Math.log('0.' + digitsToString(x.d)) / Math.LN10 + x.e + 1))\r\n : new Ctor(k + '').e;\r\n\r\n // Exponent estimate may be incorrect e.g. x: 0.999999999999999999, y: 2.29, e: 0, r.e: -1.\r\n\r\n // Overflow/underflow?\r\n if (e > Ctor.maxE + 1 || e < Ctor.minE - 1) return new Ctor(e > 0 ? s / 0 : 0);\r\n\r\n external = false;\r\n Ctor.rounding = x.s = 1;\r\n\r\n // Estimate the extra guard digits needed to ensure five correct rounding digits from\r\n // naturalLogarithm(x). Example of failure without these extra digits (precision: 10):\r\n // new Decimal(2.32456).pow('2087987436534566.46411')\r\n // should be 1.162377823e+764914905173815, but is 1.162355823e+764914905173815\r\n k = Math.min(12, (e + '').length);\r\n\r\n // r = x^y = exp(y*ln(x))\r\n r = naturalExponential(y.times(naturalLogarithm(x, pr + k)), pr);\r\n\r\n // r may be Infinity, e.g. (0.9999999999999999).pow(-1e+40)\r\n if (r.d) {\r\n\r\n // Truncate to the required precision plus five rounding digits.\r\n r = finalise(r, pr + 5, 1);\r\n\r\n // If the rounding digits are [49]9999 or [50]0000 increase the precision by 10 and recalculate\r\n // the result.\r\n if (checkRoundingDigits(r.d, pr, rm)) {\r\n e = pr + 10;\r\n\r\n // Truncate to the increased precision plus five rounding digits.\r\n r = finalise(naturalExponential(y.times(naturalLogarithm(x, e + k)), e), e + 5, 1);\r\n\r\n // Check for 14 nines from the 2nd rounding digit (the first rounding digit may be 4 or 9).\r\n if (+digitsToString(r.d).slice(pr + 1, pr + 15) + 1 == 1e14) {\r\n r = finalise(r, pr + 1, 0);\r\n }\r\n }\r\n }\r\n\r\n r.s = s;\r\n external = true;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(r, pr, rm);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this Decimal rounded to `sd` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * Return exponential notation if `sd` is less than the number of digits necessary to represent\r\n * the integer part of the value in normal notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\n P.toPrecision = function (sd, rm) {\r\n var str,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (sd === void 0) {\r\n str = finiteToString(x, x.e <= Ctor.toExpNeg || x.e >= Ctor.toExpPos);\r\n } else {\r\n checkInt32(sd, 1, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n x = finalise(new Ctor(x), sd, rm);\r\n str = finiteToString(x, sd <= x.e || x.e <= Ctor.toExpNeg, sd);\r\n }\r\n\r\n return x.isNeg() && !x.isZero() ? '-' + str : str;\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a maximum of `sd`\r\n * significant digits using rounding mode `rm`, or to `precision` and `rounding` respectively if\r\n * omitted.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * 'toSD() digits out of range: {sd}'\r\n * 'toSD() digits not an integer: {sd}'\r\n * 'toSD() rounding mode not an integer: {rm}'\r\n * 'toSD() rounding mode out of range: {rm}'\r\n *\r\n */\r\n P.toSignificantDigits = P.toSD = function (sd, rm) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n if (sd === void 0) {\r\n sd = Ctor.precision;\r\n rm = Ctor.rounding;\r\n } else {\r\n checkInt32(sd, 1, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n }\r\n\r\n return finalise(new Ctor(x), sd, rm);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this Decimal.\r\n *\r\n * Return exponential notation if this Decimal has a positive exponent equal to or greater than\r\n * `toExpPos`, or a negative exponent equal to or less than `toExpNeg`.\r\n *\r\n */\r\n P.toString = function () {\r\n var x = this,\r\n Ctor = x.constructor,\r\n str = finiteToString(x, x.e <= Ctor.toExpNeg || x.e >= Ctor.toExpPos);\r\n\r\n return x.isNeg() && !x.isZero() ? '-' + str : str;\r\n };\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the value of this Decimal truncated to a whole number.\r\n *\r\n */\r\n P.truncated = P.trunc = function () {\r\n return finalise(new this.constructor(this), this.e + 1, 1);\r\n };\r\n\r\n\r\n /*\r\n * Return a string representing the value of this Decimal.\r\n * Unlike `toString`, negative zero will include the minus sign.\r\n *\r\n */\r\n P.valueOf = P.toJSON = function () {\r\n var x = this,\r\n Ctor = x.constructor,\r\n str = finiteToString(x, x.e <= Ctor.toExpNeg || x.e >= Ctor.toExpPos);\r\n\r\n return x.isNeg() ? '-' + str : str;\r\n };\r\n\r\n\r\n // Helper functions for Decimal.prototype (P) and/or Decimal methods, and their callers.\r\n\r\n\r\n /*\r\n * digitsToString P.cubeRoot, P.logarithm, P.squareRoot, P.toFraction, P.toPower,\r\n * finiteToString, naturalExponential, naturalLogarithm\r\n * checkInt32 P.toDecimalPlaces, P.toExponential, P.toFixed, P.toNearest,\r\n * P.toPrecision, P.toSignificantDigits, toStringBinary, random\r\n * checkRoundingDigits P.logarithm, P.toPower, naturalExponential, naturalLogarithm\r\n * convertBase toStringBinary, parseOther\r\n * cos P.cos\r\n * divide P.atanh, P.cubeRoot, P.dividedBy, P.dividedToIntegerBy,\r\n * P.logarithm, P.modulo, P.squareRoot, P.tan, P.tanh, P.toFraction,\r\n * P.toNearest, toStringBinary, naturalExponential, naturalLogarithm,\r\n * taylorSeries, atan2, parseOther\r\n * finalise P.absoluteValue, P.atan, P.atanh, P.ceil, P.cos, P.cosh,\r\n * P.cubeRoot, P.dividedToIntegerBy, P.floor, P.logarithm, P.minus,\r\n * P.modulo, P.negated, P.plus, P.round, P.sin, P.sinh, P.squareRoot,\r\n * P.tan, P.times, P.toDecimalPlaces, P.toExponential, P.toFixed,\r\n * P.toNearest, P.toPower, P.toPrecision, P.toSignificantDigits,\r\n * P.truncated, divide, getLn10, getPi, naturalExponential,\r\n * naturalLogarithm, ceil, floor, round, trunc\r\n * finiteToString P.toExponential, P.toFixed, P.toPrecision, P.toString, P.valueOf,\r\n * toStringBinary\r\n * getBase10Exponent P.minus, P.plus, P.times, parseOther\r\n * getLn10 P.logarithm, naturalLogarithm\r\n * getPi P.acos, P.asin, P.atan, toLessThanHalfPi, atan2\r\n * getPrecision P.precision, P.toFraction\r\n * getZeroString digitsToString, finiteToString\r\n * intPow P.toPower, parseOther\r\n * isOdd toLessThanHalfPi\r\n * maxOrMin max, min\r\n * naturalExponential P.naturalExponential, P.toPower\r\n * naturalLogarithm P.acosh, P.asinh, P.atanh, P.logarithm, P.naturalLogarithm,\r\n * P.toPower, naturalExponential\r\n * nonFiniteToString finiteToString, toStringBinary\r\n * parseDecimal Decimal\r\n * parseOther Decimal\r\n * sin P.sin\r\n * taylorSeries P.cosh, P.sinh, cos, sin\r\n * toLessThanHalfPi P.cos, P.sin\r\n * toStringBinary P.toBinary, P.toHexadecimal, P.toOctal\r\n * truncate intPow\r\n *\r\n * Throws: P.logarithm, P.precision, P.toFraction, checkInt32, getLn10, getPi,\r\n * naturalLogarithm, config, parseOther, random, Decimal\r\n */\r\n\r\n\r\n function digitsToString(d) {\r\n var i, k, ws,\r\n indexOfLastWord = d.length - 1,\r\n str = '',\r\n w = d[0];\r\n\r\n if (indexOfLastWord > 0) {\r\n str += w;\r\n for (i = 1; i < indexOfLastWord; i++) {\r\n ws = d[i] + '';\r\n k = LOG_BASE - ws.length;\r\n if (k) str += getZeroString(k);\r\n str += ws;\r\n }\r\n\r\n w = d[i];\r\n ws = w + '';\r\n k = LOG_BASE - ws.length;\r\n if (k) str += getZeroString(k);\r\n } else if (w === 0) {\r\n return '0';\r\n }\r\n\r\n // Remove trailing zeros of last w.\r\n for (; w % 10 === 0;) w /= 10;\r\n\r\n return str + w;\r\n }\r\n\r\n\r\n function checkInt32(i, min, max) {\r\n if (i !== ~~i || i < min || i > max) {\r\n throw Error(invalidArgument + i);\r\n }\r\n }\r\n\r\n\r\n /*\r\n * Check 5 rounding digits if `repeating` is null, 4 otherwise.\r\n * `repeating == null` if caller is `log` or `pow`,\r\n * `repeating != null` if caller is `naturalLogarithm` or `naturalExponential`.\r\n */\r\n function checkRoundingDigits(d, i, rm, repeating) {\r\n var di, k, r, rd;\r\n\r\n // Get the length of the first word of the array d.\r\n for (k = d[0]; k >= 10; k /= 10) --i;\r\n\r\n // Is the rounding digit in the first word of d?\r\n if (--i < 0) {\r\n i += LOG_BASE;\r\n di = 0;\r\n } else {\r\n di = Math.ceil((i + 1) / LOG_BASE);\r\n i %= LOG_BASE;\r\n }\r\n\r\n // i is the index (0 - 6) of the rounding digit.\r\n // E.g. if within the word 3487563 the first rounding digit is 5,\r\n // then i = 4, k = 1000, rd = 3487563 % 1000 = 563\r\n k = mathpow(10, LOG_BASE - i);\r\n rd = d[di] % k | 0;\r\n\r\n if (repeating == null) {\r\n if (i < 3) {\r\n if (i == 0) rd = rd / 100 | 0;\r\n else if (i == 1) rd = rd / 10 | 0;\r\n r = rm < 4 && rd == 99999 || rm > 3 && rd == 49999 || rd == 50000 || rd == 0;\r\n } else {\r\n r = (rm < 4 && rd + 1 == k || rm > 3 && rd + 1 == k / 2) &&\r\n (d[di + 1] / k / 100 | 0) == mathpow(10, i - 2) - 1 ||\r\n (rd == k / 2 || rd == 0) && (d[di + 1] / k / 100 | 0) == 0;\r\n }\r\n } else {\r\n if (i < 4) {\r\n if (i == 0) rd = rd / 1000 | 0;\r\n else if (i == 1) rd = rd / 100 | 0;\r\n else if (i == 2) rd = rd / 10 | 0;\r\n r = (repeating || rm < 4) && rd == 9999 || !repeating && rm > 3 && rd == 4999;\r\n } else {\r\n r = ((repeating || rm < 4) && rd + 1 == k ||\r\n (!repeating && rm > 3) && rd + 1 == k / 2) &&\r\n (d[di + 1] / k / 1000 | 0) == mathpow(10, i - 3) - 1;\r\n }\r\n }\r\n\r\n return r;\r\n }\r\n\r\n\r\n // Convert string of `baseIn` to an array of numbers of `baseOut`.\r\n // Eg. convertBase('255', 10, 16) returns [15, 15].\r\n // Eg. convertBase('ff', 16, 10) returns [2, 5, 5].\r\n function convertBase(str, baseIn, baseOut) {\r\n var j,\r\n arr = [0],\r\n arrL,\r\n i = 0,\r\n strL = str.length;\r\n\r\n for (; i < strL;) {\r\n for (arrL = arr.length; arrL--;) arr[arrL] *= baseIn;\r\n arr[0] += NUMERALS.indexOf(str.charAt(i++));\r\n for (j = 0; j < arr.length; j++) {\r\n if (arr[j] > baseOut - 1) {\r\n if (arr[j + 1] === void 0) arr[j + 1] = 0;\r\n arr[j + 1] += arr[j] / baseOut | 0;\r\n arr[j] %= baseOut;\r\n }\r\n }\r\n }\r\n\r\n return arr.reverse();\r\n }\r\n\r\n\r\n /*\r\n * cos(x) = 1 - x^2/2! + x^4/4! - ...\r\n * |x| < pi/2\r\n *\r\n */\r\n function cosine(Ctor, x) {\r\n var k, len, y;\r\n\r\n if (x.isZero()) return x;\r\n\r\n // Argument reduction: cos(4x) = 8*(cos^4(x) - cos^2(x)) + 1\r\n // i.e. cos(x) = 8*(cos^4(x/4) - cos^2(x/4)) + 1\r\n\r\n // Estimate the optimum number of times to use the argument reduction.\r\n len = x.d.length;\r\n if (len < 32) {\r\n k = Math.ceil(len / 3);\r\n y = (1 / tinyPow(4, k)).toString();\r\n } else {\r\n k = 16;\r\n y = '2.3283064365386962890625e-10';\r\n }\r\n\r\n Ctor.precision += k;\r\n\r\n x = taylorSeries(Ctor, 1, x.times(y), new Ctor(1));\r\n\r\n // Reverse argument reduction\r\n for (var i = k; i--;) {\r\n var cos2x = x.times(x);\r\n x = cos2x.times(cos2x).minus(cos2x).times(8).plus(1);\r\n }\r\n\r\n Ctor.precision -= k;\r\n\r\n return x;\r\n }\r\n\r\n\r\n /*\r\n * Perform division in the specified base.\r\n */\r\n var divide = (function () {\r\n\r\n // Assumes non-zero x and k, and hence non-zero result.\r\n function multiplyInteger(x, k, base) {\r\n var temp,\r\n carry = 0,\r\n i = x.length;\r\n\r\n for (x = x.slice(); i--;) {\r\n temp = x[i] * k + carry;\r\n x[i] = temp % base | 0;\r\n carry = temp / base | 0;\r\n }\r\n\r\n if (carry) x.unshift(carry);\r\n\r\n return x;\r\n }\r\n\r\n function compare(a, b, aL, bL) {\r\n var i, r;\r\n\r\n if (aL != bL) {\r\n r = aL > bL ? 1 : -1;\r\n } else {\r\n for (i = r = 0; i < aL; i++) {\r\n if (a[i] != b[i]) {\r\n r = a[i] > b[i] ? 1 : -1;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n return r;\r\n }\r\n\r\n function subtract(a, b, aL, base) {\r\n var i = 0;\r\n\r\n // Subtract b from a.\r\n for (; aL--;) {\r\n a[aL] -= i;\r\n i = a[aL] < b[aL] ? 1 : 0;\r\n a[aL] = i * base + a[aL] - b[aL];\r\n }\r\n\r\n // Remove leading zeros.\r\n for (; !a[0] && a.length > 1;) a.shift();\r\n }\r\n\r\n return function (x, y, pr, rm, dp, base) {\r\n var cmp, e, i, k, logBase, more, prod, prodL, q, qd, rem, remL, rem0, sd, t, xi, xL, yd0,\r\n yL, yz,\r\n Ctor = x.constructor,\r\n sign = x.s == y.s ? 1 : -1,\r\n xd = x.d,\r\n yd = y.d;\r\n\r\n // Either NaN, Infinity or 0?\r\n if (!xd || !xd[0] || !yd || !yd[0]) {\r\n\r\n return new Ctor(// Return NaN if either NaN, or both Infinity or 0.\r\n !x.s || !y.s || (xd ? yd && xd[0] == yd[0] : !yd) ? NaN :\r\n\r\n // Return ±0 if x is 0 or y is ±Infinity, or return ±Infinity as y is 0.\r\n xd && xd[0] == 0 || !yd ? sign * 0 : sign / 0);\r\n }\r\n\r\n if (base) {\r\n logBase = 1;\r\n e = x.e - y.e;\r\n } else {\r\n base = BASE;\r\n logBase = LOG_BASE;\r\n e = mathfloor(x.e / logBase) - mathfloor(y.e / logBase);\r\n }\r\n\r\n yL = yd.length;\r\n xL = xd.length;\r\n q = new Ctor(sign);\r\n qd = q.d = [];\r\n\r\n // Result exponent may be one less than e.\r\n // The digit array of a Decimal from toStringBinary may have trailing zeros.\r\n for (i = 0; yd[i] == (xd[i] || 0); i++);\r\n\r\n if (yd[i] > (xd[i] || 0)) e--;\r\n\r\n if (pr == null) {\r\n sd = pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n } else if (dp) {\r\n sd = pr + (x.e - y.e) + 1;\r\n } else {\r\n sd = pr;\r\n }\r\n\r\n if (sd < 0) {\r\n qd.push(1);\r\n more = true;\r\n } else {\r\n\r\n // Convert precision in number of base 10 digits to base 1e7 digits.\r\n sd = sd / logBase + 2 | 0;\r\n i = 0;\r\n\r\n // divisor < 1e7\r\n if (yL == 1) {\r\n k = 0;\r\n yd = yd[0];\r\n sd++;\r\n\r\n // k is the carry.\r\n for (; (i < xL || k) && sd--; i++) {\r\n t = k * base + (xd[i] || 0);\r\n qd[i] = t / yd | 0;\r\n k = t % yd | 0;\r\n }\r\n\r\n more = k || i < xL;\r\n\r\n // divisor >= 1e7\r\n } else {\r\n\r\n // Normalise xd and yd so highest order digit of yd is >= base/2\r\n k = base / (yd[0] + 1) | 0;\r\n\r\n if (k > 1) {\r\n yd = multiplyInteger(yd, k, base);\r\n xd = multiplyInteger(xd, k, base);\r\n yL = yd.length;\r\n xL = xd.length;\r\n }\r\n\r\n xi = yL;\r\n rem = xd.slice(0, yL);\r\n remL = rem.length;\r\n\r\n // Add zeros to make remainder as long as divisor.\r\n for (; remL < yL;) rem[remL++] = 0;\r\n\r\n yz = yd.slice();\r\n yz.unshift(0);\r\n yd0 = yd[0];\r\n\r\n if (yd[1] >= base / 2) ++yd0;\r\n\r\n do {\r\n k = 0;\r\n\r\n // Compare divisor and remainder.\r\n cmp = compare(yd, rem, yL, remL);\r\n\r\n // If divisor < remainder.\r\n if (cmp < 0) {\r\n\r\n // Calculate trial digit, k.\r\n rem0 = rem[0];\r\n if (yL != remL) rem0 = rem0 * base + (rem[1] || 0);\r\n\r\n // k will be how many times the divisor goes into the current remainder.\r\n k = rem0 / yd0 | 0;\r\n\r\n // Algorithm:\r\n // 1. product = divisor * trial digit (k)\r\n // 2. if product > remainder: product -= divisor, k--\r\n // 3. remainder -= product\r\n // 4. if product was < remainder at 2:\r\n // 5. compare new remainder and divisor\r\n // 6. If remainder > divisor: remainder -= divisor, k++\r\n\r\n if (k > 1) {\r\n if (k >= base) k = base - 1;\r\n\r\n // product = divisor * trial digit.\r\n prod = multiplyInteger(yd, k, base);\r\n prodL = prod.length;\r\n remL = rem.length;\r\n\r\n // Compare product and remainder.\r\n cmp = compare(prod, rem, prodL, remL);\r\n\r\n // product > remainder.\r\n if (cmp == 1) {\r\n k--;\r\n\r\n // Subtract divisor from product.\r\n subtract(prod, yL < prodL ? yz : yd, prodL, base);\r\n }\r\n } else {\r\n\r\n // cmp is -1.\r\n // If k is 0, there is no need to compare yd and rem again below, so change cmp to 1\r\n // to avoid it. If k is 1 there is a need to compare yd and rem again below.\r\n if (k == 0) cmp = k = 1;\r\n prod = yd.slice();\r\n }\r\n\r\n prodL = prod.length;\r\n if (prodL < remL) prod.unshift(0);\r\n\r\n // Subtract product from remainder.\r\n subtract(rem, prod, remL, base);\r\n\r\n // If product was < previous remainder.\r\n if (cmp == -1) {\r\n remL = rem.length;\r\n\r\n // Compare divisor and new remainder.\r\n cmp = compare(yd, rem, yL, remL);\r\n\r\n // If divisor < new remainder, subtract divisor from remainder.\r\n if (cmp < 1) {\r\n k++;\r\n\r\n // Subtract divisor from remainder.\r\n subtract(rem, yL < remL ? yz : yd, remL, base);\r\n }\r\n }\r\n\r\n remL = rem.length;\r\n } else if (cmp === 0) {\r\n k++;\r\n rem = [0];\r\n } // if cmp === 1, k will be 0\r\n\r\n // Add the next digit, k, to the result array.\r\n qd[i++] = k;\r\n\r\n // Update the remainder.\r\n if (cmp && rem[0]) {\r\n rem[remL++] = xd[xi] || 0;\r\n } else {\r\n rem = [xd[xi]];\r\n remL = 1;\r\n }\r\n\r\n } while ((xi++ < xL || rem[0] !== void 0) && sd--);\r\n\r\n more = rem[0] !== void 0;\r\n }\r\n\r\n // Leading zero?\r\n if (!qd[0]) qd.shift();\r\n }\r\n\r\n // logBase is 1 when divide is being used for base conversion.\r\n if (logBase == 1) {\r\n q.e = e;\r\n inexact = more;\r\n } else {\r\n\r\n // To calculate q.e, first get the number of digits of qd[0].\r\n for (i = 1, k = qd[0]; k >= 10; k /= 10) i++;\r\n q.e = i + e * logBase - 1;\r\n\r\n finalise(q, dp ? pr + q.e + 1 : pr, rm, more);\r\n }\r\n\r\n return q;\r\n };\r\n })();\r\n\r\n\r\n /*\r\n * Round `x` to `sd` significant digits using rounding mode `rm`.\r\n * Check for over/under-flow.\r\n */\r\n function finalise(x, sd, rm, isTruncated) {\r\n var digits, i, j, k, rd, roundUp, w, xd, xdi,\r\n Ctor = x.constructor;\r\n\r\n // Don't round if sd is null or undefined.\r\n out: if (sd != null) {\r\n xd = x.d;\r\n\r\n // Infinity/NaN.\r\n if (!xd) return x;\r\n\r\n // rd: the rounding digit, i.e. the digit after the digit that may be rounded up.\r\n // w: the word of xd containing rd, a base 1e7 number.\r\n // xdi: the index of w within xd.\r\n // digits: the number of digits of w.\r\n // i: what would be the index of rd within w if all the numbers were 7 digits long (i.e. if\r\n // they had leading zeros)\r\n // j: if > 0, the actual index of rd within w (if < 0, rd is a leading zero).\r\n\r\n // Get the length of the first word of the digits array xd.\r\n for (digits = 1, k = xd[0]; k >= 10; k /= 10) digits++;\r\n i = sd - digits;\r\n\r\n // Is the rounding digit in the first word of xd?\r\n if (i < 0) {\r\n i += LOG_BASE;\r\n j = sd;\r\n w = xd[xdi = 0];\r\n\r\n // Get the rounding digit at index j of w.\r\n rd = w / mathpow(10, digits - j - 1) % 10 | 0;\r\n } else {\r\n xdi = Math.ceil((i + 1) / LOG_BASE);\r\n k = xd.length;\r\n if (xdi >= k) {\r\n if (isTruncated) {\r\n\r\n // Needed by `naturalExponential`, `naturalLogarithm` and `squareRoot`.\r\n for (; k++ <= xdi;) xd.push(0);\r\n w = rd = 0;\r\n digits = 1;\r\n i %= LOG_BASE;\r\n j = i - LOG_BASE + 1;\r\n } else {\r\n break out;\r\n }\r\n } else {\r\n w = k = xd[xdi];\r\n\r\n // Get the number of digits of w.\r\n for (digits = 1; k >= 10; k /= 10) digits++;\r\n\r\n // Get the index of rd within w.\r\n i %= LOG_BASE;\r\n\r\n // Get the index of rd within w, adjusted for leading zeros.\r\n // The number of leading zeros of w is given by LOG_BASE - digits.\r\n j = i - LOG_BASE + digits;\r\n\r\n // Get the rounding digit at index j of w.\r\n rd = j < 0 ? 0 : w / mathpow(10, digits - j - 1) % 10 | 0;\r\n }\r\n }\r\n\r\n // Are there any non-zero digits after the rounding digit?\r\n isTruncated = isTruncated || sd < 0 ||\r\n xd[xdi + 1] !== void 0 || (j < 0 ? w : w % mathpow(10, digits - j - 1));\r\n\r\n // The expression `w % mathpow(10, digits - j - 1)` returns all the digits of w to the right\r\n // of the digit at (left-to-right) index j, e.g. if w is 908714 and j is 2, the expression\r\n // will give 714.\r\n\r\n roundUp = rm < 4\r\n ? (rd || isTruncated) && (rm == 0 || rm == (x.s < 0 ? 3 : 2))\r\n : rd > 5 || rd == 5 && (rm == 4 || isTruncated || rm == 6 &&\r\n\r\n // Check whether the digit to the left of the rounding digit is odd.\r\n ((i > 0 ? j > 0 ? w / mathpow(10, digits - j) : 0 : xd[xdi - 1]) % 10) & 1 ||\r\n rm == (x.s < 0 ? 8 : 7));\r\n\r\n if (sd < 1 || !xd[0]) {\r\n xd.length = 0;\r\n if (roundUp) {\r\n\r\n // Convert sd to decimal places.\r\n sd -= x.e + 1;\r\n\r\n // 1, 0.1, 0.01, 0.001, 0.0001 etc.\r\n xd[0] = mathpow(10, (LOG_BASE - sd % LOG_BASE) % LOG_BASE);\r\n x.e = -sd || 0;\r\n } else {\r\n\r\n // Zero.\r\n xd[0] = x.e = 0;\r\n }\r\n\r\n return x;\r\n }\r\n\r\n // Remove excess digits.\r\n if (i == 0) {\r\n xd.length = xdi;\r\n k = 1;\r\n xdi--;\r\n } else {\r\n xd.length = xdi + 1;\r\n k = mathpow(10, LOG_BASE - i);\r\n\r\n // E.g. 56700 becomes 56000 if 7 is the rounding digit.\r\n // j > 0 means i > number of leading zeros of w.\r\n xd[xdi] = j > 0 ? (w / mathpow(10, digits - j) % mathpow(10, j) | 0) * k : 0;\r\n }\r\n\r\n if (roundUp) {\r\n for (;;) {\r\n\r\n // Is the digit to be rounded up in the first word of xd?\r\n if (xdi == 0) {\r\n\r\n // i will be the length of xd[0] before k is added.\r\n for (i = 1, j = xd[0]; j >= 10; j /= 10) i++;\r\n j = xd[0] += k;\r\n for (k = 1; j >= 10; j /= 10) k++;\r\n\r\n // if i != k the length has increased.\r\n if (i != k) {\r\n x.e++;\r\n if (xd[0] == BASE) xd[0] = 1;\r\n }\r\n\r\n break;\r\n } else {\r\n xd[xdi] += k;\r\n if (xd[xdi] != BASE) break;\r\n xd[xdi--] = 0;\r\n k = 1;\r\n }\r\n }\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (i = xd.length; xd[--i] === 0;) xd.pop();\r\n }\r\n\r\n if (external) {\r\n\r\n // Overflow?\r\n if (x.e > Ctor.maxE) {\r\n\r\n // Infinity.\r\n x.d = null;\r\n x.e = NaN;\r\n\r\n // Underflow?\r\n } else if (x.e < Ctor.minE) {\r\n\r\n // Zero.\r\n x.e = 0;\r\n x.d = [0];\r\n // Ctor.underflow = true;\r\n } // else Ctor.underflow = false;\r\n }\r\n\r\n return x;\r\n }\r\n\r\n\r\n function finiteToString(x, isExp, sd) {\r\n if (!x.isFinite()) return nonFiniteToString(x);\r\n var k,\r\n e = x.e,\r\n str = digitsToString(x.d),\r\n len = str.length;\r\n\r\n if (isExp) {\r\n if (sd && (k = sd - len) > 0) {\r\n str = str.charAt(0) + '.' + str.slice(1) + getZeroString(k);\r\n } else if (len > 1) {\r\n str = str.charAt(0) + '.' + str.slice(1);\r\n }\r\n\r\n str = str + (x.e < 0 ? 'e' : 'e+') + x.e;\r\n } else if (e < 0) {\r\n str = '0.' + getZeroString(-e - 1) + str;\r\n if (sd && (k = sd - len) > 0) str += getZeroString(k);\r\n } else if (e >= len) {\r\n str += getZeroString(e + 1 - len);\r\n if (sd && (k = sd - e - 1) > 0) str = str + '.' + getZeroString(k);\r\n } else {\r\n if ((k = e + 1) < len) str = str.slice(0, k) + '.' + str.slice(k);\r\n if (sd && (k = sd - len) > 0) {\r\n if (e + 1 === len) str += '.';\r\n str += getZeroString(k);\r\n }\r\n }\r\n\r\n return str;\r\n }\r\n\r\n\r\n // Calculate the base 10 exponent from the base 1e7 exponent.\r\n function getBase10Exponent(digits, e) {\r\n var w = digits[0];\r\n\r\n // Add the number of digits of the first word of the digits array.\r\n for ( e *= LOG_BASE; w >= 10; w /= 10) e++;\r\n return e;\r\n }\r\n\r\n\r\n function getLn10(Ctor, sd, pr) {\r\n if (sd > LN10_PRECISION) {\r\n\r\n // Reset global state in case the exception is caught.\r\n external = true;\r\n if (pr) Ctor.precision = pr;\r\n throw Error(precisionLimitExceeded);\r\n }\r\n return finalise(new Ctor(LN10), sd, 1, true);\r\n }\r\n\r\n\r\n function getPi(Ctor, sd, rm) {\r\n if (sd > PI_PRECISION) throw Error(precisionLimitExceeded);\r\n return finalise(new Ctor(PI), sd, rm, true);\r\n }\r\n\r\n\r\n function getPrecision(digits) {\r\n var w = digits.length - 1,\r\n len = w * LOG_BASE + 1;\r\n\r\n w = digits[w];\r\n\r\n // If non-zero...\r\n if (w) {\r\n\r\n // Subtract the number of trailing zeros of the last word.\r\n for (; w % 10 == 0; w /= 10) len--;\r\n\r\n // Add the number of digits of the first word.\r\n for (w = digits[0]; w >= 10; w /= 10) len++;\r\n }\r\n\r\n return len;\r\n }\r\n\r\n\r\n function getZeroString(k) {\r\n var zs = '';\r\n for (; k--;) zs += '0';\r\n return zs;\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the value of Decimal `x` to the power `n`, where `n` is an\r\n * integer of type number.\r\n *\r\n * Implements 'exponentiation by squaring'. Called by `pow` and `parseOther`.\r\n *\r\n */\r\n function intPow(Ctor, x, n, pr) {\r\n var isTruncated,\r\n r = new Ctor(1),\r\n\r\n // Max n of 9007199254740991 takes 53 loop iterations.\r\n // Maximum digits array length; leaves [28, 34] guard digits.\r\n k = Math.ceil(pr / LOG_BASE + 4);\r\n\r\n external = false;\r\n\r\n for (;;) {\r\n if (n % 2) {\r\n r = r.times(x);\r\n if (truncate(r.d, k)) isTruncated = true;\r\n }\r\n\r\n n = mathfloor(n / 2);\r\n if (n === 0) {\r\n\r\n // To ensure correct rounding when r.d is truncated, increment the last word if it is zero.\r\n n = r.d.length - 1;\r\n if (isTruncated && r.d[n] === 0) ++r.d[n];\r\n break;\r\n }\r\n\r\n x = x.times(x);\r\n truncate(x.d, k);\r\n }\r\n\r\n external = true;\r\n\r\n return r;\r\n }\r\n\r\n\r\n function isOdd(n) {\r\n return n.d[n.d.length - 1] & 1;\r\n }\r\n\r\n\r\n /*\r\n * Handle `max` and `min`. `ltgt` is 'lt' or 'gt'.\r\n */\r\n function maxOrMin(Ctor, args, ltgt) {\r\n var y,\r\n x = new Ctor(args[0]),\r\n i = 0;\r\n\r\n for (; ++i < args.length;) {\r\n y = new Ctor(args[i]);\r\n if (!y.s) {\r\n x = y;\r\n break;\r\n } else if (x[ltgt](y)) {\r\n x = y;\r\n }\r\n }\r\n\r\n return x;\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the natural exponential of `x` rounded to `sd` significant\r\n * digits.\r\n *\r\n * Taylor/Maclaurin series.\r\n *\r\n * exp(x) = x^0/0! + x^1/1! + x^2/2! + x^3/3! + ...\r\n *\r\n * Argument reduction:\r\n * Repeat x = x / 32, k += 5, until |x| < 0.1\r\n * exp(x) = exp(x / 2^k)^(2^k)\r\n *\r\n * Previously, the argument was initially reduced by\r\n * exp(x) = exp(r) * 10^k where r = x - k * ln10, k = floor(x / ln10)\r\n * to first put r in the range [0, ln10], before dividing by 32 until |x| < 0.1, but this was\r\n * found to be slower than just dividing repeatedly by 32 as above.\r\n *\r\n * Max integer argument: exp('20723265836946413') = 6.3e+9000000000000000\r\n * Min integer argument: exp('-20723265836946411') = 1.2e-9000000000000000\r\n * (Math object integer min/max: Math.exp(709) = 8.2e+307, Math.exp(-745) = 5e-324)\r\n *\r\n * exp(Infinity) = Infinity\r\n * exp(-Infinity) = 0\r\n * exp(NaN) = NaN\r\n * exp(±0) = 1\r\n *\r\n * exp(x) is non-terminating for any finite, non-zero x.\r\n *\r\n * The result will always be correctly rounded.\r\n *\r\n */\r\n function naturalExponential(x, sd) {\r\n var denominator, guard, j, pow, sum, t, wpr,\r\n rep = 0,\r\n i = 0,\r\n k = 0,\r\n Ctor = x.constructor,\r\n rm = Ctor.rounding,\r\n pr = Ctor.precision;\r\n\r\n // 0/NaN/Infinity?\r\n if (!x.d || !x.d[0] || x.e > 17) {\r\n\r\n return new Ctor(x.d\r\n ? !x.d[0] ? 1 : x.s < 0 ? 0 : 1 / 0\r\n : x.s ? x.s < 0 ? 0 : x : 0 / 0);\r\n }\r\n\r\n if (sd == null) {\r\n external = false;\r\n wpr = pr;\r\n } else {\r\n wpr = sd;\r\n }\r\n\r\n t = new Ctor(0.03125);\r\n\r\n // while abs(x) >= 0.1\r\n while (x.e > -2) {\r\n\r\n // x = x / 2^5\r\n x = x.times(t);\r\n k += 5;\r\n }\r\n\r\n // Use 2 * log10(2^k) + 5 (empirically derived) to estimate the increase in precision\r\n // necessary to ensure the first 4 rounding digits are correct.\r\n guard = Math.log(mathpow(2, k)) / Math.LN10 * 2 + 5 | 0;\r\n wpr += guard;\r\n denominator = pow = sum = new Ctor(1);\r\n Ctor.precision = wpr;\r\n\r\n for (;;) {\r\n pow = finalise(pow.times(x), wpr, 1);\r\n denominator = denominator.times(++i);\r\n t = sum.plus(divide(pow, denominator, wpr, 1));\r\n\r\n if (digitsToString(t.d).slice(0, wpr) === digitsToString(sum.d).slice(0, wpr)) {\r\n j = k;\r\n while (j--) sum = finalise(sum.times(sum), wpr, 1);\r\n\r\n // Check to see if the first 4 rounding digits are [49]999.\r\n // If so, repeat the summation with a higher precision, otherwise\r\n // e.g. with precision: 18, rounding: 1\r\n // exp(18.404272462595034083567793919843761) = 98372560.1229999999 (should be 98372560.123)\r\n // `wpr - guard` is the index of first rounding digit.\r\n if (sd == null) {\r\n\r\n if (rep < 3 && checkRoundingDigits(sum.d, wpr - guard, rm, rep)) {\r\n Ctor.precision = wpr += 10;\r\n denominator = pow = t = new Ctor(1);\r\n i = 0;\r\n rep++;\r\n } else {\r\n return finalise(sum, Ctor.precision = pr, rm, external = true);\r\n }\r\n } else {\r\n Ctor.precision = pr;\r\n return sum;\r\n }\r\n }\r\n\r\n sum = t;\r\n }\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the natural logarithm of `x` rounded to `sd` significant\r\n * digits.\r\n *\r\n * ln(-n) = NaN\r\n * ln(0) = -Infinity\r\n * ln(-0) = -Infinity\r\n * ln(1) = 0\r\n * ln(Infinity) = Infinity\r\n * ln(-Infinity) = NaN\r\n * ln(NaN) = NaN\r\n *\r\n * ln(n) (n != 1) is non-terminating.\r\n *\r\n */\r\n function naturalLogarithm(y, sd) {\r\n var c, c0, denominator, e, numerator, rep, sum, t, wpr, x1, x2,\r\n n = 1,\r\n guard = 10,\r\n x = y,\r\n xd = x.d,\r\n Ctor = x.constructor,\r\n rm = Ctor.rounding,\r\n pr = Ctor.precision;\r\n\r\n // Is x negative or Infinity, NaN, 0 or 1?\r\n if (x.s < 0 || !xd || !xd[0] || !x.e && xd[0] == 1 && xd.length == 1) {\r\n return new Ctor(xd && !xd[0] ? -1 / 0 : x.s != 1 ? NaN : xd ? 0 : x);\r\n }\r\n\r\n if (sd == null) {\r\n external = false;\r\n wpr = pr;\r\n } else {\r\n wpr = sd;\r\n }\r\n\r\n Ctor.precision = wpr += guard;\r\n c = digitsToString(xd);\r\n c0 = c.charAt(0);\r\n\r\n if (Math.abs(e = x.e) < 1.5e15) {\r\n\r\n // Argument reduction.\r\n // The series converges faster the closer the argument is to 1, so using\r\n // ln(a^b) = b * ln(a), ln(a) = ln(a^b) / b\r\n // multiply the argument by itself until the leading digits of the significand are 7, 8, 9,\r\n // 10, 11, 12 or 13, recording the number of multiplications so the sum of the series can\r\n // later be divided by this number, then separate out the power of 10 using\r\n // ln(a*10^b) = ln(a) + b*ln(10).\r\n\r\n // max n is 21 (gives 0.9, 1.0 or 1.1) (9e15 / 21 = 4.2e14).\r\n //while (c0 < 9 && c0 != 1 || c0 == 1 && c.charAt(1) > 1) {\r\n // max n is 6 (gives 0.7 - 1.3)\r\n while (c0 < 7 && c0 != 1 || c0 == 1 && c.charAt(1) > 3) {\r\n x = x.times(y);\r\n c = digitsToString(x.d);\r\n c0 = c.charAt(0);\r\n n++;\r\n }\r\n\r\n e = x.e;\r\n\r\n if (c0 > 1) {\r\n x = new Ctor('0.' + c);\r\n e++;\r\n } else {\r\n x = new Ctor(c0 + '.' + c.slice(1));\r\n }\r\n } else {\r\n\r\n // The argument reduction method above may result in overflow if the argument y is a massive\r\n // number with exponent >= 1500000000000000 (9e15 / 6 = 1.5e15), so instead recall this\r\n // function using ln(x*10^e) = ln(x) + e*ln(10).\r\n t = getLn10(Ctor, wpr + 2, pr).times(e + '');\r\n x = naturalLogarithm(new Ctor(c0 + '.' + c.slice(1)), wpr - guard).plus(t);\r\n Ctor.precision = pr;\r\n\r\n return sd == null ? finalise(x, pr, rm, external = true) : x;\r\n }\r\n\r\n // x1 is x reduced to a value near 1.\r\n x1 = x;\r\n\r\n // Taylor series.\r\n // ln(y) = ln((1 + x)/(1 - x)) = 2(x + x^3/3 + x^5/5 + x^7/7 + ...)\r\n // where x = (y - 1)/(y + 1) (|x| < 1)\r\n sum = numerator = x = divide(x.minus(1), x.plus(1), wpr, 1);\r\n x2 = finalise(x.times(x), wpr, 1);\r\n denominator = 3;\r\n\r\n for (;;) {\r\n numerator = finalise(numerator.times(x2), wpr, 1);\r\n t = sum.plus(divide(numerator, new Ctor(denominator), wpr, 1));\r\n\r\n if (digitsToString(t.d).slice(0, wpr) === digitsToString(sum.d).slice(0, wpr)) {\r\n sum = sum.times(2);\r\n\r\n // Reverse the argument reduction. Check that e is not 0 because, besides preventing an\r\n // unnecessary calculation, -0 + 0 = +0 and to ensure correct rounding -0 needs to stay -0.\r\n if (e !== 0) sum = sum.plus(getLn10(Ctor, wpr + 2, pr).times(e + ''));\r\n sum = divide(sum, new Ctor(n), wpr, 1);\r\n\r\n // Is rm > 3 and the first 4 rounding digits 4999, or rm < 4 (or the summation has\r\n // been repeated previously) and the first 4 rounding digits 9999?\r\n // If so, restart the summation with a higher precision, otherwise\r\n // e.g. with precision: 12, rounding: 1\r\n // ln(135520028.6126091714265381533) = 18.7246299999 when it should be 18.72463.\r\n // `wpr - guard` is the index of first rounding digit.\r\n if (sd == null) {\r\n if (checkRoundingDigits(sum.d, wpr - guard, rm, rep)) {\r\n Ctor.precision = wpr += guard;\r\n t = numerator = x = divide(x1.minus(1), x1.plus(1), wpr, 1);\r\n x2 = finalise(x.times(x), wpr, 1);\r\n denominator = rep = 1;\r\n } else {\r\n return finalise(sum, Ctor.precision = pr, rm, external = true);\r\n }\r\n } else {\r\n Ctor.precision = pr;\r\n return sum;\r\n }\r\n }\r\n\r\n sum = t;\r\n denominator += 2;\r\n }\r\n }\r\n\r\n\r\n // ±Infinity, NaN.\r\n function nonFiniteToString(x) {\r\n // Unsigned.\r\n return String(x.s * x.s / 0);\r\n }\r\n\r\n\r\n /*\r\n * Parse the value of a new Decimal `x` from string `str`.\r\n */\r\n function parseDecimal(x, str) {\r\n var e, i, len;\r\n\r\n // Decimal point?\r\n if ((e = str.indexOf('.')) > -1) str = str.replace('.', '');\r\n\r\n // Exponential form?\r\n if ((i = str.search(/e/i)) > 0) {\r\n\r\n // Determine exponent.\r\n if (e < 0) e = i;\r\n e += +str.slice(i + 1);\r\n str = str.substring(0, i);\r\n } else if (e < 0) {\r\n\r\n // Integer.\r\n e = str.length;\r\n }\r\n\r\n // Determine leading zeros.\r\n for (i = 0; str.charCodeAt(i) === 48; i++);\r\n\r\n // Determine trailing zeros.\r\n for (len = str.length; str.charCodeAt(len - 1) === 48; --len);\r\n str = str.slice(i, len);\r\n\r\n if (str) {\r\n len -= i;\r\n x.e = e = e - i - 1;\r\n x.d = [];\r\n\r\n // Transform base\r\n\r\n // e is the base 10 exponent.\r\n // i is where to slice str to get the first word of the digits array.\r\n i = (e + 1) % LOG_BASE;\r\n if (e < 0) i += LOG_BASE;\r\n\r\n if (i < len) {\r\n if (i) x.d.push(+str.slice(0, i));\r\n for (len -= LOG_BASE; i < len;) x.d.push(+str.slice(i, i += LOG_BASE));\r\n str = str.slice(i);\r\n i = LOG_BASE - str.length;\r\n } else {\r\n i -= len;\r\n }\r\n\r\n for (; i--;) str += '0';\r\n x.d.push(+str);\r\n\r\n if (external) {\r\n\r\n // Overflow?\r\n if (x.e > x.constructor.maxE) {\r\n\r\n // Infinity.\r\n x.d = null;\r\n x.e = NaN;\r\n\r\n // Underflow?\r\n } else if (x.e < x.constructor.minE) {\r\n\r\n // Zero.\r\n x.e = 0;\r\n x.d = [0];\r\n // x.constructor.underflow = true;\r\n } // else x.constructor.underflow = false;\r\n }\r\n } else {\r\n\r\n // Zero.\r\n x.e = 0;\r\n x.d = [0];\r\n }\r\n\r\n return x;\r\n }\r\n\r\n\r\n /*\r\n * Parse the value of a new Decimal `x` from a string `str`, which is not a decimal value.\r\n */\r\n function parseOther(x, str) {\r\n var base, Ctor, divisor, i, isFloat, len, p, xd, xe;\r\n\r\n if (str.indexOf('_') > -1) {\r\n str = str.replace(/(\\d)_(?=\\d)/g, '$1');\r\n if (isDecimal.test(str)) return parseDecimal(x, str);\r\n } else if (str === 'Infinity' || str === 'NaN') {\r\n if (!+str) x.s = NaN;\r\n x.e = NaN;\r\n x.d = null;\r\n return x;\r\n }\r\n\r\n if (isHex.test(str)) {\r\n base = 16;\r\n str = str.toLowerCase();\r\n } else if (isBinary.test(str)) {\r\n base = 2;\r\n } else if (isOctal.test(str)) {\r\n base = 8;\r\n } else {\r\n throw Error(invalidArgument + str);\r\n }\r\n\r\n // Is there a binary exponent part?\r\n i = str.search(/p/i);\r\n\r\n if (i > 0) {\r\n p = +str.slice(i + 1);\r\n str = str.substring(2, i);\r\n } else {\r\n str = str.slice(2);\r\n }\r\n\r\n // Convert `str` as an integer then divide the result by `base` raised to a power such that the\r\n // fraction part will be restored.\r\n i = str.indexOf('.');\r\n isFloat = i >= 0;\r\n Ctor = x.constructor;\r\n\r\n if (isFloat) {\r\n str = str.replace('.', '');\r\n len = str.length;\r\n i = len - i;\r\n\r\n // log[10](16) = 1.2041... , log[10](88) = 1.9444....\r\n divisor = intPow(Ctor, new Ctor(base), i, i * 2);\r\n }\r\n\r\n xd = convertBase(str, base, BASE);\r\n xe = xd.length - 1;\r\n\r\n // Remove trailing zeros.\r\n for (i = xe; xd[i] === 0; --i) xd.pop();\r\n if (i < 0) return new Ctor(x.s * 0);\r\n x.e = getBase10Exponent(xd, xe);\r\n x.d = xd;\r\n external = false;\r\n\r\n // At what precision to perform the division to ensure exact conversion?\r\n // maxDecimalIntegerPartDigitCount = ceil(log[10](b) * otherBaseIntegerPartDigitCount)\r\n // log[10](2) = 0.30103, log[10](8) = 0.90309, log[10](16) = 1.20412\r\n // E.g. ceil(1.2 * 3) = 4, so up to 4 decimal digits are needed to represent 3 hex int digits.\r\n // maxDecimalFractionPartDigitCount = {Hex:4|Oct:3|Bin:1} * otherBaseFractionPartDigitCount\r\n // Therefore using 4 * the number of digits of str will always be enough.\r\n if (isFloat) x = divide(x, divisor, len * 4);\r\n\r\n // Multiply by the binary exponent part if present.\r\n if (p) x = x.times(Math.abs(p) < 54 ? mathpow(2, p) : Decimal.pow(2, p));\r\n external = true;\r\n\r\n return x;\r\n }\r\n\r\n\r\n /*\r\n * sin(x) = x - x^3/3! + x^5/5! - ...\r\n * |x| < pi/2\r\n *\r\n */\r\n function sine(Ctor, x) {\r\n var k,\r\n len = x.d.length;\r\n\r\n if (len < 3) {\r\n return x.isZero() ? x : taylorSeries(Ctor, 2, x, x);\r\n }\r\n\r\n // Argument reduction: sin(5x) = 16*sin^5(x) - 20*sin^3(x) + 5*sin(x)\r\n // i.e. sin(x) = 16*sin^5(x/5) - 20*sin^3(x/5) + 5*sin(x/5)\r\n // and sin(x) = sin(x/5)(5 + sin^2(x/5)(16sin^2(x/5) - 20))\r\n\r\n // Estimate the optimum number of times to use the argument reduction.\r\n k = 1.4 * Math.sqrt(len);\r\n k = k > 16 ? 16 : k | 0;\r\n\r\n x = x.times(1 / tinyPow(5, k));\r\n x = taylorSeries(Ctor, 2, x, x);\r\n\r\n // Reverse argument reduction\r\n var sin2_x,\r\n d5 = new Ctor(5),\r\n d16 = new Ctor(16),\r\n d20 = new Ctor(20);\r\n for (; k--;) {\r\n sin2_x = x.times(x);\r\n x = x.times(d5.plus(sin2_x.times(d16.times(sin2_x).minus(d20))));\r\n }\r\n\r\n return x;\r\n }\r\n\r\n\r\n // Calculate Taylor series for `cos`, `cosh`, `sin` and `sinh`.\r\n function taylorSeries(Ctor, n, x, y, isHyperbolic) {\r\n var j, t, u, x2,\r\n i = 1,\r\n pr = Ctor.precision,\r\n k = Math.ceil(pr / LOG_BASE);\r\n\r\n external = false;\r\n x2 = x.times(x);\r\n u = new Ctor(y);\r\n\r\n for (;;) {\r\n t = divide(u.times(x2), new Ctor(n++ * n++), pr, 1);\r\n u = isHyperbolic ? y.plus(t) : y.minus(t);\r\n y = divide(t.times(x2), new Ctor(n++ * n++), pr, 1);\r\n t = u.plus(y);\r\n\r\n if (t.d[k] !== void 0) {\r\n for (j = k; t.d[j] === u.d[j] && j--;);\r\n if (j == -1) break;\r\n }\r\n\r\n j = u;\r\n u = y;\r\n y = t;\r\n t = j;\r\n i++;\r\n }\r\n\r\n external = true;\r\n t.d.length = k + 1;\r\n\r\n return t;\r\n }\r\n\r\n\r\n // Exponent e must be positive and non-zero.\r\n function tinyPow(b, e) {\r\n var n = b;\r\n while (--e) n *= b;\r\n return n;\r\n }\r\n\r\n\r\n // Return the absolute value of `x` reduced to less than or equal to half pi.\r\n function toLessThanHalfPi(Ctor, x) {\r\n var t,\r\n isNeg = x.s < 0,\r\n pi = getPi(Ctor, Ctor.precision, 1),\r\n halfPi = pi.times(0.5);\r\n\r\n x = x.abs();\r\n\r\n if (x.lte(halfPi)) {\r\n quadrant = isNeg ? 4 : 1;\r\n return x;\r\n }\r\n\r\n t = x.divToInt(pi);\r\n\r\n if (t.isZero()) {\r\n quadrant = isNeg ? 3 : 2;\r\n } else {\r\n x = x.minus(t.times(pi));\r\n\r\n // 0 <= x < pi\r\n if (x.lte(halfPi)) {\r\n quadrant = isOdd(t) ? (isNeg ? 2 : 3) : (isNeg ? 4 : 1);\r\n return x;\r\n }\r\n\r\n quadrant = isOdd(t) ? (isNeg ? 1 : 4) : (isNeg ? 3 : 2);\r\n }\r\n\r\n return x.minus(pi).abs();\r\n }\r\n\r\n\r\n /*\r\n * Return the value of Decimal `x` as a string in base `baseOut`.\r\n *\r\n * If the optional `sd` argument is present include a binary exponent suffix.\r\n */\r\n function toStringBinary(x, baseOut, sd, rm) {\r\n var base, e, i, k, len, roundUp, str, xd, y,\r\n Ctor = x.constructor,\r\n isExp = sd !== void 0;\r\n\r\n if (isExp) {\r\n checkInt32(sd, 1, MAX_DIGITS);\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n } else {\r\n sd = Ctor.precision;\r\n rm = Ctor.rounding;\r\n }\r\n\r\n if (!x.isFinite()) {\r\n str = nonFiniteToString(x);\r\n } else {\r\n str = finiteToString(x);\r\n i = str.indexOf('.');\r\n\r\n // Use exponential notation according to `toExpPos` and `toExpNeg`? No, but if required:\r\n // maxBinaryExponent = floor((decimalExponent + 1) * log[2](10))\r\n // minBinaryExponent = floor(decimalExponent * log[2](10))\r\n // log[2](10) = 3.321928094887362347870319429489390175864\r\n\r\n if (isExp) {\r\n base = 2;\r\n if (baseOut == 16) {\r\n sd = sd * 4 - 3;\r\n } else if (baseOut == 8) {\r\n sd = sd * 3 - 2;\r\n }\r\n } else {\r\n base = baseOut;\r\n }\r\n\r\n // Convert the number as an integer then divide the result by its base raised to a power such\r\n // that the fraction part will be restored.\r\n\r\n // Non-integer.\r\n if (i >= 0) {\r\n str = str.replace('.', '');\r\n y = new Ctor(1);\r\n y.e = str.length - i;\r\n y.d = convertBase(finiteToString(y), 10, base);\r\n y.e = y.d.length;\r\n }\r\n\r\n xd = convertBase(str, 10, base);\r\n e = len = xd.length;\r\n\r\n // Remove trailing zeros.\r\n for (; xd[--len] == 0;) xd.pop();\r\n\r\n if (!xd[0]) {\r\n str = isExp ? '0p+0' : '0';\r\n } else {\r\n if (i < 0) {\r\n e--;\r\n } else {\r\n x = new Ctor(x);\r\n x.d = xd;\r\n x.e = e;\r\n x = divide(x, y, sd, rm, 0, base);\r\n xd = x.d;\r\n e = x.e;\r\n roundUp = inexact;\r\n }\r\n\r\n // The rounding digit, i.e. the digit after the digit that may be rounded up.\r\n i = xd[sd];\r\n k = base / 2;\r\n roundUp = roundUp || xd[sd + 1] !== void 0;\r\n\r\n roundUp = rm < 4\r\n ? (i !== void 0 || roundUp) && (rm === 0 || rm === (x.s < 0 ? 3 : 2))\r\n : i > k || i === k && (rm === 4 || roundUp || rm === 6 && xd[sd - 1] & 1 ||\r\n rm === (x.s < 0 ? 8 : 7));\r\n\r\n xd.length = sd;\r\n\r\n if (roundUp) {\r\n\r\n // Rounding up may mean the previous digit has to be rounded up and so on.\r\n for (; ++xd[--sd] > base - 1;) {\r\n xd[sd] = 0;\r\n if (!sd) {\r\n ++e;\r\n xd.unshift(1);\r\n }\r\n }\r\n }\r\n\r\n // Determine trailing zeros.\r\n for (len = xd.length; !xd[len - 1]; --len);\r\n\r\n // E.g. [4, 11, 15] becomes 4bf.\r\n for (i = 0, str = ''; i < len; i++) str += NUMERALS.charAt(xd[i]);\r\n\r\n // Add binary exponent suffix?\r\n if (isExp) {\r\n if (len > 1) {\r\n if (baseOut == 16 || baseOut == 8) {\r\n i = baseOut == 16 ? 4 : 3;\r\n for (--len; len % i; len++) str += '0';\r\n xd = convertBase(str, base, baseOut);\r\n for (len = xd.length; !xd[len - 1]; --len);\r\n\r\n // xd[0] will always be be 1\r\n for (i = 1, str = '1.'; i < len; i++) str += NUMERALS.charAt(xd[i]);\r\n } else {\r\n str = str.charAt(0) + '.' + str.slice(1);\r\n }\r\n }\r\n\r\n str = str + (e < 0 ? 'p' : 'p+') + e;\r\n } else if (e < 0) {\r\n for (; ++e;) str = '0' + str;\r\n str = '0.' + str;\r\n } else {\r\n if (++e > len) for (e -= len; e-- ;) str += '0';\r\n else if (e < len) str = str.slice(0, e) + '.' + str.slice(e);\r\n }\r\n }\r\n\r\n str = (baseOut == 16 ? '0x' : baseOut == 2 ? '0b' : baseOut == 8 ? '0o' : '') + str;\r\n }\r\n\r\n return x.s < 0 ? '-' + str : str;\r\n }\r\n\r\n\r\n // Does not strip trailing zeros.\r\n function truncate(arr, len) {\r\n if (arr.length > len) {\r\n arr.length = len;\r\n return true;\r\n }\r\n }\r\n\r\n\r\n // Decimal methods\r\n\r\n\r\n /*\r\n * abs\r\n * acos\r\n * acosh\r\n * add\r\n * asin\r\n * asinh\r\n * atan\r\n * atanh\r\n * atan2\r\n * cbrt\r\n * ceil\r\n * clamp\r\n * clone\r\n * config\r\n * cos\r\n * cosh\r\n * div\r\n * exp\r\n * floor\r\n * hypot\r\n * ln\r\n * log\r\n * log2\r\n * log10\r\n * max\r\n * min\r\n * mod\r\n * mul\r\n * pow\r\n * random\r\n * round\r\n * set\r\n * sign\r\n * sin\r\n * sinh\r\n * sqrt\r\n * sub\r\n * sum\r\n * tan\r\n * tanh\r\n * trunc\r\n */\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the absolute value of `x`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function abs(x) {\r\n return new this(x).abs();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the arccosine in radians of `x`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function acos(x) {\r\n return new this(x).acos();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic cosine of `x`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\n function acosh(x) {\r\n return new this(x).acosh();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the sum of `x` and `y`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\n function add(x, y) {\r\n return new this(x).plus(y);\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the arcsine in radians of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function asin(x) {\r\n return new this(x).asin();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic sine of `x`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\n function asinh(x) {\r\n return new this(x).asinh();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the arctangent in radians of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function atan(x) {\r\n return new this(x).atan();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic tangent of `x`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\n function atanh(x) {\r\n return new this(x).atanh();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the arctangent in radians of `y/x` in the range -pi to pi\r\n * (inclusive), rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-pi, pi]\r\n *\r\n * y {number|string|Decimal} The y-coordinate.\r\n * x {number|string|Decimal} The x-coordinate.\r\n *\r\n * atan2(±0, -0) = ±pi\r\n * atan2(±0, +0) = ±0\r\n * atan2(±0, -x) = ±pi for x > 0\r\n * atan2(±0, x) = ±0 for x > 0\r\n * atan2(-y, ±0) = -pi/2 for y > 0\r\n * atan2(y, ±0) = pi/2 for y > 0\r\n * atan2(±y, -Infinity) = ±pi for finite y > 0\r\n * atan2(±y, +Infinity) = ±0 for finite y > 0\r\n * atan2(±Infinity, x) = ±pi/2 for finite x\r\n * atan2(±Infinity, -Infinity) = ±3*pi/4\r\n * atan2(±Infinity, +Infinity) = ±pi/4\r\n * atan2(NaN, x) = NaN\r\n * atan2(y, NaN) = NaN\r\n *\r\n */\r\n function atan2(y, x) {\r\n y = new this(y);\r\n x = new this(x);\r\n var r,\r\n pr = this.precision,\r\n rm = this.rounding,\r\n wpr = pr + 4;\r\n\r\n // Either NaN\r\n if (!y.s || !x.s) {\r\n r = new this(NaN);\r\n\r\n // Both ±Infinity\r\n } else if (!y.d && !x.d) {\r\n r = getPi(this, wpr, 1).times(x.s > 0 ? 0.25 : 0.75);\r\n r.s = y.s;\r\n\r\n // x is ±Infinity or y is ±0\r\n } else if (!x.d || y.isZero()) {\r\n r = x.s < 0 ? getPi(this, pr, rm) : new this(0);\r\n r.s = y.s;\r\n\r\n // y is ±Infinity or x is ±0\r\n } else if (!y.d || x.isZero()) {\r\n r = getPi(this, wpr, 1).times(0.5);\r\n r.s = y.s;\r\n\r\n // Both non-zero and finite\r\n } else if (x.s < 0) {\r\n this.precision = wpr;\r\n this.rounding = 1;\r\n r = this.atan(divide(y, x, wpr, 1));\r\n x = getPi(this, wpr, 1);\r\n this.precision = pr;\r\n this.rounding = rm;\r\n r = y.s < 0 ? r.minus(x) : r.plus(x);\r\n } else {\r\n r = this.atan(divide(y, x, wpr, 1));\r\n }\r\n\r\n return r;\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the cube root of `x`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function cbrt(x) {\r\n return new this(x).cbrt();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is `x` rounded to an integer using `ROUND_CEIL`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function ceil(x) {\r\n return finalise(x = new this(x), x.e + 1, 2);\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is `x` clamped to the range delineated by `min` and `max`.\r\n *\r\n * x {number|string|Decimal}\r\n * min {number|string|Decimal}\r\n * max {number|string|Decimal}\r\n *\r\n */\r\n function clamp(x, min, max) {\r\n return new this(x).clamp(min, max);\r\n }\r\n\r\n\r\n /*\r\n * Configure global settings for a Decimal constructor.\r\n *\r\n * `obj` is an object with one or more of the following properties,\r\n *\r\n * precision {number}\r\n * rounding {number}\r\n * toExpNeg {number}\r\n * toExpPos {number}\r\n * maxE {number}\r\n * minE {number}\r\n * modulo {number}\r\n * crypto {boolean|number}\r\n * defaults {true}\r\n *\r\n * E.g. Decimal.config({ precision: 20, rounding: 4 })\r\n *\r\n */\r\n function config(obj) {\r\n if (!obj || typeof obj !== 'object') throw Error(decimalError + 'Object expected');\r\n var i, p, v,\r\n useDefaults = obj.defaults === true,\r\n ps = [\r\n 'precision', 1, MAX_DIGITS,\r\n 'rounding', 0, 8,\r\n 'toExpNeg', -EXP_LIMIT, 0,\r\n 'toExpPos', 0, EXP_LIMIT,\r\n 'maxE', 0, EXP_LIMIT,\r\n 'minE', -EXP_LIMIT, 0,\r\n 'modulo', 0, 9\r\n ];\r\n\r\n for (i = 0; i < ps.length; i += 3) {\r\n if (p = ps[i], useDefaults) this[p] = DEFAULTS[p];\r\n if ((v = obj[p]) !== void 0) {\r\n if (mathfloor(v) === v && v >= ps[i + 1] && v <= ps[i + 2]) this[p] = v;\r\n else throw Error(invalidArgument + p + ': ' + v);\r\n }\r\n }\r\n\r\n if (p = 'crypto', useDefaults) this[p] = DEFAULTS[p];\r\n if ((v = obj[p]) !== void 0) {\r\n if (v === true || v === false || v === 0 || v === 1) {\r\n if (v) {\r\n if (typeof crypto != 'undefined' && crypto &&\r\n (crypto.getRandomValues || crypto.randomBytes)) {\r\n this[p] = true;\r\n } else {\r\n throw Error(cryptoUnavailable);\r\n }\r\n } else {\r\n this[p] = false;\r\n }\r\n } else {\r\n throw Error(invalidArgument + p + ': ' + v);\r\n }\r\n }\r\n\r\n return this;\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the cosine of `x`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\n function cos(x) {\r\n return new this(x).cos();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the hyperbolic cosine of `x`, rounded to precision\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\n function cosh(x) {\r\n return new this(x).cosh();\r\n }\r\n\r\n\r\n /*\r\n * Create and return a Decimal constructor with the same configuration properties as this Decimal\r\n * constructor.\r\n *\r\n */\r\n function clone(obj) {\r\n var i, p, ps;\r\n\r\n /*\r\n * The Decimal constructor and exported function.\r\n * Return a new Decimal instance.\r\n *\r\n * v {number|string|Decimal} A numeric value.\r\n *\r\n */\r\n function Decimal(v) {\r\n var e, i, t,\r\n x = this;\r\n\r\n // Decimal called without new.\r\n if (!(x instanceof Decimal)) return new Decimal(v);\r\n\r\n // Retain a reference to this Decimal constructor, and shadow Decimal.prototype.constructor\r\n // which points to Object.\r\n x.constructor = Decimal;\r\n\r\n // Duplicate.\r\n if (isDecimalInstance(v)) {\r\n x.s = v.s;\r\n\r\n if (external) {\r\n if (!v.d || v.e > Decimal.maxE) {\r\n\r\n // Infinity.\r\n x.e = NaN;\r\n x.d = null;\r\n } else if (v.e < Decimal.minE) {\r\n\r\n // Zero.\r\n x.e = 0;\r\n x.d = [0];\r\n } else {\r\n x.e = v.e;\r\n x.d = v.d.slice();\r\n }\r\n } else {\r\n x.e = v.e;\r\n x.d = v.d ? v.d.slice() : v.d;\r\n }\r\n\r\n return;\r\n }\r\n\r\n t = typeof v;\r\n\r\n if (t === 'number') {\r\n if (v === 0) {\r\n x.s = 1 / v < 0 ? -1 : 1;\r\n x.e = 0;\r\n x.d = [0];\r\n return;\r\n }\r\n\r\n if (v < 0) {\r\n v = -v;\r\n x.s = -1;\r\n } else {\r\n x.s = 1;\r\n }\r\n\r\n // Fast path for small integers.\r\n if (v === ~~v && v < 1e7) {\r\n for (e = 0, i = v; i >= 10; i /= 10) e++;\r\n\r\n if (external) {\r\n if (e > Decimal.maxE) {\r\n x.e = NaN;\r\n x.d = null;\r\n } else if (e < Decimal.minE) {\r\n x.e = 0;\r\n x.d = [0];\r\n } else {\r\n x.e = e;\r\n x.d = [v];\r\n }\r\n } else {\r\n x.e = e;\r\n x.d = [v];\r\n }\r\n\r\n return;\r\n\r\n // Infinity, NaN.\r\n } else if (v * 0 !== 0) {\r\n if (!v) x.s = NaN;\r\n x.e = NaN;\r\n x.d = null;\r\n return;\r\n }\r\n\r\n return parseDecimal(x, v.toString());\r\n\r\n } else if (t !== 'string') {\r\n throw Error(invalidArgument + v);\r\n }\r\n\r\n // Minus sign?\r\n if ((i = v.charCodeAt(0)) === 45) {\r\n v = v.slice(1);\r\n x.s = -1;\r\n } else {\r\n // Plus sign?\r\n if (i === 43) v = v.slice(1);\r\n x.s = 1;\r\n }\r\n\r\n return isDecimal.test(v) ? parseDecimal(x, v) : parseOther(x, v);\r\n }\r\n\r\n Decimal.prototype = P;\r\n\r\n Decimal.ROUND_UP = 0;\r\n Decimal.ROUND_DOWN = 1;\r\n Decimal.ROUND_CEIL = 2;\r\n Decimal.ROUND_FLOOR = 3;\r\n Decimal.ROUND_HALF_UP = 4;\r\n Decimal.ROUND_HALF_DOWN = 5;\r\n Decimal.ROUND_HALF_EVEN = 6;\r\n Decimal.ROUND_HALF_CEIL = 7;\r\n Decimal.ROUND_HALF_FLOOR = 8;\r\n Decimal.EUCLID = 9;\r\n\r\n Decimal.config = Decimal.set = config;\r\n Decimal.clone = clone;\r\n Decimal.isDecimal = isDecimalInstance;\r\n\r\n Decimal.abs = abs;\r\n Decimal.acos = acos;\r\n Decimal.acosh = acosh; // ES6\r\n Decimal.add = add;\r\n Decimal.asin = asin;\r\n Decimal.asinh = asinh; // ES6\r\n Decimal.atan = atan;\r\n Decimal.atanh = atanh; // ES6\r\n Decimal.atan2 = atan2;\r\n Decimal.cbrt = cbrt; // ES6\r\n Decimal.ceil = ceil;\r\n Decimal.clamp = clamp;\r\n Decimal.cos = cos;\r\n Decimal.cosh = cosh; // ES6\r\n Decimal.div = div;\r\n Decimal.exp = exp;\r\n Decimal.floor = floor;\r\n Decimal.hypot = hypot; // ES6\r\n Decimal.ln = ln;\r\n Decimal.log = log;\r\n Decimal.log10 = log10; // ES6\r\n Decimal.log2 = log2; // ES6\r\n Decimal.max = max;\r\n Decimal.min = min;\r\n Decimal.mod = mod;\r\n Decimal.mul = mul;\r\n Decimal.pow = pow;\r\n Decimal.random = random;\r\n Decimal.round = round;\r\n Decimal.sign = sign; // ES6\r\n Decimal.sin = sin;\r\n Decimal.sinh = sinh; // ES6\r\n Decimal.sqrt = sqrt;\r\n Decimal.sub = sub;\r\n Decimal.sum = sum;\r\n Decimal.tan = tan;\r\n Decimal.tanh = tanh; // ES6\r\n Decimal.trunc = trunc; // ES6\r\n\r\n if (obj === void 0) obj = {};\r\n if (obj) {\r\n if (obj.defaults !== true) {\r\n ps = ['precision', 'rounding', 'toExpNeg', 'toExpPos', 'maxE', 'minE', 'modulo', 'crypto'];\r\n for (i = 0; i < ps.length;) if (!obj.hasOwnProperty(p = ps[i++])) obj[p] = this[p];\r\n }\r\n }\r\n\r\n Decimal.config(obj);\r\n\r\n return Decimal;\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is `x` divided by `y`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\n function div(x, y) {\r\n return new this(x).div(y);\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the natural exponential of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} The power to which to raise the base of the natural log.\r\n *\r\n */\r\n function exp(x) {\r\n return new this(x).exp();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is `x` round to an integer using `ROUND_FLOOR`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function floor(x) {\r\n return finalise(x = new this(x), x.e + 1, 3);\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the square root of the sum of the squares of the arguments,\r\n * rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * hypot(a, b, ...) = sqrt(a^2 + b^2 + ...)\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n */\r\n function hypot() {\r\n var i, n,\r\n t = new this(0);\r\n\r\n external = false;\r\n\r\n for (i = 0; i < arguments.length;) {\r\n n = new this(arguments[i++]);\r\n if (!n.d) {\r\n if (n.s) {\r\n external = true;\r\n return new this(1 / 0);\r\n }\r\n t = n;\r\n } else if (t.d) {\r\n t = t.plus(n.times(n));\r\n }\r\n }\r\n\r\n external = true;\r\n\r\n return t.sqrt();\r\n }\r\n\r\n\r\n /*\r\n * Return true if object is a Decimal instance (where Decimal is any Decimal constructor),\r\n * otherwise return false.\r\n *\r\n */\r\n function isDecimalInstance(obj) {\r\n return obj instanceof Decimal || obj && obj.toStringTag === tag || false;\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the natural logarithm of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function ln(x) {\r\n return new this(x).ln();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the log of `x` to the base `y`, or to base 10 if no base\r\n * is specified, rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * log[y](x)\r\n *\r\n * x {number|string|Decimal} The argument of the logarithm.\r\n * y {number|string|Decimal} The base of the logarithm.\r\n *\r\n */\r\n function log(x, y) {\r\n return new this(x).log(y);\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the base 2 logarithm of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function log2(x) {\r\n return new this(x).log(2);\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the base 10 logarithm of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function log10(x) {\r\n return new this(x).log(10);\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the maximum of the arguments.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n */\r\n function max() {\r\n return maxOrMin(this, arguments, 'lt');\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the minimum of the arguments.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n */\r\n function min() {\r\n return maxOrMin(this, arguments, 'gt');\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is `x` modulo `y`, rounded to `precision` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\n function mod(x, y) {\r\n return new this(x).mod(y);\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is `x` multiplied by `y`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\n function mul(x, y) {\r\n return new this(x).mul(y);\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is `x` raised to the power `y`, rounded to precision\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} The base.\r\n * y {number|string|Decimal} The exponent.\r\n *\r\n */\r\n function pow(x, y) {\r\n return new this(x).pow(y);\r\n }\r\n\r\n\r\n /*\r\n * Returns a new Decimal with a random value equal to or greater than 0 and less than 1, and with\r\n * `sd`, or `Decimal.precision` if `sd` is omitted, significant digits (or less if trailing zeros\r\n * are produced).\r\n *\r\n * [sd] {number} Significant digits. Integer, 0 to MAX_DIGITS inclusive.\r\n *\r\n */\r\n function random(sd) {\r\n var d, e, k, n,\r\n i = 0,\r\n r = new this(1),\r\n rd = [];\r\n\r\n if (sd === void 0) sd = this.precision;\r\n else checkInt32(sd, 1, MAX_DIGITS);\r\n\r\n k = Math.ceil(sd / LOG_BASE);\r\n\r\n if (!this.crypto) {\r\n for (; i < k;) rd[i++] = Math.random() * 1e7 | 0;\r\n\r\n // Browsers supporting crypto.getRandomValues.\r\n } else if (crypto.getRandomValues) {\r\n d = crypto.getRandomValues(new Uint32Array(k));\r\n\r\n for (; i < k;) {\r\n n = d[i];\r\n\r\n // 0 <= n < 4294967296\r\n // Probability n >= 4.29e9, is 4967296 / 4294967296 = 0.00116 (1 in 865).\r\n if (n >= 4.29e9) {\r\n d[i] = crypto.getRandomValues(new Uint32Array(1))[0];\r\n } else {\r\n\r\n // 0 <= n <= 4289999999\r\n // 0 <= (n % 1e7) <= 9999999\r\n rd[i++] = n % 1e7;\r\n }\r\n }\r\n\r\n // Node.js supporting crypto.randomBytes.\r\n } else if (crypto.randomBytes) {\r\n\r\n // buffer\r\n d = crypto.randomBytes(k *= 4);\r\n\r\n for (; i < k;) {\r\n\r\n // 0 <= n < 2147483648\r\n n = d[i] + (d[i + 1] << 8) + (d[i + 2] << 16) + ((d[i + 3] & 0x7f) << 24);\r\n\r\n // Probability n >= 2.14e9, is 7483648 / 2147483648 = 0.0035 (1 in 286).\r\n if (n >= 2.14e9) {\r\n crypto.randomBytes(4).copy(d, i);\r\n } else {\r\n\r\n // 0 <= n <= 2139999999\r\n // 0 <= (n % 1e7) <= 9999999\r\n rd.push(n % 1e7);\r\n i += 4;\r\n }\r\n }\r\n\r\n i = k / 4;\r\n } else {\r\n throw Error(cryptoUnavailable);\r\n }\r\n\r\n k = rd[--i];\r\n sd %= LOG_BASE;\r\n\r\n // Convert trailing digits to zeros according to sd.\r\n if (k && sd) {\r\n n = mathpow(10, LOG_BASE - sd);\r\n rd[i] = (k / n | 0) * n;\r\n }\r\n\r\n // Remove trailing words which are zero.\r\n for (; rd[i] === 0; i--) rd.pop();\r\n\r\n // Zero?\r\n if (i < 0) {\r\n e = 0;\r\n rd = [0];\r\n } else {\r\n e = -1;\r\n\r\n // Remove leading words which are zero and adjust exponent accordingly.\r\n for (; rd[0] === 0; e -= LOG_BASE) rd.shift();\r\n\r\n // Count the digits of the first word of rd to determine leading zeros.\r\n for (k = 1, n = rd[0]; n >= 10; n /= 10) k++;\r\n\r\n // Adjust the exponent for leading zeros of the first word of rd.\r\n if (k < LOG_BASE) e -= LOG_BASE - k;\r\n }\r\n\r\n r.e = e;\r\n r.d = rd;\r\n\r\n return r;\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is `x` rounded to an integer using rounding mode `rounding`.\r\n *\r\n * To emulate `Math.round`, set rounding to 7 (ROUND_HALF_CEIL).\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function round(x) {\r\n return finalise(x = new this(x), x.e + 1, this.rounding);\r\n }\r\n\r\n\r\n /*\r\n * Return\r\n * 1 if x > 0,\r\n * -1 if x < 0,\r\n * 0 if x is 0,\r\n * -0 if x is -0,\r\n * NaN otherwise\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function sign(x) {\r\n x = new this(x);\r\n return x.d ? (x.d[0] ? x.s : 0 * x.s) : x.s || NaN;\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the sine of `x`, rounded to `precision` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\n function sin(x) {\r\n return new this(x).sin();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the hyperbolic sine of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\n function sinh(x) {\r\n return new this(x).sinh();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the square root of `x`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function sqrt(x) {\r\n return new this(x).sqrt();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is `x` minus `y`, rounded to `precision` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\n function sub(x, y) {\r\n return new this(x).sub(y);\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the sum of the arguments, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * Only the result is rounded, not the intermediate calculations.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n */\r\n function sum() {\r\n var i = 0,\r\n args = arguments,\r\n x = new this(args[i]);\r\n\r\n external = false;\r\n for (; x.s && ++i < args.length;) x = x.plus(args[i]);\r\n external = true;\r\n\r\n return finalise(x, this.precision, this.rounding);\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the tangent of `x`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\n function tan(x) {\r\n return new this(x).tan();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is the hyperbolic tangent of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\n function tanh(x) {\r\n return new this(x).tanh();\r\n }\r\n\r\n\r\n /*\r\n * Return a new Decimal whose value is `x` truncated to an integer.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\n function trunc(x) {\r\n return finalise(x = new this(x), x.e + 1, 1);\r\n }\r\n\r\n\r\n // Create and configure initial Decimal constructor.\r\n Decimal = clone(DEFAULTS);\r\n Decimal.prototype.constructor = Decimal;\r\n Decimal['default'] = Decimal.Decimal = Decimal;\r\n\r\n // Create the internal constants from their string values.\r\n LN10 = new Decimal(LN10);\r\n PI = new Decimal(PI);\r\n\r\n\r\n // Export.\r\n\r\n\r\n // AMD.\r\n if (typeof define == 'function' && define.amd) {\r\n define(function () {\r\n return Decimal;\r\n });\r\n\r\n // Node and other environments that support module.exports.\r\n } else if (typeof module != 'undefined' && module.exports) {\r\n if (typeof Symbol == 'function' && typeof Symbol.iterator == 'symbol') {\r\n P[Symbol['for']('nodejs.util.inspect.custom')] = P.toString;\r\n P[Symbol.toStringTag] = 'Decimal';\r\n }\r\n\r\n module.exports = Decimal;\r\n\r\n // Browser.\r\n } else {\r\n if (!globalScope) {\r\n globalScope = typeof self != 'undefined' && self && self.self == self ? self : window;\r\n }\r\n\r\n noConflict = globalScope.Decimal;\r\n Decimal.noConflict = function () {\r\n globalScope.Decimal = noConflict;\r\n return Decimal;\r\n };\r\n\r\n globalScope.Decimal = Decimal;\r\n }\r\n})(this);\r\n","var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n};\nvar BrowserInfo = /** @class */ (function () {\n function BrowserInfo(name, version, os) {\n this.name = name;\n this.version = version;\n this.os = os;\n this.type = 'browser';\n }\n return BrowserInfo;\n}());\nexport { BrowserInfo };\nvar NodeInfo = /** @class */ (function () {\n function NodeInfo(version) {\n this.version = version;\n this.type = 'node';\n this.name = 'node';\n this.os = process.platform;\n }\n return NodeInfo;\n}());\nexport { NodeInfo };\nvar SearchBotDeviceInfo = /** @class */ (function () {\n function SearchBotDeviceInfo(name, version, os, bot) {\n this.name = name;\n this.version = version;\n this.os = os;\n this.bot = bot;\n this.type = 'bot-device';\n }\n return SearchBotDeviceInfo;\n}());\nexport { SearchBotDeviceInfo };\nvar BotInfo = /** @class */ (function () {\n function BotInfo() {\n this.type = 'bot';\n this.bot = true; // NOTE: deprecated test name instead\n this.name = 'bot';\n this.version = null;\n this.os = null;\n }\n return BotInfo;\n}());\nexport { BotInfo };\nvar ReactNativeInfo = /** @class */ (function () {\n function ReactNativeInfo() {\n this.type = 'react-native';\n this.name = 'react-native';\n this.version = null;\n this.os = null;\n }\n return ReactNativeInfo;\n}());\nexport { ReactNativeInfo };\n// tslint:disable-next-line:max-line-length\nvar SEARCHBOX_UA_REGEX = /alexa|bot|crawl(er|ing)|facebookexternalhit|feedburner|google web preview|nagios|postrank|pingdom|slurp|spider|yahoo!|yandex/;\nvar SEARCHBOT_OS_REGEX = /(nuhk|curl|Googlebot|Yammybot|Openbot|Slurp|MSNBot|Ask\\ Jeeves\\/Teoma|ia_archiver)/;\nvar REQUIRED_VERSION_PARTS = 3;\nvar userAgentRules = [\n ['aol', /AOLShield\\/([0-9\\._]+)/],\n ['edge', /Edge\\/([0-9\\._]+)/],\n ['edge-ios', /EdgiOS\\/([0-9\\._]+)/],\n ['yandexbrowser', /YaBrowser\\/([0-9\\._]+)/],\n ['kakaotalk', /KAKAOTALK\\s([0-9\\.]+)/],\n ['samsung', /SamsungBrowser\\/([0-9\\.]+)/],\n ['silk', /\\bSilk\\/([0-9._-]+)\\b/],\n ['miui', /MiuiBrowser\\/([0-9\\.]+)$/],\n ['beaker', /BeakerBrowser\\/([0-9\\.]+)/],\n ['edge-chromium', /EdgA?\\/([0-9\\.]+)/],\n [\n 'chromium-webview',\n /(?!Chrom.*OPR)wv\\).*Chrom(?:e|ium)\\/([0-9\\.]+)(:?\\s|$)/,\n ],\n ['chrome', /(?!Chrom.*OPR)Chrom(?:e|ium)\\/([0-9\\.]+)(:?\\s|$)/],\n ['phantomjs', /PhantomJS\\/([0-9\\.]+)(:?\\s|$)/],\n ['crios', /CriOS\\/([0-9\\.]+)(:?\\s|$)/],\n ['firefox', /Firefox\\/([0-9\\.]+)(?:\\s|$)/],\n ['fxios', /FxiOS\\/([0-9\\.]+)/],\n ['opera-mini', /Opera Mini.*Version\\/([0-9\\.]+)/],\n ['opera', /Opera\\/([0-9\\.]+)(?:\\s|$)/],\n ['opera', /OPR\\/([0-9\\.]+)(:?\\s|$)/],\n ['pie', /^Microsoft Pocket Internet Explorer\\/(\\d+\\.\\d+)$/],\n ['pie', /^Mozilla\\/\\d\\.\\d+\\s\\(compatible;\\s(?:MSP?IE|MSInternet Explorer) (\\d+\\.\\d+);.*Windows CE.*\\)$/],\n ['netfront', /^Mozilla\\/\\d\\.\\d+.*NetFront\\/(\\d.\\d)/],\n ['ie', /Trident\\/7\\.0.*rv\\:([0-9\\.]+).*\\).*Gecko$/],\n ['ie', /MSIE\\s([0-9\\.]+);.*Trident\\/[4-7].0/],\n ['ie', /MSIE\\s(7\\.0)/],\n ['bb10', /BB10;\\sTouch.*Version\\/([0-9\\.]+)/],\n ['android', /Android\\s([0-9\\.]+)/],\n ['ios', /Version\\/([0-9\\._]+).*Mobile.*Safari.*/],\n ['safari', /Version\\/([0-9\\._]+).*Safari/],\n ['facebook', /FB[AS]V\\/([0-9\\.]+)/],\n ['instagram', /Instagram\\s([0-9\\.]+)/],\n ['ios-webview', /AppleWebKit\\/([0-9\\.]+).*Mobile/],\n ['ios-webview', /AppleWebKit\\/([0-9\\.]+).*Gecko\\)$/],\n ['curl', /^curl\\/([0-9\\.]+)$/],\n ['searchbot', SEARCHBOX_UA_REGEX],\n];\nvar operatingSystemRules = [\n ['iOS', /iP(hone|od|ad)/],\n ['Android OS', /Android/],\n ['BlackBerry OS', /BlackBerry|BB10/],\n ['Windows Mobile', /IEMobile/],\n ['Amazon OS', /Kindle/],\n ['Windows 3.11', /Win16/],\n ['Windows 95', /(Windows 95)|(Win95)|(Windows_95)/],\n ['Windows 98', /(Windows 98)|(Win98)/],\n ['Windows 2000', /(Windows NT 5.0)|(Windows 2000)/],\n ['Windows XP', /(Windows NT 5.1)|(Windows XP)/],\n ['Windows Server 2003', /(Windows NT 5.2)/],\n ['Windows Vista', /(Windows NT 6.0)/],\n ['Windows 7', /(Windows NT 6.1)/],\n ['Windows 8', /(Windows NT 6.2)/],\n ['Windows 8.1', /(Windows NT 6.3)/],\n ['Windows 10', /(Windows NT 10.0)/],\n ['Windows ME', /Windows ME/],\n ['Windows CE', /Windows CE|WinCE|Microsoft Pocket Internet Explorer/],\n ['Open BSD', /OpenBSD/],\n ['Sun OS', /SunOS/],\n ['Chrome OS', /CrOS/],\n ['Linux', /(Linux)|(X11)/],\n ['Mac OS', /(Mac_PowerPC)|(Macintosh)/],\n ['QNX', /QNX/],\n ['BeOS', /BeOS/],\n ['OS/2', /OS\\/2/],\n];\nexport function detect(userAgent) {\n if (!!userAgent) {\n return parseUserAgent(userAgent);\n }\n if (typeof document === 'undefined' &&\n typeof navigator !== 'undefined' &&\n navigator.product === 'ReactNative') {\n return new ReactNativeInfo();\n }\n if (typeof navigator !== 'undefined') {\n return parseUserAgent(navigator.userAgent);\n }\n return getNodeVersion();\n}\nfunction matchUserAgent(ua) {\n // opted for using reduce here rather than Array#first with a regex.test call\n // this is primarily because using the reduce we only perform the regex\n // execution once rather than once for the test and for the exec again below\n // probably something that needs to be benchmarked though\n return (ua !== '' &&\n userAgentRules.reduce(function (matched, _a) {\n var browser = _a[0], regex = _a[1];\n if (matched) {\n return matched;\n }\n var uaMatch = regex.exec(ua);\n return !!uaMatch && [browser, uaMatch];\n }, false));\n}\nexport function browserName(ua) {\n var data = matchUserAgent(ua);\n return data ? data[0] : null;\n}\nexport function parseUserAgent(ua) {\n var matchedRule = matchUserAgent(ua);\n if (!matchedRule) {\n return null;\n }\n var name = matchedRule[0], match = matchedRule[1];\n if (name === 'searchbot') {\n return new BotInfo();\n }\n // Do not use RegExp for split operation as some browser do not support it (See: http://blog.stevenlevithan.com/archives/cross-browser-split)\n var versionParts = match[1] && match[1].split('.').join('_').split('_').slice(0, 3);\n if (versionParts) {\n if (versionParts.length < REQUIRED_VERSION_PARTS) {\n versionParts = __spreadArray(__spreadArray([], versionParts, true), createVersionParts(REQUIRED_VERSION_PARTS - versionParts.length), true);\n }\n }\n else {\n versionParts = [];\n }\n var version = versionParts.join('.');\n var os = detectOS(ua);\n var searchBotMatch = SEARCHBOT_OS_REGEX.exec(ua);\n if (searchBotMatch && searchBotMatch[1]) {\n return new SearchBotDeviceInfo(name, version, os, searchBotMatch[1]);\n }\n return new BrowserInfo(name, version, os);\n}\nexport function detectOS(ua) {\n for (var ii = 0, count = operatingSystemRules.length; ii < count; ii++) {\n var _a = operatingSystemRules[ii], os = _a[0], regex = _a[1];\n var match = regex.exec(ua);\n if (match) {\n return os;\n }\n }\n return null;\n}\nexport function getNodeVersion() {\n var isNode = typeof process !== 'undefined' && process.version;\n return isNode ? new NodeInfo(process.version.slice(1)) : null;\n}\nfunction createVersionParts(count) {\n var output = [];\n for (var ii = 0; ii < count; ii++) {\n output.push('0');\n }\n return output;\n}\n","function e(e,t,r,n){return new(r||(r=Promise))((function(o,a){function i(e){try{d(n.next(e))}catch(e){a(e)}}function c(e){try{d(n.throw(e))}catch(e){a(e)}}function d(e){var t;e.done?o(e.value):(t=e.value,t instanceof r?t:new r((function(e){e(t)}))).then(i,c)}d((n=n.apply(e,t||[])).next())}))}const t=[\"geforce 320m\",\"geforce 8600\",\"geforce 8600m gt\",\"geforce 8800 gs\",\"geforce 8800 gt\",\"geforce 9400\",\"geforce 9400m g\",\"geforce 9400m\",\"geforce 9600m gt\",\"geforce 9600m\",\"geforce fx go5200\",\"geforce gt 120\",\"geforce gt 130\",\"geforce gt 330m\",\"geforce gtx 285\",\"google swiftshader\",\"intel g41\",\"intel g45\",\"intel gma 4500mhd\",\"intel gma x3100\",\"intel hd 3000\",\"intel q45\",\"legacy\",\"mali-2\",\"mali-3\",\"mali-4\",\"quadro fx 1500\",\"quadro fx 4\",\"quadro fx 5\",\"radeon hd 2400\",\"radeon hd 2600\",\"radeon hd 4670\",\"radeon hd 4850\",\"radeon hd 4870\",\"radeon hd 5670\",\"radeon hd 5750\",\"radeon hd 6290\",\"radeon hd 6300\",\"radeon hd 6310\",\"radeon hd 6320\",\"radeon hd 6490m\",\"radeon hd 6630m\",\"radeon hd 6750m\",\"radeon hd 6770m\",\"radeon hd 6970m\",\"sgx 543\",\"sgx543\"];function r(e){return e=e.toLowerCase().replace(/^angle ?\\((.+)\\)*$/,\"$1\").replace(/\\s(\\d{1,2}gb|direct3d.+$)|\\(r\\)| \\([^)]+\\)$/g,\"\")}const n=\"undefined\"==typeof window,o=(()=>{if(n)return;const{userAgent:e,platform:t,maxTouchPoints:r}=window.navigator,o=/(iphone|ipod|ipad)/i.test(e),a=\"iPad\"===t||\"MacIntel\"===t&&r>0&&!window.MSStream;return{isIpad:a,isMobile:/android/i.test(e)||o||a,isSafari12:/Version\\/12.+Safari/.test(e)}})();function a(e,t,r){if(!r)return[t];const n=function(e){const t=\"\\n precision highp float;\\n attribute vec3 aPosition;\\n varying float vvv;\\n void main() {\\n vvv = 0.31622776601683794;\\n gl_Position = vec4(aPosition, 1.0);\\n }\\n \",r=\"\\n precision highp float;\\n varying float vvv;\\n void main() {\\n vec4 enc = vec4(1.0, 255.0, 65025.0, 16581375.0) * vvv;\\n enc = fract(enc);\\n enc -= enc.yzww * vec4(1.0 / 255.0, 1.0 / 255.0, 1.0 / 255.0, 0.0);\\n gl_FragColor = enc;\\n }\\n \",n=e.createShader(35633),o=e.createShader(35632),a=e.createProgram();if(!(o&&n&&a))return;e.shaderSource(n,t),e.shaderSource(o,r),e.compileShader(n),e.compileShader(o),e.attachShader(a,n),e.attachShader(a,o),e.linkProgram(a),e.detachShader(a,n),e.detachShader(a,o),e.deleteShader(n),e.deleteShader(o),e.useProgram(a);const i=e.createBuffer();e.bindBuffer(34962,i),e.bufferData(34962,new Float32Array([-1,-1,0,3,-1,0,-1,3,0]),35044);const c=e.getAttribLocation(a,\"aPosition\");e.vertexAttribPointer(c,3,5126,!1,0,0),e.enableVertexAttribArray(c),e.clearColor(1,1,1,1),e.clear(16384),e.viewport(0,0,1,1),e.drawArrays(4,0,3);const d=new Uint8Array(4);return e.readPixels(0,0,1,1,6408,5121,d),e.deleteProgram(a),e.deleteBuffer(i),d.join(\"\")}(e),a=\"801621810\",i=\"8016218135\",c=\"80162181161\",d=(null==o?void 0:o.isIpad)?[[\"a7\",c,12],[\"a8\",i,15],[\"a8x\",i,15],[\"a9\",i,15],[\"a9x\",i,15],[\"a10\",i,15],[\"a10x\",i,15],[\"a12\",a,15],[\"a12x\",a,15],[\"a12z\",a,15],[\"a14\",a,15],[\"m1\",a,15]]:[[\"a7\",c,12],[\"a8\",i,12],[\"a9\",i,15],[\"a10\",i,15],[\"a11\",a,15],[\"a12\",a,15],[\"a13\",a,15],[\"a14\",a,15]];let l;\"80162181255\"===n?l=d.filter((([,,e])=>e>=14)):(l=d.filter((([,e])=>e===n)),l.length||(l=d));return l.map((([e])=>`apple ${e} gpu`))}const i=[],c=[];function d(e,t){if(e===t)return 0;const r=e;e.length>t.length&&(e=t,t=r);let n=e.length,o=t.length;for(;n>0&&e.charCodeAt(~-n)===t.charCodeAt(~-o);)n--,o--;let a,d=0;for(;df?s>f?f+1:s:s>l?l+1:s;return f}function l(e){return null!=e}class s extends Error{constructor(e){super(e),Object.setPrototypeOf(this,new.target.prototype)}}const f=({mobileTiers:i=[0,15,30,60],desktopTiers:c=[0,15,30,60],override:f={},glContext:u,failIfMajorPerformanceCaveat:h=!1,benchmarksURL:g=\"https://unpkg.com/detect-gpu@4.0.33/dist/benchmarks\"}={})=>e(void 0,void 0,void 0,(function*(){const p={};if(n)return{tier:0,type:\"SSR\"};const{isIpad:m=!!(null==o?void 0:o.isIpad),isMobile:v=!!(null==o?void 0:o.isMobile),screenSize:w=window.screen,loadBenchmarks:x=(t=>e(void 0,void 0,void 0,(function*(){const e=yield fetch(`${g}/${t}`).then((e=>e.json()));if(parseInt(e.shift().split(\".\")[0],10)<4)throw new s(\"Detect GPU benchmark data is out of date. Please update to version 4x\");return e})))}=f;let{renderer:A}=f;const P=(e,t,r,n,o)=>({device:o,fps:n,gpu:r,isMobile:v,tier:e,type:t});let b,S=\"\";if(A)A=r(A),b=[A];else{const e=u||function(e,t=!1){const r={alpha:!1,antialias:!1,depth:!1,failIfMajorPerformanceCaveat:t,powerPreference:\"high-performance\",stencil:!1};e&&delete r.powerPreference;const n=window.document.createElement(\"canvas\"),o=n.getContext(\"webgl\",r)||n.getContext(\"experimental-webgl\",r);return null!=o?o:void 0}(null==o?void 0:o.isSafari12,h);if(!e)return P(0,\"WEBGL_UNSUPPORTED\");const t=e.getExtension(\"WEBGL_debug_renderer_info\");if(t&&(A=e.getParameter(t.UNMASKED_RENDERER_WEBGL)),!A)return P(1,\"FALLBACK\");S=A,A=r(A),b=function(e,t,r){return\"apple gpu\"===t?a(e,t,r):[t]}(e,A,v)}const y=(yield Promise.all(b.map((function(t){var r;return e(this,void 0,void 0,(function*(){const e=(e=>{const t=v?[\"adreno\",\"apple\",\"mali-t\",\"mali\",\"nvidia\",\"powervr\"]:[\"intel\",\"apple\",\"amd\",\"radeon\",\"nvidia\",\"geforce\"];for(const r of t)if(e.includes(r))return r})(t);if(!e)return;const n=`${v?\"m\":\"d\"}-${e}${m?\"-ipad\":\"\"}.json`,o=p[n]=null!==(r=p[n])&&void 0!==r?r:x(n);let a;try{a=yield o}catch(e){if(e instanceof s)throw e;return}const i=function(e){var t;const r=(e=e.replace(/\\([^)]+\\)/,\"\")).match(/\\d+/)||e.match(/(\\W|^)([A-Za-z]{1,3})(\\W|$)/g);return null!==(t=null==r?void 0:r.join(\"\").replace(/\\W|amd/g,\"\"))&&void 0!==t?t:\"\"}(t);let c=a.filter((([,e])=>e===i));c.length||(c=a.filter((([e])=>e.includes(t))));const l=c.length;if(0===l)return;let f,[u,,,h]=l>1?c.map((e=>[e,d(t,e[0])])).sort((([,e],[,t])=>e-t))[0][0]:c[0],g=Number.MAX_VALUE;const{devicePixelRatio:A}=window,P=w.width*A*w.height*A;for(const e of h){const[t,r]=e,n=t*r,o=Math.abs(P-n);oe===r?t-n:e-r));if(!y.length){const e=t.find((e=>A.includes(e)));return e?P(0,\"BLOCKLISTED\",e):P(1,\"FALLBACK\",`${A} (${S})`)}const[,C,E,L]=y[0];if(-1===C)return P(0,\"BLOCKLISTED\",E,C,L);const M=v?i:c;let $=0;for(let e=0;e=M[e]&&($=e);return P($,\"BENCHMARK\",E,C,L)}));export{f as getGPUTier};\n//# sourceMappingURL=detect-gpu.esm.js.map\n","\"use strict\";\n\n// Map the characters to escape to their escaped values. The list is derived\n// from http://www.cespedes.org/blog/85/how-to-escape-latex-special-characters\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar defaultEscapes = {\n \"{\": \"\\\\{\",\n \"}\": \"\\\\}\",\n \"\\\\\": \"\\\\textbackslash{}\",\n \"#\": \"\\\\#\",\n $: \"\\\\$\",\n \"%\": \"\\\\%\",\n \"&\": \"\\\\&\",\n \"^\": \"\\\\textasciicircum{}\",\n _: \"\\\\_\",\n \"~\": \"\\\\textasciitilde{}\"\n};\nvar formatEscapes = {\n \"\\u2013\": \"\\\\--\",\n \"\\u2014\": \"\\\\---\",\n \" \": \"~\",\n \"\\t\": \"\\\\qquad{}\",\n \"\\r\\n\": \"\\\\newline{}\",\n \"\\n\": \"\\\\newline{}\"\n};\n\nvar defaultEscapeMapFn = function defaultEscapeMapFn(defaultEscapes, formatEscapes) {\n return _extends({}, defaultEscapes, formatEscapes);\n};\n\n/**\n * Escape a string to be used in LaTeX documents.\n * @param {string} str the string to be escaped.\n * @param {boolean} params.preserveFormatting whether formatting escapes should\n * be performed (default: false).\n * @param {function} params.escapeMapFn the function to modify the escape maps.\n * @return {string} the escaped string, ready to be used in LaTeX.\n */\nmodule.exports = function (str) {\n var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n _ref$preserveFormatti = _ref.preserveFormatting,\n preserveFormatting = _ref$preserveFormatti === undefined ? false : _ref$preserveFormatti,\n _ref$escapeMapFn = _ref.escapeMapFn,\n escapeMapFn = _ref$escapeMapFn === undefined ? defaultEscapeMapFn : _ref$escapeMapFn;\n\n var runningStr = String(str);\n var result = \"\";\n\n var escapes = escapeMapFn(_extends({}, defaultEscapes), preserveFormatting ? _extends({}, formatEscapes) : {});\n var escapeKeys = Object.keys(escapes); // as it is reused later on\n\n // Algorithm: Go through the string character by character, if it matches\n // with one of the special characters then we'll replace it with the escaped\n // version.\n\n var _loop = function _loop() {\n var specialCharFound = false;\n escapeKeys.forEach(function (key, index) {\n if (specialCharFound) {\n return;\n }\n if (runningStr.length >= key.length && runningStr.slice(0, key.length) === key) {\n result += escapes[escapeKeys[index]];\n runningStr = runningStr.slice(key.length, runningStr.length);\n specialCharFound = true;\n }\n });\n if (!specialCharFound) {\n result += runningStr.slice(0, 1);\n runningStr = runningStr.slice(1, runningStr.length);\n }\n };\n\n while (runningStr) {\n _loop();\n }\n return result;\n};","/**\n * @license Fraction.js v4.2.0 05/03/2022\n * https://www.xarg.org/2014/03/rational-numbers-in-javascript/\n *\n * Copyright (c) 2021, Robert Eisele (robert@xarg.org)\n * Dual licensed under the MIT or GPL Version 2 licenses.\n **/\n\n\n/**\n *\n * This class offers the possibility to calculate fractions.\n * You can pass a fraction in different formats. Either as array, as double, as string or as an integer.\n *\n * Array/Object form\n * [ 0 => , 1 => ]\n * [ n => , d => ]\n *\n * Integer form\n * - Single integer value\n *\n * Double form\n * - Single double value\n *\n * String form\n * 123.456 - a simple double\n * 123/456 - a string fraction\n * 123.'456' - a double with repeating decimal places\n * 123.(456) - synonym\n * 123.45'6' - a double with repeating last place\n * 123.45(6) - synonym\n *\n * Example:\n *\n * var f = new Fraction(\"9.4'31'\");\n * f.mul([-4, 3]).div(4.9);\n *\n */\n\n(function(root) {\n\n \"use strict\";\n\n // Maximum search depth for cyclic rational numbers. 2000 should be more than enough.\n // Example: 1/7 = 0.(142857) has 6 repeating decimal places.\n // If MAX_CYCLE_LEN gets reduced, long cycles will not be detected and toString() only gets the first 10 digits\n var MAX_CYCLE_LEN = 2000;\n\n // Parsed data to avoid calling \"new\" all the time\n var P = {\n \"s\": 1,\n \"n\": 0,\n \"d\": 1\n };\n\n function assign(n, s) {\n\n if (isNaN(n = parseInt(n, 10))) {\n throw Fraction['InvalidParameter'];\n }\n return n * s;\n }\n\n // Creates a new Fraction internally without the need of the bulky constructor\n function newFraction(n, d) {\n\n if (d === 0) {\n throw Fraction['DivisionByZero'];\n }\n\n var f = Object.create(Fraction.prototype);\n f[\"s\"] = n < 0 ? -1 : 1;\n\n n = n < 0 ? -n : n;\n\n var a = gcd(n, d);\n\n f[\"n\"] = n / a;\n f[\"d\"] = d / a;\n return f;\n }\n\n function factorize(num) {\n\n var factors = {};\n\n var n = num;\n var i = 2;\n var s = 4;\n\n while (s <= n) {\n\n while (n % i === 0) {\n n/= i;\n factors[i] = (factors[i] || 0) + 1;\n }\n s+= 1 + 2 * i++;\n }\n\n if (n !== num) {\n if (n > 1)\n factors[n] = (factors[n] || 0) + 1;\n } else {\n factors[num] = (factors[num] || 0) + 1;\n }\n return factors;\n }\n\n var parse = function(p1, p2) {\n\n var n = 0, d = 1, s = 1;\n var v = 0, w = 0, x = 0, y = 1, z = 1;\n\n var A = 0, B = 1;\n var C = 1, D = 1;\n\n var N = 10000000;\n var M;\n\n if (p1 === undefined || p1 === null) {\n /* void */\n } else if (p2 !== undefined) {\n n = p1;\n d = p2;\n s = n * d;\n\n if (n % 1 !== 0 || d % 1 !== 0) {\n throw Fraction['NonIntegerParameter'];\n }\n\n } else\n switch (typeof p1) {\n\n case \"object\":\n {\n if (\"d\" in p1 && \"n\" in p1) {\n n = p1[\"n\"];\n d = p1[\"d\"];\n if (\"s\" in p1)\n n*= p1[\"s\"];\n } else if (0 in p1) {\n n = p1[0];\n if (1 in p1)\n d = p1[1];\n } else {\n throw Fraction['InvalidParameter'];\n }\n s = n * d;\n break;\n }\n case \"number\":\n {\n if (p1 < 0) {\n s = p1;\n p1 = -p1;\n }\n\n if (p1 % 1 === 0) {\n n = p1;\n } else if (p1 > 0) { // check for != 0, scale would become NaN (log(0)), which converges really slow\n\n if (p1 >= 1) {\n z = Math.pow(10, Math.floor(1 + Math.log(p1) / Math.LN10));\n p1/= z;\n }\n\n // Using Farey Sequences\n // http://www.johndcook.com/blog/2010/10/20/best-rational-approximation/\n\n while (B <= N && D <= N) {\n M = (A + C) / (B + D);\n\n if (p1 === M) {\n if (B + D <= N) {\n n = A + C;\n d = B + D;\n } else if (D > B) {\n n = C;\n d = D;\n } else {\n n = A;\n d = B;\n }\n break;\n\n } else {\n\n if (p1 > M) {\n A+= C;\n B+= D;\n } else {\n C+= A;\n D+= B;\n }\n\n if (B > N) {\n n = C;\n d = D;\n } else {\n n = A;\n d = B;\n }\n }\n }\n n*= z;\n } else if (isNaN(p1) || isNaN(p2)) {\n d = n = NaN;\n }\n break;\n }\n case \"string\":\n {\n B = p1.match(/\\d+|./g);\n\n if (B === null)\n throw Fraction['InvalidParameter'];\n\n if (B[A] === '-') {// Check for minus sign at the beginning\n s = -1;\n A++;\n } else if (B[A] === '+') {// Check for plus sign at the beginning\n A++;\n }\n\n if (B.length === A + 1) { // Check if it's just a simple number \"1234\"\n w = assign(B[A++], s);\n } else if (B[A + 1] === '.' || B[A] === '.') { // Check if it's a decimal number\n\n if (B[A] !== '.') { // Handle 0.5 and .5\n v = assign(B[A++], s);\n }\n A++;\n\n // Check for decimal places\n if (A + 1 === B.length || B[A + 1] === '(' && B[A + 3] === ')' || B[A + 1] === \"'\" && B[A + 3] === \"'\") {\n w = assign(B[A], s);\n y = Math.pow(10, B[A].length);\n A++;\n }\n\n // Check for repeating places\n if (B[A] === '(' && B[A + 2] === ')' || B[A] === \"'\" && B[A + 2] === \"'\") {\n x = assign(B[A + 1], s);\n z = Math.pow(10, B[A + 1].length) - 1;\n A+= 3;\n }\n\n } else if (B[A + 1] === '/' || B[A + 1] === ':') { // Check for a simple fraction \"123/456\" or \"123:456\"\n w = assign(B[A], s);\n y = assign(B[A + 2], 1);\n A+= 3;\n } else if (B[A + 3] === '/' && B[A + 1] === ' ') { // Check for a complex fraction \"123 1/2\"\n v = assign(B[A], s);\n w = assign(B[A + 2], s);\n y = assign(B[A + 4], 1);\n A+= 5;\n }\n\n if (B.length <= A) { // Check for more tokens on the stack\n d = y * z;\n s = /* void */\n n = x + d * v + z * w;\n break;\n }\n\n /* Fall through on error */\n }\n default:\n throw Fraction['InvalidParameter'];\n }\n\n if (d === 0) {\n throw Fraction['DivisionByZero'];\n }\n\n P[\"s\"] = s < 0 ? -1 : 1;\n P[\"n\"] = Math.abs(n);\n P[\"d\"] = Math.abs(d);\n };\n\n function modpow(b, e, m) {\n\n var r = 1;\n for (; e > 0; b = (b * b) % m, e >>= 1) {\n\n if (e & 1) {\n r = (r * b) % m;\n }\n }\n return r;\n }\n\n\n function cycleLen(n, d) {\n\n for (; d % 2 === 0;\n d/= 2) {\n }\n\n for (; d % 5 === 0;\n d/= 5) {\n }\n\n if (d === 1) // Catch non-cyclic numbers\n return 0;\n\n // If we would like to compute really large numbers quicker, we could make use of Fermat's little theorem:\n // 10^(d-1) % d == 1\n // However, we don't need such large numbers and MAX_CYCLE_LEN should be the capstone,\n // as we want to translate the numbers to strings.\n\n var rem = 10 % d;\n var t = 1;\n\n for (; rem !== 1; t++) {\n rem = rem * 10 % d;\n\n if (t > MAX_CYCLE_LEN)\n return 0; // Returning 0 here means that we don't print it as a cyclic number. It's likely that the answer is `d-1`\n }\n return t;\n }\n\n\n function cycleStart(n, d, len) {\n\n var rem1 = 1;\n var rem2 = modpow(10, len, d);\n\n for (var t = 0; t < 300; t++) { // s < ~log10(Number.MAX_VALUE)\n // Solve 10^s == 10^(s+t) (mod d)\n\n if (rem1 === rem2)\n return t;\n\n rem1 = rem1 * 10 % d;\n rem2 = rem2 * 10 % d;\n }\n return 0;\n }\n\n function gcd(a, b) {\n\n if (!a)\n return b;\n if (!b)\n return a;\n\n while (1) {\n a%= b;\n if (!a)\n return b;\n b%= a;\n if (!b)\n return a;\n }\n };\n\n /**\n * Module constructor\n *\n * @constructor\n * @param {number|Fraction=} a\n * @param {number=} b\n */\n function Fraction(a, b) {\n\n parse(a, b);\n\n if (this instanceof Fraction) {\n a = gcd(P[\"d\"], P[\"n\"]); // Abuse variable a\n this[\"s\"] = P[\"s\"];\n this[\"n\"] = P[\"n\"] / a;\n this[\"d\"] = P[\"d\"] / a;\n } else {\n return newFraction(P['s'] * P['n'], P['d']);\n }\n }\n\n Fraction['DivisionByZero'] = new Error(\"Division by Zero\");\n Fraction['InvalidParameter'] = new Error(\"Invalid argument\");\n Fraction['NonIntegerParameter'] = new Error(\"Parameters must be integer\");\n\n Fraction.prototype = {\n\n \"s\": 1,\n \"n\": 0,\n \"d\": 1,\n\n /**\n * Calculates the absolute value\n *\n * Ex: new Fraction(-4).abs() => 4\n **/\n \"abs\": function() {\n\n return newFraction(this[\"n\"], this[\"d\"]);\n },\n\n /**\n * Inverts the sign of the current fraction\n *\n * Ex: new Fraction(-4).neg() => 4\n **/\n \"neg\": function() {\n\n return newFraction(-this[\"s\"] * this[\"n\"], this[\"d\"]);\n },\n\n /**\n * Adds two rational numbers\n *\n * Ex: new Fraction({n: 2, d: 3}).add(\"14.9\") => 467 / 30\n **/\n \"add\": function(a, b) {\n\n parse(a, b);\n return newFraction(\n this[\"s\"] * this[\"n\"] * P[\"d\"] + P[\"s\"] * this[\"d\"] * P[\"n\"],\n this[\"d\"] * P[\"d\"]\n );\n },\n\n /**\n * Subtracts two rational numbers\n *\n * Ex: new Fraction({n: 2, d: 3}).add(\"14.9\") => -427 / 30\n **/\n \"sub\": function(a, b) {\n\n parse(a, b);\n return newFraction(\n this[\"s\"] * this[\"n\"] * P[\"d\"] - P[\"s\"] * this[\"d\"] * P[\"n\"],\n this[\"d\"] * P[\"d\"]\n );\n },\n\n /**\n * Multiplies two rational numbers\n *\n * Ex: new Fraction(\"-17.(345)\").mul(3) => 5776 / 111\n **/\n \"mul\": function(a, b) {\n\n parse(a, b);\n return newFraction(\n this[\"s\"] * P[\"s\"] * this[\"n\"] * P[\"n\"],\n this[\"d\"] * P[\"d\"]\n );\n },\n\n /**\n * Divides two rational numbers\n *\n * Ex: new Fraction(\"-17.(345)\").inverse().div(3)\n **/\n \"div\": function(a, b) {\n\n parse(a, b);\n return newFraction(\n this[\"s\"] * P[\"s\"] * this[\"n\"] * P[\"d\"],\n this[\"d\"] * P[\"n\"]\n );\n },\n\n /**\n * Clones the actual object\n *\n * Ex: new Fraction(\"-17.(345)\").clone()\n **/\n \"clone\": function() {\n return newFraction(this['s'] * this['n'], this['d']);\n },\n\n /**\n * Calculates the modulo of two rational numbers - a more precise fmod\n *\n * Ex: new Fraction('4.(3)').mod([7, 8]) => (13/3) % (7/8) = (5/6)\n **/\n \"mod\": function(a, b) {\n\n if (isNaN(this['n']) || isNaN(this['d'])) {\n return new Fraction(NaN);\n }\n\n if (a === undefined) {\n return newFraction(this[\"s\"] * this[\"n\"] % this[\"d\"], 1);\n }\n\n parse(a, b);\n if (0 === P[\"n\"] && 0 === this[\"d\"]) {\n throw Fraction['DivisionByZero'];\n }\n\n /*\n * First silly attempt, kinda slow\n *\n return that[\"sub\"]({\n \"n\": num[\"n\"] * Math.floor((this.n / this.d) / (num.n / num.d)),\n \"d\": num[\"d\"],\n \"s\": this[\"s\"]\n });*/\n\n /*\n * New attempt: a1 / b1 = a2 / b2 * q + r\n * => b2 * a1 = a2 * b1 * q + b1 * b2 * r\n * => (b2 * a1 % a2 * b1) / (b1 * b2)\n */\n return newFraction(\n this[\"s\"] * (P[\"d\"] * this[\"n\"]) % (P[\"n\"] * this[\"d\"]),\n P[\"d\"] * this[\"d\"]\n );\n },\n\n /**\n * Calculates the fractional gcd of two rational numbers\n *\n * Ex: new Fraction(5,8).gcd(3,7) => 1/56\n */\n \"gcd\": function(a, b) {\n\n parse(a, b);\n\n // gcd(a / b, c / d) = gcd(a, c) / lcm(b, d)\n\n return newFraction(gcd(P[\"n\"], this[\"n\"]) * gcd(P[\"d\"], this[\"d\"]), P[\"d\"] * this[\"d\"]);\n },\n\n /**\n * Calculates the fractional lcm of two rational numbers\n *\n * Ex: new Fraction(5,8).lcm(3,7) => 15\n */\n \"lcm\": function(a, b) {\n\n parse(a, b);\n\n // lcm(a / b, c / d) = lcm(a, c) / gcd(b, d)\n\n if (P[\"n\"] === 0 && this[\"n\"] === 0) {\n return newFraction(0, 1);\n }\n return newFraction(P[\"n\"] * this[\"n\"], gcd(P[\"n\"], this[\"n\"]) * gcd(P[\"d\"], this[\"d\"]));\n },\n\n /**\n * Calculates the ceil of a rational number\n *\n * Ex: new Fraction('4.(3)').ceil() => (5 / 1)\n **/\n \"ceil\": function(places) {\n\n places = Math.pow(10, places || 0);\n\n if (isNaN(this[\"n\"]) || isNaN(this[\"d\"])) {\n return new Fraction(NaN);\n }\n return newFraction(Math.ceil(places * this[\"s\"] * this[\"n\"] / this[\"d\"]), places);\n },\n\n /**\n * Calculates the floor of a rational number\n *\n * Ex: new Fraction('4.(3)').floor() => (4 / 1)\n **/\n \"floor\": function(places) {\n\n places = Math.pow(10, places || 0);\n\n if (isNaN(this[\"n\"]) || isNaN(this[\"d\"])) {\n return new Fraction(NaN);\n }\n return newFraction(Math.floor(places * this[\"s\"] * this[\"n\"] / this[\"d\"]), places);\n },\n\n /**\n * Rounds a rational numbers\n *\n * Ex: new Fraction('4.(3)').round() => (4 / 1)\n **/\n \"round\": function(places) {\n\n places = Math.pow(10, places || 0);\n\n if (isNaN(this[\"n\"]) || isNaN(this[\"d\"])) {\n return new Fraction(NaN);\n }\n return newFraction(Math.round(places * this[\"s\"] * this[\"n\"] / this[\"d\"]), places);\n },\n\n /**\n * Gets the inverse of the fraction, means numerator and denominator are exchanged\n *\n * Ex: new Fraction([-3, 4]).inverse() => -4 / 3\n **/\n \"inverse\": function() {\n\n return newFraction(this[\"s\"] * this[\"d\"], this[\"n\"]);\n },\n\n /**\n * Calculates the fraction to some rational exponent, if possible\n *\n * Ex: new Fraction(-1,2).pow(-3) => -8\n */\n \"pow\": function(a, b) {\n\n parse(a, b);\n\n // Trivial case when exp is an integer\n\n if (P['d'] === 1) {\n\n if (P['s'] < 0) {\n return newFraction(Math.pow(this['s'] * this[\"d\"], P['n']), Math.pow(this[\"n\"], P['n']));\n } else {\n return newFraction(Math.pow(this['s'] * this[\"n\"], P['n']), Math.pow(this[\"d\"], P['n']));\n }\n }\n\n // Negative roots become complex\n // (-a/b)^(c/d) = x\n // <=> (-1)^(c/d) * (a/b)^(c/d) = x\n // <=> (cos(pi) + i*sin(pi))^(c/d) * (a/b)^(c/d) = x # rotate 1 by 180°\n // <=> (cos(c*pi/d) + i*sin(c*pi/d)) * (a/b)^(c/d) = x # DeMoivre's formula in Q ( https://proofwiki.org/wiki/De_Moivre%27s_Formula/Rational_Index )\n // From which follows that only for c=0 the root is non-complex. c/d is a reduced fraction, so that sin(c/dpi)=0 occurs for d=1, which is handled by our trivial case.\n if (this['s'] < 0) return null;\n\n // Now prime factor n and d\n var N = factorize(this['n']);\n var D = factorize(this['d']);\n\n // Exponentiate and take root for n and d individually\n var n = 1;\n var d = 1;\n for (var k in N) {\n if (k === '1') continue;\n if (k === '0') {\n n = 0;\n break;\n }\n N[k]*= P['n'];\n\n if (N[k] % P['d'] === 0) {\n N[k]/= P['d'];\n } else return null;\n n*= Math.pow(k, N[k]);\n }\n\n for (var k in D) {\n if (k === '1') continue;\n D[k]*= P['n'];\n\n if (D[k] % P['d'] === 0) {\n D[k]/= P['d'];\n } else return null;\n d*= Math.pow(k, D[k]);\n }\n\n if (P['s'] < 0) {\n return newFraction(d, n);\n }\n return newFraction(n, d);\n },\n\n /**\n * Check if two rational numbers are the same\n *\n * Ex: new Fraction(19.6).equals([98, 5]);\n **/\n \"equals\": function(a, b) {\n\n parse(a, b);\n return this[\"s\"] * this[\"n\"] * P[\"d\"] === P[\"s\"] * P[\"n\"] * this[\"d\"]; // Same as compare() === 0\n },\n\n /**\n * Check if two rational numbers are the same\n *\n * Ex: new Fraction(19.6).equals([98, 5]);\n **/\n \"compare\": function(a, b) {\n\n parse(a, b);\n var t = (this[\"s\"] * this[\"n\"] * P[\"d\"] - P[\"s\"] * P[\"n\"] * this[\"d\"]);\n return (0 < t) - (t < 0);\n },\n\n \"simplify\": function(eps) {\n\n if (isNaN(this['n']) || isNaN(this['d'])) {\n return this;\n }\n\n eps = eps || 0.001;\n\n var thisABS = this['abs']();\n var cont = thisABS['toContinued']();\n\n for (var i = 1; i < cont.length; i++) {\n\n var s = newFraction(cont[i - 1], 1);\n for (var k = i - 2; k >= 0; k--) {\n s = s['inverse']()['add'](cont[k]);\n }\n\n if (s['sub'](thisABS)['abs']().valueOf() < eps) {\n return s['mul'](this['s']);\n }\n }\n return this;\n },\n\n /**\n * Check if two rational numbers are divisible\n *\n * Ex: new Fraction(19.6).divisible(1.5);\n */\n \"divisible\": function(a, b) {\n\n parse(a, b);\n return !(!(P[\"n\"] * this[\"d\"]) || ((this[\"n\"] * P[\"d\"]) % (P[\"n\"] * this[\"d\"])));\n },\n\n /**\n * Returns a decimal representation of the fraction\n *\n * Ex: new Fraction(\"100.'91823'\").valueOf() => 100.91823918239183\n **/\n 'valueOf': function() {\n\n return this[\"s\"] * this[\"n\"] / this[\"d\"];\n },\n\n /**\n * Returns a string-fraction representation of a Fraction object\n *\n * Ex: new Fraction(\"1.'3'\").toFraction(true) => \"4 1/3\"\n **/\n 'toFraction': function(excludeWhole) {\n\n var whole, str = \"\";\n var n = this[\"n\"];\n var d = this[\"d\"];\n if (this[\"s\"] < 0) {\n str+= '-';\n }\n\n if (d === 1) {\n str+= n;\n } else {\n\n if (excludeWhole && (whole = Math.floor(n / d)) > 0) {\n str+= whole;\n str+= \" \";\n n%= d;\n }\n\n str+= n;\n str+= '/';\n str+= d;\n }\n return str;\n },\n\n /**\n * Returns a latex representation of a Fraction object\n *\n * Ex: new Fraction(\"1.'3'\").toLatex() => \"\\frac{4}{3}\"\n **/\n 'toLatex': function(excludeWhole) {\n\n var whole, str = \"\";\n var n = this[\"n\"];\n var d = this[\"d\"];\n if (this[\"s\"] < 0) {\n str+= '-';\n }\n\n if (d === 1) {\n str+= n;\n } else {\n\n if (excludeWhole && (whole = Math.floor(n / d)) > 0) {\n str+= whole;\n n%= d;\n }\n\n str+= \"\\\\frac{\";\n str+= n;\n str+= '}{';\n str+= d;\n str+= '}';\n }\n return str;\n },\n\n /**\n * Returns an array of continued fraction elements\n *\n * Ex: new Fraction(\"7/8\").toContinued() => [0,1,7]\n */\n 'toContinued': function() {\n\n var t;\n var a = this['n'];\n var b = this['d'];\n var res = [];\n\n if (isNaN(a) || isNaN(b)) {\n return res;\n }\n\n do {\n res.push(Math.floor(a / b));\n t = a % b;\n a = b;\n b = t;\n } while (a !== 1);\n\n return res;\n },\n\n /**\n * Creates a string representation of a fraction with all digits\n *\n * Ex: new Fraction(\"100.'91823'\").toString() => \"100.(91823)\"\n **/\n 'toString': function(dec) {\n\n var N = this[\"n\"];\n var D = this[\"d\"];\n\n if (isNaN(N) || isNaN(D)) {\n return \"NaN\";\n }\n\n dec = dec || 15; // 15 = decimal places when no repetation\n\n var cycLen = cycleLen(N, D); // Cycle length\n var cycOff = cycleStart(N, D, cycLen); // Cycle start\n\n var str = this['s'] < 0 ? \"-\" : \"\";\n\n str+= N / D | 0;\n\n N%= D;\n N*= 10;\n\n if (N)\n str+= \".\";\n\n if (cycLen) {\n\n for (var i = cycOff; i--;) {\n str+= N / D | 0;\n N%= D;\n N*= 10;\n }\n str+= \"(\";\n for (var i = cycLen; i--;) {\n str+= N / D | 0;\n N%= D;\n N*= 10;\n }\n str+= \")\";\n } else {\n for (var i = dec; N && i--;) {\n str+= N / D | 0;\n N%= D;\n N*= 10;\n }\n }\n return str;\n }\n };\n\n if (typeof define === \"function\" && define[\"amd\"]) {\n define([], function() {\n return Fraction;\n });\n } else if (typeof exports === \"object\") {\n Object.defineProperty(Fraction, \"__esModule\", { 'value': true });\n Fraction['default'] = Fraction;\n Fraction['Fraction'] = Fraction;\n module['exports'] = Fraction;\n } else {\n root['Fraction'] = Fraction;\n }\n\n})(this);\n","/*\r\n * Natural Sort algorithm for Javascript - Version 0.7 - Released under MIT license\r\n * Author: Jim Palmer (based on chunking idea from Dave Koelle)\r\n */\r\n/*jshint unused:false */\r\nmodule.exports = function naturalSort (a, b) {\r\n\t\"use strict\";\r\n\tvar re = /(^([+\\-]?(?:0|[1-9]\\d*)(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?)?$|^0x[0-9a-f]+$|\\d+)/gi,\r\n\t\tsre = /(^[ ]*|[ ]*$)/g,\r\n\t\tdre = /(^([\\w ]+,?[\\w ]+)?[\\w ]+,?[\\w ]+\\d+:\\d+(:\\d+)?[\\w ]?|^\\d{1,4}[\\/\\-]\\d{1,4}[\\/\\-]\\d{1,4}|^\\w+, \\w+ \\d+, \\d{4})/,\r\n\t\thre = /^0x[0-9a-f]+$/i,\r\n\t\tore = /^0/,\r\n\t\ti = function(s) { return naturalSort.insensitive && ('' + s).toLowerCase() || '' + s; },\r\n\t\t// convert all to strings strip whitespace\r\n\t\tx = i(a).replace(sre, '') || '',\r\n\t\ty = i(b).replace(sre, '') || '',\r\n\t\t// chunk/tokenize\r\n\t\txN = x.replace(re, '\\0$1\\0').replace(/\\0$/,'').replace(/^\\0/,'').split('\\0'),\r\n\t\tyN = y.replace(re, '\\0$1\\0').replace(/\\0$/,'').replace(/^\\0/,'').split('\\0'),\r\n\t\t// numeric, hex or date detection\r\n\t\txD = parseInt(x.match(hre), 16) || (xN.length !== 1 && x.match(dre) && Date.parse(x)),\r\n\t\tyD = parseInt(y.match(hre), 16) || xD && y.match(dre) && Date.parse(y) || null,\r\n\t\toFxNcL, oFyNcL;\r\n\t// first try and sort Hex codes or Dates\r\n\tif (yD) {\r\n\t\tif ( xD < yD ) { return -1; }\r\n\t\telse if ( xD > yD ) { return 1; }\r\n\t}\r\n\t// natural sorting through split numeric strings and default strings\r\n\tfor(var cLoc=0, numS=Math.max(xN.length, yN.length); cLoc < numS; cLoc++) {\r\n\t\t// find floats not starting with '0', string or 0 if not defined (Clint Priest)\r\n\t\toFxNcL = !(xN[cLoc] || '').match(ore) && parseFloat(xN[cLoc]) || xN[cLoc] || 0;\r\n\t\toFyNcL = !(yN[cLoc] || '').match(ore) && parseFloat(yN[cLoc]) || yN[cLoc] || 0;\r\n\t\t// handle numeric vs string comparison - number < string - (Kyle Adams)\r\n\t\tif (isNaN(oFxNcL) !== isNaN(oFyNcL)) { return (isNaN(oFxNcL)) ? 1 : -1; }\r\n\t\t// rely on string comparison if different types - i.e. '02' < 2 != '02' < '2'\r\n\t\telse if (typeof oFxNcL !== typeof oFyNcL) {\r\n\t\t\toFxNcL += '';\r\n\t\t\toFyNcL += '';\r\n\t\t}\r\n\t\tif (oFxNcL < oFyNcL) { return -1; }\r\n\t\tif (oFxNcL > oFyNcL) { return 1; }\r\n\t}\r\n\treturn 0;\r\n};\r\n","// A library of seedable RNGs implemented in Javascript.\n//\n// Usage:\n//\n// var seedrandom = require('seedrandom');\n// var random = seedrandom(1); // or any seed.\n// var x = random(); // 0 <= x < 1. Every bit is random.\n// var x = random.quick(); // 0 <= x < 1. 32 bits of randomness.\n\n// alea, a 53-bit multiply-with-carry generator by Johannes Baagøe.\n// Period: ~2^116\n// Reported to pass all BigCrush tests.\nvar alea = require('./lib/alea');\n\n// xor128, a pure xor-shift generator by George Marsaglia.\n// Period: 2^128-1.\n// Reported to fail: MatrixRank and LinearComp.\nvar xor128 = require('./lib/xor128');\n\n// xorwow, George Marsaglia's 160-bit xor-shift combined plus weyl.\n// Period: 2^192-2^32\n// Reported to fail: CollisionOver, SimpPoker, and LinearComp.\nvar xorwow = require('./lib/xorwow');\n\n// xorshift7, by François Panneton and Pierre L'ecuyer, takes\n// a different approach: it adds robustness by allowing more shifts\n// than Marsaglia's original three. It is a 7-shift generator\n// with 256 bits, that passes BigCrush with no systmatic failures.\n// Period 2^256-1.\n// No systematic BigCrush failures reported.\nvar xorshift7 = require('./lib/xorshift7');\n\n// xor4096, by Richard Brent, is a 4096-bit xor-shift with a\n// very long period that also adds a Weyl generator. It also passes\n// BigCrush with no systematic failures. Its long period may\n// be useful if you have many generators and need to avoid\n// collisions.\n// Period: 2^4128-2^32.\n// No systematic BigCrush failures reported.\nvar xor4096 = require('./lib/xor4096');\n\n// Tyche-i, by Samuel Neves and Filipe Araujo, is a bit-shifting random\n// number generator derived from ChaCha, a modern stream cipher.\n// https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n// Period: ~2^127\n// No systematic BigCrush failures reported.\nvar tychei = require('./lib/tychei');\n\n// The original ARC4-based prng included in this library.\n// Period: ~2^1600\nvar sr = require('./seedrandom');\n\nsr.alea = alea;\nsr.xor128 = xor128;\nsr.xorwow = xorwow;\nsr.xorshift7 = xorshift7;\nsr.xor4096 = xor4096;\nsr.tychei = tychei;\n\nmodule.exports = sr;\n","// A port of an algorithm by Johannes Baagøe , 2010\n// http://baagoe.com/en/RandomMusings/javascript/\n// https://github.com/nquinlan/better-random-numbers-for-javascript-mirror\n// Original work is under MIT license -\n\n// Copyright (C) 2010 by Johannes Baagøe \n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n\n\n(function(global, module, define) {\n\nfunction Alea(seed) {\n var me = this, mash = Mash();\n\n me.next = function() {\n var t = 2091639 * me.s0 + me.c * 2.3283064365386963e-10; // 2^-32\n me.s0 = me.s1;\n me.s1 = me.s2;\n return me.s2 = t - (me.c = t | 0);\n };\n\n // Apply the seeding algorithm from Baagoe.\n me.c = 1;\n me.s0 = mash(' ');\n me.s1 = mash(' ');\n me.s2 = mash(' ');\n me.s0 -= mash(seed);\n if (me.s0 < 0) { me.s0 += 1; }\n me.s1 -= mash(seed);\n if (me.s1 < 0) { me.s1 += 1; }\n me.s2 -= mash(seed);\n if (me.s2 < 0) { me.s2 += 1; }\n mash = null;\n}\n\nfunction copy(f, t) {\n t.c = f.c;\n t.s0 = f.s0;\n t.s1 = f.s1;\n t.s2 = f.s2;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new Alea(seed),\n state = opts && opts.state,\n prng = xg.next;\n prng.int32 = function() { return (xg.next() * 0x100000000) | 0; }\n prng.double = function() {\n return prng() + (prng() * 0x200000 | 0) * 1.1102230246251565e-16; // 2^-53\n };\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nfunction Mash() {\n var n = 0xefc8249d;\n\n var mash = function(data) {\n data = String(data);\n for (var i = 0; i < data.length; i++) {\n n += data.charCodeAt(i);\n var h = 0.02519603282416938 * n;\n n = h >>> 0;\n h -= n;\n h *= n;\n n = h >>> 0;\n h -= n;\n n += h * 0x100000000; // 2^32\n }\n return (n >>> 0) * 2.3283064365386963e-10; // 2^-32\n };\n\n return mash;\n}\n\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.alea = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"Tyche-i\" prng algorithm by\n// Samuel Neves and Filipe Araujo.\n// See https://eden.dei.uc.pt/~sneves/pubs/2011-snfa2.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var b = me.b, c = me.c, d = me.d, a = me.a;\n b = (b << 25) ^ (b >>> 7) ^ c;\n c = (c - d) | 0;\n d = (d << 24) ^ (d >>> 8) ^ a;\n a = (a - b) | 0;\n me.b = b = (b << 20) ^ (b >>> 12) ^ c;\n me.c = c = (c - d) | 0;\n me.d = (d << 16) ^ (c >>> 16) ^ a;\n return me.a = (a - b) | 0;\n };\n\n /* The following is non-inverted tyche, which has better internal\n * bit diffusion, but which is about 25% slower than tyche-i in JS.\n me.next = function() {\n var a = me.a, b = me.b, c = me.c, d = me.d;\n a = (me.a + me.b | 0) >>> 0;\n d = me.d ^ a; d = d << 16 ^ d >>> 16;\n c = me.c + d | 0;\n b = me.b ^ c; b = b << 12 ^ d >>> 20;\n me.a = a = a + b | 0;\n d = d ^ a; me.d = d = d << 8 ^ d >>> 24;\n me.c = c = c + d | 0;\n b = b ^ c;\n return me.b = (b << 7 ^ b >>> 25);\n }\n */\n\n me.a = 0;\n me.b = 0;\n me.c = 2654435769 | 0;\n me.d = 1367130551;\n\n if (seed === Math.floor(seed)) {\n // Integer seed.\n me.a = (seed / 0x100000000) | 0;\n me.b = seed | 0;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 20; k++) {\n me.b ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.a = f.a;\n t.b = f.b;\n t.c = f.c;\n t.d = f.d;\n return t;\n};\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.tychei = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of the \"xor128\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n\n // Set up generator function.\n me.next = function() {\n var t = me.x ^ (me.x << 11);\n me.x = me.y;\n me.y = me.z;\n me.z = me.w;\n return me.w ^= (me.w >>> 19) ^ t ^ (t >>> 8);\n };\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor128 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","// A Javascript implementaion of Richard Brent's Xorgens xor4096 algorithm.\n//\n// This fast non-cryptographic random number generator is designed for\n// use in Monte-Carlo algorithms. It combines a long-period xorshift\n// generator with a Weyl generator, and it passes all common batteries\n// of stasticial tests for randomness while consuming only a few nanoseconds\n// for each prng generated. For background on the generator, see Brent's\n// paper: \"Some long-period random number generators using shifts and xors.\"\n// http://arxiv.org/pdf/1004.3115v1.pdf\n//\n// Usage:\n//\n// var xor4096 = require('xor4096');\n// random = xor4096(1); // Seed with int32 or string.\n// assert.equal(random(), 0.1520436450538547); // (0, 1) range, 53 bits.\n// assert.equal(random.int32(), 1806534897); // signed int32, 32 bits.\n//\n// For nonzero numeric keys, this impelementation provides a sequence\n// identical to that by Brent's xorgens 3 implementaion in C. This\n// implementation also provides for initalizing the generator with\n// string seeds, or for saving and restoring the state of the generator.\n//\n// On Chrome, this prng benchmarks about 2.1 times slower than\n// Javascript's built-in Math.random().\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n var w = me.w,\n X = me.X, i = me.i, t, v;\n // Update Weyl generator.\n me.w = w = (w + 0x61c88647) | 0;\n // Update xor generator.\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n // Update Xor generator array state.\n v = X[i] = v ^ t;\n me.i = i;\n // Result is the combination.\n return (v + (w ^ (w >>> 16))) | 0;\n };\n\n function init(me, seed) {\n var t, v, i, j, w, X = [], limit = 128;\n if (seed === (seed | 0)) {\n // Numeric seeds initialize v, which is used to generates X.\n v = seed;\n seed = null;\n } else {\n // String seeds are mixed into v and X one character at a time.\n seed = seed + '\\0';\n v = 0;\n limit = Math.max(limit, seed.length);\n }\n // Initialize circular array and weyl value.\n for (i = 0, j = -32; j < limit; ++j) {\n // Put the unicode characters into the array, and shuffle them.\n if (seed) v ^= seed.charCodeAt((j + 32) % seed.length);\n // After 32 shuffles, take v as the starting w value.\n if (j === 0) w = v;\n v ^= v << 10;\n v ^= v >>> 15;\n v ^= v << 4;\n v ^= v >>> 13;\n if (j >= 0) {\n w = (w + 0x61c88647) | 0; // Weyl.\n t = (X[j & 127] ^= (v + w)); // Combine xor and weyl to init array.\n i = (0 == t) ? i + 1 : 0; // Count zeroes.\n }\n }\n // We have detected all zeroes; make the key nonzero.\n if (i >= 128) {\n X[(seed && seed.length || 0) & 127] = -1;\n }\n // Run the generator 512 times to further mix the state before using it.\n // Factoring this as a function slows the main generator, so it is just\n // unrolled here. The weyl generator is not advanced while warming up.\n i = 127;\n for (j = 4 * 128; j > 0; --j) {\n v = X[(i + 34) & 127];\n t = X[i = ((i + 1) & 127)];\n v ^= v << 13;\n t ^= t << 17;\n v ^= v >>> 15;\n t ^= t >>> 12;\n X[i] = v ^ t;\n }\n // Storing state as object members is faster than using closure variables.\n me.w = w;\n me.X = X;\n me.i = i;\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.i = f.i;\n t.w = f.w;\n t.X = f.X.slice();\n return t;\n};\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.X) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xor4096 = impl;\n}\n\n})(\n this, // window object or global\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n","// A Javascript implementaion of the \"xorshift7\" algorithm by\n// François Panneton and Pierre L'ecuyer:\n// \"On the Xorgshift Random Number Generators\"\n// http://saluc.engr.uconn.edu/refs/crypto/rng/panneton05onthexorshift.pdf\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this;\n\n // Set up generator function.\n me.next = function() {\n // Update xor generator.\n var X = me.x, i = me.i, t, v, w;\n t = X[i]; t ^= (t >>> 7); v = t ^ (t << 24);\n t = X[(i + 1) & 7]; v ^= t ^ (t >>> 10);\n t = X[(i + 3) & 7]; v ^= t ^ (t >>> 3);\n t = X[(i + 4) & 7]; v ^= t ^ (t << 7);\n t = X[(i + 7) & 7]; t = t ^ (t << 13); v ^= t ^ (t << 9);\n X[i] = v;\n me.i = (i + 1) & 7;\n return v;\n };\n\n function init(me, seed) {\n var j, w, X = [];\n\n if (seed === (seed | 0)) {\n // Seed state array using a 32-bit integer.\n w = X[0] = seed;\n } else {\n // Seed state using a string.\n seed = '' + seed;\n for (j = 0; j < seed.length; ++j) {\n X[j & 7] = (X[j & 7] << 15) ^\n (seed.charCodeAt(j) + X[(j + 1) & 7] << 13);\n }\n }\n // Enforce an array length of 8, not all zeroes.\n while (X.length < 8) X.push(0);\n for (j = 0; j < 8 && X[j] === 0; ++j);\n if (j == 8) w = X[7] = -1; else w = X[j];\n\n me.x = X;\n me.i = 0;\n\n // Discard an initial 256 values.\n for (j = 256; j > 0; --j) {\n me.next();\n }\n }\n\n init(me, seed);\n}\n\nfunction copy(f, t) {\n t.x = f.x.slice();\n t.i = f.i;\n return t;\n}\n\nfunction impl(seed, opts) {\n if (seed == null) seed = +(new Date);\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (state.x) copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorshift7 = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n","// A Javascript implementaion of the \"xorwow\" prng algorithm by\n// George Marsaglia. See http://www.jstatsoft.org/v08/i14/paper\n\n(function(global, module, define) {\n\nfunction XorGen(seed) {\n var me = this, strseed = '';\n\n // Set up generator function.\n me.next = function() {\n var t = (me.x ^ (me.x >>> 2));\n me.x = me.y; me.y = me.z; me.z = me.w; me.w = me.v;\n return (me.d = (me.d + 362437 | 0)) +\n (me.v = (me.v ^ (me.v << 4)) ^ (t ^ (t << 1))) | 0;\n };\n\n me.x = 0;\n me.y = 0;\n me.z = 0;\n me.w = 0;\n me.v = 0;\n\n if (seed === (seed | 0)) {\n // Integer seed.\n me.x = seed;\n } else {\n // String seed.\n strseed += seed;\n }\n\n // Mix in string seed, then discard an initial batch of 64 values.\n for (var k = 0; k < strseed.length + 64; k++) {\n me.x ^= strseed.charCodeAt(k) | 0;\n if (k == strseed.length) {\n me.d = me.x << 10 ^ me.x >>> 4;\n }\n me.next();\n }\n}\n\nfunction copy(f, t) {\n t.x = f.x;\n t.y = f.y;\n t.z = f.z;\n t.w = f.w;\n t.v = f.v;\n t.d = f.d;\n return t;\n}\n\nfunction impl(seed, opts) {\n var xg = new XorGen(seed),\n state = opts && opts.state,\n prng = function() { return (xg.next() >>> 0) / 0x100000000; };\n prng.double = function() {\n do {\n var top = xg.next() >>> 11,\n bot = (xg.next() >>> 0) / 0x100000000,\n result = (top + bot) / (1 << 21);\n } while (result === 0);\n return result;\n };\n prng.int32 = xg.next;\n prng.quick = prng;\n if (state) {\n if (typeof(state) == 'object') copy(state, xg);\n prng.state = function() { return copy(xg, {}); }\n }\n return prng;\n}\n\nif (module && module.exports) {\n module.exports = impl;\n} else if (define && define.amd) {\n define(function() { return impl; });\n} else {\n this.xorwow = impl;\n}\n\n})(\n this,\n (typeof module) == 'object' && module, // present in node.js\n (typeof define) == 'function' && define // present with an AMD loader\n);\n\n\n","/*\nCopyright 2019 David Bau.\n\nPermission is hereby granted, free of charge, to any person obtaining\na copy of this software and associated documentation files (the\n\"Software\"), to deal in the Software without restriction, including\nwithout limitation the rights to use, copy, modify, merge, publish,\ndistribute, sublicense, and/or sell copies of the Software, and to\npermit persons to whom the Software is furnished to do so, subject to\nthe following conditions:\n\nThe above copyright notice and this permission notice shall be\nincluded in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\nMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\nIN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\nCLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\nTORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\nSOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n*/\n\n(function (global, pool, math) {\n//\n// The following constants are related to IEEE 754 limits.\n//\n\nvar width = 256, // each RC4 output is 0 <= x < 256\n chunks = 6, // at least six RC4 outputs for each double\n digits = 52, // there are 52 significant digits in a double\n rngname = 'random', // rngname: name for Math.random and Math.seedrandom\n startdenom = math.pow(width, chunks),\n significance = math.pow(2, digits),\n overflow = significance * 2,\n mask = width - 1,\n nodecrypto; // node.js crypto module, initialized at the bottom.\n\n//\n// seedrandom()\n// This is the seedrandom function described above.\n//\nfunction seedrandom(seed, options, callback) {\n var key = [];\n options = (options == true) ? { entropy: true } : (options || {});\n\n // Flatten the seed string or build one from local entropy if needed.\n var shortseed = mixkey(flatten(\n options.entropy ? [seed, tostring(pool)] :\n (seed == null) ? autoseed() : seed, 3), key);\n\n // Use the seed to initialize an ARC4 generator.\n var arc4 = new ARC4(key);\n\n // This function returns a random double in [0, 1) that contains\n // randomness in every bit of the mantissa of the IEEE 754 value.\n var prng = function() {\n var n = arc4.g(chunks), // Start with a numerator n < 2 ^ 48\n d = startdenom, // and denominator d = 2 ^ 48.\n x = 0; // and no 'extra last byte'.\n while (n < significance) { // Fill up all significant digits by\n n = (n + x) * width; // shifting numerator and\n d *= width; // denominator and generating a\n x = arc4.g(1); // new least-significant-byte.\n }\n while (n >= overflow) { // To avoid rounding up, before adding\n n /= 2; // last byte, shift everything\n d /= 2; // right using integer math until\n x >>>= 1; // we have exactly the desired bits.\n }\n return (n + x) / d; // Form the number within [0, 1).\n };\n\n prng.int32 = function() { return arc4.g(4) | 0; }\n prng.quick = function() { return arc4.g(4) / 0x100000000; }\n prng.double = prng;\n\n // Mix the randomness into accumulated entropy.\n mixkey(tostring(arc4.S), pool);\n\n // Calling convention: what to return as a function of prng, seed, is_math.\n return (options.pass || callback ||\n function(prng, seed, is_math_call, state) {\n if (state) {\n // Load the arc4 state from the given state if it has an S array.\n if (state.S) { copy(state, arc4); }\n // Only provide the .state method if requested via options.state.\n prng.state = function() { return copy(arc4, {}); }\n }\n\n // If called as a method of Math (Math.seedrandom()), mutate\n // Math.random because that is how seedrandom.js has worked since v1.0.\n if (is_math_call) { math[rngname] = prng; return seed; }\n\n // Otherwise, it is a newer calling convention, so return the\n // prng directly.\n else return prng;\n })(\n prng,\n shortseed,\n 'global' in options ? options.global : (this == math),\n options.state);\n}\n\n//\n// ARC4\n//\n// An ARC4 implementation. The constructor takes a key in the form of\n// an array of at most (width) integers that should be 0 <= x < (width).\n//\n// The g(count) method returns a pseudorandom integer that concatenates\n// the next (count) outputs from ARC4. Its return value is a number x\n// that is in the range 0 <= x < (width ^ count).\n//\nfunction ARC4(key) {\n var t, keylen = key.length,\n me = this, i = 0, j = me.i = me.j = 0, s = me.S = [];\n\n // The empty key [] is treated as [0].\n if (!keylen) { key = [keylen++]; }\n\n // Set up S using the standard key scheduling algorithm.\n while (i < width) {\n s[i] = i++;\n }\n for (i = 0; i < width; i++) {\n s[i] = s[j = mask & (j + key[i % keylen] + (t = s[i]))];\n s[j] = t;\n }\n\n // The \"g\" method returns the next (count) outputs as one number.\n (me.g = function(count) {\n // Using instance members instead of closure state nearly doubles speed.\n var t, r = 0,\n i = me.i, j = me.j, s = me.S;\n while (count--) {\n t = s[i = mask & (i + 1)];\n r = r * width + s[mask & ((s[i] = s[j = mask & (j + t)]) + (s[j] = t))];\n }\n me.i = i; me.j = j;\n return r;\n // For robust unpredictability, the function call below automatically\n // discards an initial batch of values. This is called RC4-drop[256].\n // See http://google.com/search?q=rsa+fluhrer+response&btnI\n })(width);\n}\n\n//\n// copy()\n// Copies internal state of ARC4 to or from a plain object.\n//\nfunction copy(f, t) {\n t.i = f.i;\n t.j = f.j;\n t.S = f.S.slice();\n return t;\n};\n\n//\n// flatten()\n// Converts an object tree to nested arrays of strings.\n//\nfunction flatten(obj, depth) {\n var result = [], typ = (typeof obj), prop;\n if (depth && typ == 'object') {\n for (prop in obj) {\n try { result.push(flatten(obj[prop], depth - 1)); } catch (e) {}\n }\n }\n return (result.length ? result : typ == 'string' ? obj : obj + '\\0');\n}\n\n//\n// mixkey()\n// Mixes a string seed into a key that is an array of integers, and\n// returns a shortened string seed that is equivalent to the result key.\n//\nfunction mixkey(seed, key) {\n var stringseed = seed + '', smear, j = 0;\n while (j < stringseed.length) {\n key[mask & j] =\n mask & ((smear ^= key[mask & j] * 19) + stringseed.charCodeAt(j++));\n }\n return tostring(key);\n}\n\n//\n// autoseed()\n// Returns an object for autoseeding, using window.crypto and Node crypto\n// module if available.\n//\nfunction autoseed() {\n try {\n var out;\n if (nodecrypto && (out = nodecrypto.randomBytes)) {\n // The use of 'out' to remember randomBytes makes tight minified code.\n out = out(width);\n } else {\n out = new Uint8Array(width);\n (global.crypto || global.msCrypto).getRandomValues(out);\n }\n return tostring(out);\n } catch (e) {\n var browser = global.navigator,\n plugins = browser && browser.plugins;\n return [+new Date, global, plugins, global.screen, tostring(pool)];\n }\n}\n\n//\n// tostring()\n// Converts an array of charcodes to a string\n//\nfunction tostring(a) {\n return String.fromCharCode.apply(0, a);\n}\n\n//\n// When seedrandom.js is loaded, we immediately mix a few bits\n// from the built-in RNG into the entropy pool. Because we do\n// not want to interfere with deterministic PRNG state later,\n// seedrandom will not call math.random on its own again after\n// initialization.\n//\nmixkey(math.random(), pool);\n\n//\n// Nodejs and AMD support: export the implementation as a module using\n// either convention.\n//\nif ((typeof module) == 'object' && module.exports) {\n module.exports = seedrandom;\n // When in node.js, try using crypto package for autoseeding.\n try {\n nodecrypto = require('crypto');\n } catch (ex) {}\n} else if ((typeof define) == 'function' && define.amd) {\n define(function() { return seedrandom; });\n} else {\n // When included as a plain script, set up Math.seedrandom global.\n math['seed' + rngname] = seedrandom;\n}\n\n\n// End anonymous scope, and pass initial values.\n})(\n // global: `self` in browsers (including strict mode and web workers),\n // otherwise `this` in Node and other environments\n (typeof self !== 'undefined') ? self : this,\n [], // pool: entropy pool starts empty\n Math // math: package containing random, pow, and seedrandom\n);\n","function E () {\n // Keep this empty so it's easier to inherit from\n // (via https://github.com/lipsmack from https://github.com/scottcorgan/tiny-emitter/issues/3)\n}\n\nE.prototype = {\n on: function (name, callback, ctx) {\n var e = this.e || (this.e = {});\n\n (e[name] || (e[name] = [])).push({\n fn: callback,\n ctx: ctx\n });\n\n return this;\n },\n\n once: function (name, callback, ctx) {\n var self = this;\n function listener () {\n self.off(name, listener);\n callback.apply(ctx, arguments);\n };\n\n listener._ = callback\n return this.on(name, listener, ctx);\n },\n\n emit: function (name) {\n var data = [].slice.call(arguments, 1);\n var evtArr = ((this.e || (this.e = {}))[name] || []).slice();\n var i = 0;\n var len = evtArr.length;\n\n for (i; i < len; i++) {\n evtArr[i].fn.apply(evtArr[i].ctx, data);\n }\n\n return this;\n },\n\n off: function (name, callback) {\n var e = this.e || (this.e = {});\n var evts = e[name];\n var liveEvents = [];\n\n if (evts && callback) {\n for (var i = 0, len = evts.length; i < len; i++) {\n if (evts[i].fn !== callback && evts[i].fn._ !== callback)\n liveEvents.push(evts[i]);\n }\n }\n\n // Remove event from queue to prevent memory leak\n // Suggested by https://github.com/lazd\n // Ref: https://github.com/scottcorgan/tiny-emitter/commit/c6ebfaa9bc973b33d110a84a307742b7cf94c953#commitcomment-5024910\n\n (liveEvents.length)\n ? e[name] = liveEvents\n : delete e[name];\n\n return this;\n }\n};\n\nmodule.exports = E;\nmodule.exports.TinyEmitter = E;\n","import * as BROWSER from \"detect-browser\";\nimport { getGPUTier, TierResult } from \"detect-gpu\";\n\nconst BROWSER_INF_KEY: string = \"browserInfCache\";\n\nexport const INF_NONE = \"none\";\n\nexport class BrowserInf {\n\n private _gpuTier: TierResult | undefined;\n private _hw_nowarn: boolean | undefined;\n private _name: string = INF_NONE;\n private _os: string = INF_NONE;\n private _version: string = INF_NONE;\n\n constructor() { }\n\n private notPopulated() {\n throw new Error(\"The BrowserInf structure is not populated yet\")\n }\n\n private reset() {\n this._hw_nowarn = undefined;\n }\n\n async detect() {\n const gpuTier = await getGPUTier({\n desktopTiers: [0, 30, 60],\n mobileTiers: [0, 30, 60]\n });\n if (this._gpuTier) {\n if (this._gpuTier.type != gpuTier.type) {\n this.reset();\n this.save();\n }\n }\n this._gpuTier = gpuTier;\n\n const browser = BROWSER.detect();\n if (browser) {\n this._name = browser.name;\n this._os = browser.os ? browser.os : INF_NONE;\n this._version = browser.version ? browser.version : INF_NONE;\n }\n }\n\n private save() {\n localStorage.setItem(BROWSER_INF_KEY, JSON.stringify(this));\n }\n\n load(): boolean {\n const inf = localStorage.getItem(BROWSER_INF_KEY)\n if (inf) {\n Object.assign(this, JSON.parse(inf));\n return true;\n } else {\n return false;\n }\n }\n\n get gpuAdequate() {\n if (this._gpuTier) {\n if (this._gpuTier.type == \"FALLBACK\") return false;\n return this._gpuTier.tier > 1;\n } else {\n this.notPopulated();\n }\n }\n\n set noHWWarning(v: boolean) {\n this._hw_nowarn = v;\n this.save();\n }\n\n get noHWWarning(): boolean {\n return this._hw_nowarn ? this._hw_nowarn : false\n }\n\n get name(): string {\n return this._name;\n }\n\n get os(): string {\n return this._os;\n }\n\n\n get version(): string {\n return this._version;\n }\n\n\n\n}\n\n\n\n\nexport var browserInf: BrowserInf = new BrowserInf;\n$(async function () {\n browserInf.load()\n});","import { browserInf } from \"./frontend/Browser\";\nimport { getCurrentShip, setCurrentShip } from \"./profile/Loadout\";\nimport { getShip, loadResources, querryResources, ResourceQuerryResponse } from \"./resources\";\nimport { $uk } from \"./utils\";\n\n$(async function () {\n\n $(\"[pre-load]\").remove();\n\n\n await loadResources();\n\n setTimeout(async () => {\n await browserInf.detect();\n if (!browserInf.gpuAdequate && !browserInf.noHWWarning) {\n $uk().modal(\"#gpu-modal\").show()\n $(\"#hw-understood\").on(\"click\", function () {\n if ($(\"#hw-neverwarn\").is(\":checked\")) {\n browserInf.noHWWarning = true;\n }\n })\n }\n }, 1000);\n\n const ships = querryResources({ type: \"ship\" });\n const weapons = querryResources({ type: \"weapon\" });\n\n const TABLE_CLASS = \"uk-table uk-table-hover uk-table-middle uk-table-divider uk-table-small\"\n\n const SHIP_STATS_SHOWN = {\n Thrust: (data: any) => data.maxThrust as string,\n Turning: (data: any) => data.maxRps as string,\n Mass: (data: any) => data.mass + \"kg\",\n Health: (data: any) => data.state.health as string\n }\n\n const WEAPON_STATS_SHOWN = {\n [\"Muzzle Velocity\"]: (data: any) => data.muzzle_velocity + \" m/s\",\n [\"Fire Rate\"]: (data: any) => data.rps + \" RPS\",\n [\"Ammunition\"]: (data: any) => data.round_entity_type\n }\n\n let shipSelectionMenuSelection: string = getCurrentShip();\n\n function $ship(name: string | undefined): ResourceQuerryResponse {\n if (name == undefined || name == \"$\") {\n return querryResources({ name: getCurrentShip() })[0]\n } else {\n return querryResources({ name })[0]\n }\n }\n\n\n function getLoadoutIconPath(shipType: string): string {\n return \"assets/loadout_icons/\" + shipType + \".png\";\n }\n\n function createShipSelectHeader(resource: ResourceQuerryResponse) {\n const ship = getShip(resource.entry.name);\n $(\"#loadout-select-headers\").append(\n $(\"
  • \", { class: \"uk-padding-remove uk-box-shadow-hover-large \" })\n .append($(\"\", { class: \"uk-display-block ship-select-header\", href: \"#\" })\n .attr(\"ship\", resource.entry.name)\n .on(\"click\", function () {\n shipSelectionMenuSelection = $(this).attr(\"ship\") as string;\n $(this).addClass(\"uk-active\");\n $(\"#loadout-select-headers\").children(\".uk-active\").removeClass(\"uk-active\")\n })\n .append($(\"\", { class: \"uk-align-center\", src: getLoadoutIconPath(ship.type) }))\n .append($(\"

    \", { class: \"uk-light uk-text-center\" }).text(ship.type))\n .addClass(function (): string {\n return $(this).attr(\"ship\") == getCurrentShip() ? \"uk-active\" : \"\"\n })\n )\n )\n }\n\n function createGenericShipHeader(resource: ResourceQuerryResponse): JQuery {\n const ship = getShip(resource.entry.name);\n return $(\"
    \", { class: \"uk-container\" })\n .append($(\"\", { class: \"uk-align-center\", src: getLoadoutIconPath(ship.type) }))\n // .append($preview(ship.type))\n .append($(\"

    \", { class: \"uk-light uk-text-center\" }).text(ship.type))\n\n }\n\n function $weaponDatapage(resource: ResourceQuerryResponse): JQuery {\n const weapon = resource.resource.content;\n return $(\"
    \").append(\n $(\"

    \", { class: \"uk-light uk-text-center\" }).text(weapon.type)\n ).append(\n $(\"\", { class: TABLE_CLASS }).append(\n $(\"\").append(\n $(\"\").append(\n Object.keys(WEAPON_STATS_SHOWN).map((value, idx) => {\n return $(\"
    \").append(\n [\n $(\"
    \", { class: \"uk-table-expand\" }).text(value),\n $(\"\").text(\n WEAPON_STATS_SHOWN[value as keyof typeof WEAPON_STATS_SHOWN](weapon)\n )\n ]\n )\n })\n )\n )\n )\n )\n }\n\n function $shipDatapage(resource: ResourceQuerryResponse): JQuery {\n const ship = getShip(resource.entry.name);\n\n return $(\"
    \").append(\n $(\"

    \", { class: \"uk-light uk-text-center\" }).text(\"Ship Stats\")\n ).append(\n $(\"\", { class: TABLE_CLASS }).append(\n $(\"\").append(\n $(\"\").append(\n Object.keys(SHIP_STATS_SHOWN).map((value, idx) => {\n return $(\"
    \").append(\n [\n $(\"
    \", { class: \"uk-table-expand\" }).text(value),\n $(\"\").text(\n SHIP_STATS_SHOWN[value as keyof typeof SHIP_STATS_SHOWN](resource.resource.content)\n )\n ]\n )\n })\n )\n )\n )\n ).append(\n (ship.weapons as string[]).map((weapon) => {\n return $weaponDatapage(querryResources({ name: weapon })[0])\n })\n )\n }\n\n\n function createShipSelectDatapage(resource: ResourceQuerryResponse) {\n const ship = getShip(resource.entry.name);\n $(\"#loadout-select-datapages\").append(\n $(\"
  • \")\n .append($(\"
    \").attr(\"ship-datapage\", resource.entry.name))\n )\n }\n\n\n function updateCurrentHeaders() {\n // fill in all ship headers\n\n $(\"[current-ship-header]\")\n .children()\n .remove()\n $(\"[current-ship-header]\")\n .append(\n createGenericShipHeader($ship(\"$\"))\n )\n }\n\n function updateCurrentDatapages() {\n $(\"[ship-datapage='$']\")\n .children()\n .remove()\n $(\"[ship-datapage='$']\")\n .append($shipDatapage($ship(\"$\")))\n }\n\n // fill in selection page\n for (const ship of ships) {\n createShipSelectHeader(ship);\n createShipSelectDatapage(ship);\n }\n\n\n updateCurrentHeaders();\n\n // fill in all datapages\n $(\"[ship-datapage]\").append(\n function (this: HTMLElement): JQuery {\n return $shipDatapage($ship($(this).attr(\"ship-datapage\")))\n }\n );\n\n\n\n // apply functionality to `select` button\n $(\".select-ship\").on(\"click\", () => {\n setCurrentShip(shipSelectionMenuSelection);\n updateCurrentHeaders();\n updateCurrentDatapages();\n })\n\n\n // debug\n\n})\n\n\n\n","import { resourceMap, TYPE_SHIP } from \"../resources\"\n\nexport interface ShipChoice {\n ship: string\n}\n\nexport const DEFAULT_SHIP = \"The Classic\";\nconst CURRENT_SHIP_KEY = \"current_ship\";\n\nexport function getCurrentShip(): string {\n const ship = localStorage.getItem(CURRENT_SHIP_KEY);\n if (ship) {\n return ship;\n } else {\n localStorage.setItem(CURRENT_SHIP_KEY, DEFAULT_SHIP);\n return DEFAULT_SHIP;\n }\n}\n\n\nexport function setCurrentShip(ship: string) {\n localStorage.setItem(CURRENT_SHIP_KEY, ship);\n}\n","/**\n * Resources.ts deals with loading static game resources from the server. The file structure\n * for resources is as follows:\n * e.g: \n * static/\n * |_____resources/\n * | |_________ ...\n * |\n * |_____resourcemap.json \n * \n * The file 'resourcemap.json' is used to inform this loading system how to load resources, and where\n * to find them. The following is an example of how to use the json file (using json comments):\n * {\n * \"skybox\": { // <-- give any name here for the resource for you to keep track of\n * \"name\": \"skybox\", // <-- give the name here you would like to use client side to get this resource\n * \"type\": \"image\", // <-- give one of the constant typestrings that are implimented (image, model, sound, shader, etc...)\n * \"url\": \"skybox.jpg\" // <-- give the relative url to the resource\n * },\n * \n * \"exampleShader\": { // <-- Shaders are slightly different...\n * \"name\": \"exampleShader\",\n * \"type\": \"shader\",\n * \"vert_url\": \"ex_vert.glsl\", // <-- instead of a single url, you need to proide a url to\n * \"frag_url\": \"ex_frag.glsl\" // both the vertex and fragment shaders respectively.\n * }\n * \n * /// See the resourcemap.json file for examples of more types of resources\n * \n * }\n * \n * At the start of the program, @link resourceLoader should be called to fetch all of the resources\n * and organize them in a structure. After this point, you can use @link getModel, @link getTexture, etc...\n * to retrieve these resources (which are already loaded on client side) by their assigned names.\n * \n */\n\nimport { AudioLoader, FileLoader, LoadingManager, Mesh, ShaderMaterial, Texture, TextureLoader, Uniform } from 'three';\nimport { Font, FontLoader } from \"three/examples/jsm/loaders/FontLoader\";\nimport { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader';\nimport { Weapon } from './world/entities/player/Weapon';\n\n/**\n * The Resource class represents any type of static game file loaded from\n * the server like models, textures, shaders, sounds, etc...\n */\nclass Resource {\n /**\n * A string representing what type of resource this is\n */\n typestring: string;\n /**\n * Actual loaded data\n */\n content: any;\n\n /**\n * Construct a new resource object to represent what is loaded from the server\n * @param ts string containing the type of the data\n * @param content the actual loaded data\n */\n constructor(ts: string, content: any) {\n this.typestring = ts;\n this.content = content;\n }\n}\n\n\n/**\n * This is a global dictionary containing everything loaded by the \n * resource manager\n */\nconst globalResourceCache: { [tp: string]: Resource } = {};\n\n/// Constants for typestrings:\n/// (The same strings must be used in static/resourcemap.json)\nexport const TYPE_MODEL: string = \"model\";\nexport const TYPE_IMAGE: string = \"image\";\nexport const TYPE_SOUND: string = \"sound\";\nexport const TYPE_SHADER: string = \"shader\";\nexport const TYPE_SCENE: string = \"scene\";\nexport const TYPE_MAP: string = \"map\";\nexport const TYPE_OBJECT: string = \"object\";\nexport const TYPE_FONT: string = \"font\";\nexport const TYPE_WEAPON: string = \"weapon\";\nexport const TYPE_SHIP: string = \"ship\";\n\n/**\n * This dictionary provides a mapping between different typestrings and their\n * respective loader functions.\n */\nconst loadFunctionMap: { [tp: string]: (map: any) => Promise } = {\n [TYPE_MODEL]: loadModel,\n [TYPE_IMAGE]: loadImage,\n [TYPE_SOUND]: loadSound,\n [TYPE_SHADER]: loadShader,\n [TYPE_MAP]: loadWorld,\n [TYPE_OBJECT]: loadObject,\n [TYPE_FONT]: loadFont,\n [TYPE_WEAPON]: loadWeapon,\n [TYPE_SHIP]: loadShip\n\n} as const;\n\nfunction getterBase(name: string, expected_type: string): T {\n const maybe_value = globalResourceCache[name];\n if (maybe_value) {\n if (maybe_value.typestring != expected_type) {\n throw \"Requested resource '\" + name + \"' is of incorrect type: '\" + maybe_value.typestring + \"'. Expected type: '\" + expected_type + \"'.\";\n }\n } else {\n throw \"Requested resource '\" + name + \"' does not exist in the resource cache, or resource map.\";\n }\n return maybe_value.content as T;\n}\n\nexport function getShip(name: string): any {\n\n return getterBase(name, TYPE_SHIP);\n}\n\nexport function getWeapon(name: string): Weapon {\n return getterBase(name, TYPE_WEAPON);\n}\nexport function getObject(name: string): Mesh {\n return getterBase(name, TYPE_OBJECT);\n}\n/**\n * get a loaded model using its assigned name.\n * See the top of resources.ts for details.\n * @param name Name of the model requested\n * @returns The model's THREE js Group\n */\nexport function getModel(name: string): Mesh {\n return getterBase(name, TYPE_MODEL);\n}\n/**\n * get a loaded texture using its assigned name.\n * See the top of resources.ts for details.\n * @param name Name of the texture requested\n * @returns The THREE js Texture\n */\nexport function getTexture(name: string): Texture {\n return getterBase(name, TYPE_IMAGE);\n}\n/**\n * get a loaded shader using its assigned name.\n * See the top of resources.ts for details\n * @param name name of the shader\n * @returns The THREE js ShaderMaterial\n */\nexport function getShader(name: string): ShaderMaterial {\n return getterBase(name, TYPE_SHADER);\n}\n/**\n * get a loaded sound using its assigned name\n * @param name name of the sound\n * @returns The THREE js AudioBuffer\n */\nexport function getSound(name: string): AudioBuffer {\n return getterBase(name, TYPE_SOUND);\n}\nexport function getFont(name: string): Font {\n return getterBase(name, TYPE_FONT);\n}\n\nexport var resourceMap: { [name: string]: { [prop: string]: string } };\n\n/**\n * Call this function somewhere at entry, because until this is complete \n * no resources will be available and any calls to getModel, getTexture, etc...\n * will result in an error.\n * See the top of resources.ts for details\n * @returns void promise\n */\nexport async function loadResources() {\n\n const map = await fetch(\"/game/player/static/resourcemap.json\", { cache: \"no-cache\" });\n if (!map.ok) {\n throw map.statusText;\n }\n return resourceLoader(await map.text())\n}\n\n\nexport function collectAllMappedResourcesOfType(tp: string): Array {\n if (!resourceMap) return [];\n const out = [];\n for (let n in resourceMap) {\n if (resourceMap[n].type == tp) {\n out.push(resourceMap[n].name);\n }\n }\n return out;\n}\n\n/// Internal resource loading:\n\nfunction resource_path(s: string): string {\n return \"/game/player/static/resources/\" + s;\n}\n\n\nconst FORCE_NO_CACHE = true;\n\nasync function loadImage(map: any) {\n\n const loader = new TextureLoader();\n if (FORCE_NO_CACHE) { loader.requestHeader[\"cache-control\"] = \"no-cache\"; }\n const data = await loader.loadAsync(resource_path(map.url));\n globalResourceCache[map.name] = new Resource(TYPE_IMAGE, data);\n}\n\nasync function loadShip(map: any) {\n const loader = new FileLoader();\n if (FORCE_NO_CACHE) { loader.requestHeader[\"cache-control\"] = \"no-cache\"; }\n const data = await loader.loadAsync(resource_path(map.url));\n globalResourceCache[map.name] = new Resource(TYPE_SHIP, JSON.parse(data as string));\n}\n\nasync function loadWeapon(map: any) {\n const loader = new FileLoader();\n if (FORCE_NO_CACHE) { loader.requestHeader[\"cache-control\"] = \"no-cache\"; }\n const data = await loader.loadAsync(resource_path(map.url));\n globalResourceCache[map.name] = new Resource(TYPE_WEAPON, JSON.parse(data as string) as Weapon);\n}\n\n\nasync function loadModel(map: any) {\n const loader = new GLTFLoader();\n const data = await loader.loadAsync(resource_path(map.url));\n if (FORCE_NO_CACHE) { loader.requestHeader[\"cache-control\"] = \"no-cache\"; }\n globalResourceCache[map.name] = new Resource(TYPE_MODEL, data.scene.children[0]);\n}\n\nasync function loadSound(map: any) {\n const loader = new AudioLoader();\n const data = await loader.loadAsync(resource_path(map.url));\n if (FORCE_NO_CACHE) { loader.requestHeader[\"cache-control\"] = \"no-cache\"; }\n globalResourceCache[map.name] = new Resource(TYPE_SOUND, data);\n}\n\nasync function loadShader(map: any) {\n const loader = new FileLoader();\n if (FORCE_NO_CACHE) { loader.requestHeader[\"cache-control\"] = \"no-cache\"; }\n const vertex = await loader.loadAsync(resource_path(map.vert_url));\n const frag = await loader.loadAsync(resource_path(map.frag_url));\n globalResourceCache[map.name] = new Resource(TYPE_SHADER, new ShaderMaterial(\n { vertexShader: vertex?.toString(), fragmentShader: frag?.toString() }\n ));\n\n}\n\nasync function loadWorld(map: any) {\n const loader = new FileLoader();\n if (FORCE_NO_CACHE) { loader.requestHeader[\"cache-control\"] = \"no-cache\"; }\n const json = await loader.loadAsync(resource_path(map.url));\n globalResourceCache[map.name] = new Resource(TYPE_MAP, JSON.parse(json as string));\n}\n\nasync function loadObject(map: any) {\n const text_loader = new FileLoader();\n if(FORCE_NO_CACHE) { text_loader.requestHeader[\"cache-control\"] = \"no-cache\"; }\n const image_loader = new TextureLoader();\n if(FORCE_NO_CACHE) { image_loader.requestHeader[\"cache-control\"] = \"no-cache\"; }\n const vertex = await text_loader.loadAsync(resource_path(map.vert)) as string;\n const frag = await text_loader.loadAsync(resource_path(map.frag)) as string;\n let uniforms: { [n: string]: Uniform } = {};\n for (const uni in map.uniforms) {\n const uniform = map.uniforms[uni];\n switch (uniform.type) {\n case \"image\":\n const img = await image_loader.loadAsync(resource_path(uniform.value));\n uniforms[uni] = new Uniform(img);\n break;\n case \"number\":\n uniforms[uni] = new Uniform(uniform.value);\n break;\n default:\n console.error(\"Unkown uniform type: \", uniform.type);\n break;\n }\n }\n\n\n const material = new ShaderMaterial({\n fragmentShader: frag,\n vertexShader: vertex,\n uniforms\n });\n\n const model_loader = new GLTFLoader();\n const model = await model_loader.loadAsync(resource_path(map.model));\n const mesh: Mesh = model.scene.children[0] as Mesh;\n mesh.material = material;\n\n globalResourceCache[map.name] = new Resource(TYPE_OBJECT, mesh);\n\n}\n\nasync function loadFont(map: any) {\n const loader = new FontLoader();\n if (FORCE_NO_CACHE) { loader.requestHeader[\"cache-control\"] = \"no-cache\"; }\n const font = await loader.loadAsync(resource_path(map.url));\n globalResourceCache[map.name] = new Resource(TYPE_FONT, font);\n}\n\nasync function load(map: any): Promise {\n return loadFunctionMap[map.type](map)\n}\n\n\nasync function resourceLoader(text: string) {\n let map = JSON.parse(text);\n resourceMap = map;\n if (map) {\n let promises: Array> = new Array>();\n for (let key in map) {\n let name = map[key].name;\n let rt = map[key].type;\n let url = map[key].url;\n promises.push(\n (async () => {\n try {\n return load(map[key])\n } catch {\n console.error(\"Could not load resource: \", map[key]);\n throw \"failed to load resource\";\n }\n })()\n );\n }\n\n await Promise.all(promises);\n\n } else {\n throw \"Could not retrieve resource map from server\"\n }\n}\n\nexport interface ResourceQuerry {\n type?: string,\n name?: string,\n}\n\nexport interface ResourceQuerryResponse {\n resource: Resource,\n entry: any\n}\n\nexport function querryResources(querry: ResourceQuerry): ResourceQuerryResponse[] {\n const output: ResourceQuerryResponse[] = [];\n for (const name in resourceMap) {\n if (\n resourceMap[name].name == querry.name ||\n resourceMap[name].type == querry.type\n ) {\n output.push({ entry: resourceMap[name], resource: globalResourceCache[name] });\n }\n }\n return output;\n}","import { Vector2, Vector3 } from \"three\";\nimport math = require(\"mathjs\");\nimport * as UIkit from \"uikit\";\nimport { abs, random } from \"mathjs\";\nexport class smoothRandom {\n iterations: number[];\n mins: number[];\n maxs: number[];\n min: number;\n max: number;\n volitility: number;\n\n constructor(min: number, max: number, volitility: number, iterations: number) {\n this.iterations = Array(iterations).fill(0);\n this.mins = Array(iterations).fill(0);\n this.maxs = Array(iterations).fill(0);\n this.volitility = volitility;\n this.max = max;\n this.min = min;\n }\n\n\n backTrace() {\n this.mins[this.mins.length - 1] = this.min;\n this.maxs[this.maxs.length - 1] = this.max;\n for (let i = this.iterations.length - 2; i >= 0; i--) {\n this.maxs[i]=this.maxs[i+1]-this.iterations[i+1];\n this.mins[i]=this.mins[i+1]-this.iterations[i+1]\n }\n } \n\n generateNext(){\n this.backTrace();\n\n let baseMin = this.mins[0];\n let baseMax = this.maxs[0];\n let avg = (baseMin+baseMax)/2;\n let dist=baseMax-baseMin\n let absMin;\n let absMax;\n let absMinRange=0;\n if(abs(baseMin) > abs(baseMax)){\n absMax = baseMin;\n absMin = baseMax;\n }else{\n absMax = baseMax;\n absMin = baseMin;\n }\n\n if(absMax*absMin<=0){\n absMinRange=0;\n }else{\n absMinRange=absMin;\n }\n\n\n\n\n\n \n this.iterations[0]=(random(baseMin,baseMax)+absMinRange*this.volitility)/(this.volitility+1);\n\n\n\n for(let i =1; i 3)\n ? param.slice(3)\n : 'any';\n\n var typeNames = types.split('|').map(trim)\n .filter(notEmpty)\n .filter(notIgnore);\n\n var matchingConversions = filterConversions(conversions, typeNames);\n\n var exactTypes = typeNames.map(function (typeName) {\n var type = findTypeByName(typeName);\n\n return {\n name: typeName,\n typeIndex: findTypeIndex(type),\n test: type.test,\n conversion: null,\n conversionIndex: -1\n };\n });\n\n var convertibleTypes = matchingConversions.map(function (conversion) {\n var type = findTypeByName(conversion.from);\n\n return {\n name: conversion.from,\n typeIndex: findTypeIndex(type),\n test: type.test,\n conversion: conversion,\n conversionIndex: conversions.indexOf(conversion)\n };\n });\n\n return {\n types: exactTypes.concat(convertibleTypes),\n restParam: restParam\n };\n }\n\n /**\n * Parse a signature with comma separated parameters,\n * like \"number | boolean, ...string\"\n * @param {string} signature\n * @param {function} fn\n * @param {ConversionDef[]} conversions\n * @return {Signature | null} signature\n */\n function parseSignature (signature, fn, conversions) {\n var params = [];\n\n if (signature.trim() !== '') {\n params = signature\n .split(',')\n .map(trim)\n .map(function (param, index, array) {\n var parsedParam = parseParam(param, conversions);\n\n if (parsedParam.restParam && (index !== array.length - 1)) {\n throw new SyntaxError('Unexpected rest parameter \"' + param + '\": ' +\n 'only allowed for the last parameter');\n }\n\n return parsedParam;\n });\n }\n\n if (params.some(isInvalidParam)) {\n // invalid signature: at least one parameter has no types\n // (they may have been filtered)\n return null;\n }\n\n return {\n params: params,\n fn: fn\n };\n }\n\n /**\n * Test whether a set of params contains a restParam\n * @param {Param[]} params\n * @return {boolean} Returns true when the last parameter is a restParam\n */\n function hasRestParam(params) {\n var param = last(params)\n return param ? param.restParam : false;\n }\n\n /**\n * Test whether a parameter contains conversions\n * @param {Param} param\n * @return {boolean} Returns true when at least one of the parameters\n * contains a conversion.\n */\n function hasConversions(param) {\n return param.types.some(function (type) {\n return type.conversion != null;\n });\n }\n\n /**\n * Create a type test for a single parameter, which can have one or multiple\n * types.\n * @param {Param} param\n * @return {function(x: *) : boolean} Returns a test function\n */\n function compileTest(param) {\n if (!param || param.types.length === 0) {\n // nothing to do\n return ok;\n }\n else if (param.types.length === 1) {\n return findTypeByName(param.types[0].name).test;\n }\n else if (param.types.length === 2) {\n var test0 = findTypeByName(param.types[0].name).test;\n var test1 = findTypeByName(param.types[1].name).test;\n return function or(x) {\n return test0(x) || test1(x);\n }\n }\n else { // param.types.length > 2\n var tests = param.types.map(function (type) {\n return findTypeByName(type.name).test;\n })\n return function or(x) {\n for (var i = 0; i < tests.length; i++) {\n if (tests[i](x)) {\n return true;\n }\n }\n return false;\n }\n }\n }\n\n /**\n * Create a test for all parameters of a signature\n * @param {Param[]} params\n * @return {function(args: Array<*>) : boolean}\n */\n function compileTests(params) {\n var tests, test0, test1;\n\n if (hasRestParam(params)) {\n // variable arguments like '...number'\n tests = initial(params).map(compileTest);\n var varIndex = tests.length;\n var lastTest = compileTest(last(params));\n var testRestParam = function (args) {\n for (var i = varIndex; i < args.length; i++) {\n if (!lastTest(args[i])) {\n return false;\n }\n }\n return true;\n }\n\n return function testArgs(args) {\n for (var i = 0; i < tests.length; i++) {\n if (!tests[i](args[i])) {\n return false;\n }\n }\n return testRestParam(args) && (args.length >= varIndex + 1);\n };\n }\n else {\n // no variable arguments\n if (params.length === 0) {\n return function testArgs(args) {\n return args.length === 0;\n };\n }\n else if (params.length === 1) {\n test0 = compileTest(params[0]);\n return function testArgs(args) {\n return test0(args[0]) && args.length === 1;\n };\n }\n else if (params.length === 2) {\n test0 = compileTest(params[0]);\n test1 = compileTest(params[1]);\n return function testArgs(args) {\n return test0(args[0]) && test1(args[1]) && args.length === 2;\n };\n }\n else { // arguments.length > 2\n tests = params.map(compileTest);\n return function testArgs(args) {\n for (var i = 0; i < tests.length; i++) {\n if (!tests[i](args[i])) {\n return false;\n }\n }\n return args.length === tests.length;\n };\n }\n }\n }\n\n /**\n * Find the parameter at a specific index of a signature.\n * Handles rest parameters.\n * @param {Signature} signature\n * @param {number} index\n * @return {Param | null} Returns the matching parameter when found,\n * null otherwise.\n */\n function getParamAtIndex(signature, index) {\n return index < signature.params.length\n ? signature.params[index]\n : hasRestParam(signature.params)\n ? last(signature.params)\n : null\n }\n\n /**\n * Get all type names of a parameter\n * @param {Signature} signature\n * @param {number} index\n * @param {boolean} excludeConversions\n * @return {string[]} Returns an array with type names\n */\n function getExpectedTypeNames (signature, index, excludeConversions) {\n var param = getParamAtIndex(signature, index);\n var types = param\n ? excludeConversions\n ? param.types.filter(isExactType)\n : param.types\n : [];\n\n return types.map(getTypeName);\n }\n\n /**\n * Returns the name of a type\n * @param {Type} type\n * @return {string} Returns the type name\n */\n function getTypeName(type) {\n return type.name;\n }\n\n /**\n * Test whether a type is an exact type or conversion\n * @param {Type} type\n * @return {boolean} Returns true when\n */\n function isExactType(type) {\n return type.conversion === null || type.conversion === undefined;\n }\n\n /**\n * Helper function for creating error messages: create an array with\n * all available types on a specific argument index.\n * @param {Signature[]} signatures\n * @param {number} index\n * @return {string[]} Returns an array with available types\n */\n function mergeExpectedParams(signatures, index) {\n var typeNames = uniq(flatMap(signatures, function (signature) {\n return getExpectedTypeNames(signature, index, false);\n }));\n\n return (typeNames.indexOf('any') !== -1) ? ['any'] : typeNames;\n }\n\n /**\n * Create\n * @param {string} name The name of the function\n * @param {array.<*>} args The actual arguments passed to the function\n * @param {Signature[]} signatures A list with available signatures\n * @return {TypeError} Returns a type error with additional data\n * attached to it in the property `data`\n */\n function createError(name, args, signatures) {\n var err, expected;\n var _name = name || 'unnamed';\n\n // test for wrong type at some index\n var matchingSignatures = signatures;\n var index;\n for (index = 0; index < args.length; index++) {\n var nextMatchingDefs = matchingSignatures.filter(function (signature) {\n var test = compileTest(getParamAtIndex(signature, index));\n return (index < signature.params.length || hasRestParam(signature.params)) &&\n test(args[index]);\n });\n\n if (nextMatchingDefs.length === 0) {\n // no matching signatures anymore, throw error \"wrong type\"\n expected = mergeExpectedParams(matchingSignatures, index);\n if (expected.length > 0) {\n var actualType = findTypeName(args[index]);\n\n err = new TypeError('Unexpected type of argument in function ' + _name +\n ' (expected: ' + expected.join(' or ') +\n ', actual: ' + actualType + ', index: ' + index + ')');\n err.data = {\n category: 'wrongType',\n fn: _name,\n index: index,\n actual: actualType,\n expected: expected\n }\n return err;\n }\n }\n else {\n matchingSignatures = nextMatchingDefs;\n }\n }\n\n // test for too few arguments\n var lengths = matchingSignatures.map(function (signature) {\n return hasRestParam(signature.params) ? Infinity : signature.params.length;\n });\n if (args.length < Math.min.apply(null, lengths)) {\n expected = mergeExpectedParams(matchingSignatures, index);\n err = new TypeError('Too few arguments in function ' + _name +\n ' (expected: ' + expected.join(' or ') +\n ', index: ' + args.length + ')');\n err.data = {\n category: 'tooFewArgs',\n fn: _name,\n index: args.length,\n expected: expected\n }\n return err;\n }\n\n // test for too many arguments\n var maxLength = Math.max.apply(null, lengths);\n if (args.length > maxLength) {\n err = new TypeError('Too many arguments in function ' + _name +\n ' (expected: ' + maxLength + ', actual: ' + args.length + ')');\n err.data = {\n category: 'tooManyArgs',\n fn: _name,\n index: args.length,\n expectedLength: maxLength\n }\n return err;\n }\n\n err = new TypeError('Arguments of type \"' + args.join(', ') +\n '\" do not match any of the defined signatures of function ' + _name + '.');\n err.data = {\n category: 'mismatch',\n actual: args.map(findTypeName)\n }\n return err;\n }\n\n /**\n * Find the lowest index of all exact types of a parameter (no conversions)\n * @param {Param} param\n * @return {number} Returns the index of the lowest type in typed.types\n */\n function getLowestTypeIndex (param) {\n var min = 999;\n\n for (var i = 0; i < param.types.length; i++) {\n if (isExactType(param.types[i])) {\n min = Math.min(min, param.types[i].typeIndex);\n }\n }\n\n return min;\n }\n\n /**\n * Find the lowest index of the conversion of all types of the parameter\n * having a conversion\n * @param {Param} param\n * @return {number} Returns the lowest index of the conversions of this type\n */\n function getLowestConversionIndex (param) {\n var min = 999;\n\n for (var i = 0; i < param.types.length; i++) {\n if (!isExactType(param.types[i])) {\n min = Math.min(min, param.types[i].conversionIndex);\n }\n }\n\n return min;\n }\n\n /**\n * Compare two params\n * @param {Param} param1\n * @param {Param} param2\n * @return {number} returns a negative number when param1 must get a lower\n * index than param2, a positive number when the opposite,\n * or zero when both are equal\n */\n function compareParams (param1, param2) {\n var c;\n\n // compare having a rest parameter or not\n c = param1.restParam - param2.restParam;\n if (c !== 0) {\n return c;\n }\n\n // compare having conversions or not\n c = hasConversions(param1) - hasConversions(param2);\n if (c !== 0) {\n return c;\n }\n\n // compare the index of the types\n c = getLowestTypeIndex(param1) - getLowestTypeIndex(param2);\n if (c !== 0) {\n return c;\n }\n\n // compare the index of any conversion\n return getLowestConversionIndex(param1) - getLowestConversionIndex(param2);\n }\n\n /**\n * Compare two signatures\n * @param {Signature} signature1\n * @param {Signature} signature2\n * @return {number} returns a negative number when param1 must get a lower\n * index than param2, a positive number when the opposite,\n * or zero when both are equal\n */\n function compareSignatures (signature1, signature2) {\n var len = Math.min(signature1.params.length, signature2.params.length);\n var i;\n var c;\n\n // compare whether the params have conversions at all or not\n c = signature1.params.some(hasConversions) - signature2.params.some(hasConversions)\n if (c !== 0) {\n return c;\n }\n\n // next compare whether the params have conversions one by one\n for (i = 0; i < len; i++) {\n c = hasConversions(signature1.params[i]) - hasConversions(signature2.params[i]);\n if (c !== 0) {\n return c;\n }\n }\n\n // compare the types of the params one by one\n for (i = 0; i < len; i++) {\n c = compareParams(signature1.params[i], signature2.params[i]);\n if (c !== 0) {\n return c;\n }\n }\n\n // compare the number of params\n return signature1.params.length - signature2.params.length;\n }\n\n /**\n * Get params containing all types that can be converted to the defined types.\n *\n * @param {ConversionDef[]} conversions\n * @param {string[]} typeNames\n * @return {ConversionDef[]} Returns the conversions that are available\n * for every type (if any)\n */\n function filterConversions(conversions, typeNames) {\n var matches = {};\n\n conversions.forEach(function (conversion) {\n if (typeNames.indexOf(conversion.from) === -1 &&\n typeNames.indexOf(conversion.to) !== -1 &&\n !matches[conversion.from]) {\n matches[conversion.from] = conversion;\n }\n });\n\n return Object.keys(matches).map(function (from) {\n return matches[from];\n });\n }\n\n /**\n * Preprocess arguments before calling the original function:\n * - if needed convert the parameters\n * - in case of rest parameters, move the rest parameters into an Array\n * @param {Param[]} params\n * @param {function} fn\n * @return {function} Returns a wrapped function\n */\n function compileArgsPreprocessing(params, fn) {\n var fnConvert = fn;\n\n // TODO: can we make this wrapper function smarter/simpler?\n\n if (params.some(hasConversions)) {\n var restParam = hasRestParam(params);\n var compiledConversions = params.map(compileArgConversion)\n\n fnConvert = function convertArgs() {\n var args = [];\n var last = restParam ? arguments.length - 1 : arguments.length;\n for (var i = 0; i < last; i++) {\n args[i] = compiledConversions[i](arguments[i]);\n }\n if (restParam) {\n args[last] = arguments[last].map(compiledConversions[last]);\n }\n\n return fn.apply(this, args);\n }\n }\n\n var fnPreprocess = fnConvert;\n if (hasRestParam(params)) {\n var offset = params.length - 1;\n\n fnPreprocess = function preprocessRestParams () {\n return fnConvert.apply(this,\n slice(arguments, 0, offset).concat([slice(arguments, offset)]));\n }\n }\n\n return fnPreprocess;\n }\n\n /**\n * Compile conversion for a parameter to the right type\n * @param {Param} param\n * @return {function} Returns the wrapped function that will convert arguments\n *\n */\n function compileArgConversion(param) {\n var test0, test1, conversion0, conversion1;\n var tests = [];\n var conversions = [];\n\n param.types.forEach(function (type) {\n if (type.conversion) {\n tests.push(findTypeByName(type.conversion.from).test);\n conversions.push(type.conversion.convert);\n }\n });\n\n // create optimized conversion functions depending on the number of conversions\n switch (conversions.length) {\n case 0:\n return function convertArg(arg) {\n return arg;\n }\n\n case 1:\n test0 = tests[0]\n conversion0 = conversions[0];\n return function convertArg(arg) {\n if (test0(arg)) {\n return conversion0(arg)\n }\n return arg;\n }\n\n case 2:\n test0 = tests[0]\n test1 = tests[1]\n conversion0 = conversions[0];\n conversion1 = conversions[1];\n return function convertArg(arg) {\n if (test0(arg)) {\n return conversion0(arg)\n }\n if (test1(arg)) {\n return conversion1(arg)\n }\n return arg;\n }\n\n default:\n return function convertArg(arg) {\n for (var i = 0; i < conversions.length; i++) {\n if (tests[i](arg)) {\n return conversions[i](arg);\n }\n }\n return arg;\n }\n }\n }\n\n /**\n * Convert an array with signatures into a map with signatures,\n * where signatures with union types are split into separate signatures\n *\n * Throws an error when there are conflicting types\n *\n * @param {Signature[]} signatures\n * @return {Object.} Returns a map with signatures\n * as key and the original function\n * of this signature as value.\n */\n function createSignaturesMap(signatures) {\n var signaturesMap = {};\n signatures.forEach(function (signature) {\n if (!signature.params.some(hasConversions)) {\n splitParams(signature.params, true).forEach(function (params) {\n signaturesMap[stringifyParams(params)] = signature.fn;\n });\n }\n });\n\n return signaturesMap;\n }\n\n /**\n * Split params with union types in to separate params.\n *\n * For example:\n *\n * splitParams([['Array', 'Object'], ['string', 'RegExp'])\n * // returns:\n * // [\n * // ['Array', 'string'],\n * // ['Array', 'RegExp'],\n * // ['Object', 'string'],\n * // ['Object', 'RegExp']\n * // ]\n *\n * @param {Param[]} params\n * @param {boolean} ignoreConversionTypes\n * @return {Param[]}\n */\n function splitParams(params, ignoreConversionTypes) {\n function _splitParams(params, index, types) {\n if (index < params.length) {\n var param = params[index]\n var filteredTypes = ignoreConversionTypes\n ? param.types.filter(isExactType)\n : param.types;\n var typeGroups\n\n if (param.restParam) {\n // split the types of a rest parameter in two:\n // one with only exact types, and one with exact types and conversions\n var exactTypes = filteredTypes.filter(isExactType)\n typeGroups = exactTypes.length < filteredTypes.length\n ? [exactTypes, filteredTypes]\n : [filteredTypes]\n\n }\n else {\n // split all the types of a regular parameter into one type per group\n typeGroups = filteredTypes.map(function (type) {\n return [type]\n })\n }\n\n // recurse over the groups with types\n return flatMap(typeGroups, function (typeGroup) {\n return _splitParams(params, index + 1, types.concat([typeGroup]));\n });\n\n }\n else {\n // we've reached the end of the parameters. Now build a new Param\n var splittedParams = types.map(function (type, typeIndex) {\n return {\n types: type,\n restParam: (typeIndex === params.length - 1) && hasRestParam(params)\n }\n });\n\n return [splittedParams];\n }\n }\n\n return _splitParams(params, 0, []);\n }\n\n /**\n * Test whether two signatures have a conflicting signature\n * @param {Signature} signature1\n * @param {Signature} signature2\n * @return {boolean} Returns true when the signatures conflict, false otherwise.\n */\n function hasConflictingParams(signature1, signature2) {\n var ii = Math.max(signature1.params.length, signature2.params.length);\n\n for (var i = 0; i < ii; i++) {\n var typesNames1 = getExpectedTypeNames(signature1, i, true);\n var typesNames2 = getExpectedTypeNames(signature2, i, true);\n\n if (!hasOverlap(typesNames1, typesNames2)) {\n return false;\n }\n }\n\n var len1 = signature1.params.length;\n var len2 = signature2.params.length;\n var restParam1 = hasRestParam(signature1.params);\n var restParam2 = hasRestParam(signature2.params);\n\n return restParam1\n ? restParam2 ? (len1 === len2) : (len2 >= len1)\n : restParam2 ? (len1 >= len2) : (len1 === len2)\n }\n\n /**\n * Create a typed function\n * @param {String} name The name for the typed function\n * @param {Object.} signaturesMap\n * An object with one or\n * multiple signatures as key, and the\n * function corresponding to the\n * signature as value.\n * @return {function} Returns the created typed function.\n */\n function createTypedFunction(name, signaturesMap) {\n if (Object.keys(signaturesMap).length === 0) {\n throw new SyntaxError('No signatures provided');\n }\n\n // parse the signatures, and check for conflicts\n var parsedSignatures = [];\n Object.keys(signaturesMap)\n .map(function (signature) {\n return parseSignature(signature, signaturesMap[signature], typed.conversions);\n })\n .filter(notNull)\n .forEach(function (parsedSignature) {\n // check whether this parameter conflicts with already parsed signatures\n var conflictingSignature = findInArray(parsedSignatures, function (s) {\n return hasConflictingParams(s, parsedSignature)\n });\n if (conflictingSignature) {\n throw new TypeError('Conflicting signatures \"' +\n stringifyParams(conflictingSignature.params) + '\" and \"' +\n stringifyParams(parsedSignature.params) + '\".');\n }\n\n parsedSignatures.push(parsedSignature);\n });\n\n // split and filter the types of the signatures, and then order them\n var signatures = flatMap(parsedSignatures, function (parsedSignature) {\n var params = parsedSignature ? splitParams(parsedSignature.params, false) : []\n\n return params.map(function (params) {\n return {\n params: params,\n fn: parsedSignature.fn\n };\n });\n }).filter(notNull);\n\n signatures.sort(compareSignatures);\n\n // we create a highly optimized checks for the first couple of signatures with max 2 arguments\n var ok0 = signatures[0] && signatures[0].params.length <= 2 && !hasRestParam(signatures[0].params);\n var ok1 = signatures[1] && signatures[1].params.length <= 2 && !hasRestParam(signatures[1].params);\n var ok2 = signatures[2] && signatures[2].params.length <= 2 && !hasRestParam(signatures[2].params);\n var ok3 = signatures[3] && signatures[3].params.length <= 2 && !hasRestParam(signatures[3].params);\n var ok4 = signatures[4] && signatures[4].params.length <= 2 && !hasRestParam(signatures[4].params);\n var ok5 = signatures[5] && signatures[5].params.length <= 2 && !hasRestParam(signatures[5].params);\n var allOk = ok0 && ok1 && ok2 && ok3 && ok4 && ok5;\n\n // compile the tests\n var tests = signatures.map(function (signature) {\n return compileTests(signature.params);\n });\n\n var test00 = ok0 ? compileTest(signatures[0].params[0]) : notOk;\n var test10 = ok1 ? compileTest(signatures[1].params[0]) : notOk;\n var test20 = ok2 ? compileTest(signatures[2].params[0]) : notOk;\n var test30 = ok3 ? compileTest(signatures[3].params[0]) : notOk;\n var test40 = ok4 ? compileTest(signatures[4].params[0]) : notOk;\n var test50 = ok5 ? compileTest(signatures[5].params[0]) : notOk;\n\n var test01 = ok0 ? compileTest(signatures[0].params[1]) : notOk;\n var test11 = ok1 ? compileTest(signatures[1].params[1]) : notOk;\n var test21 = ok2 ? compileTest(signatures[2].params[1]) : notOk;\n var test31 = ok3 ? compileTest(signatures[3].params[1]) : notOk;\n var test41 = ok4 ? compileTest(signatures[4].params[1]) : notOk;\n var test51 = ok5 ? compileTest(signatures[5].params[1]) : notOk;\n\n // compile the functions\n var fns = signatures.map(function(signature) {\n return compileArgsPreprocessing(signature.params, signature.fn);\n });\n\n var fn0 = ok0 ? fns[0] : undef;\n var fn1 = ok1 ? fns[1] : undef;\n var fn2 = ok2 ? fns[2] : undef;\n var fn3 = ok3 ? fns[3] : undef;\n var fn4 = ok4 ? fns[4] : undef;\n var fn5 = ok5 ? fns[5] : undef;\n\n var len0 = ok0 ? signatures[0].params.length : -1;\n var len1 = ok1 ? signatures[1].params.length : -1;\n var len2 = ok2 ? signatures[2].params.length : -1;\n var len3 = ok3 ? signatures[3].params.length : -1;\n var len4 = ok4 ? signatures[4].params.length : -1;\n var len5 = ok5 ? signatures[5].params.length : -1;\n\n // simple and generic, but also slow\n var iStart = allOk ? 6 : 0;\n var iEnd = signatures.length;\n var generic = function generic() {\n 'use strict';\n\n for (var i = iStart; i < iEnd; i++) {\n if (tests[i](arguments)) {\n return fns[i].apply(this, arguments);\n }\n }\n\n return typed.onMismatch(name, arguments, signatures);\n }\n\n // create the typed function\n // fast, specialized version. Falls back to the slower, generic one if needed\n var fn = function fn(arg0, arg1) {\n 'use strict';\n\n if (arguments.length === len0 && test00(arg0) && test01(arg1)) { return fn0.apply(fn, arguments); }\n if (arguments.length === len1 && test10(arg0) && test11(arg1)) { return fn1.apply(fn, arguments); }\n if (arguments.length === len2 && test20(arg0) && test21(arg1)) { return fn2.apply(fn, arguments); }\n if (arguments.length === len3 && test30(arg0) && test31(arg1)) { return fn3.apply(fn, arguments); }\n if (arguments.length === len4 && test40(arg0) && test41(arg1)) { return fn4.apply(fn, arguments); }\n if (arguments.length === len5 && test50(arg0) && test51(arg1)) { return fn5.apply(fn, arguments); }\n\n return generic.apply(fn, arguments);\n }\n\n // attach name the typed function\n try {\n Object.defineProperty(fn, 'name', {value: name});\n }\n catch (err) {\n // old browsers do not support Object.defineProperty and some don't support setting the name property\n // the function name is not essential for the functioning, it's mostly useful for debugging,\n // so it's fine to have unnamed functions.\n }\n\n // attach signatures to the function\n fn.signatures = createSignaturesMap(signatures);\n\n return fn;\n }\n\n /**\n * Action to take on mismatch\n * @param {string} name Name of function that was attempted to be called\n * @param {Array} args Actual arguments to the call\n * @param {Array} signatures Known signatures of the named typed-function\n */\n function _onMismatch(name, args, signatures) {\n throw createError(name, args, signatures);\n }\n\n /**\n * Test whether a type should be NOT be ignored\n * @param {string} typeName\n * @return {boolean}\n */\n function notIgnore(typeName) {\n return typed.ignore.indexOf(typeName) === -1;\n }\n\n /**\n * trim a string\n * @param {string} str\n * @return {string}\n */\n function trim(str) {\n return str.trim();\n }\n\n /**\n * Test whether a string is not empty\n * @param {string} str\n * @return {boolean}\n */\n function notEmpty(str) {\n return !!str;\n }\n\n /**\n * test whether a value is not strict equal to null\n * @param {*} value\n * @return {boolean}\n */\n function notNull(value) {\n return value !== null;\n }\n\n /**\n * Test whether a parameter has no types defined\n * @param {Param} param\n * @return {boolean}\n */\n function isInvalidParam (param) {\n return param.types.length === 0;\n }\n\n /**\n * Return all but the last items of an array\n * @param {Array} arr\n * @return {Array}\n */\n function initial(arr) {\n return arr.slice(0, arr.length - 1);\n }\n\n /**\n * return the last item of an array\n * @param {Array} arr\n * @return {*}\n */\n function last(arr) {\n return arr[arr.length - 1];\n }\n\n /**\n * Slice an array or function Arguments\n * @param {Array | Arguments | IArguments} arr\n * @param {number} start\n * @param {number} [end]\n * @return {Array}\n */\n function slice(arr, start, end) {\n return Array.prototype.slice.call(arr, start, end);\n }\n\n /**\n * Test whether an array contains some item\n * @param {Array} array\n * @param {*} item\n * @return {boolean} Returns true if array contains item, false if not.\n */\n function contains(array, item) {\n return array.indexOf(item) !== -1;\n }\n\n /**\n * Test whether two arrays have overlapping items\n * @param {Array} array1\n * @param {Array} array2\n * @return {boolean} Returns true when at least one item exists in both arrays\n */\n function hasOverlap(array1, array2) {\n for (var i = 0; i < array1.length; i++) {\n if (contains(array2, array1[i])) {\n return true;\n }\n }\n\n return false;\n }\n\n /**\n * Return the first item from an array for which test(arr[i]) returns true\n * @param {Array} arr\n * @param {function} test\n * @return {* | undefined} Returns the first matching item\n * or undefined when there is no match\n */\n function findInArray(arr, test) {\n for (var i = 0; i < arr.length; i++) {\n if (test(arr[i])) {\n return arr[i];\n }\n }\n return undefined;\n }\n\n /**\n * Filter unique items of an array with strings\n * @param {string[]} arr\n * @return {string[]}\n */\n function uniq(arr) {\n var entries = {}\n for (var i = 0; i < arr.length; i++) {\n entries[arr[i]] = true;\n }\n return Object.keys(entries);\n }\n\n /**\n * Flat map the result invoking a callback for every item in an array.\n * https://gist.github.com/samgiles/762ee337dff48623e729\n * @param {Array} arr\n * @param {function} callback\n * @return {Array}\n */\n function flatMap(arr, callback) {\n return Array.prototype.concat.apply([], arr.map(callback));\n }\n\n /**\n * Retrieve the function name from a set of typed functions,\n * and check whether the name of all functions match (if given)\n * @param {function[]} fns\n */\n function getName (fns) {\n var name = '';\n\n for (var i = 0; i < fns.length; i++) {\n var fn = fns[i];\n\n // check whether the names are the same when defined\n if ((typeof fn.signatures === 'object' || typeof fn.signature === 'string') && fn.name !== '') {\n if (name === '') {\n name = fn.name;\n }\n else if (name !== fn.name) {\n var err = new Error('Function names do not match (expected: ' + name + ', actual: ' + fn.name + ')');\n err.data = {\n actual: fn.name,\n expected: name\n };\n throw err;\n }\n }\n }\n\n return name;\n }\n\n // extract and merge all signatures of a list with typed functions\n function extractSignatures(fns) {\n var err;\n var signaturesMap = {};\n\n function validateUnique(_signature, _fn) {\n if (signaturesMap.hasOwnProperty(_signature) && _fn !== signaturesMap[_signature]) {\n err = new Error('Signature \"' + _signature + '\" is defined twice');\n err.data = {signature: _signature};\n throw err;\n // else: both signatures point to the same function, that's fine\n }\n }\n\n for (var i = 0; i < fns.length; i++) {\n var fn = fns[i];\n\n // test whether this is a typed-function\n if (typeof fn.signatures === 'object') {\n // merge the signatures\n for (var signature in fn.signatures) {\n if (fn.signatures.hasOwnProperty(signature)) {\n validateUnique(signature, fn.signatures[signature]);\n signaturesMap[signature] = fn.signatures[signature];\n }\n }\n }\n else if (typeof fn.signature === 'string') {\n validateUnique(fn.signature, fn);\n signaturesMap[fn.signature] = fn;\n }\n else {\n err = new TypeError('Function is no typed-function (index: ' + i + ')');\n err.data = {index: i};\n throw err;\n }\n }\n\n return signaturesMap;\n }\n\n typed = createTypedFunction('typed', {\n 'string, Object': createTypedFunction,\n 'Object': function (signaturesMap) {\n // find existing name\n var fns = [];\n for (var signature in signaturesMap) {\n if (signaturesMap.hasOwnProperty(signature)) {\n fns.push(signaturesMap[signature]);\n }\n }\n var name = getName(fns);\n return createTypedFunction(name, signaturesMap);\n },\n '...Function': function (fns) {\n return createTypedFunction(getName(fns), extractSignatures(fns));\n },\n 'string, ...Function': function (name, fns) {\n return createTypedFunction(name, extractSignatures(fns));\n }\n });\n\n typed.create = create;\n typed.types = _types;\n typed.conversions = _conversions;\n typed.ignore = _ignore;\n typed.onMismatch = _onMismatch;\n typed.throwMismatchError = _onMismatch;\n typed.createError = createError;\n typed.convert = convert;\n typed.find = find;\n\n /**\n * add a type\n * @param {{name: string, test: function}} type\n * @param {boolean} [beforeObjectTest=true]\n * If true, the new test will be inserted before\n * the test with name 'Object' (if any), since\n * tests for Object match Array and classes too.\n */\n typed.addType = function (type, beforeObjectTest) {\n if (!type || typeof type.name !== 'string' || typeof type.test !== 'function') {\n throw new TypeError('Object with properties {name: string, test: function} expected');\n }\n\n if (beforeObjectTest !== false) {\n for (var i = 0; i < typed.types.length; i++) {\n if (typed.types[i].name === 'Object') {\n typed.types.splice(i, 0, type);\n return\n }\n }\n }\n\n typed.types.push(type);\n };\n\n // add a conversion\n typed.addConversion = function (conversion) {\n if (!conversion\n || typeof conversion.from !== 'string'\n || typeof conversion.to !== 'string'\n || typeof conversion.convert !== 'function') {\n throw new TypeError('Object with properties {from: string, to: string, convert: function} expected');\n }\n\n typed.conversions.push(conversion);\n };\n\n return typed;\n }\n\n return create();\n}));\n","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}\n\nmodule.exports = _arrayLikeToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\n\nmodule.exports = _arrayWithHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\n\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}\n\nmodule.exports = _arrayWithoutHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\nmodule.exports = _classCallCheck, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","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\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\n\nmodule.exports = _createClass, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","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}\n\nmodule.exports = _defineProperty, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _extends() {\n module.exports = _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _extends.apply(this, arguments);\n}\n\nmodule.exports = _extends, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n \"default\": obj\n };\n}\n\nmodule.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\n\nmodule.exports = _iterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_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}\n\nmodule.exports = _iterableToArrayLimit, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","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}\n\nmodule.exports = _nonIterableRest, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","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}\n\nmodule.exports = _nonIterableSpread, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\n\nfunction _regeneratorRuntime() {\n \"use strict\";\n /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */\n\n module.exports = _regeneratorRuntime = function _regeneratorRuntime() {\n return exports;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n var exports = {},\n Op = Object.prototype,\n hasOwn = Op.hasOwnProperty,\n $Symbol = \"function\" == typeof Symbol ? Symbol : {},\n iteratorSymbol = $Symbol.iterator || \"@@iterator\",\n asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\",\n toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n function define(obj, key, value) {\n return Object.defineProperty(obj, key, {\n value: value,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }), obj[key];\n }\n\n try {\n define({}, \"\");\n } catch (err) {\n define = function define(obj, key, value) {\n return obj[key] = value;\n };\n }\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator,\n generator = Object.create(protoGenerator.prototype),\n context = new Context(tryLocsList || []);\n return generator._invoke = function (innerFn, self, context) {\n var state = \"suspendedStart\";\n return function (method, arg) {\n if (\"executing\" === state) throw new Error(\"Generator is already running\");\n\n if (\"completed\" === state) {\n if (\"throw\" === method) throw arg;\n return doneResult();\n }\n\n for (context.method = method, context.arg = arg;;) {\n var delegate = context.delegate;\n\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n\n if (\"next\" === context.method) context.sent = context._sent = context.arg;else if (\"throw\" === context.method) {\n if (\"suspendedStart\" === state) throw state = \"completed\", context.arg;\n context.dispatchException(context.arg);\n } else \"return\" === context.method && context.abrupt(\"return\", context.arg);\n state = \"executing\";\n var record = tryCatch(innerFn, self, context);\n\n if (\"normal\" === record.type) {\n if (state = context.done ? \"completed\" : \"suspendedYield\", record.arg === ContinueSentinel) continue;\n return {\n value: record.arg,\n done: context.done\n };\n }\n\n \"throw\" === record.type && (state = \"completed\", context.method = \"throw\", context.arg = record.arg);\n }\n };\n }(innerFn, self, context), generator;\n }\n\n function tryCatch(fn, obj, arg) {\n try {\n return {\n type: \"normal\",\n arg: fn.call(obj, arg)\n };\n } catch (err) {\n return {\n type: \"throw\",\n arg: err\n };\n }\n }\n\n exports.wrap = wrap;\n var ContinueSentinel = {};\n\n function Generator() {}\n\n function GeneratorFunction() {}\n\n function GeneratorFunctionPrototype() {}\n\n var IteratorPrototype = {};\n define(IteratorPrototype, iteratorSymbol, function () {\n return this;\n });\n var getProto = Object.getPrototypeOf,\n NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype);\n var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype);\n\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 function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n\n if (\"throw\" !== record.type) {\n var result = record.arg,\n value = result.value;\n return value && \"object\" == _typeof(value) && hasOwn.call(value, \"__await\") ? PromiseImpl.resolve(value.__await).then(function (value) {\n invoke(\"next\", value, resolve, reject);\n }, function (err) {\n invoke(\"throw\", err, resolve, reject);\n }) : PromiseImpl.resolve(value).then(function (unwrapped) {\n result.value = unwrapped, resolve(result);\n }, function (error) {\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n\n reject(record.arg);\n }\n\n var previousPromise;\n\n this._invoke = function (method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function (resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n\n return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();\n };\n }\n\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n\n if (undefined === method) {\n if (context.delegate = null, \"throw\" === context.method) {\n if (delegate.iterator[\"return\"] && (context.method = \"return\", context.arg = undefined, maybeInvokeDelegate(delegate, context), \"throw\" === context.method)) return ContinueSentinel;\n context.method = \"throw\", context.arg = new TypeError(\"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 if (\"throw\" === record.type) return context.method = \"throw\", context.arg = record.arg, context.delegate = null, ContinueSentinel;\n var info = record.arg;\n return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, \"return\" !== context.method && (context.method = \"next\", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = \"throw\", context.arg = new TypeError(\"iterator result is not an object\"), context.delegate = null, ContinueSentinel);\n }\n\n function pushTryEntry(locs) {\n var entry = {\n tryLoc: locs[0]\n };\n 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\", delete record.arg, entry.completion = record;\n }\n\n function Context(tryLocsList) {\n this.tryEntries = [{\n tryLoc: \"root\"\n }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0);\n }\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) return iteratorMethod.call(iterable);\n if (\"function\" == typeof iterable.next) return iterable;\n\n if (!isNaN(iterable.length)) {\n var i = -1,\n next = function next() {\n for (; ++i < iterable.length;) {\n if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next;\n }\n\n return next.value = undefined, next.done = !0, next;\n };\n\n return next.next = next;\n }\n }\n\n return {\n next: doneResult\n };\n }\n\n function doneResult() {\n return {\n value: undefined,\n done: !0\n };\n }\n\n return GeneratorFunction.prototype = GeneratorFunctionPrototype, define(Gp, \"constructor\", GeneratorFunctionPrototype), define(GeneratorFunctionPrototype, \"constructor\", GeneratorFunction), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, \"GeneratorFunction\"), exports.isGeneratorFunction = function (genFun) {\n var ctor = \"function\" == typeof genFun && genFun.constructor;\n return !!ctor && (ctor === GeneratorFunction || \"GeneratorFunction\" === (ctor.displayName || ctor.name));\n }, exports.mark = function (genFun) {\n return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, \"GeneratorFunction\")), genFun.prototype = Object.create(Gp), genFun;\n }, exports.awrap = function (arg) {\n return {\n __await: arg\n };\n }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () {\n return this;\n }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n void 0 === PromiseImpl && (PromiseImpl = Promise);\n var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl);\n return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) {\n return result.done ? result.value : iter.next();\n });\n }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, \"Generator\"), define(Gp, iteratorSymbol, function () {\n return this;\n }), define(Gp, \"toString\", function () {\n return \"[object Generator]\";\n }), exports.keys = function (object) {\n var keys = [];\n\n for (var key in object) {\n keys.push(key);\n }\n\n return keys.reverse(), function next() {\n for (; keys.length;) {\n var key = keys.pop();\n if (key in object) return next.value = key, next.done = !1, next;\n }\n\n return next.done = !0, next;\n };\n }, exports.values = values, Context.prototype = {\n constructor: Context,\n reset: function reset(skipTempReset) {\n if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = \"next\", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) {\n \"t\" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined);\n }\n },\n stop: function stop() {\n this.done = !0;\n var rootRecord = this.tryEntries[0].completion;\n if (\"throw\" === rootRecord.type) throw rootRecord.arg;\n return this.rval;\n },\n dispatchException: function dispatchException(exception) {\n if (this.done) throw exception;\n var context = this;\n\n function handle(loc, caught) {\n return record.type = \"throw\", record.arg = exception, context.next = loc, caught && (context.method = \"next\", context.arg = undefined), !!caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i],\n record = entry.completion;\n if (\"root\" === entry.tryLoc) return handle(\"end\");\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\"),\n hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);\n } else {\n if (!hasFinally) throw new Error(\"try statement without catch or finally\");\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n }\n }\n }\n },\n abrupt: function abrupt(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n\n if (entry.tryLoc <= this.prev && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n finallyEntry && (\"break\" === type || \"continue\" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null);\n var record = finallyEntry ? finallyEntry.completion : {};\n return record.type = type, record.arg = arg, finallyEntry ? (this.method = \"next\", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record);\n },\n complete: function complete(record, afterLoc) {\n if (\"throw\" === record.type) throw record.arg;\n return \"break\" === record.type || \"continue\" === record.type ? this.next = record.arg : \"return\" === record.type ? (this.rval = this.arg = record.arg, this.method = \"return\", this.next = \"end\") : \"normal\" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel;\n },\n finish: function finish(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel;\n }\n },\n \"catch\": function _catch(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n\n if (\"throw\" === record.type) {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n\n return thrown;\n }\n }\n\n throw new Error(\"illegal catch attempt\");\n },\n delegateYield: function delegateYield(iterable, resultName, nextLoc) {\n return this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n }, \"next\" === this.method && (this.arg = undefined), ContinueSentinel;\n }\n }, exports;\n}\n\nmodule.exports = _regeneratorRuntime, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayWithHoles = require(\"./arrayWithHoles.js\");\n\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit.js\");\n\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\n\nvar nonIterableRest = require(\"./nonIterableRest.js\");\n\nfunction _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}\n\nmodule.exports = _slicedToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayWithoutHoles = require(\"./arrayWithoutHoles.js\");\n\nvar iterableToArray = require(\"./iterableToArray.js\");\n\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\n\nvar nonIterableSpread = require(\"./nonIterableSpread.js\");\n\nfunction _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}\n\nmodule.exports = _toConsumableArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return (module.exports = _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports), _typeof(obj);\n}\n\nmodule.exports = _typeof, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\n\nfunction _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}\n\nmodule.exports = _unsupportedIterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","// TODO(Babel 8): Remove this file.\n\nvar runtime = require(\"../helpers/regeneratorRuntime\")();\nmodule.exports = runtime;\n\n// Copied from https://github.com/facebook/regenerator/blob/main/packages/runtime/runtime.js#L736=\ntry {\n regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n if (typeof globalThis === \"object\") {\n globalThis.regeneratorRuntime = runtime;\n } else {\n Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n }\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createVersion = exports.createUppercasePi = exports.createUppercaseE = exports.createTrue = exports.createTau = exports.createSQRT2 = exports.createSQRT1_2 = exports.createPi = exports.createPhi = exports.createNull = exports.createNaN = exports.createLOG2E = exports.createLOG10E = exports.createLN2 = exports.createLN10 = exports.createInfinity = exports.createI = exports.createFalse = exports.createE = void 0;\n\nvar _factory = require(\"./utils/factory.js\");\n\nvar _version = require(\"./version.js\");\n\nvar _constants = require(\"./utils/bignumber/constants.js\");\n\nvar _index = require(\"./plain/number/index.js\");\n\nvar createTrue = /* #__PURE__ */(0, _factory.factory)('true', [], function () {\n return true;\n});\nexports.createTrue = createTrue;\nvar createFalse = /* #__PURE__ */(0, _factory.factory)('false', [], function () {\n return false;\n});\nexports.createFalse = createFalse;\nvar createNull = /* #__PURE__ */(0, _factory.factory)('null', [], function () {\n return null;\n});\nexports.createNull = createNull;\nvar createInfinity = /* #__PURE__ */recreateFactory('Infinity', ['config', '?BigNumber'], function (_ref) {\n var config = _ref.config,\n BigNumber = _ref.BigNumber;\n return config.number === 'BigNumber' ? new BigNumber(Infinity) : Infinity;\n});\nexports.createInfinity = createInfinity;\nvar createNaN = /* #__PURE__ */recreateFactory('NaN', ['config', '?BigNumber'], function (_ref2) {\n var config = _ref2.config,\n BigNumber = _ref2.BigNumber;\n return config.number === 'BigNumber' ? new BigNumber(NaN) : NaN;\n});\nexports.createNaN = createNaN;\nvar createPi = /* #__PURE__ */recreateFactory('pi', ['config', '?BigNumber'], function (_ref3) {\n var config = _ref3.config,\n BigNumber = _ref3.BigNumber;\n return config.number === 'BigNumber' ? (0, _constants.createBigNumberPi)(BigNumber) : _index.pi;\n});\nexports.createPi = createPi;\nvar createTau = /* #__PURE__ */recreateFactory('tau', ['config', '?BigNumber'], function (_ref4) {\n var config = _ref4.config,\n BigNumber = _ref4.BigNumber;\n return config.number === 'BigNumber' ? (0, _constants.createBigNumberTau)(BigNumber) : _index.tau;\n});\nexports.createTau = createTau;\nvar createE = /* #__PURE__ */recreateFactory('e', ['config', '?BigNumber'], function (_ref5) {\n var config = _ref5.config,\n BigNumber = _ref5.BigNumber;\n return config.number === 'BigNumber' ? (0, _constants.createBigNumberE)(BigNumber) : _index.e;\n}); // golden ratio, (1+sqrt(5))/2\n\nexports.createE = createE;\nvar createPhi = /* #__PURE__ */recreateFactory('phi', ['config', '?BigNumber'], function (_ref6) {\n var config = _ref6.config,\n BigNumber = _ref6.BigNumber;\n return config.number === 'BigNumber' ? (0, _constants.createBigNumberPhi)(BigNumber) : _index.phi;\n});\nexports.createPhi = createPhi;\nvar createLN2 = /* #__PURE__ */recreateFactory('LN2', ['config', '?BigNumber'], function (_ref7) {\n var config = _ref7.config,\n BigNumber = _ref7.BigNumber;\n return config.number === 'BigNumber' ? new BigNumber(2).ln() : Math.LN2;\n});\nexports.createLN2 = createLN2;\nvar createLN10 = /* #__PURE__ */recreateFactory('LN10', ['config', '?BigNumber'], function (_ref8) {\n var config = _ref8.config,\n BigNumber = _ref8.BigNumber;\n return config.number === 'BigNumber' ? new BigNumber(10).ln() : Math.LN10;\n});\nexports.createLN10 = createLN10;\nvar createLOG2E = /* #__PURE__ */recreateFactory('LOG2E', ['config', '?BigNumber'], function (_ref9) {\n var config = _ref9.config,\n BigNumber = _ref9.BigNumber;\n return config.number === 'BigNumber' ? new BigNumber(1).div(new BigNumber(2).ln()) : Math.LOG2E;\n});\nexports.createLOG2E = createLOG2E;\nvar createLOG10E = /* #__PURE__ */recreateFactory('LOG10E', ['config', '?BigNumber'], function (_ref10) {\n var config = _ref10.config,\n BigNumber = _ref10.BigNumber;\n return config.number === 'BigNumber' ? new BigNumber(1).div(new BigNumber(10).ln()) : Math.LOG10E;\n});\nexports.createLOG10E = createLOG10E;\nvar createSQRT1_2 = /* #__PURE__ */recreateFactory( // eslint-disable-line camelcase\n'SQRT1_2', ['config', '?BigNumber'], function (_ref11) {\n var config = _ref11.config,\n BigNumber = _ref11.BigNumber;\n return config.number === 'BigNumber' ? new BigNumber('0.5').sqrt() : Math.SQRT1_2;\n});\nexports.createSQRT1_2 = createSQRT1_2;\nvar createSQRT2 = /* #__PURE__ */recreateFactory('SQRT2', ['config', '?BigNumber'], function (_ref12) {\n var config = _ref12.config,\n BigNumber = _ref12.BigNumber;\n return config.number === 'BigNumber' ? new BigNumber(2).sqrt() : Math.SQRT2;\n});\nexports.createSQRT2 = createSQRT2;\nvar createI = /* #__PURE__ */recreateFactory('i', ['Complex'], function (_ref13) {\n var Complex = _ref13.Complex;\n return Complex.I;\n}); // for backward compatibility with v5\n\nexports.createI = createI;\nvar createUppercasePi = /* #__PURE__ */(0, _factory.factory)('PI', ['pi'], function (_ref14) {\n var pi = _ref14.pi;\n return pi;\n});\nexports.createUppercasePi = createUppercasePi;\nvar createUppercaseE = /* #__PURE__ */(0, _factory.factory)('E', ['e'], function (_ref15) {\n var e = _ref15.e;\n return e;\n});\nexports.createUppercaseE = createUppercaseE;\nvar createVersion = /* #__PURE__ */(0, _factory.factory)('version', [], function () {\n return _version.version;\n}); // helper function to create a factory with a flag recreateOnConfigChange\n// idea: allow passing optional properties to be attached to the factory function as 4th argument?\n\nexports.createVersion = createVersion;\n\nfunction recreateFactory(name, dependencies, create) {\n return (0, _factory.factory)(name, dependencies, create, {\n recreateOnConfigChange: true\n });\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.DEFAULT_CONFIG = void 0;\nvar DEFAULT_CONFIG = {\n // minimum relative difference between two compared values,\n // used by all comparison functions\n epsilon: 1e-12,\n // type of default matrix output. Choose 'matrix' (default) or 'array'\n matrix: 'Matrix',\n // type of default number output. Choose 'number' (default) 'BigNumber', or 'Fraction\n number: 'number',\n // number of significant digits in BigNumbers\n precision: 64,\n // predictable output type of functions. When true, output type depends only\n // on the input types. When false (default), output type can vary depending\n // on input values. For example `math.sqrt(-4)` returns `complex('2i')` when\n // predictable is false, and returns `NaN` when true.\n predictable: false,\n // random seed for seeded pseudo random number generation\n // null = randomly seed\n randomSeed: null\n};\nexports.DEFAULT_CONFIG = DEFAULT_CONFIG;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _typeof = require(\"@babel/runtime/helpers/typeof\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.create = create;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nrequire(\"./../utils/polyfills.js\");\n\nvar _object = require(\"../utils/object.js\");\n\nvar emitter = _interopRequireWildcard(require(\"./../utils/emitter.js\"));\n\nvar _import = require(\"./function/import.js\");\n\nvar _config = require(\"./function/config.js\");\n\nvar _factory = require(\"../utils/factory.js\");\n\nvar _is = require(\"../utils/is.js\");\n\nvar _ArgumentsError = require(\"../error/ArgumentsError.js\");\n\nvar _DimensionError = require(\"../error/DimensionError.js\");\n\nvar _IndexError = require(\"../error/IndexError.js\");\n\nvar _config2 = require(\"./config.js\");\n\nfunction _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== \"function\") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }\n\nfunction _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\n\n/**\n * Create a mathjs instance from given factory functions and optionally config\n *\n * Usage:\n *\n * const mathjs1 = create({ createAdd, createMultiply, ...})\n * const config = { number: 'BigNumber' }\n * const mathjs2 = create(all, config)\n *\n * @param {Object} [factories] An object with factory functions\n * The object can contain nested objects,\n * all nested objects will be flattened.\n * @param {Object} [config] Available options:\n * {number} epsilon\n * Minimum relative difference between two\n * compared values, used by all comparison functions.\n * {string} matrix\n * A string 'Matrix' (default) or 'Array'.\n * {string} number\n * A string 'number' (default), 'BigNumber', or 'Fraction'\n * {number} precision\n * The number of significant digits for BigNumbers.\n * Not applicable for Numbers.\n * {boolean} predictable\n * Predictable output type of functions. When true,\n * output type depends only on the input types. When\n * false (default), output type can vary depending\n * on input values. For example `math.sqrt(-4)`\n * returns `complex('2i')` when predictable is false, and\n * returns `NaN` when true.\n * {string} randomSeed\n * Random seed for seeded pseudo random number generator.\n * Set to null to randomly seed.\n * @returns {Object} Returns a bare-bone math.js instance containing\n * functions:\n * - `import` to add new functions\n * - `config` to change configuration\n * - `on`, `off`, `once`, `emit` for events\n */\nfunction create(factories, config) {\n var configInternal = (0, _extends2.default)({}, _config2.DEFAULT_CONFIG, config); // simple test for ES5 support\n\n if (typeof Object.create !== 'function') {\n throw new Error('ES5 not supported by this JavaScript engine. ' + 'Please load the es5-shim and es5-sham library for compatibility.');\n } // create the mathjs instance\n\n\n var math = emitter.mixin({\n // only here for backward compatibility for legacy factory functions\n isNumber: _is.isNumber,\n isComplex: _is.isComplex,\n isBigNumber: _is.isBigNumber,\n isFraction: _is.isFraction,\n isUnit: _is.isUnit,\n isString: _is.isString,\n isArray: _is.isArray,\n isMatrix: _is.isMatrix,\n isCollection: _is.isCollection,\n isDenseMatrix: _is.isDenseMatrix,\n isSparseMatrix: _is.isSparseMatrix,\n isRange: _is.isRange,\n isIndex: _is.isIndex,\n isBoolean: _is.isBoolean,\n isResultSet: _is.isResultSet,\n isHelp: _is.isHelp,\n isFunction: _is.isFunction,\n isDate: _is.isDate,\n isRegExp: _is.isRegExp,\n isObject: _is.isObject,\n isNull: _is.isNull,\n isUndefined: _is.isUndefined,\n isAccessorNode: _is.isAccessorNode,\n isArrayNode: _is.isArrayNode,\n isAssignmentNode: _is.isAssignmentNode,\n isBlockNode: _is.isBlockNode,\n isConditionalNode: _is.isConditionalNode,\n isConstantNode: _is.isConstantNode,\n isFunctionAssignmentNode: _is.isFunctionAssignmentNode,\n isFunctionNode: _is.isFunctionNode,\n isIndexNode: _is.isIndexNode,\n isNode: _is.isNode,\n isObjectNode: _is.isObjectNode,\n isOperatorNode: _is.isOperatorNode,\n isParenthesisNode: _is.isParenthesisNode,\n isRangeNode: _is.isRangeNode,\n isSymbolNode: _is.isSymbolNode,\n isChain: _is.isChain\n }); // load config function and apply provided config\n\n math.config = (0, _config.configFactory)(configInternal, math.emit);\n math.expression = {\n transform: {},\n mathWithTransform: {\n config: math.config\n }\n }; // cached factories and instances used by function load\n\n var legacyFactories = [];\n var legacyInstances = [];\n /**\n * Load a function or data type from a factory.\n * If the function or data type already exists, the existing instance is\n * returned.\n * @param {Function} factory\n * @returns {*}\n */\n\n function load(factory) {\n if ((0, _factory.isFactory)(factory)) {\n return factory(math);\n }\n\n var firstProperty = factory[Object.keys(factory)[0]];\n\n if ((0, _factory.isFactory)(firstProperty)) {\n return firstProperty(math);\n }\n\n if (!(0, _object.isLegacyFactory)(factory)) {\n console.warn('Factory object with properties `type`, `name`, and `factory` expected', factory);\n throw new Error('Factory object with properties `type`, `name`, and `factory` expected');\n }\n\n var index = legacyFactories.indexOf(factory);\n var instance;\n\n if (index === -1) {\n // doesn't yet exist\n if (factory.math === true) {\n // pass with math namespace\n instance = factory.factory(math.type, configInternal, load, math.typed, math);\n } else {\n instance = factory.factory(math.type, configInternal, load, math.typed);\n } // append to the cache\n\n\n legacyFactories.push(factory);\n legacyInstances.push(instance);\n } else {\n // already existing function, return the cached instance\n instance = legacyInstances[index];\n }\n\n return instance;\n }\n\n var importedFactories = {}; // load the import function\n\n function lazyTyped() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return math.typed.apply(math.typed, args);\n }\n\n var internalImport = (0, _import.importFactory)(lazyTyped, load, math, importedFactories);\n math.import = internalImport; // listen for changes in config, import all functions again when changed\n // TODO: move this listener into the import function?\n\n math.on('config', function () {\n (0, _object.values)(importedFactories).forEach(function (factory) {\n if (factory && factory.meta && factory.meta.recreateOnConfigChange) {\n // FIXME: only re-create when the current instance is the same as was initially created\n // FIXME: delete the functions/constants before importing them again?\n internalImport(factory, {\n override: true\n });\n }\n });\n }); // the create function exposed on the mathjs instance is bound to\n // the factory functions passed before\n\n math.create = create.bind(null, factories); // export factory function\n\n math.factory = _factory.factory; // import the factory functions like createAdd as an array instead of object,\n // else they will get a different naming (`createAdd` instead of `add`).\n\n math.import((0, _object.values)((0, _object.deepFlatten)(factories)));\n math.ArgumentsError = _ArgumentsError.ArgumentsError;\n math.DimensionError = _DimensionError.DimensionError;\n math.IndexError = _IndexError.IndexError;\n return math;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.NUMBER_OPTIONS = exports.MATRIX_OPTIONS = void 0;\nexports.configFactory = configFactory;\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _config2 = require(\"../config.js\");\n\nvar MATRIX_OPTIONS = ['Matrix', 'Array']; // valid values for option matrix\n\nexports.MATRIX_OPTIONS = MATRIX_OPTIONS;\nvar NUMBER_OPTIONS = ['number', 'BigNumber', 'Fraction']; // valid values for option number\n\nexports.NUMBER_OPTIONS = NUMBER_OPTIONS;\n\nfunction configFactory(config, emit) {\n /**\n * Set configuration options for math.js, and get current options.\n * Will emit a 'config' event, with arguments (curr, prev, changes).\n *\n * This function is only available on a mathjs instance created using `create`.\n *\n * Syntax:\n *\n * math.config(config: Object): Object\n *\n * Examples:\n *\n *\n * import { create, all } from 'mathjs'\n *\n * // create a mathjs instance\n * const math = create(all)\n *\n * math.config().number // outputs 'number'\n * math.evaluate('0.4') // outputs number 0.4\n * math.config({number: 'Fraction'})\n * math.evaluate('0.4') // outputs Fraction 2/5\n *\n * @param {Object} [options] Available options:\n * {number} epsilon\n * Minimum relative difference between two\n * compared values, used by all comparison functions.\n * {string} matrix\n * A string 'Matrix' (default) or 'Array'.\n * {string} number\n * A string 'number' (default), 'BigNumber', or 'Fraction'\n * {number} precision\n * The number of significant digits for BigNumbers.\n * Not applicable for Numbers.\n * {string} parenthesis\n * How to display parentheses in LaTeX and string\n * output.\n * {string} randomSeed\n * Random seed for seeded pseudo random number generator.\n * Set to null to randomly seed.\n * @return {Object} Returns the current configuration\n */\n function _config(options) {\n if (options) {\n var prev = (0, _object.mapObject)(config, _object.clone); // validate some of the options\n\n validateOption(options, 'matrix', MATRIX_OPTIONS);\n validateOption(options, 'number', NUMBER_OPTIONS); // merge options\n\n (0, _object.deepExtend)(config, options);\n var curr = (0, _object.mapObject)(config, _object.clone);\n var changes = (0, _object.mapObject)(options, _object.clone); // emit 'config' event\n\n emit('config', curr, prev, changes);\n return curr;\n } else {\n return (0, _object.mapObject)(config, _object.clone);\n }\n } // attach the valid options to the function so they can be extended\n\n\n _config.MATRIX_OPTIONS = MATRIX_OPTIONS;\n _config.NUMBER_OPTIONS = NUMBER_OPTIONS; // attach the config properties as readonly properties to the config function\n\n Object.keys(_config2.DEFAULT_CONFIG).forEach(function (key) {\n Object.defineProperty(_config, key, {\n get: function get() {\n return config[key];\n },\n enumerable: true,\n configurable: true\n });\n });\n return _config;\n}\n/**\n * Test whether an Array contains a specific item.\n * @param {Array.} array\n * @param {string} item\n * @return {boolean}\n */\n\n\nfunction contains(array, item) {\n return array.indexOf(item) !== -1;\n}\n/**\n * Validate an option\n * @param {Object} options Object with options\n * @param {string} name Name of the option to validate\n * @param {Array.} values Array with valid values for this option\n */\n\n\nfunction validateOption(options, name, values) {\n if (options[name] !== undefined && !contains(values, options[name])) {\n // unknown value\n console.warn('Warning: Unknown value \"' + options[name] + '\" for configuration option \"' + name + '\". ' + 'Available options: ' + values.map(function (value) {\n return JSON.stringify(value);\n }).join(', ') + '.');\n }\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.importFactory = importFactory;\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _ArgumentsError = require(\"../../error/ArgumentsError.js\");\n\nfunction importFactory(typed, load, math, importedFactories) {\n /**\n * Import functions from an object or a module.\n *\n * This function is only available on a mathjs instance created using `create`.\n *\n * Syntax:\n *\n * math.import(functions)\n * math.import(functions, options)\n *\n * Where:\n *\n * - `functions: Object`\n * An object with functions or factories to be imported.\n * - `options: Object` An object with import options. Available options:\n * - `override: boolean`\n * If true, existing functions will be overwritten. False by default.\n * - `silent: boolean`\n * If true, the function will not throw errors on duplicates or invalid\n * types. False by default.\n * - `wrap: boolean`\n * If true, the functions will be wrapped in a wrapper function\n * which converts data types like Matrix to primitive data types like Array.\n * The wrapper is needed when extending math.js with libraries which do not\n * support these data type. False by default.\n *\n * Examples:\n *\n * import { create, all } from 'mathjs'\n * import * as numbers from 'numbers'\n *\n * // create a mathjs instance\n * const math = create(all)\n *\n * // define new functions and variables\n * math.import({\n * myvalue: 42,\n * hello: function (name) {\n * return 'hello, ' + name + '!'\n * }\n * })\n *\n * // use the imported function and variable\n * math.myvalue * 2 // 84\n * math.hello('user') // 'hello, user!'\n *\n * // import the npm module 'numbers'\n * // (must be installed first with `npm install numbers`)\n * math.import(numbers, {wrap: true})\n *\n * math.fibonacci(7) // returns 13\n *\n * @param {Object | Array} functions Object with functions to be imported.\n * @param {Object} [options] Import options.\n */\n function mathImport(functions, options) {\n var num = arguments.length;\n\n if (num !== 1 && num !== 2) {\n throw new _ArgumentsError.ArgumentsError('import', num, 1, 2);\n }\n\n if (!options) {\n options = {};\n }\n\n function flattenImports(flatValues, value, name) {\n if (Array.isArray(value)) {\n value.forEach(function (item) {\n return flattenImports(flatValues, item);\n });\n } else if ((0, _typeof2.default)(value) === 'object') {\n for (var _name in value) {\n if ((0, _object.hasOwnProperty)(value, _name)) {\n flattenImports(flatValues, value[_name], _name);\n }\n }\n } else if ((0, _factory.isFactory)(value) || name !== undefined) {\n var flatName = (0, _factory.isFactory)(value) ? isTransformFunctionFactory(value) ? value.fn + '.transform' // TODO: this is ugly\n : value.fn : name; // we allow importing the same function twice if it points to the same implementation\n\n if ((0, _object.hasOwnProperty)(flatValues, flatName) && flatValues[flatName] !== value && !options.silent) {\n throw new Error('Cannot import \"' + flatName + '\" twice');\n }\n\n flatValues[flatName] = value;\n } else {\n if (!options.silent) {\n throw new TypeError('Factory, Object, or Array expected');\n }\n }\n }\n\n var flatValues = {};\n flattenImports(flatValues, functions);\n\n for (var name in flatValues) {\n if ((0, _object.hasOwnProperty)(flatValues, name)) {\n // console.log('import', name)\n var value = flatValues[name];\n\n if ((0, _factory.isFactory)(value)) {\n // we ignore name here and enforce the name of the factory\n // maybe at some point we do want to allow overriding it\n // in that case we can implement an option overrideFactoryNames: true\n _importFactory(value, options);\n } else if (isSupportedType(value)) {\n _import(name, value, options);\n } else {\n if (!options.silent) {\n throw new TypeError('Factory, Object, or Array expected');\n }\n }\n }\n }\n }\n /**\n * Add a property to the math namespace\n * @param {string} name\n * @param {*} value\n * @param {Object} options See import for a description of the options\n * @private\n */\n\n\n function _import(name, value, options) {\n // TODO: refactor this function, it's to complicated and contains duplicate code\n if (options.wrap && typeof value === 'function') {\n // create a wrapper around the function\n value = _wrap(value);\n } // turn a plain function with a typed-function signature into a typed-function\n\n\n if (hasTypedFunctionSignature(value)) {\n value = typed(name, (0, _defineProperty2.default)({}, value.signature, value));\n }\n\n if (isTypedFunction(math[name]) && isTypedFunction(value)) {\n if (options.override) {\n // give the typed function the right name\n value = typed(name, value.signatures);\n } else {\n // merge the existing and typed function\n value = typed(math[name], value);\n }\n\n math[name] = value;\n delete importedFactories[name];\n\n _importTransform(name, value);\n\n math.emit('import', name, function resolver() {\n return value;\n });\n return;\n }\n\n if (math[name] === undefined || options.override) {\n math[name] = value;\n delete importedFactories[name];\n\n _importTransform(name, value);\n\n math.emit('import', name, function resolver() {\n return value;\n });\n return;\n }\n\n if (!options.silent) {\n throw new Error('Cannot import \"' + name + '\": already exists');\n }\n }\n\n function _importTransform(name, value) {\n if (value && typeof value.transform === 'function') {\n math.expression.transform[name] = value.transform;\n\n if (allowedInExpressions(name)) {\n math.expression.mathWithTransform[name] = value.transform;\n }\n } else {\n // remove existing transform\n delete math.expression.transform[name];\n\n if (allowedInExpressions(name)) {\n math.expression.mathWithTransform[name] = value;\n }\n }\n }\n\n function _deleteTransform(name) {\n delete math.expression.transform[name];\n\n if (allowedInExpressions(name)) {\n math.expression.mathWithTransform[name] = math[name];\n } else {\n delete math.expression.mathWithTransform[name];\n }\n }\n /**\n * Create a wrapper a round an function which converts the arguments\n * to their primitive values (like convert a Matrix to Array)\n * @param {Function} fn\n * @return {Function} Returns the wrapped function\n * @private\n */\n\n\n function _wrap(fn) {\n var wrapper = function wrapper() {\n var args = [];\n\n for (var i = 0, len = arguments.length; i < len; i++) {\n var arg = arguments[i];\n args[i] = arg && arg.valueOf();\n }\n\n return fn.apply(math, args);\n };\n\n if (fn.transform) {\n wrapper.transform = fn.transform;\n }\n\n return wrapper;\n }\n /**\n * Import an instance of a factory into math.js\n * @param {function(scope: object)} factory\n * @param {Object} options See import for a description of the options\n * @param {string} [name=factory.name] Optional custom name\n * @private\n */\n\n\n function _importFactory(factory, options) {\n var name = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : factory.fn;\n\n if ((0, _array.contains)(name, '.')) {\n throw new Error('Factory name should not contain a nested path. ' + 'Name: ' + JSON.stringify(name));\n }\n\n var namespace = isTransformFunctionFactory(factory) ? math.expression.transform : math;\n var existingTransform = (name in math.expression.transform);\n var existing = (0, _object.hasOwnProperty)(namespace, name) ? namespace[name] : undefined;\n\n var resolver = function resolver() {\n // collect all dependencies, handle finding both functions and classes and other special cases\n var dependencies = {};\n factory.dependencies.map(_factory.stripOptionalNotation).forEach(function (dependency) {\n if ((0, _array.contains)(dependency, '.')) {\n throw new Error('Factory dependency should not contain a nested path. ' + 'Name: ' + JSON.stringify(dependency));\n }\n\n if (dependency === 'math') {\n dependencies.math = math;\n } else if (dependency === 'mathWithTransform') {\n dependencies.mathWithTransform = math.expression.mathWithTransform;\n } else if (dependency === 'classes') {\n // special case for json reviver\n dependencies.classes = math;\n } else {\n dependencies[dependency] = math[dependency];\n }\n });\n var instance = /* #__PURE__ */factory(dependencies);\n\n if (instance && typeof instance.transform === 'function') {\n throw new Error('Transforms cannot be attached to factory functions. ' + 'Please create a separate function for it with exports.path=\"expression.transform\"');\n }\n\n if (existing === undefined || options.override) {\n return instance;\n }\n\n if (isTypedFunction(existing) && isTypedFunction(instance)) {\n // merge the existing and new typed function\n return typed(existing, instance);\n }\n\n if (options.silent) {\n // keep existing, ignore imported function\n return existing;\n } else {\n throw new Error('Cannot import \"' + name + '\": already exists');\n }\n }; // TODO: add unit test with non-lazy factory\n\n\n if (!factory.meta || factory.meta.lazy !== false) {\n (0, _object.lazy)(namespace, name, resolver); // FIXME: remove the `if (existing &&` condition again. Can we make sure subset is loaded before subset.transform? (Name collision, and no dependencies between the two)\n\n if (existing && existingTransform) {\n _deleteTransform(name);\n } else {\n if (isTransformFunctionFactory(factory) || factoryAllowedInExpressions(factory)) {\n (0, _object.lazy)(math.expression.mathWithTransform, name, function () {\n return namespace[name];\n });\n }\n }\n } else {\n namespace[name] = resolver(); // FIXME: remove the `if (existing &&` condition again. Can we make sure subset is loaded before subset.transform? (Name collision, and no dependencies between the two)\n\n if (existing && existingTransform) {\n _deleteTransform(name);\n } else {\n if (isTransformFunctionFactory(factory) || factoryAllowedInExpressions(factory)) {\n (0, _object.lazy)(math.expression.mathWithTransform, name, function () {\n return namespace[name];\n });\n }\n }\n } // TODO: improve factories, store a list with imports instead which can be re-played\n\n\n importedFactories[name] = factory;\n math.emit('import', name, resolver);\n }\n /**\n * Check whether given object is a type which can be imported\n * @param {Function | number | string | boolean | null | Unit | Complex} object\n * @return {boolean}\n * @private\n */\n\n\n function isSupportedType(object) {\n return typeof object === 'function' || typeof object === 'number' || typeof object === 'string' || typeof object === 'boolean' || object === null || (0, _is.isUnit)(object) || (0, _is.isComplex)(object) || (0, _is.isBigNumber)(object) || (0, _is.isFraction)(object) || (0, _is.isMatrix)(object) || Array.isArray(object);\n }\n /**\n * Test whether a given thing is a typed-function\n * @param {*} fn\n * @return {boolean} Returns true when `fn` is a typed-function\n */\n\n\n function isTypedFunction(fn) {\n return typeof fn === 'function' && (0, _typeof2.default)(fn.signatures) === 'object';\n }\n\n function hasTypedFunctionSignature(fn) {\n return typeof fn === 'function' && typeof fn.signature === 'string';\n }\n\n function allowedInExpressions(name) {\n return !(0, _object.hasOwnProperty)(unsafe, name);\n }\n\n function factoryAllowedInExpressions(factory) {\n return factory.fn.indexOf('.') === -1 && // FIXME: make checking on path redundant, check on meta data instead\n !(0, _object.hasOwnProperty)(unsafe, factory.fn) && (!factory.meta || !factory.meta.isClass);\n }\n\n function isTransformFunctionFactory(factory) {\n return factory !== undefined && factory.meta !== undefined && factory.meta.isTransformFunction === true || false;\n } // namespaces and functions not available in the parser for safety reasons\n\n\n var unsafe = {\n expression: true,\n type: true,\n docs: true,\n error: true,\n json: true,\n chain: true // chain method not supported. Note that there is a unit chain too.\n\n };\n return mathImport;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createTyped = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _typedFunction = _interopRequireDefault(require(\"typed-function\"));\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _map = require(\"../../utils/map.js\");\n\n/**\n * Create a typed-function which checks the types of the arguments and\n * can match them against multiple provided signatures. The typed-function\n * automatically converts inputs in order to find a matching signature.\n * Typed functions throw informative errors in case of wrong input arguments.\n *\n * See the library [typed-function](https://github.com/josdejong/typed-function)\n * for detailed documentation.\n *\n * Syntax:\n *\n * math.typed(name, signatures) : function\n * math.typed(signatures) : function\n *\n * Examples:\n *\n * // create a typed function with multiple types per argument (type union)\n * const fn2 = typed({\n * 'number | boolean': function (b) {\n * return 'b is a number or boolean'\n * },\n * 'string, number | boolean': function (a, b) {\n * return 'a is a string, b is a number or boolean'\n * }\n * })\n *\n * // create a typed function with an any type argument\n * const log = typed({\n * 'string, any': function (event, data) {\n * console.log('event: ' + event + ', data: ' + JSON.stringify(data))\n * }\n * })\n *\n * @param {string} [name] Optional name for the typed-function\n * @param {Object} signatures Object with one or multiple function signatures\n * @returns {function} The created typed-function.\n */\n// returns a new instance of typed-function\nvar _createTyped2 = function _createTyped() {\n // initially, return the original instance of typed-function\n // consecutively, return a new instance from typed.create.\n _createTyped2 = _typedFunction.default.create;\n return _typedFunction.default;\n};\n\nvar dependencies = ['?BigNumber', '?Complex', '?DenseMatrix', '?Fraction'];\n/**\n * Factory function for creating a new typed instance\n * @param {Object} dependencies Object with data types like Complex and BigNumber\n * @returns {Function}\n */\n\nvar createTyped = /* #__PURE__ */(0, _factory.factory)('typed', dependencies, function createTyped(_ref) {\n var BigNumber = _ref.BigNumber,\n Complex = _ref.Complex,\n DenseMatrix = _ref.DenseMatrix,\n Fraction = _ref.Fraction;\n\n // TODO: typed-function must be able to silently ignore signatures with unknown data types\n // get a new instance of typed-function\n var typed = _createTyped2(); // define all types. The order of the types determines in which order function\n // arguments are type-checked (so for performance it's important to put the\n // most used types first).\n\n\n typed.types = [{\n name: 'number',\n test: _is.isNumber\n }, {\n name: 'Complex',\n test: _is.isComplex\n }, {\n name: 'BigNumber',\n test: _is.isBigNumber\n }, {\n name: 'Fraction',\n test: _is.isFraction\n }, {\n name: 'Unit',\n test: _is.isUnit\n }, {\n name: 'string',\n test: _is.isString\n }, {\n name: 'Chain',\n test: _is.isChain\n }, {\n name: 'Array',\n test: _is.isArray\n }, {\n name: 'Matrix',\n test: _is.isMatrix\n }, {\n name: 'DenseMatrix',\n test: _is.isDenseMatrix\n }, {\n name: 'SparseMatrix',\n test: _is.isSparseMatrix\n }, {\n name: 'Range',\n test: _is.isRange\n }, {\n name: 'Index',\n test: _is.isIndex\n }, {\n name: 'boolean',\n test: _is.isBoolean\n }, {\n name: 'ResultSet',\n test: _is.isResultSet\n }, {\n name: 'Help',\n test: _is.isHelp\n }, {\n name: 'function',\n test: _is.isFunction\n }, {\n name: 'Date',\n test: _is.isDate\n }, {\n name: 'RegExp',\n test: _is.isRegExp\n }, {\n name: 'null',\n test: _is.isNull\n }, {\n name: 'undefined',\n test: _is.isUndefined\n }, {\n name: 'AccessorNode',\n test: _is.isAccessorNode\n }, {\n name: 'ArrayNode',\n test: _is.isArrayNode\n }, {\n name: 'AssignmentNode',\n test: _is.isAssignmentNode\n }, {\n name: 'BlockNode',\n test: _is.isBlockNode\n }, {\n name: 'ConditionalNode',\n test: _is.isConditionalNode\n }, {\n name: 'ConstantNode',\n test: _is.isConstantNode\n }, {\n name: 'FunctionNode',\n test: _is.isFunctionNode\n }, {\n name: 'FunctionAssignmentNode',\n test: _is.isFunctionAssignmentNode\n }, {\n name: 'IndexNode',\n test: _is.isIndexNode\n }, {\n name: 'Node',\n test: _is.isNode\n }, {\n name: 'ObjectNode',\n test: _is.isObjectNode\n }, {\n name: 'OperatorNode',\n test: _is.isOperatorNode\n }, {\n name: 'ParenthesisNode',\n test: _is.isParenthesisNode\n }, {\n name: 'RangeNode',\n test: _is.isRangeNode\n }, {\n name: 'SymbolNode',\n test: _is.isSymbolNode\n }, {\n name: 'Map',\n test: _map.isMap\n }, {\n name: 'Object',\n test: _is.isObject\n } // order 'Object' last, it matches on other classes too\n ];\n typed.conversions = [{\n from: 'number',\n to: 'BigNumber',\n convert: function convert(x) {\n if (!BigNumber) {\n throwNoBignumber(x);\n } // note: conversion from number to BigNumber can fail if x has >15 digits\n\n\n if ((0, _number.digits)(x) > 15) {\n throw new TypeError('Cannot implicitly convert a number with >15 significant digits to BigNumber ' + '(value: ' + x + '). ' + 'Use function bignumber(x) to convert to BigNumber.');\n }\n\n return new BigNumber(x);\n }\n }, {\n from: 'number',\n to: 'Complex',\n convert: function convert(x) {\n if (!Complex) {\n throwNoComplex(x);\n }\n\n return new Complex(x, 0);\n }\n }, {\n from: 'number',\n to: 'string',\n convert: function convert(x) {\n return x + '';\n }\n }, {\n from: 'BigNumber',\n to: 'Complex',\n convert: function convert(x) {\n if (!Complex) {\n throwNoComplex(x);\n }\n\n return new Complex(x.toNumber(), 0);\n }\n }, {\n from: 'Fraction',\n to: 'BigNumber',\n convert: function convert(x) {\n throw new TypeError('Cannot implicitly convert a Fraction to BigNumber or vice versa. ' + 'Use function bignumber(x) to convert to BigNumber or fraction(x) to convert to Fraction.');\n }\n }, {\n from: 'Fraction',\n to: 'Complex',\n convert: function convert(x) {\n if (!Complex) {\n throwNoComplex(x);\n }\n\n return new Complex(x.valueOf(), 0);\n }\n }, {\n from: 'number',\n to: 'Fraction',\n convert: function convert(x) {\n if (!Fraction) {\n throwNoFraction(x);\n }\n\n var f = new Fraction(x);\n\n if (f.valueOf() !== x) {\n throw new TypeError('Cannot implicitly convert a number to a Fraction when there will be a loss of precision ' + '(value: ' + x + '). ' + 'Use function fraction(x) to convert to Fraction.');\n }\n\n return f;\n }\n }, {\n // FIXME: add conversion from Fraction to number, for example for `sqrt(fraction(1,3))`\n // from: 'Fraction',\n // to: 'number',\n // convert: function (x) {\n // return x.valueOf()\n // }\n // }, {\n from: 'string',\n to: 'number',\n convert: function convert(x) {\n var n = Number(x);\n\n if (isNaN(n)) {\n throw new Error('Cannot convert \"' + x + '\" to a number');\n }\n\n return n;\n }\n }, {\n from: 'string',\n to: 'BigNumber',\n convert: function convert(x) {\n if (!BigNumber) {\n throwNoBignumber(x);\n }\n\n try {\n return new BigNumber(x);\n } catch (err) {\n throw new Error('Cannot convert \"' + x + '\" to BigNumber');\n }\n }\n }, {\n from: 'string',\n to: 'Fraction',\n convert: function convert(x) {\n if (!Fraction) {\n throwNoFraction(x);\n }\n\n try {\n return new Fraction(x);\n } catch (err) {\n throw new Error('Cannot convert \"' + x + '\" to Fraction');\n }\n }\n }, {\n from: 'string',\n to: 'Complex',\n convert: function convert(x) {\n if (!Complex) {\n throwNoComplex(x);\n }\n\n try {\n return new Complex(x);\n } catch (err) {\n throw new Error('Cannot convert \"' + x + '\" to Complex');\n }\n }\n }, {\n from: 'boolean',\n to: 'number',\n convert: function convert(x) {\n return +x;\n }\n }, {\n from: 'boolean',\n to: 'BigNumber',\n convert: function convert(x) {\n if (!BigNumber) {\n throwNoBignumber(x);\n }\n\n return new BigNumber(+x);\n }\n }, {\n from: 'boolean',\n to: 'Fraction',\n convert: function convert(x) {\n if (!Fraction) {\n throwNoFraction(x);\n }\n\n return new Fraction(+x);\n }\n }, {\n from: 'boolean',\n to: 'string',\n convert: function convert(x) {\n return String(x);\n }\n }, {\n from: 'Array',\n to: 'Matrix',\n convert: function convert(array) {\n if (!DenseMatrix) {\n throwNoMatrix();\n }\n\n return new DenseMatrix(array);\n }\n }, {\n from: 'Matrix',\n to: 'Array',\n convert: function convert(matrix) {\n return matrix.valueOf();\n }\n }];\n return typed;\n});\nexports.createTyped = createTyped;\n\nfunction throwNoBignumber(x) {\n throw new Error(\"Cannot convert value \".concat(x, \" into a BigNumber: no class 'BigNumber' provided\"));\n}\n\nfunction throwNoComplex(x) {\n throw new Error(\"Cannot convert value \".concat(x, \" into a Complex number: no class 'Complex' provided\"));\n}\n\nfunction throwNoMatrix() {\n throw new Error('Cannot convert array into a Matrix: no class \\'DenseMatrix\\' provided');\n}\n\nfunction throwNoFraction(x) {\n throw new Error(\"Cannot convert value \".concat(x, \" into a Fraction, no class 'Fraction' provided.\"));\n}","\"use strict\";\n\nvar _typeof = require(\"@babel/runtime/helpers/typeof\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.all = void 0;\n\nvar allFactories = _interopRequireWildcard(require(\"../factoriesAny.js\"));\n\nfunction _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== \"function\") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }\n\nfunction _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\n\n// creating all factories here in a separate file is needed to get tree-shaking working\nvar all = allFactories;\nexports.all = all;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.config = void 0;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _config = require(\"../core/config.js\");\n\nvar _config2 = require(\"../core/function/config.js\");\n\n// create a read-only version of config\nvar config = /* #__PURE__ */function config(options) {\n if (options) {\n throw new Error('The global config is readonly. \\n' + 'Please create a mathjs instance if you want to change the default configuration. \\n' + 'Example:\\n' + '\\n' + ' import { create, all } from \\'mathjs\\';\\n' + ' const mathjs = create(all);\\n' + ' mathjs.config({ number: \\'BigNumber\\' });\\n');\n }\n\n return Object.freeze(_config.DEFAULT_CONFIG);\n};\n\nexports.config = config;\n(0, _extends2.default)(config, _config.DEFAULT_CONFIG, {\n MATRIX_OPTIONS: _config2.MATRIX_OPTIONS,\n NUMBER_OPTIONS: _config2.NUMBER_OPTIONS\n});","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"AccessorNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAccessorNodeGenerated.AccessorNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"ArrayNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesArrayNodeGenerated.ArrayNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"AssignmentNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAssignmentNodeGenerated.AssignmentNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"BigNumberDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBigNumberClassGenerated.BigNumberDependencies;\n }\n});\nObject.defineProperty(exports, \"BlockNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBlockNodeGenerated.BlockNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"ChainDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesChainClassGenerated.ChainDependencies;\n }\n});\nObject.defineProperty(exports, \"ComplexDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesComplexClassGenerated.ComplexDependencies;\n }\n});\nObject.defineProperty(exports, \"ConditionalNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesConditionalNodeGenerated.ConditionalNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"ConstantNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesConstantNodeGenerated.ConstantNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"DenseMatrixDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies;\n }\n});\nObject.defineProperty(exports, \"EDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesUppercaseEGenerated.EDependencies;\n }\n});\nObject.defineProperty(exports, \"FibonacciHeapDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFibonacciHeapClassGenerated.FibonacciHeapDependencies;\n }\n});\nObject.defineProperty(exports, \"FractionDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFractionClassGenerated.FractionDependencies;\n }\n});\nObject.defineProperty(exports, \"FunctionAssignmentNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFunctionAssignmentNodeGenerated.FunctionAssignmentNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"FunctionNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFunctionNodeGenerated.FunctionNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"HelpDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesHelpClassGenerated.HelpDependencies;\n }\n});\nObject.defineProperty(exports, \"ImmutableDenseMatrixDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesImmutableDenseMatrixClassGenerated.ImmutableDenseMatrixDependencies;\n }\n});\nObject.defineProperty(exports, \"IndexDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIndexClassGenerated.IndexDependencies;\n }\n});\nObject.defineProperty(exports, \"IndexNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIndexNodeGenerated.IndexNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"InfinityDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesInfinityGenerated.InfinityDependencies;\n }\n});\nObject.defineProperty(exports, \"LN10Dependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLN10Generated.LN10Dependencies;\n }\n});\nObject.defineProperty(exports, \"LN2Dependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLN2Generated.LN2Dependencies;\n }\n});\nObject.defineProperty(exports, \"LOG10EDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLOG10EGenerated.LOG10EDependencies;\n }\n});\nObject.defineProperty(exports, \"LOG2EDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLOG2EGenerated.LOG2EDependencies;\n }\n});\nObject.defineProperty(exports, \"MatrixDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMatrixClassGenerated.MatrixDependencies;\n }\n});\nObject.defineProperty(exports, \"NaNDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesNaNGenerated.NaNDependencies;\n }\n});\nObject.defineProperty(exports, \"NodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesNodeGenerated.NodeDependencies;\n }\n});\nObject.defineProperty(exports, \"ObjectNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesObjectNodeGenerated.ObjectNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"OperatorNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesOperatorNodeGenerated.OperatorNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"PIDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesUppercasePiGenerated.PIDependencies;\n }\n});\nObject.defineProperty(exports, \"ParenthesisNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"ParserDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesParserClassGenerated.ParserDependencies;\n }\n});\nObject.defineProperty(exports, \"RangeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRangeClassGenerated.RangeDependencies;\n }\n});\nObject.defineProperty(exports, \"RangeNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRangeNodeGenerated.RangeNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"RelationalNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRelationalNodeGenerated.RelationalNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"ResultSetDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesResultSetGenerated.ResultSetDependencies;\n }\n});\nObject.defineProperty(exports, \"SQRT1_2Dependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSQRT1_2Generated.SQRT1_2Dependencies;\n }\n});\nObject.defineProperty(exports, \"SQRT2Dependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSQRT2Generated.SQRT2Dependencies;\n }\n});\nObject.defineProperty(exports, \"SpaDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSpaClassGenerated.SpaDependencies;\n }\n});\nObject.defineProperty(exports, \"SparseMatrixDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies;\n }\n});\nObject.defineProperty(exports, \"SymbolNodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSymbolNodeGenerated.SymbolNodeDependencies;\n }\n});\nObject.defineProperty(exports, \"UnitDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesUnitClassGenerated.UnitDependencies;\n }\n});\nObject.defineProperty(exports, \"absDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAbsGenerated.absDependencies;\n }\n});\nObject.defineProperty(exports, \"acosDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAcosGenerated.acosDependencies;\n }\n});\nObject.defineProperty(exports, \"acoshDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAcoshGenerated.acoshDependencies;\n }\n});\nObject.defineProperty(exports, \"acotDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAcotGenerated.acotDependencies;\n }\n});\nObject.defineProperty(exports, \"acothDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAcothGenerated.acothDependencies;\n }\n});\nObject.defineProperty(exports, \"acscDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAcscGenerated.acscDependencies;\n }\n});\nObject.defineProperty(exports, \"acschDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAcschGenerated.acschDependencies;\n }\n});\nObject.defineProperty(exports, \"addDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAddGenerated.addDependencies;\n }\n});\nObject.defineProperty(exports, \"addScalarDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAddScalarGenerated.addScalarDependencies;\n }\n});\nObject.defineProperty(exports, \"all\", {\n enumerable: true,\n get: function get() {\n return _allFactoriesAny.all;\n }\n});\nObject.defineProperty(exports, \"andDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAndGenerated.andDependencies;\n }\n});\nObject.defineProperty(exports, \"applyDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesApplyGenerated.applyDependencies;\n }\n});\nObject.defineProperty(exports, \"applyTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesApplyTransformGenerated.applyTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"argDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesArgGenerated.argDependencies;\n }\n});\nObject.defineProperty(exports, \"asecDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAsecGenerated.asecDependencies;\n }\n});\nObject.defineProperty(exports, \"asechDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAsechGenerated.asechDependencies;\n }\n});\nObject.defineProperty(exports, \"asinDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAsinGenerated.asinDependencies;\n }\n});\nObject.defineProperty(exports, \"asinhDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAsinhGenerated.asinhDependencies;\n }\n});\nObject.defineProperty(exports, \"atan2Dependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAtan2Generated.atan2Dependencies;\n }\n});\nObject.defineProperty(exports, \"atanDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAtanGenerated.atanDependencies;\n }\n});\nObject.defineProperty(exports, \"atanhDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAtanhGenerated.atanhDependencies;\n }\n});\nObject.defineProperty(exports, \"atomicMassDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAtomicMassGenerated.atomicMassDependencies;\n }\n});\nObject.defineProperty(exports, \"avogadroDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesAvogadroGenerated.avogadroDependencies;\n }\n});\nObject.defineProperty(exports, \"bellNumbersDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBellNumbersGenerated.bellNumbersDependencies;\n }\n});\nObject.defineProperty(exports, \"bignumberDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBignumberGenerated.bignumberDependencies;\n }\n});\nObject.defineProperty(exports, \"binDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBinGenerated.binDependencies;\n }\n});\nObject.defineProperty(exports, \"bitAndDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBitAndGenerated.bitAndDependencies;\n }\n});\nObject.defineProperty(exports, \"bitNotDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBitNotGenerated.bitNotDependencies;\n }\n});\nObject.defineProperty(exports, \"bitOrDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBitOrGenerated.bitOrDependencies;\n }\n});\nObject.defineProperty(exports, \"bitXorDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBitXorGenerated.bitXorDependencies;\n }\n});\nObject.defineProperty(exports, \"bohrMagnetonDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBohrMagnetonGenerated.bohrMagnetonDependencies;\n }\n});\nObject.defineProperty(exports, \"bohrRadiusDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBohrRadiusGenerated.bohrRadiusDependencies;\n }\n});\nObject.defineProperty(exports, \"boltzmannDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBoltzmannGenerated.boltzmannDependencies;\n }\n});\nObject.defineProperty(exports, \"booleanDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesBooleanGenerated.booleanDependencies;\n }\n});\nObject.defineProperty(exports, \"catalanDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCatalanGenerated.catalanDependencies;\n }\n});\nObject.defineProperty(exports, \"cbrtDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCbrtGenerated.cbrtDependencies;\n }\n});\nObject.defineProperty(exports, \"ceilDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCeilGenerated.ceilDependencies;\n }\n});\nObject.defineProperty(exports, \"chainDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesChainGenerated.chainDependencies;\n }\n});\nObject.defineProperty(exports, \"classicalElectronRadiusDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesClassicalElectronRadiusGenerated.classicalElectronRadiusDependencies;\n }\n});\nObject.defineProperty(exports, \"cloneDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCloneGenerated.cloneDependencies;\n }\n});\nObject.defineProperty(exports, \"columnDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesColumnGenerated.columnDependencies;\n }\n});\nObject.defineProperty(exports, \"columnTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesColumnTransformGenerated.columnTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"combinationsDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCombinationsGenerated.combinationsDependencies;\n }\n});\nObject.defineProperty(exports, \"combinationsWithRepDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCombinationsWithRepGenerated.combinationsWithRepDependencies;\n }\n});\nObject.defineProperty(exports, \"compareDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCompareGenerated.compareDependencies;\n }\n});\nObject.defineProperty(exports, \"compareNaturalDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCompareNaturalGenerated.compareNaturalDependencies;\n }\n});\nObject.defineProperty(exports, \"compareTextDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCompareTextGenerated.compareTextDependencies;\n }\n});\nObject.defineProperty(exports, \"compileDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCompileGenerated.compileDependencies;\n }\n});\nObject.defineProperty(exports, \"complexDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesComplexGenerated.complexDependencies;\n }\n});\nObject.defineProperty(exports, \"compositionDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCompositionGenerated.compositionDependencies;\n }\n});\nObject.defineProperty(exports, \"concatDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesConcatGenerated.concatDependencies;\n }\n});\nObject.defineProperty(exports, \"concatTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesConcatTransformGenerated.concatTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"conductanceQuantumDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesConductanceQuantumGenerated.conductanceQuantumDependencies;\n }\n});\nObject.defineProperty(exports, \"conjDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesConjGenerated.conjDependencies;\n }\n});\nObject.defineProperty(exports, \"cosDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCosGenerated.cosDependencies;\n }\n});\nObject.defineProperty(exports, \"coshDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCoshGenerated.coshDependencies;\n }\n});\nObject.defineProperty(exports, \"cotDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCotGenerated.cotDependencies;\n }\n});\nObject.defineProperty(exports, \"cothDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCothGenerated.cothDependencies;\n }\n});\nObject.defineProperty(exports, \"coulombDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCoulombGenerated.coulombDependencies;\n }\n});\nObject.defineProperty(exports, \"countDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCountGenerated.countDependencies;\n }\n});\nObject.defineProperty(exports, \"createUnitDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCreateUnitGenerated.createUnitDependencies;\n }\n});\nObject.defineProperty(exports, \"crossDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCrossGenerated.crossDependencies;\n }\n});\nObject.defineProperty(exports, \"cscDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCscGenerated.cscDependencies;\n }\n});\nObject.defineProperty(exports, \"cschDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCschGenerated.cschDependencies;\n }\n});\nObject.defineProperty(exports, \"ctransposeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCtransposeGenerated.ctransposeDependencies;\n }\n});\nObject.defineProperty(exports, \"cubeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCubeGenerated.cubeDependencies;\n }\n});\nObject.defineProperty(exports, \"cumsumDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCumSumGenerated.cumsumDependencies;\n }\n});\nObject.defineProperty(exports, \"cumsumTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesCumSumTransformGenerated.cumsumTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"deepEqualDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDeepEqualGenerated.deepEqualDependencies;\n }\n});\nObject.defineProperty(exports, \"derivativeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDerivativeGenerated.derivativeDependencies;\n }\n});\nObject.defineProperty(exports, \"detDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDetGenerated.detDependencies;\n }\n});\nObject.defineProperty(exports, \"deuteronMassDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDeuteronMassGenerated.deuteronMassDependencies;\n }\n});\nObject.defineProperty(exports, \"diagDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDiagGenerated.diagDependencies;\n }\n});\nObject.defineProperty(exports, \"diffDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDiffGenerated.diffDependencies;\n }\n});\nObject.defineProperty(exports, \"diffTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDiffTransformGenerated.diffTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"distanceDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDistanceGenerated.distanceDependencies;\n }\n});\nObject.defineProperty(exports, \"divideDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDivideGenerated.divideDependencies;\n }\n});\nObject.defineProperty(exports, \"divideScalarDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDivideScalarGenerated.divideScalarDependencies;\n }\n});\nObject.defineProperty(exports, \"dotDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDotGenerated.dotDependencies;\n }\n});\nObject.defineProperty(exports, \"dotDivideDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDotDivideGenerated.dotDivideDependencies;\n }\n});\nObject.defineProperty(exports, \"dotMultiplyDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDotMultiplyGenerated.dotMultiplyDependencies;\n }\n});\nObject.defineProperty(exports, \"dotPowDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesDotPowGenerated.dotPowDependencies;\n }\n});\nObject.defineProperty(exports, \"eDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesEGenerated.eDependencies;\n }\n});\nObject.defineProperty(exports, \"efimovFactorDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesEfimovFactorGenerated.efimovFactorDependencies;\n }\n});\nObject.defineProperty(exports, \"eigsDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesEigsGenerated.eigsDependencies;\n }\n});\nObject.defineProperty(exports, \"electricConstantDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesElectricConstantGenerated.electricConstantDependencies;\n }\n});\nObject.defineProperty(exports, \"electronMassDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesElectronMassGenerated.electronMassDependencies;\n }\n});\nObject.defineProperty(exports, \"elementaryChargeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesElementaryChargeGenerated.elementaryChargeDependencies;\n }\n});\nObject.defineProperty(exports, \"equalDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesEqualGenerated.equalDependencies;\n }\n});\nObject.defineProperty(exports, \"equalScalarDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesEqualScalarGenerated.equalScalarDependencies;\n }\n});\nObject.defineProperty(exports, \"equalTextDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesEqualTextGenerated.equalTextDependencies;\n }\n});\nObject.defineProperty(exports, \"erfDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesErfGenerated.erfDependencies;\n }\n});\nObject.defineProperty(exports, \"evaluateDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesEvaluateGenerated.evaluateDependencies;\n }\n});\nObject.defineProperty(exports, \"expDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesExpGenerated.expDependencies;\n }\n});\nObject.defineProperty(exports, \"expm1Dependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesExpm1Generated.expm1Dependencies;\n }\n});\nObject.defineProperty(exports, \"expmDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesExpmGenerated.expmDependencies;\n }\n});\nObject.defineProperty(exports, \"factorialDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFactorialGenerated.factorialDependencies;\n }\n});\nObject.defineProperty(exports, \"falseDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFalseGenerated.falseDependencies;\n }\n});\nObject.defineProperty(exports, \"faradayDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFaradayGenerated.faradayDependencies;\n }\n});\nObject.defineProperty(exports, \"fermiCouplingDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFermiCouplingGenerated.fermiCouplingDependencies;\n }\n});\nObject.defineProperty(exports, \"fftDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFftGenerated.fftDependencies;\n }\n});\nObject.defineProperty(exports, \"filterDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFilterGenerated.filterDependencies;\n }\n});\nObject.defineProperty(exports, \"filterTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFilterTransformGenerated.filterTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"fineStructureDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFineStructureGenerated.fineStructureDependencies;\n }\n});\nObject.defineProperty(exports, \"firstRadiationDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFirstRadiationGenerated.firstRadiationDependencies;\n }\n});\nObject.defineProperty(exports, \"fixDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFixGenerated.fixDependencies;\n }\n});\nObject.defineProperty(exports, \"flattenDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFlattenGenerated.flattenDependencies;\n }\n});\nObject.defineProperty(exports, \"floorDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFloorGenerated.floorDependencies;\n }\n});\nObject.defineProperty(exports, \"forEachDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesForEachGenerated.forEachDependencies;\n }\n});\nObject.defineProperty(exports, \"forEachTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesForEachTransformGenerated.forEachTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"formatDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFormatGenerated.formatDependencies;\n }\n});\nObject.defineProperty(exports, \"fractionDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesFractionGenerated.fractionDependencies;\n }\n});\nObject.defineProperty(exports, \"gammaDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesGammaGenerated.gammaDependencies;\n }\n});\nObject.defineProperty(exports, \"gasConstantDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesGasConstantGenerated.gasConstantDependencies;\n }\n});\nObject.defineProperty(exports, \"gcdDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesGcdGenerated.gcdDependencies;\n }\n});\nObject.defineProperty(exports, \"getMatrixDataTypeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesGetMatrixDataTypeGenerated.getMatrixDataTypeDependencies;\n }\n});\nObject.defineProperty(exports, \"gravitationConstantDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesGravitationConstantGenerated.gravitationConstantDependencies;\n }\n});\nObject.defineProperty(exports, \"gravityDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesGravityGenerated.gravityDependencies;\n }\n});\nObject.defineProperty(exports, \"hartreeEnergyDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesHartreeEnergyGenerated.hartreeEnergyDependencies;\n }\n});\nObject.defineProperty(exports, \"hasNumericValueDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesHasNumericValueGenerated.hasNumericValueDependencies;\n }\n});\nObject.defineProperty(exports, \"helpDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesHelpGenerated.helpDependencies;\n }\n});\nObject.defineProperty(exports, \"hexDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesHexGenerated.hexDependencies;\n }\n});\nObject.defineProperty(exports, \"hypotDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesHypotGenerated.hypotDependencies;\n }\n});\nObject.defineProperty(exports, \"iDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIGenerated.iDependencies;\n }\n});\nObject.defineProperty(exports, \"identityDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIdentityGenerated.identityDependencies;\n }\n});\nObject.defineProperty(exports, \"ifftDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIfftGenerated.ifftDependencies;\n }\n});\nObject.defineProperty(exports, \"imDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesImGenerated.imDependencies;\n }\n});\nObject.defineProperty(exports, \"indexDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIndexGenerated.indexDependencies;\n }\n});\nObject.defineProperty(exports, \"indexTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIndexTransformGenerated.indexTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"intersectDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIntersectGenerated.intersectDependencies;\n }\n});\nObject.defineProperty(exports, \"invDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesInvGenerated.invDependencies;\n }\n});\nObject.defineProperty(exports, \"inverseConductanceQuantumDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesInverseConductanceQuantumGenerated.inverseConductanceQuantumDependencies;\n }\n});\nObject.defineProperty(exports, \"invmodDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesInvmodGenerated.invmodDependencies;\n }\n});\nObject.defineProperty(exports, \"isIntegerDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIsIntegerGenerated.isIntegerDependencies;\n }\n});\nObject.defineProperty(exports, \"isNaNDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIsNaNGenerated.isNaNDependencies;\n }\n});\nObject.defineProperty(exports, \"isNegativeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIsNegativeGenerated.isNegativeDependencies;\n }\n});\nObject.defineProperty(exports, \"isNumericDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIsNumericGenerated.isNumericDependencies;\n }\n});\nObject.defineProperty(exports, \"isPositiveDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIsPositiveGenerated.isPositiveDependencies;\n }\n});\nObject.defineProperty(exports, \"isPrimeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIsPrimeGenerated.isPrimeDependencies;\n }\n});\nObject.defineProperty(exports, \"isZeroDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesIsZeroGenerated.isZeroDependencies;\n }\n});\nObject.defineProperty(exports, \"kldivergenceDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesKldivergenceGenerated.kldivergenceDependencies;\n }\n});\nObject.defineProperty(exports, \"klitzingDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesKlitzingGenerated.klitzingDependencies;\n }\n});\nObject.defineProperty(exports, \"kronDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesKronGenerated.kronDependencies;\n }\n});\nObject.defineProperty(exports, \"largerDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLargerGenerated.largerDependencies;\n }\n});\nObject.defineProperty(exports, \"largerEqDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLargerEqGenerated.largerEqDependencies;\n }\n});\nObject.defineProperty(exports, \"lcmDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLcmGenerated.lcmDependencies;\n }\n});\nObject.defineProperty(exports, \"leafCountDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLeafCountGenerated.leafCountDependencies;\n }\n});\nObject.defineProperty(exports, \"leftShiftDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLeftShiftGenerated.leftShiftDependencies;\n }\n});\nObject.defineProperty(exports, \"lgammaDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLgammaGenerated.lgammaDependencies;\n }\n});\nObject.defineProperty(exports, \"log10Dependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLog10Generated.log10Dependencies;\n }\n});\nObject.defineProperty(exports, \"log1pDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLog1pGenerated.log1pDependencies;\n }\n});\nObject.defineProperty(exports, \"log2Dependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLog2Generated.log2Dependencies;\n }\n});\nObject.defineProperty(exports, \"logDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLogGenerated.logDependencies;\n }\n});\nObject.defineProperty(exports, \"loschmidtDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLoschmidtGenerated.loschmidtDependencies;\n }\n});\nObject.defineProperty(exports, \"lsolveAllDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLsolveAllGenerated.lsolveAllDependencies;\n }\n});\nObject.defineProperty(exports, \"lsolveDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLsolveGenerated.lsolveDependencies;\n }\n});\nObject.defineProperty(exports, \"lupDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLupGenerated.lupDependencies;\n }\n});\nObject.defineProperty(exports, \"lusolveDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesLusolveGenerated.lusolveDependencies;\n }\n});\nObject.defineProperty(exports, \"madDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMadGenerated.madDependencies;\n }\n});\nObject.defineProperty(exports, \"magneticConstantDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMagneticConstantGenerated.magneticConstantDependencies;\n }\n});\nObject.defineProperty(exports, \"magneticFluxQuantumDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMagneticFluxQuantumGenerated.magneticFluxQuantumDependencies;\n }\n});\nObject.defineProperty(exports, \"mapDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMapGenerated.mapDependencies;\n }\n});\nObject.defineProperty(exports, \"mapTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMapTransformGenerated.mapTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"matrixDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMatrixGenerated.matrixDependencies;\n }\n});\nObject.defineProperty(exports, \"matrixFromColumnsDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMatrixFromColumnsGenerated.matrixFromColumnsDependencies;\n }\n});\nObject.defineProperty(exports, \"matrixFromFunctionDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMatrixFromFunctionGenerated.matrixFromFunctionDependencies;\n }\n});\nObject.defineProperty(exports, \"matrixFromRowsDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMatrixFromRowsGenerated.matrixFromRowsDependencies;\n }\n});\nObject.defineProperty(exports, \"maxDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMaxGenerated.maxDependencies;\n }\n});\nObject.defineProperty(exports, \"maxTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMaxTransformGenerated.maxTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"meanDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMeanGenerated.meanDependencies;\n }\n});\nObject.defineProperty(exports, \"meanTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMeanTransformGenerated.meanTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"medianDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMedianGenerated.medianDependencies;\n }\n});\nObject.defineProperty(exports, \"minDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMinGenerated.minDependencies;\n }\n});\nObject.defineProperty(exports, \"minTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMinTransformGenerated.minTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"modDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesModGenerated.modDependencies;\n }\n});\nObject.defineProperty(exports, \"modeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesModeGenerated.modeDependencies;\n }\n});\nObject.defineProperty(exports, \"molarMassC12Dependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMolarMassC12Generated.molarMassC12Dependencies;\n }\n});\nObject.defineProperty(exports, \"molarMassDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMolarMassGenerated.molarMassDependencies;\n }\n});\nObject.defineProperty(exports, \"molarPlanckConstantDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMolarPlanckConstantGenerated.molarPlanckConstantDependencies;\n }\n});\nObject.defineProperty(exports, \"molarVolumeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMolarVolumeGenerated.molarVolumeDependencies;\n }\n});\nObject.defineProperty(exports, \"multinomialDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMultinomialGenerated.multinomialDependencies;\n }\n});\nObject.defineProperty(exports, \"multiplyDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMultiplyGenerated.multiplyDependencies;\n }\n});\nObject.defineProperty(exports, \"multiplyScalarDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies;\n }\n});\nObject.defineProperty(exports, \"neutronMassDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesNeutronMassGenerated.neutronMassDependencies;\n }\n});\nObject.defineProperty(exports, \"normDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesNormGenerated.normDependencies;\n }\n});\nObject.defineProperty(exports, \"notDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesNotGenerated.notDependencies;\n }\n});\nObject.defineProperty(exports, \"nthRootDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesNthRootGenerated.nthRootDependencies;\n }\n});\nObject.defineProperty(exports, \"nthRootsDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesNthRootsGenerated.nthRootsDependencies;\n }\n});\nObject.defineProperty(exports, \"nuclearMagnetonDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesNuclearMagnetonGenerated.nuclearMagnetonDependencies;\n }\n});\nObject.defineProperty(exports, \"nullDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesNullGenerated.nullDependencies;\n }\n});\nObject.defineProperty(exports, \"numberDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesNumberGenerated.numberDependencies;\n }\n});\nObject.defineProperty(exports, \"numericDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesNumericGenerated.numericDependencies;\n }\n});\nObject.defineProperty(exports, \"octDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesOctGenerated.octDependencies;\n }\n});\nObject.defineProperty(exports, \"onesDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesOnesGenerated.onesDependencies;\n }\n});\nObject.defineProperty(exports, \"orDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesOrGenerated.orDependencies;\n }\n});\nObject.defineProperty(exports, \"parseDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesParseGenerated.parseDependencies;\n }\n});\nObject.defineProperty(exports, \"parserDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesParserGenerated.parserDependencies;\n }\n});\nObject.defineProperty(exports, \"partitionSelectDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPartitionSelectGenerated.partitionSelectDependencies;\n }\n});\nObject.defineProperty(exports, \"permutationsDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPermutationsGenerated.permutationsDependencies;\n }\n});\nObject.defineProperty(exports, \"phiDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPhiGenerated.phiDependencies;\n }\n});\nObject.defineProperty(exports, \"piDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPiGenerated.piDependencies;\n }\n});\nObject.defineProperty(exports, \"pickRandomDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPickRandomGenerated.pickRandomDependencies;\n }\n});\nObject.defineProperty(exports, \"pinvDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPinvGenerated.pinvDependencies;\n }\n});\nObject.defineProperty(exports, \"planckChargeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPlanckChargeGenerated.planckChargeDependencies;\n }\n});\nObject.defineProperty(exports, \"planckConstantDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPlanckConstantGenerated.planckConstantDependencies;\n }\n});\nObject.defineProperty(exports, \"planckLengthDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPlanckLengthGenerated.planckLengthDependencies;\n }\n});\nObject.defineProperty(exports, \"planckMassDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPlanckMassGenerated.planckMassDependencies;\n }\n});\nObject.defineProperty(exports, \"planckTemperatureDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPlanckTemperatureGenerated.planckTemperatureDependencies;\n }\n});\nObject.defineProperty(exports, \"planckTimeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPlanckTimeGenerated.planckTimeDependencies;\n }\n});\nObject.defineProperty(exports, \"powDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPowGenerated.powDependencies;\n }\n});\nObject.defineProperty(exports, \"printDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesPrintGenerated.printDependencies;\n }\n});\nObject.defineProperty(exports, \"prodDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesProdGenerated.prodDependencies;\n }\n});\nObject.defineProperty(exports, \"protonMassDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesProtonMassGenerated.protonMassDependencies;\n }\n});\nObject.defineProperty(exports, \"qrDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesQrGenerated.qrDependencies;\n }\n});\nObject.defineProperty(exports, \"quantileSeqDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesQuantileSeqGenerated.quantileSeqDependencies;\n }\n});\nObject.defineProperty(exports, \"quantumOfCirculationDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesQuantumOfCirculationGenerated.quantumOfCirculationDependencies;\n }\n});\nObject.defineProperty(exports, \"randomDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRandomGenerated.randomDependencies;\n }\n});\nObject.defineProperty(exports, \"randomIntDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRandomIntGenerated.randomIntDependencies;\n }\n});\nObject.defineProperty(exports, \"rangeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRangeGenerated.rangeDependencies;\n }\n});\nObject.defineProperty(exports, \"rangeTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRangeTransformGenerated.rangeTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"rationalizeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRationalizeGenerated.rationalizeDependencies;\n }\n});\nObject.defineProperty(exports, \"reDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesReGenerated.reDependencies;\n }\n});\nObject.defineProperty(exports, \"reducedPlanckConstantDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesReducedPlanckConstantGenerated.reducedPlanckConstantDependencies;\n }\n});\nObject.defineProperty(exports, \"replacerDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesReplacerGenerated.replacerDependencies;\n }\n});\nObject.defineProperty(exports, \"reshapeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesReshapeGenerated.reshapeDependencies;\n }\n});\nObject.defineProperty(exports, \"resizeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesResizeGenerated.resizeDependencies;\n }\n});\nObject.defineProperty(exports, \"resolveDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesResolveGenerated.resolveDependencies;\n }\n});\nObject.defineProperty(exports, \"reviverDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesReviverGenerated.reviverDependencies;\n }\n});\nObject.defineProperty(exports, \"rightArithShiftDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRightArithShiftGenerated.rightArithShiftDependencies;\n }\n});\nObject.defineProperty(exports, \"rightLogShiftDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRightLogShiftGenerated.rightLogShiftDependencies;\n }\n});\nObject.defineProperty(exports, \"rotateDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRotateGenerated.rotateDependencies;\n }\n});\nObject.defineProperty(exports, \"rotationMatrixDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRotationMatrixGenerated.rotationMatrixDependencies;\n }\n});\nObject.defineProperty(exports, \"roundDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRoundGenerated.roundDependencies;\n }\n});\nObject.defineProperty(exports, \"rowDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRowGenerated.rowDependencies;\n }\n});\nObject.defineProperty(exports, \"rowTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRowTransformGenerated.rowTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"rydbergDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesRydbergGenerated.rydbergDependencies;\n }\n});\nObject.defineProperty(exports, \"sackurTetrodeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSackurTetrodeGenerated.sackurTetrodeDependencies;\n }\n});\nObject.defineProperty(exports, \"secDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSecGenerated.secDependencies;\n }\n});\nObject.defineProperty(exports, \"sechDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSechGenerated.sechDependencies;\n }\n});\nObject.defineProperty(exports, \"secondRadiationDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSecondRadiationGenerated.secondRadiationDependencies;\n }\n});\nObject.defineProperty(exports, \"setCartesianDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSetCartesianGenerated.setCartesianDependencies;\n }\n});\nObject.defineProperty(exports, \"setDifferenceDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSetDifferenceGenerated.setDifferenceDependencies;\n }\n});\nObject.defineProperty(exports, \"setDistinctDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSetDistinctGenerated.setDistinctDependencies;\n }\n});\nObject.defineProperty(exports, \"setIntersectDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSetIntersectGenerated.setIntersectDependencies;\n }\n});\nObject.defineProperty(exports, \"setIsSubsetDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSetIsSubsetGenerated.setIsSubsetDependencies;\n }\n});\nObject.defineProperty(exports, \"setMultiplicityDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSetMultiplicityGenerated.setMultiplicityDependencies;\n }\n});\nObject.defineProperty(exports, \"setPowersetDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSetPowersetGenerated.setPowersetDependencies;\n }\n});\nObject.defineProperty(exports, \"setSizeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSetSizeGenerated.setSizeDependencies;\n }\n});\nObject.defineProperty(exports, \"setSymDifferenceDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSetSymDifferenceGenerated.setSymDifferenceDependencies;\n }\n});\nObject.defineProperty(exports, \"setUnionDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSetUnionGenerated.setUnionDependencies;\n }\n});\nObject.defineProperty(exports, \"signDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSignGenerated.signDependencies;\n }\n});\nObject.defineProperty(exports, \"simplifyCoreDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSimplifyCoreGenerated.simplifyCoreDependencies;\n }\n});\nObject.defineProperty(exports, \"simplifyDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSimplifyGenerated.simplifyDependencies;\n }\n});\nObject.defineProperty(exports, \"sinDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSinGenerated.sinDependencies;\n }\n});\nObject.defineProperty(exports, \"sinhDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSinhGenerated.sinhDependencies;\n }\n});\nObject.defineProperty(exports, \"sizeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSizeGenerated.sizeDependencies;\n }\n});\nObject.defineProperty(exports, \"sluDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSluGenerated.sluDependencies;\n }\n});\nObject.defineProperty(exports, \"smallerDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSmallerGenerated.smallerDependencies;\n }\n});\nObject.defineProperty(exports, \"smallerEqDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSmallerEqGenerated.smallerEqDependencies;\n }\n});\nObject.defineProperty(exports, \"sortDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSortGenerated.sortDependencies;\n }\n});\nObject.defineProperty(exports, \"sparseDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSparseGenerated.sparseDependencies;\n }\n});\nObject.defineProperty(exports, \"speedOfLightDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSpeedOfLightGenerated.speedOfLightDependencies;\n }\n});\nObject.defineProperty(exports, \"splitUnitDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSplitUnitGenerated.splitUnitDependencies;\n }\n});\nObject.defineProperty(exports, \"sqrtDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSqrtGenerated.sqrtDependencies;\n }\n});\nObject.defineProperty(exports, \"sqrtmDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSqrtmGenerated.sqrtmDependencies;\n }\n});\nObject.defineProperty(exports, \"squareDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSquareGenerated.squareDependencies;\n }\n});\nObject.defineProperty(exports, \"squeezeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSqueezeGenerated.squeezeDependencies;\n }\n});\nObject.defineProperty(exports, \"stdDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesStdGenerated.stdDependencies;\n }\n});\nObject.defineProperty(exports, \"stdTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesStdTransformGenerated.stdTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"stefanBoltzmannDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesStefanBoltzmannGenerated.stefanBoltzmannDependencies;\n }\n});\nObject.defineProperty(exports, \"stirlingS2Dependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesStirlingS2Generated.stirlingS2Dependencies;\n }\n});\nObject.defineProperty(exports, \"stringDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesStringGenerated.stringDependencies;\n }\n});\nObject.defineProperty(exports, \"subsetDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSubsetGenerated.subsetDependencies;\n }\n});\nObject.defineProperty(exports, \"subsetTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSubsetTransformGenerated.subsetTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"subtractDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSubtractGenerated.subtractDependencies;\n }\n});\nObject.defineProperty(exports, \"sumDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSumGenerated.sumDependencies;\n }\n});\nObject.defineProperty(exports, \"sumTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSumTransformGenerated.sumTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"symbolicEqualDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesSymbolicEqualGenerated.symbolicEqualDependencies;\n }\n});\nObject.defineProperty(exports, \"tanDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesTanGenerated.tanDependencies;\n }\n});\nObject.defineProperty(exports, \"tanhDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesTanhGenerated.tanhDependencies;\n }\n});\nObject.defineProperty(exports, \"tauDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesTauGenerated.tauDependencies;\n }\n});\nObject.defineProperty(exports, \"thomsonCrossSectionDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesThomsonCrossSectionGenerated.thomsonCrossSectionDependencies;\n }\n});\nObject.defineProperty(exports, \"toDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesToGenerated.toDependencies;\n }\n});\nObject.defineProperty(exports, \"traceDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesTraceGenerated.traceDependencies;\n }\n});\nObject.defineProperty(exports, \"transposeDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesTransposeGenerated.transposeDependencies;\n }\n});\nObject.defineProperty(exports, \"trueDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesTrueGenerated.trueDependencies;\n }\n});\nObject.defineProperty(exports, \"typeOfDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesTypeOfGenerated.typeOfDependencies;\n }\n});\nObject.defineProperty(exports, \"typedDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesTypedGenerated.typedDependencies;\n }\n});\nObject.defineProperty(exports, \"unaryMinusDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesUnaryMinusGenerated.unaryMinusDependencies;\n }\n});\nObject.defineProperty(exports, \"unaryPlusDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesUnaryPlusGenerated.unaryPlusDependencies;\n }\n});\nObject.defineProperty(exports, \"unequalDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesUnequalGenerated.unequalDependencies;\n }\n});\nObject.defineProperty(exports, \"unitDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesUnitFunctionGenerated.unitDependencies;\n }\n});\nObject.defineProperty(exports, \"usolveAllDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesUsolveAllGenerated.usolveAllDependencies;\n }\n});\nObject.defineProperty(exports, \"usolveDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesUsolveGenerated.usolveDependencies;\n }\n});\nObject.defineProperty(exports, \"vacuumImpedanceDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesVacuumImpedanceGenerated.vacuumImpedanceDependencies;\n }\n});\nObject.defineProperty(exports, \"varianceDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesVarianceGenerated.varianceDependencies;\n }\n});\nObject.defineProperty(exports, \"varianceTransformDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesVarianceTransformGenerated.varianceTransformDependencies;\n }\n});\nObject.defineProperty(exports, \"versionDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesVersionGenerated.versionDependencies;\n }\n});\nObject.defineProperty(exports, \"weakMixingAngleDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesWeakMixingAngleGenerated.weakMixingAngleDependencies;\n }\n});\nObject.defineProperty(exports, \"wienDisplacementDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesWienDisplacementGenerated.wienDisplacementDependencies;\n }\n});\nObject.defineProperty(exports, \"xgcdDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesXgcdGenerated.xgcdDependencies;\n }\n});\nObject.defineProperty(exports, \"xorDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesXorGenerated.xorDependencies;\n }\n});\nObject.defineProperty(exports, \"zerosDependencies\", {\n enumerable: true,\n get: function get() {\n return _dependenciesZerosGenerated.zerosDependencies;\n }\n});\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAny/dependenciesAbs.generated.js\");\n\nvar _dependenciesAccessorNodeGenerated = require(\"./dependenciesAny/dependenciesAccessorNode.generated.js\");\n\nvar _dependenciesAcosGenerated = require(\"./dependenciesAny/dependenciesAcos.generated.js\");\n\nvar _dependenciesAcoshGenerated = require(\"./dependenciesAny/dependenciesAcosh.generated.js\");\n\nvar _dependenciesAcotGenerated = require(\"./dependenciesAny/dependenciesAcot.generated.js\");\n\nvar _dependenciesAcothGenerated = require(\"./dependenciesAny/dependenciesAcoth.generated.js\");\n\nvar _dependenciesAcscGenerated = require(\"./dependenciesAny/dependenciesAcsc.generated.js\");\n\nvar _dependenciesAcschGenerated = require(\"./dependenciesAny/dependenciesAcsch.generated.js\");\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAny/dependenciesAdd.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAny/dependenciesAddScalar.generated.js\");\n\nvar _dependenciesAndGenerated = require(\"./dependenciesAny/dependenciesAnd.generated.js\");\n\nvar _dependenciesApplyGenerated = require(\"./dependenciesAny/dependenciesApply.generated.js\");\n\nvar _dependenciesApplyTransformGenerated = require(\"./dependenciesAny/dependenciesApplyTransform.generated.js\");\n\nvar _dependenciesArgGenerated = require(\"./dependenciesAny/dependenciesArg.generated.js\");\n\nvar _dependenciesArrayNodeGenerated = require(\"./dependenciesAny/dependenciesArrayNode.generated.js\");\n\nvar _dependenciesAsecGenerated = require(\"./dependenciesAny/dependenciesAsec.generated.js\");\n\nvar _dependenciesAsechGenerated = require(\"./dependenciesAny/dependenciesAsech.generated.js\");\n\nvar _dependenciesAsinGenerated = require(\"./dependenciesAny/dependenciesAsin.generated.js\");\n\nvar _dependenciesAsinhGenerated = require(\"./dependenciesAny/dependenciesAsinh.generated.js\");\n\nvar _dependenciesAssignmentNodeGenerated = require(\"./dependenciesAny/dependenciesAssignmentNode.generated.js\");\n\nvar _dependenciesAtanGenerated = require(\"./dependenciesAny/dependenciesAtan.generated.js\");\n\nvar _dependenciesAtan2Generated = require(\"./dependenciesAny/dependenciesAtan2.generated.js\");\n\nvar _dependenciesAtanhGenerated = require(\"./dependenciesAny/dependenciesAtanh.generated.js\");\n\nvar _dependenciesAtomicMassGenerated = require(\"./dependenciesAny/dependenciesAtomicMass.generated.js\");\n\nvar _dependenciesAvogadroGenerated = require(\"./dependenciesAny/dependenciesAvogadro.generated.js\");\n\nvar _dependenciesBellNumbersGenerated = require(\"./dependenciesAny/dependenciesBellNumbers.generated.js\");\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesAny/dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesBignumberGenerated = require(\"./dependenciesAny/dependenciesBignumber.generated.js\");\n\nvar _dependenciesBinGenerated = require(\"./dependenciesAny/dependenciesBin.generated.js\");\n\nvar _dependenciesBitAndGenerated = require(\"./dependenciesAny/dependenciesBitAnd.generated.js\");\n\nvar _dependenciesBitNotGenerated = require(\"./dependenciesAny/dependenciesBitNot.generated.js\");\n\nvar _dependenciesBitOrGenerated = require(\"./dependenciesAny/dependenciesBitOr.generated.js\");\n\nvar _dependenciesBitXorGenerated = require(\"./dependenciesAny/dependenciesBitXor.generated.js\");\n\nvar _dependenciesBlockNodeGenerated = require(\"./dependenciesAny/dependenciesBlockNode.generated.js\");\n\nvar _dependenciesBohrMagnetonGenerated = require(\"./dependenciesAny/dependenciesBohrMagneton.generated.js\");\n\nvar _dependenciesBohrRadiusGenerated = require(\"./dependenciesAny/dependenciesBohrRadius.generated.js\");\n\nvar _dependenciesBoltzmannGenerated = require(\"./dependenciesAny/dependenciesBoltzmann.generated.js\");\n\nvar _dependenciesBooleanGenerated = require(\"./dependenciesAny/dependenciesBoolean.generated.js\");\n\nvar _dependenciesCatalanGenerated = require(\"./dependenciesAny/dependenciesCatalan.generated.js\");\n\nvar _dependenciesCbrtGenerated = require(\"./dependenciesAny/dependenciesCbrt.generated.js\");\n\nvar _dependenciesCeilGenerated = require(\"./dependenciesAny/dependenciesCeil.generated.js\");\n\nvar _dependenciesChainGenerated = require(\"./dependenciesAny/dependenciesChain.generated.js\");\n\nvar _dependenciesChainClassGenerated = require(\"./dependenciesAny/dependenciesChainClass.generated.js\");\n\nvar _dependenciesClassicalElectronRadiusGenerated = require(\"./dependenciesAny/dependenciesClassicalElectronRadius.generated.js\");\n\nvar _dependenciesCloneGenerated = require(\"./dependenciesAny/dependenciesClone.generated.js\");\n\nvar _dependenciesColumnGenerated = require(\"./dependenciesAny/dependenciesColumn.generated.js\");\n\nvar _dependenciesColumnTransformGenerated = require(\"./dependenciesAny/dependenciesColumnTransform.generated.js\");\n\nvar _dependenciesCombinationsGenerated = require(\"./dependenciesAny/dependenciesCombinations.generated.js\");\n\nvar _dependenciesCombinationsWithRepGenerated = require(\"./dependenciesAny/dependenciesCombinationsWithRep.generated.js\");\n\nvar _dependenciesCompareGenerated = require(\"./dependenciesAny/dependenciesCompare.generated.js\");\n\nvar _dependenciesCompareNaturalGenerated = require(\"./dependenciesAny/dependenciesCompareNatural.generated.js\");\n\nvar _dependenciesCompareTextGenerated = require(\"./dependenciesAny/dependenciesCompareText.generated.js\");\n\nvar _dependenciesCompileGenerated = require(\"./dependenciesAny/dependenciesCompile.generated.js\");\n\nvar _dependenciesComplexGenerated = require(\"./dependenciesAny/dependenciesComplex.generated.js\");\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesAny/dependenciesComplexClass.generated.js\");\n\nvar _dependenciesCompositionGenerated = require(\"./dependenciesAny/dependenciesComposition.generated.js\");\n\nvar _dependenciesConcatGenerated = require(\"./dependenciesAny/dependenciesConcat.generated.js\");\n\nvar _dependenciesConcatTransformGenerated = require(\"./dependenciesAny/dependenciesConcatTransform.generated.js\");\n\nvar _dependenciesConditionalNodeGenerated = require(\"./dependenciesAny/dependenciesConditionalNode.generated.js\");\n\nvar _dependenciesConductanceQuantumGenerated = require(\"./dependenciesAny/dependenciesConductanceQuantum.generated.js\");\n\nvar _dependenciesConjGenerated = require(\"./dependenciesAny/dependenciesConj.generated.js\");\n\nvar _dependenciesConstantNodeGenerated = require(\"./dependenciesAny/dependenciesConstantNode.generated.js\");\n\nvar _dependenciesCosGenerated = require(\"./dependenciesAny/dependenciesCos.generated.js\");\n\nvar _dependenciesCoshGenerated = require(\"./dependenciesAny/dependenciesCosh.generated.js\");\n\nvar _dependenciesCotGenerated = require(\"./dependenciesAny/dependenciesCot.generated.js\");\n\nvar _dependenciesCothGenerated = require(\"./dependenciesAny/dependenciesCoth.generated.js\");\n\nvar _dependenciesCoulombGenerated = require(\"./dependenciesAny/dependenciesCoulomb.generated.js\");\n\nvar _dependenciesCountGenerated = require(\"./dependenciesAny/dependenciesCount.generated.js\");\n\nvar _dependenciesCreateUnitGenerated = require(\"./dependenciesAny/dependenciesCreateUnit.generated.js\");\n\nvar _dependenciesCrossGenerated = require(\"./dependenciesAny/dependenciesCross.generated.js\");\n\nvar _dependenciesCscGenerated = require(\"./dependenciesAny/dependenciesCsc.generated.js\");\n\nvar _dependenciesCschGenerated = require(\"./dependenciesAny/dependenciesCsch.generated.js\");\n\nvar _dependenciesCtransposeGenerated = require(\"./dependenciesAny/dependenciesCtranspose.generated.js\");\n\nvar _dependenciesCubeGenerated = require(\"./dependenciesAny/dependenciesCube.generated.js\");\n\nvar _dependenciesCumSumGenerated = require(\"./dependenciesAny/dependenciesCumSum.generated.js\");\n\nvar _dependenciesCumSumTransformGenerated = require(\"./dependenciesAny/dependenciesCumSumTransform.generated.js\");\n\nvar _dependenciesDeepEqualGenerated = require(\"./dependenciesAny/dependenciesDeepEqual.generated.js\");\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesAny/dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesDerivativeGenerated = require(\"./dependenciesAny/dependenciesDerivative.generated.js\");\n\nvar _dependenciesDetGenerated = require(\"./dependenciesAny/dependenciesDet.generated.js\");\n\nvar _dependenciesDeuteronMassGenerated = require(\"./dependenciesAny/dependenciesDeuteronMass.generated.js\");\n\nvar _dependenciesDiagGenerated = require(\"./dependenciesAny/dependenciesDiag.generated.js\");\n\nvar _dependenciesDiffGenerated = require(\"./dependenciesAny/dependenciesDiff.generated.js\");\n\nvar _dependenciesDiffTransformGenerated = require(\"./dependenciesAny/dependenciesDiffTransform.generated.js\");\n\nvar _dependenciesDistanceGenerated = require(\"./dependenciesAny/dependenciesDistance.generated.js\");\n\nvar _dependenciesDivideGenerated = require(\"./dependenciesAny/dependenciesDivide.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesAny/dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesDotGenerated = require(\"./dependenciesAny/dependenciesDot.generated.js\");\n\nvar _dependenciesDotDivideGenerated = require(\"./dependenciesAny/dependenciesDotDivide.generated.js\");\n\nvar _dependenciesDotMultiplyGenerated = require(\"./dependenciesAny/dependenciesDotMultiply.generated.js\");\n\nvar _dependenciesDotPowGenerated = require(\"./dependenciesAny/dependenciesDotPow.generated.js\");\n\nvar _dependenciesEGenerated = require(\"./dependenciesAny/dependenciesE.generated.js\");\n\nvar _dependenciesEfimovFactorGenerated = require(\"./dependenciesAny/dependenciesEfimovFactor.generated.js\");\n\nvar _dependenciesEigsGenerated = require(\"./dependenciesAny/dependenciesEigs.generated.js\");\n\nvar _dependenciesElectricConstantGenerated = require(\"./dependenciesAny/dependenciesElectricConstant.generated.js\");\n\nvar _dependenciesElectronMassGenerated = require(\"./dependenciesAny/dependenciesElectronMass.generated.js\");\n\nvar _dependenciesElementaryChargeGenerated = require(\"./dependenciesAny/dependenciesElementaryCharge.generated.js\");\n\nvar _dependenciesEqualGenerated = require(\"./dependenciesAny/dependenciesEqual.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesAny/dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesEqualTextGenerated = require(\"./dependenciesAny/dependenciesEqualText.generated.js\");\n\nvar _dependenciesErfGenerated = require(\"./dependenciesAny/dependenciesErf.generated.js\");\n\nvar _dependenciesEvaluateGenerated = require(\"./dependenciesAny/dependenciesEvaluate.generated.js\");\n\nvar _dependenciesExpGenerated = require(\"./dependenciesAny/dependenciesExp.generated.js\");\n\nvar _dependenciesExpmGenerated = require(\"./dependenciesAny/dependenciesExpm.generated.js\");\n\nvar _dependenciesExpm1Generated = require(\"./dependenciesAny/dependenciesExpm1.generated.js\");\n\nvar _dependenciesFactorialGenerated = require(\"./dependenciesAny/dependenciesFactorial.generated.js\");\n\nvar _dependenciesFalseGenerated = require(\"./dependenciesAny/dependenciesFalse.generated.js\");\n\nvar _dependenciesFaradayGenerated = require(\"./dependenciesAny/dependenciesFaraday.generated.js\");\n\nvar _dependenciesFermiCouplingGenerated = require(\"./dependenciesAny/dependenciesFermiCoupling.generated.js\");\n\nvar _dependenciesFftGenerated = require(\"./dependenciesAny/dependenciesFft.generated.js\");\n\nvar _dependenciesFibonacciHeapClassGenerated = require(\"./dependenciesAny/dependenciesFibonacciHeapClass.generated.js\");\n\nvar _dependenciesFilterGenerated = require(\"./dependenciesAny/dependenciesFilter.generated.js\");\n\nvar _dependenciesFilterTransformGenerated = require(\"./dependenciesAny/dependenciesFilterTransform.generated.js\");\n\nvar _dependenciesFineStructureGenerated = require(\"./dependenciesAny/dependenciesFineStructure.generated.js\");\n\nvar _dependenciesFirstRadiationGenerated = require(\"./dependenciesAny/dependenciesFirstRadiation.generated.js\");\n\nvar _dependenciesFixGenerated = require(\"./dependenciesAny/dependenciesFix.generated.js\");\n\nvar _dependenciesFlattenGenerated = require(\"./dependenciesAny/dependenciesFlatten.generated.js\");\n\nvar _dependenciesFloorGenerated = require(\"./dependenciesAny/dependenciesFloor.generated.js\");\n\nvar _dependenciesForEachGenerated = require(\"./dependenciesAny/dependenciesForEach.generated.js\");\n\nvar _dependenciesForEachTransformGenerated = require(\"./dependenciesAny/dependenciesForEachTransform.generated.js\");\n\nvar _dependenciesFormatGenerated = require(\"./dependenciesAny/dependenciesFormat.generated.js\");\n\nvar _dependenciesFractionGenerated = require(\"./dependenciesAny/dependenciesFraction.generated.js\");\n\nvar _dependenciesFractionClassGenerated = require(\"./dependenciesAny/dependenciesFractionClass.generated.js\");\n\nvar _dependenciesFunctionAssignmentNodeGenerated = require(\"./dependenciesAny/dependenciesFunctionAssignmentNode.generated.js\");\n\nvar _dependenciesFunctionNodeGenerated = require(\"./dependenciesAny/dependenciesFunctionNode.generated.js\");\n\nvar _dependenciesGammaGenerated = require(\"./dependenciesAny/dependenciesGamma.generated.js\");\n\nvar _dependenciesGasConstantGenerated = require(\"./dependenciesAny/dependenciesGasConstant.generated.js\");\n\nvar _dependenciesGcdGenerated = require(\"./dependenciesAny/dependenciesGcd.generated.js\");\n\nvar _dependenciesGetMatrixDataTypeGenerated = require(\"./dependenciesAny/dependenciesGetMatrixDataType.generated.js\");\n\nvar _dependenciesGravitationConstantGenerated = require(\"./dependenciesAny/dependenciesGravitationConstant.generated.js\");\n\nvar _dependenciesGravityGenerated = require(\"./dependenciesAny/dependenciesGravity.generated.js\");\n\nvar _dependenciesHartreeEnergyGenerated = require(\"./dependenciesAny/dependenciesHartreeEnergy.generated.js\");\n\nvar _dependenciesHasNumericValueGenerated = require(\"./dependenciesAny/dependenciesHasNumericValue.generated.js\");\n\nvar _dependenciesHelpGenerated = require(\"./dependenciesAny/dependenciesHelp.generated.js\");\n\nvar _dependenciesHelpClassGenerated = require(\"./dependenciesAny/dependenciesHelpClass.generated.js\");\n\nvar _dependenciesHexGenerated = require(\"./dependenciesAny/dependenciesHex.generated.js\");\n\nvar _dependenciesHypotGenerated = require(\"./dependenciesAny/dependenciesHypot.generated.js\");\n\nvar _dependenciesIGenerated = require(\"./dependenciesAny/dependenciesI.generated.js\");\n\nvar _dependenciesIdentityGenerated = require(\"./dependenciesAny/dependenciesIdentity.generated.js\");\n\nvar _dependenciesIfftGenerated = require(\"./dependenciesAny/dependenciesIfft.generated.js\");\n\nvar _dependenciesImGenerated = require(\"./dependenciesAny/dependenciesIm.generated.js\");\n\nvar _dependenciesImmutableDenseMatrixClassGenerated = require(\"./dependenciesAny/dependenciesImmutableDenseMatrixClass.generated.js\");\n\nvar _dependenciesIndexGenerated = require(\"./dependenciesAny/dependenciesIndex.generated.js\");\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesAny/dependenciesIndexClass.generated.js\");\n\nvar _dependenciesIndexNodeGenerated = require(\"./dependenciesAny/dependenciesIndexNode.generated.js\");\n\nvar _dependenciesIndexTransformGenerated = require(\"./dependenciesAny/dependenciesIndexTransform.generated.js\");\n\nvar _dependenciesInfinityGenerated = require(\"./dependenciesAny/dependenciesInfinity.generated.js\");\n\nvar _dependenciesIntersectGenerated = require(\"./dependenciesAny/dependenciesIntersect.generated.js\");\n\nvar _dependenciesInvGenerated = require(\"./dependenciesAny/dependenciesInv.generated.js\");\n\nvar _dependenciesInverseConductanceQuantumGenerated = require(\"./dependenciesAny/dependenciesInverseConductanceQuantum.generated.js\");\n\nvar _dependenciesInvmodGenerated = require(\"./dependenciesAny/dependenciesInvmod.generated.js\");\n\nvar _dependenciesIsIntegerGenerated = require(\"./dependenciesAny/dependenciesIsInteger.generated.js\");\n\nvar _dependenciesIsNaNGenerated = require(\"./dependenciesAny/dependenciesIsNaN.generated.js\");\n\nvar _dependenciesIsNegativeGenerated = require(\"./dependenciesAny/dependenciesIsNegative.generated.js\");\n\nvar _dependenciesIsNumericGenerated = require(\"./dependenciesAny/dependenciesIsNumeric.generated.js\");\n\nvar _dependenciesIsPositiveGenerated = require(\"./dependenciesAny/dependenciesIsPositive.generated.js\");\n\nvar _dependenciesIsPrimeGenerated = require(\"./dependenciesAny/dependenciesIsPrime.generated.js\");\n\nvar _dependenciesIsZeroGenerated = require(\"./dependenciesAny/dependenciesIsZero.generated.js\");\n\nvar _dependenciesKldivergenceGenerated = require(\"./dependenciesAny/dependenciesKldivergence.generated.js\");\n\nvar _dependenciesKlitzingGenerated = require(\"./dependenciesAny/dependenciesKlitzing.generated.js\");\n\nvar _dependenciesKronGenerated = require(\"./dependenciesAny/dependenciesKron.generated.js\");\n\nvar _dependenciesLN10Generated = require(\"./dependenciesAny/dependenciesLN10.generated.js\");\n\nvar _dependenciesLN2Generated = require(\"./dependenciesAny/dependenciesLN2.generated.js\");\n\nvar _dependenciesLOG10EGenerated = require(\"./dependenciesAny/dependenciesLOG10E.generated.js\");\n\nvar _dependenciesLOG2EGenerated = require(\"./dependenciesAny/dependenciesLOG2E.generated.js\");\n\nvar _dependenciesLargerGenerated = require(\"./dependenciesAny/dependenciesLarger.generated.js\");\n\nvar _dependenciesLargerEqGenerated = require(\"./dependenciesAny/dependenciesLargerEq.generated.js\");\n\nvar _dependenciesLcmGenerated = require(\"./dependenciesAny/dependenciesLcm.generated.js\");\n\nvar _dependenciesLeafCountGenerated = require(\"./dependenciesAny/dependenciesLeafCount.generated.js\");\n\nvar _dependenciesLeftShiftGenerated = require(\"./dependenciesAny/dependenciesLeftShift.generated.js\");\n\nvar _dependenciesLgammaGenerated = require(\"./dependenciesAny/dependenciesLgamma.generated.js\");\n\nvar _dependenciesLogGenerated = require(\"./dependenciesAny/dependenciesLog.generated.js\");\n\nvar _dependenciesLog10Generated = require(\"./dependenciesAny/dependenciesLog10.generated.js\");\n\nvar _dependenciesLog1pGenerated = require(\"./dependenciesAny/dependenciesLog1p.generated.js\");\n\nvar _dependenciesLog2Generated = require(\"./dependenciesAny/dependenciesLog2.generated.js\");\n\nvar _dependenciesLoschmidtGenerated = require(\"./dependenciesAny/dependenciesLoschmidt.generated.js\");\n\nvar _dependenciesLsolveGenerated = require(\"./dependenciesAny/dependenciesLsolve.generated.js\");\n\nvar _dependenciesLsolveAllGenerated = require(\"./dependenciesAny/dependenciesLsolveAll.generated.js\");\n\nvar _dependenciesLupGenerated = require(\"./dependenciesAny/dependenciesLup.generated.js\");\n\nvar _dependenciesLusolveGenerated = require(\"./dependenciesAny/dependenciesLusolve.generated.js\");\n\nvar _dependenciesMadGenerated = require(\"./dependenciesAny/dependenciesMad.generated.js\");\n\nvar _dependenciesMagneticConstantGenerated = require(\"./dependenciesAny/dependenciesMagneticConstant.generated.js\");\n\nvar _dependenciesMagneticFluxQuantumGenerated = require(\"./dependenciesAny/dependenciesMagneticFluxQuantum.generated.js\");\n\nvar _dependenciesMapGenerated = require(\"./dependenciesAny/dependenciesMap.generated.js\");\n\nvar _dependenciesMapTransformGenerated = require(\"./dependenciesAny/dependenciesMapTransform.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesAny/dependenciesMatrix.generated.js\");\n\nvar _dependenciesMatrixClassGenerated = require(\"./dependenciesAny/dependenciesMatrixClass.generated.js\");\n\nvar _dependenciesMatrixFromColumnsGenerated = require(\"./dependenciesAny/dependenciesMatrixFromColumns.generated.js\");\n\nvar _dependenciesMatrixFromFunctionGenerated = require(\"./dependenciesAny/dependenciesMatrixFromFunction.generated.js\");\n\nvar _dependenciesMatrixFromRowsGenerated = require(\"./dependenciesAny/dependenciesMatrixFromRows.generated.js\");\n\nvar _dependenciesMaxGenerated = require(\"./dependenciesAny/dependenciesMax.generated.js\");\n\nvar _dependenciesMaxTransformGenerated = require(\"./dependenciesAny/dependenciesMaxTransform.generated.js\");\n\nvar _dependenciesMeanGenerated = require(\"./dependenciesAny/dependenciesMean.generated.js\");\n\nvar _dependenciesMeanTransformGenerated = require(\"./dependenciesAny/dependenciesMeanTransform.generated.js\");\n\nvar _dependenciesMedianGenerated = require(\"./dependenciesAny/dependenciesMedian.generated.js\");\n\nvar _dependenciesMinGenerated = require(\"./dependenciesAny/dependenciesMin.generated.js\");\n\nvar _dependenciesMinTransformGenerated = require(\"./dependenciesAny/dependenciesMinTransform.generated.js\");\n\nvar _dependenciesModGenerated = require(\"./dependenciesAny/dependenciesMod.generated.js\");\n\nvar _dependenciesModeGenerated = require(\"./dependenciesAny/dependenciesMode.generated.js\");\n\nvar _dependenciesMolarMassGenerated = require(\"./dependenciesAny/dependenciesMolarMass.generated.js\");\n\nvar _dependenciesMolarMassC12Generated = require(\"./dependenciesAny/dependenciesMolarMassC12.generated.js\");\n\nvar _dependenciesMolarPlanckConstantGenerated = require(\"./dependenciesAny/dependenciesMolarPlanckConstant.generated.js\");\n\nvar _dependenciesMolarVolumeGenerated = require(\"./dependenciesAny/dependenciesMolarVolume.generated.js\");\n\nvar _dependenciesMultinomialGenerated = require(\"./dependenciesAny/dependenciesMultinomial.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesAny/dependenciesMultiply.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesAny/dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesNaNGenerated = require(\"./dependenciesAny/dependenciesNaN.generated.js\");\n\nvar _dependenciesNeutronMassGenerated = require(\"./dependenciesAny/dependenciesNeutronMass.generated.js\");\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesAny/dependenciesNode.generated.js\");\n\nvar _dependenciesNormGenerated = require(\"./dependenciesAny/dependenciesNorm.generated.js\");\n\nvar _dependenciesNotGenerated = require(\"./dependenciesAny/dependenciesNot.generated.js\");\n\nvar _dependenciesNthRootGenerated = require(\"./dependenciesAny/dependenciesNthRoot.generated.js\");\n\nvar _dependenciesNthRootsGenerated = require(\"./dependenciesAny/dependenciesNthRoots.generated.js\");\n\nvar _dependenciesNuclearMagnetonGenerated = require(\"./dependenciesAny/dependenciesNuclearMagneton.generated.js\");\n\nvar _dependenciesNullGenerated = require(\"./dependenciesAny/dependenciesNull.generated.js\");\n\nvar _dependenciesNumberGenerated = require(\"./dependenciesAny/dependenciesNumber.generated.js\");\n\nvar _dependenciesNumericGenerated = require(\"./dependenciesAny/dependenciesNumeric.generated.js\");\n\nvar _dependenciesObjectNodeGenerated = require(\"./dependenciesAny/dependenciesObjectNode.generated.js\");\n\nvar _dependenciesOctGenerated = require(\"./dependenciesAny/dependenciesOct.generated.js\");\n\nvar _dependenciesOnesGenerated = require(\"./dependenciesAny/dependenciesOnes.generated.js\");\n\nvar _dependenciesOperatorNodeGenerated = require(\"./dependenciesAny/dependenciesOperatorNode.generated.js\");\n\nvar _dependenciesOrGenerated = require(\"./dependenciesAny/dependenciesOr.generated.js\");\n\nvar _dependenciesParenthesisNodeGenerated = require(\"./dependenciesAny/dependenciesParenthesisNode.generated.js\");\n\nvar _dependenciesParseGenerated = require(\"./dependenciesAny/dependenciesParse.generated.js\");\n\nvar _dependenciesParserGenerated = require(\"./dependenciesAny/dependenciesParser.generated.js\");\n\nvar _dependenciesParserClassGenerated = require(\"./dependenciesAny/dependenciesParserClass.generated.js\");\n\nvar _dependenciesPartitionSelectGenerated = require(\"./dependenciesAny/dependenciesPartitionSelect.generated.js\");\n\nvar _dependenciesPermutationsGenerated = require(\"./dependenciesAny/dependenciesPermutations.generated.js\");\n\nvar _dependenciesPhiGenerated = require(\"./dependenciesAny/dependenciesPhi.generated.js\");\n\nvar _dependenciesPiGenerated = require(\"./dependenciesAny/dependenciesPi.generated.js\");\n\nvar _dependenciesPickRandomGenerated = require(\"./dependenciesAny/dependenciesPickRandom.generated.js\");\n\nvar _dependenciesPinvGenerated = require(\"./dependenciesAny/dependenciesPinv.generated.js\");\n\nvar _dependenciesPlanckChargeGenerated = require(\"./dependenciesAny/dependenciesPlanckCharge.generated.js\");\n\nvar _dependenciesPlanckConstantGenerated = require(\"./dependenciesAny/dependenciesPlanckConstant.generated.js\");\n\nvar _dependenciesPlanckLengthGenerated = require(\"./dependenciesAny/dependenciesPlanckLength.generated.js\");\n\nvar _dependenciesPlanckMassGenerated = require(\"./dependenciesAny/dependenciesPlanckMass.generated.js\");\n\nvar _dependenciesPlanckTemperatureGenerated = require(\"./dependenciesAny/dependenciesPlanckTemperature.generated.js\");\n\nvar _dependenciesPlanckTimeGenerated = require(\"./dependenciesAny/dependenciesPlanckTime.generated.js\");\n\nvar _dependenciesPowGenerated = require(\"./dependenciesAny/dependenciesPow.generated.js\");\n\nvar _dependenciesPrintGenerated = require(\"./dependenciesAny/dependenciesPrint.generated.js\");\n\nvar _dependenciesProdGenerated = require(\"./dependenciesAny/dependenciesProd.generated.js\");\n\nvar _dependenciesProtonMassGenerated = require(\"./dependenciesAny/dependenciesProtonMass.generated.js\");\n\nvar _dependenciesQrGenerated = require(\"./dependenciesAny/dependenciesQr.generated.js\");\n\nvar _dependenciesQuantileSeqGenerated = require(\"./dependenciesAny/dependenciesQuantileSeq.generated.js\");\n\nvar _dependenciesQuantumOfCirculationGenerated = require(\"./dependenciesAny/dependenciesQuantumOfCirculation.generated.js\");\n\nvar _dependenciesRandomGenerated = require(\"./dependenciesAny/dependenciesRandom.generated.js\");\n\nvar _dependenciesRandomIntGenerated = require(\"./dependenciesAny/dependenciesRandomInt.generated.js\");\n\nvar _dependenciesRangeGenerated = require(\"./dependenciesAny/dependenciesRange.generated.js\");\n\nvar _dependenciesRangeClassGenerated = require(\"./dependenciesAny/dependenciesRangeClass.generated.js\");\n\nvar _dependenciesRangeNodeGenerated = require(\"./dependenciesAny/dependenciesRangeNode.generated.js\");\n\nvar _dependenciesRangeTransformGenerated = require(\"./dependenciesAny/dependenciesRangeTransform.generated.js\");\n\nvar _dependenciesRationalizeGenerated = require(\"./dependenciesAny/dependenciesRationalize.generated.js\");\n\nvar _dependenciesReGenerated = require(\"./dependenciesAny/dependenciesRe.generated.js\");\n\nvar _dependenciesReducedPlanckConstantGenerated = require(\"./dependenciesAny/dependenciesReducedPlanckConstant.generated.js\");\n\nvar _dependenciesRelationalNodeGenerated = require(\"./dependenciesAny/dependenciesRelationalNode.generated.js\");\n\nvar _dependenciesReplacerGenerated = require(\"./dependenciesAny/dependenciesReplacer.generated.js\");\n\nvar _dependenciesReshapeGenerated = require(\"./dependenciesAny/dependenciesReshape.generated.js\");\n\nvar _dependenciesResizeGenerated = require(\"./dependenciesAny/dependenciesResize.generated.js\");\n\nvar _dependenciesResolveGenerated = require(\"./dependenciesAny/dependenciesResolve.generated.js\");\n\nvar _dependenciesResultSetGenerated = require(\"./dependenciesAny/dependenciesResultSet.generated.js\");\n\nvar _dependenciesReviverGenerated = require(\"./dependenciesAny/dependenciesReviver.generated.js\");\n\nvar _dependenciesRightArithShiftGenerated = require(\"./dependenciesAny/dependenciesRightArithShift.generated.js\");\n\nvar _dependenciesRightLogShiftGenerated = require(\"./dependenciesAny/dependenciesRightLogShift.generated.js\");\n\nvar _dependenciesRotateGenerated = require(\"./dependenciesAny/dependenciesRotate.generated.js\");\n\nvar _dependenciesRotationMatrixGenerated = require(\"./dependenciesAny/dependenciesRotationMatrix.generated.js\");\n\nvar _dependenciesRoundGenerated = require(\"./dependenciesAny/dependenciesRound.generated.js\");\n\nvar _dependenciesRowGenerated = require(\"./dependenciesAny/dependenciesRow.generated.js\");\n\nvar _dependenciesRowTransformGenerated = require(\"./dependenciesAny/dependenciesRowTransform.generated.js\");\n\nvar _dependenciesRydbergGenerated = require(\"./dependenciesAny/dependenciesRydberg.generated.js\");\n\nvar _dependenciesSQRT1_2Generated = require(\"./dependenciesAny/dependenciesSQRT1_2.generated.js\");\n\nvar _dependenciesSQRT2Generated = require(\"./dependenciesAny/dependenciesSQRT2.generated.js\");\n\nvar _dependenciesSackurTetrodeGenerated = require(\"./dependenciesAny/dependenciesSackurTetrode.generated.js\");\n\nvar _dependenciesSecGenerated = require(\"./dependenciesAny/dependenciesSec.generated.js\");\n\nvar _dependenciesSechGenerated = require(\"./dependenciesAny/dependenciesSech.generated.js\");\n\nvar _dependenciesSecondRadiationGenerated = require(\"./dependenciesAny/dependenciesSecondRadiation.generated.js\");\n\nvar _dependenciesSetCartesianGenerated = require(\"./dependenciesAny/dependenciesSetCartesian.generated.js\");\n\nvar _dependenciesSetDifferenceGenerated = require(\"./dependenciesAny/dependenciesSetDifference.generated.js\");\n\nvar _dependenciesSetDistinctGenerated = require(\"./dependenciesAny/dependenciesSetDistinct.generated.js\");\n\nvar _dependenciesSetIntersectGenerated = require(\"./dependenciesAny/dependenciesSetIntersect.generated.js\");\n\nvar _dependenciesSetIsSubsetGenerated = require(\"./dependenciesAny/dependenciesSetIsSubset.generated.js\");\n\nvar _dependenciesSetMultiplicityGenerated = require(\"./dependenciesAny/dependenciesSetMultiplicity.generated.js\");\n\nvar _dependenciesSetPowersetGenerated = require(\"./dependenciesAny/dependenciesSetPowerset.generated.js\");\n\nvar _dependenciesSetSizeGenerated = require(\"./dependenciesAny/dependenciesSetSize.generated.js\");\n\nvar _dependenciesSetSymDifferenceGenerated = require(\"./dependenciesAny/dependenciesSetSymDifference.generated.js\");\n\nvar _dependenciesSetUnionGenerated = require(\"./dependenciesAny/dependenciesSetUnion.generated.js\");\n\nvar _dependenciesSignGenerated = require(\"./dependenciesAny/dependenciesSign.generated.js\");\n\nvar _dependenciesSimplifyGenerated = require(\"./dependenciesAny/dependenciesSimplify.generated.js\");\n\nvar _dependenciesSimplifyCoreGenerated = require(\"./dependenciesAny/dependenciesSimplifyCore.generated.js\");\n\nvar _dependenciesSinGenerated = require(\"./dependenciesAny/dependenciesSin.generated.js\");\n\nvar _dependenciesSinhGenerated = require(\"./dependenciesAny/dependenciesSinh.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesAny/dependenciesSize.generated.js\");\n\nvar _dependenciesSluGenerated = require(\"./dependenciesAny/dependenciesSlu.generated.js\");\n\nvar _dependenciesSmallerGenerated = require(\"./dependenciesAny/dependenciesSmaller.generated.js\");\n\nvar _dependenciesSmallerEqGenerated = require(\"./dependenciesAny/dependenciesSmallerEq.generated.js\");\n\nvar _dependenciesSortGenerated = require(\"./dependenciesAny/dependenciesSort.generated.js\");\n\nvar _dependenciesSpaClassGenerated = require(\"./dependenciesAny/dependenciesSpaClass.generated.js\");\n\nvar _dependenciesSparseGenerated = require(\"./dependenciesAny/dependenciesSparse.generated.js\");\n\nvar _dependenciesSparseMatrixClassGenerated = require(\"./dependenciesAny/dependenciesSparseMatrixClass.generated.js\");\n\nvar _dependenciesSpeedOfLightGenerated = require(\"./dependenciesAny/dependenciesSpeedOfLight.generated.js\");\n\nvar _dependenciesSplitUnitGenerated = require(\"./dependenciesAny/dependenciesSplitUnit.generated.js\");\n\nvar _dependenciesSqrtGenerated = require(\"./dependenciesAny/dependenciesSqrt.generated.js\");\n\nvar _dependenciesSqrtmGenerated = require(\"./dependenciesAny/dependenciesSqrtm.generated.js\");\n\nvar _dependenciesSquareGenerated = require(\"./dependenciesAny/dependenciesSquare.generated.js\");\n\nvar _dependenciesSqueezeGenerated = require(\"./dependenciesAny/dependenciesSqueeze.generated.js\");\n\nvar _dependenciesStdGenerated = require(\"./dependenciesAny/dependenciesStd.generated.js\");\n\nvar _dependenciesStdTransformGenerated = require(\"./dependenciesAny/dependenciesStdTransform.generated.js\");\n\nvar _dependenciesStefanBoltzmannGenerated = require(\"./dependenciesAny/dependenciesStefanBoltzmann.generated.js\");\n\nvar _dependenciesStirlingS2Generated = require(\"./dependenciesAny/dependenciesStirlingS2.generated.js\");\n\nvar _dependenciesStringGenerated = require(\"./dependenciesAny/dependenciesString.generated.js\");\n\nvar _dependenciesSubsetGenerated = require(\"./dependenciesAny/dependenciesSubset.generated.js\");\n\nvar _dependenciesSubsetTransformGenerated = require(\"./dependenciesAny/dependenciesSubsetTransform.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesAny/dependenciesSubtract.generated.js\");\n\nvar _dependenciesSumGenerated = require(\"./dependenciesAny/dependenciesSum.generated.js\");\n\nvar _dependenciesSumTransformGenerated = require(\"./dependenciesAny/dependenciesSumTransform.generated.js\");\n\nvar _dependenciesSymbolNodeGenerated = require(\"./dependenciesAny/dependenciesSymbolNode.generated.js\");\n\nvar _dependenciesSymbolicEqualGenerated = require(\"./dependenciesAny/dependenciesSymbolicEqual.generated.js\");\n\nvar _dependenciesTanGenerated = require(\"./dependenciesAny/dependenciesTan.generated.js\");\n\nvar _dependenciesTanhGenerated = require(\"./dependenciesAny/dependenciesTanh.generated.js\");\n\nvar _dependenciesTauGenerated = require(\"./dependenciesAny/dependenciesTau.generated.js\");\n\nvar _dependenciesThomsonCrossSectionGenerated = require(\"./dependenciesAny/dependenciesThomsonCrossSection.generated.js\");\n\nvar _dependenciesToGenerated = require(\"./dependenciesAny/dependenciesTo.generated.js\");\n\nvar _dependenciesTraceGenerated = require(\"./dependenciesAny/dependenciesTrace.generated.js\");\n\nvar _dependenciesTransposeGenerated = require(\"./dependenciesAny/dependenciesTranspose.generated.js\");\n\nvar _dependenciesTrueGenerated = require(\"./dependenciesAny/dependenciesTrue.generated.js\");\n\nvar _dependenciesTypeOfGenerated = require(\"./dependenciesAny/dependenciesTypeOf.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesAny/dependenciesTyped.generated.js\");\n\nvar _dependenciesUnaryMinusGenerated = require(\"./dependenciesAny/dependenciesUnaryMinus.generated.js\");\n\nvar _dependenciesUnaryPlusGenerated = require(\"./dependenciesAny/dependenciesUnaryPlus.generated.js\");\n\nvar _dependenciesUnequalGenerated = require(\"./dependenciesAny/dependenciesUnequal.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesAny/dependenciesUnitClass.generated.js\");\n\nvar _dependenciesUnitFunctionGenerated = require(\"./dependenciesAny/dependenciesUnitFunction.generated.js\");\n\nvar _dependenciesUppercaseEGenerated = require(\"./dependenciesAny/dependenciesUppercaseE.generated.js\");\n\nvar _dependenciesUppercasePiGenerated = require(\"./dependenciesAny/dependenciesUppercasePi.generated.js\");\n\nvar _dependenciesUsolveGenerated = require(\"./dependenciesAny/dependenciesUsolve.generated.js\");\n\nvar _dependenciesUsolveAllGenerated = require(\"./dependenciesAny/dependenciesUsolveAll.generated.js\");\n\nvar _dependenciesVacuumImpedanceGenerated = require(\"./dependenciesAny/dependenciesVacuumImpedance.generated.js\");\n\nvar _dependenciesVarianceGenerated = require(\"./dependenciesAny/dependenciesVariance.generated.js\");\n\nvar _dependenciesVarianceTransformGenerated = require(\"./dependenciesAny/dependenciesVarianceTransform.generated.js\");\n\nvar _dependenciesVersionGenerated = require(\"./dependenciesAny/dependenciesVersion.generated.js\");\n\nvar _dependenciesWeakMixingAngleGenerated = require(\"./dependenciesAny/dependenciesWeakMixingAngle.generated.js\");\n\nvar _dependenciesWienDisplacementGenerated = require(\"./dependenciesAny/dependenciesWienDisplacement.generated.js\");\n\nvar _dependenciesXgcdGenerated = require(\"./dependenciesAny/dependenciesXgcd.generated.js\");\n\nvar _dependenciesXorGenerated = require(\"./dependenciesAny/dependenciesXor.generated.js\");\n\nvar _dependenciesZerosGenerated = require(\"./dependenciesAny/dependenciesZeros.generated.js\");\n\nvar _allFactoriesAny = require(\"./allFactoriesAny.js\");","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.absDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar absDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAbs: _factoriesAny.createAbs\n};\nexports.absDependencies = absDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.AccessorNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _dependenciesSubsetGenerated = require(\"./dependenciesSubset.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar AccessorNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies,\n createAccessorNode: _factoriesAny.createAccessorNode\n};\nexports.AccessorNodeDependencies = AccessorNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acosDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar acosDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAcos: _factoriesAny.createAcos\n};\nexports.acosDependencies = acosDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acoshDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar acoshDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAcosh: _factoriesAny.createAcosh\n};\nexports.acoshDependencies = acoshDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acotDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar acotDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAcot: _factoriesAny.createAcot\n};\nexports.acotDependencies = acotDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acothDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar acothDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAcoth: _factoriesAny.createAcoth\n};\nexports.acothDependencies = acothDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acscDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar acscDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAcsc: _factoriesAny.createAcsc\n};\nexports.acscDependencies = acscDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acschDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar acschDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAcsch: _factoriesAny.createAcsch\n};\nexports.acschDependencies = acschDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.addDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesSparseMatrixClassGenerated = require(\"./dependenciesSparseMatrixClass.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar addDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies,\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAdd: _factoriesAny.createAdd\n};\nexports.addDependencies = addDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.addScalarDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar addScalarDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAddScalar: _factoriesAny.createAddScalar\n};\nexports.addScalarDependencies = addScalarDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.andDependencies = void 0;\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesNotGenerated = require(\"./dependenciesNot.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesZerosGenerated = require(\"./dependenciesZeros.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar andDependencies = {\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n notDependencies: _dependenciesNotGenerated.notDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n zerosDependencies: _dependenciesZerosGenerated.zerosDependencies,\n createAnd: _factoriesAny.createAnd\n};\nexports.andDependencies = andDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.applyDependencies = void 0;\n\nvar _dependenciesIsIntegerGenerated = require(\"./dependenciesIsInteger.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar applyDependencies = {\n isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createApply: _factoriesAny.createApply\n};\nexports.applyDependencies = applyDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.applyTransformDependencies = void 0;\n\nvar _dependenciesIsIntegerGenerated = require(\"./dependenciesIsInteger.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar applyTransformDependencies = {\n isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createApplyTransform: _factoriesAny.createApplyTransform\n};\nexports.applyTransformDependencies = applyTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.argDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar argDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createArg: _factoriesAny.createArg\n};\nexports.argDependencies = argDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ArrayNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ArrayNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n createArrayNode: _factoriesAny.createArrayNode\n};\nexports.ArrayNodeDependencies = ArrayNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.asecDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar asecDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAsec: _factoriesAny.createAsec\n};\nexports.asecDependencies = asecDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.asechDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar asechDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAsech: _factoriesAny.createAsech\n};\nexports.asechDependencies = asechDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.asinDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar asinDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAsin: _factoriesAny.createAsin\n};\nexports.asinDependencies = asinDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.asinhDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar asinhDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAsinh: _factoriesAny.createAsinh\n};\nexports.asinhDependencies = asinhDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.AssignmentNodeDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _dependenciesSubsetGenerated = require(\"./dependenciesSubset.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar AssignmentNodeDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies,\n createAssignmentNode: _factoriesAny.createAssignmentNode\n};\nexports.AssignmentNodeDependencies = AssignmentNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.atanDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar atanDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAtan: _factoriesAny.createAtan\n};\nexports.atanDependencies = atanDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.atan2Dependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar atan2Dependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAtan2: _factoriesAny.createAtan2\n};\nexports.atan2Dependencies = atan2Dependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.atanhDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar atanhDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createAtanh: _factoriesAny.createAtanh\n};\nexports.atanhDependencies = atanhDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.atomicMassDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar atomicMassDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createAtomicMass: _factoriesAny.createAtomicMass\n};\nexports.atomicMassDependencies = atomicMassDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.avogadroDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar avogadroDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createAvogadro: _factoriesAny.createAvogadro\n};\nexports.avogadroDependencies = avogadroDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bellNumbersDependencies = void 0;\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesIsIntegerGenerated = require(\"./dependenciesIsInteger.generated.js\");\n\nvar _dependenciesIsNegativeGenerated = require(\"./dependenciesIsNegative.generated.js\");\n\nvar _dependenciesStirlingS2Generated = require(\"./dependenciesStirlingS2.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar bellNumbersDependencies = {\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies,\n isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies,\n stirlingS2Dependencies: _dependenciesStirlingS2Generated.stirlingS2Dependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createBellNumbers: _factoriesAny.createBellNumbers\n};\nexports.bellNumbersDependencies = bellNumbersDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.BigNumberDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar BigNumberDependencies = {\n createBigNumberClass: _factoriesAny.createBigNumberClass\n};\nexports.BigNumberDependencies = BigNumberDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bignumberDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar bignumberDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createBignumber: _factoriesAny.createBignumber\n};\nexports.bignumberDependencies = bignumberDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.binDependencies = void 0;\n\nvar _dependenciesFormatGenerated = require(\"./dependenciesFormat.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar binDependencies = {\n formatDependencies: _dependenciesFormatGenerated.formatDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createBin: _factoriesAny.createBin\n};\nexports.binDependencies = binDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bitAndDependencies = void 0;\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar bitAndDependencies = {\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createBitAnd: _factoriesAny.createBitAnd\n};\nexports.bitAndDependencies = bitAndDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bitNotDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar bitNotDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createBitNot: _factoriesAny.createBitNot\n};\nexports.bitNotDependencies = bitNotDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bitOrDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar bitOrDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createBitOr: _factoriesAny.createBitOr\n};\nexports.bitOrDependencies = bitOrDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bitXorDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar bitXorDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createBitXor: _factoriesAny.createBitXor\n};\nexports.bitXorDependencies = bitXorDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.BlockNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _dependenciesResultSetGenerated = require(\"./dependenciesResultSet.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar BlockNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n ResultSetDependencies: _dependenciesResultSetGenerated.ResultSetDependencies,\n createBlockNode: _factoriesAny.createBlockNode\n};\nexports.BlockNodeDependencies = BlockNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bohrMagnetonDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar bohrMagnetonDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createBohrMagneton: _factoriesAny.createBohrMagneton\n};\nexports.bohrMagnetonDependencies = bohrMagnetonDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bohrRadiusDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar bohrRadiusDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createBohrRadius: _factoriesAny.createBohrRadius\n};\nexports.bohrRadiusDependencies = bohrRadiusDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.boltzmannDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar boltzmannDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createBoltzmann: _factoriesAny.createBoltzmann\n};\nexports.boltzmannDependencies = boltzmannDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.booleanDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar booleanDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createBoolean: _factoriesAny.createBoolean\n};\nexports.booleanDependencies = booleanDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.catalanDependencies = void 0;\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesCombinationsGenerated = require(\"./dependenciesCombinations.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesIsIntegerGenerated = require(\"./dependenciesIsInteger.generated.js\");\n\nvar _dependenciesIsNegativeGenerated = require(\"./dependenciesIsNegative.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar catalanDependencies = {\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n combinationsDependencies: _dependenciesCombinationsGenerated.combinationsDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies,\n isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCatalan: _factoriesAny.createCatalan\n};\nexports.catalanDependencies = catalanDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cbrtDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesFractionClassGenerated = require(\"./dependenciesFractionClass.generated.js\");\n\nvar _dependenciesIsNegativeGenerated = require(\"./dependenciesIsNegative.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesUnaryMinusGenerated = require(\"./dependenciesUnaryMinus.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar cbrtDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n FractionDependencies: _dependenciesFractionClassGenerated.FractionDependencies,\n isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies,\n createCbrt: _factoriesAny.createCbrt\n};\nexports.cbrtDependencies = cbrtDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ceilDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesRoundGenerated = require(\"./dependenciesRound.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesZerosGenerated = require(\"./dependenciesZeros.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ceilDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n roundDependencies: _dependenciesRoundGenerated.roundDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n zerosDependencies: _dependenciesZerosGenerated.zerosDependencies,\n createCeil: _factoriesAny.createCeil\n};\nexports.ceilDependencies = ceilDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.chainDependencies = void 0;\n\nvar _dependenciesChainClassGenerated = require(\"./dependenciesChainClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar chainDependencies = {\n ChainDependencies: _dependenciesChainClassGenerated.ChainDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createChain: _factoriesAny.createChain\n};\nexports.chainDependencies = chainDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ChainDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ChainDependencies = {\n createChainClass: _factoriesAny.createChainClass\n};\nexports.ChainDependencies = ChainDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.classicalElectronRadiusDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar classicalElectronRadiusDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createClassicalElectronRadius: _factoriesAny.createClassicalElectronRadius\n};\nexports.classicalElectronRadiusDependencies = classicalElectronRadiusDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cloneDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar cloneDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createClone: _factoriesAny.createClone\n};\nexports.cloneDependencies = cloneDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.columnDependencies = void 0;\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesRangeGenerated = require(\"./dependenciesRange.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar columnDependencies = {\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n rangeDependencies: _dependenciesRangeGenerated.rangeDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createColumn: _factoriesAny.createColumn\n};\nexports.columnDependencies = columnDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.columnTransformDependencies = void 0;\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesRangeGenerated = require(\"./dependenciesRange.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar columnTransformDependencies = {\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n rangeDependencies: _dependenciesRangeGenerated.rangeDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createColumnTransform: _factoriesAny.createColumnTransform\n};\nexports.columnTransformDependencies = columnTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.combinationsDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar combinationsDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCombinations: _factoriesAny.createCombinations\n};\nexports.combinationsDependencies = combinationsDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.combinationsWithRepDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar combinationsWithRepDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCombinationsWithRep: _factoriesAny.createCombinationsWithRep\n};\nexports.combinationsWithRepDependencies = combinationsWithRepDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.compareDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesFractionClassGenerated = require(\"./dependenciesFractionClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar compareDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n FractionDependencies: _dependenciesFractionClassGenerated.FractionDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCompare: _factoriesAny.createCompare\n};\nexports.compareDependencies = compareDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.compareNaturalDependencies = void 0;\n\nvar _dependenciesCompareGenerated = require(\"./dependenciesCompare.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar compareNaturalDependencies = {\n compareDependencies: _dependenciesCompareGenerated.compareDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCompareNatural: _factoriesAny.createCompareNatural\n};\nexports.compareNaturalDependencies = compareNaturalDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.compareTextDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar compareTextDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCompareText: _factoriesAny.createCompareText\n};\nexports.compareTextDependencies = compareTextDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.compileDependencies = void 0;\n\nvar _dependenciesParseGenerated = require(\"./dependenciesParse.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar compileDependencies = {\n parseDependencies: _dependenciesParseGenerated.parseDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCompile: _factoriesAny.createCompile\n};\nexports.compileDependencies = compileDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.complexDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar complexDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createComplex: _factoriesAny.createComplex\n};\nexports.complexDependencies = complexDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ComplexDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ComplexDependencies = {\n createComplexClass: _factoriesAny.createComplexClass\n};\nexports.ComplexDependencies = ComplexDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.compositionDependencies = void 0;\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesCombinationsGenerated = require(\"./dependenciesCombinations.generated.js\");\n\nvar _dependenciesIsIntegerGenerated = require(\"./dependenciesIsInteger.generated.js\");\n\nvar _dependenciesIsNegativeGenerated = require(\"./dependenciesIsNegative.generated.js\");\n\nvar _dependenciesIsPositiveGenerated = require(\"./dependenciesIsPositive.generated.js\");\n\nvar _dependenciesLargerGenerated = require(\"./dependenciesLarger.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar compositionDependencies = {\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n combinationsDependencies: _dependenciesCombinationsGenerated.combinationsDependencies,\n isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies,\n isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies,\n isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies,\n largerDependencies: _dependenciesLargerGenerated.largerDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createComposition: _factoriesAny.createComposition\n};\nexports.compositionDependencies = compositionDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.concatDependencies = void 0;\n\nvar _dependenciesIsIntegerGenerated = require(\"./dependenciesIsInteger.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar concatDependencies = {\n isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createConcat: _factoriesAny.createConcat\n};\nexports.concatDependencies = concatDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.concatTransformDependencies = void 0;\n\nvar _dependenciesIsIntegerGenerated = require(\"./dependenciesIsInteger.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar concatTransformDependencies = {\n isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createConcatTransform: _factoriesAny.createConcatTransform\n};\nexports.concatTransformDependencies = concatTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ConditionalNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ConditionalNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n createConditionalNode: _factoriesAny.createConditionalNode\n};\nexports.ConditionalNodeDependencies = ConditionalNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.conductanceQuantumDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar conductanceQuantumDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createConductanceQuantum: _factoriesAny.createConductanceQuantum\n};\nexports.conductanceQuantumDependencies = conductanceQuantumDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.conjDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar conjDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createConj: _factoriesAny.createConj\n};\nexports.conjDependencies = conjDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ConstantNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ConstantNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n createConstantNode: _factoriesAny.createConstantNode\n};\nexports.ConstantNodeDependencies = ConstantNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cosDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar cosDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCos: _factoriesAny.createCos\n};\nexports.cosDependencies = cosDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.coshDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar coshDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCosh: _factoriesAny.createCosh\n};\nexports.coshDependencies = coshDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cotDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar cotDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCot: _factoriesAny.createCot\n};\nexports.cotDependencies = cotDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cothDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar cothDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCoth: _factoriesAny.createCoth\n};\nexports.cothDependencies = cothDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.coulombDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar coulombDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createCoulomb: _factoriesAny.createCoulomb\n};\nexports.coulombDependencies = coulombDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.countDependencies = void 0;\n\nvar _dependenciesProdGenerated = require(\"./dependenciesProd.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar countDependencies = {\n prodDependencies: _dependenciesProdGenerated.prodDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCount: _factoriesAny.createCount\n};\nexports.countDependencies = countDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createUnitDependencies = void 0;\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar createUnitDependencies = {\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCreateUnit: _factoriesAny.createCreateUnit\n};\nexports.createUnitDependencies = createUnitDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.crossDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar crossDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCross: _factoriesAny.createCross\n};\nexports.crossDependencies = crossDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cscDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar cscDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCsc: _factoriesAny.createCsc\n};\nexports.cscDependencies = cscDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cschDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar cschDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCsch: _factoriesAny.createCsch\n};\nexports.cschDependencies = cschDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ctransposeDependencies = void 0;\n\nvar _dependenciesConjGenerated = require(\"./dependenciesConj.generated.js\");\n\nvar _dependenciesTransposeGenerated = require(\"./dependenciesTranspose.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ctransposeDependencies = {\n conjDependencies: _dependenciesConjGenerated.conjDependencies,\n transposeDependencies: _dependenciesTransposeGenerated.transposeDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCtranspose: _factoriesAny.createCtranspose\n};\nexports.ctransposeDependencies = ctransposeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cubeDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar cubeDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createCube: _factoriesAny.createCube\n};\nexports.cubeDependencies = cubeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cumsumDependencies = void 0;\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesUnaryPlusGenerated = require(\"./dependenciesUnaryPlus.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar cumsumDependencies = {\n addDependencies: _dependenciesAddGenerated.addDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n unaryPlusDependencies: _dependenciesUnaryPlusGenerated.unaryPlusDependencies,\n createCumSum: _factoriesAny.createCumSum\n};\nexports.cumsumDependencies = cumsumDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cumsumTransformDependencies = void 0;\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesUnaryPlusGenerated = require(\"./dependenciesUnaryPlus.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar cumsumTransformDependencies = {\n addDependencies: _dependenciesAddGenerated.addDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n unaryPlusDependencies: _dependenciesUnaryPlusGenerated.unaryPlusDependencies,\n createCumSumTransform: _factoriesAny.createCumSumTransform\n};\nexports.cumsumTransformDependencies = cumsumTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.deepEqualDependencies = void 0;\n\nvar _dependenciesEqualGenerated = require(\"./dependenciesEqual.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar deepEqualDependencies = {\n equalDependencies: _dependenciesEqualGenerated.equalDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createDeepEqual: _factoriesAny.createDeepEqual\n};\nexports.deepEqualDependencies = deepEqualDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.DenseMatrixDependencies = void 0;\n\nvar _dependenciesMatrixClassGenerated = require(\"./dependenciesMatrixClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar DenseMatrixDependencies = {\n MatrixDependencies: _dependenciesMatrixClassGenerated.MatrixDependencies,\n createDenseMatrixClass: _factoriesAny.createDenseMatrixClass\n};\nexports.DenseMatrixDependencies = DenseMatrixDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.derivativeDependencies = void 0;\n\nvar _dependenciesConstantNodeGenerated = require(\"./dependenciesConstantNode.generated.js\");\n\nvar _dependenciesFunctionNodeGenerated = require(\"./dependenciesFunctionNode.generated.js\");\n\nvar _dependenciesOperatorNodeGenerated = require(\"./dependenciesOperatorNode.generated.js\");\n\nvar _dependenciesParenthesisNodeGenerated = require(\"./dependenciesParenthesisNode.generated.js\");\n\nvar _dependenciesSymbolNodeGenerated = require(\"./dependenciesSymbolNode.generated.js\");\n\nvar _dependenciesEqualGenerated = require(\"./dependenciesEqual.generated.js\");\n\nvar _dependenciesIsZeroGenerated = require(\"./dependenciesIsZero.generated.js\");\n\nvar _dependenciesNumericGenerated = require(\"./dependenciesNumeric.generated.js\");\n\nvar _dependenciesParseGenerated = require(\"./dependenciesParse.generated.js\");\n\nvar _dependenciesSimplifyGenerated = require(\"./dependenciesSimplify.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar derivativeDependencies = {\n ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies,\n FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies,\n OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies,\n ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies,\n SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies,\n equalDependencies: _dependenciesEqualGenerated.equalDependencies,\n isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies,\n numericDependencies: _dependenciesNumericGenerated.numericDependencies,\n parseDependencies: _dependenciesParseGenerated.parseDependencies,\n simplifyDependencies: _dependenciesSimplifyGenerated.simplifyDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createDerivative: _factoriesAny.createDerivative\n};\nexports.derivativeDependencies = derivativeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.detDependencies = void 0;\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesIsZeroGenerated = require(\"./dependenciesIsZero.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesUnaryMinusGenerated = require(\"./dependenciesUnaryMinus.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar detDependencies = {\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies,\n createDet: _factoriesAny.createDet\n};\nexports.detDependencies = detDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.deuteronMassDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar deuteronMassDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createDeuteronMass: _factoriesAny.createDeuteronMass\n};\nexports.deuteronMassDependencies = deuteronMassDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.diagDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesSparseMatrixClassGenerated = require(\"./dependenciesSparseMatrixClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar diagDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createDiag: _factoriesAny.createDiag\n};\nexports.diagDependencies = diagDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.diffDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesNumberGenerated = require(\"./dependenciesNumber.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar diffDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n numberDependencies: _dependenciesNumberGenerated.numberDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createDiff: _factoriesAny.createDiff\n};\nexports.diffDependencies = diffDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.diffTransformDependencies = void 0;\n\nvar _dependenciesBignumberGenerated = require(\"./dependenciesBignumber.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesNumberGenerated = require(\"./dependenciesNumber.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar diffTransformDependencies = {\n bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n numberDependencies: _dependenciesNumberGenerated.numberDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createDiffTransform: _factoriesAny.createDiffTransform\n};\nexports.diffTransformDependencies = diffTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.distanceDependencies = void 0;\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAbs.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesSqrtGenerated = require(\"./dependenciesSqrt.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesUnaryMinusGenerated = require(\"./dependenciesUnaryMinus.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar distanceDependencies = {\n absDependencies: _dependenciesAbsGenerated.absDependencies,\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies,\n createDistance: _factoriesAny.createDistance\n};\nexports.distanceDependencies = distanceDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.divideDependencies = void 0;\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesInvGenerated = require(\"./dependenciesInv.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar divideDependencies = {\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n invDependencies: _dependenciesInvGenerated.invDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createDivide: _factoriesAny.createDivide\n};\nexports.divideDependencies = divideDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.divideScalarDependencies = void 0;\n\nvar _dependenciesNumericGenerated = require(\"./dependenciesNumeric.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar divideScalarDependencies = {\n numericDependencies: _dependenciesNumericGenerated.numericDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createDivideScalar: _factoriesAny.createDivideScalar\n};\nexports.divideScalarDependencies = divideScalarDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.dotDependencies = void 0;\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesConjGenerated = require(\"./dependenciesConj.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar dotDependencies = {\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n conjDependencies: _dependenciesConjGenerated.conjDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createDot: _factoriesAny.createDot\n};\nexports.dotDependencies = dotDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.dotDivideDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar dotDivideDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createDotDivide: _factoriesAny.createDotDivide\n};\nexports.dotDivideDependencies = dotDivideDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.dotMultiplyDependencies = void 0;\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar dotMultiplyDependencies = {\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createDotMultiply: _factoriesAny.createDotMultiply\n};\nexports.dotMultiplyDependencies = dotMultiplyDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.dotPowDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesPowGenerated = require(\"./dependenciesPow.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar dotPowDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n powDependencies: _dependenciesPowGenerated.powDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createDotPow: _factoriesAny.createDotPow\n};\nexports.dotPowDependencies = dotPowDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.eDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar eDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createE: _factoriesAny.createE\n};\nexports.eDependencies = eDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.efimovFactorDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar efimovFactorDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createEfimovFactor: _factoriesAny.createEfimovFactor\n};\nexports.efimovFactorDependencies = efimovFactorDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.eigsDependencies = void 0;\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAbs.generated.js\");\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesAtanGenerated = require(\"./dependenciesAtan.generated.js\");\n\nvar _dependenciesBignumberGenerated = require(\"./dependenciesBignumber.generated.js\");\n\nvar _dependenciesColumnGenerated = require(\"./dependenciesColumn.generated.js\");\n\nvar _dependenciesComplexGenerated = require(\"./dependenciesComplex.generated.js\");\n\nvar _dependenciesCosGenerated = require(\"./dependenciesCos.generated.js\");\n\nvar _dependenciesDiagGenerated = require(\"./dependenciesDiag.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesDotGenerated = require(\"./dependenciesDot.generated.js\");\n\nvar _dependenciesEqualGenerated = require(\"./dependenciesEqual.generated.js\");\n\nvar _dependenciesFlattenGenerated = require(\"./dependenciesFlatten.generated.js\");\n\nvar _dependenciesImGenerated = require(\"./dependenciesIm.generated.js\");\n\nvar _dependenciesInvGenerated = require(\"./dependenciesInv.generated.js\");\n\nvar _dependenciesLargerGenerated = require(\"./dependenciesLarger.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMatrixFromColumnsGenerated = require(\"./dependenciesMatrixFromColumns.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesNumberGenerated = require(\"./dependenciesNumber.generated.js\");\n\nvar _dependenciesQrGenerated = require(\"./dependenciesQr.generated.js\");\n\nvar _dependenciesReGenerated = require(\"./dependenciesRe.generated.js\");\n\nvar _dependenciesSinGenerated = require(\"./dependenciesSin.generated.js\");\n\nvar _dependenciesSmallerGenerated = require(\"./dependenciesSmaller.generated.js\");\n\nvar _dependenciesSqrtGenerated = require(\"./dependenciesSqrt.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesUsolveGenerated = require(\"./dependenciesUsolve.generated.js\");\n\nvar _dependenciesUsolveAllGenerated = require(\"./dependenciesUsolveAll.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar eigsDependencies = {\n absDependencies: _dependenciesAbsGenerated.absDependencies,\n addDependencies: _dependenciesAddGenerated.addDependencies,\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n atanDependencies: _dependenciesAtanGenerated.atanDependencies,\n bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies,\n columnDependencies: _dependenciesColumnGenerated.columnDependencies,\n complexDependencies: _dependenciesComplexGenerated.complexDependencies,\n cosDependencies: _dependenciesCosGenerated.cosDependencies,\n diagDependencies: _dependenciesDiagGenerated.diagDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n dotDependencies: _dependenciesDotGenerated.dotDependencies,\n equalDependencies: _dependenciesEqualGenerated.equalDependencies,\n flattenDependencies: _dependenciesFlattenGenerated.flattenDependencies,\n imDependencies: _dependenciesImGenerated.imDependencies,\n invDependencies: _dependenciesInvGenerated.invDependencies,\n largerDependencies: _dependenciesLargerGenerated.largerDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n matrixFromColumnsDependencies: _dependenciesMatrixFromColumnsGenerated.matrixFromColumnsDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n numberDependencies: _dependenciesNumberGenerated.numberDependencies,\n qrDependencies: _dependenciesQrGenerated.qrDependencies,\n reDependencies: _dependenciesReGenerated.reDependencies,\n sinDependencies: _dependenciesSinGenerated.sinDependencies,\n smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies,\n sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n usolveDependencies: _dependenciesUsolveGenerated.usolveDependencies,\n usolveAllDependencies: _dependenciesUsolveAllGenerated.usolveAllDependencies,\n createEigs: _factoriesAny.createEigs\n};\nexports.eigsDependencies = eigsDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.electricConstantDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar electricConstantDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createElectricConstant: _factoriesAny.createElectricConstant\n};\nexports.electricConstantDependencies = electricConstantDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.electronMassDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar electronMassDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createElectronMass: _factoriesAny.createElectronMass\n};\nexports.electronMassDependencies = electronMassDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.elementaryChargeDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar elementaryChargeDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createElementaryCharge: _factoriesAny.createElementaryCharge\n};\nexports.elementaryChargeDependencies = elementaryChargeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.equalDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar equalDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createEqual: _factoriesAny.createEqual\n};\nexports.equalDependencies = equalDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.equalScalarDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar equalScalarDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createEqualScalar: _factoriesAny.createEqualScalar\n};\nexports.equalScalarDependencies = equalScalarDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.equalTextDependencies = void 0;\n\nvar _dependenciesCompareTextGenerated = require(\"./dependenciesCompareText.generated.js\");\n\nvar _dependenciesIsZeroGenerated = require(\"./dependenciesIsZero.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar equalTextDependencies = {\n compareTextDependencies: _dependenciesCompareTextGenerated.compareTextDependencies,\n isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createEqualText: _factoriesAny.createEqualText\n};\nexports.equalTextDependencies = equalTextDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.erfDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar erfDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createErf: _factoriesAny.createErf\n};\nexports.erfDependencies = erfDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.evaluateDependencies = void 0;\n\nvar _dependenciesParseGenerated = require(\"./dependenciesParse.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar evaluateDependencies = {\n parseDependencies: _dependenciesParseGenerated.parseDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createEvaluate: _factoriesAny.createEvaluate\n};\nexports.evaluateDependencies = evaluateDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.expDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar expDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createExp: _factoriesAny.createExp\n};\nexports.expDependencies = expDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.expmDependencies = void 0;\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAbs.generated.js\");\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesIdentityGenerated = require(\"./dependenciesIdentity.generated.js\");\n\nvar _dependenciesInvGenerated = require(\"./dependenciesInv.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar expmDependencies = {\n absDependencies: _dependenciesAbsGenerated.absDependencies,\n addDependencies: _dependenciesAddGenerated.addDependencies,\n identityDependencies: _dependenciesIdentityGenerated.identityDependencies,\n invDependencies: _dependenciesInvGenerated.invDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createExpm: _factoriesAny.createExpm\n};\nexports.expmDependencies = expmDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.expm1Dependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar expm1Dependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createExpm1: _factoriesAny.createExpm1\n};\nexports.expm1Dependencies = expm1Dependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.factorialDependencies = void 0;\n\nvar _dependenciesGammaGenerated = require(\"./dependenciesGamma.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar factorialDependencies = {\n gammaDependencies: _dependenciesGammaGenerated.gammaDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createFactorial: _factoriesAny.createFactorial\n};\nexports.factorialDependencies = factorialDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.falseDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar falseDependencies = {\n createFalse: _factoriesAny.createFalse\n};\nexports.falseDependencies = falseDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.faradayDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar faradayDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createFaraday: _factoriesAny.createFaraday\n};\nexports.faradayDependencies = faradayDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.fermiCouplingDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar fermiCouplingDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createFermiCoupling: _factoriesAny.createFermiCoupling\n};\nexports.fermiCouplingDependencies = fermiCouplingDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.fftDependencies = void 0;\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesExpGenerated = require(\"./dependenciesExp.generated.js\");\n\nvar _dependenciesIGenerated = require(\"./dependenciesI.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesTauGenerated = require(\"./dependenciesTau.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar fftDependencies = {\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n expDependencies: _dependenciesExpGenerated.expDependencies,\n iDependencies: _dependenciesIGenerated.iDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n tauDependencies: _dependenciesTauGenerated.tauDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createFft: _factoriesAny.createFft\n};\nexports.fftDependencies = fftDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.FibonacciHeapDependencies = void 0;\n\nvar _dependenciesLargerGenerated = require(\"./dependenciesLarger.generated.js\");\n\nvar _dependenciesSmallerGenerated = require(\"./dependenciesSmaller.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar FibonacciHeapDependencies = {\n largerDependencies: _dependenciesLargerGenerated.largerDependencies,\n smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies,\n createFibonacciHeapClass: _factoriesAny.createFibonacciHeapClass\n};\nexports.FibonacciHeapDependencies = FibonacciHeapDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.filterDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar filterDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createFilter: _factoriesAny.createFilter\n};\nexports.filterDependencies = filterDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.filterTransformDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar filterTransformDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createFilterTransform: _factoriesAny.createFilterTransform\n};\nexports.filterTransformDependencies = filterTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.fineStructureDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar fineStructureDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createFineStructure: _factoriesAny.createFineStructure\n};\nexports.fineStructureDependencies = fineStructureDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.firstRadiationDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar firstRadiationDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createFirstRadiation: _factoriesAny.createFirstRadiation\n};\nexports.firstRadiationDependencies = firstRadiationDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.fixDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesCeilGenerated = require(\"./dependenciesCeil.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesFloorGenerated = require(\"./dependenciesFloor.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesZerosGenerated = require(\"./dependenciesZeros.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar fixDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n ceilDependencies: _dependenciesCeilGenerated.ceilDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n floorDependencies: _dependenciesFloorGenerated.floorDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n zerosDependencies: _dependenciesZerosGenerated.zerosDependencies,\n createFix: _factoriesAny.createFix\n};\nexports.fixDependencies = fixDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.flattenDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar flattenDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createFlatten: _factoriesAny.createFlatten\n};\nexports.flattenDependencies = flattenDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.floorDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesRoundGenerated = require(\"./dependenciesRound.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesZerosGenerated = require(\"./dependenciesZeros.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar floorDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n roundDependencies: _dependenciesRoundGenerated.roundDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n zerosDependencies: _dependenciesZerosGenerated.zerosDependencies,\n createFloor: _factoriesAny.createFloor\n};\nexports.floorDependencies = floorDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.forEachDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar forEachDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createForEach: _factoriesAny.createForEach\n};\nexports.forEachDependencies = forEachDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.forEachTransformDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar forEachTransformDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createForEachTransform: _factoriesAny.createForEachTransform\n};\nexports.forEachTransformDependencies = forEachTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.formatDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar formatDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createFormat: _factoriesAny.createFormat\n};\nexports.formatDependencies = formatDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.fractionDependencies = void 0;\n\nvar _dependenciesFractionClassGenerated = require(\"./dependenciesFractionClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar fractionDependencies = {\n FractionDependencies: _dependenciesFractionClassGenerated.FractionDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createFraction: _factoriesAny.createFraction\n};\nexports.fractionDependencies = fractionDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.FractionDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar FractionDependencies = {\n createFractionClass: _factoriesAny.createFractionClass\n};\nexports.FractionDependencies = FractionDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.FunctionAssignmentNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar FunctionAssignmentNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createFunctionAssignmentNode: _factoriesAny.createFunctionAssignmentNode\n};\nexports.FunctionAssignmentNodeDependencies = FunctionAssignmentNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.FunctionNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _dependenciesSymbolNodeGenerated = require(\"./dependenciesSymbolNode.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar FunctionNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies,\n createFunctionNode: _factoriesAny.createFunctionNode\n};\nexports.FunctionNodeDependencies = FunctionNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.gammaDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesPowGenerated = require(\"./dependenciesPow.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar gammaDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n powDependencies: _dependenciesPowGenerated.powDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createGamma: _factoriesAny.createGamma\n};\nexports.gammaDependencies = gammaDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.gasConstantDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar gasConstantDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createGasConstant: _factoriesAny.createGasConstant\n};\nexports.gasConstantDependencies = gasConstantDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.gcdDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar gcdDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createGcd: _factoriesAny.createGcd\n};\nexports.gcdDependencies = gcdDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getMatrixDataTypeDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar getMatrixDataTypeDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createGetMatrixDataType: _factoriesAny.createGetMatrixDataType\n};\nexports.getMatrixDataTypeDependencies = getMatrixDataTypeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.gravitationConstantDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar gravitationConstantDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createGravitationConstant: _factoriesAny.createGravitationConstant\n};\nexports.gravitationConstantDependencies = gravitationConstantDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.gravityDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar gravityDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createGravity: _factoriesAny.createGravity\n};\nexports.gravityDependencies = gravityDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hartreeEnergyDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar hartreeEnergyDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createHartreeEnergy: _factoriesAny.createHartreeEnergy\n};\nexports.hartreeEnergyDependencies = hartreeEnergyDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hasNumericValueDependencies = void 0;\n\nvar _dependenciesIsNumericGenerated = require(\"./dependenciesIsNumeric.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar hasNumericValueDependencies = {\n isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createHasNumericValue: _factoriesAny.createHasNumericValue\n};\nexports.hasNumericValueDependencies = hasNumericValueDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.helpDependencies = void 0;\n\nvar _dependenciesHelpClassGenerated = require(\"./dependenciesHelpClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar helpDependencies = {\n HelpDependencies: _dependenciesHelpClassGenerated.HelpDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createHelp: _factoriesAny.createHelp\n};\nexports.helpDependencies = helpDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.HelpDependencies = void 0;\n\nvar _dependenciesParseGenerated = require(\"./dependenciesParse.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar HelpDependencies = {\n parseDependencies: _dependenciesParseGenerated.parseDependencies,\n createHelpClass: _factoriesAny.createHelpClass\n};\nexports.HelpDependencies = HelpDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hexDependencies = void 0;\n\nvar _dependenciesFormatGenerated = require(\"./dependenciesFormat.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar hexDependencies = {\n formatDependencies: _dependenciesFormatGenerated.formatDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createHex: _factoriesAny.createHex\n};\nexports.hexDependencies = hexDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hypotDependencies = void 0;\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAbs.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesIsPositiveGenerated = require(\"./dependenciesIsPositive.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesSmallerGenerated = require(\"./dependenciesSmaller.generated.js\");\n\nvar _dependenciesSqrtGenerated = require(\"./dependenciesSqrt.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar hypotDependencies = {\n absDependencies: _dependenciesAbsGenerated.absDependencies,\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies,\n sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createHypot: _factoriesAny.createHypot\n};\nexports.hypotDependencies = hypotDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.iDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar iDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n createI: _factoriesAny.createI\n};\nexports.iDependencies = iDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.identityDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesSparseMatrixClassGenerated = require(\"./dependenciesSparseMatrixClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar identityDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createIdentity: _factoriesAny.createIdentity\n};\nexports.identityDependencies = identityDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ifftDependencies = void 0;\n\nvar _dependenciesConjGenerated = require(\"./dependenciesConj.generated.js\");\n\nvar _dependenciesDotDivideGenerated = require(\"./dependenciesDotDivide.generated.js\");\n\nvar _dependenciesFftGenerated = require(\"./dependenciesFft.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ifftDependencies = {\n conjDependencies: _dependenciesConjGenerated.conjDependencies,\n dotDivideDependencies: _dependenciesDotDivideGenerated.dotDivideDependencies,\n fftDependencies: _dependenciesFftGenerated.fftDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createIfft: _factoriesAny.createIfft\n};\nexports.ifftDependencies = ifftDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.imDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar imDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createIm: _factoriesAny.createIm\n};\nexports.imDependencies = imDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ImmutableDenseMatrixDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesSmallerGenerated = require(\"./dependenciesSmaller.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ImmutableDenseMatrixDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies,\n createImmutableDenseMatrixClass: _factoriesAny.createImmutableDenseMatrixClass\n};\nexports.ImmutableDenseMatrixDependencies = ImmutableDenseMatrixDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.indexDependencies = void 0;\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar indexDependencies = {\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createIndex: _factoriesAny.createIndex\n};\nexports.indexDependencies = indexDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.IndexDependencies = void 0;\n\nvar _dependenciesImmutableDenseMatrixClassGenerated = require(\"./dependenciesImmutableDenseMatrixClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar IndexDependencies = {\n ImmutableDenseMatrixDependencies: _dependenciesImmutableDenseMatrixClassGenerated.ImmutableDenseMatrixDependencies,\n createIndexClass: _factoriesAny.createIndexClass\n};\nexports.IndexDependencies = IndexDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.IndexNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar IndexNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n createIndexNode: _factoriesAny.createIndexNode\n};\nexports.IndexNodeDependencies = IndexNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.indexTransformDependencies = void 0;\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar indexTransformDependencies = {\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n createIndexTransform: _factoriesAny.createIndexTransform\n};\nexports.indexTransformDependencies = indexTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.InfinityDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar InfinityDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createInfinity: _factoriesAny.createInfinity\n};\nexports.InfinityDependencies = InfinityDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.intersectDependencies = void 0;\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAbs.generated.js\");\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesFlattenGenerated = require(\"./dependenciesFlatten.generated.js\");\n\nvar _dependenciesIsNumericGenerated = require(\"./dependenciesIsNumeric.generated.js\");\n\nvar _dependenciesIsZeroGenerated = require(\"./dependenciesIsZero.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesSmallerGenerated = require(\"./dependenciesSmaller.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar intersectDependencies = {\n absDependencies: _dependenciesAbsGenerated.absDependencies,\n addDependencies: _dependenciesAddGenerated.addDependencies,\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n flattenDependencies: _dependenciesFlattenGenerated.flattenDependencies,\n isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies,\n isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createIntersect: _factoriesAny.createIntersect\n};\nexports.intersectDependencies = intersectDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.invDependencies = void 0;\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAbs.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesDetGenerated = require(\"./dependenciesDet.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesIdentityGenerated = require(\"./dependenciesIdentity.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesUnaryMinusGenerated = require(\"./dependenciesUnaryMinus.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar invDependencies = {\n absDependencies: _dependenciesAbsGenerated.absDependencies,\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n detDependencies: _dependenciesDetGenerated.detDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n identityDependencies: _dependenciesIdentityGenerated.identityDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies,\n createInv: _factoriesAny.createInv\n};\nexports.invDependencies = invDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.inverseConductanceQuantumDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar inverseConductanceQuantumDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createInverseConductanceQuantum: _factoriesAny.createInverseConductanceQuantum\n};\nexports.inverseConductanceQuantumDependencies = inverseConductanceQuantumDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.invmodDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesEqualGenerated = require(\"./dependenciesEqual.generated.js\");\n\nvar _dependenciesIsIntegerGenerated = require(\"./dependenciesIsInteger.generated.js\");\n\nvar _dependenciesModGenerated = require(\"./dependenciesMod.generated.js\");\n\nvar _dependenciesSmallerGenerated = require(\"./dependenciesSmaller.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesXgcdGenerated = require(\"./dependenciesXgcd.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar invmodDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n addDependencies: _dependenciesAddGenerated.addDependencies,\n equalDependencies: _dependenciesEqualGenerated.equalDependencies,\n isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies,\n modDependencies: _dependenciesModGenerated.modDependencies,\n smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n xgcdDependencies: _dependenciesXgcdGenerated.xgcdDependencies,\n createInvmod: _factoriesAny.createInvmod\n};\nexports.invmodDependencies = invmodDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isIntegerDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar isIntegerDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createIsInteger: _factoriesAny.createIsInteger\n};\nexports.isIntegerDependencies = isIntegerDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isNaNDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar isNaNDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createIsNaN: _factoriesAny.createIsNaN\n};\nexports.isNaNDependencies = isNaNDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isNegativeDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar isNegativeDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createIsNegative: _factoriesAny.createIsNegative\n};\nexports.isNegativeDependencies = isNegativeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isNumericDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar isNumericDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createIsNumeric: _factoriesAny.createIsNumeric\n};\nexports.isNumericDependencies = isNumericDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isPositiveDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar isPositiveDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createIsPositive: _factoriesAny.createIsPositive\n};\nexports.isPositiveDependencies = isPositiveDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isPrimeDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar isPrimeDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createIsPrime: _factoriesAny.createIsPrime\n};\nexports.isPrimeDependencies = isPrimeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isZeroDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar isZeroDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createIsZero: _factoriesAny.createIsZero\n};\nexports.isZeroDependencies = isZeroDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.kldivergenceDependencies = void 0;\n\nvar _dependenciesDivideGenerated = require(\"./dependenciesDivide.generated.js\");\n\nvar _dependenciesDotDivideGenerated = require(\"./dependenciesDotDivide.generated.js\");\n\nvar _dependenciesIsNumericGenerated = require(\"./dependenciesIsNumeric.generated.js\");\n\nvar _dependenciesLogGenerated = require(\"./dependenciesLog.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesSumGenerated = require(\"./dependenciesSum.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar kldivergenceDependencies = {\n divideDependencies: _dependenciesDivideGenerated.divideDependencies,\n dotDivideDependencies: _dependenciesDotDivideGenerated.dotDivideDependencies,\n isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies,\n logDependencies: _dependenciesLogGenerated.logDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n sumDependencies: _dependenciesSumGenerated.sumDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createKldivergence: _factoriesAny.createKldivergence\n};\nexports.kldivergenceDependencies = kldivergenceDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.klitzingDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar klitzingDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createKlitzing: _factoriesAny.createKlitzing\n};\nexports.klitzingDependencies = klitzingDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.kronDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar kronDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createKron: _factoriesAny.createKron\n};\nexports.kronDependencies = kronDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LN10Dependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar LN10Dependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createLN10: _factoriesAny.createLN10\n};\nexports.LN10Dependencies = LN10Dependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LN2Dependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar LN2Dependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createLN2: _factoriesAny.createLN2\n};\nexports.LN2Dependencies = LN2Dependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LOG10EDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar LOG10EDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createLOG10E: _factoriesAny.createLOG10E\n};\nexports.LOG10EDependencies = LOG10EDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LOG2EDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar LOG2EDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createLOG2E: _factoriesAny.createLOG2E\n};\nexports.LOG2EDependencies = LOG2EDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.largerDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar largerDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createLarger: _factoriesAny.createLarger\n};\nexports.largerDependencies = largerDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.largerEqDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar largerEqDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createLargerEq: _factoriesAny.createLargerEq\n};\nexports.largerEqDependencies = largerEqDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lcmDependencies = void 0;\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar lcmDependencies = {\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createLcm: _factoriesAny.createLcm\n};\nexports.lcmDependencies = lcmDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.leafCountDependencies = void 0;\n\nvar _dependenciesParseGenerated = require(\"./dependenciesParse.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar leafCountDependencies = {\n parseDependencies: _dependenciesParseGenerated.parseDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createLeafCount: _factoriesAny.createLeafCount\n};\nexports.leafCountDependencies = leafCountDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.leftShiftDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesZerosGenerated = require(\"./dependenciesZeros.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar leftShiftDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n zerosDependencies: _dependenciesZerosGenerated.zerosDependencies,\n createLeftShift: _factoriesAny.createLeftShift\n};\nexports.leftShiftDependencies = leftShiftDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lgammaDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar lgammaDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createLgamma: _factoriesAny.createLgamma\n};\nexports.lgammaDependencies = lgammaDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.logDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar logDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createLog: _factoriesAny.createLog\n};\nexports.logDependencies = logDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.log10Dependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar log10Dependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createLog10: _factoriesAny.createLog10\n};\nexports.log10Dependencies = log10Dependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.log1pDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesLogGenerated = require(\"./dependenciesLog.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar log1pDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n logDependencies: _dependenciesLogGenerated.logDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createLog1p: _factoriesAny.createLog1p\n};\nexports.log1pDependencies = log1pDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.log2Dependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar log2Dependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createLog2: _factoriesAny.createLog2\n};\nexports.log2Dependencies = log2Dependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.loschmidtDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar loschmidtDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createLoschmidt: _factoriesAny.createLoschmidt\n};\nexports.loschmidtDependencies = loschmidtDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lsolveDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar lsolveDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createLsolve: _factoriesAny.createLsolve\n};\nexports.lsolveDependencies = lsolveDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lsolveAllDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar lsolveAllDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createLsolveAll: _factoriesAny.createLsolveAll\n};\nexports.lsolveAllDependencies = lsolveAllDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lupDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesSpaClassGenerated = require(\"./dependenciesSpaClass.generated.js\");\n\nvar _dependenciesSparseMatrixClassGenerated = require(\"./dependenciesSparseMatrixClass.generated.js\");\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAbs.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesLargerGenerated = require(\"./dependenciesLarger.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesUnaryMinusGenerated = require(\"./dependenciesUnaryMinus.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar lupDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n SpaDependencies: _dependenciesSpaClassGenerated.SpaDependencies,\n SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies,\n absDependencies: _dependenciesAbsGenerated.absDependencies,\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n largerDependencies: _dependenciesLargerGenerated.largerDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies,\n createLup: _factoriesAny.createLup\n};\nexports.lupDependencies = lupDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lusolveDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesLsolveGenerated = require(\"./dependenciesLsolve.generated.js\");\n\nvar _dependenciesLupGenerated = require(\"./dependenciesLup.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesSluGenerated = require(\"./dependenciesSlu.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesUsolveGenerated = require(\"./dependenciesUsolve.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar lusolveDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n lsolveDependencies: _dependenciesLsolveGenerated.lsolveDependencies,\n lupDependencies: _dependenciesLupGenerated.lupDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n sluDependencies: _dependenciesSluGenerated.sluDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n usolveDependencies: _dependenciesUsolveGenerated.usolveDependencies,\n createLusolve: _factoriesAny.createLusolve\n};\nexports.lusolveDependencies = lusolveDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.madDependencies = void 0;\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAbs.generated.js\");\n\nvar _dependenciesMapGenerated = require(\"./dependenciesMap.generated.js\");\n\nvar _dependenciesMedianGenerated = require(\"./dependenciesMedian.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar madDependencies = {\n absDependencies: _dependenciesAbsGenerated.absDependencies,\n mapDependencies: _dependenciesMapGenerated.mapDependencies,\n medianDependencies: _dependenciesMedianGenerated.medianDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMad: _factoriesAny.createMad\n};\nexports.madDependencies = madDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.magneticConstantDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar magneticConstantDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createMagneticConstant: _factoriesAny.createMagneticConstant\n};\nexports.magneticConstantDependencies = magneticConstantDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.magneticFluxQuantumDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar magneticFluxQuantumDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createMagneticFluxQuantum: _factoriesAny.createMagneticFluxQuantum\n};\nexports.magneticFluxQuantumDependencies = magneticFluxQuantumDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.mapDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar mapDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMap: _factoriesAny.createMap\n};\nexports.mapDependencies = mapDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.mapTransformDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar mapTransformDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMapTransform: _factoriesAny.createMapTransform\n};\nexports.mapTransformDependencies = mapTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.matrixDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesMatrixClassGenerated = require(\"./dependenciesMatrixClass.generated.js\");\n\nvar _dependenciesSparseMatrixClassGenerated = require(\"./dependenciesSparseMatrixClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar matrixDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n MatrixDependencies: _dependenciesMatrixClassGenerated.MatrixDependencies,\n SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMatrix: _factoriesAny.createMatrix\n};\nexports.matrixDependencies = matrixDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.MatrixDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar MatrixDependencies = {\n createMatrixClass: _factoriesAny.createMatrixClass\n};\nexports.MatrixDependencies = MatrixDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.matrixFromColumnsDependencies = void 0;\n\nvar _dependenciesFlattenGenerated = require(\"./dependenciesFlatten.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar matrixFromColumnsDependencies = {\n flattenDependencies: _dependenciesFlattenGenerated.flattenDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMatrixFromColumns: _factoriesAny.createMatrixFromColumns\n};\nexports.matrixFromColumnsDependencies = matrixFromColumnsDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.matrixFromFunctionDependencies = void 0;\n\nvar _dependenciesIsZeroGenerated = require(\"./dependenciesIsZero.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar matrixFromFunctionDependencies = {\n isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMatrixFromFunction: _factoriesAny.createMatrixFromFunction\n};\nexports.matrixFromFunctionDependencies = matrixFromFunctionDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.matrixFromRowsDependencies = void 0;\n\nvar _dependenciesFlattenGenerated = require(\"./dependenciesFlatten.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar matrixFromRowsDependencies = {\n flattenDependencies: _dependenciesFlattenGenerated.flattenDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMatrixFromRows: _factoriesAny.createMatrixFromRows\n};\nexports.matrixFromRowsDependencies = matrixFromRowsDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.maxDependencies = void 0;\n\nvar _dependenciesLargerGenerated = require(\"./dependenciesLarger.generated.js\");\n\nvar _dependenciesNumericGenerated = require(\"./dependenciesNumeric.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar maxDependencies = {\n largerDependencies: _dependenciesLargerGenerated.largerDependencies,\n numericDependencies: _dependenciesNumericGenerated.numericDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMax: _factoriesAny.createMax\n};\nexports.maxDependencies = maxDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.maxTransformDependencies = void 0;\n\nvar _dependenciesLargerGenerated = require(\"./dependenciesLarger.generated.js\");\n\nvar _dependenciesNumericGenerated = require(\"./dependenciesNumeric.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar maxTransformDependencies = {\n largerDependencies: _dependenciesLargerGenerated.largerDependencies,\n numericDependencies: _dependenciesNumericGenerated.numericDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMaxTransform: _factoriesAny.createMaxTransform\n};\nexports.maxTransformDependencies = maxTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.meanDependencies = void 0;\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesDivideGenerated = require(\"./dependenciesDivide.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar meanDependencies = {\n addDependencies: _dependenciesAddGenerated.addDependencies,\n divideDependencies: _dependenciesDivideGenerated.divideDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMean: _factoriesAny.createMean\n};\nexports.meanDependencies = meanDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.meanTransformDependencies = void 0;\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesDivideGenerated = require(\"./dependenciesDivide.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar meanTransformDependencies = {\n addDependencies: _dependenciesAddGenerated.addDependencies,\n divideDependencies: _dependenciesDivideGenerated.divideDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMeanTransform: _factoriesAny.createMeanTransform\n};\nexports.meanTransformDependencies = meanTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.medianDependencies = void 0;\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesCompareGenerated = require(\"./dependenciesCompare.generated.js\");\n\nvar _dependenciesDivideGenerated = require(\"./dependenciesDivide.generated.js\");\n\nvar _dependenciesPartitionSelectGenerated = require(\"./dependenciesPartitionSelect.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar medianDependencies = {\n addDependencies: _dependenciesAddGenerated.addDependencies,\n compareDependencies: _dependenciesCompareGenerated.compareDependencies,\n divideDependencies: _dependenciesDivideGenerated.divideDependencies,\n partitionSelectDependencies: _dependenciesPartitionSelectGenerated.partitionSelectDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMedian: _factoriesAny.createMedian\n};\nexports.medianDependencies = medianDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.minDependencies = void 0;\n\nvar _dependenciesNumericGenerated = require(\"./dependenciesNumeric.generated.js\");\n\nvar _dependenciesSmallerGenerated = require(\"./dependenciesSmaller.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar minDependencies = {\n numericDependencies: _dependenciesNumericGenerated.numericDependencies,\n smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMin: _factoriesAny.createMin\n};\nexports.minDependencies = minDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.minTransformDependencies = void 0;\n\nvar _dependenciesNumericGenerated = require(\"./dependenciesNumeric.generated.js\");\n\nvar _dependenciesSmallerGenerated = require(\"./dependenciesSmaller.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar minTransformDependencies = {\n numericDependencies: _dependenciesNumericGenerated.numericDependencies,\n smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMinTransform: _factoriesAny.createMinTransform\n};\nexports.minTransformDependencies = minTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.modDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar modDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMod: _factoriesAny.createMod\n};\nexports.modDependencies = modDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.modeDependencies = void 0;\n\nvar _dependenciesIsNaNGenerated = require(\"./dependenciesIsNaN.generated.js\");\n\nvar _dependenciesIsNumericGenerated = require(\"./dependenciesIsNumeric.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar modeDependencies = {\n isNaNDependencies: _dependenciesIsNaNGenerated.isNaNDependencies,\n isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMode: _factoriesAny.createMode\n};\nexports.modeDependencies = modeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.molarMassDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar molarMassDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createMolarMass: _factoriesAny.createMolarMass\n};\nexports.molarMassDependencies = molarMassDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.molarMassC12Dependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar molarMassC12Dependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createMolarMassC12: _factoriesAny.createMolarMassC12\n};\nexports.molarMassC12Dependencies = molarMassC12Dependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.molarPlanckConstantDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar molarPlanckConstantDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createMolarPlanckConstant: _factoriesAny.createMolarPlanckConstant\n};\nexports.molarPlanckConstantDependencies = molarPlanckConstantDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.molarVolumeDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar molarVolumeDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createMolarVolume: _factoriesAny.createMolarVolume\n};\nexports.molarVolumeDependencies = molarVolumeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.multinomialDependencies = void 0;\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesDivideGenerated = require(\"./dependenciesDivide.generated.js\");\n\nvar _dependenciesFactorialGenerated = require(\"./dependenciesFactorial.generated.js\");\n\nvar _dependenciesIsIntegerGenerated = require(\"./dependenciesIsInteger.generated.js\");\n\nvar _dependenciesIsPositiveGenerated = require(\"./dependenciesIsPositive.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar multinomialDependencies = {\n addDependencies: _dependenciesAddGenerated.addDependencies,\n divideDependencies: _dependenciesDivideGenerated.divideDependencies,\n factorialDependencies: _dependenciesFactorialGenerated.factorialDependencies,\n isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies,\n isPositiveDependencies: _dependenciesIsPositiveGenerated.isPositiveDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMultinomial: _factoriesAny.createMultinomial\n};\nexports.multinomialDependencies = multinomialDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.multiplyDependencies = void 0;\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesDotGenerated = require(\"./dependenciesDot.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar multiplyDependencies = {\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n dotDependencies: _dependenciesDotGenerated.dotDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMultiply: _factoriesAny.createMultiply\n};\nexports.multiplyDependencies = multiplyDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.multiplyScalarDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar multiplyScalarDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createMultiplyScalar: _factoriesAny.createMultiplyScalar\n};\nexports.multiplyScalarDependencies = multiplyScalarDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.NaNDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar NaNDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createNaN: _factoriesAny.createNaN\n};\nexports.NaNDependencies = NaNDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.neutronMassDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar neutronMassDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createNeutronMass: _factoriesAny.createNeutronMass\n};\nexports.neutronMassDependencies = neutronMassDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.NodeDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar NodeDependencies = {\n createNode: _factoriesAny.createNode\n};\nexports.NodeDependencies = NodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.normDependencies = void 0;\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAbs.generated.js\");\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesConjGenerated = require(\"./dependenciesConj.generated.js\");\n\nvar _dependenciesCtransposeGenerated = require(\"./dependenciesCtranspose.generated.js\");\n\nvar _dependenciesEigsGenerated = require(\"./dependenciesEigs.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesLargerGenerated = require(\"./dependenciesLarger.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesPowGenerated = require(\"./dependenciesPow.generated.js\");\n\nvar _dependenciesSmallerGenerated = require(\"./dependenciesSmaller.generated.js\");\n\nvar _dependenciesSqrtGenerated = require(\"./dependenciesSqrt.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar normDependencies = {\n absDependencies: _dependenciesAbsGenerated.absDependencies,\n addDependencies: _dependenciesAddGenerated.addDependencies,\n conjDependencies: _dependenciesConjGenerated.conjDependencies,\n ctransposeDependencies: _dependenciesCtransposeGenerated.ctransposeDependencies,\n eigsDependencies: _dependenciesEigsGenerated.eigsDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n largerDependencies: _dependenciesLargerGenerated.largerDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n powDependencies: _dependenciesPowGenerated.powDependencies,\n smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies,\n sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createNorm: _factoriesAny.createNorm\n};\nexports.normDependencies = normDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.notDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar notDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createNot: _factoriesAny.createNot\n};\nexports.notDependencies = notDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.nthRootDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar nthRootDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createNthRoot: _factoriesAny.createNthRoot\n};\nexports.nthRootDependencies = nthRootDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.nthRootsDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar nthRootsDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createNthRoots: _factoriesAny.createNthRoots\n};\nexports.nthRootsDependencies = nthRootsDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.nuclearMagnetonDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar nuclearMagnetonDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createNuclearMagneton: _factoriesAny.createNuclearMagneton\n};\nexports.nuclearMagnetonDependencies = nuclearMagnetonDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.nullDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar nullDependencies = {\n createNull: _factoriesAny.createNull\n};\nexports.nullDependencies = nullDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.numberDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar numberDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createNumber: _factoriesAny.createNumber\n};\nexports.numberDependencies = numberDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.numericDependencies = void 0;\n\nvar _dependenciesBignumberGenerated = require(\"./dependenciesBignumber.generated.js\");\n\nvar _dependenciesFractionGenerated = require(\"./dependenciesFraction.generated.js\");\n\nvar _dependenciesNumberGenerated = require(\"./dependenciesNumber.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar numericDependencies = {\n bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies,\n fractionDependencies: _dependenciesFractionGenerated.fractionDependencies,\n numberDependencies: _dependenciesNumberGenerated.numberDependencies,\n createNumeric: _factoriesAny.createNumeric\n};\nexports.numericDependencies = numericDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ObjectNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ObjectNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n createObjectNode: _factoriesAny.createObjectNode\n};\nexports.ObjectNodeDependencies = ObjectNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.octDependencies = void 0;\n\nvar _dependenciesFormatGenerated = require(\"./dependenciesFormat.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar octDependencies = {\n formatDependencies: _dependenciesFormatGenerated.formatDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createOct: _factoriesAny.createOct\n};\nexports.octDependencies = octDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.onesDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar onesDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createOnes: _factoriesAny.createOnes\n};\nexports.onesDependencies = onesDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.OperatorNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar OperatorNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n createOperatorNode: _factoriesAny.createOperatorNode\n};\nexports.OperatorNodeDependencies = OperatorNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.orDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar orDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createOr: _factoriesAny.createOr\n};\nexports.orDependencies = orDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ParenthesisNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ParenthesisNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n createParenthesisNode: _factoriesAny.createParenthesisNode\n};\nexports.ParenthesisNodeDependencies = ParenthesisNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.parseDependencies = void 0;\n\nvar _dependenciesAccessorNodeGenerated = require(\"./dependenciesAccessorNode.generated.js\");\n\nvar _dependenciesArrayNodeGenerated = require(\"./dependenciesArrayNode.generated.js\");\n\nvar _dependenciesAssignmentNodeGenerated = require(\"./dependenciesAssignmentNode.generated.js\");\n\nvar _dependenciesBlockNodeGenerated = require(\"./dependenciesBlockNode.generated.js\");\n\nvar _dependenciesConditionalNodeGenerated = require(\"./dependenciesConditionalNode.generated.js\");\n\nvar _dependenciesConstantNodeGenerated = require(\"./dependenciesConstantNode.generated.js\");\n\nvar _dependenciesFunctionAssignmentNodeGenerated = require(\"./dependenciesFunctionAssignmentNode.generated.js\");\n\nvar _dependenciesFunctionNodeGenerated = require(\"./dependenciesFunctionNode.generated.js\");\n\nvar _dependenciesIndexNodeGenerated = require(\"./dependenciesIndexNode.generated.js\");\n\nvar _dependenciesObjectNodeGenerated = require(\"./dependenciesObjectNode.generated.js\");\n\nvar _dependenciesOperatorNodeGenerated = require(\"./dependenciesOperatorNode.generated.js\");\n\nvar _dependenciesParenthesisNodeGenerated = require(\"./dependenciesParenthesisNode.generated.js\");\n\nvar _dependenciesRangeNodeGenerated = require(\"./dependenciesRangeNode.generated.js\");\n\nvar _dependenciesRelationalNodeGenerated = require(\"./dependenciesRelationalNode.generated.js\");\n\nvar _dependenciesSymbolNodeGenerated = require(\"./dependenciesSymbolNode.generated.js\");\n\nvar _dependenciesNumericGenerated = require(\"./dependenciesNumeric.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar parseDependencies = {\n AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies,\n ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies,\n AssignmentNodeDependencies: _dependenciesAssignmentNodeGenerated.AssignmentNodeDependencies,\n BlockNodeDependencies: _dependenciesBlockNodeGenerated.BlockNodeDependencies,\n ConditionalNodeDependencies: _dependenciesConditionalNodeGenerated.ConditionalNodeDependencies,\n ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies,\n FunctionAssignmentNodeDependencies: _dependenciesFunctionAssignmentNodeGenerated.FunctionAssignmentNodeDependencies,\n FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies,\n IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies,\n ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies,\n OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies,\n ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies,\n RangeNodeDependencies: _dependenciesRangeNodeGenerated.RangeNodeDependencies,\n RelationalNodeDependencies: _dependenciesRelationalNodeGenerated.RelationalNodeDependencies,\n SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies,\n numericDependencies: _dependenciesNumericGenerated.numericDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createParse: _factoriesAny.createParse\n};\nexports.parseDependencies = parseDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.parserDependencies = void 0;\n\nvar _dependenciesParserClassGenerated = require(\"./dependenciesParserClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar parserDependencies = {\n ParserDependencies: _dependenciesParserClassGenerated.ParserDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createParser: _factoriesAny.createParser\n};\nexports.parserDependencies = parserDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ParserDependencies = void 0;\n\nvar _dependenciesEvaluateGenerated = require(\"./dependenciesEvaluate.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ParserDependencies = {\n evaluateDependencies: _dependenciesEvaluateGenerated.evaluateDependencies,\n createParserClass: _factoriesAny.createParserClass\n};\nexports.ParserDependencies = ParserDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.partitionSelectDependencies = void 0;\n\nvar _dependenciesCompareGenerated = require(\"./dependenciesCompare.generated.js\");\n\nvar _dependenciesIsNaNGenerated = require(\"./dependenciesIsNaN.generated.js\");\n\nvar _dependenciesIsNumericGenerated = require(\"./dependenciesIsNumeric.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar partitionSelectDependencies = {\n compareDependencies: _dependenciesCompareGenerated.compareDependencies,\n isNaNDependencies: _dependenciesIsNaNGenerated.isNaNDependencies,\n isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createPartitionSelect: _factoriesAny.createPartitionSelect\n};\nexports.partitionSelectDependencies = partitionSelectDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.permutationsDependencies = void 0;\n\nvar _dependenciesFactorialGenerated = require(\"./dependenciesFactorial.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar permutationsDependencies = {\n factorialDependencies: _dependenciesFactorialGenerated.factorialDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createPermutations: _factoriesAny.createPermutations\n};\nexports.permutationsDependencies = permutationsDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.phiDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar phiDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createPhi: _factoriesAny.createPhi\n};\nexports.phiDependencies = phiDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.piDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar piDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createPi: _factoriesAny.createPi\n};\nexports.piDependencies = piDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.pickRandomDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar pickRandomDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createPickRandom: _factoriesAny.createPickRandom\n};\nexports.pickRandomDependencies = pickRandomDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.pinvDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesCtransposeGenerated = require(\"./dependenciesCtranspose.generated.js\");\n\nvar _dependenciesDeepEqualGenerated = require(\"./dependenciesDeepEqual.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesDotGenerated = require(\"./dependenciesDot.generated.js\");\n\nvar _dependenciesDotDivideGenerated = require(\"./dependenciesDotDivide.generated.js\");\n\nvar _dependenciesEqualGenerated = require(\"./dependenciesEqual.generated.js\");\n\nvar _dependenciesInvGenerated = require(\"./dependenciesInv.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar pinvDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n addDependencies: _dependenciesAddGenerated.addDependencies,\n ctransposeDependencies: _dependenciesCtransposeGenerated.ctransposeDependencies,\n deepEqualDependencies: _dependenciesDeepEqualGenerated.deepEqualDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n dotDependencies: _dependenciesDotGenerated.dotDependencies,\n dotDivideDependencies: _dependenciesDotDivideGenerated.dotDivideDependencies,\n equalDependencies: _dependenciesEqualGenerated.equalDependencies,\n invDependencies: _dependenciesInvGenerated.invDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createPinv: _factoriesAny.createPinv\n};\nexports.pinvDependencies = pinvDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.planckChargeDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar planckChargeDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createPlanckCharge: _factoriesAny.createPlanckCharge\n};\nexports.planckChargeDependencies = planckChargeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.planckConstantDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar planckConstantDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createPlanckConstant: _factoriesAny.createPlanckConstant\n};\nexports.planckConstantDependencies = planckConstantDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.planckLengthDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar planckLengthDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createPlanckLength: _factoriesAny.createPlanckLength\n};\nexports.planckLengthDependencies = planckLengthDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.planckMassDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar planckMassDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createPlanckMass: _factoriesAny.createPlanckMass\n};\nexports.planckMassDependencies = planckMassDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.planckTemperatureDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar planckTemperatureDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createPlanckTemperature: _factoriesAny.createPlanckTemperature\n};\nexports.planckTemperatureDependencies = planckTemperatureDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.planckTimeDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar planckTimeDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createPlanckTime: _factoriesAny.createPlanckTime\n};\nexports.planckTimeDependencies = planckTimeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.powDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesFractionGenerated = require(\"./dependenciesFraction.generated.js\");\n\nvar _dependenciesIdentityGenerated = require(\"./dependenciesIdentity.generated.js\");\n\nvar _dependenciesInvGenerated = require(\"./dependenciesInv.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesNumberGenerated = require(\"./dependenciesNumber.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar powDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n fractionDependencies: _dependenciesFractionGenerated.fractionDependencies,\n identityDependencies: _dependenciesIdentityGenerated.identityDependencies,\n invDependencies: _dependenciesInvGenerated.invDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n numberDependencies: _dependenciesNumberGenerated.numberDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createPow: _factoriesAny.createPow\n};\nexports.powDependencies = powDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.printDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar printDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createPrint: _factoriesAny.createPrint\n};\nexports.printDependencies = printDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.prodDependencies = void 0;\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesNumericGenerated = require(\"./dependenciesNumeric.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar prodDependencies = {\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n numericDependencies: _dependenciesNumericGenerated.numericDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createProd: _factoriesAny.createProd\n};\nexports.prodDependencies = prodDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.protonMassDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar protonMassDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createProtonMass: _factoriesAny.createProtonMass\n};\nexports.protonMassDependencies = protonMassDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.qrDependencies = void 0;\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesComplexGenerated = require(\"./dependenciesComplex.generated.js\");\n\nvar _dependenciesConjGenerated = require(\"./dependenciesConj.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesEqualGenerated = require(\"./dependenciesEqual.generated.js\");\n\nvar _dependenciesIdentityGenerated = require(\"./dependenciesIdentity.generated.js\");\n\nvar _dependenciesIsZeroGenerated = require(\"./dependenciesIsZero.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesSignGenerated = require(\"./dependenciesSign.generated.js\");\n\nvar _dependenciesSqrtGenerated = require(\"./dependenciesSqrt.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesUnaryMinusGenerated = require(\"./dependenciesUnaryMinus.generated.js\");\n\nvar _dependenciesZerosGenerated = require(\"./dependenciesZeros.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar qrDependencies = {\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n complexDependencies: _dependenciesComplexGenerated.complexDependencies,\n conjDependencies: _dependenciesConjGenerated.conjDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n equalDependencies: _dependenciesEqualGenerated.equalDependencies,\n identityDependencies: _dependenciesIdentityGenerated.identityDependencies,\n isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n signDependencies: _dependenciesSignGenerated.signDependencies,\n sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies,\n zerosDependencies: _dependenciesZerosGenerated.zerosDependencies,\n createQr: _factoriesAny.createQr\n};\nexports.qrDependencies = qrDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.quantileSeqDependencies = void 0;\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesCompareGenerated = require(\"./dependenciesCompare.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesPartitionSelectGenerated = require(\"./dependenciesPartitionSelect.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar quantileSeqDependencies = {\n addDependencies: _dependenciesAddGenerated.addDependencies,\n compareDependencies: _dependenciesCompareGenerated.compareDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n partitionSelectDependencies: _dependenciesPartitionSelectGenerated.partitionSelectDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createQuantileSeq: _factoriesAny.createQuantileSeq\n};\nexports.quantileSeqDependencies = quantileSeqDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.quantumOfCirculationDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar quantumOfCirculationDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createQuantumOfCirculation: _factoriesAny.createQuantumOfCirculation\n};\nexports.quantumOfCirculationDependencies = quantumOfCirculationDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.randomDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar randomDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createRandom: _factoriesAny.createRandom\n};\nexports.randomDependencies = randomDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.randomIntDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar randomIntDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createRandomInt: _factoriesAny.createRandomInt\n};\nexports.randomIntDependencies = randomIntDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rangeDependencies = void 0;\n\nvar _dependenciesBignumberGenerated = require(\"./dependenciesBignumber.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesLargerGenerated = require(\"./dependenciesLarger.generated.js\");\n\nvar _dependenciesLargerEqGenerated = require(\"./dependenciesLargerEq.generated.js\");\n\nvar _dependenciesSmallerGenerated = require(\"./dependenciesSmaller.generated.js\");\n\nvar _dependenciesSmallerEqGenerated = require(\"./dependenciesSmallerEq.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar rangeDependencies = {\n bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n largerDependencies: _dependenciesLargerGenerated.largerDependencies,\n largerEqDependencies: _dependenciesLargerEqGenerated.largerEqDependencies,\n smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies,\n smallerEqDependencies: _dependenciesSmallerEqGenerated.smallerEqDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createRange: _factoriesAny.createRange\n};\nexports.rangeDependencies = rangeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.RangeDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar RangeDependencies = {\n createRangeClass: _factoriesAny.createRangeClass\n};\nexports.RangeDependencies = RangeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.RangeNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar RangeNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n createRangeNode: _factoriesAny.createRangeNode\n};\nexports.RangeNodeDependencies = RangeNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rangeTransformDependencies = void 0;\n\nvar _dependenciesBignumberGenerated = require(\"./dependenciesBignumber.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesLargerGenerated = require(\"./dependenciesLarger.generated.js\");\n\nvar _dependenciesLargerEqGenerated = require(\"./dependenciesLargerEq.generated.js\");\n\nvar _dependenciesSmallerGenerated = require(\"./dependenciesSmaller.generated.js\");\n\nvar _dependenciesSmallerEqGenerated = require(\"./dependenciesSmallerEq.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar rangeTransformDependencies = {\n bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n largerDependencies: _dependenciesLargerGenerated.largerDependencies,\n largerEqDependencies: _dependenciesLargerEqGenerated.largerEqDependencies,\n smallerDependencies: _dependenciesSmallerGenerated.smallerDependencies,\n smallerEqDependencies: _dependenciesSmallerEqGenerated.smallerEqDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createRangeTransform: _factoriesAny.createRangeTransform\n};\nexports.rangeTransformDependencies = rangeTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rationalizeDependencies = void 0;\n\nvar _dependenciesBignumberGenerated = require(\"./dependenciesBignumber.generated.js\");\n\nvar _dependenciesFractionGenerated = require(\"./dependenciesFraction.generated.js\");\n\nvar _dependenciesAccessorNodeGenerated = require(\"./dependenciesAccessorNode.generated.js\");\n\nvar _dependenciesArrayNodeGenerated = require(\"./dependenciesArrayNode.generated.js\");\n\nvar _dependenciesConstantNodeGenerated = require(\"./dependenciesConstantNode.generated.js\");\n\nvar _dependenciesFunctionNodeGenerated = require(\"./dependenciesFunctionNode.generated.js\");\n\nvar _dependenciesIndexNodeGenerated = require(\"./dependenciesIndexNode.generated.js\");\n\nvar _dependenciesObjectNodeGenerated = require(\"./dependenciesObjectNode.generated.js\");\n\nvar _dependenciesOperatorNodeGenerated = require(\"./dependenciesOperatorNode.generated.js\");\n\nvar _dependenciesParenthesisNodeGenerated = require(\"./dependenciesParenthesisNode.generated.js\");\n\nvar _dependenciesSymbolNodeGenerated = require(\"./dependenciesSymbolNode.generated.js\");\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesDivideGenerated = require(\"./dependenciesDivide.generated.js\");\n\nvar _dependenciesEqualGenerated = require(\"./dependenciesEqual.generated.js\");\n\nvar _dependenciesIsZeroGenerated = require(\"./dependenciesIsZero.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesParseGenerated = require(\"./dependenciesParse.generated.js\");\n\nvar _dependenciesPowGenerated = require(\"./dependenciesPow.generated.js\");\n\nvar _dependenciesSimplifyGenerated = require(\"./dependenciesSimplify.generated.js\");\n\nvar _dependenciesSimplifyCoreGenerated = require(\"./dependenciesSimplifyCore.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar rationalizeDependencies = {\n bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies,\n fractionDependencies: _dependenciesFractionGenerated.fractionDependencies,\n AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies,\n ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies,\n ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies,\n FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies,\n IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies,\n ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies,\n OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies,\n ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies,\n SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies,\n addDependencies: _dependenciesAddGenerated.addDependencies,\n divideDependencies: _dependenciesDivideGenerated.divideDependencies,\n equalDependencies: _dependenciesEqualGenerated.equalDependencies,\n isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n parseDependencies: _dependenciesParseGenerated.parseDependencies,\n powDependencies: _dependenciesPowGenerated.powDependencies,\n simplifyDependencies: _dependenciesSimplifyGenerated.simplifyDependencies,\n simplifyCoreDependencies: _dependenciesSimplifyCoreGenerated.simplifyCoreDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createRationalize: _factoriesAny.createRationalize\n};\nexports.rationalizeDependencies = rationalizeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.reDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar reDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createRe: _factoriesAny.createRe\n};\nexports.reDependencies = reDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.reducedPlanckConstantDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar reducedPlanckConstantDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createReducedPlanckConstant: _factoriesAny.createReducedPlanckConstant\n};\nexports.reducedPlanckConstantDependencies = reducedPlanckConstantDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.RelationalNodeDependencies = void 0;\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar RelationalNodeDependencies = {\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n createRelationalNode: _factoriesAny.createRelationalNode\n};\nexports.RelationalNodeDependencies = RelationalNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.replacerDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar replacerDependencies = {\n createReplacer: _factoriesAny.createReplacer\n};\nexports.replacerDependencies = replacerDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.reshapeDependencies = void 0;\n\nvar _dependenciesIsIntegerGenerated = require(\"./dependenciesIsInteger.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar reshapeDependencies = {\n isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createReshape: _factoriesAny.createReshape\n};\nexports.reshapeDependencies = reshapeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.resizeDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar resizeDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n createResize: _factoriesAny.createResize\n};\nexports.resizeDependencies = resizeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.resolveDependencies = void 0;\n\nvar _dependenciesConstantNodeGenerated = require(\"./dependenciesConstantNode.generated.js\");\n\nvar _dependenciesFunctionNodeGenerated = require(\"./dependenciesFunctionNode.generated.js\");\n\nvar _dependenciesOperatorNodeGenerated = require(\"./dependenciesOperatorNode.generated.js\");\n\nvar _dependenciesParenthesisNodeGenerated = require(\"./dependenciesParenthesisNode.generated.js\");\n\nvar _dependenciesParseGenerated = require(\"./dependenciesParse.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar resolveDependencies = {\n ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies,\n FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies,\n OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies,\n ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies,\n parseDependencies: _dependenciesParseGenerated.parseDependencies,\n createResolve: _factoriesAny.createResolve\n};\nexports.resolveDependencies = resolveDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ResultSetDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar ResultSetDependencies = {\n createResultSet: _factoriesAny.createResultSet\n};\nexports.ResultSetDependencies = ResultSetDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.reviverDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar reviverDependencies = {\n createReviver: _factoriesAny.createReviver\n};\nexports.reviverDependencies = reviverDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rightArithShiftDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesZerosGenerated = require(\"./dependenciesZeros.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar rightArithShiftDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n zerosDependencies: _dependenciesZerosGenerated.zerosDependencies,\n createRightArithShift: _factoriesAny.createRightArithShift\n};\nexports.rightArithShiftDependencies = rightArithShiftDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rightLogShiftDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesZerosGenerated = require(\"./dependenciesZeros.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar rightLogShiftDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n zerosDependencies: _dependenciesZerosGenerated.zerosDependencies,\n createRightLogShift: _factoriesAny.createRightLogShift\n};\nexports.rightLogShiftDependencies = rightLogShiftDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rotateDependencies = void 0;\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesRotationMatrixGenerated = require(\"./dependenciesRotationMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar rotateDependencies = {\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n rotationMatrixDependencies: _dependenciesRotationMatrixGenerated.rotationMatrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createRotate: _factoriesAny.createRotate\n};\nexports.rotateDependencies = rotateDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rotationMatrixDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesSparseMatrixClassGenerated = require(\"./dependenciesSparseMatrixClass.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesCosGenerated = require(\"./dependenciesCos.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesNormGenerated = require(\"./dependenciesNorm.generated.js\");\n\nvar _dependenciesSinGenerated = require(\"./dependenciesSin.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesUnaryMinusGenerated = require(\"./dependenciesUnaryMinus.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar rotationMatrixDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies,\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n cosDependencies: _dependenciesCosGenerated.cosDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n normDependencies: _dependenciesNormGenerated.normDependencies,\n sinDependencies: _dependenciesSinGenerated.sinDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies,\n createRotationMatrix: _factoriesAny.createRotationMatrix\n};\nexports.rotationMatrixDependencies = rotationMatrixDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.roundDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesZerosGenerated = require(\"./dependenciesZeros.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar roundDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n zerosDependencies: _dependenciesZerosGenerated.zerosDependencies,\n createRound: _factoriesAny.createRound\n};\nexports.roundDependencies = roundDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rowDependencies = void 0;\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesRangeGenerated = require(\"./dependenciesRange.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar rowDependencies = {\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n rangeDependencies: _dependenciesRangeGenerated.rangeDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createRow: _factoriesAny.createRow\n};\nexports.rowDependencies = rowDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rowTransformDependencies = void 0;\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesRangeGenerated = require(\"./dependenciesRange.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar rowTransformDependencies = {\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n rangeDependencies: _dependenciesRangeGenerated.rangeDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createRowTransform: _factoriesAny.createRowTransform\n};\nexports.rowTransformDependencies = rowTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rydbergDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar rydbergDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createRydberg: _factoriesAny.createRydberg\n};\nexports.rydbergDependencies = rydbergDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.SQRT1_2Dependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\n// eslint-disable-line camelcase\nvar SQRT1_2Dependencies = {\n // eslint-disable-line camelcase\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createSQRT1_2: _factoriesAny.createSQRT1_2\n};\nexports.SQRT1_2Dependencies = SQRT1_2Dependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.SQRT2Dependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar SQRT2Dependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createSQRT2: _factoriesAny.createSQRT2\n};\nexports.SQRT2Dependencies = SQRT2Dependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sackurTetrodeDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar sackurTetrodeDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createSackurTetrode: _factoriesAny.createSackurTetrode\n};\nexports.sackurTetrodeDependencies = sackurTetrodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.secDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar secDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSec: _factoriesAny.createSec\n};\nexports.secDependencies = secDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sechDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar sechDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSech: _factoriesAny.createSech\n};\nexports.sechDependencies = sechDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.secondRadiationDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar secondRadiationDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createSecondRadiation: _factoriesAny.createSecondRadiation\n};\nexports.secondRadiationDependencies = secondRadiationDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setCartesianDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesCompareNaturalGenerated = require(\"./dependenciesCompareNatural.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesSubsetGenerated = require(\"./dependenciesSubset.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar setCartesianDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSetCartesian: _factoriesAny.createSetCartesian\n};\nexports.setCartesianDependencies = setCartesianDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setDifferenceDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesCompareNaturalGenerated = require(\"./dependenciesCompareNatural.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesSubsetGenerated = require(\"./dependenciesSubset.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar setDifferenceDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSetDifference: _factoriesAny.createSetDifference\n};\nexports.setDifferenceDependencies = setDifferenceDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setDistinctDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesCompareNaturalGenerated = require(\"./dependenciesCompareNatural.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesSubsetGenerated = require(\"./dependenciesSubset.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar setDistinctDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSetDistinct: _factoriesAny.createSetDistinct\n};\nexports.setDistinctDependencies = setDistinctDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setIntersectDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesCompareNaturalGenerated = require(\"./dependenciesCompareNatural.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesSubsetGenerated = require(\"./dependenciesSubset.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar setIntersectDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSetIntersect: _factoriesAny.createSetIntersect\n};\nexports.setIntersectDependencies = setIntersectDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setIsSubsetDependencies = void 0;\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesCompareNaturalGenerated = require(\"./dependenciesCompareNatural.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesSubsetGenerated = require(\"./dependenciesSubset.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar setIsSubsetDependencies = {\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSetIsSubset: _factoriesAny.createSetIsSubset\n};\nexports.setIsSubsetDependencies = setIsSubsetDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setMultiplicityDependencies = void 0;\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesCompareNaturalGenerated = require(\"./dependenciesCompareNatural.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesSubsetGenerated = require(\"./dependenciesSubset.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar setMultiplicityDependencies = {\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSetMultiplicity: _factoriesAny.createSetMultiplicity\n};\nexports.setMultiplicityDependencies = setMultiplicityDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setPowersetDependencies = void 0;\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesCompareNaturalGenerated = require(\"./dependenciesCompareNatural.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesSubsetGenerated = require(\"./dependenciesSubset.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar setPowersetDependencies = {\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSetPowerset: _factoriesAny.createSetPowerset\n};\nexports.setPowersetDependencies = setPowersetDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setSizeDependencies = void 0;\n\nvar _dependenciesCompareNaturalGenerated = require(\"./dependenciesCompareNatural.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar setSizeDependencies = {\n compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSetSize: _factoriesAny.createSetSize\n};\nexports.setSizeDependencies = setSizeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setSymDifferenceDependencies = void 0;\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesConcatGenerated = require(\"./dependenciesConcat.generated.js\");\n\nvar _dependenciesSetDifferenceGenerated = require(\"./dependenciesSetDifference.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesSubsetGenerated = require(\"./dependenciesSubset.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar setSymDifferenceDependencies = {\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n concatDependencies: _dependenciesConcatGenerated.concatDependencies,\n setDifferenceDependencies: _dependenciesSetDifferenceGenerated.setDifferenceDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSetSymDifference: _factoriesAny.createSetSymDifference\n};\nexports.setSymDifferenceDependencies = setSymDifferenceDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setUnionDependencies = void 0;\n\nvar _dependenciesIndexClassGenerated = require(\"./dependenciesIndexClass.generated.js\");\n\nvar _dependenciesConcatGenerated = require(\"./dependenciesConcat.generated.js\");\n\nvar _dependenciesSetIntersectGenerated = require(\"./dependenciesSetIntersect.generated.js\");\n\nvar _dependenciesSetSymDifferenceGenerated = require(\"./dependenciesSetSymDifference.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesSubsetGenerated = require(\"./dependenciesSubset.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar setUnionDependencies = {\n IndexDependencies: _dependenciesIndexClassGenerated.IndexDependencies,\n concatDependencies: _dependenciesConcatGenerated.concatDependencies,\n setIntersectDependencies: _dependenciesSetIntersectGenerated.setIntersectDependencies,\n setSymDifferenceDependencies: _dependenciesSetSymDifferenceGenerated.setSymDifferenceDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n subsetDependencies: _dependenciesSubsetGenerated.subsetDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSetUnion: _factoriesAny.createSetUnion\n};\nexports.setUnionDependencies = setUnionDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.signDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesFractionClassGenerated = require(\"./dependenciesFractionClass.generated.js\");\n\nvar _dependenciesComplexGenerated = require(\"./dependenciesComplex.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar signDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n FractionDependencies: _dependenciesFractionClassGenerated.FractionDependencies,\n complexDependencies: _dependenciesComplexGenerated.complexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSign: _factoriesAny.createSign\n};\nexports.signDependencies = signDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.simplifyDependencies = void 0;\n\nvar _dependenciesBignumberGenerated = require(\"./dependenciesBignumber.generated.js\");\n\nvar _dependenciesFractionGenerated = require(\"./dependenciesFraction.generated.js\");\n\nvar _dependenciesAccessorNodeGenerated = require(\"./dependenciesAccessorNode.generated.js\");\n\nvar _dependenciesArrayNodeGenerated = require(\"./dependenciesArrayNode.generated.js\");\n\nvar _dependenciesConstantNodeGenerated = require(\"./dependenciesConstantNode.generated.js\");\n\nvar _dependenciesFunctionNodeGenerated = require(\"./dependenciesFunctionNode.generated.js\");\n\nvar _dependenciesIndexNodeGenerated = require(\"./dependenciesIndexNode.generated.js\");\n\nvar _dependenciesObjectNodeGenerated = require(\"./dependenciesObjectNode.generated.js\");\n\nvar _dependenciesOperatorNodeGenerated = require(\"./dependenciesOperatorNode.generated.js\");\n\nvar _dependenciesParenthesisNodeGenerated = require(\"./dependenciesParenthesisNode.generated.js\");\n\nvar _dependenciesSymbolNodeGenerated = require(\"./dependenciesSymbolNode.generated.js\");\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesDivideGenerated = require(\"./dependenciesDivide.generated.js\");\n\nvar _dependenciesEqualGenerated = require(\"./dependenciesEqual.generated.js\");\n\nvar _dependenciesIsZeroGenerated = require(\"./dependenciesIsZero.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesParseGenerated = require(\"./dependenciesParse.generated.js\");\n\nvar _dependenciesPowGenerated = require(\"./dependenciesPow.generated.js\");\n\nvar _dependenciesResolveGenerated = require(\"./dependenciesResolve.generated.js\");\n\nvar _dependenciesSimplifyCoreGenerated = require(\"./dependenciesSimplifyCore.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar simplifyDependencies = {\n bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies,\n fractionDependencies: _dependenciesFractionGenerated.fractionDependencies,\n AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies,\n ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies,\n ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies,\n FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies,\n IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies,\n ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies,\n OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies,\n ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies,\n SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies,\n addDependencies: _dependenciesAddGenerated.addDependencies,\n divideDependencies: _dependenciesDivideGenerated.divideDependencies,\n equalDependencies: _dependenciesEqualGenerated.equalDependencies,\n isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n parseDependencies: _dependenciesParseGenerated.parseDependencies,\n powDependencies: _dependenciesPowGenerated.powDependencies,\n resolveDependencies: _dependenciesResolveGenerated.resolveDependencies,\n simplifyCoreDependencies: _dependenciesSimplifyCoreGenerated.simplifyCoreDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSimplify: _factoriesAny.createSimplify\n};\nexports.simplifyDependencies = simplifyDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.simplifyCoreDependencies = void 0;\n\nvar _dependenciesAccessorNodeGenerated = require(\"./dependenciesAccessorNode.generated.js\");\n\nvar _dependenciesArrayNodeGenerated = require(\"./dependenciesArrayNode.generated.js\");\n\nvar _dependenciesConstantNodeGenerated = require(\"./dependenciesConstantNode.generated.js\");\n\nvar _dependenciesFunctionNodeGenerated = require(\"./dependenciesFunctionNode.generated.js\");\n\nvar _dependenciesIndexNodeGenerated = require(\"./dependenciesIndexNode.generated.js\");\n\nvar _dependenciesObjectNodeGenerated = require(\"./dependenciesObjectNode.generated.js\");\n\nvar _dependenciesOperatorNodeGenerated = require(\"./dependenciesOperatorNode.generated.js\");\n\nvar _dependenciesParenthesisNodeGenerated = require(\"./dependenciesParenthesisNode.generated.js\");\n\nvar _dependenciesSymbolNodeGenerated = require(\"./dependenciesSymbolNode.generated.js\");\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesDivideGenerated = require(\"./dependenciesDivide.generated.js\");\n\nvar _dependenciesEqualGenerated = require(\"./dependenciesEqual.generated.js\");\n\nvar _dependenciesIsZeroGenerated = require(\"./dependenciesIsZero.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesPowGenerated = require(\"./dependenciesPow.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar simplifyCoreDependencies = {\n AccessorNodeDependencies: _dependenciesAccessorNodeGenerated.AccessorNodeDependencies,\n ArrayNodeDependencies: _dependenciesArrayNodeGenerated.ArrayNodeDependencies,\n ConstantNodeDependencies: _dependenciesConstantNodeGenerated.ConstantNodeDependencies,\n FunctionNodeDependencies: _dependenciesFunctionNodeGenerated.FunctionNodeDependencies,\n IndexNodeDependencies: _dependenciesIndexNodeGenerated.IndexNodeDependencies,\n ObjectNodeDependencies: _dependenciesObjectNodeGenerated.ObjectNodeDependencies,\n OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies,\n ParenthesisNodeDependencies: _dependenciesParenthesisNodeGenerated.ParenthesisNodeDependencies,\n SymbolNodeDependencies: _dependenciesSymbolNodeGenerated.SymbolNodeDependencies,\n addDependencies: _dependenciesAddGenerated.addDependencies,\n divideDependencies: _dependenciesDivideGenerated.divideDependencies,\n equalDependencies: _dependenciesEqualGenerated.equalDependencies,\n isZeroDependencies: _dependenciesIsZeroGenerated.isZeroDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n powDependencies: _dependenciesPowGenerated.powDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n createSimplifyCore: _factoriesAny.createSimplifyCore\n};\nexports.simplifyCoreDependencies = simplifyCoreDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sinDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar sinDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSin: _factoriesAny.createSin\n};\nexports.sinDependencies = sinDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sinhDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar sinhDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSinh: _factoriesAny.createSinh\n};\nexports.sinhDependencies = sinhDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sizeDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar sizeDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSize: _factoriesAny.createSize\n};\nexports.sizeDependencies = sizeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sluDependencies = void 0;\n\nvar _dependenciesSparseMatrixClassGenerated = require(\"./dependenciesSparseMatrixClass.generated.js\");\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAbs.generated.js\");\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesLargerGenerated = require(\"./dependenciesLarger.generated.js\");\n\nvar _dependenciesLargerEqGenerated = require(\"./dependenciesLargerEq.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTransposeGenerated = require(\"./dependenciesTranspose.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar sluDependencies = {\n SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies,\n absDependencies: _dependenciesAbsGenerated.absDependencies,\n addDependencies: _dependenciesAddGenerated.addDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n largerDependencies: _dependenciesLargerGenerated.largerDependencies,\n largerEqDependencies: _dependenciesLargerEqGenerated.largerEqDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n transposeDependencies: _dependenciesTransposeGenerated.transposeDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSlu: _factoriesAny.createSlu\n};\nexports.sluDependencies = sluDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.smallerDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar smallerDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSmaller: _factoriesAny.createSmaller\n};\nexports.smallerDependencies = smallerDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.smallerEqDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar smallerEqDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSmallerEq: _factoriesAny.createSmallerEq\n};\nexports.smallerEqDependencies = smallerEqDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sortDependencies = void 0;\n\nvar _dependenciesCompareGenerated = require(\"./dependenciesCompare.generated.js\");\n\nvar _dependenciesCompareNaturalGenerated = require(\"./dependenciesCompareNatural.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar sortDependencies = {\n compareDependencies: _dependenciesCompareGenerated.compareDependencies,\n compareNaturalDependencies: _dependenciesCompareNaturalGenerated.compareNaturalDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSort: _factoriesAny.createSort\n};\nexports.sortDependencies = sortDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.SpaDependencies = void 0;\n\nvar _dependenciesFibonacciHeapClassGenerated = require(\"./dependenciesFibonacciHeapClass.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar SpaDependencies = {\n FibonacciHeapDependencies: _dependenciesFibonacciHeapClassGenerated.FibonacciHeapDependencies,\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n createSpaClass: _factoriesAny.createSpaClass\n};\nexports.SpaDependencies = SpaDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sparseDependencies = void 0;\n\nvar _dependenciesSparseMatrixClassGenerated = require(\"./dependenciesSparseMatrixClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar sparseDependencies = {\n SparseMatrixDependencies: _dependenciesSparseMatrixClassGenerated.SparseMatrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSparse: _factoriesAny.createSparse\n};\nexports.sparseDependencies = sparseDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.SparseMatrixDependencies = void 0;\n\nvar _dependenciesMatrixClassGenerated = require(\"./dependenciesMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar SparseMatrixDependencies = {\n MatrixDependencies: _dependenciesMatrixClassGenerated.MatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSparseMatrixClass: _factoriesAny.createSparseMatrixClass\n};\nexports.SparseMatrixDependencies = SparseMatrixDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.speedOfLightDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar speedOfLightDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createSpeedOfLight: _factoriesAny.createSpeedOfLight\n};\nexports.speedOfLightDependencies = speedOfLightDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.splitUnitDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar splitUnitDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSplitUnit: _factoriesAny.createSplitUnit\n};\nexports.splitUnitDependencies = splitUnitDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sqrtDependencies = void 0;\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar sqrtDependencies = {\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSqrt: _factoriesAny.createSqrt\n};\nexports.sqrtDependencies = sqrtDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sqrtmDependencies = void 0;\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAbs.generated.js\");\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesIdentityGenerated = require(\"./dependenciesIdentity.generated.js\");\n\nvar _dependenciesInvGenerated = require(\"./dependenciesInv.generated.js\");\n\nvar _dependenciesMaxGenerated = require(\"./dependenciesMax.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesSizeGenerated = require(\"./dependenciesSize.generated.js\");\n\nvar _dependenciesSqrtGenerated = require(\"./dependenciesSqrt.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar sqrtmDependencies = {\n absDependencies: _dependenciesAbsGenerated.absDependencies,\n addDependencies: _dependenciesAddGenerated.addDependencies,\n identityDependencies: _dependenciesIdentityGenerated.identityDependencies,\n invDependencies: _dependenciesInvGenerated.invDependencies,\n maxDependencies: _dependenciesMaxGenerated.maxDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n sizeDependencies: _dependenciesSizeGenerated.sizeDependencies,\n sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSqrtm: _factoriesAny.createSqrtm\n};\nexports.sqrtmDependencies = sqrtmDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.squareDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar squareDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSquare: _factoriesAny.createSquare\n};\nexports.squareDependencies = squareDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.squeezeDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar squeezeDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSqueeze: _factoriesAny.createSqueeze\n};\nexports.squeezeDependencies = squeezeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.stdDependencies = void 0;\n\nvar _dependenciesSqrtGenerated = require(\"./dependenciesSqrt.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesVarianceGenerated = require(\"./dependenciesVariance.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar stdDependencies = {\n sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n varianceDependencies: _dependenciesVarianceGenerated.varianceDependencies,\n createStd: _factoriesAny.createStd\n};\nexports.stdDependencies = stdDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.stdTransformDependencies = void 0;\n\nvar _dependenciesSqrtGenerated = require(\"./dependenciesSqrt.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesVarianceGenerated = require(\"./dependenciesVariance.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar stdTransformDependencies = {\n sqrtDependencies: _dependenciesSqrtGenerated.sqrtDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n varianceDependencies: _dependenciesVarianceGenerated.varianceDependencies,\n createStdTransform: _factoriesAny.createStdTransform\n};\nexports.stdTransformDependencies = stdTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.stefanBoltzmannDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar stefanBoltzmannDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createStefanBoltzmann: _factoriesAny.createStefanBoltzmann\n};\nexports.stefanBoltzmannDependencies = stefanBoltzmannDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.stirlingS2Dependencies = void 0;\n\nvar _dependenciesBignumberGenerated = require(\"./dependenciesBignumber.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesCombinationsGenerated = require(\"./dependenciesCombinations.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesFactorialGenerated = require(\"./dependenciesFactorial.generated.js\");\n\nvar _dependenciesIsIntegerGenerated = require(\"./dependenciesIsInteger.generated.js\");\n\nvar _dependenciesIsNegativeGenerated = require(\"./dependenciesIsNegative.generated.js\");\n\nvar _dependenciesLargerGenerated = require(\"./dependenciesLarger.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesNumberGenerated = require(\"./dependenciesNumber.generated.js\");\n\nvar _dependenciesPowGenerated = require(\"./dependenciesPow.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar stirlingS2Dependencies = {\n bignumberDependencies: _dependenciesBignumberGenerated.bignumberDependencies,\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n combinationsDependencies: _dependenciesCombinationsGenerated.combinationsDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n factorialDependencies: _dependenciesFactorialGenerated.factorialDependencies,\n isIntegerDependencies: _dependenciesIsIntegerGenerated.isIntegerDependencies,\n isNegativeDependencies: _dependenciesIsNegativeGenerated.isNegativeDependencies,\n largerDependencies: _dependenciesLargerGenerated.largerDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n numberDependencies: _dependenciesNumberGenerated.numberDependencies,\n powDependencies: _dependenciesPowGenerated.powDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createStirlingS2: _factoriesAny.createStirlingS2\n};\nexports.stirlingS2Dependencies = stirlingS2Dependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.stringDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar stringDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createString: _factoriesAny.createString\n};\nexports.stringDependencies = stringDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.subsetDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar subsetDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSubset: _factoriesAny.createSubset\n};\nexports.subsetDependencies = subsetDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.subsetTransformDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar subsetTransformDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSubsetTransform: _factoriesAny.createSubsetTransform\n};\nexports.subsetTransformDependencies = subsetTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.subtractDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _dependenciesUnaryMinusGenerated = require(\"./dependenciesUnaryMinus.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar subtractDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n unaryMinusDependencies: _dependenciesUnaryMinusGenerated.unaryMinusDependencies,\n createSubtract: _factoriesAny.createSubtract\n};\nexports.subtractDependencies = subtractDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sumDependencies = void 0;\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesNumericGenerated = require(\"./dependenciesNumeric.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar sumDependencies = {\n addDependencies: _dependenciesAddGenerated.addDependencies,\n numericDependencies: _dependenciesNumericGenerated.numericDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSum: _factoriesAny.createSum\n};\nexports.sumDependencies = sumDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sumTransformDependencies = void 0;\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesNumericGenerated = require(\"./dependenciesNumeric.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar sumTransformDependencies = {\n addDependencies: _dependenciesAddGenerated.addDependencies,\n numericDependencies: _dependenciesNumericGenerated.numericDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSumTransform: _factoriesAny.createSumTransform\n};\nexports.sumTransformDependencies = sumTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.SymbolNodeDependencies = void 0;\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _dependenciesNodeGenerated = require(\"./dependenciesNode.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar SymbolNodeDependencies = {\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n NodeDependencies: _dependenciesNodeGenerated.NodeDependencies,\n createSymbolNode: _factoriesAny.createSymbolNode\n};\nexports.SymbolNodeDependencies = SymbolNodeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.symbolicEqualDependencies = void 0;\n\nvar _dependenciesOperatorNodeGenerated = require(\"./dependenciesOperatorNode.generated.js\");\n\nvar _dependenciesParseGenerated = require(\"./dependenciesParse.generated.js\");\n\nvar _dependenciesSimplifyGenerated = require(\"./dependenciesSimplify.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar symbolicEqualDependencies = {\n OperatorNodeDependencies: _dependenciesOperatorNodeGenerated.OperatorNodeDependencies,\n parseDependencies: _dependenciesParseGenerated.parseDependencies,\n simplifyDependencies: _dependenciesSimplifyGenerated.simplifyDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createSymbolicEqual: _factoriesAny.createSymbolicEqual\n};\nexports.symbolicEqualDependencies = symbolicEqualDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.tanDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar tanDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createTan: _factoriesAny.createTan\n};\nexports.tanDependencies = tanDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.tanhDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar tanhDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createTanh: _factoriesAny.createTanh\n};\nexports.tanhDependencies = tanhDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.tauDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar tauDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createTau: _factoriesAny.createTau\n};\nexports.tauDependencies = tauDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.thomsonCrossSectionDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar thomsonCrossSectionDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createThomsonCrossSection: _factoriesAny.createThomsonCrossSection\n};\nexports.thomsonCrossSectionDependencies = thomsonCrossSectionDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.toDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar toDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createTo: _factoriesAny.createTo\n};\nexports.toDependencies = toDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.traceDependencies = void 0;\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar traceDependencies = {\n addDependencies: _dependenciesAddGenerated.addDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createTrace: _factoriesAny.createTrace\n};\nexports.traceDependencies = traceDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.transposeDependencies = void 0;\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar transposeDependencies = {\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createTranspose: _factoriesAny.createTranspose\n};\nexports.transposeDependencies = transposeDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.trueDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar trueDependencies = {\n createTrue: _factoriesAny.createTrue\n};\nexports.trueDependencies = trueDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.typeOfDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar typeOfDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createTypeOf: _factoriesAny.createTypeOf\n};\nexports.typeOfDependencies = typeOfDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.typedDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesFractionClassGenerated = require(\"./dependenciesFractionClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar typedDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n FractionDependencies: _dependenciesFractionClassGenerated.FractionDependencies,\n createTyped: _factoriesAny.createTyped\n};\nexports.typedDependencies = typedDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.unaryMinusDependencies = void 0;\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar unaryMinusDependencies = {\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createUnaryMinus: _factoriesAny.createUnaryMinus\n};\nexports.unaryMinusDependencies = unaryMinusDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.unaryPlusDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar unaryPlusDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createUnaryPlus: _factoriesAny.createUnaryPlus\n};\nexports.unaryPlusDependencies = unaryPlusDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.unequalDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar unequalDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createUnequal: _factoriesAny.createUnequal\n};\nexports.unequalDependencies = unequalDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.UnitDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesComplexClassGenerated = require(\"./dependenciesComplexClass.generated.js\");\n\nvar _dependenciesFractionClassGenerated = require(\"./dependenciesFractionClass.generated.js\");\n\nvar _dependenciesAbsGenerated = require(\"./dependenciesAbs.generated.js\");\n\nvar _dependenciesAddScalarGenerated = require(\"./dependenciesAddScalar.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesEqualGenerated = require(\"./dependenciesEqual.generated.js\");\n\nvar _dependenciesFixGenerated = require(\"./dependenciesFix.generated.js\");\n\nvar _dependenciesFormatGenerated = require(\"./dependenciesFormat.generated.js\");\n\nvar _dependenciesIsNumericGenerated = require(\"./dependenciesIsNumeric.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesNumberGenerated = require(\"./dependenciesNumber.generated.js\");\n\nvar _dependenciesPowGenerated = require(\"./dependenciesPow.generated.js\");\n\nvar _dependenciesRoundGenerated = require(\"./dependenciesRound.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar UnitDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n ComplexDependencies: _dependenciesComplexClassGenerated.ComplexDependencies,\n FractionDependencies: _dependenciesFractionClassGenerated.FractionDependencies,\n absDependencies: _dependenciesAbsGenerated.absDependencies,\n addScalarDependencies: _dependenciesAddScalarGenerated.addScalarDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n equalDependencies: _dependenciesEqualGenerated.equalDependencies,\n fixDependencies: _dependenciesFixGenerated.fixDependencies,\n formatDependencies: _dependenciesFormatGenerated.formatDependencies,\n isNumericDependencies: _dependenciesIsNumericGenerated.isNumericDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n numberDependencies: _dependenciesNumberGenerated.numberDependencies,\n powDependencies: _dependenciesPowGenerated.powDependencies,\n roundDependencies: _dependenciesRoundGenerated.roundDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n createUnitClass: _factoriesAny.createUnitClass\n};\nexports.UnitDependencies = UnitDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.unitDependencies = void 0;\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar unitDependencies = {\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createUnitFunction: _factoriesAny.createUnitFunction\n};\nexports.unitDependencies = unitDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.EDependencies = void 0;\n\nvar _dependenciesEGenerated = require(\"./dependenciesE.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar EDependencies = {\n eDependencies: _dependenciesEGenerated.eDependencies,\n createUppercaseE: _factoriesAny.createUppercaseE\n};\nexports.EDependencies = EDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.PIDependencies = void 0;\n\nvar _dependenciesPiGenerated = require(\"./dependenciesPi.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar PIDependencies = {\n piDependencies: _dependenciesPiGenerated.piDependencies,\n createUppercasePi: _factoriesAny.createUppercasePi\n};\nexports.PIDependencies = PIDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.usolveDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar usolveDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createUsolve: _factoriesAny.createUsolve\n};\nexports.usolveDependencies = usolveDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.usolveAllDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesDivideScalarGenerated = require(\"./dependenciesDivideScalar.generated.js\");\n\nvar _dependenciesEqualScalarGenerated = require(\"./dependenciesEqualScalar.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesMultiplyScalarGenerated = require(\"./dependenciesMultiplyScalar.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar usolveAllDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n divideScalarDependencies: _dependenciesDivideScalarGenerated.divideScalarDependencies,\n equalScalarDependencies: _dependenciesEqualScalarGenerated.equalScalarDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n multiplyScalarDependencies: _dependenciesMultiplyScalarGenerated.multiplyScalarDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createUsolveAll: _factoriesAny.createUsolveAll\n};\nexports.usolveAllDependencies = usolveAllDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.vacuumImpedanceDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar vacuumImpedanceDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createVacuumImpedance: _factoriesAny.createVacuumImpedance\n};\nexports.vacuumImpedanceDependencies = vacuumImpedanceDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.varianceDependencies = void 0;\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesApplyGenerated = require(\"./dependenciesApply.generated.js\");\n\nvar _dependenciesDivideGenerated = require(\"./dependenciesDivide.generated.js\");\n\nvar _dependenciesIsNaNGenerated = require(\"./dependenciesIsNaN.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar varianceDependencies = {\n addDependencies: _dependenciesAddGenerated.addDependencies,\n applyDependencies: _dependenciesApplyGenerated.applyDependencies,\n divideDependencies: _dependenciesDivideGenerated.divideDependencies,\n isNaNDependencies: _dependenciesIsNaNGenerated.isNaNDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createVariance: _factoriesAny.createVariance\n};\nexports.varianceDependencies = varianceDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.varianceTransformDependencies = void 0;\n\nvar _dependenciesAddGenerated = require(\"./dependenciesAdd.generated.js\");\n\nvar _dependenciesApplyGenerated = require(\"./dependenciesApply.generated.js\");\n\nvar _dependenciesDivideGenerated = require(\"./dependenciesDivide.generated.js\");\n\nvar _dependenciesIsNaNGenerated = require(\"./dependenciesIsNaN.generated.js\");\n\nvar _dependenciesMultiplyGenerated = require(\"./dependenciesMultiply.generated.js\");\n\nvar _dependenciesSubtractGenerated = require(\"./dependenciesSubtract.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar varianceTransformDependencies = {\n addDependencies: _dependenciesAddGenerated.addDependencies,\n applyDependencies: _dependenciesApplyGenerated.applyDependencies,\n divideDependencies: _dependenciesDivideGenerated.divideDependencies,\n isNaNDependencies: _dependenciesIsNaNGenerated.isNaNDependencies,\n multiplyDependencies: _dependenciesMultiplyGenerated.multiplyDependencies,\n subtractDependencies: _dependenciesSubtractGenerated.subtractDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createVarianceTransform: _factoriesAny.createVarianceTransform\n};\nexports.varianceTransformDependencies = varianceTransformDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.versionDependencies = void 0;\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar versionDependencies = {\n createVersion: _factoriesAny.createVersion\n};\nexports.versionDependencies = versionDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.weakMixingAngleDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar weakMixingAngleDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n createWeakMixingAngle: _factoriesAny.createWeakMixingAngle\n};\nexports.weakMixingAngleDependencies = weakMixingAngleDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.wienDisplacementDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesUnitClassGenerated = require(\"./dependenciesUnitClass.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar wienDisplacementDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n UnitDependencies: _dependenciesUnitClassGenerated.UnitDependencies,\n createWienDisplacement: _factoriesAny.createWienDisplacement\n};\nexports.wienDisplacementDependencies = wienDisplacementDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.xgcdDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar xgcdDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createXgcd: _factoriesAny.createXgcd\n};\nexports.xgcdDependencies = xgcdDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.xorDependencies = void 0;\n\nvar _dependenciesDenseMatrixClassGenerated = require(\"./dependenciesDenseMatrixClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar xorDependencies = {\n DenseMatrixDependencies: _dependenciesDenseMatrixClassGenerated.DenseMatrixDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createXor: _factoriesAny.createXor\n};\nexports.xorDependencies = xorDependencies;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.zerosDependencies = void 0;\n\nvar _dependenciesBigNumberClassGenerated = require(\"./dependenciesBigNumberClass.generated.js\");\n\nvar _dependenciesMatrixGenerated = require(\"./dependenciesMatrix.generated.js\");\n\nvar _dependenciesTypedGenerated = require(\"./dependenciesTyped.generated.js\");\n\nvar _factoriesAny = require(\"../../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar zerosDependencies = {\n BigNumberDependencies: _dependenciesBigNumberClassGenerated.BigNumberDependencies,\n matrixDependencies: _dependenciesMatrixGenerated.matrixDependencies,\n typedDependencies: _dependenciesTypedGenerated.typedDependencies,\n createZeros: _factoriesAny.createZeros\n};\nexports.zerosDependencies = zerosDependencies;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.derivative = exports.compile = exports.chain = exports.SymbolNode = exports.RelationalNode = exports.RangeNode = exports.Parser = exports.ParenthesisNode = exports.OperatorNode = exports.ObjectNode = exports.Node = exports.IndexNode = exports.Help = exports.FunctionNode = exports.FunctionAssignmentNode = exports.ConstantNode = exports.ConditionalNode = exports.Chain = exports.BlockNode = exports.AssignmentNode = exports.ArrayNode = exports.AccessorNode = void 0;\nObject.defineProperty(exports, \"docs\", {\n enumerable: true,\n get: function get() {\n return _embeddedDocs.embeddedDocs;\n }\n});\nexports.symbolicEqual = exports.simplifyCore = exports.simplify = exports.reviver = exports.resolve = exports.rationalize = exports.parser = exports.parse = exports.leafCount = exports.help = exports.evaluate = void 0;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _configReadonly = require(\"./configReadonly.js\");\n\nvar _factoriesAny = require(\"../factoriesAny.js\");\n\nvar _pureFunctionsAnyGenerated = require(\"./pureFunctionsAny.generated.js\");\n\nvar _embeddedDocs = require(\"../expression/embeddedDocs/embeddedDocs.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar math = {}; // NOT pure!\n\nvar mathWithTransform = {}; // NOT pure!\n\nvar classes = {}; // NOT pure!\n\nvar Chain = (0, _factoriesAny.createChainClass)({\n math: math\n});\nexports.Chain = Chain;\nvar Node = (0, _factoriesAny.createNode)({\n mathWithTransform: mathWithTransform\n});\nexports.Node = Node;\nvar ObjectNode = (0, _factoriesAny.createObjectNode)({\n Node: Node\n});\nexports.ObjectNode = ObjectNode;\nvar OperatorNode = (0, _factoriesAny.createOperatorNode)({\n Node: Node\n});\nexports.OperatorNode = OperatorNode;\nvar ParenthesisNode = (0, _factoriesAny.createParenthesisNode)({\n Node: Node\n});\nexports.ParenthesisNode = ParenthesisNode;\nvar RelationalNode = (0, _factoriesAny.createRelationalNode)({\n Node: Node\n});\nexports.RelationalNode = RelationalNode;\nvar ArrayNode = (0, _factoriesAny.createArrayNode)({\n Node: Node\n});\nexports.ArrayNode = ArrayNode;\nvar BlockNode = (0, _factoriesAny.createBlockNode)({\n Node: Node,\n ResultSet: _pureFunctionsAnyGenerated.ResultSet\n});\nexports.BlockNode = BlockNode;\nvar ConditionalNode = (0, _factoriesAny.createConditionalNode)({\n Node: Node\n});\nexports.ConditionalNode = ConditionalNode;\nvar ConstantNode = (0, _factoriesAny.createConstantNode)({\n Node: Node\n});\nexports.ConstantNode = ConstantNode;\nvar RangeNode = (0, _factoriesAny.createRangeNode)({\n Node: Node\n});\nexports.RangeNode = RangeNode;\nvar reviver = (0, _factoriesAny.createReviver)({\n classes: classes\n});\nexports.reviver = reviver;\nvar chain = (0, _factoriesAny.createChain)({\n Chain: Chain,\n typed: _pureFunctionsAnyGenerated.typed\n});\nexports.chain = chain;\nvar FunctionAssignmentNode = (0, _factoriesAny.createFunctionAssignmentNode)({\n Node: Node,\n typed: _pureFunctionsAnyGenerated.typed\n});\nexports.FunctionAssignmentNode = FunctionAssignmentNode;\nvar AccessorNode = (0, _factoriesAny.createAccessorNode)({\n Node: Node,\n subset: _pureFunctionsAnyGenerated.subset\n});\nexports.AccessorNode = AccessorNode;\nvar AssignmentNode = (0, _factoriesAny.createAssignmentNode)({\n matrix: _pureFunctionsAnyGenerated.matrix,\n Node: Node,\n subset: _pureFunctionsAnyGenerated.subset\n});\nexports.AssignmentNode = AssignmentNode;\nvar IndexNode = (0, _factoriesAny.createIndexNode)({\n Node: Node,\n size: _pureFunctionsAnyGenerated.size\n});\nexports.IndexNode = IndexNode;\nvar SymbolNode = (0, _factoriesAny.createSymbolNode)({\n Unit: _pureFunctionsAnyGenerated.Unit,\n Node: Node,\n math: math\n});\nexports.SymbolNode = SymbolNode;\nvar FunctionNode = (0, _factoriesAny.createFunctionNode)({\n Node: Node,\n SymbolNode: SymbolNode,\n math: math\n});\nexports.FunctionNode = FunctionNode;\nvar parse = (0, _factoriesAny.createParse)({\n AccessorNode: AccessorNode,\n ArrayNode: ArrayNode,\n AssignmentNode: AssignmentNode,\n BlockNode: BlockNode,\n ConditionalNode: ConditionalNode,\n ConstantNode: ConstantNode,\n FunctionAssignmentNode: FunctionAssignmentNode,\n FunctionNode: FunctionNode,\n IndexNode: IndexNode,\n ObjectNode: ObjectNode,\n OperatorNode: OperatorNode,\n ParenthesisNode: ParenthesisNode,\n RangeNode: RangeNode,\n RelationalNode: RelationalNode,\n SymbolNode: SymbolNode,\n config: _configReadonly.config,\n numeric: _pureFunctionsAnyGenerated.numeric,\n typed: _pureFunctionsAnyGenerated.typed\n});\nexports.parse = parse;\nvar resolve = (0, _factoriesAny.createResolve)({\n ConstantNode: ConstantNode,\n FunctionNode: FunctionNode,\n OperatorNode: OperatorNode,\n ParenthesisNode: ParenthesisNode,\n parse: parse\n});\nexports.resolve = resolve;\nvar simplifyCore = (0, _factoriesAny.createSimplifyCore)({\n AccessorNode: AccessorNode,\n ArrayNode: ArrayNode,\n ConstantNode: ConstantNode,\n FunctionNode: FunctionNode,\n IndexNode: IndexNode,\n ObjectNode: ObjectNode,\n OperatorNode: OperatorNode,\n ParenthesisNode: ParenthesisNode,\n SymbolNode: SymbolNode,\n add: _pureFunctionsAnyGenerated.add,\n divide: _pureFunctionsAnyGenerated.divide,\n equal: _pureFunctionsAnyGenerated.equal,\n isZero: _pureFunctionsAnyGenerated.isZero,\n multiply: _pureFunctionsAnyGenerated.multiply,\n pow: _pureFunctionsAnyGenerated.pow,\n subtract: _pureFunctionsAnyGenerated.subtract\n});\nexports.simplifyCore = simplifyCore;\nvar compile = (0, _factoriesAny.createCompile)({\n parse: parse,\n typed: _pureFunctionsAnyGenerated.typed\n});\nexports.compile = compile;\nvar Help = (0, _factoriesAny.createHelpClass)({\n parse: parse\n});\nexports.Help = Help;\nvar leafCount = (0, _factoriesAny.createLeafCount)({\n parse: parse,\n typed: _pureFunctionsAnyGenerated.typed\n});\nexports.leafCount = leafCount;\nvar simplify = (0, _factoriesAny.createSimplify)({\n bignumber: _pureFunctionsAnyGenerated.bignumber,\n fraction: _pureFunctionsAnyGenerated.fraction,\n AccessorNode: AccessorNode,\n ArrayNode: ArrayNode,\n ConstantNode: ConstantNode,\n FunctionNode: FunctionNode,\n IndexNode: IndexNode,\n ObjectNode: ObjectNode,\n OperatorNode: OperatorNode,\n ParenthesisNode: ParenthesisNode,\n SymbolNode: SymbolNode,\n add: _pureFunctionsAnyGenerated.add,\n config: _configReadonly.config,\n divide: _pureFunctionsAnyGenerated.divide,\n equal: _pureFunctionsAnyGenerated.equal,\n isZero: _pureFunctionsAnyGenerated.isZero,\n mathWithTransform: mathWithTransform,\n matrix: _pureFunctionsAnyGenerated.matrix,\n multiply: _pureFunctionsAnyGenerated.multiply,\n parse: parse,\n pow: _pureFunctionsAnyGenerated.pow,\n resolve: resolve,\n simplifyCore: simplifyCore,\n subtract: _pureFunctionsAnyGenerated.subtract,\n typed: _pureFunctionsAnyGenerated.typed\n});\nexports.simplify = simplify;\nvar symbolicEqual = (0, _factoriesAny.createSymbolicEqual)({\n OperatorNode: OperatorNode,\n parse: parse,\n simplify: simplify,\n typed: _pureFunctionsAnyGenerated.typed\n});\nexports.symbolicEqual = symbolicEqual;\nvar evaluate = (0, _factoriesAny.createEvaluate)({\n parse: parse,\n typed: _pureFunctionsAnyGenerated.typed\n});\nexports.evaluate = evaluate;\nvar help = (0, _factoriesAny.createHelp)({\n Help: Help,\n mathWithTransform: mathWithTransform,\n typed: _pureFunctionsAnyGenerated.typed\n});\nexports.help = help;\nvar Parser = (0, _factoriesAny.createParserClass)({\n evaluate: evaluate\n});\nexports.Parser = Parser;\nvar rationalize = (0, _factoriesAny.createRationalize)({\n bignumber: _pureFunctionsAnyGenerated.bignumber,\n fraction: _pureFunctionsAnyGenerated.fraction,\n AccessorNode: AccessorNode,\n ArrayNode: ArrayNode,\n ConstantNode: ConstantNode,\n FunctionNode: FunctionNode,\n IndexNode: IndexNode,\n ObjectNode: ObjectNode,\n OperatorNode: OperatorNode,\n ParenthesisNode: ParenthesisNode,\n SymbolNode: SymbolNode,\n add: _pureFunctionsAnyGenerated.add,\n config: _configReadonly.config,\n divide: _pureFunctionsAnyGenerated.divide,\n equal: _pureFunctionsAnyGenerated.equal,\n isZero: _pureFunctionsAnyGenerated.isZero,\n mathWithTransform: mathWithTransform,\n matrix: _pureFunctionsAnyGenerated.matrix,\n multiply: _pureFunctionsAnyGenerated.multiply,\n parse: parse,\n pow: _pureFunctionsAnyGenerated.pow,\n simplify: simplify,\n simplifyCore: simplifyCore,\n subtract: _pureFunctionsAnyGenerated.subtract,\n typed: _pureFunctionsAnyGenerated.typed\n});\nexports.rationalize = rationalize;\nvar derivative = (0, _factoriesAny.createDerivative)({\n ConstantNode: ConstantNode,\n FunctionNode: FunctionNode,\n OperatorNode: OperatorNode,\n ParenthesisNode: ParenthesisNode,\n SymbolNode: SymbolNode,\n config: _configReadonly.config,\n equal: _pureFunctionsAnyGenerated.equal,\n isZero: _pureFunctionsAnyGenerated.isZero,\n numeric: _pureFunctionsAnyGenerated.numeric,\n parse: parse,\n simplify: simplify,\n typed: _pureFunctionsAnyGenerated.typed\n});\nexports.derivative = derivative;\nvar parser = (0, _factoriesAny.createParser)({\n Parser: Parser,\n typed: _pureFunctionsAnyGenerated.typed\n});\nexports.parser = parser;\n(0, _extends2.default)(math, {\n e: _pureFunctionsAnyGenerated.e,\n false: _pureFunctionsAnyGenerated._false,\n fineStructure: _pureFunctionsAnyGenerated.fineStructure,\n i: _pureFunctionsAnyGenerated.i,\n Infinity: _pureFunctionsAnyGenerated._Infinity,\n LN10: _pureFunctionsAnyGenerated.LN10,\n LOG10E: _pureFunctionsAnyGenerated.LOG10E,\n NaN: _pureFunctionsAnyGenerated._NaN,\n null: _pureFunctionsAnyGenerated._null,\n phi: _pureFunctionsAnyGenerated.phi,\n SQRT1_2: _pureFunctionsAnyGenerated.SQRT1_2,\n sackurTetrode: _pureFunctionsAnyGenerated.sackurTetrode,\n tau: _pureFunctionsAnyGenerated.tau,\n true: _pureFunctionsAnyGenerated._true,\n 'E': _pureFunctionsAnyGenerated.e,\n version: _pureFunctionsAnyGenerated.version,\n efimovFactor: _pureFunctionsAnyGenerated.efimovFactor,\n LN2: _pureFunctionsAnyGenerated.LN2,\n pi: _pureFunctionsAnyGenerated.pi,\n replacer: _pureFunctionsAnyGenerated.replacer,\n reviver: reviver,\n SQRT2: _pureFunctionsAnyGenerated.SQRT2,\n typed: _pureFunctionsAnyGenerated.typed,\n unaryPlus: _pureFunctionsAnyGenerated.unaryPlus,\n 'PI': _pureFunctionsAnyGenerated.pi,\n weakMixingAngle: _pureFunctionsAnyGenerated.weakMixingAngle,\n abs: _pureFunctionsAnyGenerated.abs,\n acos: _pureFunctionsAnyGenerated.acos,\n acot: _pureFunctionsAnyGenerated.acot,\n acsc: _pureFunctionsAnyGenerated.acsc,\n addScalar: _pureFunctionsAnyGenerated.addScalar,\n arg: _pureFunctionsAnyGenerated.arg,\n asech: _pureFunctionsAnyGenerated.asech,\n asinh: _pureFunctionsAnyGenerated.asinh,\n atan: _pureFunctionsAnyGenerated.atan,\n atanh: _pureFunctionsAnyGenerated.atanh,\n bignumber: _pureFunctionsAnyGenerated.bignumber,\n bitNot: _pureFunctionsAnyGenerated.bitNot,\n boolean: _pureFunctionsAnyGenerated.boolean,\n chain: chain,\n clone: _pureFunctionsAnyGenerated.clone,\n combinations: _pureFunctionsAnyGenerated.combinations,\n complex: _pureFunctionsAnyGenerated.complex,\n conj: _pureFunctionsAnyGenerated.conj,\n cosh: _pureFunctionsAnyGenerated.cosh,\n coth: _pureFunctionsAnyGenerated.coth,\n csc: _pureFunctionsAnyGenerated.csc,\n cube: _pureFunctionsAnyGenerated.cube,\n equalScalar: _pureFunctionsAnyGenerated.equalScalar,\n erf: _pureFunctionsAnyGenerated.erf,\n exp: _pureFunctionsAnyGenerated.exp,\n expm1: _pureFunctionsAnyGenerated.expm1,\n filter: _pureFunctionsAnyGenerated.filter,\n forEach: _pureFunctionsAnyGenerated.forEach,\n format: _pureFunctionsAnyGenerated.format,\n getMatrixDataType: _pureFunctionsAnyGenerated.getMatrixDataType,\n hex: _pureFunctionsAnyGenerated.hex,\n im: _pureFunctionsAnyGenerated.im,\n isInteger: _pureFunctionsAnyGenerated.isInteger,\n isNegative: _pureFunctionsAnyGenerated.isNegative,\n isPositive: _pureFunctionsAnyGenerated.isPositive,\n isZero: _pureFunctionsAnyGenerated.isZero,\n LOG2E: _pureFunctionsAnyGenerated.LOG2E,\n lgamma: _pureFunctionsAnyGenerated.lgamma,\n log10: _pureFunctionsAnyGenerated.log10,\n log2: _pureFunctionsAnyGenerated.log2,\n map: _pureFunctionsAnyGenerated.map,\n multiplyScalar: _pureFunctionsAnyGenerated.multiplyScalar,\n not: _pureFunctionsAnyGenerated.not,\n number: _pureFunctionsAnyGenerated.number,\n oct: _pureFunctionsAnyGenerated.oct,\n pickRandom: _pureFunctionsAnyGenerated.pickRandom,\n print: _pureFunctionsAnyGenerated.print,\n random: _pureFunctionsAnyGenerated.random,\n re: _pureFunctionsAnyGenerated.re,\n sec: _pureFunctionsAnyGenerated.sec,\n sign: _pureFunctionsAnyGenerated.sign,\n sin: _pureFunctionsAnyGenerated.sin,\n splitUnit: _pureFunctionsAnyGenerated.splitUnit,\n square: _pureFunctionsAnyGenerated.square,\n string: _pureFunctionsAnyGenerated.string,\n tan: _pureFunctionsAnyGenerated.tan,\n typeOf: _pureFunctionsAnyGenerated.typeOf,\n acosh: _pureFunctionsAnyGenerated.acosh,\n acsch: _pureFunctionsAnyGenerated.acsch,\n apply: _pureFunctionsAnyGenerated.apply,\n asec: _pureFunctionsAnyGenerated.asec,\n bin: _pureFunctionsAnyGenerated.bin,\n combinationsWithRep: _pureFunctionsAnyGenerated.combinationsWithRep,\n cos: _pureFunctionsAnyGenerated.cos,\n csch: _pureFunctionsAnyGenerated.csch,\n isNaN: _pureFunctionsAnyGenerated.isNaN,\n isPrime: _pureFunctionsAnyGenerated.isPrime,\n randomInt: _pureFunctionsAnyGenerated.randomInt,\n sech: _pureFunctionsAnyGenerated.sech,\n sinh: _pureFunctionsAnyGenerated.sinh,\n sparse: _pureFunctionsAnyGenerated.sparse,\n sqrt: _pureFunctionsAnyGenerated.sqrt,\n tanh: _pureFunctionsAnyGenerated.tanh,\n unaryMinus: _pureFunctionsAnyGenerated.unaryMinus,\n acoth: _pureFunctionsAnyGenerated.acoth,\n cot: _pureFunctionsAnyGenerated.cot,\n fraction: _pureFunctionsAnyGenerated.fraction,\n isNumeric: _pureFunctionsAnyGenerated.isNumeric,\n matrix: _pureFunctionsAnyGenerated.matrix,\n matrixFromFunction: _pureFunctionsAnyGenerated.matrixFromFunction,\n mod: _pureFunctionsAnyGenerated.mod,\n nthRoot: _pureFunctionsAnyGenerated.nthRoot,\n numeric: _pureFunctionsAnyGenerated.numeric,\n or: _pureFunctionsAnyGenerated.or,\n prod: _pureFunctionsAnyGenerated.prod,\n reshape: _pureFunctionsAnyGenerated.reshape,\n size: _pureFunctionsAnyGenerated.size,\n smaller: _pureFunctionsAnyGenerated.smaller,\n squeeze: _pureFunctionsAnyGenerated.squeeze,\n subset: _pureFunctionsAnyGenerated.subset,\n subtract: _pureFunctionsAnyGenerated.subtract,\n to: _pureFunctionsAnyGenerated.to,\n transpose: _pureFunctionsAnyGenerated.transpose,\n xgcd: _pureFunctionsAnyGenerated.xgcd,\n zeros: _pureFunctionsAnyGenerated.zeros,\n and: _pureFunctionsAnyGenerated.and,\n bitAnd: _pureFunctionsAnyGenerated.bitAnd,\n bitXor: _pureFunctionsAnyGenerated.bitXor,\n cbrt: _pureFunctionsAnyGenerated.cbrt,\n compare: _pureFunctionsAnyGenerated.compare,\n compareText: _pureFunctionsAnyGenerated.compareText,\n concat: _pureFunctionsAnyGenerated.concat,\n count: _pureFunctionsAnyGenerated.count,\n ctranspose: _pureFunctionsAnyGenerated.ctranspose,\n diag: _pureFunctionsAnyGenerated.diag,\n divideScalar: _pureFunctionsAnyGenerated.divideScalar,\n dotDivide: _pureFunctionsAnyGenerated.dotDivide,\n equal: _pureFunctionsAnyGenerated.equal,\n fft: _pureFunctionsAnyGenerated.fft,\n flatten: _pureFunctionsAnyGenerated.flatten,\n gcd: _pureFunctionsAnyGenerated.gcd,\n hasNumericValue: _pureFunctionsAnyGenerated.hasNumericValue,\n hypot: _pureFunctionsAnyGenerated.hypot,\n ifft: _pureFunctionsAnyGenerated.ifft,\n kron: _pureFunctionsAnyGenerated.kron,\n largerEq: _pureFunctionsAnyGenerated.largerEq,\n leftShift: _pureFunctionsAnyGenerated.leftShift,\n lsolve: _pureFunctionsAnyGenerated.lsolve,\n matrixFromColumns: _pureFunctionsAnyGenerated.matrixFromColumns,\n min: _pureFunctionsAnyGenerated.min,\n mode: _pureFunctionsAnyGenerated.mode,\n nthRoots: _pureFunctionsAnyGenerated.nthRoots,\n ones: _pureFunctionsAnyGenerated.ones,\n partitionSelect: _pureFunctionsAnyGenerated.partitionSelect,\n resize: _pureFunctionsAnyGenerated.resize,\n rightArithShift: _pureFunctionsAnyGenerated.rightArithShift,\n round: _pureFunctionsAnyGenerated.round,\n smallerEq: _pureFunctionsAnyGenerated.smallerEq,\n unequal: _pureFunctionsAnyGenerated.unequal,\n usolve: _pureFunctionsAnyGenerated.usolve,\n xor: _pureFunctionsAnyGenerated.xor,\n add: _pureFunctionsAnyGenerated.add,\n atan2: _pureFunctionsAnyGenerated.atan2,\n bitOr: _pureFunctionsAnyGenerated.bitOr,\n catalan: _pureFunctionsAnyGenerated.catalan,\n compareNatural: _pureFunctionsAnyGenerated.compareNatural,\n cumsum: _pureFunctionsAnyGenerated.cumsum,\n deepEqual: _pureFunctionsAnyGenerated.deepEqual,\n diff: _pureFunctionsAnyGenerated.diff,\n dot: _pureFunctionsAnyGenerated.dot,\n equalText: _pureFunctionsAnyGenerated.equalText,\n floor: _pureFunctionsAnyGenerated.floor,\n identity: _pureFunctionsAnyGenerated.identity,\n invmod: _pureFunctionsAnyGenerated.invmod,\n larger: _pureFunctionsAnyGenerated.larger,\n log: _pureFunctionsAnyGenerated.log,\n lsolveAll: _pureFunctionsAnyGenerated.lsolveAll,\n matrixFromRows: _pureFunctionsAnyGenerated.matrixFromRows,\n multiply: _pureFunctionsAnyGenerated.multiply,\n qr: _pureFunctionsAnyGenerated.qr,\n range: _pureFunctionsAnyGenerated.range,\n rightLogShift: _pureFunctionsAnyGenerated.rightLogShift,\n setSize: _pureFunctionsAnyGenerated.setSize,\n slu: _pureFunctionsAnyGenerated.slu,\n sum: _pureFunctionsAnyGenerated.sum,\n trace: _pureFunctionsAnyGenerated.trace,\n usolveAll: _pureFunctionsAnyGenerated.usolveAll,\n asin: _pureFunctionsAnyGenerated.asin,\n ceil: _pureFunctionsAnyGenerated.ceil,\n composition: _pureFunctionsAnyGenerated.composition,\n cross: _pureFunctionsAnyGenerated.cross,\n det: _pureFunctionsAnyGenerated.det,\n distance: _pureFunctionsAnyGenerated.distance,\n dotMultiply: _pureFunctionsAnyGenerated.dotMultiply,\n fix: _pureFunctionsAnyGenerated.fix,\n intersect: _pureFunctionsAnyGenerated.intersect,\n lcm: _pureFunctionsAnyGenerated.lcm,\n log1p: _pureFunctionsAnyGenerated.log1p,\n max: _pureFunctionsAnyGenerated.max,\n quantileSeq: _pureFunctionsAnyGenerated.quantileSeq,\n row: _pureFunctionsAnyGenerated.row,\n setCartesian: _pureFunctionsAnyGenerated.setCartesian,\n setDistinct: _pureFunctionsAnyGenerated.setDistinct,\n setIsSubset: _pureFunctionsAnyGenerated.setIsSubset,\n setPowerset: _pureFunctionsAnyGenerated.setPowerset,\n sort: _pureFunctionsAnyGenerated.sort,\n column: _pureFunctionsAnyGenerated.column,\n index: _pureFunctionsAnyGenerated.index,\n inv: _pureFunctionsAnyGenerated.inv,\n pinv: _pureFunctionsAnyGenerated.pinv,\n pow: _pureFunctionsAnyGenerated.pow,\n setDifference: _pureFunctionsAnyGenerated.setDifference,\n setMultiplicity: _pureFunctionsAnyGenerated.setMultiplicity,\n sqrtm: _pureFunctionsAnyGenerated.sqrtm,\n vacuumImpedance: _pureFunctionsAnyGenerated.vacuumImpedance,\n wienDisplacement: _pureFunctionsAnyGenerated.wienDisplacement,\n atomicMass: _pureFunctionsAnyGenerated.atomicMass,\n bohrMagneton: _pureFunctionsAnyGenerated.bohrMagneton,\n boltzmann: _pureFunctionsAnyGenerated.boltzmann,\n conductanceQuantum: _pureFunctionsAnyGenerated.conductanceQuantum,\n createUnit: _pureFunctionsAnyGenerated.createUnit,\n deuteronMass: _pureFunctionsAnyGenerated.deuteronMass,\n dotPow: _pureFunctionsAnyGenerated.dotPow,\n electricConstant: _pureFunctionsAnyGenerated.electricConstant,\n elementaryCharge: _pureFunctionsAnyGenerated.elementaryCharge,\n expm: _pureFunctionsAnyGenerated.expm,\n faraday: _pureFunctionsAnyGenerated.faraday,\n firstRadiation: _pureFunctionsAnyGenerated.firstRadiation,\n gamma: _pureFunctionsAnyGenerated.gamma,\n gravitationConstant: _pureFunctionsAnyGenerated.gravitationConstant,\n hartreeEnergy: _pureFunctionsAnyGenerated.hartreeEnergy,\n klitzing: _pureFunctionsAnyGenerated.klitzing,\n loschmidt: _pureFunctionsAnyGenerated.loschmidt,\n magneticConstant: _pureFunctionsAnyGenerated.magneticConstant,\n molarMass: _pureFunctionsAnyGenerated.molarMass,\n molarPlanckConstant: _pureFunctionsAnyGenerated.molarPlanckConstant,\n neutronMass: _pureFunctionsAnyGenerated.neutronMass,\n nuclearMagneton: _pureFunctionsAnyGenerated.nuclearMagneton,\n planckCharge: _pureFunctionsAnyGenerated.planckCharge,\n planckLength: _pureFunctionsAnyGenerated.planckLength,\n planckTemperature: _pureFunctionsAnyGenerated.planckTemperature,\n protonMass: _pureFunctionsAnyGenerated.protonMass,\n reducedPlanckConstant: _pureFunctionsAnyGenerated.reducedPlanckConstant,\n rydberg: _pureFunctionsAnyGenerated.rydberg,\n setIntersect: _pureFunctionsAnyGenerated.setIntersect,\n speedOfLight: _pureFunctionsAnyGenerated.speedOfLight,\n stefanBoltzmann: _pureFunctionsAnyGenerated.stefanBoltzmann,\n thomsonCrossSection: _pureFunctionsAnyGenerated.thomsonCrossSection,\n avogadro: _pureFunctionsAnyGenerated.avogadro,\n bohrRadius: _pureFunctionsAnyGenerated.bohrRadius,\n coulomb: _pureFunctionsAnyGenerated.coulomb,\n divide: _pureFunctionsAnyGenerated.divide,\n electronMass: _pureFunctionsAnyGenerated.electronMass,\n factorial: _pureFunctionsAnyGenerated.factorial,\n gravity: _pureFunctionsAnyGenerated.gravity,\n inverseConductanceQuantum: _pureFunctionsAnyGenerated.inverseConductanceQuantum,\n lup: _pureFunctionsAnyGenerated.lup,\n magneticFluxQuantum: _pureFunctionsAnyGenerated.magneticFluxQuantum,\n molarMassC12: _pureFunctionsAnyGenerated.molarMassC12,\n multinomial: _pureFunctionsAnyGenerated.multinomial,\n parse: parse,\n permutations: _pureFunctionsAnyGenerated.permutations,\n planckMass: _pureFunctionsAnyGenerated.planckMass,\n quantumOfCirculation: _pureFunctionsAnyGenerated.quantumOfCirculation,\n resolve: resolve,\n secondRadiation: _pureFunctionsAnyGenerated.secondRadiation,\n simplifyCore: simplifyCore,\n stirlingS2: _pureFunctionsAnyGenerated.stirlingS2,\n unit: _pureFunctionsAnyGenerated.unit,\n bellNumbers: _pureFunctionsAnyGenerated.bellNumbers,\n compile: compile,\n eigs: _pureFunctionsAnyGenerated.eigs,\n fermiCoupling: _pureFunctionsAnyGenerated.fermiCoupling,\n leafCount: leafCount,\n mean: _pureFunctionsAnyGenerated.mean,\n molarVolume: _pureFunctionsAnyGenerated.molarVolume,\n planckConstant: _pureFunctionsAnyGenerated.planckConstant,\n setSymDifference: _pureFunctionsAnyGenerated.setSymDifference,\n simplify: simplify,\n symbolicEqual: symbolicEqual,\n classicalElectronRadius: _pureFunctionsAnyGenerated.classicalElectronRadius,\n evaluate: evaluate,\n help: help,\n lusolve: _pureFunctionsAnyGenerated.lusolve,\n median: _pureFunctionsAnyGenerated.median,\n rationalize: rationalize,\n setUnion: _pureFunctionsAnyGenerated.setUnion,\n variance: _pureFunctionsAnyGenerated.variance,\n derivative: derivative,\n kldivergence: _pureFunctionsAnyGenerated.kldivergence,\n norm: _pureFunctionsAnyGenerated.norm,\n planckTime: _pureFunctionsAnyGenerated.planckTime,\n rotationMatrix: _pureFunctionsAnyGenerated.rotationMatrix,\n gasConstant: _pureFunctionsAnyGenerated.gasConstant,\n parser: parser,\n std: _pureFunctionsAnyGenerated.std,\n mad: _pureFunctionsAnyGenerated.mad,\n rotate: _pureFunctionsAnyGenerated.rotate,\n config: _configReadonly.config\n});\n(0, _extends2.default)(mathWithTransform, math, {\n filter: (0, _factoriesAny.createFilterTransform)({\n typed: _pureFunctionsAnyGenerated.typed\n }),\n forEach: (0, _factoriesAny.createForEachTransform)({\n typed: _pureFunctionsAnyGenerated.typed\n }),\n map: (0, _factoriesAny.createMapTransform)({\n typed: _pureFunctionsAnyGenerated.typed\n }),\n apply: (0, _factoriesAny.createApplyTransform)({\n isInteger: _pureFunctionsAnyGenerated.isInteger,\n typed: _pureFunctionsAnyGenerated.typed\n }),\n diff: (0, _factoriesAny.createDiffTransform)({\n bignumber: _pureFunctionsAnyGenerated.bignumber,\n matrix: _pureFunctionsAnyGenerated.matrix,\n number: _pureFunctionsAnyGenerated.number,\n subtract: _pureFunctionsAnyGenerated.subtract,\n typed: _pureFunctionsAnyGenerated.typed\n }),\n subset: (0, _factoriesAny.createSubsetTransform)({\n matrix: _pureFunctionsAnyGenerated.matrix,\n typed: _pureFunctionsAnyGenerated.typed\n }),\n concat: (0, _factoriesAny.createConcatTransform)({\n isInteger: _pureFunctionsAnyGenerated.isInteger,\n matrix: _pureFunctionsAnyGenerated.matrix,\n typed: _pureFunctionsAnyGenerated.typed\n }),\n max: (0, _factoriesAny.createMaxTransform)({\n config: _configReadonly.config,\n larger: _pureFunctionsAnyGenerated.larger,\n numeric: _pureFunctionsAnyGenerated.numeric,\n typed: _pureFunctionsAnyGenerated.typed\n }),\n min: (0, _factoriesAny.createMinTransform)({\n config: _configReadonly.config,\n numeric: _pureFunctionsAnyGenerated.numeric,\n smaller: _pureFunctionsAnyGenerated.smaller,\n typed: _pureFunctionsAnyGenerated.typed\n }),\n range: (0, _factoriesAny.createRangeTransform)({\n bignumber: _pureFunctionsAnyGenerated.bignumber,\n matrix: _pureFunctionsAnyGenerated.matrix,\n config: _configReadonly.config,\n larger: _pureFunctionsAnyGenerated.larger,\n largerEq: _pureFunctionsAnyGenerated.largerEq,\n smaller: _pureFunctionsAnyGenerated.smaller,\n smallerEq: _pureFunctionsAnyGenerated.smallerEq,\n typed: _pureFunctionsAnyGenerated.typed\n }),\n sum: (0, _factoriesAny.createSumTransform)({\n add: _pureFunctionsAnyGenerated.add,\n config: _configReadonly.config,\n numeric: _pureFunctionsAnyGenerated.numeric,\n typed: _pureFunctionsAnyGenerated.typed\n }),\n cumsum: (0, _factoriesAny.createCumSumTransform)({\n add: _pureFunctionsAnyGenerated.add,\n typed: _pureFunctionsAnyGenerated.typed,\n unaryPlus: _pureFunctionsAnyGenerated.unaryPlus\n }),\n row: (0, _factoriesAny.createRowTransform)({\n Index: _pureFunctionsAnyGenerated.Index,\n matrix: _pureFunctionsAnyGenerated.matrix,\n range: _pureFunctionsAnyGenerated.range,\n typed: _pureFunctionsAnyGenerated.typed\n }),\n column: (0, _factoriesAny.createColumnTransform)({\n Index: _pureFunctionsAnyGenerated.Index,\n matrix: _pureFunctionsAnyGenerated.matrix,\n range: _pureFunctionsAnyGenerated.range,\n typed: _pureFunctionsAnyGenerated.typed\n }),\n index: (0, _factoriesAny.createIndexTransform)({\n Index: _pureFunctionsAnyGenerated.Index\n }),\n mean: (0, _factoriesAny.createMeanTransform)({\n add: _pureFunctionsAnyGenerated.add,\n divide: _pureFunctionsAnyGenerated.divide,\n typed: _pureFunctionsAnyGenerated.typed\n }),\n variance: (0, _factoriesAny.createVarianceTransform)({\n add: _pureFunctionsAnyGenerated.add,\n apply: _pureFunctionsAnyGenerated.apply,\n divide: _pureFunctionsAnyGenerated.divide,\n isNaN: _pureFunctionsAnyGenerated.isNaN,\n multiply: _pureFunctionsAnyGenerated.multiply,\n subtract: _pureFunctionsAnyGenerated.subtract,\n typed: _pureFunctionsAnyGenerated.typed\n }),\n std: (0, _factoriesAny.createStdTransform)({\n sqrt: _pureFunctionsAnyGenerated.sqrt,\n typed: _pureFunctionsAnyGenerated.typed,\n variance: _pureFunctionsAnyGenerated.variance\n })\n});\n(0, _extends2.default)(classes, {\n BigNumber: _pureFunctionsAnyGenerated.BigNumber,\n Chain: Chain,\n Complex: _pureFunctionsAnyGenerated.Complex,\n Fraction: _pureFunctionsAnyGenerated.Fraction,\n Matrix: _pureFunctionsAnyGenerated.Matrix,\n Node: Node,\n ObjectNode: ObjectNode,\n OperatorNode: OperatorNode,\n ParenthesisNode: ParenthesisNode,\n Range: _pureFunctionsAnyGenerated.Range,\n RelationalNode: RelationalNode,\n ResultSet: _pureFunctionsAnyGenerated.ResultSet,\n ArrayNode: ArrayNode,\n BlockNode: BlockNode,\n ConditionalNode: ConditionalNode,\n ConstantNode: ConstantNode,\n DenseMatrix: _pureFunctionsAnyGenerated.DenseMatrix,\n RangeNode: RangeNode,\n FunctionAssignmentNode: FunctionAssignmentNode,\n SparseMatrix: _pureFunctionsAnyGenerated.SparseMatrix,\n AccessorNode: AccessorNode,\n AssignmentNode: AssignmentNode,\n IndexNode: IndexNode,\n FibonacciHeap: _pureFunctionsAnyGenerated.FibonacciHeap,\n ImmutableDenseMatrix: _pureFunctionsAnyGenerated.ImmutableDenseMatrix,\n Index: _pureFunctionsAnyGenerated.Index,\n Spa: _pureFunctionsAnyGenerated.Spa,\n Unit: _pureFunctionsAnyGenerated.Unit,\n SymbolNode: SymbolNode,\n FunctionNode: FunctionNode,\n Help: Help,\n Parser: Parser\n});\nChain.createProxy(math);","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar _exportNames = {\n config: true,\n IndexError: true,\n DimensionError: true,\n ArgumentsError: true,\n create: true,\n factory: true\n};\nObject.defineProperty(exports, \"ArgumentsError\", {\n enumerable: true,\n get: function get() {\n return _ArgumentsError.ArgumentsError;\n }\n});\nObject.defineProperty(exports, \"DimensionError\", {\n enumerable: true,\n get: function get() {\n return _DimensionError.DimensionError;\n }\n});\nObject.defineProperty(exports, \"IndexError\", {\n enumerable: true,\n get: function get() {\n return _IndexError.IndexError;\n }\n});\nObject.defineProperty(exports, \"config\", {\n enumerable: true,\n get: function get() {\n return _configReadonly.config;\n }\n});\nObject.defineProperty(exports, \"create\", {\n enumerable: true,\n get: function get() {\n return _create.create;\n }\n});\nObject.defineProperty(exports, \"factory\", {\n enumerable: true,\n get: function get() {\n return _factory.factory;\n }\n});\n\nvar _configReadonly = require(\"./configReadonly.js\");\n\nvar _pureFunctionsAnyGenerated = require(\"./pureFunctionsAny.generated.js\");\n\nObject.keys(_pureFunctionsAnyGenerated).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _pureFunctionsAnyGenerated[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _pureFunctionsAnyGenerated[key];\n }\n });\n});\n\nvar _impureFunctionsAnyGenerated = require(\"./impureFunctionsAny.generated.js\");\n\nObject.keys(_impureFunctionsAnyGenerated).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _impureFunctionsAnyGenerated[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _impureFunctionsAnyGenerated[key];\n }\n });\n});\n\nvar _typeChecks = require(\"./typeChecks.js\");\n\nObject.keys(_typeChecks).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _typeChecks[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _typeChecks[key];\n }\n });\n});\n\nvar _IndexError = require(\"../error/IndexError.js\");\n\nvar _DimensionError = require(\"../error/DimensionError.js\");\n\nvar _ArgumentsError = require(\"../error/ArgumentsError.js\");\n\nvar _dependenciesAnyGenerated = require(\"./dependenciesAny.generated.js\");\n\nObject.keys(_dependenciesAnyGenerated).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _dependenciesAnyGenerated[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _dependenciesAnyGenerated[key];\n }\n });\n});\n\nvar _factoriesAny = require(\"../factoriesAny.js\");\n\nObject.keys(_factoriesAny).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _factoriesAny[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _factoriesAny[key];\n }\n });\n});\n\nvar _create = require(\"../core/create.js\");\n\nvar _factory = require(\"../utils/factory.js\");","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.eigs = exports.efimovFactor = exports.e = exports.dotPow = exports.dotMultiply = exports.dotDivide = exports.dot = exports.divideScalar = exports.divide = exports.distance = exports.diff = exports.diag = exports.deuteronMass = exports.det = exports.deepEqual = exports.cumsum = exports.cube = exports.ctranspose = exports.csch = exports.csc = exports.cross = exports.createUnit = exports.count = exports.coulomb = exports.coth = exports.cot = exports.cosh = exports.cos = exports.conj = exports.conductanceQuantum = exports.concat = exports.composition = exports.complex = exports.compareText = exports.compareNatural = exports.compare = exports.combinationsWithRep = exports.combinations = exports.column = exports.clone = exports.classicalElectronRadius = exports.ceil = exports.cbrt = exports.catalan = exports.boolean = exports.boltzmann = exports.bohrRadius = exports.bohrMagneton = exports.bitXor = exports.bitOr = exports.bitNot = exports.bitAnd = exports.bin = exports.bignumber = exports.bellNumbers = exports.avogadro = exports.atomicMass = exports.atanh = exports.atan2 = exports.atan = exports.asinh = exports.asin = exports.asech = exports.asec = exports.arg = exports.apply = exports.and = exports.addScalar = exports.add = exports.acsch = exports.acsc = exports.acoth = exports.acot = exports.acosh = exports.acos = exports.abs = exports._true = exports._null = exports._false = exports._NaN = exports._Infinity = exports.Unit = exports.SparseMatrix = exports.Spa = exports.SQRT2 = exports.SQRT1_2 = exports.ResultSet = exports.Range = exports.Matrix = exports.LOG2E = exports.LOG10E = exports.LN2 = exports.LN10 = exports.Index = exports.ImmutableDenseMatrix = exports.Fraction = exports.FibonacciHeap = exports.DenseMatrix = exports.Complex = exports.BigNumber = void 0;\nexports.permutations = exports.partitionSelect = exports.or = exports.ones = exports.oct = exports.numeric = exports.number = exports.nuclearMagneton = exports.nthRoots = exports.nthRoot = exports.not = exports.norm = exports.neutronMass = exports.multiplyScalar = exports.multiply = exports.multinomial = exports.molarVolume = exports.molarPlanckConstant = exports.molarMassC12 = exports.molarMass = exports.mode = exports.mod = exports.min = exports.median = exports.mean = exports.max = exports.matrixFromRows = exports.matrixFromFunction = exports.matrixFromColumns = exports.matrix = exports.map = exports.magneticFluxQuantum = exports.magneticConstant = exports.mad = exports.lusolve = exports.lup = exports.lsolveAll = exports.lsolve = exports.loschmidt = exports.log2 = exports.log1p = exports.log10 = exports.log = exports.lgamma = exports.leftShift = exports.lcm = exports.largerEq = exports.larger = exports.kron = exports.klitzing = exports.kldivergence = exports.isZero = exports.isPrime = exports.isPositive = exports.isNumeric = exports.isNegative = exports.isNaN = exports.isInteger = exports.invmod = exports.inverseConductanceQuantum = exports.inv = exports.intersect = exports.index = exports.im = exports.ifft = exports.identity = exports.i = exports.hypot = exports.hex = exports.hasNumericValue = exports.hartreeEnergy = exports.gravity = exports.gravitationConstant = exports.getMatrixDataType = exports.gcd = exports.gasConstant = exports.gamma = exports.fraction = exports.format = exports.forEach = exports.floor = exports.flatten = exports.fix = exports.firstRadiation = exports.fineStructure = exports.filter = exports.fft = exports.fermiCoupling = exports.faraday = exports.factorial = exports.expm1 = exports.expm = exports.exp = exports.erf = exports.equalText = exports.equalScalar = exports.equal = exports.elementaryCharge = exports.electronMass = exports.electricConstant = void 0;\nexports.zeros = exports.xor = exports.xgcd = exports.wienDisplacement = exports.weakMixingAngle = exports.version = exports.variance = exports.vacuumImpedance = exports.usolveAll = exports.usolve = exports.unit = exports.unequal = exports.unaryPlus = exports.unaryMinus = exports.typed = exports.typeOf = exports.transpose = exports.trace = exports.to = exports.thomsonCrossSection = exports.tau = exports.tanh = exports.tan = exports.sum = exports.subtract = exports.subset = exports.string = exports.stirlingS2 = exports.stefanBoltzmann = exports.std = exports.squeeze = exports.square = exports.sqrtm = exports.sqrt = exports.splitUnit = exports.speedOfLight = exports.sparse = exports.sort = exports.smallerEq = exports.smaller = exports.slu = exports.size = exports.sinh = exports.sin = exports.sign = exports.setUnion = exports.setSymDifference = exports.setSize = exports.setPowerset = exports.setMultiplicity = exports.setIsSubset = exports.setIntersect = exports.setDistinct = exports.setDifference = exports.setCartesian = exports.secondRadiation = exports.sech = exports.sec = exports.sackurTetrode = exports.rydberg = exports.row = exports.round = exports.rotationMatrix = exports.rotate = exports.rightLogShift = exports.rightArithShift = exports.resize = exports.reshape = exports.replacer = exports.reducedPlanckConstant = exports.re = exports.range = exports.randomInt = exports.random = exports.quantumOfCirculation = exports.quantileSeq = exports.qr = exports.protonMass = exports.prod = exports.print = exports.pow = exports.planckTime = exports.planckTemperature = exports.planckMass = exports.planckLength = exports.planckConstant = exports.planckCharge = exports.pinv = exports.pickRandom = exports.pi = exports.phi = void 0;\n\nvar _configReadonly = require(\"./configReadonly.js\");\n\nvar _factoriesAny = require(\"../factoriesAny.js\");\n\n/**\n * THIS FILE IS AUTO-GENERATED\n * DON'T MAKE CHANGES HERE\n */\nvar BigNumber = /* #__PURE__ */(0, _factoriesAny.createBigNumberClass)({\n config: _configReadonly.config\n});\nexports.BigNumber = BigNumber;\nvar Complex = /* #__PURE__ */(0, _factoriesAny.createComplexClass)({});\nexports.Complex = Complex;\nvar e = /* #__PURE__ */(0, _factoriesAny.createE)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.e = e;\n\nvar _false = /* #__PURE__ */(0, _factoriesAny.createFalse)({});\n\nexports._false = _false;\nvar fineStructure = /* #__PURE__ */(0, _factoriesAny.createFineStructure)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.fineStructure = fineStructure;\nvar Fraction = /* #__PURE__ */(0, _factoriesAny.createFractionClass)({});\nexports.Fraction = Fraction;\nvar i = /* #__PURE__ */(0, _factoriesAny.createI)({\n Complex: Complex\n});\nexports.i = i;\n\nvar _Infinity = /* #__PURE__ */(0, _factoriesAny.createInfinity)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\n\nexports._Infinity = _Infinity;\nvar LN10 = /* #__PURE__ */(0, _factoriesAny.createLN10)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.LN10 = LN10;\nvar LOG10E = /* #__PURE__ */(0, _factoriesAny.createLOG10E)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.LOG10E = LOG10E;\nvar Matrix = /* #__PURE__ */(0, _factoriesAny.createMatrixClass)({});\nexports.Matrix = Matrix;\n\nvar _NaN = /* #__PURE__ */(0, _factoriesAny.createNaN)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\n\nexports._NaN = _NaN;\n\nvar _null = /* #__PURE__ */(0, _factoriesAny.createNull)({});\n\nexports._null = _null;\nvar phi = /* #__PURE__ */(0, _factoriesAny.createPhi)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.phi = phi;\nvar Range = /* #__PURE__ */(0, _factoriesAny.createRangeClass)({});\nexports.Range = Range;\nvar ResultSet = /* #__PURE__ */(0, _factoriesAny.createResultSet)({});\nexports.ResultSet = ResultSet;\nvar SQRT1_2 = /* #__PURE__ */(0, _factoriesAny.createSQRT1_2)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.SQRT1_2 = SQRT1_2;\nvar sackurTetrode = /* #__PURE__ */(0, _factoriesAny.createSackurTetrode)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.sackurTetrode = sackurTetrode;\nvar tau = /* #__PURE__ */(0, _factoriesAny.createTau)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.tau = tau;\n\nvar _true = /* #__PURE__ */(0, _factoriesAny.createTrue)({});\n\nexports._true = _true;\nvar version = /* #__PURE__ */(0, _factoriesAny.createVersion)({});\nexports.version = version;\nvar DenseMatrix = /* #__PURE__ */(0, _factoriesAny.createDenseMatrixClass)({\n Matrix: Matrix\n});\nexports.DenseMatrix = DenseMatrix;\nvar efimovFactor = /* #__PURE__ */(0, _factoriesAny.createEfimovFactor)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.efimovFactor = efimovFactor;\nvar LN2 = /* #__PURE__ */(0, _factoriesAny.createLN2)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.LN2 = LN2;\nvar pi = /* #__PURE__ */(0, _factoriesAny.createPi)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.pi = pi;\nvar replacer = /* #__PURE__ */(0, _factoriesAny.createReplacer)({});\nexports.replacer = replacer;\nvar SQRT2 = /* #__PURE__ */(0, _factoriesAny.createSQRT2)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.SQRT2 = SQRT2;\nvar typed = /* #__PURE__ */(0, _factoriesAny.createTyped)({\n BigNumber: BigNumber,\n Complex: Complex,\n DenseMatrix: DenseMatrix,\n Fraction: Fraction\n});\nexports.typed = typed;\nvar unaryPlus = /* #__PURE__ */(0, _factoriesAny.createUnaryPlus)({\n BigNumber: BigNumber,\n config: _configReadonly.config,\n typed: typed\n});\nexports.unaryPlus = unaryPlus;\nvar weakMixingAngle = /* #__PURE__ */(0, _factoriesAny.createWeakMixingAngle)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.weakMixingAngle = weakMixingAngle;\nvar abs = /* #__PURE__ */(0, _factoriesAny.createAbs)({\n typed: typed\n});\nexports.abs = abs;\nvar acos = /* #__PURE__ */(0, _factoriesAny.createAcos)({\n Complex: Complex,\n config: _configReadonly.config,\n typed: typed\n});\nexports.acos = acos;\nvar acot = /* #__PURE__ */(0, _factoriesAny.createAcot)({\n BigNumber: BigNumber,\n typed: typed\n});\nexports.acot = acot;\nvar acsc = /* #__PURE__ */(0, _factoriesAny.createAcsc)({\n BigNumber: BigNumber,\n Complex: Complex,\n config: _configReadonly.config,\n typed: typed\n});\nexports.acsc = acsc;\nvar addScalar = /* #__PURE__ */(0, _factoriesAny.createAddScalar)({\n typed: typed\n});\nexports.addScalar = addScalar;\nvar arg = /* #__PURE__ */(0, _factoriesAny.createArg)({\n typed: typed\n});\nexports.arg = arg;\nvar asech = /* #__PURE__ */(0, _factoriesAny.createAsech)({\n BigNumber: BigNumber,\n Complex: Complex,\n config: _configReadonly.config,\n typed: typed\n});\nexports.asech = asech;\nvar asinh = /* #__PURE__ */(0, _factoriesAny.createAsinh)({\n typed: typed\n});\nexports.asinh = asinh;\nvar atan = /* #__PURE__ */(0, _factoriesAny.createAtan)({\n typed: typed\n});\nexports.atan = atan;\nvar atanh = /* #__PURE__ */(0, _factoriesAny.createAtanh)({\n Complex: Complex,\n config: _configReadonly.config,\n typed: typed\n});\nexports.atanh = atanh;\nvar bignumber = /* #__PURE__ */(0, _factoriesAny.createBignumber)({\n BigNumber: BigNumber,\n typed: typed\n});\nexports.bignumber = bignumber;\nvar bitNot = /* #__PURE__ */(0, _factoriesAny.createBitNot)({\n typed: typed\n});\nexports.bitNot = bitNot;\nvar boolean = /* #__PURE__ */(0, _factoriesAny.createBoolean)({\n typed: typed\n});\nexports.boolean = boolean;\nvar clone = /* #__PURE__ */(0, _factoriesAny.createClone)({\n typed: typed\n});\nexports.clone = clone;\nvar combinations = /* #__PURE__ */(0, _factoriesAny.createCombinations)({\n typed: typed\n});\nexports.combinations = combinations;\nvar complex = /* #__PURE__ */(0, _factoriesAny.createComplex)({\n Complex: Complex,\n typed: typed\n});\nexports.complex = complex;\nvar conj = /* #__PURE__ */(0, _factoriesAny.createConj)({\n typed: typed\n});\nexports.conj = conj;\nvar cosh = /* #__PURE__ */(0, _factoriesAny.createCosh)({\n typed: typed\n});\nexports.cosh = cosh;\nvar coth = /* #__PURE__ */(0, _factoriesAny.createCoth)({\n BigNumber: BigNumber,\n typed: typed\n});\nexports.coth = coth;\nvar csc = /* #__PURE__ */(0, _factoriesAny.createCsc)({\n BigNumber: BigNumber,\n typed: typed\n});\nexports.csc = csc;\nvar cube = /* #__PURE__ */(0, _factoriesAny.createCube)({\n typed: typed\n});\nexports.cube = cube;\nvar equalScalar = /* #__PURE__ */(0, _factoriesAny.createEqualScalar)({\n config: _configReadonly.config,\n typed: typed\n});\nexports.equalScalar = equalScalar;\nvar erf = /* #__PURE__ */(0, _factoriesAny.createErf)({\n typed: typed\n});\nexports.erf = erf;\nvar exp = /* #__PURE__ */(0, _factoriesAny.createExp)({\n typed: typed\n});\nexports.exp = exp;\nvar expm1 = /* #__PURE__ */(0, _factoriesAny.createExpm1)({\n Complex: Complex,\n typed: typed\n});\nexports.expm1 = expm1;\nvar filter = /* #__PURE__ */(0, _factoriesAny.createFilter)({\n typed: typed\n});\nexports.filter = filter;\nvar forEach = /* #__PURE__ */(0, _factoriesAny.createForEach)({\n typed: typed\n});\nexports.forEach = forEach;\nvar format = /* #__PURE__ */(0, _factoriesAny.createFormat)({\n typed: typed\n});\nexports.format = format;\nvar getMatrixDataType = /* #__PURE__ */(0, _factoriesAny.createGetMatrixDataType)({\n typed: typed\n});\nexports.getMatrixDataType = getMatrixDataType;\nvar hex = /* #__PURE__ */(0, _factoriesAny.createHex)({\n format: format,\n typed: typed\n});\nexports.hex = hex;\nvar im = /* #__PURE__ */(0, _factoriesAny.createIm)({\n typed: typed\n});\nexports.im = im;\nvar isInteger = /* #__PURE__ */(0, _factoriesAny.createIsInteger)({\n typed: typed\n});\nexports.isInteger = isInteger;\nvar isNegative = /* #__PURE__ */(0, _factoriesAny.createIsNegative)({\n typed: typed\n});\nexports.isNegative = isNegative;\nvar isPositive = /* #__PURE__ */(0, _factoriesAny.createIsPositive)({\n typed: typed\n});\nexports.isPositive = isPositive;\nvar isZero = /* #__PURE__ */(0, _factoriesAny.createIsZero)({\n typed: typed\n});\nexports.isZero = isZero;\nvar LOG2E = /* #__PURE__ */(0, _factoriesAny.createLOG2E)({\n BigNumber: BigNumber,\n config: _configReadonly.config\n});\nexports.LOG2E = LOG2E;\nvar lgamma = /* #__PURE__ */(0, _factoriesAny.createLgamma)({\n Complex: Complex,\n typed: typed\n});\nexports.lgamma = lgamma;\nvar log10 = /* #__PURE__ */(0, _factoriesAny.createLog10)({\n Complex: Complex,\n config: _configReadonly.config,\n typed: typed\n});\nexports.log10 = log10;\nvar log2 = /* #__PURE__ */(0, _factoriesAny.createLog2)({\n Complex: Complex,\n config: _configReadonly.config,\n typed: typed\n});\nexports.log2 = log2;\nvar map = /* #__PURE__ */(0, _factoriesAny.createMap)({\n typed: typed\n});\nexports.map = map;\nvar multiplyScalar = /* #__PURE__ */(0, _factoriesAny.createMultiplyScalar)({\n typed: typed\n});\nexports.multiplyScalar = multiplyScalar;\nvar not = /* #__PURE__ */(0, _factoriesAny.createNot)({\n typed: typed\n});\nexports.not = not;\nvar number = /* #__PURE__ */(0, _factoriesAny.createNumber)({\n typed: typed\n});\nexports.number = number;\nvar oct = /* #__PURE__ */(0, _factoriesAny.createOct)({\n format: format,\n typed: typed\n});\nexports.oct = oct;\nvar pickRandom = /* #__PURE__ */(0, _factoriesAny.createPickRandom)({\n config: _configReadonly.config,\n typed: typed\n});\nexports.pickRandom = pickRandom;\nvar print = /* #__PURE__ */(0, _factoriesAny.createPrint)({\n typed: typed\n});\nexports.print = print;\nvar random = /* #__PURE__ */(0, _factoriesAny.createRandom)({\n config: _configReadonly.config,\n typed: typed\n});\nexports.random = random;\nvar re = /* #__PURE__ */(0, _factoriesAny.createRe)({\n typed: typed\n});\nexports.re = re;\nvar sec = /* #__PURE__ */(0, _factoriesAny.createSec)({\n BigNumber: BigNumber,\n typed: typed\n});\nexports.sec = sec;\nvar sign = /* #__PURE__ */(0, _factoriesAny.createSign)({\n BigNumber: BigNumber,\n Fraction: Fraction,\n complex: complex,\n typed: typed\n});\nexports.sign = sign;\nvar sin = /* #__PURE__ */(0, _factoriesAny.createSin)({\n typed: typed\n});\nexports.sin = sin;\nvar SparseMatrix = /* #__PURE__ */(0, _factoriesAny.createSparseMatrixClass)({\n Matrix: Matrix,\n equalScalar: equalScalar,\n typed: typed\n});\nexports.SparseMatrix = SparseMatrix;\nvar splitUnit = /* #__PURE__ */(0, _factoriesAny.createSplitUnit)({\n typed: typed\n});\nexports.splitUnit = splitUnit;\nvar square = /* #__PURE__ */(0, _factoriesAny.createSquare)({\n typed: typed\n});\nexports.square = square;\nvar string = /* #__PURE__ */(0, _factoriesAny.createString)({\n typed: typed\n});\nexports.string = string;\nvar tan = /* #__PURE__ */(0, _factoriesAny.createTan)({\n typed: typed\n});\nexports.tan = tan;\nvar typeOf = /* #__PURE__ */(0, _factoriesAny.createTypeOf)({\n typed: typed\n});\nexports.typeOf = typeOf;\nvar acosh = /* #__PURE__ */(0, _factoriesAny.createAcosh)({\n Complex: Complex,\n config: _configReadonly.config,\n typed: typed\n});\nexports.acosh = acosh;\nvar acsch = /* #__PURE__ */(0, _factoriesAny.createAcsch)({\n BigNumber: BigNumber,\n typed: typed\n});\nexports.acsch = acsch;\nvar apply = /* #__PURE__ */(0, _factoriesAny.createApply)({\n isInteger: isInteger,\n typed: typed\n});\nexports.apply = apply;\nvar asec = /* #__PURE__ */(0, _factoriesAny.createAsec)({\n BigNumber: BigNumber,\n Complex: Complex,\n config: _configReadonly.config,\n typed: typed\n});\nexports.asec = asec;\nvar bin = /* #__PURE__ */(0, _factoriesAny.createBin)({\n format: format,\n typed: typed\n});\nexports.bin = bin;\nvar combinationsWithRep = /* #__PURE__ */(0, _factoriesAny.createCombinationsWithRep)({\n typed: typed\n});\nexports.combinationsWithRep = combinationsWithRep;\nvar cos = /* #__PURE__ */(0, _factoriesAny.createCos)({\n typed: typed\n});\nexports.cos = cos;\nvar csch = /* #__PURE__ */(0, _factoriesAny.createCsch)({\n BigNumber: BigNumber,\n typed: typed\n});\nexports.csch = csch;\nvar isNaN = /* #__PURE__ */(0, _factoriesAny.createIsNaN)({\n typed: typed\n});\nexports.isNaN = isNaN;\nvar isPrime = /* #__PURE__ */(0, _factoriesAny.createIsPrime)({\n typed: typed\n});\nexports.isPrime = isPrime;\nvar randomInt = /* #__PURE__ */(0, _factoriesAny.createRandomInt)({\n config: _configReadonly.config,\n typed: typed\n});\nexports.randomInt = randomInt;\nvar sech = /* #__PURE__ */(0, _factoriesAny.createSech)({\n BigNumber: BigNumber,\n typed: typed\n});\nexports.sech = sech;\nvar sinh = /* #__PURE__ */(0, _factoriesAny.createSinh)({\n typed: typed\n});\nexports.sinh = sinh;\nvar sparse = /* #__PURE__ */(0, _factoriesAny.createSparse)({\n SparseMatrix: SparseMatrix,\n typed: typed\n});\nexports.sparse = sparse;\nvar sqrt = /* #__PURE__ */(0, _factoriesAny.createSqrt)({\n Complex: Complex,\n config: _configReadonly.config,\n typed: typed\n});\nexports.sqrt = sqrt;\nvar tanh = /* #__PURE__ */(0, _factoriesAny.createTanh)({\n typed: typed\n});\nexports.tanh = tanh;\nvar unaryMinus = /* #__PURE__ */(0, _factoriesAny.createUnaryMinus)({\n typed: typed\n});\nexports.unaryMinus = unaryMinus;\nvar acoth = /* #__PURE__ */(0, _factoriesAny.createAcoth)({\n BigNumber: BigNumber,\n Complex: Complex,\n config: _configReadonly.config,\n typed: typed\n});\nexports.acoth = acoth;\nvar cot = /* #__PURE__ */(0, _factoriesAny.createCot)({\n BigNumber: BigNumber,\n typed: typed\n});\nexports.cot = cot;\nvar fraction = /* #__PURE__ */(0, _factoriesAny.createFraction)({\n Fraction: Fraction,\n typed: typed\n});\nexports.fraction = fraction;\nvar isNumeric = /* #__PURE__ */(0, _factoriesAny.createIsNumeric)({\n typed: typed\n});\nexports.isNumeric = isNumeric;\nvar matrix = /* #__PURE__ */(0, _factoriesAny.createMatrix)({\n DenseMatrix: DenseMatrix,\n Matrix: Matrix,\n SparseMatrix: SparseMatrix,\n typed: typed\n});\nexports.matrix = matrix;\nvar matrixFromFunction = /* #__PURE__ */(0, _factoriesAny.createMatrixFromFunction)({\n isZero: isZero,\n matrix: matrix,\n typed: typed\n});\nexports.matrixFromFunction = matrixFromFunction;\nvar mod = /* #__PURE__ */(0, _factoriesAny.createMod)({\n DenseMatrix: DenseMatrix,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.mod = mod;\nvar nthRoot = /* #__PURE__ */(0, _factoriesAny.createNthRoot)({\n BigNumber: BigNumber,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.nthRoot = nthRoot;\nvar numeric = /* #__PURE__ */(0, _factoriesAny.createNumeric)({\n bignumber: bignumber,\n fraction: fraction,\n number: number\n});\nexports.numeric = numeric;\nvar or = /* #__PURE__ */(0, _factoriesAny.createOr)({\n DenseMatrix: DenseMatrix,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.or = or;\nvar prod = /* #__PURE__ */(0, _factoriesAny.createProd)({\n config: _configReadonly.config,\n multiplyScalar: multiplyScalar,\n numeric: numeric,\n typed: typed\n});\nexports.prod = prod;\nvar reshape = /* #__PURE__ */(0, _factoriesAny.createReshape)({\n isInteger: isInteger,\n matrix: matrix,\n typed: typed\n});\nexports.reshape = reshape;\nvar size = /* #__PURE__ */(0, _factoriesAny.createSize)({\n matrix: matrix,\n config: _configReadonly.config,\n typed: typed\n});\nexports.size = size;\nvar smaller = /* #__PURE__ */(0, _factoriesAny.createSmaller)({\n DenseMatrix: DenseMatrix,\n config: _configReadonly.config,\n matrix: matrix,\n typed: typed\n});\nexports.smaller = smaller;\nvar squeeze = /* #__PURE__ */(0, _factoriesAny.createSqueeze)({\n matrix: matrix,\n typed: typed\n});\nexports.squeeze = squeeze;\nvar subset = /* #__PURE__ */(0, _factoriesAny.createSubset)({\n matrix: matrix,\n typed: typed\n});\nexports.subset = subset;\nvar subtract = /* #__PURE__ */(0, _factoriesAny.createSubtract)({\n DenseMatrix: DenseMatrix,\n addScalar: addScalar,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed,\n unaryMinus: unaryMinus\n});\nexports.subtract = subtract;\nvar to = /* #__PURE__ */(0, _factoriesAny.createTo)({\n matrix: matrix,\n typed: typed\n});\nexports.to = to;\nvar transpose = /* #__PURE__ */(0, _factoriesAny.createTranspose)({\n matrix: matrix,\n typed: typed\n});\nexports.transpose = transpose;\nvar xgcd = /* #__PURE__ */(0, _factoriesAny.createXgcd)({\n BigNumber: BigNumber,\n config: _configReadonly.config,\n matrix: matrix,\n typed: typed\n});\nexports.xgcd = xgcd;\nvar zeros = /* #__PURE__ */(0, _factoriesAny.createZeros)({\n BigNumber: BigNumber,\n config: _configReadonly.config,\n matrix: matrix,\n typed: typed\n});\nexports.zeros = zeros;\nvar and = /* #__PURE__ */(0, _factoriesAny.createAnd)({\n equalScalar: equalScalar,\n matrix: matrix,\n not: not,\n typed: typed,\n zeros: zeros\n});\nexports.and = and;\nvar bitAnd = /* #__PURE__ */(0, _factoriesAny.createBitAnd)({\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.bitAnd = bitAnd;\nvar bitXor = /* #__PURE__ */(0, _factoriesAny.createBitXor)({\n DenseMatrix: DenseMatrix,\n matrix: matrix,\n typed: typed\n});\nexports.bitXor = bitXor;\nvar cbrt = /* #__PURE__ */(0, _factoriesAny.createCbrt)({\n BigNumber: BigNumber,\n Complex: Complex,\n Fraction: Fraction,\n config: _configReadonly.config,\n isNegative: isNegative,\n matrix: matrix,\n typed: typed,\n unaryMinus: unaryMinus\n});\nexports.cbrt = cbrt;\nvar compare = /* #__PURE__ */(0, _factoriesAny.createCompare)({\n BigNumber: BigNumber,\n DenseMatrix: DenseMatrix,\n Fraction: Fraction,\n config: _configReadonly.config,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.compare = compare;\nvar compareText = /* #__PURE__ */(0, _factoriesAny.createCompareText)({\n matrix: matrix,\n typed: typed\n});\nexports.compareText = compareText;\nvar concat = /* #__PURE__ */(0, _factoriesAny.createConcat)({\n isInteger: isInteger,\n matrix: matrix,\n typed: typed\n});\nexports.concat = concat;\nvar count = /* #__PURE__ */(0, _factoriesAny.createCount)({\n prod: prod,\n size: size,\n typed: typed\n});\nexports.count = count;\nvar ctranspose = /* #__PURE__ */(0, _factoriesAny.createCtranspose)({\n conj: conj,\n transpose: transpose,\n typed: typed\n});\nexports.ctranspose = ctranspose;\nvar diag = /* #__PURE__ */(0, _factoriesAny.createDiag)({\n DenseMatrix: DenseMatrix,\n SparseMatrix: SparseMatrix,\n matrix: matrix,\n typed: typed\n});\nexports.diag = diag;\nvar divideScalar = /* #__PURE__ */(0, _factoriesAny.createDivideScalar)({\n numeric: numeric,\n typed: typed\n});\nexports.divideScalar = divideScalar;\nvar dotDivide = /* #__PURE__ */(0, _factoriesAny.createDotDivide)({\n DenseMatrix: DenseMatrix,\n divideScalar: divideScalar,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.dotDivide = dotDivide;\nvar equal = /* #__PURE__ */(0, _factoriesAny.createEqual)({\n DenseMatrix: DenseMatrix,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.equal = equal;\nvar fft = /* #__PURE__ */(0, _factoriesAny.createFft)({\n addScalar: addScalar,\n divideScalar: divideScalar,\n exp: exp,\n i: i,\n matrix: matrix,\n multiplyScalar: multiplyScalar,\n tau: tau,\n typed: typed\n});\nexports.fft = fft;\nvar flatten = /* #__PURE__ */(0, _factoriesAny.createFlatten)({\n matrix: matrix,\n typed: typed\n});\nexports.flatten = flatten;\nvar gcd = /* #__PURE__ */(0, _factoriesAny.createGcd)({\n BigNumber: BigNumber,\n DenseMatrix: DenseMatrix,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.gcd = gcd;\nvar hasNumericValue = /* #__PURE__ */(0, _factoriesAny.createHasNumericValue)({\n isNumeric: isNumeric,\n typed: typed\n});\nexports.hasNumericValue = hasNumericValue;\nvar hypot = /* #__PURE__ */(0, _factoriesAny.createHypot)({\n abs: abs,\n addScalar: addScalar,\n divideScalar: divideScalar,\n isPositive: isPositive,\n multiplyScalar: multiplyScalar,\n smaller: smaller,\n sqrt: sqrt,\n typed: typed\n});\nexports.hypot = hypot;\nvar ifft = /* #__PURE__ */(0, _factoriesAny.createIfft)({\n conj: conj,\n dotDivide: dotDivide,\n fft: fft,\n typed: typed\n});\nexports.ifft = ifft;\nvar kron = /* #__PURE__ */(0, _factoriesAny.createKron)({\n matrix: matrix,\n multiplyScalar: multiplyScalar,\n typed: typed\n});\nexports.kron = kron;\nvar largerEq = /* #__PURE__ */(0, _factoriesAny.createLargerEq)({\n DenseMatrix: DenseMatrix,\n config: _configReadonly.config,\n matrix: matrix,\n typed: typed\n});\nexports.largerEq = largerEq;\nvar leftShift = /* #__PURE__ */(0, _factoriesAny.createLeftShift)({\n DenseMatrix: DenseMatrix,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed,\n zeros: zeros\n});\nexports.leftShift = leftShift;\nvar lsolve = /* #__PURE__ */(0, _factoriesAny.createLsolve)({\n DenseMatrix: DenseMatrix,\n divideScalar: divideScalar,\n equalScalar: equalScalar,\n matrix: matrix,\n multiplyScalar: multiplyScalar,\n subtract: subtract,\n typed: typed\n});\nexports.lsolve = lsolve;\nvar matrixFromColumns = /* #__PURE__ */(0, _factoriesAny.createMatrixFromColumns)({\n flatten: flatten,\n matrix: matrix,\n size: size,\n typed: typed\n});\nexports.matrixFromColumns = matrixFromColumns;\nvar min = /* #__PURE__ */(0, _factoriesAny.createMin)({\n config: _configReadonly.config,\n numeric: numeric,\n smaller: smaller,\n typed: typed\n});\nexports.min = min;\nvar mode = /* #__PURE__ */(0, _factoriesAny.createMode)({\n isNaN: isNaN,\n isNumeric: isNumeric,\n typed: typed\n});\nexports.mode = mode;\nvar nthRoots = /* #__PURE__ */(0, _factoriesAny.createNthRoots)({\n Complex: Complex,\n config: _configReadonly.config,\n divideScalar: divideScalar,\n typed: typed\n});\nexports.nthRoots = nthRoots;\nvar ones = /* #__PURE__ */(0, _factoriesAny.createOnes)({\n BigNumber: BigNumber,\n config: _configReadonly.config,\n matrix: matrix,\n typed: typed\n});\nexports.ones = ones;\nvar partitionSelect = /* #__PURE__ */(0, _factoriesAny.createPartitionSelect)({\n compare: compare,\n isNaN: isNaN,\n isNumeric: isNumeric,\n typed: typed\n});\nexports.partitionSelect = partitionSelect;\nvar resize = /* #__PURE__ */(0, _factoriesAny.createResize)({\n config: _configReadonly.config,\n matrix: matrix\n});\nexports.resize = resize;\nvar rightArithShift = /* #__PURE__ */(0, _factoriesAny.createRightArithShift)({\n DenseMatrix: DenseMatrix,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed,\n zeros: zeros\n});\nexports.rightArithShift = rightArithShift;\nvar round = /* #__PURE__ */(0, _factoriesAny.createRound)({\n BigNumber: BigNumber,\n DenseMatrix: DenseMatrix,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed,\n zeros: zeros\n});\nexports.round = round;\nvar smallerEq = /* #__PURE__ */(0, _factoriesAny.createSmallerEq)({\n DenseMatrix: DenseMatrix,\n config: _configReadonly.config,\n matrix: matrix,\n typed: typed\n});\nexports.smallerEq = smallerEq;\nvar unequal = /* #__PURE__ */(0, _factoriesAny.createUnequal)({\n DenseMatrix: DenseMatrix,\n config: _configReadonly.config,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.unequal = unequal;\nvar usolve = /* #__PURE__ */(0, _factoriesAny.createUsolve)({\n DenseMatrix: DenseMatrix,\n divideScalar: divideScalar,\n equalScalar: equalScalar,\n matrix: matrix,\n multiplyScalar: multiplyScalar,\n subtract: subtract,\n typed: typed\n});\nexports.usolve = usolve;\nvar xor = /* #__PURE__ */(0, _factoriesAny.createXor)({\n DenseMatrix: DenseMatrix,\n matrix: matrix,\n typed: typed\n});\nexports.xor = xor;\nvar add = /* #__PURE__ */(0, _factoriesAny.createAdd)({\n DenseMatrix: DenseMatrix,\n SparseMatrix: SparseMatrix,\n addScalar: addScalar,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.add = add;\nvar atan2 = /* #__PURE__ */(0, _factoriesAny.createAtan2)({\n BigNumber: BigNumber,\n DenseMatrix: DenseMatrix,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.atan2 = atan2;\nvar bitOr = /* #__PURE__ */(0, _factoriesAny.createBitOr)({\n DenseMatrix: DenseMatrix,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.bitOr = bitOr;\nvar catalan = /* #__PURE__ */(0, _factoriesAny.createCatalan)({\n addScalar: addScalar,\n combinations: combinations,\n divideScalar: divideScalar,\n isInteger: isInteger,\n isNegative: isNegative,\n multiplyScalar: multiplyScalar,\n typed: typed\n});\nexports.catalan = catalan;\nvar compareNatural = /* #__PURE__ */(0, _factoriesAny.createCompareNatural)({\n compare: compare,\n typed: typed\n});\nexports.compareNatural = compareNatural;\nvar cumsum = /* #__PURE__ */(0, _factoriesAny.createCumSum)({\n add: add,\n typed: typed,\n unaryPlus: unaryPlus\n});\nexports.cumsum = cumsum;\nvar deepEqual = /* #__PURE__ */(0, _factoriesAny.createDeepEqual)({\n equal: equal,\n typed: typed\n});\nexports.deepEqual = deepEqual;\nvar diff = /* #__PURE__ */(0, _factoriesAny.createDiff)({\n matrix: matrix,\n number: number,\n subtract: subtract,\n typed: typed\n});\nexports.diff = diff;\nvar dot = /* #__PURE__ */(0, _factoriesAny.createDot)({\n addScalar: addScalar,\n conj: conj,\n multiplyScalar: multiplyScalar,\n size: size,\n typed: typed\n});\nexports.dot = dot;\nvar equalText = /* #__PURE__ */(0, _factoriesAny.createEqualText)({\n compareText: compareText,\n isZero: isZero,\n typed: typed\n});\nexports.equalText = equalText;\nvar floor = /* #__PURE__ */(0, _factoriesAny.createFloor)({\n DenseMatrix: DenseMatrix,\n config: _configReadonly.config,\n equalScalar: equalScalar,\n matrix: matrix,\n round: round,\n typed: typed,\n zeros: zeros\n});\nexports.floor = floor;\nvar identity = /* #__PURE__ */(0, _factoriesAny.createIdentity)({\n BigNumber: BigNumber,\n DenseMatrix: DenseMatrix,\n SparseMatrix: SparseMatrix,\n config: _configReadonly.config,\n matrix: matrix,\n typed: typed\n});\nexports.identity = identity;\nvar invmod = /* #__PURE__ */(0, _factoriesAny.createInvmod)({\n BigNumber: BigNumber,\n add: add,\n config: _configReadonly.config,\n equal: equal,\n isInteger: isInteger,\n mod: mod,\n smaller: smaller,\n typed: typed,\n xgcd: xgcd\n});\nexports.invmod = invmod;\nvar larger = /* #__PURE__ */(0, _factoriesAny.createLarger)({\n DenseMatrix: DenseMatrix,\n config: _configReadonly.config,\n matrix: matrix,\n typed: typed\n});\nexports.larger = larger;\nvar log = /* #__PURE__ */(0, _factoriesAny.createLog)({\n Complex: Complex,\n config: _configReadonly.config,\n divideScalar: divideScalar,\n typed: typed\n});\nexports.log = log;\nvar lsolveAll = /* #__PURE__ */(0, _factoriesAny.createLsolveAll)({\n DenseMatrix: DenseMatrix,\n divideScalar: divideScalar,\n equalScalar: equalScalar,\n matrix: matrix,\n multiplyScalar: multiplyScalar,\n subtract: subtract,\n typed: typed\n});\nexports.lsolveAll = lsolveAll;\nvar matrixFromRows = /* #__PURE__ */(0, _factoriesAny.createMatrixFromRows)({\n flatten: flatten,\n matrix: matrix,\n size: size,\n typed: typed\n});\nexports.matrixFromRows = matrixFromRows;\nvar multiply = /* #__PURE__ */(0, _factoriesAny.createMultiply)({\n addScalar: addScalar,\n dot: dot,\n equalScalar: equalScalar,\n matrix: matrix,\n multiplyScalar: multiplyScalar,\n typed: typed\n});\nexports.multiply = multiply;\nvar qr = /* #__PURE__ */(0, _factoriesAny.createQr)({\n addScalar: addScalar,\n complex: complex,\n conj: conj,\n divideScalar: divideScalar,\n equal: equal,\n identity: identity,\n isZero: isZero,\n matrix: matrix,\n multiplyScalar: multiplyScalar,\n sign: sign,\n sqrt: sqrt,\n subtract: subtract,\n typed: typed,\n unaryMinus: unaryMinus,\n zeros: zeros\n});\nexports.qr = qr;\nvar range = /* #__PURE__ */(0, _factoriesAny.createRange)({\n bignumber: bignumber,\n matrix: matrix,\n config: _configReadonly.config,\n larger: larger,\n largerEq: largerEq,\n smaller: smaller,\n smallerEq: smallerEq,\n typed: typed\n});\nexports.range = range;\nvar rightLogShift = /* #__PURE__ */(0, _factoriesAny.createRightLogShift)({\n DenseMatrix: DenseMatrix,\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed,\n zeros: zeros\n});\nexports.rightLogShift = rightLogShift;\nvar setSize = /* #__PURE__ */(0, _factoriesAny.createSetSize)({\n compareNatural: compareNatural,\n typed: typed\n});\nexports.setSize = setSize;\nvar slu = /* #__PURE__ */(0, _factoriesAny.createSlu)({\n SparseMatrix: SparseMatrix,\n abs: abs,\n add: add,\n divideScalar: divideScalar,\n larger: larger,\n largerEq: largerEq,\n multiply: multiply,\n subtract: subtract,\n transpose: transpose,\n typed: typed\n});\nexports.slu = slu;\nvar sum = /* #__PURE__ */(0, _factoriesAny.createSum)({\n add: add,\n config: _configReadonly.config,\n numeric: numeric,\n typed: typed\n});\nexports.sum = sum;\nvar trace = /* #__PURE__ */(0, _factoriesAny.createTrace)({\n add: add,\n matrix: matrix,\n typed: typed\n});\nexports.trace = trace;\nvar usolveAll = /* #__PURE__ */(0, _factoriesAny.createUsolveAll)({\n DenseMatrix: DenseMatrix,\n divideScalar: divideScalar,\n equalScalar: equalScalar,\n matrix: matrix,\n multiplyScalar: multiplyScalar,\n subtract: subtract,\n typed: typed\n});\nexports.usolveAll = usolveAll;\nvar asin = /* #__PURE__ */(0, _factoriesAny.createAsin)({\n Complex: Complex,\n config: _configReadonly.config,\n typed: typed\n});\nexports.asin = asin;\nvar ceil = /* #__PURE__ */(0, _factoriesAny.createCeil)({\n DenseMatrix: DenseMatrix,\n config: _configReadonly.config,\n equalScalar: equalScalar,\n matrix: matrix,\n round: round,\n typed: typed,\n zeros: zeros\n});\nexports.ceil = ceil;\nvar composition = /* #__PURE__ */(0, _factoriesAny.createComposition)({\n addScalar: addScalar,\n combinations: combinations,\n isInteger: isInteger,\n isNegative: isNegative,\n isPositive: isPositive,\n larger: larger,\n typed: typed\n});\nexports.composition = composition;\nvar cross = /* #__PURE__ */(0, _factoriesAny.createCross)({\n matrix: matrix,\n multiply: multiply,\n subtract: subtract,\n typed: typed\n});\nexports.cross = cross;\nvar det = /* #__PURE__ */(0, _factoriesAny.createDet)({\n divideScalar: divideScalar,\n isZero: isZero,\n matrix: matrix,\n multiply: multiply,\n subtract: subtract,\n typed: typed,\n unaryMinus: unaryMinus\n});\nexports.det = det;\nvar distance = /* #__PURE__ */(0, _factoriesAny.createDistance)({\n abs: abs,\n addScalar: addScalar,\n divideScalar: divideScalar,\n multiplyScalar: multiplyScalar,\n sqrt: sqrt,\n subtract: subtract,\n typed: typed,\n unaryMinus: unaryMinus\n});\nexports.distance = distance;\nvar dotMultiply = /* #__PURE__ */(0, _factoriesAny.createDotMultiply)({\n equalScalar: equalScalar,\n matrix: matrix,\n multiplyScalar: multiplyScalar,\n typed: typed\n});\nexports.dotMultiply = dotMultiply;\nvar FibonacciHeap = /* #__PURE__ */(0, _factoriesAny.createFibonacciHeapClass)({\n larger: larger,\n smaller: smaller\n});\nexports.FibonacciHeap = FibonacciHeap;\nvar fix = /* #__PURE__ */(0, _factoriesAny.createFix)({\n Complex: Complex,\n DenseMatrix: DenseMatrix,\n ceil: ceil,\n equalScalar: equalScalar,\n floor: floor,\n matrix: matrix,\n typed: typed,\n zeros: zeros\n});\nexports.fix = fix;\nvar ImmutableDenseMatrix = /* #__PURE__ */(0, _factoriesAny.createImmutableDenseMatrixClass)({\n DenseMatrix: DenseMatrix,\n smaller: smaller\n});\nexports.ImmutableDenseMatrix = ImmutableDenseMatrix;\nvar Index = /* #__PURE__ */(0, _factoriesAny.createIndexClass)({\n ImmutableDenseMatrix: ImmutableDenseMatrix\n});\nexports.Index = Index;\nvar intersect = /* #__PURE__ */(0, _factoriesAny.createIntersect)({\n abs: abs,\n add: add,\n addScalar: addScalar,\n config: _configReadonly.config,\n divideScalar: divideScalar,\n equalScalar: equalScalar,\n flatten: flatten,\n isNumeric: isNumeric,\n isZero: isZero,\n matrix: matrix,\n multiply: multiply,\n multiplyScalar: multiplyScalar,\n smaller: smaller,\n subtract: subtract,\n typed: typed\n});\nexports.intersect = intersect;\nvar lcm = /* #__PURE__ */(0, _factoriesAny.createLcm)({\n equalScalar: equalScalar,\n matrix: matrix,\n typed: typed\n});\nexports.lcm = lcm;\nvar log1p = /* #__PURE__ */(0, _factoriesAny.createLog1p)({\n Complex: Complex,\n config: _configReadonly.config,\n divideScalar: divideScalar,\n log: log,\n typed: typed\n});\nexports.log1p = log1p;\nvar max = /* #__PURE__ */(0, _factoriesAny.createMax)({\n config: _configReadonly.config,\n larger: larger,\n numeric: numeric,\n typed: typed\n});\nexports.max = max;\nvar quantileSeq = /* #__PURE__ */(0, _factoriesAny.createQuantileSeq)({\n add: add,\n compare: compare,\n multiply: multiply,\n partitionSelect: partitionSelect,\n typed: typed\n});\nexports.quantileSeq = quantileSeq;\nvar row = /* #__PURE__ */(0, _factoriesAny.createRow)({\n Index: Index,\n matrix: matrix,\n range: range,\n typed: typed\n});\nexports.row = row;\nvar setCartesian = /* #__PURE__ */(0, _factoriesAny.createSetCartesian)({\n DenseMatrix: DenseMatrix,\n Index: Index,\n compareNatural: compareNatural,\n size: size,\n subset: subset,\n typed: typed\n});\nexports.setCartesian = setCartesian;\nvar setDistinct = /* #__PURE__ */(0, _factoriesAny.createSetDistinct)({\n DenseMatrix: DenseMatrix,\n Index: Index,\n compareNatural: compareNatural,\n size: size,\n subset: subset,\n typed: typed\n});\nexports.setDistinct = setDistinct;\nvar setIsSubset = /* #__PURE__ */(0, _factoriesAny.createSetIsSubset)({\n Index: Index,\n compareNatural: compareNatural,\n size: size,\n subset: subset,\n typed: typed\n});\nexports.setIsSubset = setIsSubset;\nvar setPowerset = /* #__PURE__ */(0, _factoriesAny.createSetPowerset)({\n Index: Index,\n compareNatural: compareNatural,\n size: size,\n subset: subset,\n typed: typed\n});\nexports.setPowerset = setPowerset;\nvar sort = /* #__PURE__ */(0, _factoriesAny.createSort)({\n compare: compare,\n compareNatural: compareNatural,\n matrix: matrix,\n typed: typed\n});\nexports.sort = sort;\nvar column = /* #__PURE__ */(0, _factoriesAny.createColumn)({\n Index: Index,\n matrix: matrix,\n range: range,\n typed: typed\n});\nexports.column = column;\nvar index = /* #__PURE__ */(0, _factoriesAny.createIndex)({\n Index: Index,\n typed: typed\n});\nexports.index = index;\nvar inv = /* #__PURE__ */(0, _factoriesAny.createInv)({\n abs: abs,\n addScalar: addScalar,\n det: det,\n divideScalar: divideScalar,\n identity: identity,\n matrix: matrix,\n multiply: multiply,\n typed: typed,\n unaryMinus: unaryMinus\n});\nexports.inv = inv;\nvar pinv = /* #__PURE__ */(0, _factoriesAny.createPinv)({\n Complex: Complex,\n add: add,\n ctranspose: ctranspose,\n deepEqual: deepEqual,\n divideScalar: divideScalar,\n dot: dot,\n dotDivide: dotDivide,\n equal: equal,\n inv: inv,\n matrix: matrix,\n multiply: multiply,\n typed: typed\n});\nexports.pinv = pinv;\nvar pow = /* #__PURE__ */(0, _factoriesAny.createPow)({\n Complex: Complex,\n config: _configReadonly.config,\n fraction: fraction,\n identity: identity,\n inv: inv,\n matrix: matrix,\n multiply: multiply,\n number: number,\n typed: typed\n});\nexports.pow = pow;\nvar setDifference = /* #__PURE__ */(0, _factoriesAny.createSetDifference)({\n DenseMatrix: DenseMatrix,\n Index: Index,\n compareNatural: compareNatural,\n size: size,\n subset: subset,\n typed: typed\n});\nexports.setDifference = setDifference;\nvar setMultiplicity = /* #__PURE__ */(0, _factoriesAny.createSetMultiplicity)({\n Index: Index,\n compareNatural: compareNatural,\n size: size,\n subset: subset,\n typed: typed\n});\nexports.setMultiplicity = setMultiplicity;\nvar Spa = /* #__PURE__ */(0, _factoriesAny.createSpaClass)({\n FibonacciHeap: FibonacciHeap,\n addScalar: addScalar,\n equalScalar: equalScalar\n});\nexports.Spa = Spa;\nvar sqrtm = /* #__PURE__ */(0, _factoriesAny.createSqrtm)({\n abs: abs,\n add: add,\n identity: identity,\n inv: inv,\n max: max,\n multiply: multiply,\n size: size,\n sqrt: sqrt,\n subtract: subtract,\n typed: typed\n});\nexports.sqrtm = sqrtm;\nvar Unit = /* #__PURE__ */(0, _factoriesAny.createUnitClass)({\n BigNumber: BigNumber,\n Complex: Complex,\n Fraction: Fraction,\n abs: abs,\n addScalar: addScalar,\n config: _configReadonly.config,\n divideScalar: divideScalar,\n equal: equal,\n fix: fix,\n format: format,\n isNumeric: isNumeric,\n multiplyScalar: multiplyScalar,\n number: number,\n pow: pow,\n round: round,\n subtract: subtract\n});\nexports.Unit = Unit;\nvar vacuumImpedance = /* #__PURE__ */(0, _factoriesAny.createVacuumImpedance)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.vacuumImpedance = vacuumImpedance;\nvar wienDisplacement = /* #__PURE__ */(0, _factoriesAny.createWienDisplacement)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.wienDisplacement = wienDisplacement;\nvar atomicMass = /* #__PURE__ */(0, _factoriesAny.createAtomicMass)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.atomicMass = atomicMass;\nvar bohrMagneton = /* #__PURE__ */(0, _factoriesAny.createBohrMagneton)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.bohrMagneton = bohrMagneton;\nvar boltzmann = /* #__PURE__ */(0, _factoriesAny.createBoltzmann)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.boltzmann = boltzmann;\nvar conductanceQuantum = /* #__PURE__ */(0, _factoriesAny.createConductanceQuantum)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.conductanceQuantum = conductanceQuantum;\nvar createUnit = /* #__PURE__ */(0, _factoriesAny.createCreateUnit)({\n Unit: Unit,\n typed: typed\n});\nexports.createUnit = createUnit;\nvar deuteronMass = /* #__PURE__ */(0, _factoriesAny.createDeuteronMass)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.deuteronMass = deuteronMass;\nvar dotPow = /* #__PURE__ */(0, _factoriesAny.createDotPow)({\n DenseMatrix: DenseMatrix,\n equalScalar: equalScalar,\n matrix: matrix,\n pow: pow,\n typed: typed\n});\nexports.dotPow = dotPow;\nvar electricConstant = /* #__PURE__ */(0, _factoriesAny.createElectricConstant)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.electricConstant = electricConstant;\nvar elementaryCharge = /* #__PURE__ */(0, _factoriesAny.createElementaryCharge)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.elementaryCharge = elementaryCharge;\nvar expm = /* #__PURE__ */(0, _factoriesAny.createExpm)({\n abs: abs,\n add: add,\n identity: identity,\n inv: inv,\n multiply: multiply,\n typed: typed\n});\nexports.expm = expm;\nvar faraday = /* #__PURE__ */(0, _factoriesAny.createFaraday)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.faraday = faraday;\nvar firstRadiation = /* #__PURE__ */(0, _factoriesAny.createFirstRadiation)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.firstRadiation = firstRadiation;\nvar gamma = /* #__PURE__ */(0, _factoriesAny.createGamma)({\n BigNumber: BigNumber,\n Complex: Complex,\n config: _configReadonly.config,\n multiplyScalar: multiplyScalar,\n pow: pow,\n typed: typed\n});\nexports.gamma = gamma;\nvar gravitationConstant = /* #__PURE__ */(0, _factoriesAny.createGravitationConstant)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.gravitationConstant = gravitationConstant;\nvar hartreeEnergy = /* #__PURE__ */(0, _factoriesAny.createHartreeEnergy)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.hartreeEnergy = hartreeEnergy;\nvar klitzing = /* #__PURE__ */(0, _factoriesAny.createKlitzing)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.klitzing = klitzing;\nvar loschmidt = /* #__PURE__ */(0, _factoriesAny.createLoschmidt)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.loschmidt = loschmidt;\nvar magneticConstant = /* #__PURE__ */(0, _factoriesAny.createMagneticConstant)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.magneticConstant = magneticConstant;\nvar molarMass = /* #__PURE__ */(0, _factoriesAny.createMolarMass)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.molarMass = molarMass;\nvar molarPlanckConstant = /* #__PURE__ */(0, _factoriesAny.createMolarPlanckConstant)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.molarPlanckConstant = molarPlanckConstant;\nvar neutronMass = /* #__PURE__ */(0, _factoriesAny.createNeutronMass)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.neutronMass = neutronMass;\nvar nuclearMagneton = /* #__PURE__ */(0, _factoriesAny.createNuclearMagneton)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.nuclearMagneton = nuclearMagneton;\nvar planckCharge = /* #__PURE__ */(0, _factoriesAny.createPlanckCharge)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.planckCharge = planckCharge;\nvar planckLength = /* #__PURE__ */(0, _factoriesAny.createPlanckLength)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.planckLength = planckLength;\nvar planckTemperature = /* #__PURE__ */(0, _factoriesAny.createPlanckTemperature)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.planckTemperature = planckTemperature;\nvar protonMass = /* #__PURE__ */(0, _factoriesAny.createProtonMass)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.protonMass = protonMass;\nvar reducedPlanckConstant = /* #__PURE__ */(0, _factoriesAny.createReducedPlanckConstant)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.reducedPlanckConstant = reducedPlanckConstant;\nvar rydberg = /* #__PURE__ */(0, _factoriesAny.createRydberg)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.rydberg = rydberg;\nvar setIntersect = /* #__PURE__ */(0, _factoriesAny.createSetIntersect)({\n DenseMatrix: DenseMatrix,\n Index: Index,\n compareNatural: compareNatural,\n size: size,\n subset: subset,\n typed: typed\n});\nexports.setIntersect = setIntersect;\nvar speedOfLight = /* #__PURE__ */(0, _factoriesAny.createSpeedOfLight)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.speedOfLight = speedOfLight;\nvar stefanBoltzmann = /* #__PURE__ */(0, _factoriesAny.createStefanBoltzmann)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.stefanBoltzmann = stefanBoltzmann;\nvar thomsonCrossSection = /* #__PURE__ */(0, _factoriesAny.createThomsonCrossSection)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.thomsonCrossSection = thomsonCrossSection;\nvar avogadro = /* #__PURE__ */(0, _factoriesAny.createAvogadro)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.avogadro = avogadro;\nvar bohrRadius = /* #__PURE__ */(0, _factoriesAny.createBohrRadius)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.bohrRadius = bohrRadius;\nvar coulomb = /* #__PURE__ */(0, _factoriesAny.createCoulomb)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.coulomb = coulomb;\nvar divide = /* #__PURE__ */(0, _factoriesAny.createDivide)({\n divideScalar: divideScalar,\n equalScalar: equalScalar,\n inv: inv,\n matrix: matrix,\n multiply: multiply,\n typed: typed\n});\nexports.divide = divide;\nvar electronMass = /* #__PURE__ */(0, _factoriesAny.createElectronMass)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.electronMass = electronMass;\nvar factorial = /* #__PURE__ */(0, _factoriesAny.createFactorial)({\n gamma: gamma,\n typed: typed\n});\nexports.factorial = factorial;\nvar gravity = /* #__PURE__ */(0, _factoriesAny.createGravity)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.gravity = gravity;\nvar inverseConductanceQuantum = /* #__PURE__ */(0, _factoriesAny.createInverseConductanceQuantum)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.inverseConductanceQuantum = inverseConductanceQuantum;\nvar lup = /* #__PURE__ */(0, _factoriesAny.createLup)({\n DenseMatrix: DenseMatrix,\n Spa: Spa,\n SparseMatrix: SparseMatrix,\n abs: abs,\n addScalar: addScalar,\n divideScalar: divideScalar,\n equalScalar: equalScalar,\n larger: larger,\n matrix: matrix,\n multiplyScalar: multiplyScalar,\n subtract: subtract,\n typed: typed,\n unaryMinus: unaryMinus\n});\nexports.lup = lup;\nvar magneticFluxQuantum = /* #__PURE__ */(0, _factoriesAny.createMagneticFluxQuantum)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.magneticFluxQuantum = magneticFluxQuantum;\nvar molarMassC12 = /* #__PURE__ */(0, _factoriesAny.createMolarMassC12)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.molarMassC12 = molarMassC12;\nvar multinomial = /* #__PURE__ */(0, _factoriesAny.createMultinomial)({\n add: add,\n divide: divide,\n factorial: factorial,\n isInteger: isInteger,\n isPositive: isPositive,\n multiply: multiply,\n typed: typed\n});\nexports.multinomial = multinomial;\nvar permutations = /* #__PURE__ */(0, _factoriesAny.createPermutations)({\n factorial: factorial,\n typed: typed\n});\nexports.permutations = permutations;\nvar planckMass = /* #__PURE__ */(0, _factoriesAny.createPlanckMass)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.planckMass = planckMass;\nvar quantumOfCirculation = /* #__PURE__ */(0, _factoriesAny.createQuantumOfCirculation)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.quantumOfCirculation = quantumOfCirculation;\nvar secondRadiation = /* #__PURE__ */(0, _factoriesAny.createSecondRadiation)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.secondRadiation = secondRadiation;\nvar stirlingS2 = /* #__PURE__ */(0, _factoriesAny.createStirlingS2)({\n bignumber: bignumber,\n addScalar: addScalar,\n combinations: combinations,\n divideScalar: divideScalar,\n factorial: factorial,\n isInteger: isInteger,\n isNegative: isNegative,\n larger: larger,\n multiplyScalar: multiplyScalar,\n number: number,\n pow: pow,\n subtract: subtract,\n typed: typed\n});\nexports.stirlingS2 = stirlingS2;\nvar unit = /* #__PURE__ */(0, _factoriesAny.createUnitFunction)({\n Unit: Unit,\n typed: typed\n});\nexports.unit = unit;\nvar bellNumbers = /* #__PURE__ */(0, _factoriesAny.createBellNumbers)({\n addScalar: addScalar,\n isInteger: isInteger,\n isNegative: isNegative,\n stirlingS2: stirlingS2,\n typed: typed\n});\nexports.bellNumbers = bellNumbers;\nvar eigs = /* #__PURE__ */(0, _factoriesAny.createEigs)({\n abs: abs,\n add: add,\n addScalar: addScalar,\n atan: atan,\n bignumber: bignumber,\n column: column,\n complex: complex,\n config: _configReadonly.config,\n cos: cos,\n diag: diag,\n divideScalar: divideScalar,\n dot: dot,\n equal: equal,\n flatten: flatten,\n im: im,\n inv: inv,\n larger: larger,\n matrix: matrix,\n matrixFromColumns: matrixFromColumns,\n multiply: multiply,\n multiplyScalar: multiplyScalar,\n number: number,\n qr: qr,\n re: re,\n sin: sin,\n smaller: smaller,\n sqrt: sqrt,\n subtract: subtract,\n typed: typed,\n usolve: usolve,\n usolveAll: usolveAll\n});\nexports.eigs = eigs;\nvar fermiCoupling = /* #__PURE__ */(0, _factoriesAny.createFermiCoupling)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.fermiCoupling = fermiCoupling;\nvar mean = /* #__PURE__ */(0, _factoriesAny.createMean)({\n add: add,\n divide: divide,\n typed: typed\n});\nexports.mean = mean;\nvar molarVolume = /* #__PURE__ */(0, _factoriesAny.createMolarVolume)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.molarVolume = molarVolume;\nvar planckConstant = /* #__PURE__ */(0, _factoriesAny.createPlanckConstant)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.planckConstant = planckConstant;\nvar setSymDifference = /* #__PURE__ */(0, _factoriesAny.createSetSymDifference)({\n Index: Index,\n concat: concat,\n setDifference: setDifference,\n size: size,\n subset: subset,\n typed: typed\n});\nexports.setSymDifference = setSymDifference;\nvar classicalElectronRadius = /* #__PURE__ */(0, _factoriesAny.createClassicalElectronRadius)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.classicalElectronRadius = classicalElectronRadius;\nvar lusolve = /* #__PURE__ */(0, _factoriesAny.createLusolve)({\n DenseMatrix: DenseMatrix,\n lsolve: lsolve,\n lup: lup,\n matrix: matrix,\n slu: slu,\n typed: typed,\n usolve: usolve\n});\nexports.lusolve = lusolve;\nvar median = /* #__PURE__ */(0, _factoriesAny.createMedian)({\n add: add,\n compare: compare,\n divide: divide,\n partitionSelect: partitionSelect,\n typed: typed\n});\nexports.median = median;\nvar setUnion = /* #__PURE__ */(0, _factoriesAny.createSetUnion)({\n Index: Index,\n concat: concat,\n setIntersect: setIntersect,\n setSymDifference: setSymDifference,\n size: size,\n subset: subset,\n typed: typed\n});\nexports.setUnion = setUnion;\nvar variance = /* #__PURE__ */(0, _factoriesAny.createVariance)({\n add: add,\n apply: apply,\n divide: divide,\n isNaN: isNaN,\n multiply: multiply,\n subtract: subtract,\n typed: typed\n});\nexports.variance = variance;\nvar kldivergence = /* #__PURE__ */(0, _factoriesAny.createKldivergence)({\n divide: divide,\n dotDivide: dotDivide,\n isNumeric: isNumeric,\n log: log,\n matrix: matrix,\n multiply: multiply,\n sum: sum,\n typed: typed\n});\nexports.kldivergence = kldivergence;\nvar norm = /* #__PURE__ */(0, _factoriesAny.createNorm)({\n abs: abs,\n add: add,\n conj: conj,\n ctranspose: ctranspose,\n eigs: eigs,\n equalScalar: equalScalar,\n larger: larger,\n matrix: matrix,\n multiply: multiply,\n pow: pow,\n smaller: smaller,\n sqrt: sqrt,\n typed: typed\n});\nexports.norm = norm;\nvar planckTime = /* #__PURE__ */(0, _factoriesAny.createPlanckTime)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.planckTime = planckTime;\nvar rotationMatrix = /* #__PURE__ */(0, _factoriesAny.createRotationMatrix)({\n BigNumber: BigNumber,\n DenseMatrix: DenseMatrix,\n SparseMatrix: SparseMatrix,\n addScalar: addScalar,\n config: _configReadonly.config,\n cos: cos,\n matrix: matrix,\n multiplyScalar: multiplyScalar,\n norm: norm,\n sin: sin,\n typed: typed,\n unaryMinus: unaryMinus\n});\nexports.rotationMatrix = rotationMatrix;\nvar gasConstant = /* #__PURE__ */(0, _factoriesAny.createGasConstant)({\n BigNumber: BigNumber,\n Unit: Unit,\n config: _configReadonly.config\n});\nexports.gasConstant = gasConstant;\nvar std = /* #__PURE__ */(0, _factoriesAny.createStd)({\n sqrt: sqrt,\n typed: typed,\n variance: variance\n});\nexports.std = std;\nvar mad = /* #__PURE__ */(0, _factoriesAny.createMad)({\n abs: abs,\n map: map,\n median: median,\n subtract: subtract,\n typed: typed\n});\nexports.mad = mad;\nvar rotate = /* #__PURE__ */(0, _factoriesAny.createRotate)({\n multiply: multiply,\n rotationMatrix: rotationMatrix,\n typed: typed\n});\nexports.rotate = rotate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"isAccessorNode\", {\n enumerable: true,\n get: function get() {\n return _is.isAccessorNode;\n }\n});\nObject.defineProperty(exports, \"isArray\", {\n enumerable: true,\n get: function get() {\n return _is.isArray;\n }\n});\nObject.defineProperty(exports, \"isArrayNode\", {\n enumerable: true,\n get: function get() {\n return _is.isArrayNode;\n }\n});\nObject.defineProperty(exports, \"isAssignmentNode\", {\n enumerable: true,\n get: function get() {\n return _is.isAssignmentNode;\n }\n});\nObject.defineProperty(exports, \"isBigNumber\", {\n enumerable: true,\n get: function get() {\n return _is.isBigNumber;\n }\n});\nObject.defineProperty(exports, \"isBlockNode\", {\n enumerable: true,\n get: function get() {\n return _is.isBlockNode;\n }\n});\nObject.defineProperty(exports, \"isBoolean\", {\n enumerable: true,\n get: function get() {\n return _is.isBoolean;\n }\n});\nObject.defineProperty(exports, \"isChain\", {\n enumerable: true,\n get: function get() {\n return _is.isChain;\n }\n});\nObject.defineProperty(exports, \"isCollection\", {\n enumerable: true,\n get: function get() {\n return _is.isCollection;\n }\n});\nObject.defineProperty(exports, \"isComplex\", {\n enumerable: true,\n get: function get() {\n return _is.isComplex;\n }\n});\nObject.defineProperty(exports, \"isConditionalNode\", {\n enumerable: true,\n get: function get() {\n return _is.isConditionalNode;\n }\n});\nObject.defineProperty(exports, \"isConstantNode\", {\n enumerable: true,\n get: function get() {\n return _is.isConstantNode;\n }\n});\nObject.defineProperty(exports, \"isDate\", {\n enumerable: true,\n get: function get() {\n return _is.isDate;\n }\n});\nObject.defineProperty(exports, \"isDenseMatrix\", {\n enumerable: true,\n get: function get() {\n return _is.isDenseMatrix;\n }\n});\nObject.defineProperty(exports, \"isFraction\", {\n enumerable: true,\n get: function get() {\n return _is.isFraction;\n }\n});\nObject.defineProperty(exports, \"isFunction\", {\n enumerable: true,\n get: function get() {\n return _is.isFunction;\n }\n});\nObject.defineProperty(exports, \"isFunctionAssignmentNode\", {\n enumerable: true,\n get: function get() {\n return _is.isFunctionAssignmentNode;\n }\n});\nObject.defineProperty(exports, \"isFunctionNode\", {\n enumerable: true,\n get: function get() {\n return _is.isFunctionNode;\n }\n});\nObject.defineProperty(exports, \"isHelp\", {\n enumerable: true,\n get: function get() {\n return _is.isHelp;\n }\n});\nObject.defineProperty(exports, \"isIndex\", {\n enumerable: true,\n get: function get() {\n return _is.isIndex;\n }\n});\nObject.defineProperty(exports, \"isIndexNode\", {\n enumerable: true,\n get: function get() {\n return _is.isIndexNode;\n }\n});\nObject.defineProperty(exports, \"isMatrix\", {\n enumerable: true,\n get: function get() {\n return _is.isMatrix;\n }\n});\nObject.defineProperty(exports, \"isNode\", {\n enumerable: true,\n get: function get() {\n return _is.isNode;\n }\n});\nObject.defineProperty(exports, \"isNull\", {\n enumerable: true,\n get: function get() {\n return _is.isNull;\n }\n});\nObject.defineProperty(exports, \"isNumber\", {\n enumerable: true,\n get: function get() {\n return _is.isNumber;\n }\n});\nObject.defineProperty(exports, \"isObject\", {\n enumerable: true,\n get: function get() {\n return _is.isObject;\n }\n});\nObject.defineProperty(exports, \"isObjectNode\", {\n enumerable: true,\n get: function get() {\n return _is.isObjectNode;\n }\n});\nObject.defineProperty(exports, \"isOperatorNode\", {\n enumerable: true,\n get: function get() {\n return _is.isOperatorNode;\n }\n});\nObject.defineProperty(exports, \"isParenthesisNode\", {\n enumerable: true,\n get: function get() {\n return _is.isParenthesisNode;\n }\n});\nObject.defineProperty(exports, \"isRange\", {\n enumerable: true,\n get: function get() {\n return _is.isRange;\n }\n});\nObject.defineProperty(exports, \"isRangeNode\", {\n enumerable: true,\n get: function get() {\n return _is.isRangeNode;\n }\n});\nObject.defineProperty(exports, \"isRegExp\", {\n enumerable: true,\n get: function get() {\n return _is.isRegExp;\n }\n});\nObject.defineProperty(exports, \"isResultSet\", {\n enumerable: true,\n get: function get() {\n return _is.isResultSet;\n }\n});\nObject.defineProperty(exports, \"isSparseMatrix\", {\n enumerable: true,\n get: function get() {\n return _is.isSparseMatrix;\n }\n});\nObject.defineProperty(exports, \"isString\", {\n enumerable: true,\n get: function get() {\n return _is.isString;\n }\n});\nObject.defineProperty(exports, \"isSymbolNode\", {\n enumerable: true,\n get: function get() {\n return _is.isSymbolNode;\n }\n});\nObject.defineProperty(exports, \"isUndefined\", {\n enumerable: true,\n get: function get() {\n return _is.isUndefined;\n }\n});\nObject.defineProperty(exports, \"isUnit\", {\n enumerable: true,\n get: function get() {\n return _is.isUnit;\n }\n});\n\nvar _is = require(\"../utils/is.js\");","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ArgumentsError = ArgumentsError;\n\n/**\n * Create a syntax error with the message:\n * 'Wrong number of arguments in function ( provided, - expected)'\n * @param {string} fn Function name\n * @param {number} count Actual argument count\n * @param {number} min Minimum required argument count\n * @param {number} [max] Maximum required argument count\n * @extends Error\n */\nfunction ArgumentsError(fn, count, min, max) {\n if (!(this instanceof ArgumentsError)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n this.fn = fn;\n this.count = count;\n this.min = min;\n this.max = max;\n this.message = 'Wrong number of arguments in function ' + fn + ' (' + count + ' provided, ' + min + (max !== undefined && max !== null ? '-' + max : '') + ' expected)';\n this.stack = new Error().stack;\n}\n\nArgumentsError.prototype = new Error();\nArgumentsError.prototype.constructor = Error;\nArgumentsError.prototype.name = 'ArgumentsError';\nArgumentsError.prototype.isArgumentsError = true;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.DimensionError = DimensionError;\n\n/**\n * Create a range error with the message:\n * 'Dimension mismatch ( != )'\n * @param {number | number[]} actual The actual size\n * @param {number | number[]} expected The expected size\n * @param {string} [relation='!='] Optional relation between actual\n * and expected size: '!=', '<', etc.\n * @extends RangeError\n */\nfunction DimensionError(actual, expected, relation) {\n if (!(this instanceof DimensionError)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n this.actual = actual;\n this.expected = expected;\n this.relation = relation;\n this.message = 'Dimension mismatch (' + (Array.isArray(actual) ? '[' + actual.join(', ') + ']' : actual) + ' ' + (this.relation || '!=') + ' ' + (Array.isArray(expected) ? '[' + expected.join(', ') + ']' : expected) + ')';\n this.stack = new Error().stack;\n}\n\nDimensionError.prototype = new RangeError();\nDimensionError.prototype.constructor = RangeError;\nDimensionError.prototype.name = 'DimensionError';\nDimensionError.prototype.isDimensionError = true;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.IndexError = IndexError;\n\n/**\n * Create a range error with the message:\n * 'Index out of range (index < min)'\n * 'Index out of range (index < max)'\n *\n * @param {number} index The actual index\n * @param {number} [min=0] Minimum index (included)\n * @param {number} [max] Maximum index (excluded)\n * @extends RangeError\n */\nfunction IndexError(index, min, max) {\n if (!(this instanceof IndexError)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n this.index = index;\n\n if (arguments.length < 3) {\n this.min = 0;\n this.max = min;\n } else {\n this.min = min;\n this.max = max;\n }\n\n if (this.min !== undefined && this.index < this.min) {\n this.message = 'Index out of range (' + this.index + ' < ' + this.min + ')';\n } else if (this.max !== undefined && this.index >= this.max) {\n this.message = 'Index out of range (' + this.index + ' > ' + (this.max - 1) + ')';\n } else {\n this.message = 'Index out of range (' + this.index + ')';\n }\n\n this.stack = new Error().stack;\n}\n\nIndexError.prototype = new RangeError();\nIndexError.prototype.constructor = RangeError;\nIndexError.prototype.name = 'IndexError';\nIndexError.prototype.isIndexError = true;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createHelpClass = void 0;\n\nvar _is = require(\"../utils/is.js\");\n\nvar _object = require(\"../utils/object.js\");\n\nvar _string = require(\"../utils/string.js\");\n\nvar _factory = require(\"../utils/factory.js\");\n\nvar name = 'Help';\nvar dependencies = ['parse'];\nvar createHelpClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var parse = _ref.parse;\n\n /**\n * Documentation object\n * @param {Object} doc Object containing properties:\n * {string} name\n * {string} category\n * {string} description\n * {string[]} syntax\n * {string[]} examples\n * {string[]} seealso\n * @constructor\n */\n function Help(doc) {\n if (!(this instanceof Help)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n if (!doc) throw new Error('Argument \"doc\" missing');\n this.doc = doc;\n }\n /**\n * Attach type information\n */\n\n\n Help.prototype.type = 'Help';\n Help.prototype.isHelp = true;\n /**\n * Generate a string representation of the Help object\n * @return {string} Returns a string\n * @private\n */\n\n Help.prototype.toString = function () {\n var doc = this.doc || {};\n var desc = '\\n';\n\n if (doc.name) {\n desc += 'Name: ' + doc.name + '\\n\\n';\n }\n\n if (doc.category) {\n desc += 'Category: ' + doc.category + '\\n\\n';\n }\n\n if (doc.description) {\n desc += 'Description:\\n ' + doc.description + '\\n\\n';\n }\n\n if (doc.syntax) {\n desc += 'Syntax:\\n ' + doc.syntax.join('\\n ') + '\\n\\n';\n }\n\n if (doc.examples) {\n desc += 'Examples:\\n';\n var scope = {};\n\n for (var i = 0; i < doc.examples.length; i++) {\n var expr = doc.examples[i];\n desc += ' ' + expr + '\\n';\n var res = void 0;\n\n try {\n // note: res can be undefined when `expr` is an empty string\n res = parse(expr).compile().evaluate(scope);\n } catch (e) {\n res = e;\n }\n\n if (res !== undefined && !(0, _is.isHelp)(res)) {\n desc += ' ' + (0, _string.format)(res, {\n precision: 14\n }) + '\\n';\n }\n }\n\n desc += '\\n';\n }\n\n if (doc.mayThrow && doc.mayThrow.length) {\n desc += 'Throws: ' + doc.mayThrow.join(', ') + '\\n\\n';\n }\n\n if (doc.seealso && doc.seealso.length) {\n desc += 'See also: ' + doc.seealso.join(', ') + '\\n';\n }\n\n return desc;\n };\n /**\n * Export the help object to JSON\n */\n\n\n Help.prototype.toJSON = function () {\n var obj = (0, _object.clone)(this.doc);\n obj.mathjs = 'Help';\n return obj;\n };\n /**\n * Instantiate a Help object from a JSON object\n * @param {Object} json\n * @returns {Help} Returns a new Help object\n */\n\n\n Help.fromJSON = function (json) {\n var doc = {};\n Object.keys(json).filter(function (prop) {\n return prop !== 'mathjs';\n }).forEach(function (prop) {\n doc[prop] = json[prop];\n });\n return new Help(doc);\n };\n /**\n * Returns a string representation of the Help object\n */\n\n\n Help.prototype.valueOf = Help.prototype.toString;\n return Help;\n}, {\n isClass: true\n});\nexports.createHelpClass = createHelpClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createParserClass = void 0;\n\nvar _factory = require(\"../utils/factory.js\");\n\nvar _map = require(\"../utils/map.js\");\n\nvar name = 'Parser';\nvar dependencies = ['evaluate'];\nvar createParserClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var evaluate = _ref.evaluate;\n\n /**\n * @constructor Parser\n * Parser contains methods to evaluate or parse expressions, and has a number\n * of convenience methods to get, set, and remove variables from memory. Parser\n * keeps a scope containing variables in memory, which is used for all\n * evaluations.\n *\n * Methods:\n * const result = parser.evaluate(expr) // evaluate an expression\n * const value = parser.get(name) // retrieve a variable from the parser\n * const values = parser.getAll() // retrieve all defined variables\n * parser.set(name, value) // set a variable in the parser\n * parser.remove(name) // clear a variable from the\n * // parsers scope\n * parser.clear() // clear the parsers scope\n *\n * Example usage:\n * const parser = new Parser()\n * // Note: there is a convenience method which can be used instead:\n * // const parser = new math.parser()\n *\n * // evaluate expressions\n * parser.evaluate('sqrt(3^2 + 4^2)') // 5\n * parser.evaluate('sqrt(-4)') // 2i\n * parser.evaluate('2 inch in cm') // 5.08 cm\n * parser.evaluate('cos(45 deg)') // 0.7071067811865476\n *\n * // define variables and functions\n * parser.evaluate('x = 7 / 2') // 3.5\n * parser.evaluate('x + 3') // 6.5\n * parser.evaluate('f(x, y) = x^y') // f(x, y)\n * parser.evaluate('f(2, 3)') // 8\n *\n * // get and set variables and functions\n * const x = parser.get('x') // 7\n * const f = parser.get('f') // function\n * const g = f(3, 2) // 9\n * parser.set('h', 500)\n * const i = parser.evaluate('h / 2') // 250\n * parser.set('hello', function (name) {\n * return 'hello, ' + name + '!'\n * })\n * parser.evaluate('hello(\"user\")') // \"hello, user!\"\n *\n * // clear defined functions and variables\n * parser.clear()\n *\n */\n function Parser() {\n if (!(this instanceof Parser)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n Object.defineProperty(this, 'scope', {\n value: (0, _map.createEmptyMap)(),\n writable: false\n });\n }\n /**\n * Attach type information\n */\n\n\n Parser.prototype.type = 'Parser';\n Parser.prototype.isParser = true;\n /**\n * Parse and evaluate the given expression\n * @param {string | string[]} expr A string containing an expression,\n * for example \"2+3\", or a list with expressions\n * @return {*} result The result, or undefined when the expression was empty\n * @throws {Error}\n */\n\n Parser.prototype.evaluate = function (expr) {\n // TODO: validate arguments\n return evaluate(expr, this.scope);\n };\n /**\n * Get a variable (a function or variable) by name from the parsers scope.\n * Returns undefined when not found\n * @param {string} name\n * @return {* | undefined} value\n */\n\n\n Parser.prototype.get = function (name) {\n // TODO: validate arguments\n if (this.scope.has(name)) {\n return this.scope.get(name);\n }\n };\n /**\n * Get a map with all defined variables\n * @return {Object} values\n */\n\n\n Parser.prototype.getAll = function () {\n return (0, _map.toObject)(this.scope);\n };\n /**\n * Get a map with all defined variables\n * @return {Map} values\n */\n\n\n Parser.prototype.getAllAsMap = function () {\n return this.scope;\n };\n /**\n * Set a symbol (a function or variable) by name from the parsers scope.\n * @param {string} name\n * @param {* | undefined} value\n */\n\n\n Parser.prototype.set = function (name, value) {\n this.scope.set(name, value);\n return value;\n };\n /**\n * Remove a variable from the parsers scope\n * @param {string} name\n */\n\n\n Parser.prototype.remove = function (name) {\n this.scope.delete(name);\n };\n /**\n * Clear the scope with variables and functions\n */\n\n\n Parser.prototype.clear = function () {\n this.scope.clear();\n };\n\n return Parser;\n}, {\n isClass: true\n});\nexports.createParserClass = createParserClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.InfinityDocs = void 0;\nvar InfinityDocs = {\n name: 'Infinity',\n category: 'Constants',\n syntax: ['Infinity'],\n description: 'Infinity, a number which is larger than the maximum number that can be handled by a floating point number.',\n examples: ['Infinity', '1 / 0'],\n seealso: []\n};\nexports.InfinityDocs = InfinityDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LN10Docs = void 0;\nvar LN10Docs = {\n name: 'LN10',\n category: 'Constants',\n syntax: ['LN10'],\n description: 'Returns the natural logarithm of 10, approximately equal to 2.302',\n examples: ['LN10', 'log(10)'],\n seealso: []\n};\nexports.LN10Docs = LN10Docs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LN2Docs = void 0;\nvar LN2Docs = {\n name: 'LN2',\n category: 'Constants',\n syntax: ['LN2'],\n description: 'Returns the natural logarithm of 2, approximately equal to 0.693',\n examples: ['LN2', 'log(2)'],\n seealso: []\n};\nexports.LN2Docs = LN2Docs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LOG10EDocs = void 0;\nvar LOG10EDocs = {\n name: 'LOG10E',\n category: 'Constants',\n syntax: ['LOG10E'],\n description: 'Returns the base-10 logarithm of E, approximately equal to 0.434',\n examples: ['LOG10E', 'log(e, 10)'],\n seealso: []\n};\nexports.LOG10EDocs = LOG10EDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LOG2EDocs = void 0;\nvar LOG2EDocs = {\n name: 'LOG2E',\n category: 'Constants',\n syntax: ['LOG2E'],\n description: 'Returns the base-2 logarithm of E, approximately equal to 1.442',\n examples: ['LOG2E', 'log(e, 2)'],\n seealso: []\n};\nexports.LOG2EDocs = LOG2EDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.NaNDocs = void 0;\nvar NaNDocs = {\n name: 'NaN',\n category: 'Constants',\n syntax: ['NaN'],\n description: 'Not a number',\n examples: ['NaN', '0 / 0'],\n seealso: []\n};\nexports.NaNDocs = NaNDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.SQRT12Docs = void 0;\nvar SQRT12Docs = {\n name: 'SQRT1_2',\n category: 'Constants',\n syntax: ['SQRT1_2'],\n description: 'Returns the square root of 1/2, approximately equal to 0.707',\n examples: ['SQRT1_2', 'sqrt(1/2)'],\n seealso: []\n};\nexports.SQRT12Docs = SQRT12Docs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.SQRT2Docs = void 0;\nvar SQRT2Docs = {\n name: 'SQRT2',\n category: 'Constants',\n syntax: ['SQRT2'],\n description: 'Returns the square root of 2, approximately equal to 1.414',\n examples: ['SQRT2', 'sqrt(2)'],\n seealso: []\n};\nexports.SQRT2Docs = SQRT2Docs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.eDocs = void 0;\nvar eDocs = {\n name: 'e',\n category: 'Constants',\n syntax: ['e'],\n description: 'Euler\\'s number, the base of the natural logarithm. Approximately equal to 2.71828',\n examples: ['e', 'e ^ 2', 'exp(2)', 'log(e)'],\n seealso: ['exp']\n};\nexports.eDocs = eDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.falseDocs = void 0;\nvar falseDocs = {\n name: 'false',\n category: 'Constants',\n syntax: ['false'],\n description: 'Boolean value false',\n examples: ['false'],\n seealso: ['true']\n};\nexports.falseDocs = falseDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.iDocs = void 0;\nvar iDocs = {\n name: 'i',\n category: 'Constants',\n syntax: ['i'],\n description: 'Imaginary unit, defined as i*i=-1. A complex number is described as a + b*i, where a is the real part, and b is the imaginary part.',\n examples: ['i', 'i * i', 'sqrt(-1)'],\n seealso: []\n};\nexports.iDocs = iDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.nullDocs = void 0;\nvar nullDocs = {\n name: 'null',\n category: 'Constants',\n syntax: ['null'],\n description: 'Value null',\n examples: ['null'],\n seealso: ['true', 'false']\n};\nexports.nullDocs = nullDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.phiDocs = void 0;\nvar phiDocs = {\n name: 'phi',\n category: 'Constants',\n syntax: ['phi'],\n description: 'Phi is the golden ratio. Two quantities are in the golden ratio if their ratio is the same as the ratio of their sum to the larger of the two quantities. Phi is defined as `(1 + sqrt(5)) / 2` and is approximately 1.618034...',\n examples: ['phi'],\n seealso: []\n};\nexports.phiDocs = phiDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.piDocs = void 0;\nvar piDocs = {\n name: 'pi',\n category: 'Constants',\n syntax: ['pi'],\n description: 'The number pi is a mathematical constant that is the ratio of a circle\\'s circumference to its diameter, and is approximately equal to 3.14159',\n examples: ['pi', 'sin(pi/2)'],\n seealso: ['tau']\n};\nexports.piDocs = piDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.tauDocs = void 0;\nvar tauDocs = {\n name: 'tau',\n category: 'Constants',\n syntax: ['tau'],\n description: 'Tau is the ratio constant of a circle\\'s circumference to radius, equal to 2 * pi, approximately 6.2832.',\n examples: ['tau', '2 * pi'],\n seealso: ['pi']\n};\nexports.tauDocs = tauDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.trueDocs = void 0;\nvar trueDocs = {\n name: 'true',\n category: 'Constants',\n syntax: ['true'],\n description: 'Boolean value true',\n examples: ['true'],\n seealso: ['false']\n};\nexports.trueDocs = trueDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.versionDocs = void 0;\nvar versionDocs = {\n name: 'version',\n category: 'Constants',\n syntax: ['version'],\n description: 'A string with the version number of math.js',\n examples: ['version'],\n seealso: []\n};\nexports.versionDocs = versionDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bignumberDocs = void 0;\nvar bignumberDocs = {\n name: 'bignumber',\n category: 'Construction',\n syntax: ['bignumber(x)'],\n description: 'Create a big number from a number or string.',\n examples: ['0.1 + 0.2', 'bignumber(0.1) + bignumber(0.2)', 'bignumber(\"7.2\")', 'bignumber(\"7.2e500\")', 'bignumber([0.1, 0.2, 0.3])'],\n seealso: ['boolean', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit']\n};\nexports.bignumberDocs = bignumberDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.booleanDocs = void 0;\nvar booleanDocs = {\n name: 'boolean',\n category: 'Construction',\n syntax: ['x', 'boolean(x)'],\n description: 'Convert a string or number into a boolean.',\n examples: ['boolean(0)', 'boolean(1)', 'boolean(3)', 'boolean(\"true\")', 'boolean(\"false\")', 'boolean([1, 0, 1, 1])'],\n seealso: ['bignumber', 'complex', 'index', 'matrix', 'number', 'string', 'unit']\n};\nexports.booleanDocs = booleanDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.complexDocs = void 0;\nvar complexDocs = {\n name: 'complex',\n category: 'Construction',\n syntax: ['complex()', 'complex(re, im)', 'complex(string)'],\n description: 'Create a complex number.',\n examples: ['complex()', 'complex(2, 3)', 'complex(\"7 - 2i\")'],\n seealso: ['bignumber', 'boolean', 'index', 'matrix', 'number', 'string', 'unit']\n};\nexports.complexDocs = complexDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createUnitDocs = void 0;\nvar createUnitDocs = {\n name: 'createUnit',\n category: 'Construction',\n syntax: ['createUnit(definitions)', 'createUnit(name, definition)'],\n description: 'Create a user-defined unit and register it with the Unit type.',\n examples: ['createUnit(\"foo\")', 'createUnit(\"knot\", {definition: \"0.514444444 m/s\", aliases: [\"knots\", \"kt\", \"kts\"]})', 'createUnit(\"mph\", \"1 mile/hour\")'],\n seealso: ['unit', 'splitUnit']\n};\nexports.createUnitDocs = createUnitDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.fractionDocs = void 0;\nvar fractionDocs = {\n name: 'fraction',\n category: 'Construction',\n syntax: ['fraction(num)', 'fraction(matrix)', 'fraction(num,den)', 'fraction({n: num, d: den})'],\n description: 'Create a fraction from a number or from integer numerator and denominator.',\n examples: ['fraction(0.125)', 'fraction(1, 3) + fraction(2, 5)', 'fraction({n: 333, d: 53})', 'fraction([sqrt(9), sqrt(10), sqrt(11)])'],\n seealso: ['bignumber', 'boolean', 'complex', 'index', 'matrix', 'string', 'unit']\n};\nexports.fractionDocs = fractionDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.indexDocs = void 0;\nvar indexDocs = {\n name: 'index',\n category: 'Construction',\n syntax: ['[start]', '[start:end]', '[start:step:end]', '[start1, start 2, ...]', '[start1:end1, start2:end2, ...]', '[start1:step1:end1, start2:step2:end2, ...]'],\n description: 'Create an index to get or replace a subset of a matrix',\n examples: ['[]', '[1, 2, 3]', 'A = [1, 2, 3; 4, 5, 6]', 'A[1, :]', 'A[1, 2] = 50', 'A[0:2, 0:2] = ones(2, 2)'],\n seealso: ['bignumber', 'boolean', 'complex', 'matrix,', 'number', 'range', 'string', 'unit']\n};\nexports.indexDocs = indexDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.matrixDocs = void 0;\nvar matrixDocs = {\n name: 'matrix',\n category: 'Construction',\n syntax: ['[]', '[a1, b1, ...; a2, b2, ...]', 'matrix()', 'matrix(\"dense\")', 'matrix([...])'],\n description: 'Create a matrix.',\n examples: ['[]', '[1, 2, 3]', '[1, 2, 3; 4, 5, 6]', 'matrix()', 'matrix([3, 4])', 'matrix([3, 4; 5, 6], \"sparse\")', 'matrix([3, 4; 5, 6], \"sparse\", \"number\")'],\n seealso: ['bignumber', 'boolean', 'complex', 'index', 'number', 'string', 'unit', 'sparse']\n};\nexports.matrixDocs = matrixDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.numberDocs = void 0;\nvar numberDocs = {\n name: 'number',\n category: 'Construction',\n syntax: ['x', 'number(x)', 'number(unit, valuelessUnit)'],\n description: 'Create a number or convert a string or boolean into a number.',\n examples: ['2', '2e3', '4.05', 'number(2)', 'number(\"7.2\")', 'number(true)', 'number([true, false, true, true])', 'number(unit(\"52cm\"), \"m\")'],\n seealso: ['bignumber', 'boolean', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit']\n};\nexports.numberDocs = numberDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sparseDocs = void 0;\nvar sparseDocs = {\n name: 'sparse',\n category: 'Construction',\n syntax: ['sparse()', 'sparse([a1, b1, ...; a1, b2, ...])', 'sparse([a1, b1, ...; a1, b2, ...], \"number\")'],\n description: 'Create a sparse matrix.',\n examples: ['sparse()', 'sparse([3, 4; 5, 6])', 'sparse([3, 0; 5, 0], \"number\")'],\n seealso: ['bignumber', 'boolean', 'complex', 'index', 'number', 'string', 'unit', 'matrix']\n};\nexports.sparseDocs = sparseDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.splitUnitDocs = void 0;\nvar splitUnitDocs = {\n name: 'splitUnit',\n category: 'Construction',\n syntax: ['splitUnit(unit: Unit, parts: Unit[])'],\n description: 'Split a unit in an array of units whose sum is equal to the original unit.',\n examples: ['splitUnit(1 m, [\"feet\", \"inch\"])'],\n seealso: ['unit', 'createUnit']\n};\nexports.splitUnitDocs = splitUnitDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.stringDocs = void 0;\nvar stringDocs = {\n name: 'string',\n category: 'Construction',\n syntax: ['\"text\"', 'string(x)'],\n description: 'Create a string or convert a value to a string',\n examples: ['\"Hello World!\"', 'string(4.2)', 'string(3 + 2i)'],\n seealso: ['bignumber', 'boolean', 'complex', 'index', 'matrix', 'number', 'unit']\n};\nexports.stringDocs = stringDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.unitDocs = void 0;\nvar unitDocs = {\n name: 'unit',\n category: 'Construction',\n syntax: ['value unit', 'unit(value, unit)', 'unit(string)'],\n description: 'Create a unit.',\n examples: ['5.5 mm', '3 inch', 'unit(7.1, \"kilogram\")', 'unit(\"23 deg\")'],\n seealso: ['bignumber', 'boolean', 'complex', 'index', 'matrix', 'number', 'string']\n};\nexports.unitDocs = unitDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.configDocs = void 0;\nvar configDocs = {\n name: 'config',\n category: 'Core',\n syntax: ['config()', 'config(options)'],\n description: 'Get configuration or change configuration.',\n examples: ['config()', '1/3 + 1/4', 'config({number: \"Fraction\"})', '1/3 + 1/4'],\n seealso: []\n};\nexports.configDocs = configDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.importDocs = void 0;\nvar importDocs = {\n name: 'import',\n category: 'Core',\n syntax: ['import(functions)', 'import(functions, options)'],\n description: 'Import functions or constants from an object.',\n examples: ['import({myFn: f(x)=x^2, myConstant: 32 })', 'myFn(2)', 'myConstant'],\n seealso: []\n};\nexports.importDocs = importDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.typedDocs = void 0;\nvar typedDocs = {\n name: 'typed',\n category: 'Core',\n syntax: ['typed(signatures)', 'typed(name, signatures)'],\n description: 'Create a typed function.',\n examples: ['double = typed({ \"number\": f(x)=x+x })', 'double(2)', 'double(\"hello\")'],\n seealso: []\n};\nexports.typedDocs = typedDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.embeddedDocs = void 0;\n\nvar _e = require(\"./constants/e.js\");\n\nvar _false = require(\"./constants/false.js\");\n\nvar _i = require(\"./constants/i.js\");\n\nvar _Infinity = require(\"./constants/Infinity.js\");\n\nvar _LN = require(\"./constants/LN10.js\");\n\nvar _LN2 = require(\"./constants/LN2.js\");\n\nvar _LOG10E = require(\"./constants/LOG10E.js\");\n\nvar _LOG2E = require(\"./constants/LOG2E.js\");\n\nvar _NaN = require(\"./constants/NaN.js\");\n\nvar _null = require(\"./constants/null.js\");\n\nvar _phi = require(\"./constants/phi.js\");\n\nvar _pi = require(\"./constants/pi.js\");\n\nvar _SQRT1_ = require(\"./constants/SQRT1_2.js\");\n\nvar _SQRT = require(\"./constants/SQRT2.js\");\n\nvar _tau = require(\"./constants/tau.js\");\n\nvar _true = require(\"./constants/true.js\");\n\nvar _version = require(\"./constants/version.js\");\n\nvar _bignumber = require(\"./construction/bignumber.js\");\n\nvar _boolean = require(\"./construction/boolean.js\");\n\nvar _complex = require(\"./construction/complex.js\");\n\nvar _createUnit = require(\"./construction/createUnit.js\");\n\nvar _fraction = require(\"./construction/fraction.js\");\n\nvar _index = require(\"./construction/index.js\");\n\nvar _matrix = require(\"./construction/matrix.js\");\n\nvar _number = require(\"./construction/number.js\");\n\nvar _sparse = require(\"./construction/sparse.js\");\n\nvar _splitUnit = require(\"./construction/splitUnit.js\");\n\nvar _string = require(\"./construction/string.js\");\n\nvar _unit = require(\"./construction/unit.js\");\n\nvar _config = require(\"./core/config.js\");\n\nvar _import = require(\"./core/import.js\");\n\nvar _typed = require(\"./core/typed.js\");\n\nvar _derivative = require(\"./function/algebra/derivative.js\");\n\nvar _leafCount = require(\"./function/algebra/leafCount.js\");\n\nvar _lsolve = require(\"./function/algebra/lsolve.js\");\n\nvar _lsolveAll = require(\"./function/algebra/lsolveAll.js\");\n\nvar _lup = require(\"./function/algebra/lup.js\");\n\nvar _lusolve = require(\"./function/algebra/lusolve.js\");\n\nvar _qr = require(\"./function/algebra/qr.js\");\n\nvar _rationalize = require(\"./function/algebra/rationalize.js\");\n\nvar _resolve = require(\"./function/algebra/resolve.js\");\n\nvar _simplify = require(\"./function/algebra/simplify.js\");\n\nvar _simplifyCore = require(\"./function/algebra/simplifyCore.js\");\n\nvar _slu = require(\"./function/algebra/slu.js\");\n\nvar _symbolicEqual = require(\"./function/algebra/symbolicEqual.js\");\n\nvar _usolve = require(\"./function/algebra/usolve.js\");\n\nvar _usolveAll = require(\"./function/algebra/usolveAll.js\");\n\nvar _abs = require(\"./function/arithmetic/abs.js\");\n\nvar _add = require(\"./function/arithmetic/add.js\");\n\nvar _cbrt = require(\"./function/arithmetic/cbrt.js\");\n\nvar _ceil = require(\"./function/arithmetic/ceil.js\");\n\nvar _cube = require(\"./function/arithmetic/cube.js\");\n\nvar _divide = require(\"./function/arithmetic/divide.js\");\n\nvar _dotDivide = require(\"./function/arithmetic/dotDivide.js\");\n\nvar _dotMultiply = require(\"./function/arithmetic/dotMultiply.js\");\n\nvar _dotPow = require(\"./function/arithmetic/dotPow.js\");\n\nvar _exp = require(\"./function/arithmetic/exp.js\");\n\nvar _expm = require(\"./function/arithmetic/expm.js\");\n\nvar _expm2 = require(\"./function/arithmetic/expm1.js\");\n\nvar _fix = require(\"./function/arithmetic/fix.js\");\n\nvar _floor = require(\"./function/arithmetic/floor.js\");\n\nvar _gcd = require(\"./function/arithmetic/gcd.js\");\n\nvar _hypot = require(\"./function/arithmetic/hypot.js\");\n\nvar _invmod = require(\"./function/arithmetic/invmod.js\");\n\nvar _lcm = require(\"./function/arithmetic/lcm.js\");\n\nvar _log = require(\"./function/arithmetic/log.js\");\n\nvar _log2 = require(\"./function/arithmetic/log10.js\");\n\nvar _log1p = require(\"./function/arithmetic/log1p.js\");\n\nvar _log3 = require(\"./function/arithmetic/log2.js\");\n\nvar _mod = require(\"./function/arithmetic/mod.js\");\n\nvar _multiply = require(\"./function/arithmetic/multiply.js\");\n\nvar _norm = require(\"./function/arithmetic/norm.js\");\n\nvar _nthRoot = require(\"./function/arithmetic/nthRoot.js\");\n\nvar _nthRoots = require(\"./function/arithmetic/nthRoots.js\");\n\nvar _pow = require(\"./function/arithmetic/pow.js\");\n\nvar _round = require(\"./function/arithmetic/round.js\");\n\nvar _sign = require(\"./function/arithmetic/sign.js\");\n\nvar _sqrt = require(\"./function/arithmetic/sqrt.js\");\n\nvar _sqrtm = require(\"./function/arithmetic/sqrtm.js\");\n\nvar _square = require(\"./function/arithmetic/square.js\");\n\nvar _subtract = require(\"./function/arithmetic/subtract.js\");\n\nvar _unaryMinus = require(\"./function/arithmetic/unaryMinus.js\");\n\nvar _unaryPlus = require(\"./function/arithmetic/unaryPlus.js\");\n\nvar _xgcd = require(\"./function/arithmetic/xgcd.js\");\n\nvar _bitAnd = require(\"./function/bitwise/bitAnd.js\");\n\nvar _bitNot = require(\"./function/bitwise/bitNot.js\");\n\nvar _bitOr = require(\"./function/bitwise/bitOr.js\");\n\nvar _bitXor = require(\"./function/bitwise/bitXor.js\");\n\nvar _leftShift = require(\"./function/bitwise/leftShift.js\");\n\nvar _rightArithShift = require(\"./function/bitwise/rightArithShift.js\");\n\nvar _rightLogShift = require(\"./function/bitwise/rightLogShift.js\");\n\nvar _bellNumbers = require(\"./function/combinatorics/bellNumbers.js\");\n\nvar _catalan = require(\"./function/combinatorics/catalan.js\");\n\nvar _composition = require(\"./function/combinatorics/composition.js\");\n\nvar _stirlingS = require(\"./function/combinatorics/stirlingS2.js\");\n\nvar _arg = require(\"./function/complex/arg.js\");\n\nvar _conj = require(\"./function/complex/conj.js\");\n\nvar _im = require(\"./function/complex/im.js\");\n\nvar _re = require(\"./function/complex/re.js\");\n\nvar _evaluate = require(\"./function/expression/evaluate.js\");\n\nvar _help = require(\"./function/expression/help.js\");\n\nvar _distance = require(\"./function/geometry/distance.js\");\n\nvar _intersect = require(\"./function/geometry/intersect.js\");\n\nvar _and = require(\"./function/logical/and.js\");\n\nvar _not = require(\"./function/logical/not.js\");\n\nvar _or = require(\"./function/logical/or.js\");\n\nvar _xor = require(\"./function/logical/xor.js\");\n\nvar _column = require(\"./function/matrix/column.js\");\n\nvar _concat = require(\"./function/matrix/concat.js\");\n\nvar _count = require(\"./function/matrix/count.js\");\n\nvar _cross = require(\"./function/matrix/cross.js\");\n\nvar _ctranspose = require(\"./function/matrix/ctranspose.js\");\n\nvar _det = require(\"./function/matrix/det.js\");\n\nvar _diag = require(\"./function/matrix/diag.js\");\n\nvar _diff = require(\"./function/matrix/diff.js\");\n\nvar _dot = require(\"./function/matrix/dot.js\");\n\nvar _eigs = require(\"./function/matrix/eigs.js\");\n\nvar _filter = require(\"./function/matrix/filter.js\");\n\nvar _flatten = require(\"./function/matrix/flatten.js\");\n\nvar _forEach = require(\"./function/matrix/forEach.js\");\n\nvar _getMatrixDataType = require(\"./function/matrix/getMatrixDataType.js\");\n\nvar _identity = require(\"./function/matrix/identity.js\");\n\nvar _inv = require(\"./function/matrix/inv.js\");\n\nvar _pinv = require(\"./function/matrix/pinv.js\");\n\nvar _kron = require(\"./function/matrix/kron.js\");\n\nvar _map = require(\"./function/matrix/map.js\");\n\nvar _matrixFromColumns = require(\"./function/matrix/matrixFromColumns.js\");\n\nvar _matrixFromFunction = require(\"./function/matrix/matrixFromFunction.js\");\n\nvar _matrixFromRows = require(\"./function/matrix/matrixFromRows.js\");\n\nvar _ones = require(\"./function/matrix/ones.js\");\n\nvar _partitionSelect = require(\"./function/matrix/partitionSelect.js\");\n\nvar _range = require(\"./function/matrix/range.js\");\n\nvar _reshape = require(\"./function/matrix/reshape.js\");\n\nvar _resize = require(\"./function/matrix/resize.js\");\n\nvar _rotate = require(\"./function/matrix/rotate.js\");\n\nvar _rotationMatrix = require(\"./function/matrix/rotationMatrix.js\");\n\nvar _row = require(\"./function/matrix/row.js\");\n\nvar _size = require(\"./function/matrix/size.js\");\n\nvar _sort = require(\"./function/matrix/sort.js\");\n\nvar _squeeze = require(\"./function/matrix/squeeze.js\");\n\nvar _subset = require(\"./function/matrix/subset.js\");\n\nvar _trace = require(\"./function/matrix/trace.js\");\n\nvar _transpose = require(\"./function/matrix/transpose.js\");\n\nvar _zeros = require(\"./function/matrix/zeros.js\");\n\nvar _fft = require(\"./function/matrix/fft.js\");\n\nvar _ifft = require(\"./function/matrix/ifft.js\");\n\nvar _combinations = require(\"./function/probability/combinations.js\");\n\nvar _combinationsWithRep = require(\"./function/probability/combinationsWithRep.js\");\n\nvar _factorial = require(\"./function/probability/factorial.js\");\n\nvar _gamma = require(\"./function/probability/gamma.js\");\n\nvar _lgamma = require(\"./function/probability/lgamma.js\");\n\nvar _kldivergence = require(\"./function/probability/kldivergence.js\");\n\nvar _multinomial = require(\"./function/probability/multinomial.js\");\n\nvar _permutations = require(\"./function/probability/permutations.js\");\n\nvar _pickRandom = require(\"./function/probability/pickRandom.js\");\n\nvar _random = require(\"./function/probability/random.js\");\n\nvar _randomInt = require(\"./function/probability/randomInt.js\");\n\nvar _compare = require(\"./function/relational/compare.js\");\n\nvar _compareNatural = require(\"./function/relational/compareNatural.js\");\n\nvar _compareText = require(\"./function/relational/compareText.js\");\n\nvar _deepEqual = require(\"./function/relational/deepEqual.js\");\n\nvar _equal = require(\"./function/relational/equal.js\");\n\nvar _equalText = require(\"./function/relational/equalText.js\");\n\nvar _larger = require(\"./function/relational/larger.js\");\n\nvar _largerEq = require(\"./function/relational/largerEq.js\");\n\nvar _smaller = require(\"./function/relational/smaller.js\");\n\nvar _smallerEq = require(\"./function/relational/smallerEq.js\");\n\nvar _unequal = require(\"./function/relational/unequal.js\");\n\nvar _setCartesian = require(\"./function/set/setCartesian.js\");\n\nvar _setDifference = require(\"./function/set/setDifference.js\");\n\nvar _setDistinct = require(\"./function/set/setDistinct.js\");\n\nvar _setIntersect = require(\"./function/set/setIntersect.js\");\n\nvar _setIsSubset = require(\"./function/set/setIsSubset.js\");\n\nvar _setMultiplicity = require(\"./function/set/setMultiplicity.js\");\n\nvar _setPowerset = require(\"./function/set/setPowerset.js\");\n\nvar _setSize = require(\"./function/set/setSize.js\");\n\nvar _setSymDifference = require(\"./function/set/setSymDifference.js\");\n\nvar _setUnion = require(\"./function/set/setUnion.js\");\n\nvar _erf = require(\"./function/special/erf.js\");\n\nvar _mad = require(\"./function/statistics/mad.js\");\n\nvar _max = require(\"./function/statistics/max.js\");\n\nvar _mean = require(\"./function/statistics/mean.js\");\n\nvar _median = require(\"./function/statistics/median.js\");\n\nvar _min = require(\"./function/statistics/min.js\");\n\nvar _mode = require(\"./function/statistics/mode.js\");\n\nvar _prod = require(\"./function/statistics/prod.js\");\n\nvar _quantileSeq = require(\"./function/statistics/quantileSeq.js\");\n\nvar _std = require(\"./function/statistics/std.js\");\n\nvar _cumsum = require(\"./function/statistics/cumsum.js\");\n\nvar _sum = require(\"./function/statistics/sum.js\");\n\nvar _variance = require(\"./function/statistics/variance.js\");\n\nvar _acos = require(\"./function/trigonometry/acos.js\");\n\nvar _acosh = require(\"./function/trigonometry/acosh.js\");\n\nvar _acot = require(\"./function/trigonometry/acot.js\");\n\nvar _acoth = require(\"./function/trigonometry/acoth.js\");\n\nvar _acsc = require(\"./function/trigonometry/acsc.js\");\n\nvar _acsch = require(\"./function/trigonometry/acsch.js\");\n\nvar _asec = require(\"./function/trigonometry/asec.js\");\n\nvar _asech = require(\"./function/trigonometry/asech.js\");\n\nvar _asin = require(\"./function/trigonometry/asin.js\");\n\nvar _asinh = require(\"./function/trigonometry/asinh.js\");\n\nvar _atan = require(\"./function/trigonometry/atan.js\");\n\nvar _atan2 = require(\"./function/trigonometry/atan2.js\");\n\nvar _atanh = require(\"./function/trigonometry/atanh.js\");\n\nvar _cos = require(\"./function/trigonometry/cos.js\");\n\nvar _cosh = require(\"./function/trigonometry/cosh.js\");\n\nvar _cot = require(\"./function/trigonometry/cot.js\");\n\nvar _coth = require(\"./function/trigonometry/coth.js\");\n\nvar _csc = require(\"./function/trigonometry/csc.js\");\n\nvar _csch = require(\"./function/trigonometry/csch.js\");\n\nvar _sec = require(\"./function/trigonometry/sec.js\");\n\nvar _sech = require(\"./function/trigonometry/sech.js\");\n\nvar _sin = require(\"./function/trigonometry/sin.js\");\n\nvar _sinh = require(\"./function/trigonometry/sinh.js\");\n\nvar _tan = require(\"./function/trigonometry/tan.js\");\n\nvar _tanh = require(\"./function/trigonometry/tanh.js\");\n\nvar _to = require(\"./function/units/to.js\");\n\nvar _bin = require(\"./function/utils/bin.js\");\n\nvar _clone = require(\"./function/utils/clone.js\");\n\nvar _format = require(\"./function/utils/format.js\");\n\nvar _hasNumericValue = require(\"./function/utils/hasNumericValue.js\");\n\nvar _hex = require(\"./function/utils/hex.js\");\n\nvar _isInteger = require(\"./function/utils/isInteger.js\");\n\nvar _isNaN = require(\"./function/utils/isNaN.js\");\n\nvar _isNegative = require(\"./function/utils/isNegative.js\");\n\nvar _isNumeric = require(\"./function/utils/isNumeric.js\");\n\nvar _isPositive = require(\"./function/utils/isPositive.js\");\n\nvar _isPrime = require(\"./function/utils/isPrime.js\");\n\nvar _isZero = require(\"./function/utils/isZero.js\");\n\nvar _numeric = require(\"./function/utils/numeric.js\");\n\nvar _oct = require(\"./function/utils/oct.js\");\n\nvar _print = require(\"./function/utils/print.js\");\n\nvar _typeOf = require(\"./function/utils/typeOf.js\");\n\nvar embeddedDocs = {\n // construction functions\n bignumber: _bignumber.bignumberDocs,\n boolean: _boolean.booleanDocs,\n complex: _complex.complexDocs,\n createUnit: _createUnit.createUnitDocs,\n fraction: _fraction.fractionDocs,\n index: _index.indexDocs,\n matrix: _matrix.matrixDocs,\n number: _number.numberDocs,\n sparse: _sparse.sparseDocs,\n splitUnit: _splitUnit.splitUnitDocs,\n string: _string.stringDocs,\n unit: _unit.unitDocs,\n // constants\n e: _e.eDocs,\n E: _e.eDocs,\n false: _false.falseDocs,\n i: _i.iDocs,\n Infinity: _Infinity.InfinityDocs,\n LN2: _LN2.LN2Docs,\n LN10: _LN.LN10Docs,\n LOG2E: _LOG2E.LOG2EDocs,\n LOG10E: _LOG10E.LOG10EDocs,\n NaN: _NaN.NaNDocs,\n null: _null.nullDocs,\n pi: _pi.piDocs,\n PI: _pi.piDocs,\n phi: _phi.phiDocs,\n SQRT1_2: _SQRT1_.SQRT12Docs,\n SQRT2: _SQRT.SQRT2Docs,\n tau: _tau.tauDocs,\n true: _true.trueDocs,\n version: _version.versionDocs,\n // physical constants\n // TODO: more detailed docs for physical constants\n speedOfLight: {\n description: 'Speed of light in vacuum',\n examples: ['speedOfLight']\n },\n gravitationConstant: {\n description: 'Newtonian constant of gravitation',\n examples: ['gravitationConstant']\n },\n planckConstant: {\n description: 'Planck constant',\n examples: ['planckConstant']\n },\n reducedPlanckConstant: {\n description: 'Reduced Planck constant',\n examples: ['reducedPlanckConstant']\n },\n magneticConstant: {\n description: 'Magnetic constant (vacuum permeability)',\n examples: ['magneticConstant']\n },\n electricConstant: {\n description: 'Electric constant (vacuum permeability)',\n examples: ['electricConstant']\n },\n vacuumImpedance: {\n description: 'Characteristic impedance of vacuum',\n examples: ['vacuumImpedance']\n },\n coulomb: {\n description: 'Coulomb\\'s constant',\n examples: ['coulomb']\n },\n elementaryCharge: {\n description: 'Elementary charge',\n examples: ['elementaryCharge']\n },\n bohrMagneton: {\n description: 'Borh magneton',\n examples: ['bohrMagneton']\n },\n conductanceQuantum: {\n description: 'Conductance quantum',\n examples: ['conductanceQuantum']\n },\n inverseConductanceQuantum: {\n description: 'Inverse conductance quantum',\n examples: ['inverseConductanceQuantum']\n },\n // josephson: {description: 'Josephson constant', examples: ['josephson']},\n magneticFluxQuantum: {\n description: 'Magnetic flux quantum',\n examples: ['magneticFluxQuantum']\n },\n nuclearMagneton: {\n description: 'Nuclear magneton',\n examples: ['nuclearMagneton']\n },\n klitzing: {\n description: 'Von Klitzing constant',\n examples: ['klitzing']\n },\n bohrRadius: {\n description: 'Borh radius',\n examples: ['bohrRadius']\n },\n classicalElectronRadius: {\n description: 'Classical electron radius',\n examples: ['classicalElectronRadius']\n },\n electronMass: {\n description: 'Electron mass',\n examples: ['electronMass']\n },\n fermiCoupling: {\n description: 'Fermi coupling constant',\n examples: ['fermiCoupling']\n },\n fineStructure: {\n description: 'Fine-structure constant',\n examples: ['fineStructure']\n },\n hartreeEnergy: {\n description: 'Hartree energy',\n examples: ['hartreeEnergy']\n },\n protonMass: {\n description: 'Proton mass',\n examples: ['protonMass']\n },\n deuteronMass: {\n description: 'Deuteron Mass',\n examples: ['deuteronMass']\n },\n neutronMass: {\n description: 'Neutron mass',\n examples: ['neutronMass']\n },\n quantumOfCirculation: {\n description: 'Quantum of circulation',\n examples: ['quantumOfCirculation']\n },\n rydberg: {\n description: 'Rydberg constant',\n examples: ['rydberg']\n },\n thomsonCrossSection: {\n description: 'Thomson cross section',\n examples: ['thomsonCrossSection']\n },\n weakMixingAngle: {\n description: 'Weak mixing angle',\n examples: ['weakMixingAngle']\n },\n efimovFactor: {\n description: 'Efimov factor',\n examples: ['efimovFactor']\n },\n atomicMass: {\n description: 'Atomic mass constant',\n examples: ['atomicMass']\n },\n avogadro: {\n description: 'Avogadro\\'s number',\n examples: ['avogadro']\n },\n boltzmann: {\n description: 'Boltzmann constant',\n examples: ['boltzmann']\n },\n faraday: {\n description: 'Faraday constant',\n examples: ['faraday']\n },\n firstRadiation: {\n description: 'First radiation constant',\n examples: ['firstRadiation']\n },\n loschmidt: {\n description: 'Loschmidt constant at T=273.15 K and p=101.325 kPa',\n examples: ['loschmidt']\n },\n gasConstant: {\n description: 'Gas constant',\n examples: ['gasConstant']\n },\n molarPlanckConstant: {\n description: 'Molar Planck constant',\n examples: ['molarPlanckConstant']\n },\n molarVolume: {\n description: 'Molar volume of an ideal gas at T=273.15 K and p=101.325 kPa',\n examples: ['molarVolume']\n },\n sackurTetrode: {\n description: 'Sackur-Tetrode constant at T=1 K and p=101.325 kPa',\n examples: ['sackurTetrode']\n },\n secondRadiation: {\n description: 'Second radiation constant',\n examples: ['secondRadiation']\n },\n stefanBoltzmann: {\n description: 'Stefan-Boltzmann constant',\n examples: ['stefanBoltzmann']\n },\n wienDisplacement: {\n description: 'Wien displacement law constant',\n examples: ['wienDisplacement']\n },\n // spectralRadiance: {description: 'First radiation constant for spectral radiance', examples: ['spectralRadiance']},\n molarMass: {\n description: 'Molar mass constant',\n examples: ['molarMass']\n },\n molarMassC12: {\n description: 'Molar mass constant of carbon-12',\n examples: ['molarMassC12']\n },\n gravity: {\n description: 'Standard acceleration of gravity (standard acceleration of free-fall on Earth)',\n examples: ['gravity']\n },\n planckLength: {\n description: 'Planck length',\n examples: ['planckLength']\n },\n planckMass: {\n description: 'Planck mass',\n examples: ['planckMass']\n },\n planckTime: {\n description: 'Planck time',\n examples: ['planckTime']\n },\n planckCharge: {\n description: 'Planck charge',\n examples: ['planckCharge']\n },\n planckTemperature: {\n description: 'Planck temperature',\n examples: ['planckTemperature']\n },\n // functions - algebra\n derivative: _derivative.derivativeDocs,\n lsolve: _lsolve.lsolveDocs,\n lsolveAll: _lsolveAll.lsolveAllDocs,\n lup: _lup.lupDocs,\n lusolve: _lusolve.lusolveDocs,\n leafCount: _leafCount.leafCountDocs,\n resolve: _resolve.resolveDocs,\n simplify: _simplify.simplifyDocs,\n simplifyCore: _simplifyCore.simplifyCoreDocs,\n symbolicEqual: _symbolicEqual.symbolicEqualDocs,\n rationalize: _rationalize.rationalizeDocs,\n slu: _slu.sluDocs,\n usolve: _usolve.usolveDocs,\n usolveAll: _usolveAll.usolveAllDocs,\n qr: _qr.qrDocs,\n // functions - arithmetic\n abs: _abs.absDocs,\n add: _add.addDocs,\n cbrt: _cbrt.cbrtDocs,\n ceil: _ceil.ceilDocs,\n cube: _cube.cubeDocs,\n divide: _divide.divideDocs,\n dotDivide: _dotDivide.dotDivideDocs,\n dotMultiply: _dotMultiply.dotMultiplyDocs,\n dotPow: _dotPow.dotPowDocs,\n exp: _exp.expDocs,\n expm: _expm.expmDocs,\n expm1: _expm2.expm1Docs,\n fix: _fix.fixDocs,\n floor: _floor.floorDocs,\n gcd: _gcd.gcdDocs,\n hypot: _hypot.hypotDocs,\n lcm: _lcm.lcmDocs,\n log: _log.logDocs,\n log2: _log3.log2Docs,\n log1p: _log1p.log1pDocs,\n log10: _log2.log10Docs,\n mod: _mod.modDocs,\n multiply: _multiply.multiplyDocs,\n norm: _norm.normDocs,\n nthRoot: _nthRoot.nthRootDocs,\n nthRoots: _nthRoots.nthRootsDocs,\n pow: _pow.powDocs,\n round: _round.roundDocs,\n sign: _sign.signDocs,\n sqrt: _sqrt.sqrtDocs,\n sqrtm: _sqrtm.sqrtmDocs,\n square: _square.squareDocs,\n subtract: _subtract.subtractDocs,\n unaryMinus: _unaryMinus.unaryMinusDocs,\n unaryPlus: _unaryPlus.unaryPlusDocs,\n xgcd: _xgcd.xgcdDocs,\n invmod: _invmod.invmodDocs,\n // functions - bitwise\n bitAnd: _bitAnd.bitAndDocs,\n bitNot: _bitNot.bitNotDocs,\n bitOr: _bitOr.bitOrDocs,\n bitXor: _bitXor.bitXorDocs,\n leftShift: _leftShift.leftShiftDocs,\n rightArithShift: _rightArithShift.rightArithShiftDocs,\n rightLogShift: _rightLogShift.rightLogShiftDocs,\n // functions - combinatorics\n bellNumbers: _bellNumbers.bellNumbersDocs,\n catalan: _catalan.catalanDocs,\n composition: _composition.compositionDocs,\n stirlingS2: _stirlingS.stirlingS2Docs,\n // functions - core\n config: _config.configDocs,\n import: _import.importDocs,\n typed: _typed.typedDocs,\n // functions - complex\n arg: _arg.argDocs,\n conj: _conj.conjDocs,\n re: _re.reDocs,\n im: _im.imDocs,\n // functions - expression\n evaluate: _evaluate.evaluateDocs,\n help: _help.helpDocs,\n // functions - geometry\n distance: _distance.distanceDocs,\n intersect: _intersect.intersectDocs,\n // functions - logical\n and: _and.andDocs,\n not: _not.notDocs,\n or: _or.orDocs,\n xor: _xor.xorDocs,\n // functions - matrix\n concat: _concat.concatDocs,\n count: _count.countDocs,\n cross: _cross.crossDocs,\n column: _column.columnDocs,\n ctranspose: _ctranspose.ctransposeDocs,\n det: _det.detDocs,\n diag: _diag.diagDocs,\n diff: _diff.diffDocs,\n dot: _dot.dotDocs,\n getMatrixDataType: _getMatrixDataType.getMatrixDataTypeDocs,\n identity: _identity.identityDocs,\n filter: _filter.filterDocs,\n flatten: _flatten.flattenDocs,\n forEach: _forEach.forEachDocs,\n inv: _inv.invDocs,\n pinv: _pinv.pinvDocs,\n eigs: _eigs.eigsDocs,\n kron: _kron.kronDocs,\n matrixFromFunction: _matrixFromFunction.matrixFromFunctionDocs,\n matrixFromRows: _matrixFromRows.matrixFromRowsDocs,\n matrixFromColumns: _matrixFromColumns.matrixFromColumnsDocs,\n map: _map.mapDocs,\n ones: _ones.onesDocs,\n partitionSelect: _partitionSelect.partitionSelectDocs,\n range: _range.rangeDocs,\n resize: _resize.resizeDocs,\n reshape: _reshape.reshapeDocs,\n rotate: _rotate.rotateDocs,\n rotationMatrix: _rotationMatrix.rotationMatrixDocs,\n row: _row.rowDocs,\n size: _size.sizeDocs,\n sort: _sort.sortDocs,\n squeeze: _squeeze.squeezeDocs,\n subset: _subset.subsetDocs,\n trace: _trace.traceDocs,\n transpose: _transpose.transposeDocs,\n zeros: _zeros.zerosDocs,\n fft: _fft.fftDocs,\n ifft: _ifft.ifftDocs,\n // functions - probability\n combinations: _combinations.combinationsDocs,\n combinationsWithRep: _combinationsWithRep.combinationsWithRepDocs,\n // distribution: distributionDocs,\n factorial: _factorial.factorialDocs,\n gamma: _gamma.gammaDocs,\n kldivergence: _kldivergence.kldivergenceDocs,\n lgamma: _lgamma.lgammaDocs,\n multinomial: _multinomial.multinomialDocs,\n permutations: _permutations.permutationsDocs,\n pickRandom: _pickRandom.pickRandomDocs,\n random: _random.randomDocs,\n randomInt: _randomInt.randomIntDocs,\n // functions - relational\n compare: _compare.compareDocs,\n compareNatural: _compareNatural.compareNaturalDocs,\n compareText: _compareText.compareTextDocs,\n deepEqual: _deepEqual.deepEqualDocs,\n equal: _equal.equalDocs,\n equalText: _equalText.equalTextDocs,\n larger: _larger.largerDocs,\n largerEq: _largerEq.largerEqDocs,\n smaller: _smaller.smallerDocs,\n smallerEq: _smallerEq.smallerEqDocs,\n unequal: _unequal.unequalDocs,\n // functions - set\n setCartesian: _setCartesian.setCartesianDocs,\n setDifference: _setDifference.setDifferenceDocs,\n setDistinct: _setDistinct.setDistinctDocs,\n setIntersect: _setIntersect.setIntersectDocs,\n setIsSubset: _setIsSubset.setIsSubsetDocs,\n setMultiplicity: _setMultiplicity.setMultiplicityDocs,\n setPowerset: _setPowerset.setPowersetDocs,\n setSize: _setSize.setSizeDocs,\n setSymDifference: _setSymDifference.setSymDifferenceDocs,\n setUnion: _setUnion.setUnionDocs,\n // functions - special\n erf: _erf.erfDocs,\n // functions - statistics\n cumsum: _cumsum.cumSumDocs,\n mad: _mad.madDocs,\n max: _max.maxDocs,\n mean: _mean.meanDocs,\n median: _median.medianDocs,\n min: _min.minDocs,\n mode: _mode.modeDocs,\n prod: _prod.prodDocs,\n quantileSeq: _quantileSeq.quantileSeqDocs,\n std: _std.stdDocs,\n sum: _sum.sumDocs,\n variance: _variance.varianceDocs,\n // functions - trigonometry\n acos: _acos.acosDocs,\n acosh: _acosh.acoshDocs,\n acot: _acot.acotDocs,\n acoth: _acoth.acothDocs,\n acsc: _acsc.acscDocs,\n acsch: _acsch.acschDocs,\n asec: _asec.asecDocs,\n asech: _asech.asechDocs,\n asin: _asin.asinDocs,\n asinh: _asinh.asinhDocs,\n atan: _atan.atanDocs,\n atanh: _atanh.atanhDocs,\n atan2: _atan2.atan2Docs,\n cos: _cos.cosDocs,\n cosh: _cosh.coshDocs,\n cot: _cot.cotDocs,\n coth: _coth.cothDocs,\n csc: _csc.cscDocs,\n csch: _csch.cschDocs,\n sec: _sec.secDocs,\n sech: _sech.sechDocs,\n sin: _sin.sinDocs,\n sinh: _sinh.sinhDocs,\n tan: _tan.tanDocs,\n tanh: _tanh.tanhDocs,\n // functions - units\n to: _to.toDocs,\n // functions - utils\n clone: _clone.cloneDocs,\n format: _format.formatDocs,\n bin: _bin.binDocs,\n oct: _oct.octDocs,\n hex: _hex.hexDocs,\n isNaN: _isNaN.isNaNDocs,\n isInteger: _isInteger.isIntegerDocs,\n isNegative: _isNegative.isNegativeDocs,\n isNumeric: _isNumeric.isNumericDocs,\n hasNumericValue: _hasNumericValue.hasNumericValueDocs,\n isPositive: _isPositive.isPositiveDocs,\n isPrime: _isPrime.isPrimeDocs,\n isZero: _isZero.isZeroDocs,\n print: _print.printDocs,\n typeOf: _typeOf.typeOfDocs,\n numeric: _numeric.numericDocs\n};\nexports.embeddedDocs = embeddedDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.derivativeDocs = void 0;\nvar derivativeDocs = {\n name: 'derivative',\n category: 'Algebra',\n syntax: ['derivative(expr, variable)', 'derivative(expr, variable, {simplify: boolean})'],\n description: 'Takes the derivative of an expression expressed in parser Nodes. The derivative will be taken over the supplied variable in the second parameter. If there are multiple variables in the expression, it will return a partial derivative.',\n examples: ['derivative(\"2x^3\", \"x\")', 'derivative(\"2x^3\", \"x\", {simplify: false})', 'derivative(\"2x^2 + 3x + 4\", \"x\")', 'derivative(\"sin(2x)\", \"x\")', 'f = parse(\"x^2 + x\")', 'x = parse(\"x\")', 'df = derivative(f, x)', 'df.evaluate({x: 3})'],\n seealso: ['simplify', 'parse', 'evaluate']\n};\nexports.derivativeDocs = derivativeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.leafCountDocs = void 0;\nvar leafCountDocs = {\n name: 'leafCount',\n category: 'Algebra',\n syntax: ['leafCount(expr)'],\n description: 'Computes the number of leaves in the parse tree of the given expression',\n examples: ['leafCount(\"e^(i*pi)-1\")', 'leafCount(parse(\"{a: 22/7, b: 10^(1/2)}\"))'],\n seealso: ['simplify']\n};\nexports.leafCountDocs = leafCountDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lsolveDocs = void 0;\nvar lsolveDocs = {\n name: 'lsolve',\n category: 'Algebra',\n syntax: ['x=lsolve(L, b)'],\n description: 'Finds one solution of the linear system L * x = b where L is an [n x n] lower triangular matrix and b is a [n] column vector.',\n examples: ['a = [-2, 3; 2, 1]', 'b = [11, 9]', 'x = lsolve(a, b)'],\n seealso: ['lsolveAll', 'lup', 'lusolve', 'usolve', 'matrix', 'sparse']\n};\nexports.lsolveDocs = lsolveDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lsolveAllDocs = void 0;\nvar lsolveAllDocs = {\n name: 'lsolveAll',\n category: 'Algebra',\n syntax: ['x=lsolveAll(L, b)'],\n description: 'Finds all solutions of the linear system L * x = b where L is an [n x n] lower triangular matrix and b is a [n] column vector.',\n examples: ['a = [-2, 3; 2, 1]', 'b = [11, 9]', 'x = lsolve(a, b)'],\n seealso: ['lsolve', 'lup', 'lusolve', 'usolve', 'matrix', 'sparse']\n};\nexports.lsolveAllDocs = lsolveAllDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lupDocs = void 0;\nvar lupDocs = {\n name: 'lup',\n category: 'Algebra',\n syntax: ['lup(m)'],\n description: 'Calculate the Matrix LU decomposition with partial pivoting. Matrix A is decomposed in three matrices (L, U, P) where P * A = L * U',\n examples: ['lup([[2, 1], [1, 4]])', 'lup(matrix([[2, 1], [1, 4]]))', 'lup(sparse([[2, 1], [1, 4]]))'],\n seealso: ['lusolve', 'lsolve', 'usolve', 'matrix', 'sparse', 'slu', 'qr']\n};\nexports.lupDocs = lupDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lusolveDocs = void 0;\nvar lusolveDocs = {\n name: 'lusolve',\n category: 'Algebra',\n syntax: ['x=lusolve(A, b)', 'x=lusolve(lu, b)'],\n description: 'Solves the linear system A * x = b where A is an [n x n] matrix and b is a [n] column vector.',\n examples: ['a = [-2, 3; 2, 1]', 'b = [11, 9]', 'x = lusolve(a, b)'],\n seealso: ['lup', 'slu', 'lsolve', 'usolve', 'matrix', 'sparse']\n};\nexports.lusolveDocs = lusolveDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.qrDocs = void 0;\nvar qrDocs = {\n name: 'qr',\n category: 'Algebra',\n syntax: ['qr(A)'],\n description: 'Calculates the Matrix QR decomposition. Matrix `A` is decomposed in two matrices (`Q`, `R`) where `Q` is an orthogonal matrix and `R` is an upper triangular matrix.',\n examples: ['qr([[1, -1, 4], [1, 4, -2], [1, 4, 2], [1, -1, 0]])'],\n seealso: ['lup', 'slu', 'matrix']\n};\nexports.qrDocs = qrDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rationalizeDocs = void 0;\nvar rationalizeDocs = {\n name: 'rationalize',\n category: 'Algebra',\n syntax: ['rationalize(expr)', 'rationalize(expr, scope)', 'rationalize(expr, scope, detailed)'],\n description: 'Transform a rationalizable expression in a rational fraction. If rational fraction is one variable polynomial then converts the numerator and denominator in canonical form, with decreasing exponents, returning the coefficients of numerator.',\n examples: ['rationalize(\"2x/y - y/(x+1)\")', 'rationalize(\"2x/y - y/(x+1)\", true)'],\n seealso: ['simplify']\n};\nexports.rationalizeDocs = rationalizeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.resolveDocs = void 0;\nvar resolveDocs = {\n name: 'resolve',\n category: 'Algebra',\n syntax: ['resolve(node, scope)'],\n description: 'Recursively substitute variables in an expression tree.',\n examples: ['resolve(parse(\"1 + x\"), { x: 7 })', 'resolve(parse(\"size(text)\"), { text: \"Hello World\" })', 'resolve(parse(\"x + y\"), { x: parse(\"3z\") })', 'resolve(parse(\"3x\"), { x: parse(\"y+z\"), z: parse(\"w^y\") })'],\n seealso: ['simplify', 'evaluate'],\n mayThrow: ['ReferenceError']\n};\nexports.resolveDocs = resolveDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.simplifyDocs = void 0;\nvar simplifyDocs = {\n name: 'simplify',\n category: 'Algebra',\n syntax: ['simplify(expr)', 'simplify(expr, rules)'],\n description: 'Simplify an expression tree.',\n examples: ['simplify(\"3 + 2 / 4\")', 'simplify(\"2x + x\")', 'f = parse(\"x * (x + 2 + x)\")', 'simplified = simplify(f)', 'simplified.evaluate({x: 2})'],\n seealso: ['simplifyCore', 'derivative', 'evaluate', 'parse', 'rationalize', 'resolve']\n};\nexports.simplifyDocs = simplifyDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.simplifyCoreDocs = void 0;\nvar simplifyCoreDocs = {\n name: 'simplifyCore',\n category: 'Algebra',\n syntax: ['simplifyCore(node)'],\n description: 'Perform simple one-pass simplifications on an expression tree.',\n examples: ['simplifyCore(parse(\"0*x\"))', 'simplifyCore(parse(\"(x+0)*2\"))'],\n seealso: ['simplify', 'evaluate']\n};\nexports.simplifyCoreDocs = simplifyCoreDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sluDocs = void 0;\nvar sluDocs = {\n name: 'slu',\n category: 'Algebra',\n syntax: ['slu(A, order, threshold)'],\n description: 'Calculate the Matrix LU decomposition with full pivoting. Matrix A is decomposed in two matrices (L, U) and two permutation vectors (pinv, q) where P * A * Q = L * U',\n examples: ['slu(sparse([4.5, 0, 3.2, 0; 3.1, 2.9, 0, 0.9; 0, 1.7, 3, 0; 3.5, 0.4, 0, 1]), 1, 0.001)'],\n seealso: ['lusolve', 'lsolve', 'usolve', 'matrix', 'sparse', 'lup', 'qr']\n};\nexports.sluDocs = sluDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.symbolicEqualDocs = void 0;\nvar symbolicEqualDocs = {\n name: 'symbolicEqual',\n category: 'Algebra',\n syntax: ['symbolicEqual(expr1, expr2)', 'symbolicEqual(expr1, expr2, options)'],\n description: 'Returns true if the difference of the expressions simplifies to 0',\n examples: ['symbolicEqual(\"x*y\",\"y*x\")', 'symbolicEqual(\"abs(x^2)\", \"x^2\")', 'symbolicEqual(\"abs(x)\", \"x\", {context: {abs: {trivial: true}}})'],\n seealso: ['simplify', 'evaluate']\n};\nexports.symbolicEqualDocs = symbolicEqualDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.usolveDocs = void 0;\nvar usolveDocs = {\n name: 'usolve',\n category: 'Algebra',\n syntax: ['x=usolve(U, b)'],\n description: 'Finds one solution of the linear system U * x = b where U is an [n x n] upper triangular matrix and b is a [n] column vector.',\n examples: ['x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])'],\n seealso: ['usolveAll', 'lup', 'lusolve', 'lsolve', 'matrix', 'sparse']\n};\nexports.usolveDocs = usolveDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.usolveAllDocs = void 0;\nvar usolveAllDocs = {\n name: 'usolveAll',\n category: 'Algebra',\n syntax: ['x=usolve(U, b)'],\n description: 'Finds all solutions of the linear system U * x = b where U is an [n x n] upper triangular matrix and b is a [n] column vector.',\n examples: ['x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])'],\n seealso: ['usolve', 'lup', 'lusolve', 'lsolve', 'matrix', 'sparse']\n};\nexports.usolveAllDocs = usolveAllDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.absDocs = void 0;\nvar absDocs = {\n name: 'abs',\n category: 'Arithmetic',\n syntax: ['abs(x)'],\n description: 'Compute the absolute value.',\n examples: ['abs(3.5)', 'abs(-4.2)'],\n seealso: ['sign']\n};\nexports.absDocs = absDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.addDocs = void 0;\nvar addDocs = {\n name: 'add',\n category: 'Operators',\n syntax: ['x + y', 'add(x, y)'],\n description: 'Add two values.',\n examples: ['a = 2.1 + 3.6', 'a - 3.6', '3 + 2i', '3 cm + 2 inch', '\"2.3\" + \"4\"'],\n seealso: ['subtract']\n};\nexports.addDocs = addDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cbrtDocs = void 0;\nvar cbrtDocs = {\n name: 'cbrt',\n category: 'Arithmetic',\n syntax: ['cbrt(x)', 'cbrt(x, allRoots)'],\n description: 'Compute the cubic root value. If x = y * y * y, then y is the cubic root of x. When `x` is a number or complex number, an optional second argument `allRoots` can be provided to return all three cubic roots. If not provided, the principal root is returned',\n examples: ['cbrt(64)', 'cube(4)', 'cbrt(-8)', 'cbrt(2 + 3i)', 'cbrt(8i)', 'cbrt(8i, true)', 'cbrt(27 m^3)'],\n seealso: ['square', 'sqrt', 'cube', 'multiply']\n};\nexports.cbrtDocs = cbrtDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ceilDocs = void 0;\nvar ceilDocs = {\n name: 'ceil',\n category: 'Arithmetic',\n syntax: ['ceil(x)'],\n description: 'Round a value towards plus infinity. If x is complex, both real and imaginary part are rounded towards plus infinity.',\n examples: ['ceil(3.2)', 'ceil(3.8)', 'ceil(-4.2)'],\n seealso: ['floor', 'fix', 'round']\n};\nexports.ceilDocs = ceilDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cubeDocs = void 0;\nvar cubeDocs = {\n name: 'cube',\n category: 'Arithmetic',\n syntax: ['cube(x)'],\n description: 'Compute the cube of a value. The cube of x is x * x * x.',\n examples: ['cube(2)', '2^3', '2 * 2 * 2'],\n seealso: ['multiply', 'square', 'pow']\n};\nexports.cubeDocs = cubeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.divideDocs = void 0;\nvar divideDocs = {\n name: 'divide',\n category: 'Operators',\n syntax: ['x / y', 'divide(x, y)'],\n description: 'Divide two values.',\n examples: ['a = 2 / 3', 'a * 3', '4.5 / 2', '3 + 4 / 2', '(3 + 4) / 2', '18 km / 4.5'],\n seealso: ['multiply']\n};\nexports.divideDocs = divideDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.dotDivideDocs = void 0;\nvar dotDivideDocs = {\n name: 'dotDivide',\n category: 'Operators',\n syntax: ['x ./ y', 'dotDivide(x, y)'],\n description: 'Divide two values element wise.',\n examples: ['a = [1, 2, 3; 4, 5, 6]', 'b = [2, 1, 1; 3, 2, 5]', 'a ./ b'],\n seealso: ['multiply', 'dotMultiply', 'divide']\n};\nexports.dotDivideDocs = dotDivideDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.dotMultiplyDocs = void 0;\nvar dotMultiplyDocs = {\n name: 'dotMultiply',\n category: 'Operators',\n syntax: ['x .* y', 'dotMultiply(x, y)'],\n description: 'Multiply two values element wise.',\n examples: ['a = [1, 2, 3; 4, 5, 6]', 'b = [2, 1, 1; 3, 2, 5]', 'a .* b'],\n seealso: ['multiply', 'divide', 'dotDivide']\n};\nexports.dotMultiplyDocs = dotMultiplyDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.dotPowDocs = void 0;\nvar dotPowDocs = {\n name: 'dotPow',\n category: 'Operators',\n syntax: ['x .^ y', 'dotPow(x, y)'],\n description: 'Calculates the power of x to y element wise.',\n examples: ['a = [1, 2, 3; 4, 5, 6]', 'a .^ 2'],\n seealso: ['pow']\n};\nexports.dotPowDocs = dotPowDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.expDocs = void 0;\nvar expDocs = {\n name: 'exp',\n category: 'Arithmetic',\n syntax: ['exp(x)'],\n description: 'Calculate the exponent of a value.',\n examples: ['exp(1.3)', 'e ^ 1.3', 'log(exp(1.3))', 'x = 2.4', '(exp(i*x) == cos(x) + i*sin(x)) # Euler\\'s formula'],\n seealso: ['expm', 'expm1', 'pow', 'log']\n};\nexports.expDocs = expDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.expmDocs = void 0;\nvar expmDocs = {\n name: 'expm',\n category: 'Arithmetic',\n syntax: ['exp(x)'],\n description: 'Compute the matrix exponential, expm(A) = e^A. ' + 'The matrix must be square. ' + 'Not to be confused with exp(a), which performs element-wise exponentiation.',\n examples: ['expm([[0,2],[0,0]])'],\n seealso: ['exp']\n};\nexports.expmDocs = expmDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.expm1Docs = void 0;\nvar expm1Docs = {\n name: 'expm1',\n category: 'Arithmetic',\n syntax: ['expm1(x)'],\n description: 'Calculate the value of subtracting 1 from the exponential value.',\n examples: ['expm1(2)', 'pow(e, 2) - 1', 'log(expm1(2) + 1)'],\n seealso: ['exp', 'pow', 'log']\n};\nexports.expm1Docs = expm1Docs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.fixDocs = void 0;\nvar fixDocs = {\n name: 'fix',\n category: 'Arithmetic',\n syntax: ['fix(x)'],\n description: 'Round a value towards zero. If x is complex, both real and imaginary part are rounded towards zero.',\n examples: ['fix(3.2)', 'fix(3.8)', 'fix(-4.2)', 'fix(-4.8)'],\n seealso: ['ceil', 'floor', 'round']\n};\nexports.fixDocs = fixDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.floorDocs = void 0;\nvar floorDocs = {\n name: 'floor',\n category: 'Arithmetic',\n syntax: ['floor(x)'],\n description: 'Round a value towards minus infinity.If x is complex, both real and imaginary part are rounded towards minus infinity.',\n examples: ['floor(3.2)', 'floor(3.8)', 'floor(-4.2)'],\n seealso: ['ceil', 'fix', 'round']\n};\nexports.floorDocs = floorDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.gcdDocs = void 0;\nvar gcdDocs = {\n name: 'gcd',\n category: 'Arithmetic',\n syntax: ['gcd(a, b)', 'gcd(a, b, c, ...)'],\n description: 'Compute the greatest common divisor.',\n examples: ['gcd(8, 12)', 'gcd(-4, 6)', 'gcd(25, 15, -10)'],\n seealso: ['lcm', 'xgcd']\n};\nexports.gcdDocs = gcdDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hypotDocs = void 0;\nvar hypotDocs = {\n name: 'hypot',\n category: 'Arithmetic',\n syntax: ['hypot(a, b, c, ...)', 'hypot([a, b, c, ...])'],\n description: 'Calculate the hypotenusa of a list with values. ',\n examples: ['hypot(3, 4)', 'sqrt(3^2 + 4^2)', 'hypot(-2)', 'hypot([3, 4, 5])'],\n seealso: ['abs', 'norm']\n};\nexports.hypotDocs = hypotDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.invmodDocs = void 0;\nvar invmodDocs = {\n name: 'invmod',\n category: 'Arithmetic',\n syntax: ['invmod(a, b)'],\n description: 'Calculate the (modular) multiplicative inverse of a modulo b. Solution to the equation ax ≣ 1 (mod b)',\n examples: ['invmod(8, 12)=NaN', 'invmod(7, 13)=2', 'math.invmod(15151, 15122)=10429'],\n seealso: ['gcd', 'xgcd']\n};\nexports.invmodDocs = invmodDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lcmDocs = void 0;\nvar lcmDocs = {\n name: 'lcm',\n category: 'Arithmetic',\n syntax: ['lcm(x, y)'],\n description: 'Compute the least common multiple.',\n examples: ['lcm(4, 6)', 'lcm(6, 21)', 'lcm(6, 21, 5)'],\n seealso: ['gcd']\n};\nexports.lcmDocs = lcmDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.logDocs = void 0;\nvar logDocs = {\n name: 'log',\n category: 'Arithmetic',\n syntax: ['log(x)', 'log(x, base)'],\n description: 'Compute the logarithm of a value. If no base is provided, the natural logarithm of x is calculated. If base if provided, the logarithm is calculated for the specified base. log(x, base) is defined as log(x) / log(base).',\n examples: ['log(3.5)', 'a = log(2.4)', 'exp(a)', '10 ^ 4', 'log(10000, 10)', 'log(10000) / log(10)', 'b = log(1024, 2)', '2 ^ b'],\n seealso: ['exp', 'log1p', 'log2', 'log10']\n};\nexports.logDocs = logDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.log10Docs = void 0;\nvar log10Docs = {\n name: 'log10',\n category: 'Arithmetic',\n syntax: ['log10(x)'],\n description: 'Compute the 10-base logarithm of a value.',\n examples: ['log10(0.00001)', 'log10(10000)', '10 ^ 4', 'log(10000) / log(10)', 'log(10000, 10)'],\n seealso: ['exp', 'log']\n};\nexports.log10Docs = log10Docs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.log1pDocs = void 0;\nvar log1pDocs = {\n name: 'log1p',\n category: 'Arithmetic',\n syntax: ['log1p(x)', 'log1p(x, base)'],\n description: 'Calculate the logarithm of a `value+1`',\n examples: ['log1p(2.5)', 'exp(log1p(1.4))', 'pow(10, 4)', 'log1p(9999, 10)', 'log1p(9999) / log(10)'],\n seealso: ['exp', 'log', 'log2', 'log10']\n};\nexports.log1pDocs = log1pDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.log2Docs = void 0;\nvar log2Docs = {\n name: 'log2',\n category: 'Arithmetic',\n syntax: ['log2(x)'],\n description: 'Calculate the 2-base of a value. This is the same as calculating `log(x, 2)`.',\n examples: ['log2(0.03125)', 'log2(16)', 'log2(16) / log2(2)', 'pow(2, 4)'],\n seealso: ['exp', 'log1p', 'log', 'log10']\n};\nexports.log2Docs = log2Docs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.modDocs = void 0;\nvar modDocs = {\n name: 'mod',\n category: 'Operators',\n syntax: ['x % y', 'x mod y', 'mod(x, y)'],\n description: 'Calculates the modulus, the remainder of an integer division.',\n examples: ['7 % 3', '11 % 2', '10 mod 4', 'isOdd(x) = x % 2', 'isOdd(2)', 'isOdd(3)'],\n seealso: ['divide']\n};\nexports.modDocs = modDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.multiplyDocs = void 0;\nvar multiplyDocs = {\n name: 'multiply',\n category: 'Operators',\n syntax: ['x * y', 'multiply(x, y)'],\n description: 'multiply two values.',\n examples: ['a = 2.1 * 3.4', 'a / 3.4', '2 * 3 + 4', '2 * (3 + 4)', '3 * 2.1 km'],\n seealso: ['divide']\n};\nexports.multiplyDocs = multiplyDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.normDocs = void 0;\nvar normDocs = {\n name: 'norm',\n category: 'Arithmetic',\n syntax: ['norm(x)', 'norm(x, p)'],\n description: 'Calculate the norm of a number, vector or matrix.',\n examples: ['abs(-3.5)', 'norm(-3.5)', 'norm(3 - 4i)', 'norm([1, 2, -3], Infinity)', 'norm([1, 2, -3], -Infinity)', 'norm([3, 4], 2)', 'norm([[1, 2], [3, 4]], 1)', 'norm([[1, 2], [3, 4]], \"inf\")', 'norm([[1, 2], [3, 4]], \"fro\")']\n};\nexports.normDocs = normDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.nthRootDocs = void 0;\nvar nthRootDocs = {\n name: 'nthRoot',\n category: 'Arithmetic',\n syntax: ['nthRoot(a)', 'nthRoot(a, root)'],\n description: 'Calculate the nth root of a value. ' + 'The principal nth root of a positive real number A, ' + 'is the positive real solution of the equation \"x^root = A\".',\n examples: ['4 ^ 3', 'nthRoot(64, 3)', 'nthRoot(9, 2)', 'sqrt(9)'],\n seealso: ['nthRoots', 'pow', 'sqrt']\n};\nexports.nthRootDocs = nthRootDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.nthRootsDocs = void 0;\nvar nthRootsDocs = {\n name: 'nthRoots',\n category: 'Arithmetic',\n syntax: ['nthRoots(A)', 'nthRoots(A, root)'],\n description: '' + 'Calculate the nth roots of a value. ' + 'An nth root of a positive real number A, ' + 'is a positive real solution of the equation \"x^root = A\". ' + 'This function returns an array of complex values.',\n examples: ['nthRoots(1)', 'nthRoots(1, 3)'],\n seealso: ['sqrt', 'pow', 'nthRoot']\n};\nexports.nthRootsDocs = nthRootsDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.powDocs = void 0;\nvar powDocs = {\n name: 'pow',\n category: 'Operators',\n syntax: ['x ^ y', 'pow(x, y)'],\n description: 'Calculates the power of x to y, x^y.',\n examples: ['2^3', '2*2*2', '1 + e ^ (pi * i)', 'math.pow([[1, 2], [4, 3]], 2)', 'math.pow([[1, 2], [4, 3]], -1)'],\n seealso: ['multiply', 'nthRoot', 'nthRoots', 'sqrt']\n};\nexports.powDocs = powDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.roundDocs = void 0;\nvar roundDocs = {\n name: 'round',\n category: 'Arithmetic',\n syntax: ['round(x)', 'round(x, n)'],\n description: 'round a value towards the nearest integer.If x is complex, both real and imaginary part are rounded towards the nearest integer. When n is specified, the value is rounded to n decimals.',\n examples: ['round(3.2)', 'round(3.8)', 'round(-4.2)', 'round(-4.8)', 'round(pi, 3)', 'round(123.45678, 2)'],\n seealso: ['ceil', 'floor', 'fix']\n};\nexports.roundDocs = roundDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.signDocs = void 0;\nvar signDocs = {\n name: 'sign',\n category: 'Arithmetic',\n syntax: ['sign(x)'],\n description: 'Compute the sign of a value. The sign of a value x is 1 when x>1, -1 when x<0, and 0 when x=0.',\n examples: ['sign(3.5)', 'sign(-4.2)', 'sign(0)'],\n seealso: ['abs']\n};\nexports.signDocs = signDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sqrtDocs = void 0;\nvar sqrtDocs = {\n name: 'sqrt',\n category: 'Arithmetic',\n syntax: ['sqrt(x)'],\n description: 'Compute the square root value. If x = y * y, then y is the square root of x.',\n examples: ['sqrt(25)', '5 * 5', 'sqrt(-1)'],\n seealso: ['square', 'sqrtm', 'multiply', 'nthRoot', 'nthRoots', 'pow']\n};\nexports.sqrtDocs = sqrtDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sqrtmDocs = void 0;\nvar sqrtmDocs = {\n name: 'sqrtm',\n category: 'Arithmetic',\n syntax: ['sqrtm(x)'],\n description: 'Calculate the principal square root of a square matrix. The principal square root matrix `X` of another matrix `A` is such that `X * X = A`.',\n examples: ['sqrtm([[1, 2], [3, 4]])'],\n seealso: ['sqrt', 'abs', 'square', 'multiply']\n};\nexports.sqrtmDocs = sqrtmDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.squareDocs = void 0;\nvar squareDocs = {\n name: 'square',\n category: 'Arithmetic',\n syntax: ['square(x)'],\n description: 'Compute the square of a value. The square of x is x * x.',\n examples: ['square(3)', 'sqrt(9)', '3^2', '3 * 3'],\n seealso: ['multiply', 'pow', 'sqrt', 'cube']\n};\nexports.squareDocs = squareDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.subtractDocs = void 0;\nvar subtractDocs = {\n name: 'subtract',\n category: 'Operators',\n syntax: ['x - y', 'subtract(x, y)'],\n description: 'subtract two values.',\n examples: ['a = 5.3 - 2', 'a + 2', '2/3 - 1/6', '2 * 3 - 3', '2.1 km - 500m'],\n seealso: ['add']\n};\nexports.subtractDocs = subtractDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.unaryMinusDocs = void 0;\nvar unaryMinusDocs = {\n name: 'unaryMinus',\n category: 'Operators',\n syntax: ['-x', 'unaryMinus(x)'],\n description: 'Inverse the sign of a value. Converts booleans and strings to numbers.',\n examples: ['-4.5', '-(-5.6)', '-\"22\"'],\n seealso: ['add', 'subtract', 'unaryPlus']\n};\nexports.unaryMinusDocs = unaryMinusDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.unaryPlusDocs = void 0;\nvar unaryPlusDocs = {\n name: 'unaryPlus',\n category: 'Operators',\n syntax: ['+x', 'unaryPlus(x)'],\n description: 'Converts booleans and strings to numbers.',\n examples: ['+true', '+\"2\"'],\n seealso: ['add', 'subtract', 'unaryMinus']\n};\nexports.unaryPlusDocs = unaryPlusDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.xgcdDocs = void 0;\nvar xgcdDocs = {\n name: 'xgcd',\n category: 'Arithmetic',\n syntax: ['xgcd(a, b)'],\n description: 'Calculate the extended greatest common divisor for two values. The result is an array [d, x, y] with 3 entries, where d is the greatest common divisor, and d = x * a + y * b.',\n examples: ['xgcd(8, 12)', 'gcd(8, 12)', 'xgcd(36163, 21199)'],\n seealso: ['gcd', 'lcm']\n};\nexports.xgcdDocs = xgcdDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bitAndDocs = void 0;\nvar bitAndDocs = {\n name: 'bitAnd',\n category: 'Bitwise',\n syntax: ['x & y', 'bitAnd(x, y)'],\n description: 'Bitwise AND operation. Performs the logical AND operation on each pair of the corresponding bits of the two given values by multiplying them. If both bits in the compared position are 1, the bit in the resulting binary representation is 1, otherwise, the result is 0',\n examples: ['5 & 3', 'bitAnd(53, 131)', '[1, 12, 31] & 42'],\n seealso: ['bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift']\n};\nexports.bitAndDocs = bitAndDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bitNotDocs = void 0;\nvar bitNotDocs = {\n name: 'bitNot',\n category: 'Bitwise',\n syntax: ['~x', 'bitNot(x)'],\n description: 'Bitwise NOT operation. Performs a logical negation on each bit of the given value. Bits that are 0 become 1, and those that are 1 become 0.',\n examples: ['~1', '~2', 'bitNot([2, -3, 4])'],\n seealso: ['bitAnd', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift']\n};\nexports.bitNotDocs = bitNotDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bitOrDocs = void 0;\nvar bitOrDocs = {\n name: 'bitOr',\n category: 'Bitwise',\n syntax: ['x | y', 'bitOr(x, y)'],\n description: 'Bitwise OR operation. Performs the logical inclusive OR operation on each pair of corresponding bits of the two given values. The result in each position is 1 if the first bit is 1 or the second bit is 1 or both bits are 1, otherwise, the result is 0.',\n examples: ['5 | 3', 'bitOr([1, 2, 3], 4)'],\n seealso: ['bitAnd', 'bitNot', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift']\n};\nexports.bitOrDocs = bitOrDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bitXorDocs = void 0;\nvar bitXorDocs = {\n name: 'bitXor',\n category: 'Bitwise',\n syntax: ['bitXor(x, y)'],\n description: 'Bitwise XOR operation, exclusive OR. Performs the logical exclusive OR operation on each pair of corresponding bits of the two given values. The result in each position is 1 if only the first bit is 1 or only the second bit is 1, but will be 0 if both are 0 or both are 1.',\n examples: ['bitOr(1, 2)', 'bitXor([2, 3, 4], 4)'],\n seealso: ['bitAnd', 'bitNot', 'bitOr', 'leftShift', 'rightArithShift', 'rightLogShift']\n};\nexports.bitXorDocs = bitXorDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.leftShiftDocs = void 0;\nvar leftShiftDocs = {\n name: 'leftShift',\n category: 'Bitwise',\n syntax: ['x << y', 'leftShift(x, y)'],\n description: 'Bitwise left logical shift of a value x by y number of bits.',\n examples: ['4 << 1', '8 >> 1'],\n seealso: ['bitAnd', 'bitNot', 'bitOr', 'bitXor', 'rightArithShift', 'rightLogShift']\n};\nexports.leftShiftDocs = leftShiftDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rightArithShiftDocs = void 0;\nvar rightArithShiftDocs = {\n name: 'rightArithShift',\n category: 'Bitwise',\n syntax: ['x >> y', 'rightArithShift(x, y)'],\n description: 'Bitwise right arithmetic shift of a value x by y number of bits.',\n examples: ['8 >> 1', '4 << 1', '-12 >> 2'],\n seealso: ['bitAnd', 'bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightLogShift']\n};\nexports.rightArithShiftDocs = rightArithShiftDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rightLogShiftDocs = void 0;\nvar rightLogShiftDocs = {\n name: 'rightLogShift',\n category: 'Bitwise',\n syntax: ['x >>> y', 'rightLogShift(x, y)'],\n description: 'Bitwise right logical shift of a value x by y number of bits.',\n examples: ['8 >>> 1', '4 << 1', '-12 >>> 2'],\n seealso: ['bitAnd', 'bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift']\n};\nexports.rightLogShiftDocs = rightLogShiftDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bellNumbersDocs = void 0;\nvar bellNumbersDocs = {\n name: 'bellNumbers',\n category: 'Combinatorics',\n syntax: ['bellNumbers(n)'],\n description: 'The Bell Numbers count the number of partitions of a set. A partition is a pairwise disjoint subset of S whose union is S. `bellNumbers` only takes integer arguments. The following condition must be enforced: n >= 0.',\n examples: ['bellNumbers(3)', 'bellNumbers(8)'],\n seealso: ['stirlingS2']\n};\nexports.bellNumbersDocs = bellNumbersDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.catalanDocs = void 0;\nvar catalanDocs = {\n name: 'catalan',\n category: 'Combinatorics',\n syntax: ['catalan(n)'],\n description: 'The Catalan Numbers enumerate combinatorial structures of many different types. catalan only takes integer arguments. The following condition must be enforced: n >= 0.',\n examples: ['catalan(3)', 'catalan(8)'],\n seealso: ['bellNumbers']\n};\nexports.catalanDocs = catalanDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.compositionDocs = void 0;\nvar compositionDocs = {\n name: 'composition',\n category: 'Combinatorics',\n syntax: ['composition(n, k)'],\n description: 'The composition counts of n into k parts. composition only takes integer arguments. The following condition must be enforced: k <= n.',\n examples: ['composition(5, 3)'],\n seealso: ['combinations']\n};\nexports.compositionDocs = compositionDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.stirlingS2Docs = void 0;\nvar stirlingS2Docs = {\n name: 'stirlingS2',\n category: 'Combinatorics',\n syntax: ['stirlingS2(n, k)'],\n description: 'he Stirling numbers of the second kind, counts the number of ways to partition a set of n labelled objects into k nonempty unlabelled subsets. `stirlingS2` only takes integer arguments. The following condition must be enforced: k <= n. If n = k or k = 1, then s(n,k) = 1.',\n examples: ['stirlingS2(5, 3)'],\n seealso: ['bellNumbers']\n};\nexports.stirlingS2Docs = stirlingS2Docs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.argDocs = void 0;\nvar argDocs = {\n name: 'arg',\n category: 'Complex',\n syntax: ['arg(x)'],\n description: 'Compute the argument of a complex value. If x = a+bi, the argument is computed as atan2(b, a).',\n examples: ['arg(2 + 2i)', 'atan2(3, 2)', 'arg(2 + 3i)'],\n seealso: ['re', 'im', 'conj', 'abs']\n};\nexports.argDocs = argDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.conjDocs = void 0;\nvar conjDocs = {\n name: 'conj',\n category: 'Complex',\n syntax: ['conj(x)'],\n description: 'Compute the complex conjugate of a complex value. If x = a+bi, the complex conjugate is a-bi.',\n examples: ['conj(2 + 3i)', 'conj(2 - 3i)', 'conj(-5.2i)'],\n seealso: ['re', 'im', 'abs', 'arg']\n};\nexports.conjDocs = conjDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.imDocs = void 0;\nvar imDocs = {\n name: 'im',\n category: 'Complex',\n syntax: ['im(x)'],\n description: 'Get the imaginary part of a complex number.',\n examples: ['im(2 + 3i)', 're(2 + 3i)', 'im(-5.2i)', 'im(2.4)'],\n seealso: ['re', 'conj', 'abs', 'arg']\n};\nexports.imDocs = imDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.reDocs = void 0;\nvar reDocs = {\n name: 're',\n category: 'Complex',\n syntax: ['re(x)'],\n description: 'Get the real part of a complex number.',\n examples: ['re(2 + 3i)', 'im(2 + 3i)', 're(-5.2i)', 're(2.4)'],\n seealso: ['im', 'conj', 'abs', 'arg']\n};\nexports.reDocs = reDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.evaluateDocs = void 0;\nvar evaluateDocs = {\n name: 'evaluate',\n category: 'Expression',\n syntax: ['evaluate(expression)', 'evaluate([expr1, expr2, expr3, ...])'],\n description: 'Evaluate an expression or an array with expressions.',\n examples: ['evaluate(\"2 + 3\")', 'evaluate(\"sqrt(\" + 4 + \")\")'],\n seealso: []\n};\nexports.evaluateDocs = evaluateDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.helpDocs = void 0;\nvar helpDocs = {\n name: 'help',\n category: 'Expression',\n syntax: ['help(object)', 'help(string)'],\n description: 'Display documentation on a function or data type.',\n examples: ['help(sqrt)', 'help(\"complex\")'],\n seealso: []\n};\nexports.helpDocs = helpDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.distanceDocs = void 0;\nvar distanceDocs = {\n name: 'distance',\n category: 'Geometry',\n syntax: ['distance([x1, y1], [x2, y2])', 'distance([[x1, y1], [x2, y2]])'],\n description: 'Calculates the Euclidean distance between two points.',\n examples: ['distance([0,0], [4,4])', 'distance([[0,0], [4,4]])'],\n seealso: []\n};\nexports.distanceDocs = distanceDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.intersectDocs = void 0;\nvar intersectDocs = {\n name: 'intersect',\n category: 'Geometry',\n syntax: ['intersect(expr1, expr2, expr3, expr4)', 'intersect(expr1, expr2, expr3)'],\n description: 'Computes the intersection point of lines and/or planes.',\n examples: ['intersect([0, 0], [10, 10], [10, 0], [0, 10])', 'intersect([1, 0, 1], [4, -2, 2], [1, 1, 1, 6])'],\n seealso: []\n};\nexports.intersectDocs = intersectDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.andDocs = void 0;\nvar andDocs = {\n name: 'and',\n category: 'Logical',\n syntax: ['x and y', 'and(x, y)'],\n description: 'Logical and. Test whether two values are both defined with a nonzero/nonempty value.',\n examples: ['true and false', 'true and true', '2 and 4'],\n seealso: ['not', 'or', 'xor']\n};\nexports.andDocs = andDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.notDocs = void 0;\nvar notDocs = {\n name: 'not',\n category: 'Logical',\n syntax: ['not x', 'not(x)'],\n description: 'Logical not. Flips the boolean value of given argument.',\n examples: ['not true', 'not false', 'not 2', 'not 0'],\n seealso: ['and', 'or', 'xor']\n};\nexports.notDocs = notDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.orDocs = void 0;\nvar orDocs = {\n name: 'or',\n category: 'Logical',\n syntax: ['x or y', 'or(x, y)'],\n description: 'Logical or. Test if at least one value is defined with a nonzero/nonempty value.',\n examples: ['true or false', 'false or false', '0 or 4'],\n seealso: ['not', 'and', 'xor']\n};\nexports.orDocs = orDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.xorDocs = void 0;\nvar xorDocs = {\n name: 'xor',\n category: 'Logical',\n syntax: ['x xor y', 'xor(x, y)'],\n description: 'Logical exclusive or, xor. Test whether one and only one value is defined with a nonzero/nonempty value.',\n examples: ['true xor false', 'false xor false', 'true xor true', '0 xor 4'],\n seealso: ['not', 'and', 'or']\n};\nexports.xorDocs = xorDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.columnDocs = void 0;\nvar columnDocs = {\n name: 'column',\n category: 'Matrix',\n syntax: ['column(x, index)'],\n description: 'Return a column from a matrix or array.',\n examples: ['A = [[1, 2], [3, 4]]', 'column(A, 1)', 'column(A, 2)'],\n seealso: ['row', 'matrixFromColumns']\n};\nexports.columnDocs = columnDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.concatDocs = void 0;\nvar concatDocs = {\n name: 'concat',\n category: 'Matrix',\n syntax: ['concat(A, B, C, ...)', 'concat(A, B, C, ..., dim)'],\n description: 'Concatenate matrices. By default, the matrices are concatenated by the last dimension. The dimension on which to concatenate can be provided as last argument.',\n examples: ['A = [1, 2; 5, 6]', 'B = [3, 4; 7, 8]', 'concat(A, B)', 'concat(A, B, 1)', 'concat(A, B, 2)'],\n seealso: ['det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros']\n};\nexports.concatDocs = concatDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.countDocs = void 0;\nvar countDocs = {\n name: 'count',\n category: 'Matrix',\n syntax: ['count(x)'],\n description: 'Count the number of elements of a matrix, array or string.',\n examples: ['a = [1, 2; 3, 4; 5, 6]', 'count(a)', 'size(a)', 'count(\"hello world\")'],\n seealso: ['size']\n};\nexports.countDocs = countDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.crossDocs = void 0;\nvar crossDocs = {\n name: 'cross',\n category: 'Matrix',\n syntax: ['cross(A, B)'],\n description: 'Calculate the cross product for two vectors in three dimensional space.',\n examples: ['cross([1, 1, 0], [0, 1, 1])', 'cross([3, -3, 1], [4, 9, 2])', 'cross([2, 3, 4], [5, 6, 7])'],\n seealso: ['multiply', 'dot']\n};\nexports.crossDocs = crossDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ctransposeDocs = void 0;\nvar ctransposeDocs = {\n name: 'ctranspose',\n category: 'Matrix',\n syntax: ['x\\'', 'ctranspose(x)'],\n description: 'Complex Conjugate and Transpose a matrix',\n examples: ['a = [1, 2, 3; 4, 5, 6]', 'a\\'', 'ctranspose(a)'],\n seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'zeros']\n};\nexports.ctransposeDocs = ctransposeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.detDocs = void 0;\nvar detDocs = {\n name: 'det',\n category: 'Matrix',\n syntax: ['det(x)'],\n description: 'Calculate the determinant of a matrix',\n examples: ['det([1, 2; 3, 4])', 'det([-2, 2, 3; -1, 1, 3; 2, 0, -1])'],\n seealso: ['concat', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros']\n};\nexports.detDocs = detDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.diagDocs = void 0;\nvar diagDocs = {\n name: 'diag',\n category: 'Matrix',\n syntax: ['diag(x)', 'diag(x, k)'],\n description: 'Create a diagonal matrix or retrieve the diagonal of a matrix. When x is a vector, a matrix with the vector values on the diagonal will be returned. When x is a matrix, a vector with the diagonal values of the matrix is returned. When k is provided, the k-th diagonal will be filled in or retrieved, if k is positive, the values are placed on the super diagonal. When k is negative, the values are placed on the sub diagonal.',\n examples: ['diag(1:3)', 'diag(1:3, 1)', 'a = [1, 2, 3; 4, 5, 6; 7, 8, 9]', 'diag(a)'],\n seealso: ['concat', 'det', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros']\n};\nexports.diagDocs = diagDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.diffDocs = void 0;\nvar diffDocs = {\n name: 'diff',\n category: 'Matrix',\n syntax: ['diff(arr)', 'diff(arr, dim)'],\n description: ['Create a new matrix or array with the difference of the passed matrix or array.', 'Dim parameter is optional and used to indicant the dimension of the array/matrix to apply the difference', 'If no dimension parameter is passed it is assumed as dimension 0', 'Dimension is zero-based in javascript and one-based in the parser', 'Arrays must be \\'rectangular\\' meaning arrays like [1, 2]', 'If something is passed as a matrix it will be returned as a matrix but other than that all matrices are converted to arrays'],\n examples: ['diff([1, 2, 4, 7, 0])', 'diff([1, 2, 4, 7, 0], 0)', 'diff(matrix([1, 2, 4, 7, 0]))', 'diff([[1, 2], [3, 4]])', 'diff([[1, 2], [3, 4]], 0)', 'diff([[1, 2], [3, 4]], 1)', 'diff([[1, 2], [3, 4]], bignumber(1))', 'diff(matrix([[1, 2], [3, 4]]), 1)', 'diff([[1, 2], matrix([3, 4])], 1)'],\n seealso: ['subtract', 'partitionSelect']\n};\nexports.diffDocs = diffDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.dotDocs = void 0;\nvar dotDocs = {\n name: 'dot',\n category: 'Matrix',\n syntax: ['dot(A, B)', 'A * B'],\n description: 'Calculate the dot product of two vectors. ' + 'The dot product of A = [a1, a2, a3, ..., an] and B = [b1, b2, b3, ..., bn] ' + 'is defined as dot(A, B) = a1 * b1 + a2 * b2 + a3 * b3 + ... + an * bn',\n examples: ['dot([2, 4, 1], [2, 2, 3])', '[2, 4, 1] * [2, 2, 3]'],\n seealso: ['multiply', 'cross']\n};\nexports.dotDocs = dotDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.eigsDocs = void 0;\nvar eigsDocs = {\n name: 'eigs',\n category: 'Matrix',\n syntax: ['eigs(x)'],\n description: 'Calculate the eigenvalues and eigenvectors of a real symmetric matrix',\n examples: ['eigs([[5, 2.3], [2.3, 1]])'],\n seealso: ['inv']\n};\nexports.eigsDocs = eigsDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.fftDocs = void 0;\nvar fftDocs = {\n name: 'fft',\n category: 'Matrix',\n syntax: ['fft(x)'],\n description: 'Calculate N-dimensional fourier transform',\n examples: ['fft([[1, 0], [1, 0]])'],\n seealso: ['ifft']\n};\nexports.fftDocs = fftDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.filterDocs = void 0;\nvar filterDocs = {\n name: 'filter',\n category: 'Matrix',\n syntax: ['filter(x, test)'],\n description: 'Filter items in a matrix.',\n examples: ['isPositive(x) = x > 0', 'filter([6, -2, -1, 4, 3], isPositive)', 'filter([6, -2, 0, 1, 0], x != 0)'],\n seealso: ['sort', 'map', 'forEach']\n};\nexports.filterDocs = filterDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.flattenDocs = void 0;\nvar flattenDocs = {\n name: 'flatten',\n category: 'Matrix',\n syntax: ['flatten(x)'],\n description: 'Flatten a multi dimensional matrix into a single dimensional matrix.',\n examples: ['a = [1, 2, 3; 4, 5, 6]', 'size(a)', 'b = flatten(a)', 'size(b)'],\n seealso: ['concat', 'resize', 'size', 'squeeze']\n};\nexports.flattenDocs = flattenDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.forEachDocs = void 0;\nvar forEachDocs = {\n name: 'forEach',\n category: 'Matrix',\n syntax: ['forEach(x, callback)'],\n description: 'Iterates over all elements of a matrix/array, and executes the given callback function.',\n examples: ['numberOfPets = {}', 'addPet(n) = numberOfPets[n] = (numberOfPets[n] ? numberOfPets[n]:0 ) + 1;', 'forEach([\"Dog\",\"Cat\",\"Cat\"], addPet)', 'numberOfPets'],\n seealso: ['map', 'sort', 'filter']\n};\nexports.forEachDocs = forEachDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getMatrixDataTypeDocs = void 0;\nvar getMatrixDataTypeDocs = {\n name: 'getMatrixDataType',\n category: 'Matrix',\n syntax: ['getMatrixDataType(x)'],\n description: 'Find the data type of all elements in a matrix or array, ' + 'for example \"number\" if all items are a number ' + 'and \"Complex\" if all values are complex numbers. ' + 'If a matrix contains more than one data type, it will return \"mixed\".',\n examples: ['getMatrixDataType([1, 2, 3])', 'getMatrixDataType([[5 cm], [2 inch]])', 'getMatrixDataType([1, \"text\"])', 'getMatrixDataType([1, bignumber(4)])'],\n seealso: ['matrix', 'sparse', 'typeOf']\n};\nexports.getMatrixDataTypeDocs = getMatrixDataTypeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.identityDocs = void 0;\nvar identityDocs = {\n name: 'identity',\n category: 'Matrix',\n syntax: ['identity(n)', 'identity(m, n)', 'identity([m, n])'],\n description: 'Returns the identity matrix with size m-by-n. The matrix has ones on the diagonal and zeros elsewhere.',\n examples: ['identity(3)', 'identity(3, 5)', 'a = [1, 2, 3; 4, 5, 6]', 'identity(size(a))'],\n seealso: ['concat', 'det', 'diag', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros']\n};\nexports.identityDocs = identityDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ifftDocs = void 0;\nvar ifftDocs = {\n name: 'ifft',\n category: 'Matrix',\n syntax: ['ifft(x)'],\n description: 'Calculate N-dimensional inverse fourier transform',\n examples: ['ifft([[2, 2], [0, 0]])'],\n seealso: ['fft']\n};\nexports.ifftDocs = ifftDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.invDocs = void 0;\nvar invDocs = {\n name: 'inv',\n category: 'Matrix',\n syntax: ['inv(x)'],\n description: 'Calculate the inverse of a matrix',\n examples: ['inv([1, 2; 3, 4])', 'inv(4)', '1 / 4'],\n seealso: ['concat', 'det', 'diag', 'identity', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros']\n};\nexports.invDocs = invDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.kronDocs = void 0;\nvar kronDocs = {\n name: 'kron',\n category: 'Matrix',\n syntax: ['kron(x, y)'],\n description: 'Calculates the kronecker product of 2 matrices or vectors.',\n examples: ['kron([[1, 0], [0, 1]], [[1, 2], [3, 4]])', 'kron([1,1], [2,3,4])'],\n seealso: ['multiply', 'dot', 'cross']\n};\nexports.kronDocs = kronDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.mapDocs = void 0;\nvar mapDocs = {\n name: 'map',\n category: 'Matrix',\n syntax: ['map(x, callback)'],\n description: 'Create a new matrix or array with the results of the callback function executed on each entry of the matrix/array.',\n examples: ['map([1, 2, 3], square)'],\n seealso: ['filter', 'forEach']\n};\nexports.mapDocs = mapDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.matrixFromColumnsDocs = void 0;\nvar matrixFromColumnsDocs = {\n name: 'matrixFromColumns',\n category: 'Matrix',\n syntax: ['math.matrixFromColumns(...arr)', 'math.matrixFromColumns(row1, row2)', 'math.matrixFromColumns(row1, row2, row3)'],\n description: 'Create a dense matrix from vectors as individual columns.',\n examples: ['matrixFromColumns([1, 2, 3], [[4],[5],[6]])'],\n seealso: ['matrix', 'matrixFromRows', 'matrixFromFunction', 'zeros']\n};\nexports.matrixFromColumnsDocs = matrixFromColumnsDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.matrixFromFunctionDocs = void 0;\nvar matrixFromFunctionDocs = {\n name: 'matrixFromFunction',\n category: 'Matrix',\n syntax: ['math.matrixFromFunction(size, fn)', 'math.matrixFromFunction(size, fn, format)', 'math.matrixFromFunction(size, fn, format, datatype)', 'math.matrixFromFunction(size, format, fn)', 'math.matrixFromFunction(size, format, datatype, fn)'],\n description: 'Create a matrix by evaluating a generating function at each index.',\n examples: ['f(I) = I[1] - I[2]', 'matrixFromFunction([3,3], f)', 'g(I) = I[1] - I[2] == 1 ? 4 : 0', 'matrixFromFunction([100, 100], \"sparse\", g)', 'matrixFromFunction([5], random)'],\n seealso: ['matrix', 'matrixFromRows', 'matrixFromColumns', 'zeros']\n};\nexports.matrixFromFunctionDocs = matrixFromFunctionDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.matrixFromRowsDocs = void 0;\nvar matrixFromRowsDocs = {\n name: 'matrixFromRows',\n category: 'Matrix',\n syntax: ['math.matrixFromRows(...arr)', 'math.matrixFromRows(row1, row2)', 'math.matrixFromRows(row1, row2, row3)'],\n description: 'Create a dense matrix from vectors as individual rows.',\n examples: ['matrixFromRows([1, 2, 3], [[4],[5],[6]])'],\n seealso: ['matrix', 'matrixFromColumns', 'matrixFromFunction', 'zeros']\n};\nexports.matrixFromRowsDocs = matrixFromRowsDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.onesDocs = void 0;\nvar onesDocs = {\n name: 'ones',\n category: 'Matrix',\n syntax: ['ones(m)', 'ones(m, n)', 'ones(m, n, p, ...)', 'ones([m])', 'ones([m, n])', 'ones([m, n, p, ...])'],\n description: 'Create a matrix containing ones.',\n examples: ['ones(3)', 'ones(3, 5)', 'ones([2,3]) * 4.5', 'a = [1, 2, 3; 4, 5, 6]', 'ones(size(a))'],\n seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros']\n};\nexports.onesDocs = onesDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.partitionSelectDocs = void 0;\nvar partitionSelectDocs = {\n name: 'partitionSelect',\n category: 'Matrix',\n syntax: ['partitionSelect(x, k)', 'partitionSelect(x, k, compare)'],\n description: 'Partition-based selection of an array or 1D matrix. Will find the kth smallest value, and mutates the input array. Uses Quickselect.',\n examples: ['partitionSelect([5, 10, 1], 2)', 'partitionSelect([\"C\", \"B\", \"A\", \"D\"], 1)'],\n seealso: ['sort']\n};\nexports.partitionSelectDocs = partitionSelectDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.pinvDocs = void 0;\nvar pinvDocs = {\n name: 'pinv',\n category: 'Matrix',\n syntax: ['pinv(x)'],\n description: 'Calculate the Moore–Penrose inverse of a matrix',\n examples: ['pinv([1, 2; 3, 4])', 'pinv([[1, 0], [0, 1], [0, 1]])', 'pinv(4)'],\n seealso: ['inv']\n};\nexports.pinvDocs = pinvDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rangeDocs = void 0;\nvar rangeDocs = {\n name: 'range',\n category: 'Type',\n syntax: ['start:end', 'start:step:end', 'range(start, end)', 'range(start, end, step)', 'range(string)'],\n description: 'Create a range. Lower bound of the range is included, upper bound is excluded.',\n examples: ['1:5', '3:-1:-3', 'range(3, 7)', 'range(0, 12, 2)', 'range(\"4:10\")', 'a = [1, 2, 3, 4; 5, 6, 7, 8]', 'a[1:2, 1:2]'],\n seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros']\n};\nexports.rangeDocs = rangeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.reshapeDocs = void 0;\nvar reshapeDocs = {\n name: 'reshape',\n category: 'Matrix',\n syntax: ['reshape(x, sizes)'],\n description: 'Reshape a multi dimensional array to fit the specified dimensions.',\n examples: ['reshape([1, 2, 3, 4, 5, 6], [2, 3])', 'reshape([[1, 2], [3, 4]], [1, 4])', 'reshape([[1, 2], [3, 4]], [4])'],\n seealso: ['size', 'squeeze', 'resize']\n};\nexports.reshapeDocs = reshapeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.resizeDocs = void 0;\nvar resizeDocs = {\n name: 'resize',\n category: 'Matrix',\n syntax: ['resize(x, size)', 'resize(x, size, defaultValue)'],\n description: 'Resize a matrix.',\n examples: ['resize([1,2,3,4,5], [3])', 'resize([1,2,3], [5])', 'resize([1,2,3], [5], -1)', 'resize(2, [2, 3])', 'resize(\"hello\", [8], \"!\")'],\n seealso: ['size', 'subset', 'squeeze', 'reshape']\n};\nexports.resizeDocs = resizeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rotateDocs = void 0;\nvar rotateDocs = {\n name: 'rotate',\n category: 'Matrix',\n syntax: ['rotate(w, theta)', 'rotate(w, theta, v)'],\n description: 'Returns a 2-D rotation matrix (2x2) for a given angle (in radians). ' + 'Returns a 2-D rotation matrix (3x3) of a given angle (in radians) around given axis.',\n examples: ['rotate([1, 0], math.pi / 2)', 'rotate(matrix([1, 0]), unit(\"35deg\"))', 'rotate([1, 0, 0], unit(\"90deg\"), [0, 0, 1])', 'rotate(matrix([1, 0, 0]), unit(\"90deg\"), matrix([0, 0, 1]))'],\n seealso: ['matrix', 'rotationMatrix']\n};\nexports.rotateDocs = rotateDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rotationMatrixDocs = void 0;\nvar rotationMatrixDocs = {\n name: 'rotationMatrix',\n category: 'Matrix',\n syntax: ['rotationMatrix(theta)', 'rotationMatrix(theta, v)', 'rotationMatrix(theta, v, format)'],\n description: 'Returns a 2-D rotation matrix (2x2) for a given angle (in radians). ' + 'Returns a 2-D rotation matrix (3x3) of a given angle (in radians) around given axis.',\n examples: ['rotationMatrix(pi / 2)', 'rotationMatrix(unit(\"45deg\"), [0, 0, 1])', 'rotationMatrix(1, matrix([0, 0, 1]), \"sparse\")'],\n seealso: ['cos', 'sin']\n};\nexports.rotationMatrixDocs = rotationMatrixDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rowDocs = void 0;\nvar rowDocs = {\n name: 'row',\n category: 'Matrix',\n syntax: ['row(x, index)'],\n description: 'Return a row from a matrix or array.',\n examples: ['A = [[1, 2], [3, 4]]', 'row(A, 1)', 'row(A, 2)'],\n seealso: ['column', 'matrixFromRows']\n};\nexports.rowDocs = rowDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sizeDocs = void 0;\nvar sizeDocs = {\n name: 'size',\n category: 'Matrix',\n syntax: ['size(x)'],\n description: 'Calculate the size of a matrix.',\n examples: ['size(2.3)', 'size(\"hello world\")', 'a = [1, 2; 3, 4; 5, 6]', 'size(a)', 'size(1:6)'],\n seealso: ['concat', 'count', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'squeeze', 'subset', 'trace', 'transpose', 'zeros']\n};\nexports.sizeDocs = sizeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sortDocs = void 0;\nvar sortDocs = {\n name: 'sort',\n category: 'Matrix',\n syntax: ['sort(x)', 'sort(x, compare)'],\n description: 'Sort the items in a matrix. Compare can be a string \"asc\", \"desc\", \"natural\", or a custom sort function.',\n examples: ['sort([5, 10, 1])', 'sort([\"C\", \"B\", \"A\", \"D\"])', 'sortByLength(a, b) = size(a)[1] - size(b)[1]', 'sort([\"Langdon\", \"Tom\", \"Sara\"], sortByLength)', 'sort([\"10\", \"1\", \"2\"], \"natural\")'],\n seealso: ['map', 'filter', 'forEach']\n};\nexports.sortDocs = sortDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.squeezeDocs = void 0;\nvar squeezeDocs = {\n name: 'squeeze',\n category: 'Matrix',\n syntax: ['squeeze(x)'],\n description: 'Remove inner and outer singleton dimensions from a matrix.',\n examples: ['a = zeros(3,2,1)', 'size(squeeze(a))', 'b = zeros(1,1,3)', 'size(squeeze(b))'],\n seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'subset', 'trace', 'transpose', 'zeros']\n};\nexports.squeezeDocs = squeezeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.subsetDocs = void 0;\nvar subsetDocs = {\n name: 'subset',\n category: 'Matrix',\n syntax: ['value(index)', 'value(index) = replacement', 'subset(value, [index])', 'subset(value, [index], replacement)'],\n description: 'Get or set a subset of the entries of a matrix or ' + 'characters of a string. ' + 'Indexes are one-based. There should be one index specification for ' + 'each dimension of the target. Each specification can be a single ' + 'index, a list of indices, or a range in colon notation `l:u`. ' + 'In a range, both the lower bound l and upper bound u are included; ' + 'and if a bound is omitted it defaults to the most extreme valid value. ' + 'The cartesian product of the indices specified in each dimension ' + 'determines the target of the operation.',\n examples: ['d = [1, 2; 3, 4]', 'e = []', 'e[1, 1:2] = [5, 6]', 'e[2, :] = [7, 8]', 'f = d * e', 'f[2, 1]', 'f[:, 1]', 'f[[1,2], [1,3]] = [9, 10; 11, 12]', 'f'],\n seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'trace', 'transpose', 'zeros']\n};\nexports.subsetDocs = subsetDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.traceDocs = void 0;\nvar traceDocs = {\n name: 'trace',\n category: 'Matrix',\n syntax: ['trace(A)'],\n description: 'Calculate the trace of a matrix: the sum of the elements on the main diagonal of a square matrix.',\n examples: ['A = [1, 2, 3; -1, 2, 3; 2, 0, 3]', 'trace(A)'],\n seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'transpose', 'zeros']\n};\nexports.traceDocs = traceDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.transposeDocs = void 0;\nvar transposeDocs = {\n name: 'transpose',\n category: 'Matrix',\n syntax: ['x\\'', 'transpose(x)'],\n description: 'Transpose a matrix',\n examples: ['a = [1, 2, 3; 4, 5, 6]', 'a\\'', 'transpose(a)'],\n seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'zeros']\n};\nexports.transposeDocs = transposeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.zerosDocs = void 0;\nvar zerosDocs = {\n name: 'zeros',\n category: 'Matrix',\n syntax: ['zeros(m)', 'zeros(m, n)', 'zeros(m, n, p, ...)', 'zeros([m])', 'zeros([m, n])', 'zeros([m, n, p, ...])'],\n description: 'Create a matrix containing zeros.',\n examples: ['zeros(3)', 'zeros(3, 5)', 'a = [1, 2, 3; 4, 5, 6]', 'zeros(size(a))'],\n seealso: ['concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose']\n};\nexports.zerosDocs = zerosDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.combinationsDocs = void 0;\nvar combinationsDocs = {\n name: 'combinations',\n category: 'Probability',\n syntax: ['combinations(n, k)'],\n description: 'Compute the number of combinations of n items taken k at a time',\n examples: ['combinations(7, 5)'],\n seealso: ['combinationsWithRep', 'permutations', 'factorial']\n};\nexports.combinationsDocs = combinationsDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.combinationsWithRepDocs = void 0;\nvar combinationsWithRepDocs = {\n name: 'combinationsWithRep',\n category: 'Probability',\n syntax: ['combinationsWithRep(n, k)'],\n description: 'Compute the number of combinations of n items taken k at a time with replacements.',\n examples: ['combinationsWithRep(7, 5)'],\n seealso: ['combinations', 'permutations', 'factorial']\n};\nexports.combinationsWithRepDocs = combinationsWithRepDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.factorialDocs = void 0;\nvar factorialDocs = {\n name: 'factorial',\n category: 'Probability',\n syntax: ['n!', 'factorial(n)'],\n description: 'Compute the factorial of a value',\n examples: ['5!', '5 * 4 * 3 * 2 * 1', '3!'],\n seealso: ['combinations', 'combinationsWithRep', 'permutations', 'gamma']\n};\nexports.factorialDocs = factorialDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.gammaDocs = void 0;\nvar gammaDocs = {\n name: 'gamma',\n category: 'Probability',\n syntax: ['gamma(n)'],\n description: 'Compute the gamma function. For small values, the Lanczos approximation is used, and for large values the extended Stirling approximation.',\n examples: ['gamma(4)', '3!', 'gamma(1/2)', 'sqrt(pi)'],\n seealso: ['factorial']\n};\nexports.gammaDocs = gammaDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.kldivergenceDocs = void 0;\nvar kldivergenceDocs = {\n name: 'kldivergence',\n category: 'Probability',\n syntax: ['kldivergence(x, y)'],\n description: 'Calculate the Kullback-Leibler (KL) divergence between two distributions.',\n examples: ['kldivergence([0.7,0.5,0.4], [0.2,0.9,0.5])'],\n seealso: []\n};\nexports.kldivergenceDocs = kldivergenceDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lgammaDocs = void 0;\nvar lgammaDocs = {\n name: 'lgamma',\n category: 'Probability',\n syntax: ['lgamma(n)'],\n description: 'Logarithm of the gamma function for real, positive numbers and complex numbers, ' + 'using Lanczos approximation for numbers and Stirling series for complex numbers.',\n examples: ['lgamma(4)', 'lgamma(1/2)', 'lgamma(math.i)', 'lgamma(complex(1.1, 2))'],\n seealso: ['gamma']\n};\nexports.lgammaDocs = lgammaDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.multinomialDocs = void 0;\nvar multinomialDocs = {\n name: 'multinomial',\n category: 'Probability',\n syntax: ['multinomial(A)'],\n description: 'Multinomial Coefficients compute the number of ways of picking a1, a2, ..., ai unordered outcomes from `n` possibilities. multinomial takes one array of integers as an argument. The following condition must be enforced: every ai > 0.',\n examples: ['multinomial([1, 2, 1])'],\n seealso: ['combinations', 'factorial']\n};\nexports.multinomialDocs = multinomialDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.permutationsDocs = void 0;\nvar permutationsDocs = {\n name: 'permutations',\n category: 'Probability',\n syntax: ['permutations(n)', 'permutations(n, k)'],\n description: 'Compute the number of permutations of n items taken k at a time',\n examples: ['permutations(5)', 'permutations(5, 3)'],\n seealso: ['combinations', 'combinationsWithRep', 'factorial']\n};\nexports.permutationsDocs = permutationsDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.pickRandomDocs = void 0;\nvar pickRandomDocs = {\n name: 'pickRandom',\n category: 'Probability',\n syntax: ['pickRandom(array)', 'pickRandom(array, number)', 'pickRandom(array, weights)', 'pickRandom(array, number, weights)', 'pickRandom(array, weights, number)'],\n description: 'Pick a random entry from a given array.',\n examples: ['pickRandom(0:10)', 'pickRandom([1, 3, 1, 6])', 'pickRandom([1, 3, 1, 6], 2)', 'pickRandom([1, 3, 1, 6], [2, 3, 2, 1])', 'pickRandom([1, 3, 1, 6], 2, [2, 3, 2, 1])', 'pickRandom([1, 3, 1, 6], [2, 3, 2, 1], 2)'],\n seealso: ['random', 'randomInt']\n};\nexports.pickRandomDocs = pickRandomDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.randomDocs = void 0;\nvar randomDocs = {\n name: 'random',\n category: 'Probability',\n syntax: ['random()', 'random(max)', 'random(min, max)', 'random(size)', 'random(size, max)', 'random(size, min, max)'],\n description: 'Return a random number.',\n examples: ['random()', 'random(10, 20)', 'random([2, 3])'],\n seealso: ['pickRandom', 'randomInt']\n};\nexports.randomDocs = randomDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.randomIntDocs = void 0;\nvar randomIntDocs = {\n name: 'randomInt',\n category: 'Probability',\n syntax: ['randomInt(max)', 'randomInt(min, max)', 'randomInt(size)', 'randomInt(size, max)', 'randomInt(size, min, max)'],\n description: 'Return a random integer number',\n examples: ['randomInt(10, 20)', 'randomInt([2, 3], 10)'],\n seealso: ['pickRandom', 'random']\n};\nexports.randomIntDocs = randomIntDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.compareDocs = void 0;\nvar compareDocs = {\n name: 'compare',\n category: 'Relational',\n syntax: ['compare(x, y)'],\n description: 'Compare two values. ' + 'Returns 1 when x > y, -1 when x < y, and 0 when x == y.',\n examples: ['compare(2, 3)', 'compare(3, 2)', 'compare(2, 2)', 'compare(5cm, 40mm)', 'compare(2, [1, 2, 3])'],\n seealso: ['equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compareNatural', 'compareText']\n};\nexports.compareDocs = compareDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.compareNaturalDocs = void 0;\nvar compareNaturalDocs = {\n name: 'compareNatural',\n category: 'Relational',\n syntax: ['compareNatural(x, y)'],\n description: 'Compare two values of any type in a deterministic, natural way. ' + 'Returns 1 when x > y, -1 when x < y, and 0 when x == y.',\n examples: ['compareNatural(2, 3)', 'compareNatural(3, 2)', 'compareNatural(2, 2)', 'compareNatural(5cm, 40mm)', 'compareNatural(\"2\", \"10\")', 'compareNatural(2 + 3i, 2 + 4i)', 'compareNatural([1, 2, 4], [1, 2, 3])', 'compareNatural([1, 5], [1, 2, 3])', 'compareNatural([1, 2], [1, 2])', 'compareNatural({a: 2}, {a: 4})'],\n seealso: ['equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compare', 'compareText']\n};\nexports.compareNaturalDocs = compareNaturalDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.compareTextDocs = void 0;\nvar compareTextDocs = {\n name: 'compareText',\n category: 'Relational',\n syntax: ['compareText(x, y)'],\n description: 'Compare two strings lexically. Comparison is case sensitive. ' + 'Returns 1 when x > y, -1 when x < y, and 0 when x == y.',\n examples: ['compareText(\"B\", \"A\")', 'compareText(\"A\", \"B\")', 'compareText(\"A\", \"A\")', 'compareText(\"2\", \"10\")', 'compare(\"2\", \"10\")', 'compare(2, 10)', 'compareNatural(\"2\", \"10\")', 'compareText(\"B\", [\"A\", \"B\", \"C\"])'],\n seealso: ['compare', 'compareNatural']\n};\nexports.compareTextDocs = compareTextDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.deepEqualDocs = void 0;\nvar deepEqualDocs = {\n name: 'deepEqual',\n category: 'Relational',\n syntax: ['deepEqual(x, y)'],\n description: 'Check equality of two matrices element wise. Returns true if the size of both matrices is equal and when and each of the elements are equal.',\n examples: ['deepEqual([1,3,4], [1,3,4])', 'deepEqual([1,3,4], [1,3])'],\n seealso: ['equal', 'unequal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare']\n};\nexports.deepEqualDocs = deepEqualDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.equalDocs = void 0;\nvar equalDocs = {\n name: 'equal',\n category: 'Relational',\n syntax: ['x == y', 'equal(x, y)'],\n description: 'Check equality of two values. Returns true if the values are equal, and false if not.',\n examples: ['2+2 == 3', '2+2 == 4', 'a = 3.2', 'b = 6-2.8', 'a == b', '50cm == 0.5m'],\n seealso: ['unequal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare', 'deepEqual', 'equalText']\n};\nexports.equalDocs = equalDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.equalTextDocs = void 0;\nvar equalTextDocs = {\n name: 'equalText',\n category: 'Relational',\n syntax: ['equalText(x, y)'],\n description: 'Check equality of two strings. Comparison is case sensitive. Returns true if the values are equal, and false if not.',\n examples: ['equalText(\"Hello\", \"Hello\")', 'equalText(\"a\", \"A\")', 'equal(\"2e3\", \"2000\")', 'equalText(\"2e3\", \"2000\")', 'equalText(\"B\", [\"A\", \"B\", \"C\"])'],\n seealso: ['compare', 'compareNatural', 'compareText', 'equal']\n};\nexports.equalTextDocs = equalTextDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.largerDocs = void 0;\nvar largerDocs = {\n name: 'larger',\n category: 'Relational',\n syntax: ['x > y', 'larger(x, y)'],\n description: 'Check if value x is larger than y. Returns true if x is larger than y, and false if not.',\n examples: ['2 > 3', '5 > 2*2', 'a = 3.3', 'b = 6-2.8', '(a > b)', '(b < a)', '5 cm > 2 inch'],\n seealso: ['equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compare']\n};\nexports.largerDocs = largerDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.largerEqDocs = void 0;\nvar largerEqDocs = {\n name: 'largerEq',\n category: 'Relational',\n syntax: ['x >= y', 'largerEq(x, y)'],\n description: 'Check if value x is larger or equal to y. Returns true if x is larger or equal to y, and false if not.',\n examples: ['2 >= 1+1', '2 > 1+1', 'a = 3.2', 'b = 6-2.8', '(a >= b)'],\n seealso: ['equal', 'unequal', 'smallerEq', 'smaller', 'compare']\n};\nexports.largerEqDocs = largerEqDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.smallerDocs = void 0;\nvar smallerDocs = {\n name: 'smaller',\n category: 'Relational',\n syntax: ['x < y', 'smaller(x, y)'],\n description: 'Check if value x is smaller than value y. Returns true if x is smaller than y, and false if not.',\n examples: ['2 < 3', '5 < 2*2', 'a = 3.3', 'b = 6-2.8', '(a < b)', '5 cm < 2 inch'],\n seealso: ['equal', 'unequal', 'larger', 'smallerEq', 'largerEq', 'compare']\n};\nexports.smallerDocs = smallerDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.smallerEqDocs = void 0;\nvar smallerEqDocs = {\n name: 'smallerEq',\n category: 'Relational',\n syntax: ['x <= y', 'smallerEq(x, y)'],\n description: 'Check if value x is smaller or equal to value y. Returns true if x is smaller than y, and false if not.',\n examples: ['2 <= 1+1', '2 < 1+1', 'a = 3.2', 'b = 6-2.8', '(a <= b)'],\n seealso: ['equal', 'unequal', 'larger', 'smaller', 'largerEq', 'compare']\n};\nexports.smallerEqDocs = smallerEqDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.unequalDocs = void 0;\nvar unequalDocs = {\n name: 'unequal',\n category: 'Relational',\n syntax: ['x != y', 'unequal(x, y)'],\n description: 'Check unequality of two values. Returns true if the values are unequal, and false if they are equal.',\n examples: ['2+2 != 3', '2+2 != 4', 'a = 3.2', 'b = 6-2.8', 'a != b', '50cm != 0.5m', '5 cm != 2 inch'],\n seealso: ['equal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare', 'deepEqual']\n};\nexports.unequalDocs = unequalDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setCartesianDocs = void 0;\nvar setCartesianDocs = {\n name: 'setCartesian',\n category: 'Set',\n syntax: ['setCartesian(set1, set2)'],\n description: 'Create the cartesian product of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays and the values will be sorted in ascending order before the operation.',\n examples: ['setCartesian([1, 2], [3, 4])'],\n seealso: ['setUnion', 'setIntersect', 'setDifference', 'setPowerset']\n};\nexports.setCartesianDocs = setCartesianDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setDifferenceDocs = void 0;\nvar setDifferenceDocs = {\n name: 'setDifference',\n category: 'Set',\n syntax: ['setDifference(set1, set2)'],\n description: 'Create the difference of two (multi)sets: every element of set1, that is not the element of set2. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n examples: ['setDifference([1, 2, 3, 4], [3, 4, 5, 6])', 'setDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])'],\n seealso: ['setUnion', 'setIntersect', 'setSymDifference']\n};\nexports.setDifferenceDocs = setDifferenceDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setDistinctDocs = void 0;\nvar setDistinctDocs = {\n name: 'setDistinct',\n category: 'Set',\n syntax: ['setDistinct(set)'],\n description: 'Collect the distinct elements of a multiset. A multi-dimension array will be converted to a single-dimension array before the operation.',\n examples: ['setDistinct([1, 1, 1, 2, 2, 3])'],\n seealso: ['setMultiplicity']\n};\nexports.setDistinctDocs = setDistinctDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setIntersectDocs = void 0;\nvar setIntersectDocs = {\n name: 'setIntersect',\n category: 'Set',\n syntax: ['setIntersect(set1, set2)'],\n description: 'Create the intersection of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n examples: ['setIntersect([1, 2, 3, 4], [3, 4, 5, 6])', 'setIntersect([[1, 2], [3, 4]], [[3, 4], [5, 6]])'],\n seealso: ['setUnion', 'setDifference']\n};\nexports.setIntersectDocs = setIntersectDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setIsSubsetDocs = void 0;\nvar setIsSubsetDocs = {\n name: 'setIsSubset',\n category: 'Set',\n syntax: ['setIsSubset(set1, set2)'],\n description: 'Check whether a (multi)set is a subset of another (multi)set: every element of set1 is the element of set2. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n examples: ['setIsSubset([1, 2], [3, 4, 5, 6])', 'setIsSubset([3, 4], [3, 4, 5, 6])'],\n seealso: ['setUnion', 'setIntersect', 'setDifference']\n};\nexports.setIsSubsetDocs = setIsSubsetDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setMultiplicityDocs = void 0;\nvar setMultiplicityDocs = {\n name: 'setMultiplicity',\n category: 'Set',\n syntax: ['setMultiplicity(element, set)'],\n description: 'Count the multiplicity of an element in a multiset. A multi-dimension array will be converted to a single-dimension array before the operation.',\n examples: ['setMultiplicity(1, [1, 2, 2, 4])', 'setMultiplicity(2, [1, 2, 2, 4])'],\n seealso: ['setDistinct', 'setSize']\n};\nexports.setMultiplicityDocs = setMultiplicityDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setPowersetDocs = void 0;\nvar setPowersetDocs = {\n name: 'setPowerset',\n category: 'Set',\n syntax: ['setPowerset(set)'],\n description: 'Create the powerset of a (multi)set: the powerset contains very possible subsets of a (multi)set. A multi-dimension array will be converted to a single-dimension array before the operation.',\n examples: ['setPowerset([1, 2, 3])'],\n seealso: ['setCartesian']\n};\nexports.setPowersetDocs = setPowersetDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setSizeDocs = void 0;\nvar setSizeDocs = {\n name: 'setSize',\n category: 'Set',\n syntax: ['setSize(set)', 'setSize(set, unique)'],\n description: 'Count the number of elements of a (multi)set. When the second parameter \"unique\" is true, count only the unique values. A multi-dimension array will be converted to a single-dimension array before the operation.',\n examples: ['setSize([1, 2, 2, 4])', 'setSize([1, 2, 2, 4], true)'],\n seealso: ['setUnion', 'setIntersect', 'setDifference']\n};\nexports.setSizeDocs = setSizeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setSymDifferenceDocs = void 0;\nvar setSymDifferenceDocs = {\n name: 'setSymDifference',\n category: 'Set',\n syntax: ['setSymDifference(set1, set2)'],\n description: 'Create the symmetric difference of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n examples: ['setSymDifference([1, 2, 3, 4], [3, 4, 5, 6])', 'setSymDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])'],\n seealso: ['setUnion', 'setIntersect', 'setDifference']\n};\nexports.setSymDifferenceDocs = setSymDifferenceDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setUnionDocs = void 0;\nvar setUnionDocs = {\n name: 'setUnion',\n category: 'Set',\n syntax: ['setUnion(set1, set2)'],\n description: 'Create the union of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n examples: ['setUnion([1, 2, 3, 4], [3, 4, 5, 6])', 'setUnion([[1, 2], [3, 4]], [[3, 4], [5, 6]])'],\n seealso: ['setIntersect', 'setDifference']\n};\nexports.setUnionDocs = setUnionDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.erfDocs = void 0;\nvar erfDocs = {\n name: 'erf',\n category: 'Special',\n syntax: ['erf(x)'],\n description: 'Compute the erf function of a value using a rational Chebyshev approximations for different intervals of x',\n examples: ['erf(0.2)', 'erf(-0.5)', 'erf(4)'],\n seealso: []\n};\nexports.erfDocs = erfDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cumSumDocs = void 0;\nvar cumSumDocs = {\n name: 'cumsum',\n category: 'Statistics',\n syntax: ['cumsum(a, b, c, ...)', 'cumsum(A)'],\n description: 'Compute the cumulative sum of all values.',\n examples: ['cumsum(2, 3, 4, 1)', 'cumsum([2, 3, 4, 1])', 'cumsum([1, 2; 3, 4])', 'cumsum([1, 2; 3, 4], 1)', 'cumsum([1, 2; 3, 4], 2)'],\n seealso: ['max', 'mean', 'median', 'min', 'prod', 'std', 'sum', 'variance']\n};\nexports.cumSumDocs = cumSumDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.madDocs = void 0;\nvar madDocs = {\n name: 'mad',\n category: 'Statistics',\n syntax: ['mad(a, b, c, ...)', 'mad(A)'],\n description: 'Compute the median absolute deviation of a matrix or a list with values. The median absolute deviation is defined as the median of the absolute deviations from the median.',\n examples: ['mad(10, 20, 30)', 'mad([1, 2, 3])'],\n seealso: ['mean', 'median', 'std', 'abs']\n};\nexports.madDocs = madDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.maxDocs = void 0;\nvar maxDocs = {\n name: 'max',\n category: 'Statistics',\n syntax: ['max(a, b, c, ...)', 'max(A)', 'max(A, dim)'],\n description: 'Compute the maximum value of a list of values.',\n examples: ['max(2, 3, 4, 1)', 'max([2, 3, 4, 1])', 'max([2, 5; 4, 3])', 'max([2, 5; 4, 3], 1)', 'max([2, 5; 4, 3], 2)', 'max(2.7, 7.1, -4.5, 2.0, 4.1)', 'min(2.7, 7.1, -4.5, 2.0, 4.1)'],\n seealso: ['mean', 'median', 'min', 'prod', 'std', 'sum', 'variance']\n};\nexports.maxDocs = maxDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.meanDocs = void 0;\nvar meanDocs = {\n name: 'mean',\n category: 'Statistics',\n syntax: ['mean(a, b, c, ...)', 'mean(A)', 'mean(A, dim)'],\n description: 'Compute the arithmetic mean of a list of values.',\n examples: ['mean(2, 3, 4, 1)', 'mean([2, 3, 4, 1])', 'mean([2, 5; 4, 3])', 'mean([2, 5; 4, 3], 1)', 'mean([2, 5; 4, 3], 2)', 'mean([1.0, 2.7, 3.2, 4.0])'],\n seealso: ['max', 'median', 'min', 'prod', 'std', 'sum', 'variance']\n};\nexports.meanDocs = meanDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.medianDocs = void 0;\nvar medianDocs = {\n name: 'median',\n category: 'Statistics',\n syntax: ['median(a, b, c, ...)', 'median(A)'],\n description: 'Compute the median of all values. The values are sorted and the middle value is returned. In case of an even number of values, the average of the two middle values is returned.',\n examples: ['median(5, 2, 7)', 'median([3, -1, 5, 7])'],\n seealso: ['max', 'mean', 'min', 'prod', 'std', 'sum', 'variance', 'quantileSeq']\n};\nexports.medianDocs = medianDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.minDocs = void 0;\nvar minDocs = {\n name: 'min',\n category: 'Statistics',\n syntax: ['min(a, b, c, ...)', 'min(A)', 'min(A, dim)'],\n description: 'Compute the minimum value of a list of values.',\n examples: ['min(2, 3, 4, 1)', 'min([2, 3, 4, 1])', 'min([2, 5; 4, 3])', 'min([2, 5; 4, 3], 1)', 'min([2, 5; 4, 3], 2)', 'min(2.7, 7.1, -4.5, 2.0, 4.1)', 'max(2.7, 7.1, -4.5, 2.0, 4.1)'],\n seealso: ['max', 'mean', 'median', 'prod', 'std', 'sum', 'variance']\n};\nexports.minDocs = minDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.modeDocs = void 0;\nvar modeDocs = {\n name: 'mode',\n category: 'Statistics',\n syntax: ['mode(a, b, c, ...)', 'mode(A)', 'mode(A, a, b, B, c, ...)'],\n description: 'Computes the mode of all values as an array. In case mode being more than one, multiple values are returned in an array.',\n examples: ['mode(2, 1, 4, 3, 1)', 'mode([1, 2.7, 3.2, 4, 2.7])', 'mode(1, 4, 6, 1, 6)'],\n seealso: ['max', 'mean', 'min', 'median', 'prod', 'std', 'sum', 'variance']\n};\nexports.modeDocs = modeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.prodDocs = void 0;\nvar prodDocs = {\n name: 'prod',\n category: 'Statistics',\n syntax: ['prod(a, b, c, ...)', 'prod(A)'],\n description: 'Compute the product of all values.',\n examples: ['prod(2, 3, 4)', 'prod([2, 3, 4])', 'prod([2, 5; 4, 3])'],\n seealso: ['max', 'mean', 'min', 'median', 'min', 'std', 'sum', 'variance']\n};\nexports.prodDocs = prodDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.quantileSeqDocs = void 0;\nvar quantileSeqDocs = {\n name: 'quantileSeq',\n category: 'Statistics',\n syntax: ['quantileSeq(A, prob[, sorted])', 'quantileSeq(A, [prob1, prob2, ...][, sorted])', 'quantileSeq(A, N[, sorted])'],\n description: 'Compute the prob order quantile of a matrix or a list with values. The sequence is sorted and the middle value is returned. Supported types of sequence values are: Number, BigNumber, Unit Supported types of probablity are: Number, BigNumber. \\n\\nIn case of a (multi dimensional) array or matrix, the prob order quantile of all elements will be calculated.',\n examples: ['quantileSeq([3, -1, 5, 7], 0.5)', 'quantileSeq([3, -1, 5, 7], [1/3, 2/3])', 'quantileSeq([3, -1, 5, 7], 2)', 'quantileSeq([-1, 3, 5, 7], 0.5, true)'],\n seealso: ['mean', 'median', 'min', 'max', 'prod', 'std', 'sum', 'variance']\n};\nexports.quantileSeqDocs = quantileSeqDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.stdDocs = void 0;\nvar stdDocs = {\n name: 'std',\n category: 'Statistics',\n syntax: ['std(a, b, c, ...)', 'std(A)', 'std(A, normalization)'],\n description: 'Compute the standard deviation of all values, defined as std(A) = sqrt(variance(A)). Optional parameter normalization can be \"unbiased\" (default), \"uncorrected\", or \"biased\".',\n examples: ['std(2, 4, 6)', 'std([2, 4, 6, 8])', 'std([2, 4, 6, 8], \"uncorrected\")', 'std([2, 4, 6, 8], \"biased\")', 'std([1, 2, 3; 4, 5, 6])'],\n seealso: ['max', 'mean', 'min', 'median', 'prod', 'sum', 'variance']\n};\nexports.stdDocs = stdDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sumDocs = void 0;\nvar sumDocs = {\n name: 'sum',\n category: 'Statistics',\n syntax: ['sum(a, b, c, ...)', 'sum(A)'],\n description: 'Compute the sum of all values.',\n examples: ['sum(2, 3, 4, 1)', 'sum([2, 3, 4, 1])', 'sum([2, 5; 4, 3])'],\n seealso: ['max', 'mean', 'median', 'min', 'prod', 'std', 'sum', 'variance']\n};\nexports.sumDocs = sumDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.varianceDocs = void 0;\nvar varianceDocs = {\n name: 'variance',\n category: 'Statistics',\n syntax: ['variance(a, b, c, ...)', 'variance(A)', 'variance(A, normalization)'],\n description: 'Compute the variance of all values. Optional parameter normalization can be \"unbiased\" (default), \"uncorrected\", or \"biased\".',\n examples: ['variance(2, 4, 6)', 'variance([2, 4, 6, 8])', 'variance([2, 4, 6, 8], \"uncorrected\")', 'variance([2, 4, 6, 8], \"biased\")', 'variance([1, 2, 3; 4, 5, 6])'],\n seealso: ['max', 'mean', 'min', 'median', 'min', 'prod', 'std', 'sum']\n};\nexports.varianceDocs = varianceDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acosDocs = void 0;\nvar acosDocs = {\n name: 'acos',\n category: 'Trigonometry',\n syntax: ['acos(x)'],\n description: 'Compute the inverse cosine of a value in radians.',\n examples: ['acos(0.5)', 'acos(cos(2.3))'],\n seealso: ['cos', 'atan', 'asin']\n};\nexports.acosDocs = acosDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acoshDocs = void 0;\nvar acoshDocs = {\n name: 'acosh',\n category: 'Trigonometry',\n syntax: ['acosh(x)'],\n description: 'Calculate the hyperbolic arccos of a value, defined as `acosh(x) = ln(sqrt(x^2 - 1) + x)`.',\n examples: ['acosh(1.5)'],\n seealso: ['cosh', 'asinh', 'atanh']\n};\nexports.acoshDocs = acoshDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acotDocs = void 0;\nvar acotDocs = {\n name: 'acot',\n category: 'Trigonometry',\n syntax: ['acot(x)'],\n description: 'Calculate the inverse cotangent of a value.',\n examples: ['acot(0.5)', 'acot(cot(0.5))', 'acot(2)'],\n seealso: ['cot', 'atan']\n};\nexports.acotDocs = acotDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acothDocs = void 0;\nvar acothDocs = {\n name: 'acoth',\n category: 'Trigonometry',\n syntax: ['acoth(x)'],\n description: 'Calculate the hyperbolic arccotangent of a value, defined as `acoth(x) = (ln((x+1)/x) + ln(x/(x-1))) / 2`.',\n examples: ['acoth(2)', 'acoth(0.5)'],\n seealso: ['acsch', 'asech']\n};\nexports.acothDocs = acothDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acscDocs = void 0;\nvar acscDocs = {\n name: 'acsc',\n category: 'Trigonometry',\n syntax: ['acsc(x)'],\n description: 'Calculate the inverse cotangent of a value.',\n examples: ['acsc(2)', 'acsc(csc(0.5))', 'acsc(0.5)'],\n seealso: ['csc', 'asin', 'asec']\n};\nexports.acscDocs = acscDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acschDocs = void 0;\nvar acschDocs = {\n name: 'acsch',\n category: 'Trigonometry',\n syntax: ['acsch(x)'],\n description: 'Calculate the hyperbolic arccosecant of a value, defined as `acsch(x) = ln(1/x + sqrt(1/x^2 + 1))`.',\n examples: ['acsch(0.5)'],\n seealso: ['asech', 'acoth']\n};\nexports.acschDocs = acschDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.asecDocs = void 0;\nvar asecDocs = {\n name: 'asec',\n category: 'Trigonometry',\n syntax: ['asec(x)'],\n description: 'Calculate the inverse secant of a value.',\n examples: ['asec(0.5)', 'asec(sec(0.5))', 'asec(2)'],\n seealso: ['acos', 'acot', 'acsc']\n};\nexports.asecDocs = asecDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.asechDocs = void 0;\nvar asechDocs = {\n name: 'asech',\n category: 'Trigonometry',\n syntax: ['asech(x)'],\n description: 'Calculate the inverse secant of a value.',\n examples: ['asech(0.5)'],\n seealso: ['acsch', 'acoth']\n};\nexports.asechDocs = asechDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.asinDocs = void 0;\nvar asinDocs = {\n name: 'asin',\n category: 'Trigonometry',\n syntax: ['asin(x)'],\n description: 'Compute the inverse sine of a value in radians.',\n examples: ['asin(0.5)', 'asin(sin(0.5))'],\n seealso: ['sin', 'acos', 'atan']\n};\nexports.asinDocs = asinDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.asinhDocs = void 0;\nvar asinhDocs = {\n name: 'asinh',\n category: 'Trigonometry',\n syntax: ['asinh(x)'],\n description: 'Calculate the hyperbolic arcsine of a value, defined as `asinh(x) = ln(x + sqrt(x^2 + 1))`.',\n examples: ['asinh(0.5)'],\n seealso: ['acosh', 'atanh']\n};\nexports.asinhDocs = asinhDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.atanDocs = void 0;\nvar atanDocs = {\n name: 'atan',\n category: 'Trigonometry',\n syntax: ['atan(x)'],\n description: 'Compute the inverse tangent of a value in radians.',\n examples: ['atan(0.5)', 'atan(tan(0.5))'],\n seealso: ['tan', 'acos', 'asin']\n};\nexports.atanDocs = atanDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.atan2Docs = void 0;\nvar atan2Docs = {\n name: 'atan2',\n category: 'Trigonometry',\n syntax: ['atan2(y, x)'],\n description: 'Computes the principal value of the arc tangent of y/x in radians.',\n examples: ['atan2(2, 2) / pi', 'angle = 60 deg in rad', 'x = cos(angle)', 'y = sin(angle)', 'atan2(y, x)'],\n seealso: ['sin', 'cos', 'tan']\n};\nexports.atan2Docs = atan2Docs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.atanhDocs = void 0;\nvar atanhDocs = {\n name: 'atanh',\n category: 'Trigonometry',\n syntax: ['atanh(x)'],\n description: 'Calculate the hyperbolic arctangent of a value, defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`.',\n examples: ['atanh(0.5)'],\n seealso: ['acosh', 'asinh']\n};\nexports.atanhDocs = atanhDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cosDocs = void 0;\nvar cosDocs = {\n name: 'cos',\n category: 'Trigonometry',\n syntax: ['cos(x)'],\n description: 'Compute the cosine of x in radians.',\n examples: ['cos(2)', 'cos(pi / 4) ^ 2', 'cos(180 deg)', 'cos(60 deg)', 'sin(0.2)^2 + cos(0.2)^2'],\n seealso: ['acos', 'sin', 'tan']\n};\nexports.cosDocs = cosDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.coshDocs = void 0;\nvar coshDocs = {\n name: 'cosh',\n category: 'Trigonometry',\n syntax: ['cosh(x)'],\n description: 'Compute the hyperbolic cosine of x in radians.',\n examples: ['cosh(0.5)'],\n seealso: ['sinh', 'tanh', 'coth']\n};\nexports.coshDocs = coshDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cotDocs = void 0;\nvar cotDocs = {\n name: 'cot',\n category: 'Trigonometry',\n syntax: ['cot(x)'],\n description: 'Compute the cotangent of x in radians. Defined as 1/tan(x)',\n examples: ['cot(2)', '1 / tan(2)'],\n seealso: ['sec', 'csc', 'tan']\n};\nexports.cotDocs = cotDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cothDocs = void 0;\nvar cothDocs = {\n name: 'coth',\n category: 'Trigonometry',\n syntax: ['coth(x)'],\n description: 'Compute the hyperbolic cotangent of x in radians.',\n examples: ['coth(2)', '1 / tanh(2)'],\n seealso: ['sech', 'csch', 'tanh']\n};\nexports.cothDocs = cothDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cscDocs = void 0;\nvar cscDocs = {\n name: 'csc',\n category: 'Trigonometry',\n syntax: ['csc(x)'],\n description: 'Compute the cosecant of x in radians. Defined as 1/sin(x)',\n examples: ['csc(2)', '1 / sin(2)'],\n seealso: ['sec', 'cot', 'sin']\n};\nexports.cscDocs = cscDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cschDocs = void 0;\nvar cschDocs = {\n name: 'csch',\n category: 'Trigonometry',\n syntax: ['csch(x)'],\n description: 'Compute the hyperbolic cosecant of x in radians. Defined as 1/sinh(x)',\n examples: ['csch(2)', '1 / sinh(2)'],\n seealso: ['sech', 'coth', 'sinh']\n};\nexports.cschDocs = cschDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.secDocs = void 0;\nvar secDocs = {\n name: 'sec',\n category: 'Trigonometry',\n syntax: ['sec(x)'],\n description: 'Compute the secant of x in radians. Defined as 1/cos(x)',\n examples: ['sec(2)', '1 / cos(2)'],\n seealso: ['cot', 'csc', 'cos']\n};\nexports.secDocs = secDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sechDocs = void 0;\nvar sechDocs = {\n name: 'sech',\n category: 'Trigonometry',\n syntax: ['sech(x)'],\n description: 'Compute the hyperbolic secant of x in radians. Defined as 1/cosh(x)',\n examples: ['sech(2)', '1 / cosh(2)'],\n seealso: ['coth', 'csch', 'cosh']\n};\nexports.sechDocs = sechDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sinDocs = void 0;\nvar sinDocs = {\n name: 'sin',\n category: 'Trigonometry',\n syntax: ['sin(x)'],\n description: 'Compute the sine of x in radians.',\n examples: ['sin(2)', 'sin(pi / 4) ^ 2', 'sin(90 deg)', 'sin(30 deg)', 'sin(0.2)^2 + cos(0.2)^2'],\n seealso: ['asin', 'cos', 'tan']\n};\nexports.sinDocs = sinDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sinhDocs = void 0;\nvar sinhDocs = {\n name: 'sinh',\n category: 'Trigonometry',\n syntax: ['sinh(x)'],\n description: 'Compute the hyperbolic sine of x in radians.',\n examples: ['sinh(0.5)'],\n seealso: ['cosh', 'tanh']\n};\nexports.sinhDocs = sinhDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.tanDocs = void 0;\nvar tanDocs = {\n name: 'tan',\n category: 'Trigonometry',\n syntax: ['tan(x)'],\n description: 'Compute the tangent of x in radians.',\n examples: ['tan(0.5)', 'sin(0.5) / cos(0.5)', 'tan(pi / 4)', 'tan(45 deg)'],\n seealso: ['atan', 'sin', 'cos']\n};\nexports.tanDocs = tanDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.tanhDocs = void 0;\nvar tanhDocs = {\n name: 'tanh',\n category: 'Trigonometry',\n syntax: ['tanh(x)'],\n description: 'Compute the hyperbolic tangent of x in radians.',\n examples: ['tanh(0.5)', 'sinh(0.5) / cosh(0.5)'],\n seealso: ['sinh', 'cosh']\n};\nexports.tanhDocs = tanhDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.toDocs = void 0;\nvar toDocs = {\n name: 'to',\n category: 'Units',\n syntax: ['x to unit', 'to(x, unit)'],\n description: 'Change the unit of a value.',\n examples: ['5 inch to cm', '3.2kg to g', '16 bytes in bits'],\n seealso: []\n};\nexports.toDocs = toDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.binDocs = void 0;\nvar binDocs = {\n name: 'bin',\n category: 'Utils',\n syntax: ['bin(value)'],\n description: 'Format a number as binary',\n examples: ['bin(2)'],\n seealso: ['oct', 'hex']\n};\nexports.binDocs = binDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cloneDocs = void 0;\nvar cloneDocs = {\n name: 'clone',\n category: 'Utils',\n syntax: ['clone(x)'],\n description: 'Clone a variable. Creates a copy of primitive variables,and a deep copy of matrices',\n examples: ['clone(3.5)', 'clone(2 - 4i)', 'clone(45 deg)', 'clone([1, 2; 3, 4])', 'clone(\"hello world\")'],\n seealso: []\n};\nexports.cloneDocs = cloneDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.formatDocs = void 0;\nvar formatDocs = {\n name: 'format',\n category: 'Utils',\n syntax: ['format(value)', 'format(value, precision)'],\n description: 'Format a value of any type as string.',\n examples: ['format(2.3)', 'format(3 - 4i)', 'format([])', 'format(pi, 3)'],\n seealso: ['print']\n};\nexports.formatDocs = formatDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hasNumericValueDocs = void 0;\nvar hasNumericValueDocs = {\n name: 'hasNumericValue',\n category: 'Utils',\n syntax: ['hasNumericValue(x)'],\n description: 'Test whether a value is an numeric value. ' + 'In case of a string, true is returned if the string contains a numeric value.',\n examples: ['hasNumericValue(2)', 'hasNumericValue(\"2\")', 'isNumeric(\"2\")', 'hasNumericValue(0)', 'hasNumericValue(bignumber(500))', 'hasNumericValue(fraction(0.125))', 'hasNumericValue(2 + 3i)', 'hasNumericValue([2.3, \"foo\", false])'],\n seealso: ['isInteger', 'isZero', 'isNegative', 'isPositive', 'isNaN', 'isNumeric']\n};\nexports.hasNumericValueDocs = hasNumericValueDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hexDocs = void 0;\nvar hexDocs = {\n name: 'hex',\n category: 'Utils',\n syntax: ['hex(value)'],\n description: 'Format a number as hexadecimal',\n examples: ['hex(240)'],\n seealso: ['bin', 'oct']\n};\nexports.hexDocs = hexDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isIntegerDocs = void 0;\nvar isIntegerDocs = {\n name: 'isInteger',\n category: 'Utils',\n syntax: ['isInteger(x)'],\n description: 'Test whether a value is an integer number.',\n examples: ['isInteger(2)', 'isInteger(3.5)', 'isInteger([3, 0.5, -2])'],\n seealso: ['isNegative', 'isNumeric', 'isPositive', 'isZero']\n};\nexports.isIntegerDocs = isIntegerDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isNaNDocs = void 0;\nvar isNaNDocs = {\n name: 'isNaN',\n category: 'Utils',\n syntax: ['isNaN(x)'],\n description: 'Test whether a value is NaN (not a number)',\n examples: ['isNaN(2)', 'isNaN(0 / 0)', 'isNaN(NaN)', 'isNaN(Infinity)'],\n seealso: ['isNegative', 'isNumeric', 'isPositive', 'isZero']\n};\nexports.isNaNDocs = isNaNDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isNegativeDocs = void 0;\nvar isNegativeDocs = {\n name: 'isNegative',\n category: 'Utils',\n syntax: ['isNegative(x)'],\n description: 'Test whether a value is negative: smaller than zero.',\n examples: ['isNegative(2)', 'isNegative(0)', 'isNegative(-4)', 'isNegative([3, 0.5, -2])'],\n seealso: ['isInteger', 'isNumeric', 'isPositive', 'isZero']\n};\nexports.isNegativeDocs = isNegativeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isNumericDocs = void 0;\nvar isNumericDocs = {\n name: 'isNumeric',\n category: 'Utils',\n syntax: ['isNumeric(x)'],\n description: 'Test whether a value is a numeric value. ' + 'Returns true when the input is a number, BigNumber, Fraction, or boolean.',\n examples: ['isNumeric(2)', 'isNumeric(\"2\")', 'hasNumericValue(\"2\")', 'isNumeric(0)', 'isNumeric(bignumber(500))', 'isNumeric(fraction(0.125))', 'isNumeric(2 + 3i)', 'isNumeric([2.3, \"foo\", false])'],\n seealso: ['isInteger', 'isZero', 'isNegative', 'isPositive', 'isNaN', 'hasNumericValue']\n};\nexports.isNumericDocs = isNumericDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isPositiveDocs = void 0;\nvar isPositiveDocs = {\n name: 'isPositive',\n category: 'Utils',\n syntax: ['isPositive(x)'],\n description: 'Test whether a value is positive: larger than zero.',\n examples: ['isPositive(2)', 'isPositive(0)', 'isPositive(-4)', 'isPositive([3, 0.5, -2])'],\n seealso: ['isInteger', 'isNumeric', 'isNegative', 'isZero']\n};\nexports.isPositiveDocs = isPositiveDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isPrimeDocs = void 0;\nvar isPrimeDocs = {\n name: 'isPrime',\n category: 'Utils',\n syntax: ['isPrime(x)'],\n description: 'Test whether a value is prime: has no divisors other than itself and one.',\n examples: ['isPrime(3)', 'isPrime(-2)', 'isPrime([2, 17, 100])'],\n seealso: ['isInteger', 'isNumeric', 'isNegative', 'isZero']\n};\nexports.isPrimeDocs = isPrimeDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isZeroDocs = void 0;\nvar isZeroDocs = {\n name: 'isZero',\n category: 'Utils',\n syntax: ['isZero(x)'],\n description: 'Test whether a value is zero.',\n examples: ['isZero(2)', 'isZero(0)', 'isZero(-4)', 'isZero([3, 0, -2, 0])'],\n seealso: ['isInteger', 'isNumeric', 'isNegative', 'isPositive']\n};\nexports.isZeroDocs = isZeroDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.numericDocs = void 0;\nvar numericDocs = {\n name: 'numeric',\n category: 'Utils',\n syntax: ['numeric(x)'],\n description: 'Convert a numeric input to a specific numeric type: number, BigNumber, or Fraction.',\n examples: ['numeric(\"4\")', 'numeric(\"4\", \"number\")', 'numeric(\"4\", \"BigNumber\")', 'numeric(\"4\", \"Fraction)', 'numeric(4, \"Fraction\")', 'numeric(fraction(2, 5), \"number)'],\n seealso: ['number', 'fraction', 'bignumber', 'string', 'format']\n};\nexports.numericDocs = numericDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.octDocs = void 0;\nvar octDocs = {\n name: 'oct',\n category: 'Utils',\n syntax: ['oct(value)'],\n description: 'Format a number as octal',\n examples: ['oct(56)'],\n seealso: ['bin', 'hex']\n};\nexports.octDocs = octDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.printDocs = void 0;\nvar printDocs = {\n name: 'print',\n category: 'Utils',\n syntax: ['print(template, values)', 'print(template, values, precision)'],\n description: 'Interpolate values into a string template.',\n examples: ['print(\"Lucy is $age years old\", {age: 5})', 'print(\"The value of pi is $pi\", {pi: pi}, 3)', 'print(\"Hello, $user.name!\", {user: {name: \"John\"}})', 'print(\"Values: $0, $1, $2\", [6, 9, 4])'],\n seealso: ['format']\n};\nexports.printDocs = printDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.typeOfDocs = void 0;\nvar typeOfDocs = {\n name: 'typeOf',\n category: 'Utils',\n syntax: ['typeOf(x)'],\n description: 'Get the type of a variable.',\n examples: ['typeOf(3.5)', 'typeOf(2 - 4i)', 'typeOf(45 deg)', 'typeOf(\"hello world\")'],\n seealso: ['getMatrixDataType']\n};\nexports.typeOfDocs = typeOfDocs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCompile = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'compile';\nvar dependencies = ['typed', 'parse'];\nvar createCompile = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n parse = _ref.parse;\n\n /**\n * Parse and compile an expression.\n * Returns a an object with a function `evaluate([scope])` to evaluate the\n * compiled expression.\n *\n * Syntax:\n *\n * math.compile(expr) // returns one node\n * math.compile([expr1, expr2, expr3, ...]) // returns an array with nodes\n *\n * Examples:\n *\n * const code1 = math.compile('sqrt(3^2 + 4^2)')\n * code1.evaluate() // 5\n *\n * let scope = {a: 3, b: 4}\n * const code2 = math.compile('a * b') // 12\n * code2.evaluate(scope) // 12\n * scope.a = 5\n * code2.evaluate(scope) // 20\n *\n * const nodes = math.compile(['a = 3', 'b = 4', 'a * b'])\n * nodes[2].evaluate() // 12\n *\n * See also:\n *\n * parse, evaluate\n *\n * @param {string | string[] | Array | Matrix} expr\n * The expression to be compiled\n * @return {{evaluate: Function} | Array.<{evaluate: Function}>} code\n * An object with the compiled expression\n * @throws {Error}\n */\n return typed(name, {\n string: function string(expr) {\n return parse(expr).compile();\n },\n 'Array | Matrix': function ArrayMatrix(expr) {\n return (0, _collection.deepMap)(expr, function (entry) {\n return parse(entry).compile();\n });\n }\n });\n});\nexports.createCompile = createCompile;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createEvaluate = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _map = require(\"../../utils/map.js\");\n\nvar name = 'evaluate';\nvar dependencies = ['typed', 'parse'];\nvar createEvaluate = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n parse = _ref.parse;\n\n /**\n * Evaluate an expression.\n *\n * Note the evaluating arbitrary expressions may involve security risks,\n * see [https://mathjs.org/docs/expressions/security.html](https://mathjs.org/docs/expressions/security.html) for more information.\n *\n * Syntax:\n *\n * math.evaluate(expr)\n * math.evaluate(expr, scope)\n * math.evaluate([expr1, expr2, expr3, ...])\n * math.evaluate([expr1, expr2, expr3, ...], scope)\n *\n * Example:\n *\n * math.evaluate('(2+3)/4') // 1.25\n * math.evaluate('sqrt(3^2 + 4^2)') // 5\n * math.evaluate('sqrt(-4)') // 2i\n * math.evaluate(['a=3', 'b=4', 'a*b']) // [3, 4, 12]\n *\n * let scope = {a:3, b:4}\n * math.evaluate('a * b', scope) // 12\n *\n * See also:\n *\n * parse, compile\n *\n * @param {string | string[] | Matrix} expr The expression to be evaluated\n * @param {Object} [scope] Scope to read/write variables\n * @return {*} The result of the expression\n * @throws {Error}\n */\n return typed(name, {\n string: function string(expr) {\n var scope = (0, _map.createEmptyMap)();\n return parse(expr).compile().evaluate(scope);\n },\n 'string, Map | Object': function stringMapObject(expr, scope) {\n return parse(expr).compile().evaluate(scope);\n },\n 'Array | Matrix': function ArrayMatrix(expr) {\n var scope = (0, _map.createEmptyMap)();\n return (0, _collection.deepMap)(expr, function (entry) {\n return parse(entry).compile().evaluate(scope);\n });\n },\n 'Array | Matrix, Map | Object': function ArrayMatrixMapObject(expr, scope) {\n return (0, _collection.deepMap)(expr, function (entry) {\n return parse(entry).compile().evaluate(scope);\n });\n }\n });\n});\nexports.createEvaluate = createEvaluate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createHelp = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _customs = require(\"../../utils/customs.js\");\n\nvar _embeddedDocs = require(\"../embeddedDocs/embeddedDocs.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar name = 'help';\nvar dependencies = ['typed', 'mathWithTransform', 'Help'];\nvar createHelp = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n mathWithTransform = _ref.mathWithTransform,\n Help = _ref.Help;\n\n /**\n * Retrieve help on a function or data type.\n * Help files are retrieved from the embedded documentation in math.docs.\n *\n * Syntax:\n *\n * math.help(search)\n *\n * Examples:\n *\n * console.log(math.help('sin').toString())\n * console.log(math.help(math.add).toString())\n * console.log(math.help(math.add).toJSON())\n *\n * @param {Function | string | Object} search A function or function name\n * for which to get help\n * @return {Help} A help object\n */\n return typed(name, {\n any: function any(search) {\n var prop;\n var searchName = search;\n\n if (typeof search !== 'string') {\n for (prop in mathWithTransform) {\n // search in functions and constants\n if ((0, _object.hasOwnProperty)(mathWithTransform, prop) && search === mathWithTransform[prop]) {\n searchName = prop;\n break;\n }\n }\n /* TODO: implement help for data types\n if (!text) {\n // search data type\n for (prop in math.type) {\n if (hasOwnProperty(math, prop)) {\n if (search === math.type[prop]) {\n text = prop\n break\n }\n }\n }\n }\n */\n\n }\n\n var doc = (0, _customs.getSafeProperty)(_embeddedDocs.embeddedDocs, searchName);\n\n if (!doc) {\n var searchText = typeof searchName === 'function' ? searchName.name : searchName;\n throw new Error('No documentation found on \"' + searchText + '\"');\n }\n\n return new Help(doc);\n }\n });\n});\nexports.createHelp = createHelp;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createParser = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'parser';\nvar dependencies = ['typed', 'Parser'];\nvar createParser = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Parser = _ref.Parser;\n\n /**\n * Create a parser. The function creates a new `math.Parser` object.\n *\n * Syntax:\n *\n * math.parser()\n *\n * Examples:\n *\n * const parser = new math.parser()\n *\n * // evaluate expressions\n * const a = parser.evaluate('sqrt(3^2 + 4^2)') // 5\n * const b = parser.evaluate('sqrt(-4)') // 2i\n * const c = parser.evaluate('2 inch in cm') // 5.08 cm\n * const d = parser.evaluate('cos(45 deg)') // 0.7071067811865476\n *\n * // define variables and functions\n * parser.evaluate('x = 7 / 2') // 3.5\n * parser.evaluate('x + 3') // 6.5\n * parser.evaluate('f(x, y) = x^y') // f(x, y)\n * parser.evaluate('f(2, 3)') // 8\n *\n * // get and set variables and functions\n * const x = parser.get('x') // 7\n * const f = parser.get('f') // function\n * const g = f(3, 2) // 9\n * parser.set('h', 500)\n * const i = parser.evaluate('h / 2') // 250\n * parser.set('hello', function (name) {\n * return 'hello, ' + name + '!'\n * })\n * parser.evaluate('hello(\"user\")') // \"hello, user!\"\n *\n * // clear defined functions and variables\n * parser.clear()\n *\n * See also:\n *\n * evaluate, compile, parse\n *\n * @return {Parser} Parser\n */\n return typed(name, {\n '': function _() {\n return new Parser();\n }\n });\n});\nexports.createParser = createParser;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.keywords = void 0;\n// Reserved keywords not allowed to use in the parser\nvar keywords = new Set(['end']);\nexports.keywords = keywords;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAccessorNode = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _customs = require(\"../../utils/customs.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _access = require(\"./utils/access.js\");\n\nvar name = 'AccessorNode';\nvar dependencies = ['subset', 'Node'];\nvar createAccessorNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var subset = _ref.subset,\n Node = _ref.Node;\n var access = (0, _access.accessFactory)({\n subset: subset\n });\n /**\n * @constructor AccessorNode\n * @extends {Node}\n * Access an object property or get a matrix subset\n *\n * @param {Node} object The object from which to retrieve\n * a property or subset.\n * @param {IndexNode} index IndexNode containing ranges\n */\n\n function AccessorNode(object, index) {\n if (!(this instanceof AccessorNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n if (!(0, _is.isNode)(object)) {\n throw new TypeError('Node expected for parameter \"object\"');\n }\n\n if (!(0, _is.isIndexNode)(index)) {\n throw new TypeError('IndexNode expected for parameter \"index\"');\n }\n\n this.object = object || null;\n this.index = index; // readonly property name\n\n Object.defineProperty(this, 'name', {\n get: function () {\n if (this.index) {\n return this.index.isObjectProperty() ? this.index.getObjectProperty() : '';\n } else {\n return this.object.name || '';\n }\n }.bind(this),\n set: function set() {\n throw new Error('Cannot assign a new name, name is read-only');\n }\n });\n }\n\n AccessorNode.prototype = new Node();\n AccessorNode.prototype.type = 'AccessorNode';\n AccessorNode.prototype.isAccessorNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n AccessorNode.prototype._compile = function (math, argNames) {\n var evalObject = this.object._compile(math, argNames);\n\n var evalIndex = this.index._compile(math, argNames);\n\n if (this.index.isObjectProperty()) {\n var prop = this.index.getObjectProperty();\n return function evalAccessorNode(scope, args, context) {\n // get a property from an object evaluated using the scope.\n return (0, _customs.getSafeProperty)(evalObject(scope, args, context), prop);\n };\n } else {\n return function evalAccessorNode(scope, args, context) {\n var object = evalObject(scope, args, context);\n var index = evalIndex(scope, args, object); // we pass object here instead of context\n\n return access(object, index);\n };\n }\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n AccessorNode.prototype.forEach = function (callback) {\n callback(this.object, 'object', this);\n callback(this.index, 'index', this);\n };\n /**\n * Create a new AccessorNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {AccessorNode} Returns a transformed copy of the node\n */\n\n\n AccessorNode.prototype.map = function (callback) {\n return new AccessorNode(this._ifNode(callback(this.object, 'object', this)), this._ifNode(callback(this.index, 'index', this)));\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {AccessorNode}\n */\n\n\n AccessorNode.prototype.clone = function () {\n return new AccessorNode(this.object, this.index);\n };\n /**\n * Get string representation\n * @param {Object} options\n * @return {string}\n */\n\n\n AccessorNode.prototype._toString = function (options) {\n var object = this.object.toString(options);\n\n if (needParenthesis(this.object)) {\n object = '(' + object + ')';\n }\n\n return object + this.index.toString(options);\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string}\n */\n\n\n AccessorNode.prototype.toHTML = function (options) {\n var object = this.object.toHTML(options);\n\n if (needParenthesis(this.object)) {\n object = '(' + object + ')';\n }\n\n return object + this.index.toHTML(options);\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string}\n */\n\n\n AccessorNode.prototype._toTex = function (options) {\n var object = this.object.toTex(options);\n\n if (needParenthesis(this.object)) {\n object = '\\\\left(\\' + object + \\'\\\\right)';\n }\n\n return object + this.index.toTex(options);\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n AccessorNode.prototype.toJSON = function () {\n return {\n mathjs: 'AccessorNode',\n object: this.object,\n index: this.index\n };\n };\n /**\n * Instantiate an AccessorNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"AccessorNode\", object: ..., index: ...}`,\n * where mathjs is optional\n * @returns {AccessorNode}\n */\n\n\n AccessorNode.fromJSON = function (json) {\n return new AccessorNode(json.object, json.index);\n };\n /**\n * Are parenthesis needed?\n * @private\n */\n\n\n function needParenthesis(node) {\n // TODO: maybe make a method on the nodes which tells whether they need parenthesis?\n return !((0, _is.isAccessorNode)(node) || (0, _is.isArrayNode)(node) || (0, _is.isConstantNode)(node) || (0, _is.isFunctionNode)(node) || (0, _is.isObjectNode)(node) || (0, _is.isParenthesisNode)(node) || (0, _is.isSymbolNode)(node));\n }\n\n return AccessorNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createAccessorNode = createAccessorNode;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createArrayNode = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'ArrayNode';\nvar dependencies = ['Node'];\nvar createArrayNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var Node = _ref.Node;\n\n /**\n * @constructor ArrayNode\n * @extends {Node}\n * Holds an 1-dimensional array with items\n * @param {Node[]} [items] 1 dimensional array with items\n */\n function ArrayNode(items) {\n if (!(this instanceof ArrayNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n this.items = items || []; // validate input\n\n if (!Array.isArray(this.items) || !this.items.every(_is.isNode)) {\n throw new TypeError('Array containing Nodes expected');\n }\n }\n\n ArrayNode.prototype = new Node();\n ArrayNode.prototype.type = 'ArrayNode';\n ArrayNode.prototype.isArrayNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n ArrayNode.prototype._compile = function (math, argNames) {\n var evalItems = (0, _array.map)(this.items, function (item) {\n return item._compile(math, argNames);\n });\n var asMatrix = math.config.matrix !== 'Array';\n\n if (asMatrix) {\n var matrix = math.matrix;\n return function evalArrayNode(scope, args, context) {\n return matrix((0, _array.map)(evalItems, function (evalItem) {\n return evalItem(scope, args, context);\n }));\n };\n } else {\n return function evalArrayNode(scope, args, context) {\n return (0, _array.map)(evalItems, function (evalItem) {\n return evalItem(scope, args, context);\n });\n };\n }\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n ArrayNode.prototype.forEach = function (callback) {\n for (var i = 0; i < this.items.length; i++) {\n var node = this.items[i];\n callback(node, 'items[' + i + ']', this);\n }\n };\n /**\n * Create a new ArrayNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {ArrayNode} Returns a transformed copy of the node\n */\n\n\n ArrayNode.prototype.map = function (callback) {\n var items = [];\n\n for (var i = 0; i < this.items.length; i++) {\n items[i] = this._ifNode(callback(this.items[i], 'items[' + i + ']', this));\n }\n\n return new ArrayNode(items);\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {ArrayNode}\n */\n\n\n ArrayNode.prototype.clone = function () {\n return new ArrayNode(this.items.slice(0));\n };\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n\n ArrayNode.prototype._toString = function (options) {\n var items = this.items.map(function (node) {\n return node.toString(options);\n });\n return '[' + items.join(', ') + ']';\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n ArrayNode.prototype.toJSON = function () {\n return {\n mathjs: 'ArrayNode',\n items: this.items\n };\n };\n /**\n * Instantiate an ArrayNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"ArrayNode\", items: [...]}`,\n * where mathjs is optional\n * @returns {ArrayNode}\n */\n\n\n ArrayNode.fromJSON = function (json) {\n return new ArrayNode(json.items);\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n\n ArrayNode.prototype.toHTML = function (options) {\n var items = this.items.map(function (node) {\n return node.toHTML(options);\n });\n return '[' + items.join(',') + ']';\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n ArrayNode.prototype._toTex = function (options) {\n function itemsToTex(items, nested) {\n var mixedItems = items.some(_is.isArrayNode) && !items.every(_is.isArrayNode);\n var itemsFormRow = nested || mixedItems;\n var itemSep = itemsFormRow ? '&' : '\\\\\\\\';\n var itemsTex = items.map(function (node) {\n if (node.items) {\n return itemsToTex(node.items, !nested);\n } else {\n return node.toTex(options);\n }\n }).join(itemSep);\n return mixedItems || !itemsFormRow || itemsFormRow && !nested ? '\\\\begin{bmatrix}' + itemsTex + '\\\\end{bmatrix}' : itemsTex;\n }\n\n return itemsToTex(this.items, false);\n };\n\n return ArrayNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createArrayNode = createArrayNode;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAssignmentNode = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _customs = require(\"../../utils/customs.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _access = require(\"./utils/access.js\");\n\nvar _assign = require(\"./utils/assign.js\");\n\nvar _operators = require(\"../operators.js\");\n\nvar name = 'AssignmentNode';\nvar dependencies = ['subset', '?matrix', // FIXME: should not be needed at all, should be handled by subset\n'Node'];\nvar createAssignmentNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var subset = _ref.subset,\n matrix = _ref.matrix,\n Node = _ref.Node;\n var access = (0, _access.accessFactory)({\n subset: subset\n });\n var assign = (0, _assign.assignFactory)({\n subset: subset,\n matrix: matrix\n });\n /**\n * @constructor AssignmentNode\n * @extends {Node}\n *\n * Define a symbol, like `a=3.2`, update a property like `a.b=3.2`, or\n * replace a subset of a matrix like `A[2,2]=42`.\n *\n * Syntax:\n *\n * new AssignmentNode(symbol, value)\n * new AssignmentNode(object, index, value)\n *\n * Usage:\n *\n * new AssignmentNode(new SymbolNode('a'), new ConstantNode(2)) // a=2\n * new AssignmentNode(new SymbolNode('a'), new IndexNode('b'), new ConstantNode(2)) // a.b=2\n * new AssignmentNode(new SymbolNode('a'), new IndexNode(1, 2), new ConstantNode(3)) // a[1,2]=3\n *\n * @param {SymbolNode | AccessorNode} object Object on which to assign a value\n * @param {IndexNode} [index=null] Index, property name or matrix\n * index. Optional. If not provided\n * and `object` is a SymbolNode,\n * the property is assigned to the\n * global scope.\n * @param {Node} value The value to be assigned\n */\n\n function AssignmentNode(object, index, value) {\n if (!(this instanceof AssignmentNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n this.object = object;\n this.index = value ? index : null;\n this.value = value || index; // validate input\n\n if (!(0, _is.isSymbolNode)(object) && !(0, _is.isAccessorNode)(object)) {\n throw new TypeError('SymbolNode or AccessorNode expected as \"object\"');\n }\n\n if ((0, _is.isSymbolNode)(object) && object.name === 'end') {\n throw new Error('Cannot assign to symbol \"end\"');\n }\n\n if (this.index && !(0, _is.isIndexNode)(this.index)) {\n // index is optional\n throw new TypeError('IndexNode expected as \"index\"');\n }\n\n if (!(0, _is.isNode)(this.value)) {\n throw new TypeError('Node expected as \"value\"');\n } // readonly property name\n\n\n Object.defineProperty(this, 'name', {\n get: function () {\n if (this.index) {\n return this.index.isObjectProperty() ? this.index.getObjectProperty() : '';\n } else {\n return this.object.name || '';\n }\n }.bind(this),\n set: function set() {\n throw new Error('Cannot assign a new name, name is read-only');\n }\n });\n }\n\n AssignmentNode.prototype = new Node();\n AssignmentNode.prototype.type = 'AssignmentNode';\n AssignmentNode.prototype.isAssignmentNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n AssignmentNode.prototype._compile = function (math, argNames) {\n var evalObject = this.object._compile(math, argNames);\n\n var evalIndex = this.index ? this.index._compile(math, argNames) : null;\n\n var evalValue = this.value._compile(math, argNames);\n\n var name = this.object.name;\n\n if (!this.index) {\n // apply a variable to the scope, for example `a=2`\n if (!(0, _is.isSymbolNode)(this.object)) {\n throw new TypeError('SymbolNode expected as object');\n }\n\n return function evalAssignmentNode(scope, args, context) {\n var value = evalValue(scope, args, context);\n scope.set(name, value);\n return value;\n };\n } else if (this.index.isObjectProperty()) {\n // apply an object property for example `a.b=2`\n var prop = this.index.getObjectProperty();\n return function evalAssignmentNode(scope, args, context) {\n var object = evalObject(scope, args, context);\n var value = evalValue(scope, args, context);\n (0, _customs.setSafeProperty)(object, prop, value);\n return value;\n };\n } else if ((0, _is.isSymbolNode)(this.object)) {\n // update a matrix subset, for example `a[2]=3`\n return function evalAssignmentNode(scope, args, context) {\n var childObject = evalObject(scope, args, context);\n var value = evalValue(scope, args, context);\n var index = evalIndex(scope, args, childObject); // Important: we pass childObject instead of context\n\n scope.set(name, assign(childObject, index, value));\n return value;\n };\n } else {\n // isAccessorNode(node.object) === true\n // update a matrix subset, for example `a.b[2]=3`\n // we will not use the compile function of the AccessorNode, but compile it\n // ourselves here as we need the parent object of the AccessorNode:\n // wee need to apply the updated object to parent object\n var evalParentObject = this.object.object._compile(math, argNames);\n\n if (this.object.index.isObjectProperty()) {\n var parentProp = this.object.index.getObjectProperty();\n return function evalAssignmentNode(scope, args, context) {\n var parent = evalParentObject(scope, args, context);\n var childObject = (0, _customs.getSafeProperty)(parent, parentProp);\n var index = evalIndex(scope, args, childObject); // Important: we pass childObject instead of context\n\n var value = evalValue(scope, args, context);\n (0, _customs.setSafeProperty)(parent, parentProp, assign(childObject, index, value));\n return value;\n };\n } else {\n // if some parameters use the 'end' parameter, we need to calculate the size\n var evalParentIndex = this.object.index._compile(math, argNames);\n\n return function evalAssignmentNode(scope, args, context) {\n var parent = evalParentObject(scope, args, context);\n var parentIndex = evalParentIndex(scope, args, parent); // Important: we pass parent instead of context\n\n var childObject = access(parent, parentIndex);\n var index = evalIndex(scope, args, childObject); // Important: we pass childObject instead of context\n\n var value = evalValue(scope, args, context);\n assign(parent, parentIndex, assign(childObject, index, value));\n return value;\n };\n }\n }\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n AssignmentNode.prototype.forEach = function (callback) {\n callback(this.object, 'object', this);\n\n if (this.index) {\n callback(this.index, 'index', this);\n }\n\n callback(this.value, 'value', this);\n };\n /**\n * Create a new AssignmentNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {AssignmentNode} Returns a transformed copy of the node\n */\n\n\n AssignmentNode.prototype.map = function (callback) {\n var object = this._ifNode(callback(this.object, 'object', this));\n\n var index = this.index ? this._ifNode(callback(this.index, 'index', this)) : null;\n\n var value = this._ifNode(callback(this.value, 'value', this));\n\n return new AssignmentNode(object, index, value);\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {AssignmentNode}\n */\n\n\n AssignmentNode.prototype.clone = function () {\n return new AssignmentNode(this.object, this.index, this.value);\n };\n /*\n * Is parenthesis needed?\n * @param {node} node\n * @param {string} [parenthesis='keep']\n * @private\n */\n\n\n function needParenthesis(node, parenthesis) {\n if (!parenthesis) {\n parenthesis = 'keep';\n }\n\n var precedence = (0, _operators.getPrecedence)(node, parenthesis);\n var exprPrecedence = (0, _operators.getPrecedence)(node.value, parenthesis);\n return parenthesis === 'all' || exprPrecedence !== null && exprPrecedence <= precedence;\n }\n /**\n * Get string representation\n * @param {Object} options\n * @return {string}\n */\n\n\n AssignmentNode.prototype._toString = function (options) {\n var object = this.object.toString(options);\n var index = this.index ? this.index.toString(options) : '';\n var value = this.value.toString(options);\n\n if (needParenthesis(this, options && options.parenthesis)) {\n value = '(' + value + ')';\n }\n\n return object + index + ' = ' + value;\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n AssignmentNode.prototype.toJSON = function () {\n return {\n mathjs: 'AssignmentNode',\n object: this.object,\n index: this.index,\n value: this.value\n };\n };\n /**\n * Instantiate an AssignmentNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"AssignmentNode\", object: ..., index: ..., value: ...}`,\n * where mathjs is optional\n * @returns {AssignmentNode}\n */\n\n\n AssignmentNode.fromJSON = function (json) {\n return new AssignmentNode(json.object, json.index, json.value);\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string}\n */\n\n\n AssignmentNode.prototype.toHTML = function (options) {\n var object = this.object.toHTML(options);\n var index = this.index ? this.index.toHTML(options) : '';\n var value = this.value.toHTML(options);\n\n if (needParenthesis(this, options && options.parenthesis)) {\n value = '(' + value + ')';\n }\n\n return object + index + '=' + value;\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string}\n */\n\n\n AssignmentNode.prototype._toTex = function (options) {\n var object = this.object.toTex(options);\n var index = this.index ? this.index.toTex(options) : '';\n var value = this.value.toTex(options);\n\n if (needParenthesis(this, options && options.parenthesis)) {\n value = \"\\\\left(\".concat(value, \"\\\\right)\");\n }\n\n return object + index + ':=' + value;\n };\n\n return AssignmentNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createAssignmentNode = createAssignmentNode;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createBlockNode = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'BlockNode';\nvar dependencies = ['ResultSet', 'Node'];\nvar createBlockNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var ResultSet = _ref.ResultSet,\n Node = _ref.Node;\n\n /**\n * @constructor BlockNode\n * @extends {Node}\n * Holds a set with blocks\n * @param {Array.<{node: Node} | {node: Node, visible: boolean}>} blocks\n * An array with blocks, where a block is constructed as an Object\n * with properties block, which is a Node, and visible, which is\n * a boolean. The property visible is optional and is true by default\n */\n function BlockNode(blocks) {\n if (!(this instanceof BlockNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n } // validate input, copy blocks\n\n\n if (!Array.isArray(blocks)) throw new Error('Array expected');\n this.blocks = blocks.map(function (block) {\n var node = block && block.node;\n var visible = block && block.visible !== undefined ? block.visible : true;\n if (!(0, _is.isNode)(node)) throw new TypeError('Property \"node\" must be a Node');\n if (typeof visible !== 'boolean') throw new TypeError('Property \"visible\" must be a boolean');\n return {\n node: node,\n visible: visible\n };\n });\n }\n\n BlockNode.prototype = new Node();\n BlockNode.prototype.type = 'BlockNode';\n BlockNode.prototype.isBlockNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n BlockNode.prototype._compile = function (math, argNames) {\n var evalBlocks = (0, _array.map)(this.blocks, function (block) {\n return {\n evaluate: block.node._compile(math, argNames),\n visible: block.visible\n };\n });\n return function evalBlockNodes(scope, args, context) {\n var results = [];\n (0, _array.forEach)(evalBlocks, function evalBlockNode(block) {\n var result = block.evaluate(scope, args, context);\n\n if (block.visible) {\n results.push(result);\n }\n });\n return new ResultSet(results);\n };\n };\n /**\n * Execute a callback for each of the child blocks of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n BlockNode.prototype.forEach = function (callback) {\n for (var i = 0; i < this.blocks.length; i++) {\n callback(this.blocks[i].node, 'blocks[' + i + '].node', this);\n }\n };\n /**\n * Create a new BlockNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {BlockNode} Returns a transformed copy of the node\n */\n\n\n BlockNode.prototype.map = function (callback) {\n var blocks = [];\n\n for (var i = 0; i < this.blocks.length; i++) {\n var block = this.blocks[i];\n\n var node = this._ifNode(callback(block.node, 'blocks[' + i + '].node', this));\n\n blocks[i] = {\n node: node,\n visible: block.visible\n };\n }\n\n return new BlockNode(blocks);\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {BlockNode}\n */\n\n\n BlockNode.prototype.clone = function () {\n var blocks = this.blocks.map(function (block) {\n return {\n node: block.node,\n visible: block.visible\n };\n });\n return new BlockNode(blocks);\n };\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n\n BlockNode.prototype._toString = function (options) {\n return this.blocks.map(function (param) {\n return param.node.toString(options) + (param.visible ? '' : ';');\n }).join('\\n');\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n BlockNode.prototype.toJSON = function () {\n return {\n mathjs: 'BlockNode',\n blocks: this.blocks\n };\n };\n /**\n * Instantiate an BlockNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"BlockNode\", blocks: [{node: ..., visible: false}, ...]}`,\n * where mathjs is optional\n * @returns {BlockNode}\n */\n\n\n BlockNode.fromJSON = function (json) {\n return new BlockNode(json.blocks);\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n\n BlockNode.prototype.toHTML = function (options) {\n return this.blocks.map(function (param) {\n return param.node.toHTML(options) + (param.visible ? '' : ';');\n }).join('
    ');\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n BlockNode.prototype._toTex = function (options) {\n return this.blocks.map(function (param) {\n return param.node.toTex(options) + (param.visible ? '' : ';');\n }).join('\\\\;\\\\;\\n');\n };\n\n return BlockNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createBlockNode = createBlockNode;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createConditionalNode = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _operators = require(\"../operators.js\");\n\nvar name = 'ConditionalNode';\nvar dependencies = ['Node'];\nvar createConditionalNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var Node = _ref.Node;\n\n /**\n * A lazy evaluating conditional operator: 'condition ? trueExpr : falseExpr'\n *\n * @param {Node} condition Condition, must result in a boolean\n * @param {Node} trueExpr Expression evaluated when condition is true\n * @param {Node} falseExpr Expression evaluated when condition is true\n *\n * @constructor ConditionalNode\n * @extends {Node}\n */\n function ConditionalNode(condition, trueExpr, falseExpr) {\n if (!(this instanceof ConditionalNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n if (!(0, _is.isNode)(condition)) throw new TypeError('Parameter condition must be a Node');\n if (!(0, _is.isNode)(trueExpr)) throw new TypeError('Parameter trueExpr must be a Node');\n if (!(0, _is.isNode)(falseExpr)) throw new TypeError('Parameter falseExpr must be a Node');\n this.condition = condition;\n this.trueExpr = trueExpr;\n this.falseExpr = falseExpr;\n }\n\n ConditionalNode.prototype = new Node();\n ConditionalNode.prototype.type = 'ConditionalNode';\n ConditionalNode.prototype.isConditionalNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n ConditionalNode.prototype._compile = function (math, argNames) {\n var evalCondition = this.condition._compile(math, argNames);\n\n var evalTrueExpr = this.trueExpr._compile(math, argNames);\n\n var evalFalseExpr = this.falseExpr._compile(math, argNames);\n\n return function evalConditionalNode(scope, args, context) {\n return testCondition(evalCondition(scope, args, context)) ? evalTrueExpr(scope, args, context) : evalFalseExpr(scope, args, context);\n };\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n ConditionalNode.prototype.forEach = function (callback) {\n callback(this.condition, 'condition', this);\n callback(this.trueExpr, 'trueExpr', this);\n callback(this.falseExpr, 'falseExpr', this);\n };\n /**\n * Create a new ConditionalNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {ConditionalNode} Returns a transformed copy of the node\n */\n\n\n ConditionalNode.prototype.map = function (callback) {\n return new ConditionalNode(this._ifNode(callback(this.condition, 'condition', this)), this._ifNode(callback(this.trueExpr, 'trueExpr', this)), this._ifNode(callback(this.falseExpr, 'falseExpr', this)));\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {ConditionalNode}\n */\n\n\n ConditionalNode.prototype.clone = function () {\n return new ConditionalNode(this.condition, this.trueExpr, this.falseExpr);\n };\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n ConditionalNode.prototype._toString = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var precedence = (0, _operators.getPrecedence)(this, parenthesis); // Enclose Arguments in parentheses if they are an OperatorNode\n // or have lower or equal precedence\n // NOTE: enclosing all OperatorNodes in parentheses is a decision\n // purely based on aesthetics and readability\n\n var condition = this.condition.toString(options);\n var conditionPrecedence = (0, _operators.getPrecedence)(this.condition, parenthesis);\n\n if (parenthesis === 'all' || this.condition.type === 'OperatorNode' || conditionPrecedence !== null && conditionPrecedence <= precedence) {\n condition = '(' + condition + ')';\n }\n\n var trueExpr = this.trueExpr.toString(options);\n var truePrecedence = (0, _operators.getPrecedence)(this.trueExpr, parenthesis);\n\n if (parenthesis === 'all' || this.trueExpr.type === 'OperatorNode' || truePrecedence !== null && truePrecedence <= precedence) {\n trueExpr = '(' + trueExpr + ')';\n }\n\n var falseExpr = this.falseExpr.toString(options);\n var falsePrecedence = (0, _operators.getPrecedence)(this.falseExpr, parenthesis);\n\n if (parenthesis === 'all' || this.falseExpr.type === 'OperatorNode' || falsePrecedence !== null && falsePrecedence <= precedence) {\n falseExpr = '(' + falseExpr + ')';\n }\n\n return condition + ' ? ' + trueExpr + ' : ' + falseExpr;\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n ConditionalNode.prototype.toJSON = function () {\n return {\n mathjs: 'ConditionalNode',\n condition: this.condition,\n trueExpr: this.trueExpr,\n falseExpr: this.falseExpr\n };\n };\n /**\n * Instantiate an ConditionalNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"ConditionalNode\", \"condition\": ..., \"trueExpr\": ..., \"falseExpr\": ...}`,\n * where mathjs is optional\n * @returns {ConditionalNode}\n */\n\n\n ConditionalNode.fromJSON = function (json) {\n return new ConditionalNode(json.condition, json.trueExpr, json.falseExpr);\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n ConditionalNode.prototype.toHTML = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var precedence = (0, _operators.getPrecedence)(this, parenthesis); // Enclose Arguments in parentheses if they are an OperatorNode\n // or have lower or equal precedence\n // NOTE: enclosing all OperatorNodes in parentheses is a decision\n // purely based on aesthetics and readability\n\n var condition = this.condition.toHTML(options);\n var conditionPrecedence = (0, _operators.getPrecedence)(this.condition, parenthesis);\n\n if (parenthesis === 'all' || this.condition.type === 'OperatorNode' || conditionPrecedence !== null && conditionPrecedence <= precedence) {\n condition = '(' + condition + ')';\n }\n\n var trueExpr = this.trueExpr.toHTML(options);\n var truePrecedence = (0, _operators.getPrecedence)(this.trueExpr, parenthesis);\n\n if (parenthesis === 'all' || this.trueExpr.type === 'OperatorNode' || truePrecedence !== null && truePrecedence <= precedence) {\n trueExpr = '(' + trueExpr + ')';\n }\n\n var falseExpr = this.falseExpr.toHTML(options);\n var falsePrecedence = (0, _operators.getPrecedence)(this.falseExpr, parenthesis);\n\n if (parenthesis === 'all' || this.falseExpr.type === 'OperatorNode' || falsePrecedence !== null && falsePrecedence <= precedence) {\n falseExpr = '(' + falseExpr + ')';\n }\n\n return condition + '?' + trueExpr + ':' + falseExpr;\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n ConditionalNode.prototype._toTex = function (options) {\n return '\\\\begin{cases} {' + this.trueExpr.toTex(options) + '}, &\\\\quad{\\\\text{if }\\\\;' + this.condition.toTex(options) + '}\\\\\\\\{' + this.falseExpr.toTex(options) + '}, &\\\\quad{\\\\text{otherwise}}\\\\end{cases}';\n };\n /**\n * Test whether a condition is met\n * @param {*} condition\n * @returns {boolean} true if condition is true or non-zero, else false\n */\n\n\n function testCondition(condition) {\n if (typeof condition === 'number' || typeof condition === 'boolean' || typeof condition === 'string') {\n return !!condition;\n }\n\n if (condition) {\n if ((0, _is.isBigNumber)(condition)) {\n return !condition.isZero();\n }\n\n if ((0, _is.isComplex)(condition)) {\n return !!(condition.re || condition.im);\n }\n\n if ((0, _is.isUnit)(condition)) {\n return !!condition.value;\n }\n }\n\n if (condition === null || condition === undefined) {\n return false;\n }\n\n throw new TypeError('Unsupported type of condition \"' + (0, _is.typeOf)(condition) + '\"');\n }\n\n return ConditionalNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createConditionalNode = createConditionalNode;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createConstantNode = void 0;\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _latex = require(\"../../utils/latex.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'ConstantNode';\nvar dependencies = ['Node'];\nvar createConstantNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var Node = _ref.Node;\n\n /**\n * A ConstantNode holds a constant value like a number or string.\n *\n * Usage:\n *\n * new ConstantNode(2.3)\n * new ConstantNode('hello')\n *\n * @param {*} value Value can be any type (number, BigNumber, string, ...)\n * @constructor ConstantNode\n * @extends {Node}\n */\n function ConstantNode(value) {\n if (!(this instanceof ConstantNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n this.value = value;\n }\n\n ConstantNode.prototype = new Node();\n ConstantNode.prototype.type = 'ConstantNode';\n ConstantNode.prototype.isConstantNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n ConstantNode.prototype._compile = function (math, argNames) {\n var value = this.value;\n return function evalConstantNode() {\n return value;\n };\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n ConstantNode.prototype.forEach = function (callback) {// nothing to do, we don't have childs\n };\n /**\n * Create a new ConstantNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node) : Node} callback\n * @returns {ConstantNode} Returns a clone of the node\n */\n\n\n ConstantNode.prototype.map = function (callback) {\n return this.clone();\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {ConstantNode}\n */\n\n\n ConstantNode.prototype.clone = function () {\n return new ConstantNode(this.value);\n };\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n ConstantNode.prototype._toString = function (options) {\n return (0, _string.format)(this.value, options);\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n ConstantNode.prototype.toHTML = function (options) {\n var value = this._toString(options);\n\n switch ((0, _is.typeOf)(this.value)) {\n case 'number':\n case 'BigNumber':\n case 'Fraction':\n return '' + value + '';\n\n case 'string':\n return '' + value + '';\n\n case 'boolean':\n return '' + value + '';\n\n case 'null':\n return '' + value + '';\n\n case 'undefined':\n return '' + value + '';\n\n default:\n return '' + value + '';\n }\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n ConstantNode.prototype.toJSON = function () {\n return {\n mathjs: 'ConstantNode',\n value: this.value\n };\n };\n /**\n * Instantiate a ConstantNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"SymbolNode\", value: 2.3}`,\n * where mathjs is optional\n * @returns {ConstantNode}\n */\n\n\n ConstantNode.fromJSON = function (json) {\n return new ConstantNode(json.value);\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n ConstantNode.prototype._toTex = function (options) {\n var value = this._toString(options);\n\n switch ((0, _is.typeOf)(this.value)) {\n case 'string':\n return '\\\\mathtt{' + (0, _latex.escapeLatex)(value) + '}';\n\n case 'number':\n case 'BigNumber':\n {\n if (!isFinite(this.value)) {\n return this.value.valueOf() < 0 ? '-\\\\infty' : '\\\\infty';\n }\n\n var index = value.toLowerCase().indexOf('e');\n\n if (index !== -1) {\n return value.substring(0, index) + '\\\\cdot10^{' + value.substring(index + 1) + '}';\n }\n }\n return value;\n\n case 'Fraction':\n return this.value.toLatex();\n\n default:\n return value;\n }\n };\n\n return ConstantNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createConstantNode = createConstantNode;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFunctionAssignmentNode = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _keywords = require(\"../keywords.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _latex = require(\"../../utils/latex.js\");\n\nvar _operators = require(\"../operators.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'FunctionAssignmentNode';\nvar dependencies = ['typed', 'Node'];\nvar createFunctionAssignmentNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Node = _ref.Node;\n\n /**\n * @constructor FunctionAssignmentNode\n * @extends {Node}\n * Function assignment\n *\n * @param {string} name Function name\n * @param {string[] | Array.<{name: string, type: string}>} params\n * Array with function parameter names, or an\n * array with objects containing the name\n * and type of the parameter\n * @param {Node} expr The function expression\n */\n function FunctionAssignmentNode(name, params, expr) {\n if (!(this instanceof FunctionAssignmentNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n } // validate input\n\n\n if (typeof name !== 'string') throw new TypeError('String expected for parameter \"name\"');\n if (!Array.isArray(params)) throw new TypeError('Array containing strings or objects expected for parameter \"params\"');\n if (!(0, _is.isNode)(expr)) throw new TypeError('Node expected for parameter \"expr\"');\n if (_keywords.keywords.has(name)) throw new Error('Illegal function name, \"' + name + '\" is a reserved keyword');\n this.name = name;\n this.params = params.map(function (param) {\n return param && param.name || param;\n });\n this.types = params.map(function (param) {\n return param && param.type || 'any';\n });\n this.expr = expr;\n }\n\n FunctionAssignmentNode.prototype = new Node();\n FunctionAssignmentNode.prototype.type = 'FunctionAssignmentNode';\n FunctionAssignmentNode.prototype.isFunctionAssignmentNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n FunctionAssignmentNode.prototype._compile = function (math, argNames) {\n var childArgNames = Object.create(argNames);\n (0, _array.forEach)(this.params, function (param) {\n childArgNames[param] = true;\n }); // compile the function expression with the child args\n\n var evalExpr = this.expr._compile(math, childArgNames);\n\n var name = this.name;\n var params = this.params;\n var signature = (0, _array.join)(this.types, ',');\n var syntax = name + '(' + (0, _array.join)(this.params, ', ') + ')';\n return function evalFunctionAssignmentNode(scope, args, context) {\n var signatures = {};\n\n signatures[signature] = function () {\n var childArgs = Object.create(args);\n\n for (var i = 0; i < params.length; i++) {\n childArgs[params[i]] = arguments[i];\n }\n\n return evalExpr(scope, childArgs, context);\n };\n\n var fn = typed(name, signatures);\n fn.syntax = syntax;\n scope.set(name, fn);\n return fn;\n };\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n FunctionAssignmentNode.prototype.forEach = function (callback) {\n callback(this.expr, 'expr', this);\n };\n /**\n * Create a new FunctionAssignmentNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {FunctionAssignmentNode} Returns a transformed copy of the node\n */\n\n\n FunctionAssignmentNode.prototype.map = function (callback) {\n var expr = this._ifNode(callback(this.expr, 'expr', this));\n\n return new FunctionAssignmentNode(this.name, this.params.slice(0), expr);\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {FunctionAssignmentNode}\n */\n\n\n FunctionAssignmentNode.prototype.clone = function () {\n return new FunctionAssignmentNode(this.name, this.params.slice(0), this.expr);\n };\n /**\n * Is parenthesis needed?\n * @param {Node} node\n * @param {Object} parenthesis\n * @private\n */\n\n\n function needParenthesis(node, parenthesis) {\n var precedence = (0, _operators.getPrecedence)(node, parenthesis);\n var exprPrecedence = (0, _operators.getPrecedence)(node.expr, parenthesis);\n return parenthesis === 'all' || exprPrecedence !== null && exprPrecedence <= precedence;\n }\n /**\n * get string representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n FunctionAssignmentNode.prototype._toString = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var expr = this.expr.toString(options);\n\n if (needParenthesis(this, parenthesis)) {\n expr = '(' + expr + ')';\n }\n\n return this.name + '(' + this.params.join(', ') + ') = ' + expr;\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n FunctionAssignmentNode.prototype.toJSON = function () {\n var types = this.types;\n return {\n mathjs: 'FunctionAssignmentNode',\n name: this.name,\n params: this.params.map(function (param, index) {\n return {\n name: param,\n type: types[index]\n };\n }),\n expr: this.expr\n };\n };\n /**\n * Instantiate an FunctionAssignmentNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"FunctionAssignmentNode\", name: ..., params: ..., expr: ...}`,\n * where mathjs is optional\n * @returns {FunctionAssignmentNode}\n */\n\n\n FunctionAssignmentNode.fromJSON = function (json) {\n return new FunctionAssignmentNode(json.name, json.params, json.expr);\n };\n /**\n * get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n FunctionAssignmentNode.prototype.toHTML = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var params = [];\n\n for (var i = 0; i < this.params.length; i++) {\n params.push('' + (0, _string.escape)(this.params[i]) + '');\n }\n\n var expr = this.expr.toHTML(options);\n\n if (needParenthesis(this, parenthesis)) {\n expr = '(' + expr + ')';\n }\n\n return '' + (0, _string.escape)(this.name) + '' + '(' + params.join(',') + ')=' + expr;\n };\n /**\n * get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n FunctionAssignmentNode.prototype._toTex = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var expr = this.expr.toTex(options);\n\n if (needParenthesis(this, parenthesis)) {\n expr = \"\\\\left(\".concat(expr, \"\\\\right)\");\n }\n\n return '\\\\mathrm{' + this.name + '}\\\\left(' + this.params.map(_latex.toSymbol).join(',') + '\\\\right):=' + expr;\n };\n\n return FunctionAssignmentNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createFunctionAssignmentNode = createFunctionAssignmentNode;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFunctionNode = void 0;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _customs = require(\"../../utils/customs.js\");\n\nvar _scope = require(\"../../utils/scope.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _latex = require(\"../../utils/latex.js\");\n\nvar name = 'FunctionNode';\nvar dependencies = ['math', 'Node', 'SymbolNode'];\nvar createFunctionNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var math = _ref.math,\n Node = _ref.Node,\n SymbolNode = _ref.SymbolNode;\n\n /**\n * @constructor FunctionNode\n * @extends {./Node}\n * invoke a list with arguments on a node\n * @param {./Node | string} fn Node resolving with a function on which to invoke\n * the arguments, typically a SymboNode or AccessorNode\n * @param {./Node[]} args\n */\n function FunctionNode(fn, args) {\n if (!(this instanceof FunctionNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n if (typeof fn === 'string') {\n fn = new SymbolNode(fn);\n } // validate input\n\n\n if (!(0, _is.isNode)(fn)) throw new TypeError('Node expected as parameter \"fn\"');\n\n if (!Array.isArray(args) || !args.every(_is.isNode)) {\n throw new TypeError('Array containing Nodes expected for parameter \"args\"');\n }\n\n this.fn = fn;\n this.args = args || []; // readonly property name\n\n Object.defineProperty(this, 'name', {\n get: function () {\n return this.fn.name || '';\n }.bind(this),\n set: function set() {\n throw new Error('Cannot assign a new name, name is read-only');\n }\n });\n }\n\n FunctionNode.prototype = new Node();\n FunctionNode.prototype.type = 'FunctionNode';\n FunctionNode.prototype.isFunctionNode = true;\n /* format to fixed length */\n\n var strin = function strin(entity) {\n return (0, _string.format)(entity, {\n truncate: 78\n });\n };\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n\n FunctionNode.prototype._compile = function (math, argNames) {\n if (!(this instanceof FunctionNode)) {\n throw new TypeError('No valid FunctionNode');\n } // compile arguments\n\n\n var evalArgs = this.args.map(function (arg) {\n return arg._compile(math, argNames);\n });\n\n if ((0, _is.isSymbolNode)(this.fn)) {\n var _name = this.fn.name;\n\n if (!argNames[_name]) {\n // we can statically determine whether the function has an rawArgs property\n var fn = _name in math ? (0, _customs.getSafeProperty)(math, _name) : undefined;\n var isRaw = typeof fn === 'function' && fn.rawArgs === true;\n\n var resolveFn = function resolveFn(scope) {\n var value;\n\n if (scope.has(_name)) {\n value = scope.get(_name);\n } else if (_name in math) {\n value = (0, _customs.getSafeProperty)(math, _name);\n } else {\n return FunctionNode.onUndefinedFunction(_name);\n }\n\n if (typeof value === 'function') {\n return value;\n }\n\n throw new TypeError(\"'\".concat(_name, \"' is not a function; its value is:\\n \").concat(strin(value)));\n };\n\n if (isRaw) {\n // pass unevaluated parameters (nodes) to the function\n // \"raw\" evaluation\n var rawArgs = this.args;\n return function evalFunctionNode(scope, args, context) {\n var fn = resolveFn(scope);\n return fn(rawArgs, math, (0, _scope.createSubScope)(scope, args), scope);\n };\n } else {\n // \"regular\" evaluation\n switch (evalArgs.length) {\n case 0:\n return function evalFunctionNode(scope, args, context) {\n var fn = resolveFn(scope);\n return fn();\n };\n\n case 1:\n return function evalFunctionNode(scope, args, context) {\n var fn = resolveFn(scope);\n var evalArg0 = evalArgs[0];\n return fn(evalArg0(scope, args, context));\n };\n\n case 2:\n return function evalFunctionNode(scope, args, context) {\n var fn = resolveFn(scope);\n var evalArg0 = evalArgs[0];\n var evalArg1 = evalArgs[1];\n return fn(evalArg0(scope, args, context), evalArg1(scope, args, context));\n };\n\n default:\n return function evalFunctionNode(scope, args, context) {\n var fn = resolveFn(scope);\n var values = evalArgs.map(function (evalArg) {\n return evalArg(scope, args, context);\n });\n return fn.apply(void 0, (0, _toConsumableArray2.default)(values));\n };\n }\n }\n } else {\n // the function symbol is an argName\n var _rawArgs = this.args;\n return function evalFunctionNode(scope, args, context) {\n var fn = args[_name];\n\n if (typeof fn !== 'function') {\n throw new TypeError(\"Argument '\".concat(_name, \"' was not a function; received: \").concat(strin(fn)));\n }\n\n if (fn.rawArgs) {\n return fn(_rawArgs, math, (0, _scope.createSubScope)(scope, args), scope); // \"raw\" evaluation\n } else {\n var values = evalArgs.map(function (evalArg) {\n return evalArg(scope, args, context);\n });\n return fn.apply(fn, values);\n }\n };\n }\n } else if ((0, _is.isAccessorNode)(this.fn) && (0, _is.isIndexNode)(this.fn.index) && this.fn.index.isObjectProperty()) {\n // execute the function with the right context: the object of the AccessorNode\n var evalObject = this.fn.object._compile(math, argNames);\n\n var prop = this.fn.index.getObjectProperty();\n var _rawArgs2 = this.args;\n return function evalFunctionNode(scope, args, context) {\n var object = evalObject(scope, args, context);\n (0, _customs.validateSafeMethod)(object, prop);\n var isRaw = object[prop] && object[prop].rawArgs;\n\n if (isRaw) {\n return object[prop](_rawArgs2, math, (0, _scope.createSubScope)(scope, args), scope); // \"raw\" evaluation\n } else {\n // \"regular\" evaluation\n var values = evalArgs.map(function (evalArg) {\n return evalArg(scope, args, context);\n });\n return object[prop].apply(object, values);\n }\n };\n } else {\n // node.fn.isAccessorNode && !node.fn.index.isObjectProperty()\n // we have to dynamically determine whether the function has a rawArgs property\n var fnExpr = this.fn.toString();\n\n var evalFn = this.fn._compile(math, argNames);\n\n var _rawArgs3 = this.args;\n return function evalFunctionNode(scope, args, context) {\n var fn = evalFn(scope, args, context);\n\n if (typeof fn !== 'function') {\n throw new TypeError(\"Expression '\".concat(fnExpr, \"' did not evaluate to a function; value is:\") + \"\\n \".concat(strin(fn)));\n }\n\n if (fn.rawArgs) {\n return fn(_rawArgs3, math, (0, _scope.createSubScope)(scope, args), scope); // \"raw\" evaluation\n } else {\n // \"regular\" evaluation\n var values = evalArgs.map(function (evalArg) {\n return evalArg(scope, args, context);\n });\n return fn.apply(fn, values);\n }\n };\n }\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n FunctionNode.prototype.forEach = function (callback) {\n callback(this.fn, 'fn', this);\n\n for (var i = 0; i < this.args.length; i++) {\n callback(this.args[i], 'args[' + i + ']', this);\n }\n };\n /**\n * Create a new FunctionNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {FunctionNode} Returns a transformed copy of the node\n */\n\n\n FunctionNode.prototype.map = function (callback) {\n var fn = this._ifNode(callback(this.fn, 'fn', this));\n\n var args = [];\n\n for (var i = 0; i < this.args.length; i++) {\n args[i] = this._ifNode(callback(this.args[i], 'args[' + i + ']', this));\n }\n\n return new FunctionNode(fn, args);\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {FunctionNode}\n */\n\n\n FunctionNode.prototype.clone = function () {\n return new FunctionNode(this.fn, this.args.slice(0));\n };\n /**\n * Throws an error 'Undefined function {name}'\n * @param {string} name\n */\n\n\n FunctionNode.onUndefinedFunction = function (name) {\n throw new Error('Undefined function ' + name);\n }; // backup Node's toString function\n // @private\n\n\n var nodeToString = FunctionNode.prototype.toString;\n /**\n * Get string representation. (wrapper function)\n * This overrides parts of Node's toString function.\n * If callback is an object containing callbacks, it\n * calls the correct callback for the current node,\n * otherwise it falls back to calling Node's toString\n * function.\n *\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n FunctionNode.prototype.toString = function (options) {\n var customString;\n var name = this.fn.toString(options);\n\n if (options && (0, _typeof2.default)(options.handler) === 'object' && (0, _object.hasOwnProperty)(options.handler, name)) {\n // callback is a map of callback functions\n customString = options.handler[name](this, options);\n }\n\n if (typeof customString !== 'undefined') {\n return customString;\n } // fall back to Node's toString\n\n\n return nodeToString.call(this, options);\n };\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n FunctionNode.prototype._toString = function (options) {\n var args = this.args.map(function (arg) {\n return arg.toString(options);\n });\n var fn = (0, _is.isFunctionAssignmentNode)(this.fn) ? '(' + this.fn.toString(options) + ')' : this.fn.toString(options); // format the arguments like \"add(2, 4.2)\"\n\n return fn + '(' + args.join(', ') + ')';\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n FunctionNode.prototype.toJSON = function () {\n return {\n mathjs: 'FunctionNode',\n fn: this.fn,\n args: this.args\n };\n };\n /**\n * Instantiate an AssignmentNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"FunctionNode\", fn: ..., args: ...}`,\n * where mathjs is optional\n * @returns {FunctionNode}\n */\n\n\n FunctionNode.fromJSON = function (json) {\n return new FunctionNode(json.fn, json.args);\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n FunctionNode.prototype.toHTML = function (options) {\n var args = this.args.map(function (arg) {\n return arg.toHTML(options);\n }); // format the arguments like \"add(2, 4.2)\"\n\n return '' + (0, _string.escape)(this.fn) + '(' + args.join(',') + ')';\n };\n /*\n * Expand a LaTeX template\n *\n * @param {string} template\n * @param {Node} node\n * @param {Object} options\n * @private\n **/\n\n\n function expandTemplate(template, node, options) {\n var latex = ''; // Match everything of the form ${identifier} or ${identifier[2]} or $$\n // while submatching identifier and 2 (in the second case)\n\n var regex = /\\$(?:\\{([a-z_][a-z_0-9]*)(?:\\[([0-9]+)\\])?\\}|\\$)/gi;\n var inputPos = 0; // position in the input string\n\n var match;\n\n while ((match = regex.exec(template)) !== null) {\n // go through all matches\n // add everything in front of the match to the LaTeX string\n latex += template.substring(inputPos, match.index);\n inputPos = match.index;\n\n if (match[0] === '$$') {\n // escaped dollar sign\n latex += '$';\n inputPos++;\n } else {\n // template parameter\n inputPos += match[0].length;\n var property = node[match[1]];\n\n if (!property) {\n throw new ReferenceError('Template: Property ' + match[1] + ' does not exist.');\n }\n\n if (match[2] === undefined) {\n // no square brackets\n switch ((0, _typeof2.default)(property)) {\n case 'string':\n latex += property;\n break;\n\n case 'object':\n if ((0, _is.isNode)(property)) {\n latex += property.toTex(options);\n } else if (Array.isArray(property)) {\n // make array of Nodes into comma separated list\n latex += property.map(function (arg, index) {\n if ((0, _is.isNode)(arg)) {\n return arg.toTex(options);\n }\n\n throw new TypeError('Template: ' + match[1] + '[' + index + '] is not a Node.');\n }).join(',');\n } else {\n throw new TypeError('Template: ' + match[1] + ' has to be a Node, String or array of Nodes');\n }\n\n break;\n\n default:\n throw new TypeError('Template: ' + match[1] + ' has to be a Node, String or array of Nodes');\n }\n } else {\n // with square brackets\n if ((0, _is.isNode)(property[match[2]] && property[match[2]])) {\n latex += property[match[2]].toTex(options);\n } else {\n throw new TypeError('Template: ' + match[1] + '[' + match[2] + '] is not a Node.');\n }\n }\n }\n }\n\n latex += template.slice(inputPos); // append rest of the template\n\n return latex;\n } // backup Node's toTex function\n // @private\n\n\n var nodeToTex = FunctionNode.prototype.toTex;\n /**\n * Get LaTeX representation. (wrapper function)\n * This overrides parts of Node's toTex function.\n * If callback is an object containing callbacks, it\n * calls the correct callback for the current node,\n * otherwise it falls back to calling Node's toTex\n * function.\n *\n * @param {Object} options\n * @return {string}\n */\n\n FunctionNode.prototype.toTex = function (options) {\n var customTex;\n\n if (options && (0, _typeof2.default)(options.handler) === 'object' && (0, _object.hasOwnProperty)(options.handler, this.name)) {\n // callback is a map of callback functions\n customTex = options.handler[this.name](this, options);\n }\n\n if (typeof customTex !== 'undefined') {\n return customTex;\n } // fall back to Node's toTex\n\n\n return nodeToTex.call(this, options);\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n FunctionNode.prototype._toTex = function (options) {\n var args = this.args.map(function (arg) {\n // get LaTeX of the arguments\n return arg.toTex(options);\n });\n var latexConverter;\n\n if (_latex.latexFunctions[this.name]) {\n latexConverter = _latex.latexFunctions[this.name];\n } // toTex property on the function itself\n\n\n if (math[this.name] && (typeof math[this.name].toTex === 'function' || (0, _typeof2.default)(math[this.name].toTex) === 'object' || typeof math[this.name].toTex === 'string')) {\n // .toTex is a callback function\n latexConverter = math[this.name].toTex;\n }\n\n var customToTex;\n\n switch ((0, _typeof2.default)(latexConverter)) {\n case 'function':\n // a callback function\n customToTex = latexConverter(this, options);\n break;\n\n case 'string':\n // a template string\n customToTex = expandTemplate(latexConverter, this, options);\n break;\n\n case 'object':\n // an object with different \"converters\" for different numbers of arguments\n switch ((0, _typeof2.default)(latexConverter[args.length])) {\n case 'function':\n customToTex = latexConverter[args.length](this, options);\n break;\n\n case 'string':\n customToTex = expandTemplate(latexConverter[args.length], this, options);\n break;\n }\n\n }\n\n if (typeof customToTex !== 'undefined') {\n return customToTex;\n }\n\n return expandTemplate(_latex.defaultTemplate, this, options);\n };\n /**\n * Get identifier.\n * @return {string}\n */\n\n\n FunctionNode.prototype.getIdentifier = function () {\n return this.type + ':' + this.name;\n };\n\n return FunctionNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createFunctionNode = createFunctionNode;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIndexNode = void 0;\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _customs = require(\"../../utils/customs.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar name = 'IndexNode';\nvar dependencies = ['Node', 'size'];\nvar createIndexNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var Node = _ref.Node,\n size = _ref.size;\n\n /**\n * @constructor IndexNode\n * @extends Node\n *\n * Describes a subset of a matrix or an object property.\n * Cannot be used on its own, needs to be used within an AccessorNode or\n * AssignmentNode.\n *\n * @param {Node[]} dimensions\n * @param {boolean} [dotNotation=false] Optional property describing whether\n * this index was written using dot\n * notation like `a.b`, or using bracket\n * notation like `a[\"b\"]` (default).\n * Used to stringify an IndexNode.\n */\n function IndexNode(dimensions, dotNotation) {\n if (!(this instanceof IndexNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n this.dimensions = dimensions;\n this.dotNotation = dotNotation || false; // validate input\n\n if (!Array.isArray(dimensions) || !dimensions.every(_is.isNode)) {\n throw new TypeError('Array containing Nodes expected for parameter \"dimensions\"');\n }\n\n if (this.dotNotation && !this.isObjectProperty()) {\n throw new Error('dotNotation only applicable for object properties');\n }\n }\n\n IndexNode.prototype = new Node();\n IndexNode.prototype.type = 'IndexNode';\n IndexNode.prototype.isIndexNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n IndexNode.prototype._compile = function (math, argNames) {\n // TODO: implement support for bignumber (currently bignumbers are silently\n // reduced to numbers when changing the value to zero-based)\n // TODO: Optimization: when the range values are ConstantNodes,\n // we can beforehand resolve the zero-based value\n // optimization for a simple object property\n var evalDimensions = (0, _array.map)(this.dimensions, function (dimension, i) {\n var needsEnd = dimension.filter(function (node) {\n return node.isSymbolNode && node.name === 'end';\n }).length > 0;\n\n if (needsEnd) {\n // SymbolNode 'end' is used inside the index,\n // like in `A[end]` or `A[end - 2]`\n var childArgNames = Object.create(argNames);\n childArgNames.end = true;\n\n var _evalDimension = dimension._compile(math, childArgNames);\n\n return function evalDimension(scope, args, context) {\n if (!(0, _is.isMatrix)(context) && !(0, _is.isArray)(context) && !(0, _is.isString)(context)) {\n throw new TypeError('Cannot resolve \"end\": ' + 'context must be a Matrix, Array, or string but is ' + (0, _is.typeOf)(context));\n }\n\n var s = size(context).valueOf();\n var childArgs = Object.create(args);\n childArgs.end = s[i];\n return _evalDimension(scope, childArgs, context);\n };\n } else {\n // SymbolNode `end` not used\n return dimension._compile(math, argNames);\n }\n });\n var index = (0, _customs.getSafeProperty)(math, 'index');\n return function evalIndexNode(scope, args, context) {\n var dimensions = (0, _array.map)(evalDimensions, function (evalDimension) {\n return evalDimension(scope, args, context);\n });\n return index.apply(void 0, (0, _toConsumableArray2.default)(dimensions));\n };\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n IndexNode.prototype.forEach = function (callback) {\n for (var i = 0; i < this.dimensions.length; i++) {\n callback(this.dimensions[i], 'dimensions[' + i + ']', this);\n }\n };\n /**\n * Create a new IndexNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {IndexNode} Returns a transformed copy of the node\n */\n\n\n IndexNode.prototype.map = function (callback) {\n var dimensions = [];\n\n for (var i = 0; i < this.dimensions.length; i++) {\n dimensions[i] = this._ifNode(callback(this.dimensions[i], 'dimensions[' + i + ']', this));\n }\n\n return new IndexNode(dimensions, this.dotNotation);\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {IndexNode}\n */\n\n\n IndexNode.prototype.clone = function () {\n return new IndexNode(this.dimensions.slice(0), this.dotNotation);\n };\n /**\n * Test whether this IndexNode contains a single property name\n * @return {boolean}\n */\n\n\n IndexNode.prototype.isObjectProperty = function () {\n return this.dimensions.length === 1 && (0, _is.isConstantNode)(this.dimensions[0]) && typeof this.dimensions[0].value === 'string';\n };\n /**\n * Returns the property name if IndexNode contains a property.\n * If not, returns null.\n * @return {string | null}\n */\n\n\n IndexNode.prototype.getObjectProperty = function () {\n return this.isObjectProperty() ? this.dimensions[0].value : null;\n };\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n IndexNode.prototype._toString = function (options) {\n // format the parameters like \"[1, 0:5]\"\n return this.dotNotation ? '.' + this.getObjectProperty() : '[' + this.dimensions.join(', ') + ']';\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n IndexNode.prototype.toJSON = function () {\n return {\n mathjs: 'IndexNode',\n dimensions: this.dimensions,\n dotNotation: this.dotNotation\n };\n };\n /**\n * Instantiate an IndexNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"IndexNode\", dimensions: [...], dotNotation: false}`,\n * where mathjs is optional\n * @returns {IndexNode}\n */\n\n\n IndexNode.fromJSON = function (json) {\n return new IndexNode(json.dimensions, json.dotNotation);\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n IndexNode.prototype.toHTML = function (options) {\n // format the parameters like \"[1, 0:5]\"\n var dimensions = [];\n\n for (var i = 0; i < this.dimensions.length; i++) {\n dimensions[i] = this.dimensions[i].toHTML();\n }\n\n if (this.dotNotation) {\n return '.' + '' + (0, _string.escape)(this.getObjectProperty()) + '';\n } else {\n return '[' + dimensions.join(',') + ']';\n }\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n IndexNode.prototype._toTex = function (options) {\n var dimensions = this.dimensions.map(function (range) {\n return range.toTex(options);\n });\n return this.dotNotation ? '.' + this.getObjectProperty() + '' : '_{' + dimensions.join(',') + '}';\n };\n\n return IndexNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createIndexNode = createIndexNode;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createNode = void 0;\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _keywords = require(\"../keywords.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _map = require(\"../../utils/map.js\");\n\nvar name = 'Node';\nvar dependencies = ['mathWithTransform'];\nvar createNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var mathWithTransform = _ref.mathWithTransform;\n\n /**\n * Node\n */\n function Node() {\n if (!(this instanceof Node)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n }\n /**\n * Evaluate the node\n * @param {Object} [scope] Scope to read/write variables\n * @return {*} Returns the result\n */\n\n\n Node.prototype.evaluate = function (scope) {\n return this.compile().evaluate(scope);\n };\n\n Node.prototype.type = 'Node';\n Node.prototype.isNode = true;\n Node.prototype.comment = '';\n /**\n * Compile the node into an optimized, evauatable JavaScript function\n * @return {{evaluate: function([Object])}} object\n * Returns an object with a function 'evaluate',\n * which can be invoked as expr.evaluate([scope: Object]),\n * where scope is an optional object with\n * variables.\n */\n\n Node.prototype.compile = function () {\n var expr = this._compile(mathWithTransform, {});\n\n var args = {};\n var context = null;\n\n function evaluate(scope) {\n var s = (0, _map.createMap)(scope);\n\n _validateScope(s);\n\n return expr(s, args, context);\n }\n\n return {\n evaluate: evaluate\n };\n };\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n\n Node.prototype._compile = function (math, argNames) {\n throw new Error('Method _compile should be implemented by type ' + this.type);\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n Node.prototype.forEach = function (callback) {\n // must be implemented by each of the Node implementations\n throw new Error('Cannot run forEach on a Node interface');\n };\n /**\n * Create a new Node having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {OperatorNode} Returns a transformed copy of the node\n */\n\n\n Node.prototype.map = function (callback) {\n // must be implemented by each of the Node implementations\n throw new Error('Cannot run map on a Node interface');\n };\n /**\n * Validate whether an object is a Node, for use with map\n * @param {Node} node\n * @returns {Node} Returns the input if it's a node, else throws an Error\n * @protected\n */\n\n\n Node.prototype._ifNode = function (node) {\n if (!(0, _is.isNode)(node)) {\n throw new TypeError('Callback function must return a Node');\n }\n\n return node;\n };\n /**\n * Recursively traverse all nodes in a node tree. Executes given callback for\n * this node and each of its child nodes.\n * @param {function(node: Node, path: string, parent: Node)} callback\n * A callback called for every node in the node tree.\n */\n\n\n Node.prototype.traverse = function (callback) {\n // execute callback for itself\n // eslint-disable-next-line\n callback(this, null, null); // recursively traverse over all childs of a node\n\n function _traverse(node, callback) {\n node.forEach(function (child, path, parent) {\n callback(child, path, parent);\n\n _traverse(child, callback);\n });\n }\n\n _traverse(this, callback);\n };\n /**\n * Recursively transform a node tree via a transform function.\n *\n * For example, to replace all nodes of type SymbolNode having name 'x' with a\n * ConstantNode with value 2:\n *\n * const res = Node.transform(function (node, path, parent) {\n * if (node && node.isSymbolNode) && (node.name === 'x')) {\n * return new ConstantNode(2)\n * }\n * else {\n * return node\n * }\n * })\n *\n * @param {function(node: Node, path: string, parent: Node) : Node} callback\n * A mapping function accepting a node, and returning\n * a replacement for the node or the original node.\n * Signature: callback(node: Node, index: string, parent: Node) : Node\n * @return {Node} Returns the original node or its replacement\n */\n\n\n Node.prototype.transform = function (callback) {\n function _transform(child, path, parent) {\n var replacement = callback(child, path, parent);\n\n if (replacement !== child) {\n // stop iterating when the node is replaced\n return replacement;\n }\n\n return child.map(_transform);\n }\n\n return _transform(this, null, null);\n };\n /**\n * Find any node in the node tree matching given filter function. For example, to\n * find all nodes of type SymbolNode having name 'x':\n *\n * const results = Node.filter(function (node) {\n * return (node && node.isSymbolNode) && (node.name === 'x')\n * })\n *\n * @param {function(node: Node, path: string, parent: Node) : Node} callback\n * A test function returning true when a node matches, and false\n * otherwise. Function signature:\n * callback(node: Node, index: string, parent: Node) : boolean\n * @return {Node[]} nodes An array with nodes matching given filter criteria\n */\n\n\n Node.prototype.filter = function (callback) {\n var nodes = [];\n this.traverse(function (node, path, parent) {\n if (callback(node, path, parent)) {\n nodes.push(node);\n }\n });\n return nodes;\n };\n /**\n * Create a shallow clone of this node\n * @return {Node}\n */\n\n\n Node.prototype.clone = function () {\n // must be implemented by each of the Node implementations\n throw new Error('Cannot clone a Node interface');\n };\n /**\n * Create a deep clone of this node\n * @return {Node}\n */\n\n\n Node.prototype.cloneDeep = function () {\n return this.map(function (node) {\n return node.cloneDeep();\n });\n };\n /**\n * Deep compare this node with another node.\n * @param {Node} other\n * @return {boolean} Returns true when both nodes are of the same type and\n * contain the same values (as do their childs)\n */\n\n\n Node.prototype.equals = function (other) {\n return other ? (0, _object.deepStrictEqual)(this, other) : false;\n };\n /**\n * Get string representation. (wrapper function)\n *\n * This function can get an object of the following form:\n * {\n * handler: //This can be a callback function of the form\n * // \"function callback(node, options)\"or\n * // a map that maps function names (used in FunctionNodes)\n * // to callbacks\n * parenthesis: \"keep\" //the parenthesis option (This is optional)\n * }\n *\n * @param {Object} [options]\n * @return {string}\n */\n\n\n Node.prototype.toString = function (options) {\n var customString = this._getCustomString(options);\n\n if (typeof customString !== 'undefined') {\n return customString;\n }\n\n return this._toString(options);\n };\n /**\n * Get a JSON representation of the node\n * Both .toJSON() and the static .fromJSON(json) should be implemented by all\n * implementations of Node\n * @returns {Object}\n */\n\n\n Node.prototype.toJSON = function () {\n throw new Error('Cannot serialize object: toJSON not implemented by ' + this.type);\n };\n /**\n * Get HTML representation. (wrapper function)\n *\n * This function can get an object of the following form:\n * {\n * handler: //This can be a callback function of the form\n * // \"function callback(node, options)\" or\n * // a map that maps function names (used in FunctionNodes)\n * // to callbacks\n * parenthesis: \"keep\" //the parenthesis option (This is optional)\n * }\n *\n * @param {Object} [options]\n * @return {string}\n */\n\n\n Node.prototype.toHTML = function (options) {\n var customString = this._getCustomString(options);\n\n if (typeof customString !== 'undefined') {\n return customString;\n }\n\n return this.toHTML(options);\n };\n /**\n * Internal function to generate the string output.\n * This has to be implemented by every Node\n *\n * @throws {Error}\n */\n\n\n Node.prototype._toString = function () {\n // must be implemented by each of the Node implementations\n throw new Error('_toString not implemented for ' + this.type);\n };\n /**\n * Get LaTeX representation. (wrapper function)\n *\n * This function can get an object of the following form:\n * {\n * handler: //This can be a callback function of the form\n * // \"function callback(node, options)\"or\n * // a map that maps function names (used in FunctionNodes)\n * // to callbacks\n * parenthesis: \"keep\" //the parenthesis option (This is optional)\n * }\n *\n * @param {Object} [options]\n * @return {string}\n */\n\n\n Node.prototype.toTex = function (options) {\n var customString = this._getCustomString(options);\n\n if (typeof customString !== 'undefined') {\n return customString;\n }\n\n return this._toTex(options);\n };\n /**\n * Internal function to generate the LaTeX output.\n * This has to be implemented by every Node\n *\n * @param {Object} [options]\n * @throws {Error}\n */\n\n\n Node.prototype._toTex = function (options) {\n // must be implemented by each of the Node implementations\n throw new Error('_toTex not implemented for ' + this.type);\n };\n /**\n * Helper used by `to...` functions.\n */\n\n\n Node.prototype._getCustomString = function (options) {\n if (options && (0, _typeof2.default)(options) === 'object') {\n switch ((0, _typeof2.default)(options.handler)) {\n case 'object':\n case 'undefined':\n return;\n\n case 'function':\n return options.handler(this, options);\n\n default:\n throw new TypeError('Object or function expected as callback');\n }\n }\n };\n /**\n * Get identifier.\n * @return {string}\n */\n\n\n Node.prototype.getIdentifier = function () {\n return this.type;\n };\n /**\n * Get the content of the current Node.\n * @return {Node} node\n **/\n\n\n Node.prototype.getContent = function () {\n return this;\n };\n /**\n * Validate the symbol names of a scope.\n * Throws an error when the scope contains an illegal symbol.\n * @param {Object} scope\n */\n\n\n function _validateScope(scope) {\n for (var _i = 0, _arr = (0, _toConsumableArray2.default)(_keywords.keywords); _i < _arr.length; _i++) {\n var symbol = _arr[_i];\n\n if (scope.has(symbol)) {\n throw new Error('Scope contains an illegal symbol, \"' + symbol + '\" is a reserved keyword');\n }\n }\n }\n\n return Node;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createNode = createNode;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createObjectNode = void 0;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _customs = require(\"../../utils/customs.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'ObjectNode';\nvar dependencies = ['Node'];\nvar createObjectNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var Node = _ref.Node;\n\n /**\n * @constructor ObjectNode\n * @extends {Node}\n * Holds an object with keys/values\n * @param {Object.} [properties] object with key/value pairs\n */\n function ObjectNode(properties) {\n if (!(this instanceof ObjectNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n this.properties = properties || {}; // validate input\n\n if (properties) {\n if (!((0, _typeof2.default)(properties) === 'object') || !Object.keys(properties).every(function (key) {\n return (0, _is.isNode)(properties[key]);\n })) {\n throw new TypeError('Object containing Nodes expected');\n }\n }\n }\n\n ObjectNode.prototype = new Node();\n ObjectNode.prototype.type = 'ObjectNode';\n ObjectNode.prototype.isObjectNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n ObjectNode.prototype._compile = function (math, argNames) {\n var evalEntries = {};\n\n for (var key in this.properties) {\n if ((0, _object.hasOwnProperty)(this.properties, key)) {\n // we stringify/parse the key here to resolve unicode characters,\n // so you cannot create a key like {\"co\\\\u006Estructor\": null}\n var stringifiedKey = (0, _string.stringify)(key);\n var parsedKey = JSON.parse(stringifiedKey);\n\n if (!(0, _customs.isSafeProperty)(this.properties, parsedKey)) {\n throw new Error('No access to property \"' + parsedKey + '\"');\n }\n\n evalEntries[parsedKey] = this.properties[key]._compile(math, argNames);\n }\n }\n\n return function evalObjectNode(scope, args, context) {\n var obj = {};\n\n for (var _key in evalEntries) {\n if ((0, _object.hasOwnProperty)(evalEntries, _key)) {\n obj[_key] = evalEntries[_key](scope, args, context);\n }\n }\n\n return obj;\n };\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n ObjectNode.prototype.forEach = function (callback) {\n for (var key in this.properties) {\n if ((0, _object.hasOwnProperty)(this.properties, key)) {\n callback(this.properties[key], 'properties[' + (0, _string.stringify)(key) + ']', this);\n }\n }\n };\n /**\n * Create a new ObjectNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {ObjectNode} Returns a transformed copy of the node\n */\n\n\n ObjectNode.prototype.map = function (callback) {\n var properties = {};\n\n for (var key in this.properties) {\n if ((0, _object.hasOwnProperty)(this.properties, key)) {\n properties[key] = this._ifNode(callback(this.properties[key], 'properties[' + (0, _string.stringify)(key) + ']', this));\n }\n }\n\n return new ObjectNode(properties);\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {ObjectNode}\n */\n\n\n ObjectNode.prototype.clone = function () {\n var properties = {};\n\n for (var key in this.properties) {\n if ((0, _object.hasOwnProperty)(this.properties, key)) {\n properties[key] = this.properties[key];\n }\n }\n\n return new ObjectNode(properties);\n };\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n\n ObjectNode.prototype._toString = function (options) {\n var entries = [];\n\n for (var key in this.properties) {\n if ((0, _object.hasOwnProperty)(this.properties, key)) {\n entries.push((0, _string.stringify)(key) + ': ' + this.properties[key].toString(options));\n }\n }\n\n return '{' + entries.join(', ') + '}';\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n ObjectNode.prototype.toJSON = function () {\n return {\n mathjs: 'ObjectNode',\n properties: this.properties\n };\n };\n /**\n * Instantiate an OperatorNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"ObjectNode\", \"properties\": {...}}`,\n * where mathjs is optional\n * @returns {ObjectNode}\n */\n\n\n ObjectNode.fromJSON = function (json) {\n return new ObjectNode(json.properties);\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n\n ObjectNode.prototype.toHTML = function (options) {\n var entries = [];\n\n for (var key in this.properties) {\n if ((0, _object.hasOwnProperty)(this.properties, key)) {\n entries.push('' + (0, _string.escape)(key) + '' + ':' + this.properties[key].toHTML(options));\n }\n }\n\n return '{' + entries.join(',') + '}';\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n ObjectNode.prototype._toTex = function (options) {\n var entries = [];\n\n for (var key in this.properties) {\n if ((0, _object.hasOwnProperty)(this.properties, key)) {\n entries.push('\\\\mathbf{' + key + ':} & ' + this.properties[key].toTex(options) + '\\\\\\\\');\n }\n }\n\n return \"\\\\left\\\\{\\\\begin{array}{ll}\".concat(entries.join('\\n'), \"\\\\end{array}\\\\right\\\\}\");\n };\n\n return ObjectNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createObjectNode = createObjectNode;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createOperatorNode = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _customs = require(\"../../utils/customs.js\");\n\nvar _operators = require(\"../operators.js\");\n\nvar _latex = require(\"../../utils/latex.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'OperatorNode';\nvar dependencies = ['Node'];\nvar createOperatorNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var Node = _ref.Node;\n\n /**\n * @constructor OperatorNode\n * @extends {Node}\n * An operator with two arguments, like 2+3\n *\n * @param {string} op Operator name, for example '+'\n * @param {string} fn Function name, for example 'add'\n * @param {Node[]} args Operator arguments\n * @param {boolean} [implicit] Is this an implicit multiplication?\n * @param {boolean} [isPercentage] Is this an percentage Operation?\n */\n function OperatorNode(op, fn, args, implicit, isPercentage) {\n if (!(this instanceof OperatorNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n } // validate input\n\n\n if (typeof op !== 'string') {\n throw new TypeError('string expected for parameter \"op\"');\n }\n\n if (typeof fn !== 'string') {\n throw new TypeError('string expected for parameter \"fn\"');\n }\n\n if (!Array.isArray(args) || !args.every(_is.isNode)) {\n throw new TypeError('Array containing Nodes expected for parameter \"args\"');\n }\n\n this.implicit = implicit === true;\n this.isPercentage = isPercentage === true;\n this.op = op;\n this.fn = fn;\n this.args = args || [];\n }\n\n OperatorNode.prototype = new Node();\n OperatorNode.prototype.type = 'OperatorNode';\n OperatorNode.prototype.isOperatorNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n OperatorNode.prototype._compile = function (math, argNames) {\n // validate fn\n if (typeof this.fn !== 'string' || !(0, _customs.isSafeMethod)(math, this.fn)) {\n if (!math[this.fn]) {\n throw new Error('Function ' + this.fn + ' missing in provided namespace \"math\"');\n } else {\n throw new Error('No access to function \"' + this.fn + '\"');\n }\n }\n\n var fn = (0, _customs.getSafeProperty)(math, this.fn);\n var evalArgs = (0, _array.map)(this.args, function (arg) {\n return arg._compile(math, argNames);\n });\n\n if (evalArgs.length === 1) {\n var evalArg0 = evalArgs[0];\n return function evalOperatorNode(scope, args, context) {\n return fn(evalArg0(scope, args, context));\n };\n } else if (evalArgs.length === 2) {\n var _evalArg = evalArgs[0];\n var evalArg1 = evalArgs[1];\n return function evalOperatorNode(scope, args, context) {\n return fn(_evalArg(scope, args, context), evalArg1(scope, args, context));\n };\n } else {\n return function evalOperatorNode(scope, args, context) {\n return fn.apply(null, (0, _array.map)(evalArgs, function (evalArg) {\n return evalArg(scope, args, context);\n }));\n };\n }\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n OperatorNode.prototype.forEach = function (callback) {\n for (var i = 0; i < this.args.length; i++) {\n callback(this.args[i], 'args[' + i + ']', this);\n }\n };\n /**\n * Create a new OperatorNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {OperatorNode} Returns a transformed copy of the node\n */\n\n\n OperatorNode.prototype.map = function (callback) {\n var args = [];\n\n for (var i = 0; i < this.args.length; i++) {\n args[i] = this._ifNode(callback(this.args[i], 'args[' + i + ']', this));\n }\n\n return new OperatorNode(this.op, this.fn, args, this.implicit, this.isPercentage);\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {OperatorNode}\n */\n\n\n OperatorNode.prototype.clone = function () {\n return new OperatorNode(this.op, this.fn, this.args.slice(0), this.implicit, this.isPercentage);\n };\n /**\n * Check whether this is an unary OperatorNode:\n * has exactly one argument, like `-a`.\n * @return {boolean} Returns true when an unary operator node, false otherwise.\n */\n\n\n OperatorNode.prototype.isUnary = function () {\n return this.args.length === 1;\n };\n /**\n * Check whether this is a binary OperatorNode:\n * has exactly two arguments, like `a + b`.\n * @return {boolean} Returns true when a binary operator node, false otherwise.\n */\n\n\n OperatorNode.prototype.isBinary = function () {\n return this.args.length === 2;\n };\n /**\n * Calculate which parentheses are necessary. Gets an OperatorNode\n * (which is the root of the tree) and an Array of Nodes\n * (this.args) and returns an array where 'true' means that an argument\n * has to be enclosed in parentheses whereas 'false' means the opposite.\n *\n * @param {OperatorNode} root\n * @param {string} parenthesis\n * @param {Node[]} args\n * @param {boolean} latex\n * @return {boolean[]}\n * @private\n */\n\n\n function calculateNecessaryParentheses(root, parenthesis, implicit, args, latex) {\n // precedence of the root OperatorNode\n var precedence = (0, _operators.getPrecedence)(root, parenthesis);\n var associativity = (0, _operators.getAssociativity)(root, parenthesis);\n\n if (parenthesis === 'all' || args.length > 2 && root.getIdentifier() !== 'OperatorNode:add' && root.getIdentifier() !== 'OperatorNode:multiply') {\n return args.map(function (arg) {\n switch (arg.getContent().type) {\n // Nodes that don't need extra parentheses\n case 'ArrayNode':\n case 'ConstantNode':\n case 'SymbolNode':\n case 'ParenthesisNode':\n return false;\n\n default:\n return true;\n }\n });\n }\n\n var result;\n\n switch (args.length) {\n case 0:\n result = [];\n break;\n\n case 1:\n // unary operators\n {\n // precedence of the operand\n var operandPrecedence = (0, _operators.getPrecedence)(args[0], parenthesis); // handle special cases for LaTeX, where some of the parentheses aren't needed\n\n if (latex && operandPrecedence !== null) {\n var operandIdentifier;\n var rootIdentifier;\n\n if (parenthesis === 'keep') {\n operandIdentifier = args[0].getIdentifier();\n rootIdentifier = root.getIdentifier();\n } else {\n // Ignore Parenthesis Nodes when not in 'keep' mode\n operandIdentifier = args[0].getContent().getIdentifier();\n rootIdentifier = root.getContent().getIdentifier();\n }\n\n if (_operators.properties[precedence][rootIdentifier].latexLeftParens === false) {\n result = [false];\n break;\n }\n\n if (_operators.properties[operandPrecedence][operandIdentifier].latexParens === false) {\n result = [false];\n break;\n }\n }\n\n if (operandPrecedence === null) {\n // if the operand has no defined precedence, no parens are needed\n result = [false];\n break;\n }\n\n if (operandPrecedence <= precedence) {\n // if the operands precedence is lower, parens are needed\n result = [true];\n break;\n } // otherwise, no parens needed\n\n\n result = [false];\n }\n break;\n\n case 2:\n // binary operators\n {\n var lhsParens; // left hand side needs parenthesis?\n // precedence of the left hand side\n\n var lhsPrecedence = (0, _operators.getPrecedence)(args[0], parenthesis); // is the root node associative with the left hand side\n\n var assocWithLhs = (0, _operators.isAssociativeWith)(root, args[0], parenthesis);\n\n if (lhsPrecedence === null) {\n // if the left hand side has no defined precedence, no parens are needed\n // FunctionNode for example\n lhsParens = false;\n } else if (lhsPrecedence === precedence && associativity === 'right' && !assocWithLhs) {\n // In case of equal precedence, if the root node is left associative\n // parens are **never** necessary for the left hand side.\n // If it is right associative however, parens are necessary\n // if the root node isn't associative with the left hand side\n lhsParens = true;\n } else if (lhsPrecedence < precedence) {\n lhsParens = true;\n } else {\n lhsParens = false;\n }\n\n var rhsParens; // right hand side needs parenthesis?\n // precedence of the right hand side\n\n var rhsPrecedence = (0, _operators.getPrecedence)(args[1], parenthesis); // is the root node associative with the right hand side?\n\n var assocWithRhs = (0, _operators.isAssociativeWith)(root, args[1], parenthesis);\n\n if (rhsPrecedence === null) {\n // if the right hand side has no defined precedence, no parens are needed\n // FunctionNode for example\n rhsParens = false;\n } else if (rhsPrecedence === precedence && associativity === 'left' && !assocWithRhs) {\n // In case of equal precedence, if the root node is right associative\n // parens are **never** necessary for the right hand side.\n // If it is left associative however, parens are necessary\n // if the root node isn't associative with the right hand side\n rhsParens = true;\n } else if (rhsPrecedence < precedence) {\n rhsParens = true;\n } else {\n rhsParens = false;\n } // handle special cases for LaTeX, where some of the parentheses aren't needed\n\n\n if (latex) {\n var _rootIdentifier;\n\n var lhsIdentifier;\n var rhsIdentifier;\n\n if (parenthesis === 'keep') {\n _rootIdentifier = root.getIdentifier();\n lhsIdentifier = root.args[0].getIdentifier();\n rhsIdentifier = root.args[1].getIdentifier();\n } else {\n // Ignore ParenthesisNodes when not in 'keep' mode\n _rootIdentifier = root.getContent().getIdentifier();\n lhsIdentifier = root.args[0].getContent().getIdentifier();\n rhsIdentifier = root.args[1].getContent().getIdentifier();\n }\n\n if (lhsPrecedence !== null) {\n if (_operators.properties[precedence][_rootIdentifier].latexLeftParens === false) {\n lhsParens = false;\n }\n\n if (_operators.properties[lhsPrecedence][lhsIdentifier].latexParens === false) {\n lhsParens = false;\n }\n }\n\n if (rhsPrecedence !== null) {\n if (_operators.properties[precedence][_rootIdentifier].latexRightParens === false) {\n rhsParens = false;\n }\n\n if (_operators.properties[rhsPrecedence][rhsIdentifier].latexParens === false) {\n rhsParens = false;\n }\n }\n }\n\n result = [lhsParens, rhsParens];\n }\n break;\n\n default:\n if (root.getIdentifier() === 'OperatorNode:add' || root.getIdentifier() === 'OperatorNode:multiply') {\n result = args.map(function (arg) {\n var argPrecedence = (0, _operators.getPrecedence)(arg, parenthesis);\n var assocWithArg = (0, _operators.isAssociativeWith)(root, arg, parenthesis);\n var argAssociativity = (0, _operators.getAssociativity)(arg, parenthesis);\n\n if (argPrecedence === null) {\n // if the argument has no defined precedence, no parens are needed\n return false;\n } else if (precedence === argPrecedence && associativity === argAssociativity && !assocWithArg) {\n return true;\n } else if (argPrecedence < precedence) {\n return true;\n }\n\n return false;\n });\n }\n\n break;\n } // handles an edge case of 'auto' parentheses with implicit multiplication of ConstantNode\n // In that case print parentheses for ParenthesisNodes even though they normally wouldn't be\n // printed.\n\n\n if (args.length >= 2 && root.getIdentifier() === 'OperatorNode:multiply' && root.implicit && parenthesis === 'auto' && implicit === 'hide') {\n result = args.map(function (arg, index) {\n var isParenthesisNode = arg.getIdentifier() === 'ParenthesisNode';\n\n if (result[index] || isParenthesisNode) {\n // put in parenthesis?\n return true;\n }\n\n return false;\n });\n }\n\n return result;\n }\n /**\n * Get string representation.\n * @param {Object} options\n * @return {string} str\n */\n\n\n OperatorNode.prototype._toString = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var implicit = options && options.implicit ? options.implicit : 'hide';\n var args = this.args;\n var parens = calculateNecessaryParentheses(this, parenthesis, implicit, args, false);\n\n if (args.length === 1) {\n // unary operators\n var assoc = (0, _operators.getAssociativity)(this, parenthesis);\n var operand = args[0].toString(options);\n\n if (parens[0]) {\n operand = '(' + operand + ')';\n } // for example for \"not\", we want a space between operand and argument\n\n\n var opIsNamed = /[a-zA-Z]+/.test(this.op);\n\n if (assoc === 'right') {\n // prefix operator\n return this.op + (opIsNamed ? ' ' : '') + operand;\n } else if (assoc === 'left') {\n // postfix\n return operand + (opIsNamed ? ' ' : '') + this.op;\n } // fall back to postfix\n\n\n return operand + this.op;\n } else if (args.length === 2) {\n var lhs = args[0].toString(options); // left hand side\n\n var rhs = args[1].toString(options); // right hand side\n\n if (parens[0]) {\n // left hand side in parenthesis?\n lhs = '(' + lhs + ')';\n }\n\n if (parens[1]) {\n // right hand side in parenthesis?\n rhs = '(' + rhs + ')';\n }\n\n if (this.implicit && this.getIdentifier() === 'OperatorNode:multiply' && implicit === 'hide') {\n return lhs + ' ' + rhs;\n }\n\n return lhs + ' ' + this.op + ' ' + rhs;\n } else if (args.length > 2 && (this.getIdentifier() === 'OperatorNode:add' || this.getIdentifier() === 'OperatorNode:multiply')) {\n var stringifiedArgs = args.map(function (arg, index) {\n arg = arg.toString(options);\n\n if (parens[index]) {\n // put in parenthesis?\n arg = '(' + arg + ')';\n }\n\n return arg;\n });\n\n if (this.implicit && this.getIdentifier() === 'OperatorNode:multiply' && implicit === 'hide') {\n return stringifiedArgs.join(' ');\n }\n\n return stringifiedArgs.join(' ' + this.op + ' ');\n } else {\n // fallback to formatting as a function call\n return this.fn + '(' + this.args.join(', ') + ')';\n }\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n OperatorNode.prototype.toJSON = function () {\n return {\n mathjs: 'OperatorNode',\n op: this.op,\n fn: this.fn,\n args: this.args,\n implicit: this.implicit,\n isPercentage: this.isPercentage\n };\n };\n /**\n * Instantiate an OperatorNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"OperatorNode\", \"op\": \"+\", \"fn\": \"add\", \"args\": [...], \"implicit\": false, \"isPercentage\":false}`,\n * where mathjs is optional\n * @returns {OperatorNode}\n */\n\n\n OperatorNode.fromJSON = function (json) {\n return new OperatorNode(json.op, json.fn, json.args, json.implicit, json.isPercentage);\n };\n /**\n * Get HTML representation.\n * @param {Object} options\n * @return {string} str\n */\n\n\n OperatorNode.prototype.toHTML = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var implicit = options && options.implicit ? options.implicit : 'hide';\n var args = this.args;\n var parens = calculateNecessaryParentheses(this, parenthesis, implicit, args, false);\n\n if (args.length === 1) {\n // unary operators\n var assoc = (0, _operators.getAssociativity)(this, parenthesis);\n var operand = args[0].toHTML(options);\n\n if (parens[0]) {\n operand = '(' + operand + ')';\n }\n\n if (assoc === 'right') {\n // prefix operator\n return '' + (0, _string.escape)(this.op) + '' + operand;\n } else {\n // postfix when assoc === 'left' or undefined\n return operand + '' + (0, _string.escape)(this.op) + '';\n }\n } else if (args.length === 2) {\n // binary operatoes\n var lhs = args[0].toHTML(options); // left hand side\n\n var rhs = args[1].toHTML(options); // right hand side\n\n if (parens[0]) {\n // left hand side in parenthesis?\n lhs = '(' + lhs + ')';\n }\n\n if (parens[1]) {\n // right hand side in parenthesis?\n rhs = '(' + rhs + ')';\n }\n\n if (this.implicit && this.getIdentifier() === 'OperatorNode:multiply' && implicit === 'hide') {\n return lhs + '' + rhs;\n }\n\n return lhs + '' + (0, _string.escape)(this.op) + '' + rhs;\n } else {\n var stringifiedArgs = args.map(function (arg, index) {\n arg = arg.toHTML(options);\n\n if (parens[index]) {\n // put in parenthesis?\n arg = '(' + arg + ')';\n }\n\n return arg;\n });\n\n if (args.length > 2 && (this.getIdentifier() === 'OperatorNode:add' || this.getIdentifier() === 'OperatorNode:multiply')) {\n if (this.implicit && this.getIdentifier() === 'OperatorNode:multiply' && implicit === 'hide') {\n return stringifiedArgs.join('');\n }\n\n return stringifiedArgs.join('' + (0, _string.escape)(this.op) + '');\n } else {\n // fallback to formatting as a function call\n return '' + (0, _string.escape)(this.fn) + '(' + stringifiedArgs.join(',') + ')';\n }\n }\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n OperatorNode.prototype._toTex = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var implicit = options && options.implicit ? options.implicit : 'hide';\n var args = this.args;\n var parens = calculateNecessaryParentheses(this, parenthesis, implicit, args, true);\n var op = _latex.latexOperators[this.fn];\n op = typeof op === 'undefined' ? this.op : op; // fall back to using this.op\n\n if (args.length === 1) {\n // unary operators\n var assoc = (0, _operators.getAssociativity)(this, parenthesis);\n var operand = args[0].toTex(options);\n\n if (parens[0]) {\n operand = \"\\\\left(\".concat(operand, \"\\\\right)\");\n }\n\n if (assoc === 'right') {\n // prefix operator\n return op + operand;\n } else if (assoc === 'left') {\n // postfix operator\n return operand + op;\n } // fall back to postfix\n\n\n return operand + op;\n } else if (args.length === 2) {\n // binary operators\n var lhs = args[0]; // left hand side\n\n var lhsTex = lhs.toTex(options);\n\n if (parens[0]) {\n lhsTex = \"\\\\left(\".concat(lhsTex, \"\\\\right)\");\n }\n\n var rhs = args[1]; // right hand side\n\n var rhsTex = rhs.toTex(options);\n\n if (parens[1]) {\n rhsTex = \"\\\\left(\".concat(rhsTex, \"\\\\right)\");\n } // handle some exceptions (due to the way LaTeX works)\n\n\n var lhsIdentifier;\n\n if (parenthesis === 'keep') {\n lhsIdentifier = lhs.getIdentifier();\n } else {\n // Ignore ParenthesisNodes if in 'keep' mode\n lhsIdentifier = lhs.getContent().getIdentifier();\n }\n\n switch (this.getIdentifier()) {\n case 'OperatorNode:divide':\n // op contains '\\\\frac' at this point\n return op + '{' + lhsTex + '}' + '{' + rhsTex + '}';\n\n case 'OperatorNode:pow':\n lhsTex = '{' + lhsTex + '}';\n rhsTex = '{' + rhsTex + '}';\n\n switch (lhsIdentifier) {\n case 'ConditionalNode': //\n\n case 'OperatorNode:divide':\n lhsTex = \"\\\\left(\".concat(lhsTex, \"\\\\right)\");\n }\n\n break;\n\n case 'OperatorNode:multiply':\n if (this.implicit && implicit === 'hide') {\n return lhsTex + '~' + rhsTex;\n }\n\n }\n\n return lhsTex + op + rhsTex;\n } else if (args.length > 2 && (this.getIdentifier() === 'OperatorNode:add' || this.getIdentifier() === 'OperatorNode:multiply')) {\n var texifiedArgs = args.map(function (arg, index) {\n arg = arg.toTex(options);\n\n if (parens[index]) {\n arg = \"\\\\left(\".concat(arg, \"\\\\right)\");\n }\n\n return arg;\n });\n\n if (this.getIdentifier() === 'OperatorNode:multiply' && this.implicit) {\n return texifiedArgs.join('~');\n }\n\n return texifiedArgs.join(op);\n } else {\n // fall back to formatting as a function call\n // as this is a fallback, it doesn't use\n // fancy function names\n return '\\\\mathrm{' + this.fn + '}\\\\left(' + args.map(function (arg) {\n return arg.toTex(options);\n }).join(',') + '\\\\right)';\n }\n };\n /**\n * Get identifier.\n * @return {string}\n */\n\n\n OperatorNode.prototype.getIdentifier = function () {\n return this.type + ':' + this.fn;\n };\n\n return OperatorNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createOperatorNode = createOperatorNode;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createParenthesisNode = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'ParenthesisNode';\nvar dependencies = ['Node'];\nvar createParenthesisNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var Node = _ref.Node;\n\n /**\n * @constructor ParenthesisNode\n * @extends {Node}\n * A parenthesis node describes manual parenthesis from the user input\n * @param {Node} content\n * @extends {Node}\n */\n function ParenthesisNode(content) {\n if (!(this instanceof ParenthesisNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n } // validate input\n\n\n if (!(0, _is.isNode)(content)) {\n throw new TypeError('Node expected for parameter \"content\"');\n }\n\n this.content = content;\n }\n\n ParenthesisNode.prototype = new Node();\n ParenthesisNode.prototype.type = 'ParenthesisNode';\n ParenthesisNode.prototype.isParenthesisNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n ParenthesisNode.prototype._compile = function (math, argNames) {\n return this.content._compile(math, argNames);\n };\n /**\n * Get the content of the current Node.\n * @return {Node} content\n * @override\n **/\n\n\n ParenthesisNode.prototype.getContent = function () {\n return this.content.getContent();\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n ParenthesisNode.prototype.forEach = function (callback) {\n callback(this.content, 'content', this);\n };\n /**\n * Create a new ParenthesisNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node) : Node} callback\n * @returns {ParenthesisNode} Returns a clone of the node\n */\n\n\n ParenthesisNode.prototype.map = function (callback) {\n var content = callback(this.content, 'content', this);\n return new ParenthesisNode(content);\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {ParenthesisNode}\n */\n\n\n ParenthesisNode.prototype.clone = function () {\n return new ParenthesisNode(this.content);\n };\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n\n ParenthesisNode.prototype._toString = function (options) {\n if (!options || options && !options.parenthesis || options && options.parenthesis === 'keep') {\n return '(' + this.content.toString(options) + ')';\n }\n\n return this.content.toString(options);\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n ParenthesisNode.prototype.toJSON = function () {\n return {\n mathjs: 'ParenthesisNode',\n content: this.content\n };\n };\n /**\n * Instantiate an ParenthesisNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"ParenthesisNode\", \"content\": ...}`,\n * where mathjs is optional\n * @returns {ParenthesisNode}\n */\n\n\n ParenthesisNode.fromJSON = function (json) {\n return new ParenthesisNode(json.content);\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n\n ParenthesisNode.prototype.toHTML = function (options) {\n if (!options || options && !options.parenthesis || options && options.parenthesis === 'keep') {\n return '(' + this.content.toHTML(options) + ')';\n }\n\n return this.content.toHTML(options);\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n\n ParenthesisNode.prototype._toTex = function (options) {\n if (!options || options && !options.parenthesis || options && options.parenthesis === 'keep') {\n return \"\\\\left(\".concat(this.content.toTex(options), \"\\\\right)\");\n }\n\n return this.content.toTex(options);\n };\n\n return ParenthesisNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createParenthesisNode = createParenthesisNode;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRangeNode = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _operators = require(\"../operators.js\");\n\nvar name = 'RangeNode';\nvar dependencies = ['Node'];\nvar createRangeNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var Node = _ref.Node;\n\n /**\n * @constructor RangeNode\n * @extends {Node}\n * create a range\n * @param {Node} start included lower-bound\n * @param {Node} end included upper-bound\n * @param {Node} [step] optional step\n */\n function RangeNode(start, end, step) {\n if (!(this instanceof RangeNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n } // validate inputs\n\n\n if (!(0, _is.isNode)(start)) throw new TypeError('Node expected');\n if (!(0, _is.isNode)(end)) throw new TypeError('Node expected');\n if (step && !(0, _is.isNode)(step)) throw new TypeError('Node expected');\n if (arguments.length > 3) throw new Error('Too many arguments');\n this.start = start; // included lower-bound\n\n this.end = end; // included upper-bound\n\n this.step = step || null; // optional step\n }\n\n RangeNode.prototype = new Node();\n RangeNode.prototype.type = 'RangeNode';\n RangeNode.prototype.isRangeNode = true;\n /**\n * Check whether the RangeNode needs the `end` symbol to be defined.\n * This end is the size of the Matrix in current dimension.\n * @return {boolean}\n */\n\n RangeNode.prototype.needsEnd = function () {\n // find all `end` symbols in this RangeNode\n var endSymbols = this.filter(function (node) {\n return (0, _is.isSymbolNode)(node) && node.name === 'end';\n });\n return endSymbols.length > 0;\n };\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n\n RangeNode.prototype._compile = function (math, argNames) {\n var range = math.range;\n\n var evalStart = this.start._compile(math, argNames);\n\n var evalEnd = this.end._compile(math, argNames);\n\n if (this.step) {\n var evalStep = this.step._compile(math, argNames);\n\n return function evalRangeNode(scope, args, context) {\n return range(evalStart(scope, args, context), evalEnd(scope, args, context), evalStep(scope, args, context));\n };\n } else {\n return function evalRangeNode(scope, args, context) {\n return range(evalStart(scope, args, context), evalEnd(scope, args, context));\n };\n }\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n RangeNode.prototype.forEach = function (callback) {\n callback(this.start, 'start', this);\n callback(this.end, 'end', this);\n\n if (this.step) {\n callback(this.step, 'step', this);\n }\n };\n /**\n * Create a new RangeNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {RangeNode} Returns a transformed copy of the node\n */\n\n\n RangeNode.prototype.map = function (callback) {\n return new RangeNode(this._ifNode(callback(this.start, 'start', this)), this._ifNode(callback(this.end, 'end', this)), this.step && this._ifNode(callback(this.step, 'step', this)));\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {RangeNode}\n */\n\n\n RangeNode.prototype.clone = function () {\n return new RangeNode(this.start, this.end, this.step && this.step);\n };\n /**\n * Calculate the necessary parentheses\n * @param {Node} node\n * @param {string} parenthesis\n * @return {Object} parentheses\n * @private\n */\n\n\n function calculateNecessaryParentheses(node, parenthesis) {\n var precedence = (0, _operators.getPrecedence)(node, parenthesis);\n var parens = {};\n var startPrecedence = (0, _operators.getPrecedence)(node.start, parenthesis);\n parens.start = startPrecedence !== null && startPrecedence <= precedence || parenthesis === 'all';\n\n if (node.step) {\n var stepPrecedence = (0, _operators.getPrecedence)(node.step, parenthesis);\n parens.step = stepPrecedence !== null && stepPrecedence <= precedence || parenthesis === 'all';\n }\n\n var endPrecedence = (0, _operators.getPrecedence)(node.end, parenthesis);\n parens.end = endPrecedence !== null && endPrecedence <= precedence || parenthesis === 'all';\n return parens;\n }\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n RangeNode.prototype._toString = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var parens = calculateNecessaryParentheses(this, parenthesis); // format string as start:step:stop\n\n var str;\n var start = this.start.toString(options);\n\n if (parens.start) {\n start = '(' + start + ')';\n }\n\n str = start;\n\n if (this.step) {\n var step = this.step.toString(options);\n\n if (parens.step) {\n step = '(' + step + ')';\n }\n\n str += ':' + step;\n }\n\n var end = this.end.toString(options);\n\n if (parens.end) {\n end = '(' + end + ')';\n }\n\n str += ':' + end;\n return str;\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n RangeNode.prototype.toJSON = function () {\n return {\n mathjs: 'RangeNode',\n start: this.start,\n end: this.end,\n step: this.step\n };\n };\n /**\n * Instantiate an RangeNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"RangeNode\", \"start\": ..., \"end\": ..., \"step\": ...}`,\n * where mathjs is optional\n * @returns {RangeNode}\n */\n\n\n RangeNode.fromJSON = function (json) {\n return new RangeNode(json.start, json.end, json.step);\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n RangeNode.prototype.toHTML = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var parens = calculateNecessaryParentheses(this, parenthesis); // format string as start:step:stop\n\n var str;\n var start = this.start.toHTML(options);\n\n if (parens.start) {\n start = '(' + start + ')';\n }\n\n str = start;\n\n if (this.step) {\n var step = this.step.toHTML(options);\n\n if (parens.step) {\n step = '(' + step + ')';\n }\n\n str += ':' + step;\n }\n\n var end = this.end.toHTML(options);\n\n if (parens.end) {\n end = '(' + end + ')';\n }\n\n str += ':' + end;\n return str;\n };\n /**\n * Get LaTeX representation\n * @params {Object} options\n * @return {string} str\n */\n\n\n RangeNode.prototype._toTex = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var parens = calculateNecessaryParentheses(this, parenthesis);\n var str = this.start.toTex(options);\n\n if (parens.start) {\n str = \"\\\\left(\".concat(str, \"\\\\right)\");\n }\n\n if (this.step) {\n var step = this.step.toTex(options);\n\n if (parens.step) {\n step = \"\\\\left(\".concat(step, \"\\\\right)\");\n }\n\n str += ':' + step;\n }\n\n var end = this.end.toTex(options);\n\n if (parens.end) {\n end = \"\\\\left(\".concat(end, \"\\\\right)\");\n }\n\n str += ':' + end;\n return str;\n };\n\n return RangeNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createRangeNode = createRangeNode;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRelationalNode = void 0;\n\nvar _operators = require(\"../operators.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _customs = require(\"../../utils/customs.js\");\n\nvar _latex = require(\"../../utils/latex.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'RelationalNode';\nvar dependencies = ['Node'];\nvar createRelationalNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var Node = _ref.Node;\n\n /**\n * A node representing a chained conditional expression, such as 'x > y > z'\n *\n * @param {String[]} conditionals An array of conditional operators used to compare the parameters\n * @param {Node[]} params The parameters that will be compared\n *\n * @constructor RelationalNode\n * @extends {Node}\n */\n function RelationalNode(conditionals, params) {\n if (!(this instanceof RelationalNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n if (!Array.isArray(conditionals)) throw new TypeError('Parameter conditionals must be an array');\n if (!Array.isArray(params)) throw new TypeError('Parameter params must be an array');\n if (conditionals.length !== params.length - 1) throw new TypeError('Parameter params must contain exactly one more element than parameter conditionals');\n this.conditionals = conditionals;\n this.params = params;\n }\n\n RelationalNode.prototype = new Node();\n RelationalNode.prototype.type = 'RelationalNode';\n RelationalNode.prototype.isRelationalNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n RelationalNode.prototype._compile = function (math, argNames) {\n var self = this;\n var compiled = this.params.map(function (p) {\n return p._compile(math, argNames);\n });\n return function evalRelationalNode(scope, args, context) {\n var evalLhs;\n var evalRhs = compiled[0](scope, args, context);\n\n for (var i = 0; i < self.conditionals.length; i++) {\n evalLhs = evalRhs;\n evalRhs = compiled[i + 1](scope, args, context);\n var condFn = (0, _customs.getSafeProperty)(math, self.conditionals[i]);\n\n if (!condFn(evalLhs, evalRhs)) {\n return false;\n }\n }\n\n return true;\n };\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n RelationalNode.prototype.forEach = function (callback) {\n var _this = this;\n\n this.params.forEach(function (n, i) {\n return callback(n, 'params[' + i + ']', _this);\n }, this);\n };\n /**\n * Create a new RelationalNode having its childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node): Node} callback\n * @returns {RelationalNode} Returns a transformed copy of the node\n */\n\n\n RelationalNode.prototype.map = function (callback) {\n var _this2 = this;\n\n return new RelationalNode(this.conditionals.slice(), this.params.map(function (n, i) {\n return _this2._ifNode(callback(n, 'params[' + i + ']', _this2));\n }, this));\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {RelationalNode}\n */\n\n\n RelationalNode.prototype.clone = function () {\n return new RelationalNode(this.conditionals, this.params);\n };\n /**\n * Get string representation.\n * @param {Object} options\n * @return {string} str\n */\n\n\n RelationalNode.prototype._toString = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var precedence = (0, _operators.getPrecedence)(this, parenthesis);\n var paramStrings = this.params.map(function (p, index) {\n var paramPrecedence = (0, _operators.getPrecedence)(p, parenthesis);\n return parenthesis === 'all' || paramPrecedence !== null && paramPrecedence <= precedence ? '(' + p.toString(options) + ')' : p.toString(options);\n });\n var operatorMap = {\n equal: '==',\n unequal: '!=',\n smaller: '<',\n larger: '>',\n smallerEq: '<=',\n largerEq: '>='\n };\n var ret = paramStrings[0];\n\n for (var i = 0; i < this.conditionals.length; i++) {\n ret += ' ' + operatorMap[this.conditionals[i]] + ' ' + paramStrings[i + 1];\n }\n\n return ret;\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n RelationalNode.prototype.toJSON = function () {\n return {\n mathjs: 'RelationalNode',\n conditionals: this.conditionals,\n params: this.params\n };\n };\n /**\n * Instantiate a RelationalNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"RelationalNode\", \"condition\": ..., \"trueExpr\": ..., \"falseExpr\": ...}`,\n * where mathjs is optional\n * @returns {RelationalNode}\n */\n\n\n RelationalNode.fromJSON = function (json) {\n return new RelationalNode(json.conditionals, json.params);\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n RelationalNode.prototype.toHTML = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var precedence = (0, _operators.getPrecedence)(this, parenthesis);\n var paramStrings = this.params.map(function (p, index) {\n var paramPrecedence = (0, _operators.getPrecedence)(p, parenthesis);\n return parenthesis === 'all' || paramPrecedence !== null && paramPrecedence <= precedence ? '(' + p.toHTML(options) + ')' : p.toHTML(options);\n });\n var operatorMap = {\n equal: '==',\n unequal: '!=',\n smaller: '<',\n larger: '>',\n smallerEq: '<=',\n largerEq: '>='\n };\n var ret = paramStrings[0];\n\n for (var i = 0; i < this.conditionals.length; i++) {\n ret += '' + (0, _string.escape)(operatorMap[this.conditionals[i]]) + '' + paramStrings[i + 1];\n }\n\n return ret;\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n */\n\n\n RelationalNode.prototype._toTex = function (options) {\n var parenthesis = options && options.parenthesis ? options.parenthesis : 'keep';\n var precedence = (0, _operators.getPrecedence)(this, parenthesis);\n var paramStrings = this.params.map(function (p, index) {\n var paramPrecedence = (0, _operators.getPrecedence)(p, parenthesis);\n return parenthesis === 'all' || paramPrecedence !== null && paramPrecedence <= precedence ? '\\\\left(' + p.toTex(options) + '\\right)' : p.toTex(options);\n });\n var ret = paramStrings[0];\n\n for (var i = 0; i < this.conditionals.length; i++) {\n ret += _latex.latexOperators[this.conditionals[i]] + paramStrings[i + 1];\n }\n\n return ret;\n };\n\n return RelationalNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createRelationalNode = createRelationalNode;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSymbolNode = void 0;\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _customs = require(\"../../utils/customs.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _latex = require(\"../../utils/latex.js\");\n\nvar name = 'SymbolNode';\nvar dependencies = ['math', '?Unit', 'Node'];\nvar createSymbolNode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var math = _ref.math,\n Unit = _ref.Unit,\n Node = _ref.Node;\n\n /**\n * Check whether some name is a valueless unit like \"inch\".\n * @param {string} name\n * @return {boolean}\n */\n function isValuelessUnit(name) {\n return Unit ? Unit.isValuelessUnit(name) : false;\n }\n /**\n * @constructor SymbolNode\n * @extends {Node}\n * A symbol node can hold and resolve a symbol\n * @param {string} name\n * @extends {Node}\n */\n\n\n function SymbolNode(name) {\n if (!(this instanceof SymbolNode)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n } // validate input\n\n\n if (typeof name !== 'string') throw new TypeError('String expected for parameter \"name\"');\n this.name = name;\n }\n\n SymbolNode.prototype = new Node();\n SymbolNode.prototype.type = 'SymbolNode';\n SymbolNode.prototype.isSymbolNode = true;\n /**\n * Compile a node into a JavaScript function.\n * This basically pre-calculates as much as possible and only leaves open\n * calculations which depend on a dynamic scope with variables.\n * @param {Object} math Math.js namespace with functions and constants.\n * @param {Object} argNames An object with argument names as key and `true`\n * as value. Used in the SymbolNode to optimize\n * for arguments from user assigned functions\n * (see FunctionAssignmentNode) or special symbols\n * like `end` (see IndexNode).\n * @return {function} Returns a function which can be called like:\n * evalNode(scope: Object, args: Object, context: *)\n */\n\n SymbolNode.prototype._compile = function (math, argNames) {\n var name = this.name;\n\n if (argNames[name] === true) {\n // this is a FunctionAssignment argument\n // (like an x when inside the expression of a function assignment `f(x) = ...`)\n return function (scope, args, context) {\n return args[name];\n };\n } else if (name in math) {\n return function (scope, args, context) {\n return scope.has(name) ? scope.get(name) : (0, _customs.getSafeProperty)(math, name);\n };\n } else {\n var isUnit = isValuelessUnit(name);\n return function (scope, args, context) {\n return scope.has(name) ? scope.get(name) : isUnit ? new Unit(null, name) : SymbolNode.onUndefinedSymbol(name);\n };\n }\n };\n /**\n * Execute a callback for each of the child nodes of this node\n * @param {function(child: Node, path: string, parent: Node)} callback\n */\n\n\n SymbolNode.prototype.forEach = function (callback) {// nothing to do, we don't have childs\n };\n /**\n * Create a new SymbolNode having it's childs be the results of calling\n * the provided callback function for each of the childs of the original node.\n * @param {function(child: Node, path: string, parent: Node) : Node} callback\n * @returns {SymbolNode} Returns a clone of the node\n */\n\n\n SymbolNode.prototype.map = function (callback) {\n return this.clone();\n };\n /**\n * Throws an error 'Undefined symbol {name}'\n * @param {string} name\n */\n\n\n SymbolNode.onUndefinedSymbol = function (name) {\n throw new Error('Undefined symbol ' + name);\n };\n /**\n * Create a clone of this node, a shallow copy\n * @return {SymbolNode}\n */\n\n\n SymbolNode.prototype.clone = function () {\n return new SymbolNode(this.name);\n };\n /**\n * Get string representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n\n SymbolNode.prototype._toString = function (options) {\n return this.name;\n };\n /**\n * Get HTML representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n\n SymbolNode.prototype.toHTML = function (options) {\n var name = (0, _string.escape)(this.name);\n\n if (name === 'true' || name === 'false') {\n return '' + name + '';\n } else if (name === 'i') {\n return '' + name + '';\n } else if (name === 'Infinity') {\n return '' + name + '';\n } else if (name === 'NaN') {\n return '' + name + '';\n } else if (name === 'null') {\n return '' + name + '';\n } else if (name === 'undefined') {\n return '' + name + '';\n }\n\n return '' + name + '';\n };\n /**\n * Get a JSON representation of the node\n * @returns {Object}\n */\n\n\n SymbolNode.prototype.toJSON = function () {\n return {\n mathjs: 'SymbolNode',\n name: this.name\n };\n };\n /**\n * Instantiate a SymbolNode from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"SymbolNode\", name: \"x\"}`,\n * where mathjs is optional\n * @returns {SymbolNode}\n */\n\n\n SymbolNode.fromJSON = function (json) {\n return new SymbolNode(json.name);\n };\n /**\n * Get LaTeX representation\n * @param {Object} options\n * @return {string} str\n * @override\n */\n\n\n SymbolNode.prototype._toTex = function (options) {\n var isUnit = false;\n\n if (typeof math[this.name] === 'undefined' && isValuelessUnit(this.name)) {\n isUnit = true;\n }\n\n var symbol = (0, _latex.toSymbol)(this.name, isUnit);\n\n if (symbol[0] === '\\\\') {\n // no space needed if the symbol starts with '\\'\n return symbol;\n } // the space prevents symbols from breaking stuff like '\\cdot' if it's written right before the symbol\n\n\n return ' ' + symbol;\n };\n\n return SymbolNode;\n}, {\n isClass: true,\n isNode: true\n});\nexports.createSymbolNode = createSymbolNode;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.accessFactory = accessFactory;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _errorTransform = require(\"../../transform/utils/errorTransform.js\");\n\nvar _customs = require(\"../../../utils/customs.js\");\n\nfunction accessFactory(_ref) {\n var subset = _ref.subset;\n\n /**\n * Retrieve part of an object:\n *\n * - Retrieve a property from an object\n * - Retrieve a part of a string\n * - Retrieve a matrix subset\n *\n * @param {Object | Array | Matrix | string} object\n * @param {Index} index\n * @return {Object | Array | Matrix | string} Returns the subset\n */\n return function access(object, index) {\n try {\n if (Array.isArray(object)) {\n return subset(object, index);\n } else if (object && typeof object.subset === 'function') {\n // Matrix\n return object.subset(index);\n } else if (typeof object === 'string') {\n // TODO: move getStringSubset into a separate util file, use that\n return subset(object, index);\n } else if ((0, _typeof2.default)(object) === 'object') {\n if (!index.isObjectProperty()) {\n throw new TypeError('Cannot apply a numeric index as object property');\n }\n\n return (0, _customs.getSafeProperty)(object, index.getObjectProperty());\n } else {\n throw new TypeError('Cannot apply index: unsupported type of object');\n }\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n };\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.assignFactory = assignFactory;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _errorTransform = require(\"../../transform/utils/errorTransform.js\");\n\nvar _customs = require(\"../../../utils/customs.js\");\n\nfunction assignFactory(_ref) {\n var subset = _ref.subset,\n matrix = _ref.matrix;\n\n /**\n * Replace part of an object:\n *\n * - Assign a property to an object\n * - Replace a part of a string\n * - Replace a matrix subset\n *\n * @param {Object | Array | Matrix | string} object\n * @param {Index} index\n * @param {*} value\n * @return {Object | Array | Matrix | string} Returns the original object\n * except in case of a string\n */\n // TODO: change assign to return the value instead of the object\n return function assign(object, index, value) {\n try {\n if (Array.isArray(object)) {\n // we use matrix.subset here instead of the function subset because we must not clone the contents\n return matrix(object).subset(index, value).valueOf();\n } else if (object && typeof object.subset === 'function') {\n // Matrix\n return object.subset(index, value);\n } else if (typeof object === 'string') {\n // TODO: move setStringSubset into a separate util file, use that\n return subset(object, index, value);\n } else if ((0, _typeof2.default)(object) === 'object') {\n if (!index.isObjectProperty()) {\n throw TypeError('Cannot apply a numeric index as object property');\n }\n\n (0, _customs.setSafeProperty)(object, index.getObjectProperty(), value);\n return object;\n } else {\n throw new TypeError('Cannot apply index: unsupported type of object');\n }\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n };\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getAssociativity = getAssociativity;\nexports.getPrecedence = getPrecedence;\nexports.isAssociativeWith = isAssociativeWith;\nexports.properties = void 0;\n\nvar _object = require(\"../utils/object.js\");\n\n// list of identifiers of nodes in order of their precedence\n// also contains information about left/right associativity\n// and which other operator the operator is associative with\n// Example:\n// addition is associative with addition and subtraction, because:\n// (a+b)+c=a+(b+c)\n// (a+b)-c=a+(b-c)\n//\n// postfix operators are left associative, prefix operators\n// are right associative\n//\n// It's also possible to set the following properties:\n// latexParens: if set to false, this node doesn't need to be enclosed\n// in parentheses when using LaTeX\n// latexLeftParens: if set to false, this !OperatorNode's!\n// left argument doesn't need to be enclosed\n// in parentheses\n// latexRightParens: the same for the right argument\nvar properties = [{\n // assignment\n AssignmentNode: {},\n FunctionAssignmentNode: {}\n}, {\n // conditional expression\n ConditionalNode: {\n latexLeftParens: false,\n latexRightParens: false,\n latexParens: false // conditionals don't need parentheses in LaTeX because\n // they are 2 dimensional\n\n }\n}, {\n // logical or\n 'OperatorNode:or': {\n associativity: 'left',\n associativeWith: []\n }\n}, {\n // logical xor\n 'OperatorNode:xor': {\n associativity: 'left',\n associativeWith: []\n }\n}, {\n // logical and\n 'OperatorNode:and': {\n associativity: 'left',\n associativeWith: []\n }\n}, {\n // bitwise or\n 'OperatorNode:bitOr': {\n associativity: 'left',\n associativeWith: []\n }\n}, {\n // bitwise xor\n 'OperatorNode:bitXor': {\n associativity: 'left',\n associativeWith: []\n }\n}, {\n // bitwise and\n 'OperatorNode:bitAnd': {\n associativity: 'left',\n associativeWith: []\n }\n}, {\n // relational operators\n 'OperatorNode:equal': {\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:unequal': {\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:smaller': {\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:larger': {\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:smallerEq': {\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:largerEq': {\n associativity: 'left',\n associativeWith: []\n },\n RelationalNode: {\n associativity: 'left',\n associativeWith: []\n }\n}, {\n // bitshift operators\n 'OperatorNode:leftShift': {\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:rightArithShift': {\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:rightLogShift': {\n associativity: 'left',\n associativeWith: []\n }\n}, {\n // unit conversion\n 'OperatorNode:to': {\n associativity: 'left',\n associativeWith: []\n }\n}, {\n // range\n RangeNode: {}\n}, {\n // addition, subtraction\n 'OperatorNode:add': {\n associativity: 'left',\n associativeWith: ['OperatorNode:add', 'OperatorNode:subtract']\n },\n 'OperatorNode:subtract': {\n associativity: 'left',\n associativeWith: []\n }\n}, {\n // multiply, divide, modulus\n 'OperatorNode:multiply': {\n associativity: 'left',\n associativeWith: ['OperatorNode:multiply', 'OperatorNode:divide', 'Operator:dotMultiply', 'Operator:dotDivide']\n },\n 'OperatorNode:divide': {\n associativity: 'left',\n associativeWith: [],\n latexLeftParens: false,\n latexRightParens: false,\n latexParens: false // fractions don't require parentheses because\n // they're 2 dimensional, so parens aren't needed\n // in LaTeX\n\n },\n 'OperatorNode:dotMultiply': {\n associativity: 'left',\n associativeWith: ['OperatorNode:multiply', 'OperatorNode:divide', 'OperatorNode:dotMultiply', 'OperatorNode:doDivide']\n },\n 'OperatorNode:dotDivide': {\n associativity: 'left',\n associativeWith: []\n },\n 'OperatorNode:mod': {\n associativity: 'left',\n associativeWith: []\n }\n}, {\n // unary prefix operators\n 'OperatorNode:unaryPlus': {\n associativity: 'right'\n },\n 'OperatorNode:unaryMinus': {\n associativity: 'right'\n },\n 'OperatorNode:bitNot': {\n associativity: 'right'\n },\n 'OperatorNode:not': {\n associativity: 'right'\n }\n}, {\n // exponentiation\n 'OperatorNode:pow': {\n associativity: 'right',\n associativeWith: [],\n latexRightParens: false // the exponent doesn't need parentheses in\n // LaTeX because it's 2 dimensional\n // (it's on top)\n\n },\n 'OperatorNode:dotPow': {\n associativity: 'right',\n associativeWith: []\n }\n}, {\n // factorial\n 'OperatorNode:factorial': {\n associativity: 'left'\n }\n}, {\n // matrix transpose\n 'OperatorNode:transpose': {\n associativity: 'left'\n }\n}];\n/**\n * Get the precedence of a Node.\n * Higher number for higher precedence, starting with 0.\n * Returns null if the precedence is undefined.\n *\n * @param {Node} _node\n * @param {string} parenthesis\n * @return {number | null}\n */\n\nexports.properties = properties;\n\nfunction getPrecedence(_node, parenthesis) {\n var node = _node;\n\n if (parenthesis !== 'keep') {\n // ParenthesisNodes are only ignored when not in 'keep' mode\n node = _node.getContent();\n }\n\n var identifier = node.getIdentifier();\n\n for (var i = 0; i < properties.length; i++) {\n if (identifier in properties[i]) {\n return i;\n }\n }\n\n return null;\n}\n/**\n * Get the associativity of an operator (left or right).\n * Returns a string containing 'left' or 'right' or null if\n * the associativity is not defined.\n *\n * @param {Node} _node\n * @param {string} parenthesis\n * @return {string|null}\n * @throws {Error}\n */\n\n\nfunction getAssociativity(_node, parenthesis) {\n var node = _node;\n\n if (parenthesis !== 'keep') {\n // ParenthesisNodes are only ignored when not in 'keep' mode\n node = _node.getContent();\n }\n\n var identifier = node.getIdentifier();\n var index = getPrecedence(node, parenthesis);\n\n if (index === null) {\n // node isn't in the list\n return null;\n }\n\n var property = properties[index][identifier];\n\n if ((0, _object.hasOwnProperty)(property, 'associativity')) {\n if (property.associativity === 'left') {\n return 'left';\n }\n\n if (property.associativity === 'right') {\n return 'right';\n } // associativity is invalid\n\n\n throw Error('\\'' + identifier + '\\' has the invalid associativity \\'' + property.associativity + '\\'.');\n } // associativity is undefined\n\n\n return null;\n}\n/**\n * Check if an operator is associative with another operator.\n * Returns either true or false or null if not defined.\n *\n * @param {Node} nodeA\n * @param {Node} nodeB\n * @param {string} parenthesis\n * @return {boolean | null}\n */\n\n\nfunction isAssociativeWith(nodeA, nodeB, parenthesis) {\n // ParenthesisNodes are only ignored when not in 'keep' mode\n var a = parenthesis !== 'keep' ? nodeA.getContent() : nodeA;\n var b = parenthesis !== 'keep' ? nodeA.getContent() : nodeB;\n var identifierA = a.getIdentifier();\n var identifierB = b.getIdentifier();\n var index = getPrecedence(a, parenthesis);\n\n if (index === null) {\n // node isn't in the list\n return null;\n }\n\n var property = properties[index][identifierA];\n\n if ((0, _object.hasOwnProperty)(property, 'associativeWith') && property.associativeWith instanceof Array) {\n for (var i = 0; i < property.associativeWith.length; i++) {\n if (property.associativeWith[i] === identifierB) {\n return true;\n }\n }\n\n return false;\n } // associativeWith is not defined\n\n\n return null;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createParse = void 0;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _factory = require(\"../utils/factory.js\");\n\nvar _is = require(\"../utils/is.js\");\n\nvar _collection = require(\"../utils/collection.js\");\n\nvar _object = require(\"../utils/object.js\");\n\nvar name = 'parse';\nvar dependencies = ['typed', 'numeric', 'config', 'AccessorNode', 'ArrayNode', 'AssignmentNode', 'BlockNode', 'ConditionalNode', 'ConstantNode', 'FunctionAssignmentNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'ParenthesisNode', 'RangeNode', 'RelationalNode', 'SymbolNode'];\nvar createParse = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n numeric = _ref.numeric,\n config = _ref.config,\n AccessorNode = _ref.AccessorNode,\n ArrayNode = _ref.ArrayNode,\n AssignmentNode = _ref.AssignmentNode,\n BlockNode = _ref.BlockNode,\n ConditionalNode = _ref.ConditionalNode,\n ConstantNode = _ref.ConstantNode,\n FunctionAssignmentNode = _ref.FunctionAssignmentNode,\n FunctionNode = _ref.FunctionNode,\n IndexNode = _ref.IndexNode,\n ObjectNode = _ref.ObjectNode,\n OperatorNode = _ref.OperatorNode,\n ParenthesisNode = _ref.ParenthesisNode,\n RangeNode = _ref.RangeNode,\n RelationalNode = _ref.RelationalNode,\n SymbolNode = _ref.SymbolNode;\n\n /**\n * Parse an expression. Returns a node tree, which can be evaluated by\n * invoking node.evaluate().\n *\n * Note the evaluating arbitrary expressions may involve security risks,\n * see [https://mathjs.org/docs/expressions/security.html](https://mathjs.org/docs/expressions/security.html) for more information.\n *\n * Syntax:\n *\n * math.parse(expr)\n * math.parse(expr, options)\n * math.parse([expr1, expr2, expr3, ...])\n * math.parse([expr1, expr2, expr3, ...], options)\n *\n * Example:\n *\n * const node1 = math.parse('sqrt(3^2 + 4^2)')\n * node1.compile().evaluate() // 5\n *\n * let scope = {a:3, b:4}\n * const node2 = math.parse('a * b') // 12\n * const code2 = node2.compile()\n * code2.evaluate(scope) // 12\n * scope.a = 5\n * code2.evaluate(scope) // 20\n *\n * const nodes = math.parse(['a = 3', 'b = 4', 'a * b'])\n * nodes[2].compile().evaluate() // 12\n *\n * See also:\n *\n * evaluate, compile\n *\n * @param {string | string[] | Matrix} expr Expression to be parsed\n * @param {{nodes: Object}} [options] Available options:\n * - `nodes` a set of custom nodes\n * @return {Node | Node[]} node\n * @throws {Error}\n */\n var parse = typed(name, {\n string: function string(expression) {\n return parseStart(expression, {});\n },\n 'Array | Matrix': function ArrayMatrix(expressions) {\n return parseMultiple(expressions, {});\n },\n 'string, Object': function stringObject(expression, options) {\n var extraNodes = options.nodes !== undefined ? options.nodes : {};\n return parseStart(expression, extraNodes);\n },\n 'Array | Matrix, Object': parseMultiple\n });\n\n function parseMultiple(expressions) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var extraNodes = options.nodes !== undefined ? options.nodes : {}; // parse an array or matrix with expressions\n\n return (0, _collection.deepMap)(expressions, function (elem) {\n if (typeof elem !== 'string') throw new TypeError('String expected');\n return parseStart(elem, extraNodes);\n });\n } // token types enumeration\n\n\n var TOKENTYPE = {\n NULL: 0,\n DELIMITER: 1,\n NUMBER: 2,\n SYMBOL: 3,\n UNKNOWN: 4\n }; // map with all delimiters\n\n var DELIMITERS = {\n ',': true,\n '(': true,\n ')': true,\n '[': true,\n ']': true,\n '{': true,\n '}': true,\n '\"': true,\n '\\'': true,\n ';': true,\n '+': true,\n '-': true,\n '*': true,\n '.*': true,\n '/': true,\n './': true,\n '%': true,\n '^': true,\n '.^': true,\n '~': true,\n '!': true,\n '&': true,\n '|': true,\n '^|': true,\n '=': true,\n ':': true,\n '?': true,\n '==': true,\n '!=': true,\n '<': true,\n '>': true,\n '<=': true,\n '>=': true,\n '<<': true,\n '>>': true,\n '>>>': true\n }; // map with all named delimiters\n\n var NAMED_DELIMITERS = {\n mod: true,\n to: true,\n in: true,\n and: true,\n xor: true,\n or: true,\n not: true\n };\n var CONSTANTS = {\n true: true,\n false: false,\n null: null,\n undefined: undefined\n };\n var NUMERIC_CONSTANTS = ['NaN', 'Infinity'];\n\n function initialState() {\n return {\n extraNodes: {},\n // current extra nodes, must be careful not to mutate\n expression: '',\n // current expression\n comment: '',\n // last parsed comment\n index: 0,\n // current index in expr\n token: '',\n // current token\n tokenType: TOKENTYPE.NULL,\n // type of the token\n nestingLevel: 0,\n // level of nesting inside parameters, used to ignore newline characters\n conditionalLevel: null // when a conditional is being parsed, the level of the conditional is stored here\n\n };\n }\n /**\n * View upto `length` characters of the expression starting at the current character.\n *\n * @param {Object} state\n * @param {number} [length=1] Number of characters to view\n * @returns {string}\n * @private\n */\n\n\n function currentString(state, length) {\n return state.expression.substr(state.index, length);\n }\n /**\n * View the current character. Returns '' if end of expression is reached.\n *\n * @param {Object} state\n * @returns {string}\n * @private\n */\n\n\n function currentCharacter(state) {\n return currentString(state, 1);\n }\n /**\n * Get the next character from the expression.\n * The character is stored into the char c. If the end of the expression is\n * reached, the function puts an empty string in c.\n * @private\n */\n\n\n function next(state) {\n state.index++;\n }\n /**\n * Preview the previous character from the expression.\n * @return {string} cNext\n * @private\n */\n\n\n function prevCharacter(state) {\n return state.expression.charAt(state.index - 1);\n }\n /**\n * Preview the next character from the expression.\n * @return {string} cNext\n * @private\n */\n\n\n function nextCharacter(state) {\n return state.expression.charAt(state.index + 1);\n }\n /**\n * Get next token in the current string expr.\n * The token and token type are available as token and tokenType\n * @private\n */\n\n\n function getToken(state) {\n state.tokenType = TOKENTYPE.NULL;\n state.token = '';\n state.comment = ''; // skip over ignored characters:\n\n while (true) {\n // comments:\n if (currentCharacter(state) === '#') {\n while (currentCharacter(state) !== '\\n' && currentCharacter(state) !== '') {\n state.comment += currentCharacter(state);\n next(state);\n }\n } // whitespace: space, tab, and newline when inside parameters\n\n\n if (parse.isWhitespace(currentCharacter(state), state.nestingLevel)) {\n next(state);\n } else {\n break;\n }\n } // check for end of expression\n\n\n if (currentCharacter(state) === '') {\n // token is still empty\n state.tokenType = TOKENTYPE.DELIMITER;\n return;\n } // check for new line character\n\n\n if (currentCharacter(state) === '\\n' && !state.nestingLevel) {\n state.tokenType = TOKENTYPE.DELIMITER;\n state.token = currentCharacter(state);\n next(state);\n return;\n }\n\n var c1 = currentCharacter(state);\n var c2 = currentString(state, 2);\n var c3 = currentString(state, 3);\n\n if (c3.length === 3 && DELIMITERS[c3]) {\n state.tokenType = TOKENTYPE.DELIMITER;\n state.token = c3;\n next(state);\n next(state);\n next(state);\n return;\n } // check for delimiters consisting of 2 characters\n\n\n if (c2.length === 2 && DELIMITERS[c2]) {\n state.tokenType = TOKENTYPE.DELIMITER;\n state.token = c2;\n next(state);\n next(state);\n return;\n } // check for delimiters consisting of 1 character\n\n\n if (DELIMITERS[c1]) {\n state.tokenType = TOKENTYPE.DELIMITER;\n state.token = c1;\n next(state);\n return;\n } // check for a number\n\n\n if (parse.isDigitDot(c1)) {\n state.tokenType = TOKENTYPE.NUMBER; // check for binary, octal, or hex\n\n var _c = currentString(state, 2);\n\n if (_c === '0b' || _c === '0o' || _c === '0x') {\n state.token += currentCharacter(state);\n next(state);\n state.token += currentCharacter(state);\n next(state);\n\n while (parse.isHexDigit(currentCharacter(state))) {\n state.token += currentCharacter(state);\n next(state);\n }\n\n if (currentCharacter(state) === '.') {\n // this number has a radix point\n state.token += '.';\n next(state); // get the digits after the radix\n\n while (parse.isHexDigit(currentCharacter(state))) {\n state.token += currentCharacter(state);\n next(state);\n }\n } else if (currentCharacter(state) === 'i') {\n // this number has a word size suffix\n state.token += 'i';\n next(state); // get the word size\n\n while (parse.isDigit(currentCharacter(state))) {\n state.token += currentCharacter(state);\n next(state);\n }\n }\n\n return;\n } // get number, can have a single dot\n\n\n if (currentCharacter(state) === '.') {\n state.token += currentCharacter(state);\n next(state);\n\n if (!parse.isDigit(currentCharacter(state))) {\n // this is no number, it is just a dot (can be dot notation)\n state.tokenType = TOKENTYPE.DELIMITER;\n return;\n }\n } else {\n while (parse.isDigit(currentCharacter(state))) {\n state.token += currentCharacter(state);\n next(state);\n }\n\n if (parse.isDecimalMark(currentCharacter(state), nextCharacter(state))) {\n state.token += currentCharacter(state);\n next(state);\n }\n }\n\n while (parse.isDigit(currentCharacter(state))) {\n state.token += currentCharacter(state);\n next(state);\n } // check for exponential notation like \"2.3e-4\", \"1.23e50\" or \"2e+4\"\n\n\n if (currentCharacter(state) === 'E' || currentCharacter(state) === 'e') {\n if (parse.isDigit(nextCharacter(state)) || nextCharacter(state) === '-' || nextCharacter(state) === '+') {\n state.token += currentCharacter(state);\n next(state);\n\n if (currentCharacter(state) === '+' || currentCharacter(state) === '-') {\n state.token += currentCharacter(state);\n next(state);\n } // Scientific notation MUST be followed by an exponent\n\n\n if (!parse.isDigit(currentCharacter(state))) {\n throw createSyntaxError(state, 'Digit expected, got \"' + currentCharacter(state) + '\"');\n }\n\n while (parse.isDigit(currentCharacter(state))) {\n state.token += currentCharacter(state);\n next(state);\n }\n\n if (parse.isDecimalMark(currentCharacter(state), nextCharacter(state))) {\n throw createSyntaxError(state, 'Digit expected, got \"' + currentCharacter(state) + '\"');\n }\n } else if (nextCharacter(state) === '.') {\n next(state);\n throw createSyntaxError(state, 'Digit expected, got \"' + currentCharacter(state) + '\"');\n }\n }\n\n return;\n } // check for variables, functions, named operators\n\n\n if (parse.isAlpha(currentCharacter(state), prevCharacter(state), nextCharacter(state))) {\n while (parse.isAlpha(currentCharacter(state), prevCharacter(state), nextCharacter(state)) || parse.isDigit(currentCharacter(state))) {\n state.token += currentCharacter(state);\n next(state);\n }\n\n if ((0, _object.hasOwnProperty)(NAMED_DELIMITERS, state.token)) {\n state.tokenType = TOKENTYPE.DELIMITER;\n } else {\n state.tokenType = TOKENTYPE.SYMBOL;\n }\n\n return;\n } // something unknown is found, wrong characters -> a syntax error\n\n\n state.tokenType = TOKENTYPE.UNKNOWN;\n\n while (currentCharacter(state) !== '') {\n state.token += currentCharacter(state);\n next(state);\n }\n\n throw createSyntaxError(state, 'Syntax error in part \"' + state.token + '\"');\n }\n /**\n * Get next token and skip newline tokens\n */\n\n\n function getTokenSkipNewline(state) {\n do {\n getToken(state);\n } while (state.token === '\\n'); // eslint-disable-line no-unmodified-loop-condition\n\n }\n /**\n * Open parameters.\n * New line characters will be ignored until closeParams(state) is called\n */\n\n\n function openParams(state) {\n state.nestingLevel++;\n }\n /**\n * Close parameters.\n * New line characters will no longer be ignored\n */\n\n\n function closeParams(state) {\n state.nestingLevel--;\n }\n /**\n * Checks whether the current character `c` is a valid alpha character:\n *\n * - A latin letter (upper or lower case) Ascii: a-z, A-Z\n * - An underscore Ascii: _\n * - A dollar sign Ascii: $\n * - A latin letter with accents Unicode: \\u00C0 - \\u02AF\n * - A greek letter Unicode: \\u0370 - \\u03FF\n * - A mathematical alphanumeric symbol Unicode: \\u{1D400} - \\u{1D7FF} excluding invalid code points\n *\n * The previous and next characters are needed to determine whether\n * this character is part of a unicode surrogate pair.\n *\n * @param {string} c Current character in the expression\n * @param {string} cPrev Previous character\n * @param {string} cNext Next character\n * @return {boolean}\n */\n\n\n parse.isAlpha = function isAlpha(c, cPrev, cNext) {\n return parse.isValidLatinOrGreek(c) || parse.isValidMathSymbol(c, cNext) || parse.isValidMathSymbol(cPrev, c);\n };\n /**\n * Test whether a character is a valid latin, greek, or letter-like character\n * @param {string} c\n * @return {boolean}\n */\n\n\n parse.isValidLatinOrGreek = function isValidLatinOrGreek(c) {\n return /^[a-zA-Z_$\\u00C0-\\u02AF\\u0370-\\u03FF\\u2100-\\u214F]$/.test(c);\n };\n /**\n * Test whether two given 16 bit characters form a surrogate pair of a\n * unicode math symbol.\n *\n * https://unicode-table.com/en/\n * https://www.wikiwand.com/en/Mathematical_operators_and_symbols_in_Unicode\n *\n * Note: In ES6 will be unicode aware:\n * https://stackoverflow.com/questions/280712/javascript-unicode-regexes\n * https://mathiasbynens.be/notes/es6-unicode-regex\n *\n * @param {string} high\n * @param {string} low\n * @return {boolean}\n */\n\n\n parse.isValidMathSymbol = function isValidMathSymbol(high, low) {\n return /^[\\uD835]$/.test(high) && /^[\\uDC00-\\uDFFF]$/.test(low) && /^[^\\uDC55\\uDC9D\\uDCA0\\uDCA1\\uDCA3\\uDCA4\\uDCA7\\uDCA8\\uDCAD\\uDCBA\\uDCBC\\uDCC4\\uDD06\\uDD0B\\uDD0C\\uDD15\\uDD1D\\uDD3A\\uDD3F\\uDD45\\uDD47-\\uDD49\\uDD51\\uDEA6\\uDEA7\\uDFCC\\uDFCD]$/.test(low);\n };\n /**\n * Check whether given character c is a white space character: space, tab, or enter\n * @param {string} c\n * @param {number} nestingLevel\n * @return {boolean}\n */\n\n\n parse.isWhitespace = function isWhitespace(c, nestingLevel) {\n // TODO: also take '\\r' carriage return as newline? Or does that give problems on mac?\n return c === ' ' || c === '\\t' || c === '\\n' && nestingLevel > 0;\n };\n /**\n * Test whether the character c is a decimal mark (dot).\n * This is the case when it's not the start of a delimiter '.*', './', or '.^'\n * @param {string} c\n * @param {string} cNext\n * @return {boolean}\n */\n\n\n parse.isDecimalMark = function isDecimalMark(c, cNext) {\n return c === '.' && cNext !== '/' && cNext !== '*' && cNext !== '^';\n };\n /**\n * checks if the given char c is a digit or dot\n * @param {string} c a string with one character\n * @return {boolean}\n */\n\n\n parse.isDigitDot = function isDigitDot(c) {\n return c >= '0' && c <= '9' || c === '.';\n };\n /**\n * checks if the given char c is a digit\n * @param {string} c a string with one character\n * @return {boolean}\n */\n\n\n parse.isDigit = function isDigit(c) {\n return c >= '0' && c <= '9';\n };\n /**\n * checks if the given char c is a hex digit\n * @param {string} c a string with one character\n * @return {boolean}\n */\n\n\n parse.isHexDigit = function isHexDigit(c) {\n return c >= '0' && c <= '9' || c >= 'a' && c <= 'f' || c >= 'A' && c <= 'F';\n };\n /**\n * Start of the parse levels below, in order of precedence\n * @return {Node} node\n * @private\n */\n\n\n function parseStart(expression, extraNodes) {\n var state = initialState();\n (0, _extends2.default)(state, {\n expression: expression,\n extraNodes: extraNodes\n });\n getToken(state);\n var node = parseBlock(state); // check for garbage at the end of the expression\n // an expression ends with a empty character '' and tokenType DELIMITER\n\n if (state.token !== '') {\n if (state.tokenType === TOKENTYPE.DELIMITER) {\n // user entered a not existing operator like \"//\"\n // TODO: give hints for aliases, for example with \"<>\" give as hint \" did you mean !== ?\"\n throw createError(state, 'Unexpected operator ' + state.token);\n } else {\n throw createSyntaxError(state, 'Unexpected part \"' + state.token + '\"');\n }\n }\n\n return node;\n }\n /**\n * Parse a block with expressions. Expressions can be separated by a newline\n * character '\\n', or by a semicolon ';'. In case of a semicolon, no output\n * of the preceding line is returned.\n * @return {Node} node\n * @private\n */\n\n\n function parseBlock(state) {\n var node;\n var blocks = [];\n var visible;\n\n if (state.token !== '' && state.token !== '\\n' && state.token !== ';') {\n node = parseAssignment(state);\n node.comment = state.comment;\n } // TODO: simplify this loop\n\n\n while (state.token === '\\n' || state.token === ';') {\n // eslint-disable-line no-unmodified-loop-condition\n if (blocks.length === 0 && node) {\n visible = state.token !== ';';\n blocks.push({\n node: node,\n visible: visible\n });\n }\n\n getToken(state);\n\n if (state.token !== '\\n' && state.token !== ';' && state.token !== '') {\n node = parseAssignment(state);\n node.comment = state.comment;\n visible = state.token !== ';';\n blocks.push({\n node: node,\n visible: visible\n });\n }\n }\n\n if (blocks.length > 0) {\n return new BlockNode(blocks);\n } else {\n if (!node) {\n node = new ConstantNode(undefined);\n node.comment = state.comment;\n }\n\n return node;\n }\n }\n /**\n * Assignment of a function or variable,\n * - can be a variable like 'a=2.3'\n * - or a updating an existing variable like 'matrix(2,3:5)=[6,7,8]'\n * - defining a function like 'f(x) = x^2'\n * @return {Node} node\n * @private\n */\n\n\n function parseAssignment(state) {\n var name, args, value, valid;\n var node = parseConditional(state);\n\n if (state.token === '=') {\n if ((0, _is.isSymbolNode)(node)) {\n // parse a variable assignment like 'a = 2/3'\n name = node.name;\n getTokenSkipNewline(state);\n value = parseAssignment(state);\n return new AssignmentNode(new SymbolNode(name), value);\n } else if ((0, _is.isAccessorNode)(node)) {\n // parse a matrix subset assignment like 'A[1,2] = 4'\n getTokenSkipNewline(state);\n value = parseAssignment(state);\n return new AssignmentNode(node.object, node.index, value);\n } else if ((0, _is.isFunctionNode)(node) && (0, _is.isSymbolNode)(node.fn)) {\n // parse function assignment like 'f(x) = x^2'\n valid = true;\n args = [];\n name = node.name;\n node.args.forEach(function (arg, index) {\n if ((0, _is.isSymbolNode)(arg)) {\n args[index] = arg.name;\n } else {\n valid = false;\n }\n });\n\n if (valid) {\n getTokenSkipNewline(state);\n value = parseAssignment(state);\n return new FunctionAssignmentNode(name, args, value);\n }\n }\n\n throw createSyntaxError(state, 'Invalid left hand side of assignment operator =');\n }\n\n return node;\n }\n /**\n * conditional operation\n *\n * condition ? truePart : falsePart\n *\n * Note: conditional operator is right-associative\n *\n * @return {Node} node\n * @private\n */\n\n\n function parseConditional(state) {\n var node = parseLogicalOr(state);\n\n while (state.token === '?') {\n // eslint-disable-line no-unmodified-loop-condition\n // set a conditional level, the range operator will be ignored as long\n // as conditionalLevel === state.nestingLevel.\n var prev = state.conditionalLevel;\n state.conditionalLevel = state.nestingLevel;\n getTokenSkipNewline(state);\n var condition = node;\n var trueExpr = parseAssignment(state);\n if (state.token !== ':') throw createSyntaxError(state, 'False part of conditional expression expected');\n state.conditionalLevel = null;\n getTokenSkipNewline(state);\n var falseExpr = parseAssignment(state); // Note: check for conditional operator again, right associativity\n\n node = new ConditionalNode(condition, trueExpr, falseExpr); // restore the previous conditional level\n\n state.conditionalLevel = prev;\n }\n\n return node;\n }\n /**\n * logical or, 'x or y'\n * @return {Node} node\n * @private\n */\n\n\n function parseLogicalOr(state) {\n var node = parseLogicalXor(state);\n\n while (state.token === 'or') {\n // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state);\n node = new OperatorNode('or', 'or', [node, parseLogicalXor(state)]);\n }\n\n return node;\n }\n /**\n * logical exclusive or, 'x xor y'\n * @return {Node} node\n * @private\n */\n\n\n function parseLogicalXor(state) {\n var node = parseLogicalAnd(state);\n\n while (state.token === 'xor') {\n // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state);\n node = new OperatorNode('xor', 'xor', [node, parseLogicalAnd(state)]);\n }\n\n return node;\n }\n /**\n * logical and, 'x and y'\n * @return {Node} node\n * @private\n */\n\n\n function parseLogicalAnd(state) {\n var node = parseBitwiseOr(state);\n\n while (state.token === 'and') {\n // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state);\n node = new OperatorNode('and', 'and', [node, parseBitwiseOr(state)]);\n }\n\n return node;\n }\n /**\n * bitwise or, 'x | y'\n * @return {Node} node\n * @private\n */\n\n\n function parseBitwiseOr(state) {\n var node = parseBitwiseXor(state);\n\n while (state.token === '|') {\n // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state);\n node = new OperatorNode('|', 'bitOr', [node, parseBitwiseXor(state)]);\n }\n\n return node;\n }\n /**\n * bitwise exclusive or (xor), 'x ^| y'\n * @return {Node} node\n * @private\n */\n\n\n function parseBitwiseXor(state) {\n var node = parseBitwiseAnd(state);\n\n while (state.token === '^|') {\n // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state);\n node = new OperatorNode('^|', 'bitXor', [node, parseBitwiseAnd(state)]);\n }\n\n return node;\n }\n /**\n * bitwise and, 'x & y'\n * @return {Node} node\n * @private\n */\n\n\n function parseBitwiseAnd(state) {\n var node = parseRelational(state);\n\n while (state.token === '&') {\n // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state);\n node = new OperatorNode('&', 'bitAnd', [node, parseRelational(state)]);\n }\n\n return node;\n }\n /**\n * Parse a chained conditional, like 'a > b >= c'\n * @return {Node} node\n */\n\n\n function parseRelational(state) {\n var params = [parseShift(state)];\n var conditionals = [];\n var operators = {\n '==': 'equal',\n '!=': 'unequal',\n '<': 'smaller',\n '>': 'larger',\n '<=': 'smallerEq',\n '>=': 'largerEq'\n };\n\n while ((0, _object.hasOwnProperty)(operators, state.token)) {\n // eslint-disable-line no-unmodified-loop-condition\n var cond = {\n name: state.token,\n fn: operators[state.token]\n };\n conditionals.push(cond);\n getTokenSkipNewline(state);\n params.push(parseShift(state));\n }\n\n if (params.length === 1) {\n return params[0];\n } else if (params.length === 2) {\n return new OperatorNode(conditionals[0].name, conditionals[0].fn, params);\n } else {\n return new RelationalNode(conditionals.map(function (c) {\n return c.fn;\n }), params);\n }\n }\n /**\n * Bitwise left shift, bitwise right arithmetic shift, bitwise right logical shift\n * @return {Node} node\n * @private\n */\n\n\n function parseShift(state) {\n var node, name, fn, params;\n node = parseConversion(state);\n var operators = {\n '<<': 'leftShift',\n '>>': 'rightArithShift',\n '>>>': 'rightLogShift'\n };\n\n while ((0, _object.hasOwnProperty)(operators, state.token)) {\n name = state.token;\n fn = operators[name];\n getTokenSkipNewline(state);\n params = [node, parseConversion(state)];\n node = new OperatorNode(name, fn, params);\n }\n\n return node;\n }\n /**\n * conversion operators 'to' and 'in'\n * @return {Node} node\n * @private\n */\n\n\n function parseConversion(state) {\n var node, name, fn, params;\n node = parseRange(state);\n var operators = {\n to: 'to',\n in: 'to' // alias of 'to'\n\n };\n\n while ((0, _object.hasOwnProperty)(operators, state.token)) {\n name = state.token;\n fn = operators[name];\n getTokenSkipNewline(state);\n\n if (name === 'in' && state.token === '') {\n // end of expression -> this is the unit 'in' ('inch')\n node = new OperatorNode('*', 'multiply', [node, new SymbolNode('in')], true);\n } else {\n // operator 'a to b' or 'a in b'\n params = [node, parseRange(state)];\n node = new OperatorNode(name, fn, params);\n }\n }\n\n return node;\n }\n /**\n * parse range, \"start:end\", \"start:step:end\", \":\", \"start:\", \":end\", etc\n * @return {Node} node\n * @private\n */\n\n\n function parseRange(state) {\n var node;\n var params = [];\n\n if (state.token === ':') {\n // implicit start=1 (one-based)\n node = new ConstantNode(1);\n } else {\n // explicit start\n node = parseAddSubtract(state);\n }\n\n if (state.token === ':' && state.conditionalLevel !== state.nestingLevel) {\n // we ignore the range operator when a conditional operator is being processed on the same level\n params.push(node); // parse step and end\n\n while (state.token === ':' && params.length < 3) {\n // eslint-disable-line no-unmodified-loop-condition\n getTokenSkipNewline(state);\n\n if (state.token === ')' || state.token === ']' || state.token === ',' || state.token === '') {\n // implicit end\n params.push(new SymbolNode('end'));\n } else {\n // explicit end\n params.push(parseAddSubtract(state));\n }\n }\n\n if (params.length === 3) {\n // params = [start, step, end]\n node = new RangeNode(params[0], params[2], params[1]); // start, end, step\n } else {\n // length === 2\n // params = [start, end]\n node = new RangeNode(params[0], params[1]); // start, end\n }\n }\n\n return node;\n }\n /**\n * add or subtract\n * @return {Node} node\n * @private\n */\n\n\n function parseAddSubtract(state) {\n var node, name, fn, params;\n node = parseMultiplyDivide(state);\n var operators = {\n '+': 'add',\n '-': 'subtract'\n };\n\n while ((0, _object.hasOwnProperty)(operators, state.token)) {\n name = state.token;\n fn = operators[name];\n getTokenSkipNewline(state);\n var rightNode = parseMultiplyDivide(state);\n\n if (rightNode.isPercentage) {\n params = [node, new OperatorNode('*', 'multiply', [node, rightNode])];\n } else {\n params = [node, rightNode];\n }\n\n node = new OperatorNode(name, fn, params);\n }\n\n return node;\n }\n /**\n * multiply, divide, modulus\n * @return {Node} node\n * @private\n */\n\n\n function parseMultiplyDivide(state) {\n var node, last, name, fn;\n node = parseImplicitMultiplication(state);\n last = node;\n var operators = {\n '*': 'multiply',\n '.*': 'dotMultiply',\n '/': 'divide',\n './': 'dotDivide'\n };\n\n while (true) {\n if ((0, _object.hasOwnProperty)(operators, state.token)) {\n // explicit operators\n name = state.token;\n fn = operators[name];\n getTokenSkipNewline(state);\n last = parseImplicitMultiplication(state);\n node = new OperatorNode(name, fn, [node, last]);\n } else {\n break;\n }\n }\n\n return node;\n }\n /**\n * implicit multiplication\n * @return {Node} node\n * @private\n */\n\n\n function parseImplicitMultiplication(state) {\n var node, last;\n node = parseRule2(state);\n last = node;\n\n while (true) {\n if (state.tokenType === TOKENTYPE.SYMBOL || state.token === 'in' && (0, _is.isConstantNode)(node) || state.tokenType === TOKENTYPE.NUMBER && !(0, _is.isConstantNode)(last) && (!(0, _is.isOperatorNode)(last) || last.op === '!') || state.token === '(') {\n // parse implicit multiplication\n //\n // symbol: implicit multiplication like '2a', '(2+3)a', 'a b'\n // number: implicit multiplication like '(2+3)2'\n // parenthesis: implicit multiplication like '2(3+4)', '(3+4)(1+2)'\n last = parseRule2(state);\n node = new OperatorNode('*', 'multiply', [node, last], true\n /* implicit */\n );\n } else {\n break;\n }\n }\n\n return node;\n }\n /**\n * Infamous \"rule 2\" as described in https://github.com/josdejong/mathjs/issues/792#issuecomment-361065370\n * Explicit division gets higher precedence than implicit multiplication\n * when the division matches this pattern: [number] / [number] [symbol]\n * @return {Node} node\n * @private\n */\n\n\n function parseRule2(state) {\n var node = parsePercentage(state);\n var last = node;\n var tokenStates = [];\n\n while (true) {\n // Match the \"number /\" part of the pattern \"number / number symbol\"\n if (state.token === '/' && (0, _is.isConstantNode)(last)) {\n // Look ahead to see if the next token is a number\n tokenStates.push((0, _extends2.default)({}, state));\n getTokenSkipNewline(state); // Match the \"number / number\" part of the pattern\n\n if (state.tokenType === TOKENTYPE.NUMBER) {\n // Look ahead again\n tokenStates.push((0, _extends2.default)({}, state));\n getTokenSkipNewline(state); // Match the \"symbol\" part of the pattern, or a left parenthesis\n\n if (state.tokenType === TOKENTYPE.SYMBOL || state.token === '(') {\n // We've matched the pattern \"number / number symbol\".\n // Rewind once and build the \"number / number\" node; the symbol will be consumed later\n (0, _extends2.default)(state, tokenStates.pop());\n tokenStates.pop();\n last = parsePercentage(state);\n node = new OperatorNode('/', 'divide', [node, last]);\n } else {\n // Not a match, so rewind\n tokenStates.pop();\n (0, _extends2.default)(state, tokenStates.pop());\n break;\n }\n } else {\n // Not a match, so rewind\n (0, _extends2.default)(state, tokenStates.pop());\n break;\n }\n } else {\n break;\n }\n }\n\n return node;\n }\n /**\n * percentage or mod\n * @return {Node} node\n * @private\n */\n\n\n function parsePercentage(state) {\n var node, name, fn, params;\n node = parseUnary(state);\n var operators = {\n '%': 'mod',\n mod: 'mod'\n };\n\n while ((0, _object.hasOwnProperty)(operators, state.token)) {\n name = state.token;\n fn = operators[name];\n getTokenSkipNewline(state);\n\n if (name === '%' && state.tokenType === TOKENTYPE.DELIMITER && state.token !== '(') {\n // If the expression contains only %, then treat that as /100\n node = new OperatorNode('/', 'divide', [node, new ConstantNode(100)], false, true);\n } else {\n params = [node, parseUnary(state)];\n node = new OperatorNode(name, fn, params);\n }\n }\n\n return node;\n }\n /**\n * Unary plus and minus, and logical and bitwise not\n * @return {Node} node\n * @private\n */\n\n\n function parseUnary(state) {\n var name, params, fn;\n var operators = {\n '-': 'unaryMinus',\n '+': 'unaryPlus',\n '~': 'bitNot',\n not: 'not'\n };\n\n if ((0, _object.hasOwnProperty)(operators, state.token)) {\n fn = operators[state.token];\n name = state.token;\n getTokenSkipNewline(state);\n params = [parseUnary(state)];\n return new OperatorNode(name, fn, params);\n }\n\n return parsePow(state);\n }\n /**\n * power\n * Note: power operator is right associative\n * @return {Node} node\n * @private\n */\n\n\n function parsePow(state) {\n var node, name, fn, params;\n node = parseLeftHandOperators(state);\n\n if (state.token === '^' || state.token === '.^') {\n name = state.token;\n fn = name === '^' ? 'pow' : 'dotPow';\n getTokenSkipNewline(state);\n params = [node, parseUnary(state)]; // Go back to unary, we can have '2^-3'\n\n node = new OperatorNode(name, fn, params);\n }\n\n return node;\n }\n /**\n * Left hand operators: factorial x!, ctranspose x'\n * @return {Node} node\n * @private\n */\n\n\n function parseLeftHandOperators(state) {\n var node, name, fn, params;\n node = parseCustomNodes(state);\n var operators = {\n '!': 'factorial',\n '\\'': 'ctranspose'\n };\n\n while ((0, _object.hasOwnProperty)(operators, state.token)) {\n name = state.token;\n fn = operators[name];\n getToken(state);\n params = [node];\n node = new OperatorNode(name, fn, params);\n node = parseAccessors(state, node);\n }\n\n return node;\n }\n /**\n * Parse a custom node handler. A node handler can be used to process\n * nodes in a custom way, for example for handling a plot.\n *\n * A handler must be passed as second argument of the parse function.\n * - must extend math.Node\n * - must contain a function _compile(defs: Object) : string\n * - must contain a function find(filter: Object) : Node[]\n * - must contain a function toString() : string\n * - the constructor is called with a single argument containing all parameters\n *\n * For example:\n *\n * nodes = {\n * 'plot': PlotHandler\n * }\n *\n * The constructor of the handler is called as:\n *\n * node = new PlotHandler(params)\n *\n * The handler will be invoked when evaluating an expression like:\n *\n * node = math.parse('plot(sin(x), x)', nodes)\n *\n * @return {Node} node\n * @private\n */\n\n\n function parseCustomNodes(state) {\n var params = [];\n\n if (state.tokenType === TOKENTYPE.SYMBOL && (0, _object.hasOwnProperty)(state.extraNodes, state.token)) {\n var CustomNode = state.extraNodes[state.token];\n getToken(state); // parse parameters\n\n if (state.token === '(') {\n params = [];\n openParams(state);\n getToken(state);\n\n if (state.token !== ')') {\n params.push(parseAssignment(state)); // parse a list with parameters\n\n while (state.token === ',') {\n // eslint-disable-line no-unmodified-loop-condition\n getToken(state);\n params.push(parseAssignment(state));\n }\n }\n\n if (state.token !== ')') {\n throw createSyntaxError(state, 'Parenthesis ) expected');\n }\n\n closeParams(state);\n getToken(state);\n } // create a new custom node\n // noinspection JSValidateTypes\n\n\n return new CustomNode(params);\n }\n\n return parseSymbol(state);\n }\n /**\n * parse symbols: functions, variables, constants, units\n * @return {Node} node\n * @private\n */\n\n\n function parseSymbol(state) {\n var node, name;\n\n if (state.tokenType === TOKENTYPE.SYMBOL || state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS) {\n name = state.token;\n getToken(state);\n\n if ((0, _object.hasOwnProperty)(CONSTANTS, name)) {\n // true, false, null, ...\n node = new ConstantNode(CONSTANTS[name]);\n } else if (NUMERIC_CONSTANTS.indexOf(name) !== -1) {\n // NaN, Infinity\n node = new ConstantNode(numeric(name, 'number'));\n } else {\n node = new SymbolNode(name);\n } // parse function parameters and matrix index\n\n\n node = parseAccessors(state, node);\n return node;\n }\n\n return parseDoubleQuotesString(state);\n }\n /**\n * parse accessors:\n * - function invocation in round brackets (...), for example sqrt(2)\n * - index enclosed in square brackets [...], for example A[2,3]\n * - dot notation for properties, like foo.bar\n * @param {Object} state\n * @param {Node} node Node on which to apply the parameters. If there\n * are no parameters in the expression, the node\n * itself is returned\n * @param {string[]} [types] Filter the types of notations\n * can be ['(', '[', '.']\n * @return {Node} node\n * @private\n */\n\n\n function parseAccessors(state, node, types) {\n var params;\n\n while ((state.token === '(' || state.token === '[' || state.token === '.') && (!types || types.indexOf(state.token) !== -1)) {\n // eslint-disable-line no-unmodified-loop-condition\n params = [];\n\n if (state.token === '(') {\n if ((0, _is.isSymbolNode)(node) || (0, _is.isAccessorNode)(node)) {\n // function invocation like fn(2, 3) or obj.fn(2, 3)\n openParams(state);\n getToken(state);\n\n if (state.token !== ')') {\n params.push(parseAssignment(state)); // parse a list with parameters\n\n while (state.token === ',') {\n // eslint-disable-line no-unmodified-loop-condition\n getToken(state);\n params.push(parseAssignment(state));\n }\n }\n\n if (state.token !== ')') {\n throw createSyntaxError(state, 'Parenthesis ) expected');\n }\n\n closeParams(state);\n getToken(state);\n node = new FunctionNode(node, params);\n } else {\n // implicit multiplication like (2+3)(4+5) or sqrt(2)(1+2)\n // don't parse it here but let it be handled by parseImplicitMultiplication\n // with correct precedence\n return node;\n }\n } else if (state.token === '[') {\n // index notation like variable[2, 3]\n openParams(state);\n getToken(state);\n\n if (state.token !== ']') {\n params.push(parseAssignment(state)); // parse a list with parameters\n\n while (state.token === ',') {\n // eslint-disable-line no-unmodified-loop-condition\n getToken(state);\n params.push(parseAssignment(state));\n }\n }\n\n if (state.token !== ']') {\n throw createSyntaxError(state, 'Parenthesis ] expected');\n }\n\n closeParams(state);\n getToken(state);\n node = new AccessorNode(node, new IndexNode(params));\n } else {\n // dot notation like variable.prop\n getToken(state);\n\n if (state.tokenType !== TOKENTYPE.SYMBOL) {\n throw createSyntaxError(state, 'Property name expected after dot');\n }\n\n params.push(new ConstantNode(state.token));\n getToken(state);\n var dotNotation = true;\n node = new AccessorNode(node, new IndexNode(params, dotNotation));\n }\n }\n\n return node;\n }\n /**\n * Parse a double quotes string.\n * @return {Node} node\n * @private\n */\n\n\n function parseDoubleQuotesString(state) {\n var node, str;\n\n if (state.token === '\"') {\n str = parseDoubleQuotesStringToken(state); // create constant\n\n node = new ConstantNode(str); // parse index parameters\n\n node = parseAccessors(state, node);\n return node;\n }\n\n return parseSingleQuotesString(state);\n }\n /**\n * Parse a string surrounded by double quotes \"...\"\n * @return {string}\n */\n\n\n function parseDoubleQuotesStringToken(state) {\n var str = '';\n\n while (currentCharacter(state) !== '' && currentCharacter(state) !== '\"') {\n if (currentCharacter(state) === '\\\\') {\n // escape character, immediately process the next\n // character to prevent stopping at a next '\\\"'\n str += currentCharacter(state);\n next(state);\n }\n\n str += currentCharacter(state);\n next(state);\n }\n\n getToken(state);\n\n if (state.token !== '\"') {\n throw createSyntaxError(state, 'End of string \" expected');\n }\n\n getToken(state);\n return JSON.parse('\"' + str + '\"'); // unescape escaped characters\n }\n /**\n * Parse a single quotes string.\n * @return {Node} node\n * @private\n */\n\n\n function parseSingleQuotesString(state) {\n var node, str;\n\n if (state.token === '\\'') {\n str = parseSingleQuotesStringToken(state); // create constant\n\n node = new ConstantNode(str); // parse index parameters\n\n node = parseAccessors(state, node);\n return node;\n }\n\n return parseMatrix(state);\n }\n /**\n * Parse a string surrounded by single quotes '...'\n * @return {string}\n */\n\n\n function parseSingleQuotesStringToken(state) {\n var str = '';\n\n while (currentCharacter(state) !== '' && currentCharacter(state) !== '\\'') {\n if (currentCharacter(state) === '\\\\') {\n // escape character, immediately process the next\n // character to prevent stopping at a next '\\''\n str += currentCharacter(state);\n next(state);\n }\n\n str += currentCharacter(state);\n next(state);\n }\n\n getToken(state);\n\n if (state.token !== '\\'') {\n throw createSyntaxError(state, 'End of string \\' expected');\n }\n\n getToken(state);\n return JSON.parse('\"' + str + '\"'); // unescape escaped characters\n }\n /**\n * parse the matrix\n * @return {Node} node\n * @private\n */\n\n\n function parseMatrix(state) {\n var array, params, rows, cols;\n\n if (state.token === '[') {\n // matrix [...]\n openParams(state);\n getToken(state);\n\n if (state.token !== ']') {\n // this is a non-empty matrix\n var row = parseRow(state);\n\n if (state.token === ';') {\n // 2 dimensional array\n rows = 1;\n params = [row]; // the rows of the matrix are separated by dot-comma's\n\n while (state.token === ';') {\n // eslint-disable-line no-unmodified-loop-condition\n getToken(state);\n params[rows] = parseRow(state);\n rows++;\n }\n\n if (state.token !== ']') {\n throw createSyntaxError(state, 'End of matrix ] expected');\n }\n\n closeParams(state);\n getToken(state); // check if the number of columns matches in all rows\n\n cols = params[0].items.length;\n\n for (var r = 1; r < rows; r++) {\n if (params[r].items.length !== cols) {\n throw createError(state, 'Column dimensions mismatch ' + '(' + params[r].items.length + ' !== ' + cols + ')');\n }\n }\n\n array = new ArrayNode(params);\n } else {\n // 1 dimensional vector\n if (state.token !== ']') {\n throw createSyntaxError(state, 'End of matrix ] expected');\n }\n\n closeParams(state);\n getToken(state);\n array = row;\n }\n } else {\n // this is an empty matrix \"[ ]\"\n closeParams(state);\n getToken(state);\n array = new ArrayNode([]);\n }\n\n return parseAccessors(state, array);\n }\n\n return parseObject(state);\n }\n /**\n * Parse a single comma-separated row from a matrix, like 'a, b, c'\n * @return {ArrayNode} node\n */\n\n\n function parseRow(state) {\n var params = [parseAssignment(state)];\n var len = 1;\n\n while (state.token === ',') {\n // eslint-disable-line no-unmodified-loop-condition\n getToken(state); // parse expression\n\n params[len] = parseAssignment(state);\n len++;\n }\n\n return new ArrayNode(params);\n }\n /**\n * parse an object, enclosed in angle brackets{...}, for example {value: 2}\n * @return {Node} node\n * @private\n */\n\n\n function parseObject(state) {\n if (state.token === '{') {\n openParams(state);\n var key;\n var properties = {};\n\n do {\n getToken(state);\n\n if (state.token !== '}') {\n // parse key\n if (state.token === '\"') {\n key = parseDoubleQuotesStringToken(state);\n } else if (state.token === '\\'') {\n key = parseSingleQuotesStringToken(state);\n } else if (state.tokenType === TOKENTYPE.SYMBOL || state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS) {\n key = state.token;\n getToken(state);\n } else {\n throw createSyntaxError(state, 'Symbol or string expected as object key');\n } // parse key/value separator\n\n\n if (state.token !== ':') {\n throw createSyntaxError(state, 'Colon : expected after object key');\n }\n\n getToken(state); // parse key\n\n properties[key] = parseAssignment(state);\n }\n } while (state.token === ','); // eslint-disable-line no-unmodified-loop-condition\n\n\n if (state.token !== '}') {\n throw createSyntaxError(state, 'Comma , or bracket } expected after object value');\n }\n\n closeParams(state);\n getToken(state);\n var node = new ObjectNode(properties); // parse index parameters\n\n node = parseAccessors(state, node);\n return node;\n }\n\n return parseNumber(state);\n }\n /**\n * parse a number\n * @return {Node} node\n * @private\n */\n\n\n function parseNumber(state) {\n var numberStr;\n\n if (state.tokenType === TOKENTYPE.NUMBER) {\n // this is a number\n numberStr = state.token;\n getToken(state);\n return new ConstantNode(numeric(numberStr, config.number));\n }\n\n return parseParentheses(state);\n }\n /**\n * parentheses\n * @return {Node} node\n * @private\n */\n\n\n function parseParentheses(state) {\n var node; // check if it is a parenthesized expression\n\n if (state.token === '(') {\n // parentheses (...)\n openParams(state);\n getToken(state);\n node = parseAssignment(state); // start again\n\n if (state.token !== ')') {\n throw createSyntaxError(state, 'Parenthesis ) expected');\n }\n\n closeParams(state);\n getToken(state);\n node = new ParenthesisNode(node);\n node = parseAccessors(state, node);\n return node;\n }\n\n return parseEnd(state);\n }\n /**\n * Evaluated when the expression is not yet ended but expected to end\n * @return {Node} res\n * @private\n */\n\n\n function parseEnd(state) {\n if (state.token === '') {\n // syntax error or unexpected end of expression\n throw createSyntaxError(state, 'Unexpected end of expression');\n } else {\n throw createSyntaxError(state, 'Value expected');\n }\n }\n /**\n * Shortcut for getting the current row value (one based)\n * Returns the line of the currently handled expression\n * @private\n */\n\n /* TODO: implement keeping track on the row number\n function row () {\n return null\n }\n */\n\n /**\n * Shortcut for getting the current col value (one based)\n * Returns the column (position) where the last state.token starts\n * @private\n */\n\n\n function col(state) {\n return state.index - state.token.length + 1;\n }\n /**\n * Create an error\n * @param {Object} state\n * @param {string} message\n * @return {SyntaxError} instantiated error\n * @private\n */\n\n\n function createSyntaxError(state, message) {\n var c = col(state);\n var error = new SyntaxError(message + ' (char ' + c + ')');\n error.char = c;\n return error;\n }\n /**\n * Create an error\n * @param {Object} state\n * @param {string} message\n * @return {Error} instantiated error\n * @private\n */\n\n\n function createError(state, message) {\n var c = col(state);\n var error = new SyntaxError(message + ' (char ' + c + ')');\n error.char = c;\n return error;\n }\n\n return parse;\n});\nexports.createParse = createParse;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createApplyTransform = void 0;\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _apply = require(\"../../function/matrix/apply.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar name = 'apply';\nvar dependencies = ['typed', 'isInteger'];\n/**\n * Attach a transform function to math.apply\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function apply\n * from one-based to zero based\n */\n\nvar createApplyTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n isInteger = _ref.isInteger;\n var apply = (0, _apply.createApply)({\n typed: typed,\n isInteger: isInteger\n }); // @see: comment of concat itself\n\n return typed('apply', {\n '...any': function any(args) {\n // change dim from one-based to zero-based\n var dim = args[1];\n\n if ((0, _is.isNumber)(dim)) {\n args[1] = dim - 1;\n } else if ((0, _is.isBigNumber)(dim)) {\n args[1] = dim.minus(1);\n }\n\n try {\n return apply.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createApplyTransform = createApplyTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createColumnTransform = void 0;\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _column = require(\"../../function/matrix/column.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar name = 'column';\nvar dependencies = ['typed', 'Index', 'matrix', 'range'];\n/**\n * Attach a transform function to matrix.column\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `index` parameter of function column\n * from zero-based to one-based\n */\n\nvar createColumnTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Index = _ref.Index,\n matrix = _ref.matrix,\n range = _ref.range;\n var column = (0, _column.createColumn)({\n typed: typed,\n Index: Index,\n matrix: matrix,\n range: range\n }); // @see: comment of column itself\n\n return typed('column', {\n '...any': function any(args) {\n // change last argument from zero-based to one-based\n var lastIndex = args.length - 1;\n var last = args[lastIndex];\n\n if ((0, _is.isNumber)(last)) {\n args[lastIndex] = last - 1;\n }\n\n try {\n return column.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createColumnTransform = createColumnTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createConcatTransform = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _concat = require(\"../../function/matrix/concat.js\");\n\nvar name = 'concat';\nvar dependencies = ['typed', 'matrix', 'isInteger'];\nvar createConcatTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n isInteger = _ref.isInteger;\n var concat = (0, _concat.createConcat)({\n typed: typed,\n matrix: matrix,\n isInteger: isInteger\n });\n /**\n * Attach a transform function to math.range\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function concat\n * from one-based to zero based\n */\n\n return typed('concat', {\n '...any': function any(args) {\n // change last argument from one-based to zero-based\n var lastIndex = args.length - 1;\n var last = args[lastIndex];\n\n if ((0, _is.isNumber)(last)) {\n args[lastIndex] = last - 1;\n } else if ((0, _is.isBigNumber)(last)) {\n args[lastIndex] = last.minus(1);\n }\n\n try {\n return concat.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createConcatTransform = createConcatTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCumSumTransform = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _cumsum = require(\"../../function/statistics/cumsum.js\");\n\n/**\n * Attach a transform function to math.sum\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function sum\n * from one-based to zero based\n */\nvar name = 'cumsum';\nvar dependencies = ['typed', 'add', 'unaryPlus'];\nvar createCumSumTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n add = _ref.add,\n unaryPlus = _ref.unaryPlus;\n var cumsum = (0, _cumsum.createCumSum)({\n typed: typed,\n add: add,\n unaryPlus: unaryPlus\n });\n return typed(name, {\n '...any': function any(args) {\n // change last argument dim from one-based to zero-based\n if (args.length === 2 && (0, _is.isCollection)(args[0])) {\n var dim = args[1];\n\n if ((0, _is.isNumber)(dim)) {\n args[1] = dim - 1;\n } else if ((0, _is.isBigNumber)(dim)) {\n args[1] = dim.minus(1);\n }\n }\n\n try {\n return cumsum.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createCumSumTransform = createCumSumTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDiffTransform = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _diff = require(\"../../function/matrix/diff.js\");\n\nvar _lastDimToZeroBase = require(\"./utils/lastDimToZeroBase.js\");\n\nvar name = 'diff';\nvar dependencies = ['typed', 'matrix', 'subtract', 'number', 'bignumber'];\nvar createDiffTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n subtract = _ref.subtract,\n number = _ref.number,\n bignumber = _ref.bignumber;\n var diff = (0, _diff.createDiff)({\n typed: typed,\n matrix: matrix,\n subtract: subtract,\n number: number,\n bignumber: bignumber\n });\n /**\n * Attach a transform function to math.diff\n * Adds a property transform containing the transform function.\n *\n * This transform creates a range which includes the end value\n */\n\n return typed(name, {\n '...any': function any(args) {\n args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args);\n\n try {\n return diff.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createDiffTransform = createDiffTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFilterTransform = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _function = require(\"../../utils/function.js\");\n\nvar _compileInlineExpression = require(\"./utils/compileInlineExpression.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'filter';\nvar dependencies = ['typed'];\nvar createFilterTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Attach a transform function to math.filter\n * Adds a property transform containing the transform function.\n *\n * This transform adds support for equations as test function for math.filter,\n * so you can do something like 'filter([3, -2, 5], x > 0)'.\n */\n function filterTransform(args, math, scope) {\n var x, callback;\n\n if (args[0]) {\n x = args[0].compile().evaluate(scope);\n }\n\n if (args[1]) {\n if ((0, _is.isSymbolNode)(args[1]) || (0, _is.isFunctionAssignmentNode)(args[1])) {\n // a function pointer, like filter([3, -2, 5], myTestFunction)\n callback = args[1].compile().evaluate(scope);\n } else {\n // an expression like filter([3, -2, 5], x > 0)\n callback = (0, _compileInlineExpression.compileInlineExpression)(args[1], math, scope);\n }\n }\n\n return filter(x, callback);\n }\n\n filterTransform.rawArgs = true; // one based version of function filter\n\n var filter = typed('filter', {\n 'Array, function': _filter,\n 'Matrix, function': function MatrixFunction(x, test) {\n return x.create(_filter(x.toArray(), test));\n },\n 'Array, RegExp': _array.filterRegExp,\n 'Matrix, RegExp': function MatrixRegExp(x, test) {\n return x.create((0, _array.filterRegExp)(x.toArray(), test));\n }\n });\n return filterTransform;\n}, {\n isTransformFunction: true\n});\n/**\n * Filter values in a callback given a callback function\n *\n * !!! Passes a one-based index !!!\n *\n * @param {Array} x\n * @param {Function} callback\n * @return {Array} Returns the filtered array\n * @private\n */\n\nexports.createFilterTransform = createFilterTransform;\n\nfunction _filter(x, callback) {\n // figure out what number of arguments the callback function expects\n var args = (0, _function.maxArgumentCount)(callback);\n return (0, _array.filter)(x, function (value, index, array) {\n // invoke the callback function with the right number of arguments\n if (args === 1) {\n return callback(value);\n } else if (args === 2) {\n return callback(value, [index + 1]);\n } else {\n // 3 or -1\n return callback(value, [index + 1], array);\n }\n });\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createForEachTransform = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _function = require(\"../../utils/function.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _compileInlineExpression = require(\"./utils/compileInlineExpression.js\");\n\nvar name = 'forEach';\nvar dependencies = ['typed'];\nvar createForEachTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Attach a transform function to math.forEach\n * Adds a property transform containing the transform function.\n *\n * This transform creates a one-based index instead of a zero-based index\n */\n function forEachTransform(args, math, scope) {\n var x, callback;\n\n if (args[0]) {\n x = args[0].compile().evaluate(scope);\n }\n\n if (args[1]) {\n if ((0, _is.isSymbolNode)(args[1]) || (0, _is.isFunctionAssignmentNode)(args[1])) {\n // a function pointer, like forEach([3, -2, 5], myTestFunction)\n callback = args[1].compile().evaluate(scope);\n } else {\n // an expression like forEach([3, -2, 5], x > 0 ? callback1(x) : callback2(x) )\n callback = (0, _compileInlineExpression.compileInlineExpression)(args[1], math, scope);\n }\n }\n\n return _forEach(x, callback);\n }\n\n forEachTransform.rawArgs = true; // one-based version of forEach\n\n var _forEach = typed('forEach', {\n 'Array | Matrix, function': function ArrayMatrixFunction(array, callback) {\n // figure out what number of arguments the callback function expects\n var args = (0, _function.maxArgumentCount)(callback);\n\n var recurse = function recurse(value, index) {\n if (Array.isArray(value)) {\n (0, _array.forEach)(value, function (child, i) {\n // we create a copy of the index array and append the new index value\n recurse(child, index.concat(i + 1)); // one based index, hence i+1\n });\n } else {\n // invoke the callback function with the right number of arguments\n if (args === 1) {\n callback(value);\n } else if (args === 2) {\n callback(value, index);\n } else {\n // 3 or -1\n callback(value, index, array);\n }\n }\n };\n\n recurse(array.valueOf(), []); // pass Array\n }\n });\n\n return forEachTransform;\n}, {\n isTransformFunction: true\n});\nexports.createForEachTransform = createForEachTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIndexTransform = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'index';\nvar dependencies = ['Index'];\nvar createIndexTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var Index = _ref.Index;\n\n /**\n * Attach a transform function to math.index\n * Adds a property transform containing the transform function.\n *\n * This transform creates a one-based index instead of a zero-based index\n */\n return function indexTransform() {\n var args = [];\n\n for (var i = 0, ii = arguments.length; i < ii; i++) {\n var arg = arguments[i]; // change from one-based to zero based, and convert BigNumber to number\n\n if ((0, _is.isRange)(arg)) {\n arg.start--;\n arg.end -= arg.step > 0 ? 0 : 2;\n } else if (arg && arg.isSet === true) {\n arg = arg.map(function (v) {\n return v - 1;\n });\n } else if ((0, _is.isArray)(arg) || (0, _is.isMatrix)(arg)) {\n arg = arg.map(function (v) {\n return v - 1;\n });\n } else if ((0, _is.isNumber)(arg)) {\n arg--;\n } else if ((0, _is.isBigNumber)(arg)) {\n arg = arg.toNumber() - 1;\n } else if (typeof arg === 'string') {// leave as is\n } else {\n throw new TypeError('Dimension must be an Array, Matrix, number, string, or Range');\n }\n\n args[i] = arg;\n }\n\n var res = new Index();\n Index.apply(res, args);\n return res;\n };\n}, {\n isTransformFunction: true\n});\nexports.createIndexTransform = createIndexTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMapTransform = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _function = require(\"../../utils/function.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _compileInlineExpression = require(\"./utils/compileInlineExpression.js\");\n\nvar name = 'map';\nvar dependencies = ['typed'];\nvar createMapTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Attach a transform function to math.map\n * Adds a property transform containing the transform function.\n *\n * This transform creates a one-based index instead of a zero-based index\n */\n function mapTransform(args, math, scope) {\n var x, callback;\n\n if (args[0]) {\n x = args[0].compile().evaluate(scope);\n }\n\n if (args[1]) {\n if ((0, _is.isSymbolNode)(args[1]) || (0, _is.isFunctionAssignmentNode)(args[1])) {\n // a function pointer, like filter([3, -2, 5], myTestFunction)\n callback = args[1].compile().evaluate(scope);\n } else {\n // an expression like filter([3, -2, 5], x > 0)\n callback = (0, _compileInlineExpression.compileInlineExpression)(args[1], math, scope);\n }\n }\n\n return map(x, callback);\n }\n\n mapTransform.rawArgs = true; // one-based version of map function\n\n var map = typed('map', {\n 'Array, function': function ArrayFunction(x, callback) {\n return _map(x, callback, x);\n },\n 'Matrix, function': function MatrixFunction(x, callback) {\n return x.create(_map(x.valueOf(), callback, x));\n }\n });\n return mapTransform;\n}, {\n isTransformFunction: true\n});\n/**\n * Map for a multi dimensional array. One-based indexes\n * @param {Array} array\n * @param {function} callback\n * @param {Array} orig\n * @return {Array}\n * @private\n */\n\nexports.createMapTransform = createMapTransform;\n\nfunction _map(array, callback, orig) {\n // figure out what number of arguments the callback function expects\n var argsCount = (0, _function.maxArgumentCount)(callback);\n\n function recurse(value, index) {\n if (Array.isArray(value)) {\n return (0, _array.map)(value, function (child, i) {\n // we create a copy of the index array and append the new index value\n return recurse(child, index.concat(i + 1)); // one based index, hence i + 1\n });\n } else {\n // invoke the (typed) callback function with the right number of arguments\n if (argsCount === 1) {\n return callback(value);\n } else if (argsCount === 2) {\n return callback(value, index);\n } else {\n // 3 or -1\n return callback(value, index, orig);\n }\n }\n }\n\n return recurse(array, []);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMaxTransform = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _max = require(\"../../function/statistics/max.js\");\n\nvar _lastDimToZeroBase = require(\"./utils/lastDimToZeroBase.js\");\n\nvar name = 'max';\nvar dependencies = ['typed', 'config', 'numeric', 'larger'];\nvar createMaxTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n numeric = _ref.numeric,\n larger = _ref.larger;\n var max = (0, _max.createMax)({\n typed: typed,\n config: config,\n numeric: numeric,\n larger: larger\n });\n /**\n * Attach a transform function to math.max\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function max\n * from one-based to zero based\n */\n\n return typed('max', {\n '...any': function any(args) {\n args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args);\n\n try {\n return max.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createMaxTransform = createMaxTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMeanTransform = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _mean = require(\"../../function/statistics/mean.js\");\n\nvar _lastDimToZeroBase = require(\"./utils/lastDimToZeroBase.js\");\n\nvar name = 'mean';\nvar dependencies = ['typed', 'add', 'divide'];\nvar createMeanTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n add = _ref.add,\n divide = _ref.divide;\n var mean = (0, _mean.createMean)({\n typed: typed,\n add: add,\n divide: divide\n });\n /**\n * Attach a transform function to math.mean\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function mean\n * from one-based to zero based\n */\n\n return typed('mean', {\n '...any': function any(args) {\n args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args);\n\n try {\n return mean.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createMeanTransform = createMeanTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMinTransform = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _min = require(\"../../function/statistics/min.js\");\n\nvar _lastDimToZeroBase = require(\"./utils/lastDimToZeroBase.js\");\n\nvar name = 'min';\nvar dependencies = ['typed', 'config', 'numeric', 'smaller'];\nvar createMinTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n numeric = _ref.numeric,\n smaller = _ref.smaller;\n var min = (0, _min.createMin)({\n typed: typed,\n config: config,\n numeric: numeric,\n smaller: smaller\n });\n /**\n * Attach a transform function to math.min\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function min\n * from one-based to zero based\n */\n\n return typed('min', {\n '...any': function any(args) {\n args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args);\n\n try {\n return min.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createMinTransform = createMinTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRangeTransform = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _range = require(\"../../function/matrix/range.js\");\n\nvar name = 'range';\nvar dependencies = ['typed', 'config', '?matrix', '?bignumber', 'smaller', 'smallerEq', 'larger', 'largerEq'];\nvar createRangeTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n matrix = _ref.matrix,\n bignumber = _ref.bignumber,\n smaller = _ref.smaller,\n smallerEq = _ref.smallerEq,\n larger = _ref.larger,\n largerEq = _ref.largerEq;\n var range = (0, _range.createRange)({\n typed: typed,\n config: config,\n matrix: matrix,\n bignumber: bignumber,\n smaller: smaller,\n smallerEq: smallerEq,\n larger: larger,\n largerEq: largerEq\n });\n /**\n * Attach a transform function to math.range\n * Adds a property transform containing the transform function.\n *\n * This transform creates a range which includes the end value\n */\n\n return typed('range', {\n '...any': function any(args) {\n var lastIndex = args.length - 1;\n var last = args[lastIndex];\n\n if (typeof last !== 'boolean') {\n // append a parameter includeEnd=true\n args.push(true);\n }\n\n return range.apply(null, args);\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createRangeTransform = createRangeTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRowTransform = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _row = require(\"../../function/matrix/row.js\");\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar name = 'row';\nvar dependencies = ['typed', 'Index', 'matrix', 'range'];\n/**\n * Attach a transform function to matrix.column\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `index` parameter of function column\n * from zero-based to one-based\n */\n\nvar createRowTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Index = _ref.Index,\n matrix = _ref.matrix,\n range = _ref.range;\n var row = (0, _row.createRow)({\n typed: typed,\n Index: Index,\n matrix: matrix,\n range: range\n }); // @see: comment of row itself\n\n return typed('row', {\n '...any': function any(args) {\n // change last argument from zero-based to one-based\n var lastIndex = args.length - 1;\n var last = args[lastIndex];\n\n if ((0, _is.isNumber)(last)) {\n args[lastIndex] = last - 1;\n }\n\n try {\n return row.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createRowTransform = createRowTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createStdTransform = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _std = require(\"../../function/statistics/std.js\");\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _lastDimToZeroBase = require(\"./utils/lastDimToZeroBase.js\");\n\nvar name = 'std';\nvar dependencies = ['typed', 'sqrt', 'variance'];\n/**\n * Attach a transform function to math.std\n * Adds a property transform containing the transform function.\n *\n * This transform changed the `dim` parameter of function std\n * from one-based to zero based\n */\n\nvar createStdTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n sqrt = _ref.sqrt,\n variance = _ref.variance;\n var std = (0, _std.createStd)({\n typed: typed,\n sqrt: sqrt,\n variance: variance\n });\n return typed('std', {\n '...any': function any(args) {\n args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args);\n\n try {\n return std.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createStdTransform = createStdTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSubsetTransform = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _subset = require(\"../../function/matrix/subset.js\");\n\nvar name = 'subset';\nvar dependencies = ['typed', 'matrix'];\nvar createSubsetTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix;\n var subset = (0, _subset.createSubset)({\n typed: typed,\n matrix: matrix\n });\n /**\n * Attach a transform function to math.subset\n * Adds a property transform containing the transform function.\n *\n * This transform creates a range which includes the end value\n */\n\n return typed('subset', {\n '...any': function any(args) {\n try {\n return subset.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createSubsetTransform = createSubsetTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSumTransform = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _sum = require(\"../../function/statistics/sum.js\");\n\nvar _lastDimToZeroBase = require(\"./utils/lastDimToZeroBase.js\");\n\n/**\n * Attach a transform function to math.sum\n * Adds a property transform containing the transform function.\n *\n * This transform changed the last `dim` parameter of function sum\n * from one-based to zero based\n */\nvar name = 'sum';\nvar dependencies = ['typed', 'config', 'add', 'numeric'];\nvar createSumTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n add = _ref.add,\n numeric = _ref.numeric;\n var sum = (0, _sum.createSum)({\n typed: typed,\n config: config,\n add: add,\n numeric: numeric\n });\n return typed(name, {\n '...any': function any(args) {\n args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args);\n\n try {\n return sum.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createSumTransform = createSumTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.compileInlineExpression = compileInlineExpression;\n\nvar _is = require(\"../../../utils/is.js\");\n\nvar _scope = require(\"../../../utils/scope.js\");\n\n/**\n * Compile an inline expression like \"x > 0\"\n * @param {Node} expression\n * @param {Object} math\n * @param {Object} scope\n * @return {function} Returns a function with one argument which fills in the\n * undefined variable (like \"x\") and evaluates the expression\n */\nfunction compileInlineExpression(expression, math, scope) {\n // find an undefined symbol\n var symbol = expression.filter(function (node) {\n return (0, _is.isSymbolNode)(node) && !(node.name in math) && !scope.has(node.name);\n })[0];\n\n if (!symbol) {\n throw new Error('No undefined variable found in inline expression \"' + expression + '\"');\n } // create a test function for this equation\n\n\n var name = symbol.name; // variable name\n\n var subScope = (0, _scope.createSubScope)(scope);\n var eq = expression.compile();\n return function inlineExpression(x) {\n subScope.set(name, x);\n return eq.evaluate(subScope);\n };\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.errorTransform = errorTransform;\n\nvar _IndexError = require(\"../../../error/IndexError.js\");\n\n/**\n * Transform zero-based indices to one-based indices in errors\n * @param {Error} err\n * @returns {Error | IndexError} Returns the transformed error\n */\nfunction errorTransform(err) {\n if (err && err.isIndexError) {\n return new _IndexError.IndexError(err.index + 1, err.min + 1, err.max !== undefined ? err.max + 1 : undefined);\n }\n\n return err;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lastDimToZeroBase = lastDimToZeroBase;\n\nvar _is = require(\"../../../utils/is.js\");\n\n/**\n * Change last argument dim from one-based to zero-based.\n */\nfunction lastDimToZeroBase(args) {\n if (args.length === 2 && (0, _is.isCollection)(args[0])) {\n args = args.slice();\n var dim = args[1];\n\n if ((0, _is.isNumber)(dim)) {\n args[1] = dim - 1;\n } else if ((0, _is.isBigNumber)(dim)) {\n args[1] = dim.minus(1);\n }\n }\n\n return args;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createVarianceTransform = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _errorTransform = require(\"./utils/errorTransform.js\");\n\nvar _variance = require(\"../../function/statistics/variance.js\");\n\nvar _lastDimToZeroBase = require(\"./utils/lastDimToZeroBase.js\");\n\nvar name = 'variance';\nvar dependencies = ['typed', 'add', 'subtract', 'multiply', 'divide', 'apply', 'isNaN'];\n/**\n * Attach a transform function to math.var\n * Adds a property transform containing the transform function.\n *\n * This transform changed the `dim` parameter of function var\n * from one-based to zero based\n */\n\nvar createVarianceTransform = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n add = _ref.add,\n subtract = _ref.subtract,\n multiply = _ref.multiply,\n divide = _ref.divide,\n apply = _ref.apply,\n isNaN = _ref.isNaN;\n var variance = (0, _variance.createVariance)({\n typed: typed,\n add: add,\n subtract: subtract,\n multiply: multiply,\n divide: divide,\n apply: apply,\n isNaN: isNaN\n });\n return typed(name, {\n '...any': function any(args) {\n args = (0, _lastDimToZeroBase.lastDimToZeroBase)(args);\n\n try {\n return variance.apply(null, args);\n } catch (err) {\n throw (0, _errorTransform.errorTransform)(err);\n }\n }\n });\n}, {\n isTransformFunction: true\n});\nexports.createVarianceTransform = createVarianceTransform;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"createAbs\", {\n enumerable: true,\n get: function get() {\n return _abs.createAbs;\n }\n});\nObject.defineProperty(exports, \"createAccessorNode\", {\n enumerable: true,\n get: function get() {\n return _AccessorNode.createAccessorNode;\n }\n});\nObject.defineProperty(exports, \"createAcos\", {\n enumerable: true,\n get: function get() {\n return _acos.createAcos;\n }\n});\nObject.defineProperty(exports, \"createAcosh\", {\n enumerable: true,\n get: function get() {\n return _acosh.createAcosh;\n }\n});\nObject.defineProperty(exports, \"createAcot\", {\n enumerable: true,\n get: function get() {\n return _acot.createAcot;\n }\n});\nObject.defineProperty(exports, \"createAcoth\", {\n enumerable: true,\n get: function get() {\n return _acoth.createAcoth;\n }\n});\nObject.defineProperty(exports, \"createAcsc\", {\n enumerable: true,\n get: function get() {\n return _acsc.createAcsc;\n }\n});\nObject.defineProperty(exports, \"createAcsch\", {\n enumerable: true,\n get: function get() {\n return _acsch.createAcsch;\n }\n});\nObject.defineProperty(exports, \"createAdd\", {\n enumerable: true,\n get: function get() {\n return _add.createAdd;\n }\n});\nObject.defineProperty(exports, \"createAddScalar\", {\n enumerable: true,\n get: function get() {\n return _addScalar.createAddScalar;\n }\n});\nObject.defineProperty(exports, \"createAnd\", {\n enumerable: true,\n get: function get() {\n return _and.createAnd;\n }\n});\nObject.defineProperty(exports, \"createApply\", {\n enumerable: true,\n get: function get() {\n return _apply.createApply;\n }\n});\nObject.defineProperty(exports, \"createApplyTransform\", {\n enumerable: true,\n get: function get() {\n return _applyTransform.createApplyTransform;\n }\n});\nObject.defineProperty(exports, \"createArg\", {\n enumerable: true,\n get: function get() {\n return _arg.createArg;\n }\n});\nObject.defineProperty(exports, \"createArrayNode\", {\n enumerable: true,\n get: function get() {\n return _ArrayNode.createArrayNode;\n }\n});\nObject.defineProperty(exports, \"createAsec\", {\n enumerable: true,\n get: function get() {\n return _asec.createAsec;\n }\n});\nObject.defineProperty(exports, \"createAsech\", {\n enumerable: true,\n get: function get() {\n return _asech.createAsech;\n }\n});\nObject.defineProperty(exports, \"createAsin\", {\n enumerable: true,\n get: function get() {\n return _asin.createAsin;\n }\n});\nObject.defineProperty(exports, \"createAsinh\", {\n enumerable: true,\n get: function get() {\n return _asinh.createAsinh;\n }\n});\nObject.defineProperty(exports, \"createAssignmentNode\", {\n enumerable: true,\n get: function get() {\n return _AssignmentNode.createAssignmentNode;\n }\n});\nObject.defineProperty(exports, \"createAtan\", {\n enumerable: true,\n get: function get() {\n return _atan.createAtan;\n }\n});\nObject.defineProperty(exports, \"createAtan2\", {\n enumerable: true,\n get: function get() {\n return _atan2.createAtan2;\n }\n});\nObject.defineProperty(exports, \"createAtanh\", {\n enumerable: true,\n get: function get() {\n return _atanh.createAtanh;\n }\n});\nObject.defineProperty(exports, \"createAtomicMass\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createAtomicMass;\n }\n});\nObject.defineProperty(exports, \"createAvogadro\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createAvogadro;\n }\n});\nObject.defineProperty(exports, \"createBellNumbers\", {\n enumerable: true,\n get: function get() {\n return _bellNumbers.createBellNumbers;\n }\n});\nObject.defineProperty(exports, \"createBigNumberClass\", {\n enumerable: true,\n get: function get() {\n return _BigNumber.createBigNumberClass;\n }\n});\nObject.defineProperty(exports, \"createBignumber\", {\n enumerable: true,\n get: function get() {\n return _bignumber.createBignumber;\n }\n});\nObject.defineProperty(exports, \"createBin\", {\n enumerable: true,\n get: function get() {\n return _bin.createBin;\n }\n});\nObject.defineProperty(exports, \"createBitAnd\", {\n enumerable: true,\n get: function get() {\n return _bitAnd.createBitAnd;\n }\n});\nObject.defineProperty(exports, \"createBitNot\", {\n enumerable: true,\n get: function get() {\n return _bitNot.createBitNot;\n }\n});\nObject.defineProperty(exports, \"createBitOr\", {\n enumerable: true,\n get: function get() {\n return _bitOr.createBitOr;\n }\n});\nObject.defineProperty(exports, \"createBitXor\", {\n enumerable: true,\n get: function get() {\n return _bitXor.createBitXor;\n }\n});\nObject.defineProperty(exports, \"createBlockNode\", {\n enumerable: true,\n get: function get() {\n return _BlockNode.createBlockNode;\n }\n});\nObject.defineProperty(exports, \"createBohrMagneton\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createBohrMagneton;\n }\n});\nObject.defineProperty(exports, \"createBohrRadius\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createBohrRadius;\n }\n});\nObject.defineProperty(exports, \"createBoltzmann\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createBoltzmann;\n }\n});\nObject.defineProperty(exports, \"createBoolean\", {\n enumerable: true,\n get: function get() {\n return _boolean.createBoolean;\n }\n});\nObject.defineProperty(exports, \"createCatalan\", {\n enumerable: true,\n get: function get() {\n return _catalan.createCatalan;\n }\n});\nObject.defineProperty(exports, \"createCbrt\", {\n enumerable: true,\n get: function get() {\n return _cbrt.createCbrt;\n }\n});\nObject.defineProperty(exports, \"createCeil\", {\n enumerable: true,\n get: function get() {\n return _ceil.createCeil;\n }\n});\nObject.defineProperty(exports, \"createChain\", {\n enumerable: true,\n get: function get() {\n return _chain.createChain;\n }\n});\nObject.defineProperty(exports, \"createChainClass\", {\n enumerable: true,\n get: function get() {\n return _Chain.createChainClass;\n }\n});\nObject.defineProperty(exports, \"createClassicalElectronRadius\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createClassicalElectronRadius;\n }\n});\nObject.defineProperty(exports, \"createClone\", {\n enumerable: true,\n get: function get() {\n return _clone.createClone;\n }\n});\nObject.defineProperty(exports, \"createColumn\", {\n enumerable: true,\n get: function get() {\n return _column.createColumn;\n }\n});\nObject.defineProperty(exports, \"createColumnTransform\", {\n enumerable: true,\n get: function get() {\n return _columnTransform.createColumnTransform;\n }\n});\nObject.defineProperty(exports, \"createCombinations\", {\n enumerable: true,\n get: function get() {\n return _combinations.createCombinations;\n }\n});\nObject.defineProperty(exports, \"createCombinationsWithRep\", {\n enumerable: true,\n get: function get() {\n return _combinationsWithRep.createCombinationsWithRep;\n }\n});\nObject.defineProperty(exports, \"createCompare\", {\n enumerable: true,\n get: function get() {\n return _compare.createCompare;\n }\n});\nObject.defineProperty(exports, \"createCompareNatural\", {\n enumerable: true,\n get: function get() {\n return _compareNatural.createCompareNatural;\n }\n});\nObject.defineProperty(exports, \"createCompareText\", {\n enumerable: true,\n get: function get() {\n return _compareText.createCompareText;\n }\n});\nObject.defineProperty(exports, \"createCompile\", {\n enumerable: true,\n get: function get() {\n return _compile.createCompile;\n }\n});\nObject.defineProperty(exports, \"createComplex\", {\n enumerable: true,\n get: function get() {\n return _complex.createComplex;\n }\n});\nObject.defineProperty(exports, \"createComplexClass\", {\n enumerable: true,\n get: function get() {\n return _Complex.createComplexClass;\n }\n});\nObject.defineProperty(exports, \"createComposition\", {\n enumerable: true,\n get: function get() {\n return _composition.createComposition;\n }\n});\nObject.defineProperty(exports, \"createConcat\", {\n enumerable: true,\n get: function get() {\n return _concat.createConcat;\n }\n});\nObject.defineProperty(exports, \"createConcatTransform\", {\n enumerable: true,\n get: function get() {\n return _concatTransform.createConcatTransform;\n }\n});\nObject.defineProperty(exports, \"createConditionalNode\", {\n enumerable: true,\n get: function get() {\n return _ConditionalNode.createConditionalNode;\n }\n});\nObject.defineProperty(exports, \"createConductanceQuantum\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createConductanceQuantum;\n }\n});\nObject.defineProperty(exports, \"createConj\", {\n enumerable: true,\n get: function get() {\n return _conj.createConj;\n }\n});\nObject.defineProperty(exports, \"createConstantNode\", {\n enumerable: true,\n get: function get() {\n return _ConstantNode.createConstantNode;\n }\n});\nObject.defineProperty(exports, \"createCos\", {\n enumerable: true,\n get: function get() {\n return _cos.createCos;\n }\n});\nObject.defineProperty(exports, \"createCosh\", {\n enumerable: true,\n get: function get() {\n return _cosh.createCosh;\n }\n});\nObject.defineProperty(exports, \"createCot\", {\n enumerable: true,\n get: function get() {\n return _cot.createCot;\n }\n});\nObject.defineProperty(exports, \"createCoth\", {\n enumerable: true,\n get: function get() {\n return _coth.createCoth;\n }\n});\nObject.defineProperty(exports, \"createCoulomb\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createCoulomb;\n }\n});\nObject.defineProperty(exports, \"createCount\", {\n enumerable: true,\n get: function get() {\n return _count.createCount;\n }\n});\nObject.defineProperty(exports, \"createCreateUnit\", {\n enumerable: true,\n get: function get() {\n return _createUnit.createCreateUnit;\n }\n});\nObject.defineProperty(exports, \"createCross\", {\n enumerable: true,\n get: function get() {\n return _cross.createCross;\n }\n});\nObject.defineProperty(exports, \"createCsc\", {\n enumerable: true,\n get: function get() {\n return _csc.createCsc;\n }\n});\nObject.defineProperty(exports, \"createCsch\", {\n enumerable: true,\n get: function get() {\n return _csch.createCsch;\n }\n});\nObject.defineProperty(exports, \"createCtranspose\", {\n enumerable: true,\n get: function get() {\n return _ctranspose.createCtranspose;\n }\n});\nObject.defineProperty(exports, \"createCube\", {\n enumerable: true,\n get: function get() {\n return _cube.createCube;\n }\n});\nObject.defineProperty(exports, \"createCumSum\", {\n enumerable: true,\n get: function get() {\n return _cumsum.createCumSum;\n }\n});\nObject.defineProperty(exports, \"createCumSumTransform\", {\n enumerable: true,\n get: function get() {\n return _cumsumTransform.createCumSumTransform;\n }\n});\nObject.defineProperty(exports, \"createDeepEqual\", {\n enumerable: true,\n get: function get() {\n return _deepEqual.createDeepEqual;\n }\n});\nObject.defineProperty(exports, \"createDenseMatrixClass\", {\n enumerable: true,\n get: function get() {\n return _DenseMatrix.createDenseMatrixClass;\n }\n});\nObject.defineProperty(exports, \"createDerivative\", {\n enumerable: true,\n get: function get() {\n return _derivative.createDerivative;\n }\n});\nObject.defineProperty(exports, \"createDet\", {\n enumerable: true,\n get: function get() {\n return _det.createDet;\n }\n});\nObject.defineProperty(exports, \"createDeuteronMass\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createDeuteronMass;\n }\n});\nObject.defineProperty(exports, \"createDiag\", {\n enumerable: true,\n get: function get() {\n return _diag.createDiag;\n }\n});\nObject.defineProperty(exports, \"createDiff\", {\n enumerable: true,\n get: function get() {\n return _diff.createDiff;\n }\n});\nObject.defineProperty(exports, \"createDiffTransform\", {\n enumerable: true,\n get: function get() {\n return _diffTransform.createDiffTransform;\n }\n});\nObject.defineProperty(exports, \"createDistance\", {\n enumerable: true,\n get: function get() {\n return _distance.createDistance;\n }\n});\nObject.defineProperty(exports, \"createDivide\", {\n enumerable: true,\n get: function get() {\n return _divide.createDivide;\n }\n});\nObject.defineProperty(exports, \"createDivideScalar\", {\n enumerable: true,\n get: function get() {\n return _divideScalar.createDivideScalar;\n }\n});\nObject.defineProperty(exports, \"createDot\", {\n enumerable: true,\n get: function get() {\n return _dot.createDot;\n }\n});\nObject.defineProperty(exports, \"createDotDivide\", {\n enumerable: true,\n get: function get() {\n return _dotDivide.createDotDivide;\n }\n});\nObject.defineProperty(exports, \"createDotMultiply\", {\n enumerable: true,\n get: function get() {\n return _dotMultiply.createDotMultiply;\n }\n});\nObject.defineProperty(exports, \"createDotPow\", {\n enumerable: true,\n get: function get() {\n return _dotPow.createDotPow;\n }\n});\nObject.defineProperty(exports, \"createE\", {\n enumerable: true,\n get: function get() {\n return _constants.createE;\n }\n});\nObject.defineProperty(exports, \"createEfimovFactor\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createEfimovFactor;\n }\n});\nObject.defineProperty(exports, \"createEigs\", {\n enumerable: true,\n get: function get() {\n return _eigs.createEigs;\n }\n});\nObject.defineProperty(exports, \"createElectricConstant\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createElectricConstant;\n }\n});\nObject.defineProperty(exports, \"createElectronMass\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createElectronMass;\n }\n});\nObject.defineProperty(exports, \"createElementaryCharge\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createElementaryCharge;\n }\n});\nObject.defineProperty(exports, \"createEqual\", {\n enumerable: true,\n get: function get() {\n return _equal.createEqual;\n }\n});\nObject.defineProperty(exports, \"createEqualScalar\", {\n enumerable: true,\n get: function get() {\n return _equalScalar.createEqualScalar;\n }\n});\nObject.defineProperty(exports, \"createEqualText\", {\n enumerable: true,\n get: function get() {\n return _equalText.createEqualText;\n }\n});\nObject.defineProperty(exports, \"createErf\", {\n enumerable: true,\n get: function get() {\n return _erf.createErf;\n }\n});\nObject.defineProperty(exports, \"createEvaluate\", {\n enumerable: true,\n get: function get() {\n return _evaluate.createEvaluate;\n }\n});\nObject.defineProperty(exports, \"createExp\", {\n enumerable: true,\n get: function get() {\n return _exp.createExp;\n }\n});\nObject.defineProperty(exports, \"createExpm\", {\n enumerable: true,\n get: function get() {\n return _expm2.createExpm;\n }\n});\nObject.defineProperty(exports, \"createExpm1\", {\n enumerable: true,\n get: function get() {\n return _expm.createExpm1;\n }\n});\nObject.defineProperty(exports, \"createFactorial\", {\n enumerable: true,\n get: function get() {\n return _factorial.createFactorial;\n }\n});\nObject.defineProperty(exports, \"createFalse\", {\n enumerable: true,\n get: function get() {\n return _constants.createFalse;\n }\n});\nObject.defineProperty(exports, \"createFaraday\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createFaraday;\n }\n});\nObject.defineProperty(exports, \"createFermiCoupling\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createFermiCoupling;\n }\n});\nObject.defineProperty(exports, \"createFft\", {\n enumerable: true,\n get: function get() {\n return _fft.createFft;\n }\n});\nObject.defineProperty(exports, \"createFibonacciHeapClass\", {\n enumerable: true,\n get: function get() {\n return _FibonacciHeap.createFibonacciHeapClass;\n }\n});\nObject.defineProperty(exports, \"createFilter\", {\n enumerable: true,\n get: function get() {\n return _filter.createFilter;\n }\n});\nObject.defineProperty(exports, \"createFilterTransform\", {\n enumerable: true,\n get: function get() {\n return _filterTransform.createFilterTransform;\n }\n});\nObject.defineProperty(exports, \"createFineStructure\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createFineStructure;\n }\n});\nObject.defineProperty(exports, \"createFirstRadiation\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createFirstRadiation;\n }\n});\nObject.defineProperty(exports, \"createFix\", {\n enumerable: true,\n get: function get() {\n return _fix.createFix;\n }\n});\nObject.defineProperty(exports, \"createFlatten\", {\n enumerable: true,\n get: function get() {\n return _flatten.createFlatten;\n }\n});\nObject.defineProperty(exports, \"createFloor\", {\n enumerable: true,\n get: function get() {\n return _floor.createFloor;\n }\n});\nObject.defineProperty(exports, \"createForEach\", {\n enumerable: true,\n get: function get() {\n return _forEach.createForEach;\n }\n});\nObject.defineProperty(exports, \"createForEachTransform\", {\n enumerable: true,\n get: function get() {\n return _forEachTransform.createForEachTransform;\n }\n});\nObject.defineProperty(exports, \"createFormat\", {\n enumerable: true,\n get: function get() {\n return _format.createFormat;\n }\n});\nObject.defineProperty(exports, \"createFraction\", {\n enumerable: true,\n get: function get() {\n return _fraction.createFraction;\n }\n});\nObject.defineProperty(exports, \"createFractionClass\", {\n enumerable: true,\n get: function get() {\n return _Fraction.createFractionClass;\n }\n});\nObject.defineProperty(exports, \"createFunctionAssignmentNode\", {\n enumerable: true,\n get: function get() {\n return _FunctionAssignmentNode.createFunctionAssignmentNode;\n }\n});\nObject.defineProperty(exports, \"createFunctionNode\", {\n enumerable: true,\n get: function get() {\n return _FunctionNode.createFunctionNode;\n }\n});\nObject.defineProperty(exports, \"createGamma\", {\n enumerable: true,\n get: function get() {\n return _gamma.createGamma;\n }\n});\nObject.defineProperty(exports, \"createGasConstant\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createGasConstant;\n }\n});\nObject.defineProperty(exports, \"createGcd\", {\n enumerable: true,\n get: function get() {\n return _gcd.createGcd;\n }\n});\nObject.defineProperty(exports, \"createGetMatrixDataType\", {\n enumerable: true,\n get: function get() {\n return _getMatrixDataType.createGetMatrixDataType;\n }\n});\nObject.defineProperty(exports, \"createGravitationConstant\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createGravitationConstant;\n }\n});\nObject.defineProperty(exports, \"createGravity\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createGravity;\n }\n});\nObject.defineProperty(exports, \"createHartreeEnergy\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createHartreeEnergy;\n }\n});\nObject.defineProperty(exports, \"createHasNumericValue\", {\n enumerable: true,\n get: function get() {\n return _hasNumericValue.createHasNumericValue;\n }\n});\nObject.defineProperty(exports, \"createHelp\", {\n enumerable: true,\n get: function get() {\n return _help.createHelp;\n }\n});\nObject.defineProperty(exports, \"createHelpClass\", {\n enumerable: true,\n get: function get() {\n return _Help.createHelpClass;\n }\n});\nObject.defineProperty(exports, \"createHex\", {\n enumerable: true,\n get: function get() {\n return _hex.createHex;\n }\n});\nObject.defineProperty(exports, \"createHypot\", {\n enumerable: true,\n get: function get() {\n return _hypot.createHypot;\n }\n});\nObject.defineProperty(exports, \"createI\", {\n enumerable: true,\n get: function get() {\n return _constants.createI;\n }\n});\nObject.defineProperty(exports, \"createIdentity\", {\n enumerable: true,\n get: function get() {\n return _identity.createIdentity;\n }\n});\nObject.defineProperty(exports, \"createIfft\", {\n enumerable: true,\n get: function get() {\n return _ifft.createIfft;\n }\n});\nObject.defineProperty(exports, \"createIm\", {\n enumerable: true,\n get: function get() {\n return _im.createIm;\n }\n});\nObject.defineProperty(exports, \"createImmutableDenseMatrixClass\", {\n enumerable: true,\n get: function get() {\n return _ImmutableDenseMatrix.createImmutableDenseMatrixClass;\n }\n});\nObject.defineProperty(exports, \"createIndex\", {\n enumerable: true,\n get: function get() {\n return _index.createIndex;\n }\n});\nObject.defineProperty(exports, \"createIndexClass\", {\n enumerable: true,\n get: function get() {\n return _MatrixIndex.createIndexClass;\n }\n});\nObject.defineProperty(exports, \"createIndexNode\", {\n enumerable: true,\n get: function get() {\n return _IndexNode.createIndexNode;\n }\n});\nObject.defineProperty(exports, \"createIndexTransform\", {\n enumerable: true,\n get: function get() {\n return _indexTransform.createIndexTransform;\n }\n});\nObject.defineProperty(exports, \"createInfinity\", {\n enumerable: true,\n get: function get() {\n return _constants.createInfinity;\n }\n});\nObject.defineProperty(exports, \"createIntersect\", {\n enumerable: true,\n get: function get() {\n return _intersect.createIntersect;\n }\n});\nObject.defineProperty(exports, \"createInv\", {\n enumerable: true,\n get: function get() {\n return _inv.createInv;\n }\n});\nObject.defineProperty(exports, \"createInverseConductanceQuantum\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createInverseConductanceQuantum;\n }\n});\nObject.defineProperty(exports, \"createInvmod\", {\n enumerable: true,\n get: function get() {\n return _invmod.createInvmod;\n }\n});\nObject.defineProperty(exports, \"createIsInteger\", {\n enumerable: true,\n get: function get() {\n return _isInteger.createIsInteger;\n }\n});\nObject.defineProperty(exports, \"createIsNaN\", {\n enumerable: true,\n get: function get() {\n return _isNaN.createIsNaN;\n }\n});\nObject.defineProperty(exports, \"createIsNegative\", {\n enumerable: true,\n get: function get() {\n return _isNegative.createIsNegative;\n }\n});\nObject.defineProperty(exports, \"createIsNumeric\", {\n enumerable: true,\n get: function get() {\n return _isNumeric.createIsNumeric;\n }\n});\nObject.defineProperty(exports, \"createIsPositive\", {\n enumerable: true,\n get: function get() {\n return _isPositive.createIsPositive;\n }\n});\nObject.defineProperty(exports, \"createIsPrime\", {\n enumerable: true,\n get: function get() {\n return _isPrime.createIsPrime;\n }\n});\nObject.defineProperty(exports, \"createIsZero\", {\n enumerable: true,\n get: function get() {\n return _isZero.createIsZero;\n }\n});\nObject.defineProperty(exports, \"createKldivergence\", {\n enumerable: true,\n get: function get() {\n return _kldivergence.createKldivergence;\n }\n});\nObject.defineProperty(exports, \"createKlitzing\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createKlitzing;\n }\n});\nObject.defineProperty(exports, \"createKron\", {\n enumerable: true,\n get: function get() {\n return _kron.createKron;\n }\n});\nObject.defineProperty(exports, \"createLN10\", {\n enumerable: true,\n get: function get() {\n return _constants.createLN10;\n }\n});\nObject.defineProperty(exports, \"createLN2\", {\n enumerable: true,\n get: function get() {\n return _constants.createLN2;\n }\n});\nObject.defineProperty(exports, \"createLOG10E\", {\n enumerable: true,\n get: function get() {\n return _constants.createLOG10E;\n }\n});\nObject.defineProperty(exports, \"createLOG2E\", {\n enumerable: true,\n get: function get() {\n return _constants.createLOG2E;\n }\n});\nObject.defineProperty(exports, \"createLarger\", {\n enumerable: true,\n get: function get() {\n return _larger.createLarger;\n }\n});\nObject.defineProperty(exports, \"createLargerEq\", {\n enumerable: true,\n get: function get() {\n return _largerEq.createLargerEq;\n }\n});\nObject.defineProperty(exports, \"createLcm\", {\n enumerable: true,\n get: function get() {\n return _lcm.createLcm;\n }\n});\nObject.defineProperty(exports, \"createLeafCount\", {\n enumerable: true,\n get: function get() {\n return _leafCount.createLeafCount;\n }\n});\nObject.defineProperty(exports, \"createLeftShift\", {\n enumerable: true,\n get: function get() {\n return _leftShift.createLeftShift;\n }\n});\nObject.defineProperty(exports, \"createLgamma\", {\n enumerable: true,\n get: function get() {\n return _lgamma.createLgamma;\n }\n});\nObject.defineProperty(exports, \"createLog\", {\n enumerable: true,\n get: function get() {\n return _log3.createLog;\n }\n});\nObject.defineProperty(exports, \"createLog10\", {\n enumerable: true,\n get: function get() {\n return _log.createLog10;\n }\n});\nObject.defineProperty(exports, \"createLog1p\", {\n enumerable: true,\n get: function get() {\n return _log1p.createLog1p;\n }\n});\nObject.defineProperty(exports, \"createLog2\", {\n enumerable: true,\n get: function get() {\n return _log2.createLog2;\n }\n});\nObject.defineProperty(exports, \"createLoschmidt\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createLoschmidt;\n }\n});\nObject.defineProperty(exports, \"createLsolve\", {\n enumerable: true,\n get: function get() {\n return _lsolve.createLsolve;\n }\n});\nObject.defineProperty(exports, \"createLsolveAll\", {\n enumerable: true,\n get: function get() {\n return _lsolveAll.createLsolveAll;\n }\n});\nObject.defineProperty(exports, \"createLup\", {\n enumerable: true,\n get: function get() {\n return _lup.createLup;\n }\n});\nObject.defineProperty(exports, \"createLusolve\", {\n enumerable: true,\n get: function get() {\n return _lusolve.createLusolve;\n }\n});\nObject.defineProperty(exports, \"createMad\", {\n enumerable: true,\n get: function get() {\n return _mad.createMad;\n }\n});\nObject.defineProperty(exports, \"createMagneticConstant\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createMagneticConstant;\n }\n});\nObject.defineProperty(exports, \"createMagneticFluxQuantum\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createMagneticFluxQuantum;\n }\n});\nObject.defineProperty(exports, \"createMap\", {\n enumerable: true,\n get: function get() {\n return _map.createMap;\n }\n});\nObject.defineProperty(exports, \"createMapTransform\", {\n enumerable: true,\n get: function get() {\n return _mapTransform.createMapTransform;\n }\n});\nObject.defineProperty(exports, \"createMatrix\", {\n enumerable: true,\n get: function get() {\n return _matrix.createMatrix;\n }\n});\nObject.defineProperty(exports, \"createMatrixClass\", {\n enumerable: true,\n get: function get() {\n return _Matrix.createMatrixClass;\n }\n});\nObject.defineProperty(exports, \"createMatrixFromColumns\", {\n enumerable: true,\n get: function get() {\n return _matrixFromColumns.createMatrixFromColumns;\n }\n});\nObject.defineProperty(exports, \"createMatrixFromFunction\", {\n enumerable: true,\n get: function get() {\n return _matrixFromFunction.createMatrixFromFunction;\n }\n});\nObject.defineProperty(exports, \"createMatrixFromRows\", {\n enumerable: true,\n get: function get() {\n return _matrixFromRows.createMatrixFromRows;\n }\n});\nObject.defineProperty(exports, \"createMax\", {\n enumerable: true,\n get: function get() {\n return _max.createMax;\n }\n});\nObject.defineProperty(exports, \"createMaxTransform\", {\n enumerable: true,\n get: function get() {\n return _maxTransform.createMaxTransform;\n }\n});\nObject.defineProperty(exports, \"createMean\", {\n enumerable: true,\n get: function get() {\n return _mean.createMean;\n }\n});\nObject.defineProperty(exports, \"createMeanTransform\", {\n enumerable: true,\n get: function get() {\n return _meanTransform.createMeanTransform;\n }\n});\nObject.defineProperty(exports, \"createMedian\", {\n enumerable: true,\n get: function get() {\n return _median.createMedian;\n }\n});\nObject.defineProperty(exports, \"createMin\", {\n enumerable: true,\n get: function get() {\n return _min.createMin;\n }\n});\nObject.defineProperty(exports, \"createMinTransform\", {\n enumerable: true,\n get: function get() {\n return _minTransform.createMinTransform;\n }\n});\nObject.defineProperty(exports, \"createMod\", {\n enumerable: true,\n get: function get() {\n return _mod.createMod;\n }\n});\nObject.defineProperty(exports, \"createMode\", {\n enumerable: true,\n get: function get() {\n return _mode.createMode;\n }\n});\nObject.defineProperty(exports, \"createMolarMass\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createMolarMass;\n }\n});\nObject.defineProperty(exports, \"createMolarMassC12\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createMolarMassC12;\n }\n});\nObject.defineProperty(exports, \"createMolarPlanckConstant\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createMolarPlanckConstant;\n }\n});\nObject.defineProperty(exports, \"createMolarVolume\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createMolarVolume;\n }\n});\nObject.defineProperty(exports, \"createMultinomial\", {\n enumerable: true,\n get: function get() {\n return _multinomial.createMultinomial;\n }\n});\nObject.defineProperty(exports, \"createMultiply\", {\n enumerable: true,\n get: function get() {\n return _multiply.createMultiply;\n }\n});\nObject.defineProperty(exports, \"createMultiplyScalar\", {\n enumerable: true,\n get: function get() {\n return _multiplyScalar.createMultiplyScalar;\n }\n});\nObject.defineProperty(exports, \"createNaN\", {\n enumerable: true,\n get: function get() {\n return _constants.createNaN;\n }\n});\nObject.defineProperty(exports, \"createNeutronMass\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createNeutronMass;\n }\n});\nObject.defineProperty(exports, \"createNode\", {\n enumerable: true,\n get: function get() {\n return _Node.createNode;\n }\n});\nObject.defineProperty(exports, \"createNorm\", {\n enumerable: true,\n get: function get() {\n return _norm.createNorm;\n }\n});\nObject.defineProperty(exports, \"createNot\", {\n enumerable: true,\n get: function get() {\n return _not.createNot;\n }\n});\nObject.defineProperty(exports, \"createNthRoot\", {\n enumerable: true,\n get: function get() {\n return _nthRoot.createNthRoot;\n }\n});\nObject.defineProperty(exports, \"createNthRoots\", {\n enumerable: true,\n get: function get() {\n return _nthRoots.createNthRoots;\n }\n});\nObject.defineProperty(exports, \"createNuclearMagneton\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createNuclearMagneton;\n }\n});\nObject.defineProperty(exports, \"createNull\", {\n enumerable: true,\n get: function get() {\n return _constants.createNull;\n }\n});\nObject.defineProperty(exports, \"createNumber\", {\n enumerable: true,\n get: function get() {\n return _number.createNumber;\n }\n});\nObject.defineProperty(exports, \"createNumeric\", {\n enumerable: true,\n get: function get() {\n return _numeric.createNumeric;\n }\n});\nObject.defineProperty(exports, \"createObjectNode\", {\n enumerable: true,\n get: function get() {\n return _ObjectNode.createObjectNode;\n }\n});\nObject.defineProperty(exports, \"createOct\", {\n enumerable: true,\n get: function get() {\n return _oct.createOct;\n }\n});\nObject.defineProperty(exports, \"createOnes\", {\n enumerable: true,\n get: function get() {\n return _ones.createOnes;\n }\n});\nObject.defineProperty(exports, \"createOperatorNode\", {\n enumerable: true,\n get: function get() {\n return _OperatorNode.createOperatorNode;\n }\n});\nObject.defineProperty(exports, \"createOr\", {\n enumerable: true,\n get: function get() {\n return _or.createOr;\n }\n});\nObject.defineProperty(exports, \"createParenthesisNode\", {\n enumerable: true,\n get: function get() {\n return _ParenthesisNode.createParenthesisNode;\n }\n});\nObject.defineProperty(exports, \"createParse\", {\n enumerable: true,\n get: function get() {\n return _parse.createParse;\n }\n});\nObject.defineProperty(exports, \"createParser\", {\n enumerable: true,\n get: function get() {\n return _parser.createParser;\n }\n});\nObject.defineProperty(exports, \"createParserClass\", {\n enumerable: true,\n get: function get() {\n return _Parser.createParserClass;\n }\n});\nObject.defineProperty(exports, \"createPartitionSelect\", {\n enumerable: true,\n get: function get() {\n return _partitionSelect.createPartitionSelect;\n }\n});\nObject.defineProperty(exports, \"createPermutations\", {\n enumerable: true,\n get: function get() {\n return _permutations.createPermutations;\n }\n});\nObject.defineProperty(exports, \"createPhi\", {\n enumerable: true,\n get: function get() {\n return _constants.createPhi;\n }\n});\nObject.defineProperty(exports, \"createPi\", {\n enumerable: true,\n get: function get() {\n return _constants.createPi;\n }\n});\nObject.defineProperty(exports, \"createPickRandom\", {\n enumerable: true,\n get: function get() {\n return _pickRandom.createPickRandom;\n }\n});\nObject.defineProperty(exports, \"createPinv\", {\n enumerable: true,\n get: function get() {\n return _pinv.createPinv;\n }\n});\nObject.defineProperty(exports, \"createPlanckCharge\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createPlanckCharge;\n }\n});\nObject.defineProperty(exports, \"createPlanckConstant\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createPlanckConstant;\n }\n});\nObject.defineProperty(exports, \"createPlanckLength\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createPlanckLength;\n }\n});\nObject.defineProperty(exports, \"createPlanckMass\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createPlanckMass;\n }\n});\nObject.defineProperty(exports, \"createPlanckTemperature\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createPlanckTemperature;\n }\n});\nObject.defineProperty(exports, \"createPlanckTime\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createPlanckTime;\n }\n});\nObject.defineProperty(exports, \"createPow\", {\n enumerable: true,\n get: function get() {\n return _pow.createPow;\n }\n});\nObject.defineProperty(exports, \"createPrint\", {\n enumerable: true,\n get: function get() {\n return _print.createPrint;\n }\n});\nObject.defineProperty(exports, \"createProd\", {\n enumerable: true,\n get: function get() {\n return _prod.createProd;\n }\n});\nObject.defineProperty(exports, \"createProtonMass\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createProtonMass;\n }\n});\nObject.defineProperty(exports, \"createQr\", {\n enumerable: true,\n get: function get() {\n return _qr.createQr;\n }\n});\nObject.defineProperty(exports, \"createQuantileSeq\", {\n enumerable: true,\n get: function get() {\n return _quantileSeq.createQuantileSeq;\n }\n});\nObject.defineProperty(exports, \"createQuantumOfCirculation\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createQuantumOfCirculation;\n }\n});\nObject.defineProperty(exports, \"createRandom\", {\n enumerable: true,\n get: function get() {\n return _random.createRandom;\n }\n});\nObject.defineProperty(exports, \"createRandomInt\", {\n enumerable: true,\n get: function get() {\n return _randomInt.createRandomInt;\n }\n});\nObject.defineProperty(exports, \"createRange\", {\n enumerable: true,\n get: function get() {\n return _range.createRange;\n }\n});\nObject.defineProperty(exports, \"createRangeClass\", {\n enumerable: true,\n get: function get() {\n return _Range.createRangeClass;\n }\n});\nObject.defineProperty(exports, \"createRangeNode\", {\n enumerable: true,\n get: function get() {\n return _RangeNode.createRangeNode;\n }\n});\nObject.defineProperty(exports, \"createRangeTransform\", {\n enumerable: true,\n get: function get() {\n return _rangeTransform.createRangeTransform;\n }\n});\nObject.defineProperty(exports, \"createRationalize\", {\n enumerable: true,\n get: function get() {\n return _rationalize.createRationalize;\n }\n});\nObject.defineProperty(exports, \"createRe\", {\n enumerable: true,\n get: function get() {\n return _re.createRe;\n }\n});\nObject.defineProperty(exports, \"createReducedPlanckConstant\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createReducedPlanckConstant;\n }\n});\nObject.defineProperty(exports, \"createRelationalNode\", {\n enumerable: true,\n get: function get() {\n return _RelationalNode.createRelationalNode;\n }\n});\nObject.defineProperty(exports, \"createReplacer\", {\n enumerable: true,\n get: function get() {\n return _replacer.createReplacer;\n }\n});\nObject.defineProperty(exports, \"createReshape\", {\n enumerable: true,\n get: function get() {\n return _reshape.createReshape;\n }\n});\nObject.defineProperty(exports, \"createResize\", {\n enumerable: true,\n get: function get() {\n return _resize.createResize;\n }\n});\nObject.defineProperty(exports, \"createResolve\", {\n enumerable: true,\n get: function get() {\n return _resolve.createResolve;\n }\n});\nObject.defineProperty(exports, \"createResultSet\", {\n enumerable: true,\n get: function get() {\n return _ResultSet.createResultSet;\n }\n});\nObject.defineProperty(exports, \"createReviver\", {\n enumerable: true,\n get: function get() {\n return _reviver.createReviver;\n }\n});\nObject.defineProperty(exports, \"createRightArithShift\", {\n enumerable: true,\n get: function get() {\n return _rightArithShift.createRightArithShift;\n }\n});\nObject.defineProperty(exports, \"createRightLogShift\", {\n enumerable: true,\n get: function get() {\n return _rightLogShift.createRightLogShift;\n }\n});\nObject.defineProperty(exports, \"createRotate\", {\n enumerable: true,\n get: function get() {\n return _rotate.createRotate;\n }\n});\nObject.defineProperty(exports, \"createRotationMatrix\", {\n enumerable: true,\n get: function get() {\n return _rotationMatrix.createRotationMatrix;\n }\n});\nObject.defineProperty(exports, \"createRound\", {\n enumerable: true,\n get: function get() {\n return _round.createRound;\n }\n});\nObject.defineProperty(exports, \"createRow\", {\n enumerable: true,\n get: function get() {\n return _row.createRow;\n }\n});\nObject.defineProperty(exports, \"createRowTransform\", {\n enumerable: true,\n get: function get() {\n return _rowTransform.createRowTransform;\n }\n});\nObject.defineProperty(exports, \"createRydberg\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createRydberg;\n }\n});\nObject.defineProperty(exports, \"createSQRT1_2\", {\n enumerable: true,\n get: function get() {\n return _constants.createSQRT1_2;\n }\n});\nObject.defineProperty(exports, \"createSQRT2\", {\n enumerable: true,\n get: function get() {\n return _constants.createSQRT2;\n }\n});\nObject.defineProperty(exports, \"createSackurTetrode\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createSackurTetrode;\n }\n});\nObject.defineProperty(exports, \"createSec\", {\n enumerable: true,\n get: function get() {\n return _sec.createSec;\n }\n});\nObject.defineProperty(exports, \"createSech\", {\n enumerable: true,\n get: function get() {\n return _sech.createSech;\n }\n});\nObject.defineProperty(exports, \"createSecondRadiation\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createSecondRadiation;\n }\n});\nObject.defineProperty(exports, \"createSetCartesian\", {\n enumerable: true,\n get: function get() {\n return _setCartesian.createSetCartesian;\n }\n});\nObject.defineProperty(exports, \"createSetDifference\", {\n enumerable: true,\n get: function get() {\n return _setDifference.createSetDifference;\n }\n});\nObject.defineProperty(exports, \"createSetDistinct\", {\n enumerable: true,\n get: function get() {\n return _setDistinct.createSetDistinct;\n }\n});\nObject.defineProperty(exports, \"createSetIntersect\", {\n enumerable: true,\n get: function get() {\n return _setIntersect.createSetIntersect;\n }\n});\nObject.defineProperty(exports, \"createSetIsSubset\", {\n enumerable: true,\n get: function get() {\n return _setIsSubset.createSetIsSubset;\n }\n});\nObject.defineProperty(exports, \"createSetMultiplicity\", {\n enumerable: true,\n get: function get() {\n return _setMultiplicity.createSetMultiplicity;\n }\n});\nObject.defineProperty(exports, \"createSetPowerset\", {\n enumerable: true,\n get: function get() {\n return _setPowerset.createSetPowerset;\n }\n});\nObject.defineProperty(exports, \"createSetSize\", {\n enumerable: true,\n get: function get() {\n return _setSize.createSetSize;\n }\n});\nObject.defineProperty(exports, \"createSetSymDifference\", {\n enumerable: true,\n get: function get() {\n return _setSymDifference.createSetSymDifference;\n }\n});\nObject.defineProperty(exports, \"createSetUnion\", {\n enumerable: true,\n get: function get() {\n return _setUnion.createSetUnion;\n }\n});\nObject.defineProperty(exports, \"createSign\", {\n enumerable: true,\n get: function get() {\n return _sign.createSign;\n }\n});\nObject.defineProperty(exports, \"createSimplify\", {\n enumerable: true,\n get: function get() {\n return _simplify.createSimplify;\n }\n});\nObject.defineProperty(exports, \"createSimplifyCore\", {\n enumerable: true,\n get: function get() {\n return _simplifyCore.createSimplifyCore;\n }\n});\nObject.defineProperty(exports, \"createSin\", {\n enumerable: true,\n get: function get() {\n return _sin.createSin;\n }\n});\nObject.defineProperty(exports, \"createSinh\", {\n enumerable: true,\n get: function get() {\n return _sinh.createSinh;\n }\n});\nObject.defineProperty(exports, \"createSize\", {\n enumerable: true,\n get: function get() {\n return _size.createSize;\n }\n});\nObject.defineProperty(exports, \"createSlu\", {\n enumerable: true,\n get: function get() {\n return _slu.createSlu;\n }\n});\nObject.defineProperty(exports, \"createSmaller\", {\n enumerable: true,\n get: function get() {\n return _smaller.createSmaller;\n }\n});\nObject.defineProperty(exports, \"createSmallerEq\", {\n enumerable: true,\n get: function get() {\n return _smallerEq.createSmallerEq;\n }\n});\nObject.defineProperty(exports, \"createSort\", {\n enumerable: true,\n get: function get() {\n return _sort.createSort;\n }\n});\nObject.defineProperty(exports, \"createSpaClass\", {\n enumerable: true,\n get: function get() {\n return _Spa.createSpaClass;\n }\n});\nObject.defineProperty(exports, \"createSparse\", {\n enumerable: true,\n get: function get() {\n return _sparse.createSparse;\n }\n});\nObject.defineProperty(exports, \"createSparseMatrixClass\", {\n enumerable: true,\n get: function get() {\n return _SparseMatrix.createSparseMatrixClass;\n }\n});\nObject.defineProperty(exports, \"createSpeedOfLight\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createSpeedOfLight;\n }\n});\nObject.defineProperty(exports, \"createSplitUnit\", {\n enumerable: true,\n get: function get() {\n return _splitUnit.createSplitUnit;\n }\n});\nObject.defineProperty(exports, \"createSqrt\", {\n enumerable: true,\n get: function get() {\n return _sqrt.createSqrt;\n }\n});\nObject.defineProperty(exports, \"createSqrtm\", {\n enumerable: true,\n get: function get() {\n return _sqrtm.createSqrtm;\n }\n});\nObject.defineProperty(exports, \"createSquare\", {\n enumerable: true,\n get: function get() {\n return _square.createSquare;\n }\n});\nObject.defineProperty(exports, \"createSqueeze\", {\n enumerable: true,\n get: function get() {\n return _squeeze.createSqueeze;\n }\n});\nObject.defineProperty(exports, \"createStd\", {\n enumerable: true,\n get: function get() {\n return _std.createStd;\n }\n});\nObject.defineProperty(exports, \"createStdTransform\", {\n enumerable: true,\n get: function get() {\n return _stdTransform.createStdTransform;\n }\n});\nObject.defineProperty(exports, \"createStefanBoltzmann\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createStefanBoltzmann;\n }\n});\nObject.defineProperty(exports, \"createStirlingS2\", {\n enumerable: true,\n get: function get() {\n return _stirlingS.createStirlingS2;\n }\n});\nObject.defineProperty(exports, \"createString\", {\n enumerable: true,\n get: function get() {\n return _string.createString;\n }\n});\nObject.defineProperty(exports, \"createSubset\", {\n enumerable: true,\n get: function get() {\n return _subset.createSubset;\n }\n});\nObject.defineProperty(exports, \"createSubsetTransform\", {\n enumerable: true,\n get: function get() {\n return _subsetTransform.createSubsetTransform;\n }\n});\nObject.defineProperty(exports, \"createSubtract\", {\n enumerable: true,\n get: function get() {\n return _subtract.createSubtract;\n }\n});\nObject.defineProperty(exports, \"createSum\", {\n enumerable: true,\n get: function get() {\n return _sum.createSum;\n }\n});\nObject.defineProperty(exports, \"createSumTransform\", {\n enumerable: true,\n get: function get() {\n return _sumTransform.createSumTransform;\n }\n});\nObject.defineProperty(exports, \"createSymbolNode\", {\n enumerable: true,\n get: function get() {\n return _SymbolNode.createSymbolNode;\n }\n});\nObject.defineProperty(exports, \"createSymbolicEqual\", {\n enumerable: true,\n get: function get() {\n return _symbolicEqual.createSymbolicEqual;\n }\n});\nObject.defineProperty(exports, \"createTan\", {\n enumerable: true,\n get: function get() {\n return _tan.createTan;\n }\n});\nObject.defineProperty(exports, \"createTanh\", {\n enumerable: true,\n get: function get() {\n return _tanh.createTanh;\n }\n});\nObject.defineProperty(exports, \"createTau\", {\n enumerable: true,\n get: function get() {\n return _constants.createTau;\n }\n});\nObject.defineProperty(exports, \"createThomsonCrossSection\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createThomsonCrossSection;\n }\n});\nObject.defineProperty(exports, \"createTo\", {\n enumerable: true,\n get: function get() {\n return _to.createTo;\n }\n});\nObject.defineProperty(exports, \"createTrace\", {\n enumerable: true,\n get: function get() {\n return _trace.createTrace;\n }\n});\nObject.defineProperty(exports, \"createTranspose\", {\n enumerable: true,\n get: function get() {\n return _transpose.createTranspose;\n }\n});\nObject.defineProperty(exports, \"createTrue\", {\n enumerable: true,\n get: function get() {\n return _constants.createTrue;\n }\n});\nObject.defineProperty(exports, \"createTypeOf\", {\n enumerable: true,\n get: function get() {\n return _typeOf.createTypeOf;\n }\n});\nObject.defineProperty(exports, \"createTyped\", {\n enumerable: true,\n get: function get() {\n return _typed.createTyped;\n }\n});\nObject.defineProperty(exports, \"createUnaryMinus\", {\n enumerable: true,\n get: function get() {\n return _unaryMinus.createUnaryMinus;\n }\n});\nObject.defineProperty(exports, \"createUnaryPlus\", {\n enumerable: true,\n get: function get() {\n return _unaryPlus.createUnaryPlus;\n }\n});\nObject.defineProperty(exports, \"createUnequal\", {\n enumerable: true,\n get: function get() {\n return _unequal.createUnequal;\n }\n});\nObject.defineProperty(exports, \"createUnitClass\", {\n enumerable: true,\n get: function get() {\n return _Unit.createUnitClass;\n }\n});\nObject.defineProperty(exports, \"createUnitFunction\", {\n enumerable: true,\n get: function get() {\n return _unit.createUnitFunction;\n }\n});\nObject.defineProperty(exports, \"createUppercaseE\", {\n enumerable: true,\n get: function get() {\n return _constants.createUppercaseE;\n }\n});\nObject.defineProperty(exports, \"createUppercasePi\", {\n enumerable: true,\n get: function get() {\n return _constants.createUppercasePi;\n }\n});\nObject.defineProperty(exports, \"createUsolve\", {\n enumerable: true,\n get: function get() {\n return _usolve.createUsolve;\n }\n});\nObject.defineProperty(exports, \"createUsolveAll\", {\n enumerable: true,\n get: function get() {\n return _usolveAll.createUsolveAll;\n }\n});\nObject.defineProperty(exports, \"createVacuumImpedance\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createVacuumImpedance;\n }\n});\nObject.defineProperty(exports, \"createVariance\", {\n enumerable: true,\n get: function get() {\n return _variance.createVariance;\n }\n});\nObject.defineProperty(exports, \"createVarianceTransform\", {\n enumerable: true,\n get: function get() {\n return _varianceTransform.createVarianceTransform;\n }\n});\nObject.defineProperty(exports, \"createVersion\", {\n enumerable: true,\n get: function get() {\n return _constants.createVersion;\n }\n});\nObject.defineProperty(exports, \"createWeakMixingAngle\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createWeakMixingAngle;\n }\n});\nObject.defineProperty(exports, \"createWienDisplacement\", {\n enumerable: true,\n get: function get() {\n return _physicalConstants.createWienDisplacement;\n }\n});\nObject.defineProperty(exports, \"createXgcd\", {\n enumerable: true,\n get: function get() {\n return _xgcd.createXgcd;\n }\n});\nObject.defineProperty(exports, \"createXor\", {\n enumerable: true,\n get: function get() {\n return _xor.createXor;\n }\n});\nObject.defineProperty(exports, \"createZeros\", {\n enumerable: true,\n get: function get() {\n return _zeros.createZeros;\n }\n});\n\nvar _typed = require(\"./core/function/typed.js\");\n\nvar _ResultSet = require(\"./type/resultset/ResultSet.js\");\n\nvar _BigNumber = require(\"./type/bignumber/BigNumber.js\");\n\nvar _Complex = require(\"./type/complex/Complex.js\");\n\nvar _Fraction = require(\"./type/fraction/Fraction.js\");\n\nvar _Range = require(\"./type/matrix/Range.js\");\n\nvar _Matrix = require(\"./type/matrix/Matrix.js\");\n\nvar _DenseMatrix = require(\"./type/matrix/DenseMatrix.js\");\n\nvar _clone = require(\"./function/utils/clone.js\");\n\nvar _isInteger = require(\"./function/utils/isInteger.js\");\n\nvar _isNegative = require(\"./function/utils/isNegative.js\");\n\nvar _isNumeric = require(\"./function/utils/isNumeric.js\");\n\nvar _hasNumericValue = require(\"./function/utils/hasNumericValue.js\");\n\nvar _isPositive = require(\"./function/utils/isPositive.js\");\n\nvar _isZero = require(\"./function/utils/isZero.js\");\n\nvar _isNaN = require(\"./function/utils/isNaN.js\");\n\nvar _typeOf = require(\"./function/utils/typeOf.js\");\n\nvar _equalScalar = require(\"./function/relational/equalScalar.js\");\n\nvar _SparseMatrix = require(\"./type/matrix/SparseMatrix.js\");\n\nvar _number = require(\"./type/number.js\");\n\nvar _string = require(\"./type/string.js\");\n\nvar _boolean = require(\"./type/boolean.js\");\n\nvar _bignumber = require(\"./type/bignumber/function/bignumber.js\");\n\nvar _complex = require(\"./type/complex/function/complex.js\");\n\nvar _fraction = require(\"./type/fraction/function/fraction.js\");\n\nvar _matrix = require(\"./type/matrix/function/matrix.js\");\n\nvar _matrixFromFunction = require(\"./function/matrix/matrixFromFunction.js\");\n\nvar _matrixFromRows = require(\"./function/matrix/matrixFromRows.js\");\n\nvar _matrixFromColumns = require(\"./function/matrix/matrixFromColumns.js\");\n\nvar _splitUnit = require(\"./type/unit/function/splitUnit.js\");\n\nvar _unaryMinus = require(\"./function/arithmetic/unaryMinus.js\");\n\nvar _unaryPlus = require(\"./function/arithmetic/unaryPlus.js\");\n\nvar _abs = require(\"./function/arithmetic/abs.js\");\n\nvar _apply = require(\"./function/matrix/apply.js\");\n\nvar _addScalar = require(\"./function/arithmetic/addScalar.js\");\n\nvar _cbrt = require(\"./function/arithmetic/cbrt.js\");\n\nvar _ceil = require(\"./function/arithmetic/ceil.js\");\n\nvar _cube = require(\"./function/arithmetic/cube.js\");\n\nvar _exp = require(\"./function/arithmetic/exp.js\");\n\nvar _expm = require(\"./function/arithmetic/expm1.js\");\n\nvar _fix = require(\"./function/arithmetic/fix.js\");\n\nvar _floor = require(\"./function/arithmetic/floor.js\");\n\nvar _gcd = require(\"./function/arithmetic/gcd.js\");\n\nvar _lcm = require(\"./function/arithmetic/lcm.js\");\n\nvar _log = require(\"./function/arithmetic/log10.js\");\n\nvar _log2 = require(\"./function/arithmetic/log2.js\");\n\nvar _mod = require(\"./function/arithmetic/mod.js\");\n\nvar _multiplyScalar = require(\"./function/arithmetic/multiplyScalar.js\");\n\nvar _multiply = require(\"./function/arithmetic/multiply.js\");\n\nvar _nthRoot = require(\"./function/arithmetic/nthRoot.js\");\n\nvar _sign = require(\"./function/arithmetic/sign.js\");\n\nvar _sqrt = require(\"./function/arithmetic/sqrt.js\");\n\nvar _square = require(\"./function/arithmetic/square.js\");\n\nvar _subtract = require(\"./function/arithmetic/subtract.js\");\n\nvar _xgcd = require(\"./function/arithmetic/xgcd.js\");\n\nvar _invmod = require(\"./function/arithmetic/invmod.js\");\n\nvar _dotMultiply = require(\"./function/arithmetic/dotMultiply.js\");\n\nvar _bitAnd = require(\"./function/bitwise/bitAnd.js\");\n\nvar _bitNot = require(\"./function/bitwise/bitNot.js\");\n\nvar _bitOr = require(\"./function/bitwise/bitOr.js\");\n\nvar _bitXor = require(\"./function/bitwise/bitXor.js\");\n\nvar _arg = require(\"./function/complex/arg.js\");\n\nvar _conj = require(\"./function/complex/conj.js\");\n\nvar _im = require(\"./function/complex/im.js\");\n\nvar _re = require(\"./function/complex/re.js\");\n\nvar _not = require(\"./function/logical/not.js\");\n\nvar _or = require(\"./function/logical/or.js\");\n\nvar _xor = require(\"./function/logical/xor.js\");\n\nvar _concat = require(\"./function/matrix/concat.js\");\n\nvar _column = require(\"./function/matrix/column.js\");\n\nvar _count = require(\"./function/matrix/count.js\");\n\nvar _cross = require(\"./function/matrix/cross.js\");\n\nvar _diag = require(\"./function/matrix/diag.js\");\n\nvar _filter = require(\"./function/matrix/filter.js\");\n\nvar _flatten = require(\"./function/matrix/flatten.js\");\n\nvar _forEach = require(\"./function/matrix/forEach.js\");\n\nvar _getMatrixDataType = require(\"./function/matrix/getMatrixDataType.js\");\n\nvar _identity = require(\"./function/matrix/identity.js\");\n\nvar _kron = require(\"./function/matrix/kron.js\");\n\nvar _map = require(\"./function/matrix/map.js\");\n\nvar _diff = require(\"./function/matrix/diff.js\");\n\nvar _ones = require(\"./function/matrix/ones.js\");\n\nvar _range = require(\"./function/matrix/range.js\");\n\nvar _reshape = require(\"./function/matrix/reshape.js\");\n\nvar _resize = require(\"./function/matrix/resize.js\");\n\nvar _rotate = require(\"./function/matrix/rotate.js\");\n\nvar _rotationMatrix = require(\"./function/matrix/rotationMatrix.js\");\n\nvar _row = require(\"./function/matrix/row.js\");\n\nvar _size = require(\"./function/matrix/size.js\");\n\nvar _squeeze = require(\"./function/matrix/squeeze.js\");\n\nvar _subset = require(\"./function/matrix/subset.js\");\n\nvar _transpose = require(\"./function/matrix/transpose.js\");\n\nvar _ctranspose = require(\"./function/matrix/ctranspose.js\");\n\nvar _zeros = require(\"./function/matrix/zeros.js\");\n\nvar _fft = require(\"./function/matrix/fft.js\");\n\nvar _ifft = require(\"./function/matrix/ifft.js\");\n\nvar _erf = require(\"./function/special/erf.js\");\n\nvar _mode = require(\"./function/statistics/mode.js\");\n\nvar _prod = require(\"./function/statistics/prod.js\");\n\nvar _format = require(\"./function/string/format.js\");\n\nvar _bin = require(\"./function/string/bin.js\");\n\nvar _oct = require(\"./function/string/oct.js\");\n\nvar _hex = require(\"./function/string/hex.js\");\n\nvar _print = require(\"./function/string/print.js\");\n\nvar _to = require(\"./function/unit/to.js\");\n\nvar _isPrime = require(\"./function/utils/isPrime.js\");\n\nvar _numeric = require(\"./function/utils/numeric.js\");\n\nvar _divideScalar = require(\"./function/arithmetic/divideScalar.js\");\n\nvar _pow = require(\"./function/arithmetic/pow.js\");\n\nvar _round = require(\"./function/arithmetic/round.js\");\n\nvar _log3 = require(\"./function/arithmetic/log.js\");\n\nvar _log1p = require(\"./function/arithmetic/log1p.js\");\n\nvar _nthRoots = require(\"./function/arithmetic/nthRoots.js\");\n\nvar _dotPow = require(\"./function/arithmetic/dotPow.js\");\n\nvar _dotDivide = require(\"./function/arithmetic/dotDivide.js\");\n\nvar _lsolve = require(\"./function/algebra/solver/lsolve.js\");\n\nvar _usolve = require(\"./function/algebra/solver/usolve.js\");\n\nvar _lsolveAll = require(\"./function/algebra/solver/lsolveAll.js\");\n\nvar _usolveAll = require(\"./function/algebra/solver/usolveAll.js\");\n\nvar _leftShift = require(\"./function/bitwise/leftShift.js\");\n\nvar _rightArithShift = require(\"./function/bitwise/rightArithShift.js\");\n\nvar _rightLogShift = require(\"./function/bitwise/rightLogShift.js\");\n\nvar _and = require(\"./function/logical/and.js\");\n\nvar _compare = require(\"./function/relational/compare.js\");\n\nvar _compareNatural = require(\"./function/relational/compareNatural.js\");\n\nvar _compareText = require(\"./function/relational/compareText.js\");\n\nvar _equal = require(\"./function/relational/equal.js\");\n\nvar _equalText = require(\"./function/relational/equalText.js\");\n\nvar _smaller = require(\"./function/relational/smaller.js\");\n\nvar _smallerEq = require(\"./function/relational/smallerEq.js\");\n\nvar _larger = require(\"./function/relational/larger.js\");\n\nvar _largerEq = require(\"./function/relational/largerEq.js\");\n\nvar _deepEqual = require(\"./function/relational/deepEqual.js\");\n\nvar _unequal = require(\"./function/relational/unequal.js\");\n\nvar _partitionSelect = require(\"./function/matrix/partitionSelect.js\");\n\nvar _sort = require(\"./function/matrix/sort.js\");\n\nvar _max = require(\"./function/statistics/max.js\");\n\nvar _min = require(\"./function/statistics/min.js\");\n\nvar _ImmutableDenseMatrix = require(\"./type/matrix/ImmutableDenseMatrix.js\");\n\nvar _MatrixIndex = require(\"./type/matrix/MatrixIndex.js\");\n\nvar _FibonacciHeap = require(\"./type/matrix/FibonacciHeap.js\");\n\nvar _Spa = require(\"./type/matrix/Spa.js\");\n\nvar _Unit = require(\"./type/unit/Unit.js\");\n\nvar _unit = require(\"./type/unit/function/unit.js\");\n\nvar _sparse = require(\"./type/matrix/function/sparse.js\");\n\nvar _createUnit = require(\"./type/unit/function/createUnit.js\");\n\nvar _acos = require(\"./function/trigonometry/acos.js\");\n\nvar _acosh = require(\"./function/trigonometry/acosh.js\");\n\nvar _acot = require(\"./function/trigonometry/acot.js\");\n\nvar _acoth = require(\"./function/trigonometry/acoth.js\");\n\nvar _acsc = require(\"./function/trigonometry/acsc.js\");\n\nvar _acsch = require(\"./function/trigonometry/acsch.js\");\n\nvar _asec = require(\"./function/trigonometry/asec.js\");\n\nvar _asech = require(\"./function/trigonometry/asech.js\");\n\nvar _asin = require(\"./function/trigonometry/asin.js\");\n\nvar _asinh = require(\"./function/trigonometry/asinh.js\");\n\nvar _atan = require(\"./function/trigonometry/atan.js\");\n\nvar _atan2 = require(\"./function/trigonometry/atan2.js\");\n\nvar _atanh = require(\"./function/trigonometry/atanh.js\");\n\nvar _cos = require(\"./function/trigonometry/cos.js\");\n\nvar _cosh = require(\"./function/trigonometry/cosh.js\");\n\nvar _cot = require(\"./function/trigonometry/cot.js\");\n\nvar _coth = require(\"./function/trigonometry/coth.js\");\n\nvar _csc = require(\"./function/trigonometry/csc.js\");\n\nvar _csch = require(\"./function/trigonometry/csch.js\");\n\nvar _sec = require(\"./function/trigonometry/sec.js\");\n\nvar _sech = require(\"./function/trigonometry/sech.js\");\n\nvar _sin = require(\"./function/trigonometry/sin.js\");\n\nvar _sinh = require(\"./function/trigonometry/sinh.js\");\n\nvar _tan = require(\"./function/trigonometry/tan.js\");\n\nvar _tanh = require(\"./function/trigonometry/tanh.js\");\n\nvar _setCartesian = require(\"./function/set/setCartesian.js\");\n\nvar _setDifference = require(\"./function/set/setDifference.js\");\n\nvar _setDistinct = require(\"./function/set/setDistinct.js\");\n\nvar _setIntersect = require(\"./function/set/setIntersect.js\");\n\nvar _setIsSubset = require(\"./function/set/setIsSubset.js\");\n\nvar _setMultiplicity = require(\"./function/set/setMultiplicity.js\");\n\nvar _setPowerset = require(\"./function/set/setPowerset.js\");\n\nvar _setSize = require(\"./function/set/setSize.js\");\n\nvar _setSymDifference = require(\"./function/set/setSymDifference.js\");\n\nvar _setUnion = require(\"./function/set/setUnion.js\");\n\nvar _add = require(\"./function/arithmetic/add.js\");\n\nvar _hypot = require(\"./function/arithmetic/hypot.js\");\n\nvar _norm = require(\"./function/arithmetic/norm.js\");\n\nvar _dot = require(\"./function/matrix/dot.js\");\n\nvar _trace = require(\"./function/matrix/trace.js\");\n\nvar _index = require(\"./type/matrix/function/index.js\");\n\nvar _Node = require(\"./expression/node/Node.js\");\n\nvar _AccessorNode = require(\"./expression/node/AccessorNode.js\");\n\nvar _ArrayNode = require(\"./expression/node/ArrayNode.js\");\n\nvar _AssignmentNode = require(\"./expression/node/AssignmentNode.js\");\n\nvar _BlockNode = require(\"./expression/node/BlockNode.js\");\n\nvar _ConditionalNode = require(\"./expression/node/ConditionalNode.js\");\n\nvar _ConstantNode = require(\"./expression/node/ConstantNode.js\");\n\nvar _FunctionAssignmentNode = require(\"./expression/node/FunctionAssignmentNode.js\");\n\nvar _IndexNode = require(\"./expression/node/IndexNode.js\");\n\nvar _ObjectNode = require(\"./expression/node/ObjectNode.js\");\n\nvar _OperatorNode = require(\"./expression/node/OperatorNode.js\");\n\nvar _ParenthesisNode = require(\"./expression/node/ParenthesisNode.js\");\n\nvar _RangeNode = require(\"./expression/node/RangeNode.js\");\n\nvar _RelationalNode = require(\"./expression/node/RelationalNode.js\");\n\nvar _SymbolNode = require(\"./expression/node/SymbolNode.js\");\n\nvar _FunctionNode = require(\"./expression/node/FunctionNode.js\");\n\nvar _parse = require(\"./expression/parse.js\");\n\nvar _compile = require(\"./expression/function/compile.js\");\n\nvar _evaluate = require(\"./expression/function/evaluate.js\");\n\nvar _Parser = require(\"./expression/Parser.js\");\n\nvar _parser = require(\"./expression/function/parser.js\");\n\nvar _lup = require(\"./function/algebra/decomposition/lup.js\");\n\nvar _qr = require(\"./function/algebra/decomposition/qr.js\");\n\nvar _slu = require(\"./function/algebra/decomposition/slu.js\");\n\nvar _lusolve = require(\"./function/algebra/solver/lusolve.js\");\n\nvar _Help = require(\"./expression/Help.js\");\n\nvar _Chain = require(\"./type/chain/Chain.js\");\n\nvar _help = require(\"./expression/function/help.js\");\n\nvar _chain = require(\"./type/chain/function/chain.js\");\n\nvar _det = require(\"./function/matrix/det.js\");\n\nvar _inv = require(\"./function/matrix/inv.js\");\n\nvar _pinv = require(\"./function/matrix/pinv.js\");\n\nvar _eigs = require(\"./function/matrix/eigs.js\");\n\nvar _expm2 = require(\"./function/matrix/expm.js\");\n\nvar _sqrtm = require(\"./function/matrix/sqrtm.js\");\n\nvar _divide = require(\"./function/arithmetic/divide.js\");\n\nvar _distance = require(\"./function/geometry/distance.js\");\n\nvar _intersect = require(\"./function/geometry/intersect.js\");\n\nvar _sum = require(\"./function/statistics/sum.js\");\n\nvar _cumsum = require(\"./function/statistics/cumsum.js\");\n\nvar _mean = require(\"./function/statistics/mean.js\");\n\nvar _median = require(\"./function/statistics/median.js\");\n\nvar _mad = require(\"./function/statistics/mad.js\");\n\nvar _variance = require(\"./function/statistics/variance.js\");\n\nvar _quantileSeq = require(\"./function/statistics/quantileSeq.js\");\n\nvar _std = require(\"./function/statistics/std.js\");\n\nvar _combinations = require(\"./function/probability/combinations.js\");\n\nvar _combinationsWithRep = require(\"./function/probability/combinationsWithRep.js\");\n\nvar _gamma = require(\"./function/probability/gamma.js\");\n\nvar _lgamma = require(\"./function/probability/lgamma.js\");\n\nvar _factorial = require(\"./function/probability/factorial.js\");\n\nvar _kldivergence = require(\"./function/probability/kldivergence.js\");\n\nvar _multinomial = require(\"./function/probability/multinomial.js\");\n\nvar _permutations = require(\"./function/probability/permutations.js\");\n\nvar _pickRandom = require(\"./function/probability/pickRandom.js\");\n\nvar _random = require(\"./function/probability/random.js\");\n\nvar _randomInt = require(\"./function/probability/randomInt.js\");\n\nvar _stirlingS = require(\"./function/combinatorics/stirlingS2.js\");\n\nvar _bellNumbers = require(\"./function/combinatorics/bellNumbers.js\");\n\nvar _catalan = require(\"./function/combinatorics/catalan.js\");\n\nvar _composition = require(\"./function/combinatorics/composition.js\");\n\nvar _leafCount = require(\"./function/algebra/leafCount.js\");\n\nvar _simplify = require(\"./function/algebra/simplify.js\");\n\nvar _simplifyCore = require(\"./function/algebra/simplifyCore.js\");\n\nvar _resolve = require(\"./function/algebra/resolve.js\");\n\nvar _symbolicEqual = require(\"./function/algebra/symbolicEqual.js\");\n\nvar _derivative = require(\"./function/algebra/derivative.js\");\n\nvar _rationalize = require(\"./function/algebra/rationalize.js\");\n\nvar _reviver = require(\"./json/reviver.js\");\n\nvar _replacer = require(\"./json/replacer.js\");\n\nvar _constants = require(\"./constants.js\");\n\nvar _physicalConstants = require(\"./type/unit/physicalConstants.js\");\n\nvar _applyTransform = require(\"./expression/transform/apply.transform.js\");\n\nvar _columnTransform = require(\"./expression/transform/column.transform.js\");\n\nvar _filterTransform = require(\"./expression/transform/filter.transform.js\");\n\nvar _forEachTransform = require(\"./expression/transform/forEach.transform.js\");\n\nvar _indexTransform = require(\"./expression/transform/index.transform.js\");\n\nvar _mapTransform = require(\"./expression/transform/map.transform.js\");\n\nvar _maxTransform = require(\"./expression/transform/max.transform.js\");\n\nvar _meanTransform = require(\"./expression/transform/mean.transform.js\");\n\nvar _minTransform = require(\"./expression/transform/min.transform.js\");\n\nvar _rangeTransform = require(\"./expression/transform/range.transform.js\");\n\nvar _rowTransform = require(\"./expression/transform/row.transform.js\");\n\nvar _subsetTransform = require(\"./expression/transform/subset.transform.js\");\n\nvar _concatTransform = require(\"./expression/transform/concat.transform.js\");\n\nvar _diffTransform = require(\"./expression/transform/diff.transform.js\");\n\nvar _stdTransform = require(\"./expression/transform/std.transform.js\");\n\nvar _sumTransform = require(\"./expression/transform/sum.transform.js\");\n\nvar _cumsumTransform = require(\"./expression/transform/cumsum.transform.js\");\n\nvar _varianceTransform = require(\"./expression/transform/variance.transform.js\");","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLup = void 0;\n\nvar _object = require(\"../../../utils/object.js\");\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar name = 'lup';\nvar dependencies = ['typed', 'matrix', 'abs', 'addScalar', 'divideScalar', 'multiplyScalar', 'subtract', 'larger', 'equalScalar', 'unaryMinus', 'DenseMatrix', 'SparseMatrix', 'Spa'];\nvar createLup = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n abs = _ref.abs,\n addScalar = _ref.addScalar,\n divideScalar = _ref.divideScalar,\n multiplyScalar = _ref.multiplyScalar,\n subtract = _ref.subtract,\n larger = _ref.larger,\n equalScalar = _ref.equalScalar,\n unaryMinus = _ref.unaryMinus,\n DenseMatrix = _ref.DenseMatrix,\n SparseMatrix = _ref.SparseMatrix,\n Spa = _ref.Spa;\n\n /**\n * Calculate the Matrix LU decomposition with partial pivoting. Matrix `A` is decomposed in two matrices (`L`, `U`) and a\n * row permutation vector `p` where `A[p,:] = L * U`\n *\n * Syntax:\n *\n * math.lup(A)\n *\n * Example:\n *\n * const m = [[2, 1], [1, 4]]\n * const r = math.lup(m)\n * // r = {\n * // L: [[1, 0], [0.5, 1]],\n * // U: [[2, 1], [0, 3.5]],\n * // P: [0, 1]\n * // }\n *\n * See also:\n *\n * slu, lsolve, lusolve, usolve\n *\n * @param {Matrix | Array} A A two dimensional matrix or array for which to get the LUP decomposition.\n *\n * @return {{L: Array | Matrix, U: Array | Matrix, P: Array.}} The lower triangular matrix, the upper triangular matrix and the permutation matrix.\n */\n return typed(name, {\n DenseMatrix: function DenseMatrix(m) {\n return _denseLUP(m);\n },\n SparseMatrix: function SparseMatrix(m) {\n return _sparseLUP(m);\n },\n Array: function Array(a) {\n // create dense matrix from array\n var m = matrix(a); // lup, use matrix implementation\n\n var r = _denseLUP(m); // result\n\n\n return {\n L: r.L.valueOf(),\n U: r.U.valueOf(),\n p: r.p\n };\n }\n });\n\n function _denseLUP(m) {\n // rows & columns\n var rows = m._size[0];\n var columns = m._size[1]; // minimum rows and columns\n\n var n = Math.min(rows, columns); // matrix array, clone original data\n\n var data = (0, _object.clone)(m._data); // l matrix arrays\n\n var ldata = [];\n var lsize = [rows, n]; // u matrix arrays\n\n var udata = [];\n var usize = [n, columns]; // vars\n\n var i, j, k; // permutation vector\n\n var p = [];\n\n for (i = 0; i < rows; i++) {\n p[i] = i;\n } // loop columns\n\n\n for (j = 0; j < columns; j++) {\n // skip first column in upper triangular matrix\n if (j > 0) {\n // loop rows\n for (i = 0; i < rows; i++) {\n // min i,j\n var min = Math.min(i, j); // v[i, j]\n\n var s = 0; // loop up to min\n\n for (k = 0; k < min; k++) {\n // s = l[i, k] - data[k, j]\n s = addScalar(s, multiplyScalar(data[i][k], data[k][j]));\n }\n\n data[i][j] = subtract(data[i][j], s);\n }\n } // row with larger value in cvector, row >= j\n\n\n var pi = j;\n var pabsv = 0;\n var vjj = 0; // loop rows\n\n for (i = j; i < rows; i++) {\n // data @ i, j\n var v = data[i][j]; // absolute value\n\n var absv = abs(v); // value is greater than pivote value\n\n if (larger(absv, pabsv)) {\n // store row\n pi = i; // update max value\n\n pabsv = absv; // value @ [j, j]\n\n vjj = v;\n }\n } // swap rows (j <-> pi)\n\n\n if (j !== pi) {\n // swap values j <-> pi in p\n p[j] = [p[pi], p[pi] = p[j]][0]; // swap j <-> pi in data\n\n DenseMatrix._swapRows(j, pi, data);\n } // check column is in lower triangular matrix\n\n\n if (j < rows) {\n // loop rows (lower triangular matrix)\n for (i = j + 1; i < rows; i++) {\n // value @ i, j\n var vij = data[i][j];\n\n if (!equalScalar(vij, 0)) {\n // update data\n data[i][j] = divideScalar(data[i][j], vjj);\n }\n }\n }\n } // loop columns\n\n\n for (j = 0; j < columns; j++) {\n // loop rows\n for (i = 0; i < rows; i++) {\n // initialize row in arrays\n if (j === 0) {\n // check row exists in upper triangular matrix\n if (i < columns) {\n // U\n udata[i] = [];\n } // L\n\n\n ldata[i] = [];\n } // check we are in the upper triangular matrix\n\n\n if (i < j) {\n // check row exists in upper triangular matrix\n if (i < columns) {\n // U\n udata[i][j] = data[i][j];\n } // check column exists in lower triangular matrix\n\n\n if (j < rows) {\n // L\n ldata[i][j] = 0;\n }\n\n continue;\n } // diagonal value\n\n\n if (i === j) {\n // check row exists in upper triangular matrix\n if (i < columns) {\n // U\n udata[i][j] = data[i][j];\n } // check column exists in lower triangular matrix\n\n\n if (j < rows) {\n // L\n ldata[i][j] = 1;\n }\n\n continue;\n } // check row exists in upper triangular matrix\n\n\n if (i < columns) {\n // U\n udata[i][j] = 0;\n } // check column exists in lower triangular matrix\n\n\n if (j < rows) {\n // L\n ldata[i][j] = data[i][j];\n }\n }\n } // l matrix\n\n\n var l = new DenseMatrix({\n data: ldata,\n size: lsize\n }); // u matrix\n\n var u = new DenseMatrix({\n data: udata,\n size: usize\n }); // p vector\n\n var pv = [];\n\n for (i = 0, n = p.length; i < n; i++) {\n pv[p[i]] = i;\n } // return matrices\n\n\n return {\n L: l,\n U: u,\n p: pv,\n toString: function toString() {\n return 'L: ' + this.L.toString() + '\\nU: ' + this.U.toString() + '\\nP: ' + this.p;\n }\n };\n }\n\n function _sparseLUP(m) {\n // rows & columns\n var rows = m._size[0];\n var columns = m._size[1]; // minimum rows and columns\n\n var n = Math.min(rows, columns); // matrix arrays (will not be modified, thanks to permutation vector)\n\n var values = m._values;\n var index = m._index;\n var ptr = m._ptr; // l matrix arrays\n\n var lvalues = [];\n var lindex = [];\n var lptr = [];\n var lsize = [rows, n]; // u matrix arrays\n\n var uvalues = [];\n var uindex = [];\n var uptr = [];\n var usize = [n, columns]; // vars\n\n var i, j, k; // permutation vectors, (current index -> original index) and (original index -> current index)\n\n var pvCo = [];\n var pvOc = [];\n\n for (i = 0; i < rows; i++) {\n pvCo[i] = i;\n pvOc[i] = i;\n } // swap indices in permutation vectors (condition x < y)!\n\n\n var swapIndeces = function swapIndeces(x, y) {\n // find pv indeces getting data from x and y\n var kx = pvOc[x];\n var ky = pvOc[y]; // update permutation vector current -> original\n\n pvCo[kx] = y;\n pvCo[ky] = x; // update permutation vector original -> current\n\n pvOc[x] = ky;\n pvOc[y] = kx;\n }; // loop columns\n\n\n var _loop = function _loop() {\n // sparse accumulator\n var spa = new Spa(); // check lower triangular matrix has a value @ column j\n\n if (j < rows) {\n // update ptr\n lptr.push(lvalues.length); // first value in j column for lower triangular matrix\n\n lvalues.push(1);\n lindex.push(j);\n } // update ptr\n\n\n uptr.push(uvalues.length); // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n\n var k0 = ptr[j];\n var k1 = ptr[j + 1]; // copy column j into sparse accumulator\n\n for (k = k0; k < k1; k++) {\n // row\n i = index[k]; // copy column values into sparse accumulator (use permutation vector)\n\n spa.set(pvCo[i], values[k]);\n } // skip first column in upper triangular matrix\n\n\n if (j > 0) {\n // loop rows in column j (above diagonal)\n spa.forEach(0, j - 1, function (k, vkj) {\n // loop rows in column k (L)\n SparseMatrix._forEachRow(k, lvalues, lindex, lptr, function (i, vik) {\n // check row is below k\n if (i > k) {\n // update spa value\n spa.accumulate(i, unaryMinus(multiplyScalar(vik, vkj)));\n }\n });\n });\n } // row with larger value in spa, row >= j\n\n\n var pi = j;\n var vjj = spa.get(j);\n var pabsv = abs(vjj); // loop values in spa (order by row, below diagonal)\n\n spa.forEach(j + 1, rows - 1, function (x, v) {\n // absolute value\n var absv = abs(v); // value is greater than pivote value\n\n if (larger(absv, pabsv)) {\n // store row\n pi = x; // update max value\n\n pabsv = absv; // value @ [j, j]\n\n vjj = v;\n }\n }); // swap rows (j <-> pi)\n\n if (j !== pi) {\n // swap values j <-> pi in L\n SparseMatrix._swapRows(j, pi, lsize[1], lvalues, lindex, lptr); // swap values j <-> pi in U\n\n\n SparseMatrix._swapRows(j, pi, usize[1], uvalues, uindex, uptr); // swap values in spa\n\n\n spa.swap(j, pi); // update permutation vector (swap values @ j, pi)\n\n swapIndeces(j, pi);\n } // loop values in spa (order by row)\n\n\n spa.forEach(0, rows - 1, function (x, v) {\n // check we are above diagonal\n if (x <= j) {\n // update upper triangular matrix\n uvalues.push(v);\n uindex.push(x);\n } else {\n // update value\n v = divideScalar(v, vjj); // check value is non zero\n\n if (!equalScalar(v, 0)) {\n // update lower triangular matrix\n lvalues.push(v);\n lindex.push(x);\n }\n }\n });\n };\n\n for (j = 0; j < columns; j++) {\n _loop();\n } // update ptrs\n\n\n uptr.push(uvalues.length);\n lptr.push(lvalues.length); // return matrices\n\n return {\n L: new SparseMatrix({\n values: lvalues,\n index: lindex,\n ptr: lptr,\n size: lsize\n }),\n U: new SparseMatrix({\n values: uvalues,\n index: uindex,\n ptr: uptr,\n size: usize\n }),\n p: pvCo,\n toString: function toString() {\n return 'L: ' + this.L.toString() + '\\nU: ' + this.U.toString() + '\\nP: ' + this.p;\n }\n };\n }\n});\nexports.createLup = createLup;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createQr = void 0;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar name = 'qr';\nvar dependencies = ['typed', 'matrix', 'zeros', 'identity', 'isZero', 'equal', 'sign', 'sqrt', 'conj', 'unaryMinus', 'addScalar', 'divideScalar', 'multiplyScalar', 'subtract', 'complex'];\nvar createQr = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n zeros = _ref.zeros,\n identity = _ref.identity,\n isZero = _ref.isZero,\n equal = _ref.equal,\n sign = _ref.sign,\n sqrt = _ref.sqrt,\n conj = _ref.conj,\n unaryMinus = _ref.unaryMinus,\n addScalar = _ref.addScalar,\n divideScalar = _ref.divideScalar,\n multiplyScalar = _ref.multiplyScalar,\n subtract = _ref.subtract,\n complex = _ref.complex;\n\n /**\n * Calculate the Matrix QR decomposition. Matrix `A` is decomposed in\n * two matrices (`Q`, `R`) where `Q` is an\n * orthogonal matrix and `R` is an upper triangular matrix.\n *\n * Syntax:\n *\n * math.qr(A)\n *\n * Example:\n *\n * const m = [\n * [1, -1, 4],\n * [1, 4, -2],\n * [1, 4, 2],\n * [1, -1, 0]\n * ]\n * const result = math.qr(m)\n * // r = {\n * // Q: [\n * // [0.5, -0.5, 0.5],\n * // [0.5, 0.5, -0.5],\n * // [0.5, 0.5, 0.5],\n * // [0.5, -0.5, -0.5],\n * // ],\n * // R: [\n * // [2, 3, 2],\n * // [0, 5, -2],\n * // [0, 0, 4],\n * // [0, 0, 0]\n * // ]\n * // }\n *\n * See also:\n *\n * lup, lusolve\n *\n * @param {Matrix | Array} A A two dimensional matrix or array\n * for which to get the QR decomposition.\n *\n * @return {{Q: Array | Matrix, R: Array | Matrix}} Q: the orthogonal\n * matrix and R: the upper triangular matrix\n */\n return (0, _extends2.default)(typed(name, {\n DenseMatrix: function DenseMatrix(m) {\n return _denseQR(m);\n },\n SparseMatrix: function SparseMatrix(m) {\n return _sparseQR(m);\n },\n Array: function Array(a) {\n // create dense matrix from array\n var m = matrix(a); // lup, use matrix implementation\n\n var r = _denseQR(m); // result\n\n\n return {\n Q: r.Q.valueOf(),\n R: r.R.valueOf()\n };\n }\n }), {\n _denseQRimpl: _denseQRimpl\n });\n\n function _denseQRimpl(m) {\n // rows & columns (m x n)\n var rows = m._size[0]; // m\n\n var cols = m._size[1]; // n\n\n var Q = identity([rows], 'dense');\n var Qdata = Q._data;\n var R = m.clone();\n var Rdata = R._data; // vars\n\n var i, j, k;\n var w = zeros([rows], '');\n\n for (k = 0; k < Math.min(cols, rows); ++k) {\n /*\n * **k-th Household matrix**\n *\n * The matrix I - 2*v*transpose(v)\n * x = first column of A\n * x1 = first element of x\n * alpha = x1 / |x1| * |x|\n * e1 = tranpose([1, 0, 0, ...])\n * u = x - alpha * e1\n * v = u / |u|\n *\n * Household matrix = I - 2 * v * tranpose(v)\n *\n * * Initially Q = I and R = A.\n * * Household matrix is a reflection in a plane normal to v which\n * will zero out all but the top right element in R.\n * * Appplying reflection to both Q and R will not change product.\n * * Repeat this process on the (1,1) minor to get R as an upper\n * triangular matrix.\n * * Reflections leave the magnitude of the columns of Q unchanged\n * so Q remains othoganal.\n *\n */\n var pivot = Rdata[k][k];\n var sgn = unaryMinus(equal(pivot, 0) ? 1 : sign(pivot));\n var conjSgn = conj(sgn);\n var alphaSquared = 0;\n\n for (i = k; i < rows; i++) {\n alphaSquared = addScalar(alphaSquared, multiplyScalar(Rdata[i][k], conj(Rdata[i][k])));\n }\n\n var alpha = multiplyScalar(sgn, sqrt(alphaSquared));\n\n if (!isZero(alpha)) {\n // first element in vector u\n var u1 = subtract(pivot, alpha); // w = v * u1 / |u| (only elements k to (rows-1) are used)\n\n w[k] = 1;\n\n for (i = k + 1; i < rows; i++) {\n w[i] = divideScalar(Rdata[i][k], u1);\n } // tau = - conj(u1 / alpha)\n\n\n var tau = unaryMinus(conj(divideScalar(u1, alpha)));\n var s = void 0;\n /*\n * tau and w have been choosen so that\n *\n * 2 * v * tranpose(v) = tau * w * tranpose(w)\n */\n\n /*\n * -- calculate R = R - tau * w * tranpose(w) * R --\n * Only do calculation with rows k to (rows-1)\n * Additionally columns 0 to (k-1) will not be changed by this\n * multiplication so do not bother recalculating them\n */\n\n for (j = k; j < cols; j++) {\n s = 0.0; // calculate jth element of [tranpose(w) * R]\n\n for (i = k; i < rows; i++) {\n s = addScalar(s, multiplyScalar(conj(w[i]), Rdata[i][j]));\n } // calculate the jth element of [tau * transpose(w) * R]\n\n\n s = multiplyScalar(s, tau);\n\n for (i = k; i < rows; i++) {\n Rdata[i][j] = multiplyScalar(subtract(Rdata[i][j], multiplyScalar(w[i], s)), conjSgn);\n }\n }\n /*\n * -- calculate Q = Q - tau * Q * w * transpose(w) --\n * Q is a square matrix (rows x rows)\n * Only do calculation with columns k to (rows-1)\n * Additionally rows 0 to (k-1) will not be changed by this\n * multiplication so do not bother recalculating them\n */\n\n\n for (i = 0; i < rows; i++) {\n s = 0.0; // calculate ith element of [Q * w]\n\n for (j = k; j < rows; j++) {\n s = addScalar(s, multiplyScalar(Qdata[i][j], w[j]));\n } // calculate the ith element of [tau * Q * w]\n\n\n s = multiplyScalar(s, tau);\n\n for (j = k; j < rows; ++j) {\n Qdata[i][j] = divideScalar(subtract(Qdata[i][j], multiplyScalar(s, conj(w[j]))), conjSgn);\n }\n }\n }\n } // return matrices\n\n\n return {\n Q: Q,\n R: R,\n toString: function toString() {\n return 'Q: ' + this.Q.toString() + '\\nR: ' + this.R.toString();\n }\n };\n }\n\n function _denseQR(m) {\n var ret = _denseQRimpl(m);\n\n var Rdata = ret.R._data;\n\n if (m._data.length > 0) {\n var zero = Rdata[0][0].type === 'Complex' ? complex(0) : 0;\n\n for (var i = 0; i < Rdata.length; ++i) {\n for (var j = 0; j < i && j < (Rdata[0] || []).length; ++j) {\n Rdata[i][j] = zero;\n }\n }\n }\n\n return ret;\n }\n\n function _sparseQR(m) {\n throw new Error('qr not implemented for sparse matrices yet');\n }\n});\nexports.createQr = createQr;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSlu = void 0;\n\nvar _number = require(\"../../../utils/number.js\");\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _csSqr = require(\"../sparse/csSqr.js\");\n\nvar _csLu = require(\"../sparse/csLu.js\");\n\nvar name = 'slu';\nvar dependencies = ['typed', 'abs', 'add', 'multiply', 'transpose', 'divideScalar', 'subtract', 'larger', 'largerEq', 'SparseMatrix'];\nvar createSlu = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n abs = _ref.abs,\n add = _ref.add,\n multiply = _ref.multiply,\n transpose = _ref.transpose,\n divideScalar = _ref.divideScalar,\n subtract = _ref.subtract,\n larger = _ref.larger,\n largerEq = _ref.largerEq,\n SparseMatrix = _ref.SparseMatrix;\n var csSqr = (0, _csSqr.createCsSqr)({\n add: add,\n multiply: multiply,\n transpose: transpose\n });\n var csLu = (0, _csLu.createCsLu)({\n abs: abs,\n divideScalar: divideScalar,\n multiply: multiply,\n subtract: subtract,\n larger: larger,\n largerEq: largerEq,\n SparseMatrix: SparseMatrix\n });\n /**\n * Calculate the Sparse Matrix LU decomposition with full pivoting. Sparse Matrix `A` is decomposed in two matrices (`L`, `U`) and two permutation vectors (`pinv`, `q`) where\n *\n * `P * A * Q = L * U`\n *\n * Syntax:\n *\n * math.slu(A, order, threshold)\n *\n * Examples:\n *\n * const A = math.sparse([[4,3], [6, 3]])\n * math.slu(A, 1, 0.001)\n * // returns:\n * // {\n * // L: [[1, 0], [1.5, 1]]\n * // U: [[4, 3], [0, -1.5]]\n * // p: [0, 1]\n * // q: [0, 1]\n * // }\n *\n * See also:\n *\n * lup, lsolve, usolve, lusolve\n *\n * @param {SparseMatrix} A A two dimensional sparse matrix for which to get the LU decomposition.\n * @param {Number} order The Symbolic Ordering and Analysis order:\n * 0 - Natural ordering, no permutation vector q is returned\n * 1 - Matrix must be square, symbolic ordering and analisis is performed on M = A + A'\n * 2 - Symbolic ordering and analisis is performed on M = A' * A. Dense columns from A' are dropped, A recreated from A'.\n * This is appropriatefor LU factorization of unsymmetric matrices.\n * 3 - Symbolic ordering and analisis is performed on M = A' * A. This is best used for LU factorization is matrix M has no dense rows.\n * A dense row is a row with more than 10*sqr(columns) entries.\n * @param {Number} threshold Partial pivoting threshold (1 for partial pivoting)\n *\n * @return {Object} The lower triangular matrix, the upper triangular matrix and the permutation vectors.\n */\n\n return typed(name, {\n 'SparseMatrix, number, number': function SparseMatrixNumberNumber(a, order, threshold) {\n // verify order\n if (!(0, _number.isInteger)(order) || order < 0 || order > 3) {\n throw new Error('Symbolic Ordering and Analysis order must be an integer number in the interval [0, 3]');\n } // verify threshold\n\n\n if (threshold < 0 || threshold > 1) {\n throw new Error('Partial pivoting threshold must be a number from 0 to 1');\n } // perform symbolic ordering and analysis\n\n\n var s = csSqr(order, a, false); // perform lu decomposition\n\n var f = csLu(a, s, threshold); // return decomposition\n\n return {\n L: f.L,\n U: f.U,\n p: f.pinv,\n q: s.q,\n toString: function toString() {\n return 'L: ' + this.L.toString() + '\\nU: ' + this.U.toString() + '\\np: ' + this.p.toString() + (this.q ? '\\nq: ' + this.q.toString() : '') + '\\n';\n }\n };\n }\n });\n});\nexports.createSlu = createSlu;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDerivative = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'derivative';\nvar dependencies = ['typed', 'config', 'parse', 'simplify', 'equal', 'isZero', 'numeric', 'ConstantNode', 'FunctionNode', 'OperatorNode', 'ParenthesisNode', 'SymbolNode'];\nvar createDerivative = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n parse = _ref.parse,\n simplify = _ref.simplify,\n equal = _ref.equal,\n isZero = _ref.isZero,\n numeric = _ref.numeric,\n ConstantNode = _ref.ConstantNode,\n FunctionNode = _ref.FunctionNode,\n OperatorNode = _ref.OperatorNode,\n ParenthesisNode = _ref.ParenthesisNode,\n SymbolNode = _ref.SymbolNode;\n\n /**\n * Takes the derivative of an expression expressed in parser Nodes.\n * The derivative will be taken over the supplied variable in the\n * second parameter. If there are multiple variables in the expression,\n * it will return a partial derivative.\n *\n * This uses rules of differentiation which can be found here:\n *\n * - [Differentiation rules (Wikipedia)](https://en.wikipedia.org/wiki/Differentiation_rules)\n *\n * Syntax:\n *\n * derivative(expr, variable)\n * derivative(expr, variable, options)\n *\n * Examples:\n *\n * math.derivative('x^2', 'x') // Node {2 * x}\n * math.derivative('x^2', 'x', {simplify: false}) // Node {2 * 1 * x ^ (2 - 1)\n * math.derivative('sin(2x)', 'x')) // Node {2 * cos(2 * x)}\n * math.derivative('2*x', 'x').evaluate() // number 2\n * math.derivative('x^2', 'x').evaluate({x: 4}) // number 8\n * const f = math.parse('x^2')\n * const x = math.parse('x')\n * math.derivative(f, x) // Node {2 * x}\n *\n * See also:\n *\n * simplify, parse, evaluate\n *\n * @param {Node | string} expr The expression to differentiate\n * @param {SymbolNode | string} variable The variable over which to differentiate\n * @param {{simplify: boolean}} [options]\n * There is one option available, `simplify`, which\n * is true by default. When false, output will not\n * be simplified.\n * @return {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} The derivative of `expr`\n */\n var derivative = typed('derivative', {\n 'Node, SymbolNode, Object': function NodeSymbolNodeObject(expr, variable, options) {\n var constNodes = {};\n constTag(constNodes, expr, variable.name);\n\n var res = _derivative(expr, constNodes);\n\n return options.simplify ? simplify(res) : res;\n },\n 'Node, SymbolNode': function NodeSymbolNode(expr, variable) {\n return this(expr, variable, {\n simplify: true\n });\n },\n 'string, SymbolNode': function stringSymbolNode(expr, variable) {\n return this(parse(expr), variable);\n },\n 'string, SymbolNode, Object': function stringSymbolNodeObject(expr, variable, options) {\n return this(parse(expr), variable, options);\n },\n 'string, string': function stringString(expr, variable) {\n return this(parse(expr), parse(variable));\n },\n 'string, string, Object': function stringStringObject(expr, variable, options) {\n return this(parse(expr), parse(variable), options);\n },\n 'Node, string': function NodeString(expr, variable) {\n return this(expr, parse(variable));\n },\n 'Node, string, Object': function NodeStringObject(expr, variable, options) {\n return this(expr, parse(variable), options);\n } // TODO: replace the 8 signatures above with 4 as soon as typed-function supports optional arguments\n\n /* TODO: implement and test syntax with order of derivatives -> implement as an option {order: number}\n 'Node, SymbolNode, ConstantNode': function (expr, variable, {order}) {\n let res = expr\n for (let i = 0; i < order; i++) {\n let constNodes = {}\n constTag(constNodes, expr, variable.name)\n res = _derivative(res, constNodes)\n }\n return res\n }\n */\n\n });\n derivative._simplify = true;\n\n derivative.toTex = function (deriv) {\n return _derivTex.apply(null, deriv.args);\n }; // FIXME: move the toTex method of derivative to latex.js. Difficulty is that it relies on parse.\n // NOTE: the optional \"order\" parameter here is currently unused\n\n\n var _derivTex = typed('_derivTex', {\n 'Node, SymbolNode': function NodeSymbolNode(expr, x) {\n if ((0, _is.isConstantNode)(expr) && (0, _is.typeOf)(expr.value) === 'string') {\n return _derivTex(parse(expr.value).toString(), x.toString(), 1);\n } else {\n return _derivTex(expr.toTex(), x.toString(), 1);\n }\n },\n 'Node, ConstantNode': function NodeConstantNode(expr, x) {\n if ((0, _is.typeOf)(x.value) === 'string') {\n return _derivTex(expr, parse(x.value));\n } else {\n throw new Error(\"The second parameter to 'derivative' is a non-string constant\");\n }\n },\n 'Node, SymbolNode, ConstantNode': function NodeSymbolNodeConstantNode(expr, x, order) {\n return _derivTex(expr.toString(), x.name, order.value);\n },\n 'string, string, number': function stringStringNumber(expr, x, order) {\n var d;\n\n if (order === 1) {\n d = '{d\\\\over d' + x + '}';\n } else {\n d = '{d^{' + order + '}\\\\over d' + x + '^{' + order + '}}';\n }\n\n return d + \"\\\\left[\".concat(expr, \"\\\\right]\");\n }\n });\n /**\n * Does a depth-first search on the expression tree to identify what Nodes\n * are constants (e.g. 2 + 2), and stores the ones that are constants in\n * constNodes. Classification is done as follows:\n *\n * 1. ConstantNodes are constants.\n * 2. If there exists a SymbolNode, of which we are differentiating over,\n * in the subtree it is not constant.\n *\n * @param {Object} constNodes Holds the nodes that are constant\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node\n * @param {string} varName Variable that we are differentiating\n * @return {boolean} if node is constant\n */\n // TODO: can we rewrite constTag into a pure function?\n\n\n var constTag = typed('constTag', {\n 'Object, ConstantNode, string': function ObjectConstantNodeString(constNodes, node) {\n constNodes[node] = true;\n return true;\n },\n 'Object, SymbolNode, string': function ObjectSymbolNodeString(constNodes, node, varName) {\n // Treat other variables like constants. For reasoning, see:\n // https://en.wikipedia.org/wiki/Partial_derivative\n if (node.name !== varName) {\n constNodes[node] = true;\n return true;\n }\n\n return false;\n },\n 'Object, ParenthesisNode, string': function ObjectParenthesisNodeString(constNodes, node, varName) {\n return constTag(constNodes, node.content, varName);\n },\n 'Object, FunctionAssignmentNode, string': function ObjectFunctionAssignmentNodeString(constNodes, node, varName) {\n if (node.params.indexOf(varName) === -1) {\n constNodes[node] = true;\n return true;\n }\n\n return constTag(constNodes, node.expr, varName);\n },\n 'Object, FunctionNode | OperatorNode, string': function ObjectFunctionNodeOperatorNodeString(constNodes, node, varName) {\n if (node.args.length > 0) {\n var isConst = constTag(constNodes, node.args[0], varName);\n\n for (var i = 1; i < node.args.length; ++i) {\n isConst = constTag(constNodes, node.args[i], varName) && isConst;\n }\n\n if (isConst) {\n constNodes[node] = true;\n return true;\n }\n }\n\n return false;\n }\n });\n /**\n * Applies differentiation rules.\n *\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node\n * @param {Object} constNodes Holds the nodes that are constant\n * @return {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} The derivative of `expr`\n */\n\n var _derivative = typed('_derivative', {\n 'ConstantNode, Object': function ConstantNodeObject(node) {\n return createConstantNode(0);\n },\n 'SymbolNode, Object': function SymbolNodeObject(node, constNodes) {\n if (constNodes[node] !== undefined) {\n return createConstantNode(0);\n }\n\n return createConstantNode(1);\n },\n 'ParenthesisNode, Object': function ParenthesisNodeObject(node, constNodes) {\n return new ParenthesisNode(_derivative(node.content, constNodes));\n },\n 'FunctionAssignmentNode, Object': function FunctionAssignmentNodeObject(node, constNodes) {\n if (constNodes[node] !== undefined) {\n return createConstantNode(0);\n }\n\n return _derivative(node.expr, constNodes);\n },\n 'FunctionNode, Object': function FunctionNodeObject(node, constNodes) {\n if (node.args.length !== 1) {\n funcArgsCheck(node);\n }\n\n if (constNodes[node] !== undefined) {\n return createConstantNode(0);\n }\n\n var arg0 = node.args[0];\n var arg1;\n var div = false; // is output a fraction?\n\n var negative = false; // is output negative?\n\n var funcDerivative;\n\n switch (node.name) {\n case 'cbrt':\n // d/dx(cbrt(x)) = 1 / (3x^(2/3))\n div = true;\n funcDerivative = new OperatorNode('*', 'multiply', [createConstantNode(3), new OperatorNode('^', 'pow', [arg0, new OperatorNode('/', 'divide', [createConstantNode(2), createConstantNode(3)])])]);\n break;\n\n case 'sqrt':\n case 'nthRoot':\n // d/dx(sqrt(x)) = 1 / (2*sqrt(x))\n if (node.args.length === 1) {\n div = true;\n funcDerivative = new OperatorNode('*', 'multiply', [createConstantNode(2), new FunctionNode('sqrt', [arg0])]);\n } else if (node.args.length === 2) {\n // Rearrange from nthRoot(x, a) -> x^(1/a)\n arg1 = new OperatorNode('/', 'divide', [createConstantNode(1), node.args[1]]); // Is a variable?\n\n constNodes[arg1] = constNodes[node.args[1]];\n return _derivative(new OperatorNode('^', 'pow', [arg0, arg1]), constNodes);\n }\n\n break;\n\n case 'log10':\n arg1 = createConstantNode(10);\n\n /* fall through! */\n\n case 'log':\n if (!arg1 && node.args.length === 1) {\n // d/dx(log(x)) = 1 / x\n funcDerivative = arg0.clone();\n div = true;\n } else if (node.args.length === 1 && arg1 || node.args.length === 2 && constNodes[node.args[1]] !== undefined) {\n // d/dx(log(x, c)) = 1 / (x*ln(c))\n funcDerivative = new OperatorNode('*', 'multiply', [arg0.clone(), new FunctionNode('log', [arg1 || node.args[1]])]);\n div = true;\n } else if (node.args.length === 2) {\n // d/dx(log(f(x), g(x))) = d/dx(log(f(x)) / log(g(x)))\n return _derivative(new OperatorNode('/', 'divide', [new FunctionNode('log', [arg0]), new FunctionNode('log', [node.args[1]])]), constNodes);\n }\n\n break;\n\n case 'pow':\n constNodes[arg1] = constNodes[node.args[1]]; // Pass to pow operator node parser\n\n return _derivative(new OperatorNode('^', 'pow', [arg0, node.args[1]]), constNodes);\n\n case 'exp':\n // d/dx(e^x) = e^x\n funcDerivative = new FunctionNode('exp', [arg0.clone()]);\n break;\n\n case 'sin':\n // d/dx(sin(x)) = cos(x)\n funcDerivative = new FunctionNode('cos', [arg0.clone()]);\n break;\n\n case 'cos':\n // d/dx(cos(x)) = -sin(x)\n funcDerivative = new OperatorNode('-', 'unaryMinus', [new FunctionNode('sin', [arg0.clone()])]);\n break;\n\n case 'tan':\n // d/dx(tan(x)) = sec(x)^2\n funcDerivative = new OperatorNode('^', 'pow', [new FunctionNode('sec', [arg0.clone()]), createConstantNode(2)]);\n break;\n\n case 'sec':\n // d/dx(sec(x)) = sec(x)tan(x)\n funcDerivative = new OperatorNode('*', 'multiply', [node, new FunctionNode('tan', [arg0.clone()])]);\n break;\n\n case 'csc':\n // d/dx(csc(x)) = -csc(x)cot(x)\n negative = true;\n funcDerivative = new OperatorNode('*', 'multiply', [node, new FunctionNode('cot', [arg0.clone()])]);\n break;\n\n case 'cot':\n // d/dx(cot(x)) = -csc(x)^2\n negative = true;\n funcDerivative = new OperatorNode('^', 'pow', [new FunctionNode('csc', [arg0.clone()]), createConstantNode(2)]);\n break;\n\n case 'asin':\n // d/dx(asin(x)) = 1 / sqrt(1 - x^2)\n div = true;\n funcDerivative = new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])])]);\n break;\n\n case 'acos':\n // d/dx(acos(x)) = -1 / sqrt(1 - x^2)\n div = true;\n negative = true;\n funcDerivative = new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])])]);\n break;\n\n case 'atan':\n // d/dx(atan(x)) = 1 / (x^2 + 1)\n div = true;\n funcDerivative = new OperatorNode('+', 'add', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)]);\n break;\n\n case 'asec':\n // d/dx(asec(x)) = 1 / (|x|*sqrt(x^2 - 1))\n div = true;\n funcDerivative = new OperatorNode('*', 'multiply', [new FunctionNode('abs', [arg0.clone()]), new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])])]);\n break;\n\n case 'acsc':\n // d/dx(acsc(x)) = -1 / (|x|*sqrt(x^2 - 1))\n div = true;\n negative = true;\n funcDerivative = new OperatorNode('*', 'multiply', [new FunctionNode('abs', [arg0.clone()]), new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])])]);\n break;\n\n case 'acot':\n // d/dx(acot(x)) = -1 / (x^2 + 1)\n div = true;\n negative = true;\n funcDerivative = new OperatorNode('+', 'add', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)]);\n break;\n\n case 'sinh':\n // d/dx(sinh(x)) = cosh(x)\n funcDerivative = new FunctionNode('cosh', [arg0.clone()]);\n break;\n\n case 'cosh':\n // d/dx(cosh(x)) = sinh(x)\n funcDerivative = new FunctionNode('sinh', [arg0.clone()]);\n break;\n\n case 'tanh':\n // d/dx(tanh(x)) = sech(x)^2\n funcDerivative = new OperatorNode('^', 'pow', [new FunctionNode('sech', [arg0.clone()]), createConstantNode(2)]);\n break;\n\n case 'sech':\n // d/dx(sech(x)) = -sech(x)tanh(x)\n negative = true;\n funcDerivative = new OperatorNode('*', 'multiply', [node, new FunctionNode('tanh', [arg0.clone()])]);\n break;\n\n case 'csch':\n // d/dx(csch(x)) = -csch(x)coth(x)\n negative = true;\n funcDerivative = new OperatorNode('*', 'multiply', [node, new FunctionNode('coth', [arg0.clone()])]);\n break;\n\n case 'coth':\n // d/dx(coth(x)) = -csch(x)^2\n negative = true;\n funcDerivative = new OperatorNode('^', 'pow', [new FunctionNode('csch', [arg0.clone()]), createConstantNode(2)]);\n break;\n\n case 'asinh':\n // d/dx(asinh(x)) = 1 / sqrt(x^2 + 1)\n div = true;\n funcDerivative = new FunctionNode('sqrt', [new OperatorNode('+', 'add', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])]);\n break;\n\n case 'acosh':\n // d/dx(acosh(x)) = 1 / sqrt(x^2 - 1); XXX potentially only for x >= 1 (the real spectrum)\n div = true;\n funcDerivative = new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])]);\n break;\n\n case 'atanh':\n // d/dx(atanh(x)) = 1 / (1 - x^2)\n div = true;\n funcDerivative = new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])]);\n break;\n\n case 'asech':\n // d/dx(asech(x)) = -1 / (x*sqrt(1 - x^2))\n div = true;\n negative = true;\n funcDerivative = new OperatorNode('*', 'multiply', [arg0.clone(), new FunctionNode('sqrt', [new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])])])]);\n break;\n\n case 'acsch':\n // d/dx(acsch(x)) = -1 / (|x|*sqrt(x^2 + 1))\n div = true;\n negative = true;\n funcDerivative = new OperatorNode('*', 'multiply', [new FunctionNode('abs', [arg0.clone()]), new FunctionNode('sqrt', [new OperatorNode('+', 'add', [new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)]), createConstantNode(1)])])]);\n break;\n\n case 'acoth':\n // d/dx(acoth(x)) = -1 / (1 - x^2)\n div = true;\n negative = true;\n funcDerivative = new OperatorNode('-', 'subtract', [createConstantNode(1), new OperatorNode('^', 'pow', [arg0.clone(), createConstantNode(2)])]);\n break;\n\n case 'abs':\n // d/dx(abs(x)) = abs(x)/x\n funcDerivative = new OperatorNode('/', 'divide', [new FunctionNode(new SymbolNode('abs'), [arg0.clone()]), arg0.clone()]);\n break;\n\n case 'gamma': // Needs digamma function, d/dx(gamma(x)) = gamma(x)digamma(x)\n\n default:\n throw new Error('Function \"' + node.name + '\" is not supported by derivative, or a wrong number of arguments is passed');\n }\n\n var op, func;\n\n if (div) {\n op = '/';\n func = 'divide';\n } else {\n op = '*';\n func = 'multiply';\n }\n /* Apply chain rule to all functions:\n F(x) = f(g(x))\n F'(x) = g'(x)*f'(g(x)) */\n\n\n var chainDerivative = _derivative(arg0, constNodes);\n\n if (negative) {\n chainDerivative = new OperatorNode('-', 'unaryMinus', [chainDerivative]);\n }\n\n return new OperatorNode(op, func, [chainDerivative, funcDerivative]);\n },\n 'OperatorNode, Object': function OperatorNodeObject(node, constNodes) {\n if (constNodes[node] !== undefined) {\n return createConstantNode(0);\n }\n\n if (node.op === '+') {\n // d/dx(sum(f(x)) = sum(f'(x))\n return new OperatorNode(node.op, node.fn, node.args.map(function (arg) {\n return _derivative(arg, constNodes);\n }));\n }\n\n if (node.op === '-') {\n // d/dx(+/-f(x)) = +/-f'(x)\n if (node.isUnary()) {\n return new OperatorNode(node.op, node.fn, [_derivative(node.args[0], constNodes)]);\n } // Linearity of differentiation, d/dx(f(x) +/- g(x)) = f'(x) +/- g'(x)\n\n\n if (node.isBinary()) {\n return new OperatorNode(node.op, node.fn, [_derivative(node.args[0], constNodes), _derivative(node.args[1], constNodes)]);\n }\n }\n\n if (node.op === '*') {\n // d/dx(c*f(x)) = c*f'(x)\n var constantTerms = node.args.filter(function (arg) {\n return constNodes[arg] !== undefined;\n });\n\n if (constantTerms.length > 0) {\n var nonConstantTerms = node.args.filter(function (arg) {\n return constNodes[arg] === undefined;\n });\n var nonConstantNode = nonConstantTerms.length === 1 ? nonConstantTerms[0] : new OperatorNode('*', 'multiply', nonConstantTerms);\n var newArgs = constantTerms.concat(_derivative(nonConstantNode, constNodes));\n return new OperatorNode('*', 'multiply', newArgs);\n } // Product Rule, d/dx(f(x)*g(x)) = f'(x)*g(x) + f(x)*g'(x)\n\n\n return new OperatorNode('+', 'add', node.args.map(function (argOuter) {\n return new OperatorNode('*', 'multiply', node.args.map(function (argInner) {\n return argInner === argOuter ? _derivative(argInner, constNodes) : argInner.clone();\n }));\n }));\n }\n\n if (node.op === '/' && node.isBinary()) {\n var arg0 = node.args[0];\n var arg1 = node.args[1]; // d/dx(f(x) / c) = f'(x) / c\n\n if (constNodes[arg1] !== undefined) {\n return new OperatorNode('/', 'divide', [_derivative(arg0, constNodes), arg1]);\n } // Reciprocal Rule, d/dx(c / f(x)) = -c(f'(x)/f(x)^2)\n\n\n if (constNodes[arg0] !== undefined) {\n return new OperatorNode('*', 'multiply', [new OperatorNode('-', 'unaryMinus', [arg0]), new OperatorNode('/', 'divide', [_derivative(arg1, constNodes), new OperatorNode('^', 'pow', [arg1.clone(), createConstantNode(2)])])]);\n } // Quotient rule, d/dx(f(x) / g(x)) = (f'(x)g(x) - f(x)g'(x)) / g(x)^2\n\n\n return new OperatorNode('/', 'divide', [new OperatorNode('-', 'subtract', [new OperatorNode('*', 'multiply', [_derivative(arg0, constNodes), arg1.clone()]), new OperatorNode('*', 'multiply', [arg0.clone(), _derivative(arg1, constNodes)])]), new OperatorNode('^', 'pow', [arg1.clone(), createConstantNode(2)])]);\n }\n\n if (node.op === '^' && node.isBinary()) {\n var _arg = node.args[0];\n var _arg2 = node.args[1];\n\n if (constNodes[_arg] !== undefined) {\n // If is secretly constant; 0^f(x) = 1 (in JS), 1^f(x) = 1\n if ((0, _is.isConstantNode)(_arg) && (isZero(_arg.value) || equal(_arg.value, 1))) {\n return createConstantNode(0);\n } // d/dx(c^f(x)) = c^f(x)*ln(c)*f'(x)\n\n\n return new OperatorNode('*', 'multiply', [node, new OperatorNode('*', 'multiply', [new FunctionNode('log', [_arg.clone()]), _derivative(_arg2.clone(), constNodes)])]);\n }\n\n if (constNodes[_arg2] !== undefined) {\n if ((0, _is.isConstantNode)(_arg2)) {\n // If is secretly constant; f(x)^0 = 1 -> d/dx(1) = 0\n if (isZero(_arg2.value)) {\n return createConstantNode(0);\n } // Ignore exponent; f(x)^1 = f(x)\n\n\n if (equal(_arg2.value, 1)) {\n return _derivative(_arg, constNodes);\n }\n } // Elementary Power Rule, d/dx(f(x)^c) = c*f'(x)*f(x)^(c-1)\n\n\n var powMinusOne = new OperatorNode('^', 'pow', [_arg.clone(), new OperatorNode('-', 'subtract', [_arg2, createConstantNode(1)])]);\n return new OperatorNode('*', 'multiply', [_arg2.clone(), new OperatorNode('*', 'multiply', [_derivative(_arg, constNodes), powMinusOne])]);\n } // Functional Power Rule, d/dx(f^g) = f^g*[f'*(g/f) + g'ln(f)]\n\n\n return new OperatorNode('*', 'multiply', [new OperatorNode('^', 'pow', [_arg.clone(), _arg2.clone()]), new OperatorNode('+', 'add', [new OperatorNode('*', 'multiply', [_derivative(_arg, constNodes), new OperatorNode('/', 'divide', [_arg2.clone(), _arg.clone()])]), new OperatorNode('*', 'multiply', [_derivative(_arg2, constNodes), new FunctionNode('log', [_arg.clone()])])])]);\n }\n\n throw new Error('Operator \"' + node.op + '\" is not supported by derivative, or a wrong number of arguments is passed');\n }\n });\n /**\n * Ensures the number of arguments for a function are correct,\n * and will throw an error otherwise.\n *\n * @param {FunctionNode} node\n */\n\n\n function funcArgsCheck(node) {\n // TODO add min, max etc\n if ((node.name === 'log' || node.name === 'nthRoot' || node.name === 'pow') && node.args.length === 2) {\n return;\n } // There should be an incorrect number of arguments if we reach here\n // Change all args to constants to avoid unidentified\n // symbol error when compiling function\n\n\n for (var i = 0; i < node.args.length; ++i) {\n node.args[i] = createConstantNode(0);\n }\n\n node.compile().evaluate();\n throw new Error('Expected TypeError, but none found');\n }\n /**\n * Helper function to create a constant node with a specific type\n * (number, BigNumber, Fraction)\n * @param {number} value\n * @param {string} [valueType]\n * @return {ConstantNode}\n */\n\n\n function createConstantNode(value, valueType) {\n return new ConstantNode(numeric(value, valueType || config.number));\n }\n\n return derivative;\n});\nexports.createDerivative = createDerivative;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLeafCount = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'leafCount';\nvar dependencies = ['parse', 'typed'];\nvar createLeafCount = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var parse = _ref.parse,\n typed = _ref.typed;\n\n // This does the real work, but we don't have to recurse through\n // a typed call if we separate it out\n function countLeaves(node) {\n var count = 0;\n node.forEach(function (n) {\n count += countLeaves(n);\n });\n return count || 1;\n }\n /**\n * Gives the number of \"leaf nodes\" in the parse tree of the given expression\n * A leaf node is one that has no subexpressions, essentially either a\n * symbol or a constant. Note that `5!` has just one leaf, the '5'; the\n * unary factorial operator does not add a leaf. On the other hand,\n * function symbols do add leaves, so `sin(x)/cos(x)` has four leaves.\n *\n * The `simplify()` function should generally not increase the `leafCount()`\n * of an expression, although currently there is no guarantee that it never\n * does so. In many cases, `simplify()` reduces the leaf count.\n *\n * Syntax:\n *\n * leafCount(expr)\n *\n * Examples:\n *\n * math.leafCount('x') // 1\n * math.leafCount(math.parse('a*d-b*c')) // 4\n * math.leafCount('[a,b;c,d][0,1]') // 6\n *\n * See also:\n *\n * simplify\n *\n * @param {Node|string} expr The expression to count the leaves of\n *\n * @return {number} The number of leaves of `expr`\n *\n */\n\n\n return typed(name, {\n string: function string(expr) {\n return this(parse(expr));\n },\n Node: function Node(expr) {\n return countLeaves(expr);\n }\n });\n});\nexports.createLeafCount = createLeafCount;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRationalize = void 0;\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _simplifyConstant = require(\"./simplify/simplifyConstant.js\");\n\nvar name = 'rationalize';\nvar dependencies = ['config', 'typed', 'equal', 'isZero', 'add', 'subtract', 'multiply', 'divide', 'pow', 'parse', 'simplifyCore', 'simplify', '?bignumber', '?fraction', 'mathWithTransform', 'matrix', 'AccessorNode', 'ArrayNode', 'ConstantNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'SymbolNode', 'ParenthesisNode'];\nvar createRationalize = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var config = _ref.config,\n typed = _ref.typed,\n equal = _ref.equal,\n isZero = _ref.isZero,\n add = _ref.add,\n subtract = _ref.subtract,\n multiply = _ref.multiply,\n divide = _ref.divide,\n pow = _ref.pow,\n parse = _ref.parse,\n simplifyCore = _ref.simplifyCore,\n simplify = _ref.simplify,\n fraction = _ref.fraction,\n bignumber = _ref.bignumber,\n mathWithTransform = _ref.mathWithTransform,\n matrix = _ref.matrix,\n AccessorNode = _ref.AccessorNode,\n ArrayNode = _ref.ArrayNode,\n ConstantNode = _ref.ConstantNode,\n FunctionNode = _ref.FunctionNode,\n IndexNode = _ref.IndexNode,\n ObjectNode = _ref.ObjectNode,\n OperatorNode = _ref.OperatorNode,\n SymbolNode = _ref.SymbolNode,\n ParenthesisNode = _ref.ParenthesisNode;\n var simplifyConstant = (0, _simplifyConstant.createSimplifyConstant)({\n typed: typed,\n config: config,\n mathWithTransform: mathWithTransform,\n matrix: matrix,\n fraction: fraction,\n bignumber: bignumber,\n AccessorNode: AccessorNode,\n ArrayNode: ArrayNode,\n ConstantNode: ConstantNode,\n FunctionNode: FunctionNode,\n IndexNode: IndexNode,\n ObjectNode: ObjectNode,\n OperatorNode: OperatorNode,\n SymbolNode: SymbolNode\n });\n /**\n * Transform a rationalizable expression in a rational fraction.\n * If rational fraction is one variable polynomial then converts\n * the numerator and denominator in canonical form, with decreasing\n * exponents, returning the coefficients of numerator.\n *\n * Syntax:\n *\n * rationalize(expr)\n * rationalize(expr, detailed)\n * rationalize(expr, scope)\n * rationalize(expr, scope, detailed)\n *\n * Examples:\n *\n * math.rationalize('sin(x)+y')\n * // Error: There is an unsolved function call\n * math.rationalize('2x/y - y/(x+1)')\n * // (2*x^2-y^2+2*x)/(x*y+y)\n * math.rationalize('(2x+1)^6')\n * // 64*x^6+192*x^5+240*x^4+160*x^3+60*x^2+12*x+1\n * math.rationalize('2x/( (2x-1) / (3x+2) ) - 5x/ ( (3x+4) / (2x^2-5) ) + 3')\n * // -20*x^4+28*x^3+104*x^2+6*x-12)/(6*x^2+5*x-4)\n * math.rationalize('x/(1-x)/(x-2)/(x-3)/(x-4) + 2x/ ( (1-2x)/(2-3x) )/ ((3-4x)/(4-5x) )') =\n * // (-30*x^7+344*x^6-1506*x^5+3200*x^4-3472*x^3+1846*x^2-381*x)/\n * // (-8*x^6+90*x^5-383*x^4+780*x^3-797*x^2+390*x-72)\n *\n * math.rationalize('x+x+x+y',{y:1}) // 3*x+1\n * math.rationalize('x+x+x+y',{}) // 3*x+y\n *\n * const ret = math.rationalize('x+x+x+y',{},true)\n * // ret.expression=3*x+y, ret.variables = [\"x\",\"y\"]\n * const ret = math.rationalize('-2+5x^2',{},true)\n * // ret.expression=5*x^2-2, ret.variables = [\"x\"], ret.coefficients=[-2,0,5]\n *\n * See also:\n *\n * simplify\n *\n * @param {Node|string} expr The expression to check if is a polynomial expression\n * @param {Object|boolean} optional scope of expression or true for already evaluated rational expression at input\n * @param {Boolean} detailed optional True if return an object, false if return expression node (default)\n *\n * @return {Object | Node} The rational polynomial of `expr` or an object\n * `{expression, numerator, denominator, variables, coefficients}`, where\n * `expression` is a `Node` with the node simplified expression,\n * `numerator` is a `Node` with the simplified numerator of expression,\n * `denominator` is a `Node` or `boolean` with the simplified denominator or `false` (if there is no denominator),\n * `variables` is an array with variable names,\n * and `coefficients` is an array with coefficients of numerator sorted by increased exponent\n * {Expression Node} node simplified expression\n *\n */\n\n return typed(name, {\n string: function string(expr) {\n return this(parse(expr), {}, false);\n },\n 'string, boolean': function stringBoolean(expr, detailed) {\n return this(parse(expr), {}, detailed);\n },\n 'string, Object': function stringObject(expr, scope) {\n return this(parse(expr), scope, false);\n },\n 'string, Object, boolean': function stringObjectBoolean(expr, scope, detailed) {\n return this(parse(expr), scope, detailed);\n },\n Node: function Node(expr) {\n return this(expr, {}, false);\n },\n 'Node, boolean': function NodeBoolean(expr, detailed) {\n return this(expr, {}, detailed);\n },\n 'Node, Object': function NodeObject(expr, scope) {\n return this(expr, scope, false);\n },\n 'Node, Object, boolean': function NodeObjectBoolean(expr, scope, detailed) {\n var setRules = rulesRationalize(); // Rules for change polynomial in near canonical form\n\n var polyRet = polynomial(expr, scope, true, setRules.firstRules); // Check if expression is a rationalizable polynomial\n\n var nVars = polyRet.variables.length;\n var noExactFractions = {\n exactFractions: false\n };\n var withExactFractions = {\n exactFractions: true\n };\n expr = polyRet.expression;\n\n if (nVars >= 1) {\n // If expression in not a constant\n expr = expandPower(expr); // First expand power of polynomials (cannot be made from rules!)\n\n var sBefore; // Previous expression\n\n var rules;\n var eDistrDiv = true;\n var redoInic = false; // Apply the initial rules, including succ div rules:\n\n expr = simplify(expr, setRules.firstRules, {}, noExactFractions);\n var s;\n\n while (true) {\n // Alternate applying successive division rules and distr.div.rules\n // until there are no more changes:\n rules = eDistrDiv ? setRules.distrDivRules : setRules.sucDivRules;\n expr = simplify(expr, rules, {}, withExactFractions);\n eDistrDiv = !eDistrDiv; // Swap between Distr.Div and Succ. Div. Rules\n\n s = expr.toString();\n\n if (s === sBefore) {\n break; // No changes : end of the loop\n }\n\n redoInic = true;\n sBefore = s;\n }\n\n if (redoInic) {\n // Apply first rules again without succ div rules (if there are changes)\n expr = simplify(expr, setRules.firstRulesAgain, {}, noExactFractions);\n } // Apply final rules:\n\n\n expr = simplify(expr, setRules.finalRules, {}, noExactFractions);\n } // NVars >= 1\n\n\n var coefficients = [];\n var retRationalize = {};\n\n if (expr.type === 'OperatorNode' && expr.isBinary() && expr.op === '/') {\n // Separate numerator from denominator\n if (nVars === 1) {\n expr.args[0] = polyToCanonical(expr.args[0], coefficients);\n expr.args[1] = polyToCanonical(expr.args[1]);\n }\n\n if (detailed) {\n retRationalize.numerator = expr.args[0];\n retRationalize.denominator = expr.args[1];\n }\n } else {\n if (nVars === 1) {\n expr = polyToCanonical(expr, coefficients);\n }\n\n if (detailed) {\n retRationalize.numerator = expr;\n retRationalize.denominator = null;\n }\n } // nVars\n\n\n if (!detailed) return expr;\n retRationalize.coefficients = coefficients;\n retRationalize.variables = polyRet.variables;\n retRationalize.expression = expr;\n return retRationalize;\n } // ^^^^^^^ end of rationalize ^^^^^^^^\n\n }); // end of typed rationalize\n\n /**\n * Function to simplify an expression using an optional scope and\n * return it if the expression is a polynomial expression, i.e.\n * an expression with one or more variables and the operators\n * +, -, *, and ^, where the exponent can only be a positive integer.\n *\n * Syntax:\n *\n * polynomial(expr,scope,extended, rules)\n *\n * @param {Node | string} expr The expression to simplify and check if is polynomial expression\n * @param {object} scope Optional scope for expression simplification\n * @param {boolean} extended Optional. Default is false. When true allows divide operator.\n * @param {array} rules Optional. Default is no rule.\n *\n *\n * @return {Object}\n * {Object} node: node simplified expression\n * {Array} variables: variable names\n */\n\n function polynomial(expr, scope, extended, rules) {\n var variables = [];\n var node = simplify(expr, rules, scope, {\n exactFractions: false\n }); // Resolves any variables and functions with all defined parameters\n\n extended = !!extended;\n var oper = '+-*' + (extended ? '/' : '');\n recPoly(node);\n var retFunc = {};\n retFunc.expression = node;\n retFunc.variables = variables;\n return retFunc; // -------------------------------------------------------------------------------------------------------\n\n /**\n * Function to simplify an expression using an optional scope and\n * return it if the expression is a polynomial expression, i.e.\n * an expression with one or more variables and the operators\n * +, -, *, and ^, where the exponent can only be a positive integer.\n *\n * Syntax:\n *\n * recPoly(node)\n *\n *\n * @param {Node} node The current sub tree expression in recursion\n *\n * @return nothing, throw an exception if error\n */\n\n function recPoly(node) {\n var tp = node.type; // node type\n\n if (tp === 'FunctionNode') {\n // No function call in polynomial expression\n throw new Error('There is an unsolved function call');\n } else if (tp === 'OperatorNode') {\n if (node.op === '^') {\n // TODO: handle negative exponents like in '1/x^(-2)'\n if (node.args[1].type !== 'ConstantNode' || !(0, _number.isInteger)(parseFloat(node.args[1].value))) {\n throw new Error('There is a non-integer exponent');\n } else {\n recPoly(node.args[0]);\n }\n } else {\n if (oper.indexOf(node.op) === -1) {\n throw new Error('Operator ' + node.op + ' invalid in polynomial expression');\n }\n\n for (var i = 0; i < node.args.length; i++) {\n recPoly(node.args[i]);\n }\n } // type of operator\n\n } else if (tp === 'SymbolNode') {\n var _name = node.name; // variable name\n\n var pos = variables.indexOf(_name);\n\n if (pos === -1) {\n // new variable in expression\n variables.push(_name);\n }\n } else if (tp === 'ParenthesisNode') {\n recPoly(node.content);\n } else if (tp !== 'ConstantNode') {\n throw new Error('type ' + tp + ' is not allowed in polynomial expression');\n }\n } // end of recPoly\n\n } // end of polynomial\n // ---------------------------------------------------------------------------------------\n\n /**\n * Return a rule set to rationalize an polynomial expression in rationalize\n *\n * Syntax:\n *\n * rulesRationalize()\n *\n * @return {array} rule set to rationalize an polynomial expression\n */\n\n\n function rulesRationalize() {\n var oldRules = [simplifyCore, // sCore\n {\n l: 'n+n',\n r: '2*n'\n }, {\n l: 'n+-n',\n r: '0'\n }, simplifyConstant, // sConstant\n {\n l: 'n*(n1^-1)',\n r: 'n/n1'\n }, {\n l: 'n*n1^-n2',\n r: 'n/n1^n2'\n }, {\n l: 'n1^-1',\n r: '1/n1'\n }, {\n l: 'n*(n1/n2)',\n r: '(n*n1)/n2'\n }, {\n l: '1*n',\n r: 'n'\n }];\n var rulesFirst = [{\n l: '(-n1)/(-n2)',\n r: 'n1/n2'\n }, // Unary division\n {\n l: '(-n1)*(-n2)',\n r: 'n1*n2'\n }, // Unary multiplication\n {\n l: 'n1--n2',\n r: 'n1+n2'\n }, // '--' elimination\n {\n l: 'n1-n2',\n r: 'n1+(-n2)'\n }, // Subtraction turn into add with un�ry minus\n {\n l: '(n1+n2)*n3',\n r: '(n1*n3 + n2*n3)'\n }, // Distributive 1\n {\n l: 'n1*(n2+n3)',\n r: '(n1*n2+n1*n3)'\n }, // Distributive 2\n {\n l: 'c1*n + c2*n',\n r: '(c1+c2)*n'\n }, // Joining constants\n {\n l: 'c1*n + n',\n r: '(c1+1)*n'\n }, // Joining constants\n {\n l: 'c1*n - c2*n',\n r: '(c1-c2)*n'\n }, // Joining constants\n {\n l: 'c1*n - n',\n r: '(c1-1)*n'\n }, // Joining constants\n {\n l: 'v/c',\n r: '(1/c)*v'\n }, // variable/constant (new!)\n {\n l: 'v/-c',\n r: '-(1/c)*v'\n }, // variable/constant (new!)\n {\n l: '-v*-c',\n r: 'c*v'\n }, // Inversion constant and variable 1\n {\n l: '-v*c',\n r: '-c*v'\n }, // Inversion constant and variable 2\n {\n l: 'v*-c',\n r: '-c*v'\n }, // Inversion constant and variable 3\n {\n l: 'v*c',\n r: 'c*v'\n }, // Inversion constant and variable 4\n {\n l: '-(-n1*n2)',\n r: '(n1*n2)'\n }, // Unary propagation\n {\n l: '-(n1*n2)',\n r: '(-n1*n2)'\n }, // Unary propagation\n {\n l: '-(-n1+n2)',\n r: '(n1-n2)'\n }, // Unary propagation\n {\n l: '-(n1+n2)',\n r: '(-n1-n2)'\n }, // Unary propagation\n {\n l: '(n1^n2)^n3',\n r: '(n1^(n2*n3))'\n }, // Power to Power\n {\n l: '-(-n1/n2)',\n r: '(n1/n2)'\n }, // Division and Unary\n {\n l: '-(n1/n2)',\n r: '(-n1/n2)'\n }]; // Divisao and Unary\n\n var rulesDistrDiv = [{\n l: '(n1/n2 + n3/n4)',\n r: '((n1*n4 + n3*n2)/(n2*n4))'\n }, // Sum of fractions\n {\n l: '(n1/n2 + n3)',\n r: '((n1 + n3*n2)/n2)'\n }, // Sum fraction with number 1\n {\n l: '(n1 + n2/n3)',\n r: '((n1*n3 + n2)/n3)'\n }]; // Sum fraction with number 1\n\n var rulesSucDiv = [{\n l: '(n1/(n2/n3))',\n r: '((n1*n3)/n2)'\n }, // Division simplification\n {\n l: '(n1/n2/n3)',\n r: '(n1/(n2*n3))'\n }];\n var setRules = {}; // rules set in 4 steps.\n // All rules => infinite loop\n // setRules.allRules =oldRules.concat(rulesFirst,rulesDistrDiv,rulesSucDiv)\n\n setRules.firstRules = oldRules.concat(rulesFirst, rulesSucDiv); // First rule set\n\n setRules.distrDivRules = rulesDistrDiv; // Just distr. div. rules\n\n setRules.sucDivRules = rulesSucDiv; // Jus succ. div. rules\n\n setRules.firstRulesAgain = oldRules.concat(rulesFirst); // Last rules set without succ. div.\n // Division simplification\n // Second rule set.\n // There is no aggregate expression with parentesis, but the only variable can be scattered.\n\n setRules.finalRules = [simplifyCore, // simplify.rules[0]\n {\n l: 'n*-n',\n r: '-n^2'\n }, // Joining multiply with power 1\n {\n l: 'n*n',\n r: 'n^2'\n }, // Joining multiply with power 2\n simplifyConstant, // simplify.rules[14] old 3rd index in oldRules\n {\n l: 'n*-n^n1',\n r: '-n^(n1+1)'\n }, // Joining multiply with power 3\n {\n l: 'n*n^n1',\n r: 'n^(n1+1)'\n }, // Joining multiply with power 4\n {\n l: 'n^n1*-n^n2',\n r: '-n^(n1+n2)'\n }, // Joining multiply with power 5\n {\n l: 'n^n1*n^n2',\n r: 'n^(n1+n2)'\n }, // Joining multiply with power 6\n {\n l: 'n^n1*-n',\n r: '-n^(n1+1)'\n }, // Joining multiply with power 7\n {\n l: 'n^n1*n',\n r: 'n^(n1+1)'\n }, // Joining multiply with power 8\n {\n l: 'n^n1/-n',\n r: '-n^(n1-1)'\n }, // Joining multiply with power 8\n {\n l: 'n^n1/n',\n r: 'n^(n1-1)'\n }, // Joining division with power 1\n {\n l: 'n/-n^n1',\n r: '-n^(1-n1)'\n }, // Joining division with power 2\n {\n l: 'n/n^n1',\n r: 'n^(1-n1)'\n }, // Joining division with power 3\n {\n l: 'n^n1/-n^n2',\n r: 'n^(n1-n2)'\n }, // Joining division with power 4\n {\n l: 'n^n1/n^n2',\n r: 'n^(n1-n2)'\n }, // Joining division with power 5\n {\n l: 'n1+(-n2*n3)',\n r: 'n1-n2*n3'\n }, // Solving useless parenthesis 1\n {\n l: 'v*(-c)',\n r: '-c*v'\n }, // Solving useless unary 2\n {\n l: 'n1+-n2',\n r: 'n1-n2'\n }, // Solving +- together (new!)\n {\n l: 'v*c',\n r: 'c*v'\n }, // inversion constant with variable\n {\n l: '(n1^n2)^n3',\n r: '(n1^(n2*n3))'\n } // Power to Power\n ];\n return setRules;\n } // End rulesRationalize\n // ---------------------------------------------------------------------------------------\n\n /**\n * Expand recursively a tree node for handling with expressions with exponents\n * (it's not for constants, symbols or functions with exponents)\n * PS: The other parameters are internal for recursion\n *\n * Syntax:\n *\n * expandPower(node)\n *\n * @param {Node} node Current expression node\n * @param {node} parent Parent current node inside the recursion\n * @param (int} Parent number of chid inside the rercursion\n *\n * @return {node} node expression with all powers expanded.\n */\n\n\n function expandPower(node, parent, indParent) {\n var tp = node.type;\n var internal = arguments.length > 1; // TRUE in internal calls\n\n if (tp === 'OperatorNode' && node.isBinary()) {\n var does = false;\n var val;\n\n if (node.op === '^') {\n // First operator: Parenthesis or UnaryMinus\n if ((node.args[0].type === 'ParenthesisNode' || node.args[0].type === 'OperatorNode') && node.args[1].type === 'ConstantNode') {\n // Second operator: Constant\n val = parseFloat(node.args[1].value);\n does = val >= 2 && (0, _number.isInteger)(val);\n }\n }\n\n if (does) {\n // Exponent >= 2\n // Before:\n // operator A --> Subtree\n // parent pow\n // constant\n //\n if (val > 2) {\n // Exponent > 2,\n // AFTER: (exponent > 2)\n // operator A --> Subtree\n // parent *\n // deep clone (operator A --> Subtree\n // pow\n // constant - 1\n //\n var nEsqTopo = node.args[0];\n var nDirTopo = new OperatorNode('^', 'pow', [node.args[0].cloneDeep(), new ConstantNode(val - 1)]);\n node = new OperatorNode('*', 'multiply', [nEsqTopo, nDirTopo]);\n } else {\n // Expo = 2 - no power\n // AFTER: (exponent = 2)\n // operator A --> Subtree\n // parent oper\n // deep clone (operator A --> Subtree)\n //\n node = new OperatorNode('*', 'multiply', [node.args[0], node.args[0].cloneDeep()]);\n }\n\n if (internal) {\n // Change parent references in internal recursive calls\n if (indParent === 'content') {\n parent.content = node;\n } else {\n parent.args[indParent] = node;\n }\n }\n } // does\n\n } // binary OperatorNode\n\n\n if (tp === 'ParenthesisNode') {\n // Recursion\n expandPower(node.content, node, 'content');\n } else if (tp !== 'ConstantNode' && tp !== 'SymbolNode') {\n for (var i = 0; i < node.args.length; i++) {\n expandPower(node.args[i], node, i);\n }\n }\n\n if (!internal) {\n // return the root node\n return node;\n }\n } // End expandPower\n // ---------------------------------------------------------------------------------------\n\n /**\n * Auxilary function for rationalize\n * Convert near canonical polynomial in one variable in a canonical polynomial\n * with one term for each exponent in decreasing order\n *\n * Syntax:\n *\n * polyToCanonical(node [, coefficients])\n *\n * @param {Node | string} expr The near canonical polynomial expression to convert in a a canonical polynomial expression\n *\n * The string or tree expression needs to be at below syntax, with free spaces:\n * ( (^(-)? | [+-]? )cte (*)? var (^expo)? | cte )+\n * Where 'var' is one variable with any valid name\n * 'cte' are real numeric constants with any value. It can be omitted if equal than 1\n * 'expo' are integers greater than 0. It can be omitted if equal than 1.\n *\n * @param {array} coefficients Optional returns coefficients sorted by increased exponent\n *\n *\n * @return {node} new node tree with one variable polynomial or string error.\n */\n\n\n function polyToCanonical(node, coefficients) {\n if (coefficients === undefined) {\n coefficients = [];\n } // coefficients.\n\n\n coefficients[0] = 0; // index is the exponent\n\n var o = {};\n o.cte = 1;\n o.oper = '+'; // fire: mark with * or ^ when finds * or ^ down tree, reset to \"\" with + and -.\n // It is used to deduce the exponent: 1 for *, 0 for \"\".\n\n o.fire = '';\n var maxExpo = 0; // maximum exponent\n\n var varname = ''; // variable name\n\n recurPol(node, null, o);\n maxExpo = coefficients.length - 1;\n var first = true;\n var no;\n\n for (var i = maxExpo; i >= 0; i--) {\n if (coefficients[i] === 0) continue;\n var n1 = new ConstantNode(first ? coefficients[i] : Math.abs(coefficients[i]));\n var op = coefficients[i] < 0 ? '-' : '+';\n\n if (i > 0) {\n // Is not a constant without variable\n var n2 = new SymbolNode(varname);\n\n if (i > 1) {\n var n3 = new ConstantNode(i);\n n2 = new OperatorNode('^', 'pow', [n2, n3]);\n }\n\n if (coefficients[i] === -1 && first) {\n n1 = new OperatorNode('-', 'unaryMinus', [n2]);\n } else if (Math.abs(coefficients[i]) === 1) {\n n1 = n2;\n } else {\n n1 = new OperatorNode('*', 'multiply', [n1, n2]);\n }\n }\n\n if (first) {\n no = n1;\n } else if (op === '+') {\n no = new OperatorNode('+', 'add', [no, n1]);\n } else {\n no = new OperatorNode('-', 'subtract', [no, n1]);\n }\n\n first = false;\n } // for\n\n\n if (first) {\n return new ConstantNode(0);\n } else {\n return no;\n }\n /**\n * Recursive auxilary function inside polyToCanonical for\n * converting expression in canonical form\n *\n * Syntax:\n *\n * recurPol(node, noPai, obj)\n *\n * @param {Node} node The current subpolynomial expression\n * @param {Node | Null} noPai The current parent node\n * @param {object} obj Object with many internal flags\n *\n * @return {} No return. If error, throws an exception\n */\n\n\n function recurPol(node, noPai, o) {\n var tp = node.type;\n\n if (tp === 'FunctionNode') {\n // ***** FunctionName *****\n // No function call in polynomial expression\n throw new Error('There is an unsolved function call');\n } else if (tp === 'OperatorNode') {\n // ***** OperatorName *****\n if ('+-*^'.indexOf(node.op) === -1) throw new Error('Operator ' + node.op + ' invalid');\n\n if (noPai !== null) {\n // -(unary),^ : children of *,+,-\n if ((node.fn === 'unaryMinus' || node.fn === 'pow') && noPai.fn !== 'add' && noPai.fn !== 'subtract' && noPai.fn !== 'multiply') {\n throw new Error('Invalid ' + node.op + ' placing');\n } // -,+,* : children of +,-\n\n\n if ((node.fn === 'subtract' || node.fn === 'add' || node.fn === 'multiply') && noPai.fn !== 'add' && noPai.fn !== 'subtract') {\n throw new Error('Invalid ' + node.op + ' placing');\n } // -,+ : first child\n\n\n if ((node.fn === 'subtract' || node.fn === 'add' || node.fn === 'unaryMinus') && o.noFil !== 0) {\n throw new Error('Invalid ' + node.op + ' placing');\n }\n } // Has parent\n // Firers: ^,* Old: ^,&,-(unary): firers\n\n\n if (node.op === '^' || node.op === '*') {\n o.fire = node.op;\n }\n\n for (var _i = 0; _i < node.args.length; _i++) {\n // +,-: reset fire\n if (node.fn === 'unaryMinus') o.oper = '-';\n\n if (node.op === '+' || node.fn === 'subtract') {\n o.fire = '';\n o.cte = 1; // default if there is no constant\n\n o.oper = _i === 0 ? '+' : node.op;\n }\n\n o.noFil = _i; // number of son\n\n recurPol(node.args[_i], node, o);\n } // for in children\n\n } else if (tp === 'SymbolNode') {\n // ***** SymbolName *****\n if (node.name !== varname && varname !== '') {\n throw new Error('There is more than one variable');\n }\n\n varname = node.name;\n\n if (noPai === null) {\n coefficients[1] = 1;\n return;\n } // ^: Symbol is First child\n\n\n if (noPai.op === '^' && o.noFil !== 0) {\n throw new Error('In power the variable should be the first parameter');\n } // *: Symbol is Second child\n\n\n if (noPai.op === '*' && o.noFil !== 1) {\n throw new Error('In multiply the variable should be the second parameter');\n } // Symbol: firers '',* => it means there is no exponent above, so it's 1 (cte * var)\n\n\n if (o.fire === '' || o.fire === '*') {\n if (maxExpo < 1) coefficients[1] = 0;\n coefficients[1] += o.cte * (o.oper === '+' ? 1 : -1);\n maxExpo = Math.max(1, maxExpo);\n }\n } else if (tp === 'ConstantNode') {\n var valor = parseFloat(node.value);\n\n if (noPai === null) {\n coefficients[0] = valor;\n return;\n }\n\n if (noPai.op === '^') {\n // cte: second child of power\n if (o.noFil !== 1) throw new Error('Constant cannot be powered');\n\n if (!(0, _number.isInteger)(valor) || valor <= 0) {\n throw new Error('Non-integer exponent is not allowed');\n }\n\n for (var _i2 = maxExpo + 1; _i2 < valor; _i2++) {\n coefficients[_i2] = 0;\n }\n\n if (valor > maxExpo) coefficients[valor] = 0;\n coefficients[valor] += o.cte * (o.oper === '+' ? 1 : -1);\n maxExpo = Math.max(valor, maxExpo);\n return;\n }\n\n o.cte = valor; // Cte: firer '' => There is no exponent and no multiplication, so the exponent is 0.\n\n if (o.fire === '') {\n coefficients[0] += o.cte * (o.oper === '+' ? 1 : -1);\n }\n } else {\n throw new Error('Type ' + tp + ' is not allowed');\n }\n } // End of recurPol\n\n } // End of polyToCanonical\n\n});\nexports.createRationalize = createRationalize;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createResolve = void 0;\n\nvar _map = require(\"../../utils/map.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'resolve';\nvar dependencies = ['parse', 'ConstantNode', 'FunctionNode', 'OperatorNode', 'ParenthesisNode'];\nvar createResolve = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var parse = _ref.parse,\n ConstantNode = _ref.ConstantNode,\n FunctionNode = _ref.FunctionNode,\n OperatorNode = _ref.OperatorNode,\n ParenthesisNode = _ref.ParenthesisNode;\n\n /**\n * resolve(expr, scope) replaces variable nodes with their scoped values\n *\n * Syntax:\n *\n * resolve(expr, scope)\n *\n * Examples:\n *\n * math.resolve('x + y', {x:1, y:2}) // Node {1 + 2}\n * math.resolve(math.parse('x+y'), {x:1, y:2}) // Node {1 + 2}\n * math.simplify('x+y', {x:2, y:'x+x'}).toString() // \"6\"\n *\n * See also:\n *\n * simplify, evaluate\n *\n * @param {Node | Node[]} node\n * The expression tree (or trees) to be simplified\n * @param {Object} scope\n * Scope specifying variables to be resolved\n * @return {Node | Node[]} Returns `node` with variables recursively substituted.\n * @throws {ReferenceError}\n * If there is a cyclic dependency among the variables in `scope`,\n * resolution is impossible and a ReferenceError is thrown.\n */\n function resolve(node, scope) {\n var within = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : new Set();\n\n // note `within`:\n // `within` is not documented, since it is for internal cycle\n // detection only\n if (!scope) {\n return node;\n }\n\n if (!(0, _map.isMap)(scope)) {\n scope = (0, _map.createMap)(scope);\n }\n\n if ((0, _is.isSymbolNode)(node)) {\n if (within.has(node.name)) {\n var variables = Array.from(within).join(', ');\n throw new ReferenceError(\"recursive loop of variable definitions among {\".concat(variables, \"}\"));\n }\n\n var value = scope.get(node.name);\n\n if ((0, _is.isNode)(value)) {\n var nextWithin = new Set(within);\n nextWithin.add(node.name);\n return resolve(value, scope, nextWithin);\n } else if (typeof value === 'number') {\n return parse(String(value));\n } else if (value !== undefined) {\n return new ConstantNode(value);\n } else {\n return node;\n }\n } else if ((0, _is.isOperatorNode)(node)) {\n var args = node.args.map(function (arg) {\n return resolve(arg, scope, within);\n });\n return new OperatorNode(node.op, node.fn, args, node.implicit);\n } else if ((0, _is.isParenthesisNode)(node)) {\n return new ParenthesisNode(resolve(node.content, scope, within));\n } else if ((0, _is.isFunctionNode)(node)) {\n var _args = node.args.map(function (arg) {\n return resolve(arg, scope, within);\n });\n\n return new FunctionNode(node.name, _args);\n } // Otherwise just recursively resolve any children (might also work\n // for some of the above special cases)\n\n\n return node.map(function (child) {\n return resolve(child, scope, within);\n });\n }\n\n return resolve;\n});\nexports.createResolve = createResolve;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSimplify = void 0;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _util = require(\"./simplify/util.js\");\n\nvar _simplifyConstant = require(\"./simplify/simplifyConstant.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _map = require(\"../../utils/map.js\");\n\nvar name = 'simplify';\nvar dependencies = ['config', 'typed', 'parse', 'add', 'subtract', 'multiply', 'divide', 'pow', 'isZero', 'equal', 'resolve', 'simplifyCore', '?fraction', '?bignumber', 'mathWithTransform', 'matrix', 'AccessorNode', 'ArrayNode', 'ConstantNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'ParenthesisNode', 'SymbolNode'];\nvar createSimplify = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var config = _ref.config,\n typed = _ref.typed,\n parse = _ref.parse,\n add = _ref.add,\n subtract = _ref.subtract,\n multiply = _ref.multiply,\n divide = _ref.divide,\n pow = _ref.pow,\n isZero = _ref.isZero,\n equal = _ref.equal,\n resolve = _ref.resolve,\n simplifyCore = _ref.simplifyCore,\n fraction = _ref.fraction,\n bignumber = _ref.bignumber,\n mathWithTransform = _ref.mathWithTransform,\n matrix = _ref.matrix,\n AccessorNode = _ref.AccessorNode,\n ArrayNode = _ref.ArrayNode,\n ConstantNode = _ref.ConstantNode,\n FunctionNode = _ref.FunctionNode,\n IndexNode = _ref.IndexNode,\n ObjectNode = _ref.ObjectNode,\n OperatorNode = _ref.OperatorNode,\n ParenthesisNode = _ref.ParenthesisNode,\n SymbolNode = _ref.SymbolNode;\n var simplifyConstant = (0, _simplifyConstant.createSimplifyConstant)({\n typed: typed,\n config: config,\n mathWithTransform: mathWithTransform,\n matrix: matrix,\n fraction: fraction,\n bignumber: bignumber,\n AccessorNode: AccessorNode,\n ArrayNode: ArrayNode,\n ConstantNode: ConstantNode,\n FunctionNode: FunctionNode,\n IndexNode: IndexNode,\n ObjectNode: ObjectNode,\n OperatorNode: OperatorNode,\n SymbolNode: SymbolNode\n });\n\n var _createUtil = (0, _util.createUtil)({\n FunctionNode: FunctionNode,\n OperatorNode: OperatorNode,\n SymbolNode: SymbolNode\n }),\n hasProperty = _createUtil.hasProperty,\n isCommutative = _createUtil.isCommutative,\n isAssociative = _createUtil.isAssociative,\n mergeContext = _createUtil.mergeContext,\n flatten = _createUtil.flatten,\n unflattenr = _createUtil.unflattenr,\n unflattenl = _createUtil.unflattenl,\n createMakeNodeFunction = _createUtil.createMakeNodeFunction,\n defaultContext = _createUtil.defaultContext,\n realContext = _createUtil.realContext,\n positiveContext = _createUtil.positiveContext;\n /**\n * Simplify an expression tree.\n *\n * A list of rules are applied to an expression, repeating over the list until\n * no further changes are made.\n * It's possible to pass a custom set of rules to the function as second\n * argument. A rule can be specified as an object, string, or function:\n *\n * const rules = [\n * { l: 'n1*n3 + n2*n3', r: '(n1+n2)*n3' },\n * 'n1*n3 + n2*n3 -> (n1+n2)*n3',\n * function (node) {\n * // ... return a new node or return the node unchanged\n * return node\n * }\n * ]\n *\n * String and object rules consist of a left and right pattern. The left is\n * used to match against the expression and the right determines what matches\n * are replaced with. The main difference between a pattern and a normal\n * expression is that variables starting with the following characters are\n * interpreted as wildcards:\n *\n * - 'n' - matches any Node\n * - 'c' - matches any ConstantNode\n * - 'v' - matches any Node that is not a ConstantNode\n *\n * The default list of rules is exposed on the function as `simplify.rules`\n * and can be used as a basis to built a set of custom rules.\n *\n * To specify a rule as a string, separate the left and right pattern by '->'\n * When specifying a rule as an object, the following keys are meaningful:\n * - l - the left pattern\n * - r - the right pattern\n * - s - in lieu of l and r, the string form that is broken at -> to give them\n * - repeat - whether to repeat this rule until the expression stabilizes\n * - assuming - gives a context object, as in the 'context' option to\n * simplify. Every property in the context object must match the current\n * context in order, or else the rule will not be applied.\n * - imposeContext - gives a context object, as in the 'context' option to\n * simplify. Any settings specified will override the incoming context\n * for all matches of this rule.\n *\n * For more details on the theory, see:\n *\n * - [Strategies for simplifying math expressions (Stackoverflow)](https://stackoverflow.com/questions/7540227/strategies-for-simplifying-math-expressions)\n * - [Symbolic computation - Simplification (Wikipedia)](https://en.wikipedia.org/wiki/Symbolic_computation#Simplification)\n *\n * An optional `options` argument can be passed as last argument of `simplify`.\n * Currently available options (defaults in parentheses):\n * - `consoleDebug` (false): whether to write the expression being simplified\n * and any changes to it, along with the rule responsible, to console\n * - `context` (simplify.defaultContext): an object giving properties of\n * each operator, which determine what simplifications are allowed. The\n * currently meaningful properties are commutative, associative,\n * total (whether the operation is defined for all arguments), and\n * trivial (whether the operation applied to a single argument leaves\n * that argument unchanged). The default context is very permissive and\n * allows almost all simplifications. Only properties differing from\n * the default need to be specified; the default context is used as a\n * fallback. Additional contexts `simplify.realContext` and\n * `simplify.positiveContext` are supplied to cause simplify to perform\n * just simplifications guaranteed to preserve all values of the expression\n * assuming all variables and subexpressions are real numbers or\n * positive real numbers, respectively. (Note that these are in some cases\n * more restrictive than the default context; for example, the default\n * context will allow `x/x` to simplify to 1, whereas\n * `simplify.realContext` will not, as `0/0` is not equal to 1.)\n * - `exactFractions` (true): whether to try to convert all constants to\n * exact rational numbers.\n * - `fractionsLimit` (10000): when `exactFractions` is true, constants will\n * be expressed as fractions only when both numerator and denominator\n * are smaller than `fractionsLimit`.\n *\n * Syntax:\n *\n * simplify(expr)\n * simplify(expr, rules)\n * simplify(expr, rules)\n * simplify(expr, rules, scope)\n * simplify(expr, rules, scope, options)\n * simplify(expr, scope)\n * simplify(expr, scope, options)\n *\n * Examples:\n *\n * math.simplify('2 * 1 * x ^ (2 - 1)') // Node \"2 * x\"\n * math.simplify('2 * 3 * x', {x: 4}) // Node \"24\"\n * const f = math.parse('2 * 1 * x ^ (2 - 1)')\n * math.simplify(f) // Node \"2 * x\"\n * math.simplify('0.4 * x', {}, {exactFractions: true}) // Node \"x * 2 / 5\"\n * math.simplify('0.4 * x', {}, {exactFractions: false}) // Node \"0.4 * x\"\n *\n * See also:\n *\n * simplifyCore, derivative, evaluate, parse, rationalize, resolve\n *\n * @param {Node | string} expr\n * The expression to be simplified\n * @param {Array<{l:string, r: string} | string | function>} [rules]\n * Optional list with custom rules\n * @return {Node} Returns the simplified form of `expr`\n */\n\n\n var simplify = typed('simplify', {\n string: function string(expr) {\n return this(parse(expr), this.rules, (0, _map.createEmptyMap)(), {});\n },\n 'string, Map | Object': function stringMapObject(expr, scope) {\n return this(parse(expr), this.rules, scope, {});\n },\n 'string, Map | Object, Object': function stringMapObjectObject(expr, scope, options) {\n return this(parse(expr), this.rules, scope, options);\n },\n 'string, Array': function stringArray(expr, rules) {\n return this(parse(expr), rules, (0, _map.createEmptyMap)(), {});\n },\n 'string, Array, Map | Object': function stringArrayMapObject(expr, rules, scope) {\n return this(parse(expr), rules, scope, {});\n },\n 'string, Array, Map | Object, Object': function stringArrayMapObjectObject(expr, rules, scope, options) {\n return this(parse(expr), rules, scope, options);\n },\n 'Node, Map | Object': function NodeMapObject(expr, scope) {\n return this(expr, this.rules, scope, {});\n },\n 'Node, Map | Object, Object': function NodeMapObjectObject(expr, scope, options) {\n return this(expr, this.rules, scope, options);\n },\n Node: function Node(expr) {\n return this(expr, this.rules, (0, _map.createEmptyMap)(), {});\n },\n 'Node, Array': function NodeArray(expr, rules) {\n return this(expr, rules, (0, _map.createEmptyMap)(), {});\n },\n 'Node, Array, Map | Object': function NodeArrayMapObject(expr, rules, scope) {\n return this(expr, rules, scope, {});\n },\n 'Node, Array, Object, Object': function NodeArrayObjectObject(expr, rules, scope, options) {\n return this(expr, rules, (0, _map.createMap)(scope), options);\n },\n 'Node, Array, Map, Object': function NodeArrayMapObject(expr, rules, scope, options) {\n var debug = options.consoleDebug;\n rules = _buildRules(rules, options.context);\n var res = resolve(expr, scope);\n res = removeParens(res);\n var visited = {};\n var str = res.toString({\n parenthesis: 'all'\n });\n\n while (!visited[str]) {\n visited[str] = true;\n _lastsym = 0; // counter for placeholder symbols\n\n var laststr = str;\n if (debug) console.log('Working on: ', str);\n\n for (var i = 0; i < rules.length; i++) {\n var rulestr = '';\n\n if (typeof rules[i] === 'function') {\n res = rules[i](res, options);\n if (debug) rulestr = rules[i].name;\n } else {\n flatten(res, options.context);\n res = applyRule(res, rules[i], options.context);\n\n if (debug) {\n rulestr = \"\".concat(rules[i].l.toString(), \" -> \").concat(rules[i].r.toString());\n }\n }\n\n if (debug) {\n var newstr = res.toString({\n parenthesis: 'all'\n });\n\n if (newstr !== laststr) {\n console.log('Applying', rulestr, 'produced', newstr);\n laststr = newstr;\n }\n }\n /* Use left-heavy binary tree internally,\n * since custom rule functions may expect it\n */\n\n\n unflattenl(res, options.context);\n }\n\n str = res.toString({\n parenthesis: 'all'\n });\n }\n\n return res;\n }\n });\n simplify.defaultContext = defaultContext;\n simplify.realContext = realContext;\n simplify.positiveContext = positiveContext;\n\n function removeParens(node) {\n return node.transform(function (node, path, parent) {\n return (0, _is.isParenthesisNode)(node) ? removeParens(node.content) : node;\n });\n } // All constants that are allowed in rules\n\n\n var SUPPORTED_CONSTANTS = {\n true: true,\n false: true,\n e: true,\n i: true,\n Infinity: true,\n LN2: true,\n LN10: true,\n LOG2E: true,\n LOG10E: true,\n NaN: true,\n phi: true,\n pi: true,\n SQRT1_2: true,\n SQRT2: true,\n tau: true // null: false,\n // undefined: false,\n // version: false,\n\n }; // Array of strings, used to build the ruleSet.\n // Each l (left side) and r (right side) are parsed by\n // the expression parser into a node tree.\n // Left hand sides are matched to subtrees within the\n // expression to be parsed and replaced with the right\n // hand side.\n // TODO: Add support for constraints on constants (either in the form of a '=' expression or a callback [callback allows things like comparing symbols alphabetically])\n // To evaluate lhs constants for rhs constants, use: { l: 'c1+c2', r: 'c3', evaluate: 'c3 = c1 + c2' }. Multiple assignments are separated by ';' in block format.\n // It is possible to get into an infinite loop with conflicting rules\n\n simplify.rules = [simplifyCore, // { l: 'n+0', r: 'n' }, // simplifyCore\n // { l: 'n^0', r: '1' }, // simplifyCore\n // { l: '0*n', r: '0' }, // simplifyCore\n // { l: 'n/n', r: '1'}, // simplifyCore\n // { l: 'n^1', r: 'n' }, // simplifyCore\n // { l: '+n1', r:'n1' }, // simplifyCore\n // { l: 'n--n1', r:'n+n1' }, // simplifyCore\n {\n l: 'log(e)',\n r: '1'\n }, // temporary rules\n // Note initially we tend constants to the right because like-term\n // collection prefers the left, and we would rather collect nonconstants\n {\n s: 'n-n1 -> n+-n1',\n // temporarily replace 'subtract' so we can further flatten the 'add' operator\n assuming: {\n subtract: {\n total: true\n }\n }\n }, {\n s: 'n-n -> 0',\n // partial alternative when we can't always subtract\n assuming: {\n subtract: {\n total: false\n }\n }\n }, {\n s: '-(c*v) -> v * (-c)',\n // make non-constant terms positive\n assuming: {\n multiply: {\n commutative: true\n },\n subtract: {\n total: true\n }\n }\n }, {\n s: '-(c*v) -> (-c) * v',\n // non-commutative version, part 1\n assuming: {\n multiply: {\n commutative: false\n },\n subtract: {\n total: true\n }\n }\n }, {\n s: '-(v*c) -> v * (-c)',\n // non-commutative version, part 2\n assuming: {\n multiply: {\n commutative: false\n },\n subtract: {\n total: true\n }\n }\n }, {\n l: '-(n1/n2)',\n r: '-n1/n2'\n }, {\n l: '-v',\n r: 'v * (-1)'\n }, // finish making non-constant terms positive\n {\n l: '(n1 + n2)*(-1)',\n r: 'n1*(-1) + n2*(-1)',\n repeat: true\n }, // expand negations to achieve as much sign cancellation as possible\n {\n l: 'n/n1^n2',\n r: 'n*n1^-n2'\n }, // temporarily replace 'divide' so we can further flatten the 'multiply' operator\n {\n l: 'n/n1',\n r: 'n*n1^-1'\n }, {\n s: '(n1*n2)^n3 -> n1^n3 * n2^n3',\n assuming: {\n multiply: {\n commutative: true\n }\n }\n }, {\n s: '(n1*n2)^(-1) -> n2^(-1) * n1^(-1)',\n assuming: {\n multiply: {\n commutative: false\n }\n }\n }, // expand nested exponentiation\n {\n s: '(n ^ n1) ^ n2 -> n ^ (n1 * n2)',\n assuming: {\n divide: {\n total: true\n }\n } // 1/(1/n) = n needs 1/n to exist\n\n }, // collect like factors; into a sum, only do this for nonconstants\n {\n l: ' v * ( v * n1 + n2)',\n r: 'v^2 * n1 + v * n2'\n }, {\n s: ' v * (v^n4 * n1 + n2) -> v^(1+n4) * n1 + v * n2',\n assuming: {\n divide: {\n total: true\n }\n } // v*1/v = v^(1+-1) needs 1/v\n\n }, {\n s: 'v^n3 * ( v * n1 + n2) -> v^(n3+1) * n1 + v^n3 * n2',\n assuming: {\n divide: {\n total: true\n }\n }\n }, {\n s: 'v^n3 * (v^n4 * n1 + n2) -> v^(n3+n4) * n1 + v^n3 * n2',\n assuming: {\n divide: {\n total: true\n }\n }\n }, {\n l: 'n*n',\n r: 'n^2'\n }, {\n s: 'n * n^n1 -> n^(n1+1)',\n assuming: {\n divide: {\n total: true\n }\n } // n*1/n = n^(-1+1) needs 1/n\n\n }, {\n s: 'n^n1 * n^n2 -> n^(n1+n2)',\n assuming: {\n divide: {\n total: true\n }\n } // ditto for n^2*1/n^2\n\n }, // Unfortunately, to deal with more complicated cancellations, it\n // becomes necessary to simplify constants twice per pass. It's not\n // terribly expensive compared to matching rules, so this should not\n // pose a performance problem.\n simplifyConstant, // First: before collecting like terms\n // collect like terms\n {\n s: 'n+n -> 2*n',\n assuming: {\n add: {\n total: true\n }\n } // 2 = 1 + 1 needs to exist\n\n }, {\n l: 'n+-n',\n r: '0'\n }, {\n l: 'v*n + v',\n r: 'v*(n+1)'\n }, // NOTE: leftmost position is special:\n {\n l: 'n3*n1 + n3*n2',\n r: 'n3*(n1+n2)'\n }, // All sub-monomials tried there.\n {\n l: 'n3^(-n4)*n1 + n3 * n2',\n r: 'n3^(-n4)*(n1 + n3^(n4+1) *n2)'\n }, {\n l: 'n3^(-n4)*n1 + n3^n5 * n2',\n r: 'n3^(-n4)*(n1 + n3^(n4+n5)*n2)'\n }, {\n s: 'n*v + v -> (n+1)*v',\n // noncommutative additional cases\n assuming: {\n multiply: {\n commutative: false\n }\n }\n }, {\n s: 'n1*n3 + n2*n3 -> (n1+n2)*n3',\n assuming: {\n multiply: {\n commutative: false\n }\n }\n }, {\n s: 'n1*n3^(-n4) + n2 * n3 -> (n1 + n2*n3^(n4 + 1))*n3^(-n4)',\n assuming: {\n multiply: {\n commutative: false\n }\n }\n }, {\n s: 'n1*n3^(-n4) + n2 * n3^n5 -> (n1 + n2*n3^(n4 + n5))*n3^(-n4)',\n assuming: {\n multiply: {\n commutative: false\n }\n }\n }, {\n l: 'n*c + c',\n r: '(n+1)*c'\n }, {\n s: 'c*n + c -> c*(n+1)',\n assuming: {\n multiply: {\n commutative: false\n }\n }\n }, simplifyConstant, // Second: before returning expressions to \"standard form\"\n // make factors positive (and undo 'make non-constant terms positive')\n {\n s: '(-n)*n1 -> -(n*n1)',\n assuming: {\n subtract: {\n total: true\n }\n }\n }, {\n s: 'n1*(-n) -> -(n1*n)',\n // in case * non-commutative\n assuming: {\n subtract: {\n total: true\n },\n multiply: {\n commutative: false\n }\n }\n }, // final ordering of constants\n {\n s: 'c+v -> v+c',\n assuming: {\n add: {\n commutative: true\n }\n },\n imposeContext: {\n add: {\n commutative: false\n }\n }\n }, {\n s: 'v*c -> c*v',\n assuming: {\n multiply: {\n commutative: true\n }\n },\n imposeContext: {\n multiply: {\n commutative: false\n }\n }\n }, // undo temporary rules\n // { l: '(-1) * n', r: '-n' }, // #811 added test which proved this is redundant\n {\n l: 'n+-n1',\n r: 'n-n1'\n }, // undo replace 'subtract'\n {\n s: 'n*(n1^-1) -> n/n1',\n // undo replace 'divide'; for * commutative\n assuming: {\n multiply: {\n commutative: true\n }\n } // o.w. / not conventional\n\n }, {\n s: 'n*n1^-n2 -> n/n1^n2',\n assuming: {\n multiply: {\n commutative: true\n }\n } // o.w. / not conventional\n\n }, {\n s: 'n^-1 -> 1/n',\n assuming: {\n multiply: {\n commutative: true\n }\n } // o.w. / not conventional\n\n }, {\n l: 'n^1',\n r: 'n'\n }, // can be produced by power cancellation\n {\n s: 'n*(n1/n2) -> (n*n1)/n2',\n // '*' before '/'\n assuming: {\n multiply: {\n associative: true\n }\n }\n }, {\n s: 'n-(n1+n2) -> n-n1-n2',\n // '-' before '+'\n assuming: {\n addition: {\n associative: true,\n commutative: true\n }\n }\n }, // { l: '(n1/n2)/n3', r: 'n1/(n2*n3)' },\n // { l: '(n*n1)/(n*n2)', r: 'n1/n2' },\n // simplifyConstant can leave an extra factor of 1, which can always\n // be eliminated, since the identity always commutes\n {\n l: '1*n',\n r: 'n',\n imposeContext: {\n multiply: {\n commutative: true\n }\n }\n }, {\n s: 'n1/(n2/n3) -> (n1*n3)/n2',\n assuming: {\n multiply: {\n associative: true\n }\n }\n }, {\n l: 'n1/(-n2)',\n r: '-n1/n2'\n }];\n /**\n * Takes any rule object as allowed by the specification in simplify\n * and puts it in a standard form used by applyRule\n */\n\n function _canonicalizeRule(ruleObject, context) {\n var newRule = {};\n\n if (ruleObject.s) {\n var lr = ruleObject.s.split('->');\n\n if (lr.length === 2) {\n newRule.l = lr[0];\n newRule.r = lr[1];\n } else {\n throw SyntaxError('Could not parse rule: ' + ruleObject.s);\n }\n } else {\n newRule.l = ruleObject.l;\n newRule.r = ruleObject.r;\n }\n\n newRule.l = removeParens(parse(newRule.l));\n newRule.r = removeParens(parse(newRule.r));\n\n for (var _i = 0, _arr = ['imposeContext', 'repeat', 'assuming']; _i < _arr.length; _i++) {\n var prop = _arr[_i];\n\n if (prop in ruleObject) {\n newRule[prop] = ruleObject[prop];\n }\n }\n\n if (ruleObject.evaluate) {\n newRule.evaluate = parse(ruleObject.evaluate);\n }\n\n if (isAssociative(newRule.l, context)) {\n var makeNode = createMakeNodeFunction(newRule.l);\n\n var expandsym = _getExpandPlaceholderSymbol();\n\n newRule.expanded = {};\n newRule.expanded.l = makeNode([newRule.l.clone(), expandsym]); // Push the expandsym into the deepest possible branch.\n // This helps to match the newRule against nodes returned from getSplits() later on.\n\n flatten(newRule.expanded.l, context);\n unflattenr(newRule.expanded.l, context);\n newRule.expanded.r = makeNode([newRule.r, expandsym]);\n }\n\n return newRule;\n }\n /**\n * Parse the string array of rules into nodes\n *\n * Example syntax for rules:\n *\n * Position constants to the left in a product:\n * { l: 'n1 * c1', r: 'c1 * n1' }\n * n1 is any Node, and c1 is a ConstantNode.\n *\n * Apply difference of squares formula:\n * { l: '(n1 - n2) * (n1 + n2)', r: 'n1^2 - n2^2' }\n * n1, n2 mean any Node.\n *\n * Short hand notation:\n * 'n1 * c1 -> c1 * n1'\n */\n\n\n function _buildRules(rules, context) {\n // Array of rules to be used to simplify expressions\n var ruleSet = [];\n\n for (var i = 0; i < rules.length; i++) {\n var rule = rules[i];\n var newRule = void 0;\n var ruleType = (0, _typeof2.default)(rule);\n\n switch (ruleType) {\n case 'string':\n rule = {\n s: rule\n };\n\n /* falls through */\n\n case 'object':\n newRule = _canonicalizeRule(rule, context);\n break;\n\n case 'function':\n newRule = rule;\n break;\n\n default:\n throw TypeError('Unsupported type of rule: ' + ruleType);\n } // console.log('Adding rule: ' + rules[i])\n // console.log(newRule)\n\n\n ruleSet.push(newRule);\n }\n\n return ruleSet;\n }\n\n var _lastsym = 0;\n\n function _getExpandPlaceholderSymbol() {\n return new SymbolNode('_p' + _lastsym++);\n }\n\n function mapRule(nodes, rule, context) {\n var resNodes = nodes;\n\n if (nodes) {\n for (var i = 0; i < nodes.length; ++i) {\n var newNode = applyRule(nodes[i], rule, context);\n\n if (newNode !== nodes[i]) {\n if (resNodes === nodes) {\n resNodes = nodes.slice();\n }\n\n resNodes[i] = newNode;\n }\n }\n }\n\n return resNodes;\n }\n /**\n * Returns a simplfied form of node, or the original node if no simplification was possible.\n *\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node\n * @param {Object | Function} rule\n * @param {Object} context -- information about assumed properties of operators\n * @return {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} The simplified form of `expr`, or the original node if no simplification was possible.\n */\n\n\n function applyRule(node, rule, context) {\n // console.log('Entering applyRule(\"', rule.l.toString({parenthesis:'all'}), '->', rule.r.toString({parenthesis:'all'}), '\",', node.toString({parenthesis:'all'}),')')\n // check that the assumptions for this rule are satisfied by the current\n // context:\n if (rule.assuming) {\n for (var symbol in rule.assuming) {\n for (var property in rule.assuming[symbol]) {\n if (hasProperty(symbol, property, context) !== rule.assuming[symbol][property]) {\n return node;\n }\n }\n }\n }\n\n var mergedContext = mergeContext(rule.imposeContext, context); // Do not clone node unless we find a match\n\n var res = node; // First replace our child nodes with their simplified versions\n // If a child could not be simplified, applying the rule to it\n // will have no effect since the node is returned unchanged\n\n if (res instanceof OperatorNode || res instanceof FunctionNode) {\n var newArgs = mapRule(res.args, rule, context);\n\n if (newArgs !== res.args) {\n res = res.clone();\n res.args = newArgs;\n }\n } else if (res instanceof ParenthesisNode) {\n if (res.content) {\n var newContent = applyRule(res.content, rule, context);\n\n if (newContent !== res.content) {\n res = new ParenthesisNode(newContent);\n }\n }\n } else if (res instanceof ArrayNode) {\n var newItems = mapRule(res.items, rule, context);\n\n if (newItems !== res.items) {\n res = new ArrayNode(newItems);\n }\n } else if (res instanceof AccessorNode) {\n var newObj = res.object;\n\n if (res.object) {\n newObj = applyRule(res.object, rule, context);\n }\n\n var newIndex = res.index;\n\n if (res.index) {\n newIndex = applyRule(res.index, rule, context);\n }\n\n if (newObj !== res.object || newIndex !== res.index) {\n res = new AccessorNode(newObj, newIndex);\n }\n } else if (res instanceof IndexNode) {\n var newDims = mapRule(res.dimensions, rule, context);\n\n if (newDims !== res.dimensions) {\n res = new IndexNode(newDims);\n }\n } else if (res instanceof ObjectNode) {\n var changed = false;\n var newProps = {};\n\n for (var prop in res.properties) {\n newProps[prop] = applyRule(res.properties[prop], rule, context);\n\n if (newProps[prop] !== res.properties[prop]) {\n changed = true;\n }\n }\n\n if (changed) {\n res = new ObjectNode(newProps);\n }\n } // Try to match a rule against this node\n\n\n var repl = rule.r;\n\n var matches = _ruleMatch(rule.l, res, mergedContext)[0]; // If the rule is associative operator, we can try matching it while allowing additional terms.\n // This allows us to match rules like 'n+n' to the expression '(1+x)+x' or even 'x+1+x' if the operator is commutative.\n\n\n if (!matches && rule.expanded) {\n repl = rule.expanded.r;\n matches = _ruleMatch(rule.expanded.l, res, mergedContext)[0];\n }\n\n if (matches) {\n // const before = res.toString({parenthesis: 'all'})\n // Create a new node by cloning the rhs of the matched rule\n // we keep any implicit multiplication state if relevant\n var implicit = res.implicit;\n res = repl.clone();\n\n if (implicit && 'implicit' in repl) {\n res.implicit = true;\n } // Replace placeholders with their respective nodes without traversing deeper into the replaced nodes\n\n\n res = res.transform(function (node) {\n if (node.isSymbolNode && (0, _object.hasOwnProperty)(matches.placeholders, node.name)) {\n return matches.placeholders[node.name].clone();\n } else {\n return node;\n }\n }); // const after = res.toString({parenthesis: 'all'})\n // console.log('Simplified ' + before + ' to ' + after)\n }\n\n if (rule.repeat && res !== node) {\n res = applyRule(res, rule, context);\n }\n\n return res;\n }\n /**\n * Get (binary) combinations of a flattened binary node\n * e.g. +(node1, node2, node3) -> [\n * +(node1, +(node2, node3)),\n * +(node2, +(node1, node3)),\n * +(node3, +(node1, node2))]\n *\n */\n\n\n function getSplits(node, context) {\n var res = [];\n var right, rightArgs;\n var makeNode = createMakeNodeFunction(node);\n\n if (isCommutative(node, context)) {\n for (var i = 0; i < node.args.length; i++) {\n rightArgs = node.args.slice(0);\n rightArgs.splice(i, 1);\n right = rightArgs.length === 1 ? rightArgs[0] : makeNode(rightArgs);\n res.push(makeNode([node.args[i], right]));\n }\n } else {\n // Keep order, but try all parenthesizations\n for (var _i2 = 1; _i2 < node.args.length; _i2++) {\n var left = node.args[0];\n\n if (_i2 > 1) {\n left = makeNode(node.args.slice(0, _i2));\n }\n\n rightArgs = node.args.slice(_i2);\n right = rightArgs.length === 1 ? rightArgs[0] : makeNode(rightArgs);\n res.push(makeNode([left, right]));\n }\n }\n\n return res;\n }\n /**\n * Returns the set union of two match-placeholders or null if there is a conflict.\n */\n\n\n function mergeMatch(match1, match2) {\n var res = {\n placeholders: {}\n }; // Some matches may not have placeholders; this is OK\n\n if (!match1.placeholders && !match2.placeholders) {\n return res;\n } else if (!match1.placeholders) {\n return match2;\n } else if (!match2.placeholders) {\n return match1;\n } // Placeholders with the same key must match exactly\n\n\n for (var key in match1.placeholders) {\n if ((0, _object.hasOwnProperty)(match1.placeholders, key)) {\n res.placeholders[key] = match1.placeholders[key];\n\n if ((0, _object.hasOwnProperty)(match2.placeholders, key)) {\n if (!_exactMatch(match1.placeholders[key], match2.placeholders[key])) {\n return null;\n }\n }\n }\n }\n\n for (var _key in match2.placeholders) {\n if ((0, _object.hasOwnProperty)(match2.placeholders, _key)) {\n res.placeholders[_key] = match2.placeholders[_key];\n }\n }\n\n return res;\n }\n /**\n * Combine two lists of matches by applying mergeMatch to the cartesian product of two lists of matches.\n * Each list represents matches found in one child of a node.\n */\n\n\n function combineChildMatches(list1, list2) {\n var res = [];\n\n if (list1.length === 0 || list2.length === 0) {\n return res;\n }\n\n var merged;\n\n for (var i1 = 0; i1 < list1.length; i1++) {\n for (var i2 = 0; i2 < list2.length; i2++) {\n merged = mergeMatch(list1[i1], list2[i2]);\n\n if (merged) {\n res.push(merged);\n }\n }\n }\n\n return res;\n }\n /**\n * Combine multiple lists of matches by applying mergeMatch to the cartesian product of two lists of matches.\n * Each list represents matches found in one child of a node.\n * Returns a list of unique matches.\n */\n\n\n function mergeChildMatches(childMatches) {\n if (childMatches.length === 0) {\n return childMatches;\n }\n\n var sets = childMatches.reduce(combineChildMatches);\n var uniqueSets = [];\n var unique = {};\n\n for (var i = 0; i < sets.length; i++) {\n var s = JSON.stringify(sets[i]);\n\n if (!unique[s]) {\n unique[s] = true;\n uniqueSets.push(sets[i]);\n }\n }\n\n return uniqueSets;\n }\n /**\n * Determines whether node matches rule.\n *\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} rule\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} node\n * @param {Object} context -- provides assumed properties of operators\n * @param {Boolean} isSplit -- whether we are in process of splitting an\n * n-ary operator node into possible binary combinations.\n * Defaults to false.\n * @return {Object} Information about the match, if it exists.\n */\n\n\n function _ruleMatch(rule, node, context, isSplit) {\n // console.log('Entering _ruleMatch(' + JSON.stringify(rule) + ', ' + JSON.stringify(node) + ')')\n // console.log('rule = ' + rule)\n // console.log('node = ' + node)\n // console.log('Entering _ruleMatch(', rule.toString({parenthesis:'all'}), ', ', node.toString({parenthesis:'all'}), ', ', context, ')')\n var res = [{\n placeholders: {}\n }];\n\n if (rule instanceof OperatorNode && node instanceof OperatorNode || rule instanceof FunctionNode && node instanceof FunctionNode) {\n // If the rule is an OperatorNode or a FunctionNode, then node must match exactly\n if (rule instanceof OperatorNode) {\n if (rule.op !== node.op || rule.fn !== node.fn) {\n return [];\n }\n } else if (rule instanceof FunctionNode) {\n if (rule.name !== node.name) {\n return [];\n }\n } // rule and node match. Search the children of rule and node.\n\n\n if (node.args.length === 1 && rule.args.length === 1 || !isAssociative(node, context) && node.args.length === rule.args.length || isSplit) {\n // Expect non-associative operators to match exactly,\n // except in any order if operator is commutative\n var childMatches = [];\n\n for (var i = 0; i < rule.args.length; i++) {\n var childMatch = _ruleMatch(rule.args[i], node.args[i], context);\n\n if (childMatch.length === 0) {\n // Child did not match, so stop searching immediately\n break;\n } // The child matched, so add the information returned from the child to our result\n\n\n childMatches.push(childMatch);\n }\n\n if (childMatches.length !== rule.args.length) {\n if (!isCommutative(node, context) || // exact match in order needed\n rule.args.length === 1) {\n // nothing to commute\n return [];\n }\n\n if (rule.args.length > 2) {\n /* Need to generate all permutations and try them.\n * It's a bit complicated, and unlikely to come up since there\n * are very few ternary or higher operators. So punt for now.\n */\n throw new Error('permuting >2 commutative non-associative rule arguments not yet implemented');\n }\n /* Exactly two arguments, try them reversed */\n\n\n var leftMatch = _ruleMatch(rule.args[0], node.args[1], context);\n\n if (leftMatch.length === 0) {\n return [];\n }\n\n var rightMatch = _ruleMatch(rule.args[1], node.args[0], context);\n\n if (rightMatch.length === 0) {\n return [];\n }\n\n childMatches = [leftMatch, rightMatch];\n }\n\n res = mergeChildMatches(childMatches);\n } else if (node.args.length >= 2 && rule.args.length === 2) {\n // node is flattened, rule is not\n // Associative operators/functions can be split in different ways so we check if the rule matches each\n // them and return their union.\n var splits = getSplits(node, context);\n var splitMatches = [];\n\n for (var _i3 = 0; _i3 < splits.length; _i3++) {\n var matchSet = _ruleMatch(rule, splits[_i3], context, true); // recursing at the same tree depth here\n\n\n splitMatches = splitMatches.concat(matchSet);\n }\n\n return splitMatches;\n } else if (rule.args.length > 2) {\n throw Error('Unexpected non-binary associative function: ' + rule.toString());\n } else {\n // Incorrect number of arguments in rule and node, so no match\n return [];\n }\n } else if (rule instanceof SymbolNode) {\n // If the rule is a SymbolNode, then it carries a special meaning\n // according to the first character of the symbol node name.\n // c.* matches a ConstantNode\n // n.* matches any node\n if (rule.name.length === 0) {\n throw new Error('Symbol in rule has 0 length...!?');\n }\n\n if (SUPPORTED_CONSTANTS[rule.name]) {\n // built-in constant must match exactly\n if (rule.name !== node.name) {\n return [];\n }\n } else if (rule.name[0] === 'n' || rule.name.substring(0, 2) === '_p') {\n // rule matches _anything_, so assign this node to the rule.name placeholder\n // Assign node to the rule.name placeholder.\n // Our parent will check for matches among placeholders.\n res[0].placeholders[rule.name] = node;\n } else if (rule.name[0] === 'v') {\n // rule matches any variable thing (not a ConstantNode)\n if (!(0, _is.isConstantNode)(node)) {\n res[0].placeholders[rule.name] = node;\n } else {\n // Mis-match: rule was expecting something other than a ConstantNode\n return [];\n }\n } else if (rule.name[0] === 'c') {\n // rule matches any ConstantNode\n if (node instanceof ConstantNode) {\n res[0].placeholders[rule.name] = node;\n } else {\n // Mis-match: rule was expecting a ConstantNode\n return [];\n }\n } else {\n throw new Error('Invalid symbol in rule: ' + rule.name);\n }\n } else if (rule instanceof ConstantNode) {\n // Literal constant must match exactly\n if (!equal(rule.value, node.value)) {\n return [];\n }\n } else {\n // Some other node was encountered which we aren't prepared for, so no match\n return [];\n } // It's a match!\n // console.log('_ruleMatch(' + rule.toString() + ', ' + node.toString() + ') found a match')\n\n\n return res;\n }\n /**\n * Determines whether p and q (and all their children nodes) are identical.\n *\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} p\n * @param {ConstantNode | SymbolNode | ParenthesisNode | FunctionNode | OperatorNode} q\n * @return {Object} Information about the match, if it exists.\n */\n\n\n function _exactMatch(p, q) {\n if (p instanceof ConstantNode && q instanceof ConstantNode) {\n if (!equal(p.value, q.value)) {\n return false;\n }\n } else if (p instanceof SymbolNode && q instanceof SymbolNode) {\n if (p.name !== q.name) {\n return false;\n }\n } else if (p instanceof OperatorNode && q instanceof OperatorNode || p instanceof FunctionNode && q instanceof FunctionNode) {\n if (p instanceof OperatorNode) {\n if (p.op !== q.op || p.fn !== q.fn) {\n return false;\n }\n } else if (p instanceof FunctionNode) {\n if (p.name !== q.name) {\n return false;\n }\n }\n\n if (p.args.length !== q.args.length) {\n return false;\n }\n\n for (var i = 0; i < p.args.length; i++) {\n if (!_exactMatch(p.args[i], q.args[i])) {\n return false;\n }\n }\n } else {\n return false;\n }\n\n return true;\n }\n\n return simplify;\n});\nexports.createSimplify = createSimplify;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSimplifyConstant = void 0;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _is = require(\"../../../utils/is.js\");\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _util = require(\"./util.js\");\n\nvar _noop = require(\"../../../utils/noop.js\");\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { 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 = it.call(o); }, 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\nvar name = 'simplifyConstant';\nvar dependencies = ['typed', 'config', 'mathWithTransform', 'matrix', '?fraction', '?bignumber', 'AccessorNode', 'ArrayNode', 'ConstantNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'SymbolNode'];\nvar createSimplifyConstant = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n mathWithTransform = _ref.mathWithTransform,\n matrix = _ref.matrix,\n fraction = _ref.fraction,\n bignumber = _ref.bignumber,\n AccessorNode = _ref.AccessorNode,\n ArrayNode = _ref.ArrayNode,\n ConstantNode = _ref.ConstantNode,\n FunctionNode = _ref.FunctionNode,\n IndexNode = _ref.IndexNode,\n ObjectNode = _ref.ObjectNode,\n OperatorNode = _ref.OperatorNode,\n SymbolNode = _ref.SymbolNode;\n\n var _createUtil = (0, _util.createUtil)({\n FunctionNode: FunctionNode,\n OperatorNode: OperatorNode,\n SymbolNode: SymbolNode\n }),\n isCommutative = _createUtil.isCommutative,\n isAssociative = _createUtil.isAssociative,\n allChildren = _createUtil.allChildren,\n createMakeNodeFunction = _createUtil.createMakeNodeFunction;\n\n function simplifyConstant(expr, options) {\n return _ensureNode(foldFraction(expr, options));\n }\n\n function _removeFractions(thing) {\n if ((0, _is.isFraction)(thing)) {\n return thing.valueOf();\n }\n\n if (thing instanceof Array) {\n return thing.map(_removeFractions);\n }\n\n if ((0, _is.isMatrix)(thing)) {\n return matrix(_removeFractions(thing.valueOf()));\n }\n\n return thing;\n }\n\n function _eval(fnname, args, options) {\n try {\n return mathWithTransform[fnname].apply(null, args);\n } catch (ignore) {\n // sometimes the implicit type conversion causes the evaluation to fail, so we'll try again after removing Fractions\n args = args.map(_removeFractions);\n return _toNumber(mathWithTransform[fnname].apply(null, args), options);\n }\n }\n\n var _toNode = typed({\n Fraction: _fractionToNode,\n number: function number(n) {\n if (n < 0) {\n return unaryMinusNode(new ConstantNode(-n));\n }\n\n return new ConstantNode(n);\n },\n BigNumber: function BigNumber(n) {\n if (n < 0) {\n return unaryMinusNode(new ConstantNode(-n));\n }\n\n return new ConstantNode(n); // old parameters: (n.toString(), 'number')\n },\n Complex: function Complex(s) {\n throw new Error('Cannot convert Complex number to Node');\n },\n string: function string(s) {\n return new ConstantNode(s);\n },\n Matrix: function Matrix(m) {\n return new ArrayNode(m.valueOf().map(function (e) {\n return _toNode(e);\n }));\n }\n });\n\n function _ensureNode(thing) {\n if ((0, _is.isNode)(thing)) {\n return thing;\n }\n\n return _toNode(thing);\n } // convert a number to a fraction only if it can be expressed exactly,\n // and when both numerator and denominator are small enough\n\n\n function _exactFraction(n, options) {\n var exactFractions = options && options.exactFractions !== false;\n\n if (exactFractions && isFinite(n) && fraction) {\n var f = fraction(n);\n var fractionsLimit = options && typeof options.fractionsLimit === 'number' ? options.fractionsLimit : Infinity; // no limit by default\n\n if (f.valueOf() === n && f.n < fractionsLimit && f.d < fractionsLimit) {\n return f;\n }\n }\n\n return n;\n } // Convert numbers to a preferred number type in preference order: Fraction, number, Complex\n // BigNumbers are left alone\n\n\n var _toNumber = typed({\n 'string, Object': function stringObject(s, options) {\n if (config.number === 'BigNumber') {\n if (bignumber === undefined) {\n (0, _noop.noBignumber)();\n }\n\n return bignumber(s);\n } else if (config.number === 'Fraction') {\n if (fraction === undefined) {\n (0, _noop.noFraction)();\n }\n\n return fraction(s);\n } else {\n var n = parseFloat(s);\n return _exactFraction(n, options);\n }\n },\n 'Fraction, Object': function FractionObject(s, options) {\n return s;\n },\n // we don't need options here\n 'BigNumber, Object': function BigNumberObject(s, options) {\n return s;\n },\n // we don't need options here\n 'number, Object': function numberObject(s, options) {\n return _exactFraction(s, options);\n },\n 'Complex, Object': function ComplexObject(s, options) {\n if (s.im !== 0) {\n return s;\n }\n\n return _exactFraction(s.re, options);\n },\n 'Matrix, Object': function MatrixObject(s, options) {\n return matrix(_exactFraction(s.valueOf()));\n },\n 'Array, Object': function ArrayObject(s, options) {\n return s.map(_exactFraction);\n }\n });\n\n function unaryMinusNode(n) {\n return new OperatorNode('-', 'unaryMinus', [n]);\n }\n\n function _fractionToNode(f) {\n var n;\n var vn = f.s * f.n;\n\n if (vn < 0) {\n n = new OperatorNode('-', 'unaryMinus', [new ConstantNode(-vn)]);\n } else {\n n = new ConstantNode(vn);\n }\n\n if (f.d === 1) {\n return n;\n }\n\n return new OperatorNode('/', 'divide', [n, new ConstantNode(f.d)]);\n }\n /* Handles constant indexing of ArrayNodes, matrices, and ObjectNodes */\n\n\n function _foldAccessor(obj, index, options) {\n if (!(0, _is.isIndexNode)(index)) {\n // don't know what to do with that...\n return new AccessorNode(_ensureNode(obj), _ensureNode(index));\n }\n\n if ((0, _is.isArrayNode)(obj) || (0, _is.isMatrix)(obj)) {\n var remainingDims = Array.from(index.dimensions);\n /* We will resolve constant indices one at a time, looking\n * just in the first or second dimensions because (a) arrays\n * of more than two dimensions are likely rare, and (b) pulling\n * out the third or higher dimension would be pretty intricate.\n * The price is that we miss simplifying [..3d array][x,y,1]\n */\n\n while (remainingDims.length > 0) {\n if ((0, _is.isConstantNode)(remainingDims[0]) && typeof remainingDims[0].value !== 'string') {\n var first = _toNumber(remainingDims.shift().value, options);\n\n if ((0, _is.isArrayNode)(obj)) {\n obj = obj.items[first - 1];\n } else {\n // matrix\n obj = obj.valueOf()[first - 1];\n\n if (obj instanceof Array) {\n obj = matrix(obj);\n }\n }\n } else if (remainingDims.length > 1 && (0, _is.isConstantNode)(remainingDims[1]) && typeof remainingDims[1].value !== 'string') {\n var second = _toNumber(remainingDims[1].value, options);\n\n var tryItems = [];\n var fromItems = (0, _is.isArrayNode)(obj) ? obj.items : obj.valueOf();\n\n var _iterator = _createForOfIteratorHelper(fromItems),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var item = _step.value;\n\n if ((0, _is.isArrayNode)(item)) {\n tryItems.push(item.items[second - 1]);\n } else if ((0, _is.isMatrix)(obj)) {\n tryItems.push(item[second - 1]);\n } else {\n break;\n }\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n if (tryItems.length === fromItems.length) {\n if ((0, _is.isArrayNode)(obj)) {\n obj = new ArrayNode(tryItems);\n } else {\n // matrix\n obj = matrix(tryItems);\n }\n\n remainingDims.splice(1, 1);\n } else {\n // extracting slice along 2nd dimension failed, give up\n break;\n }\n } else {\n // neither 1st or 2nd dimension is constant, give up\n break;\n }\n }\n\n if (remainingDims.length === index.dimensions.length) {\n /* No successful constant indexing */\n return new AccessorNode(_ensureNode(obj), index);\n }\n\n if (remainingDims.length > 0) {\n /* Indexed some but not all dimensions */\n index = new IndexNode(remainingDims);\n return new AccessorNode(_ensureNode(obj), index);\n }\n /* All dimensions were constant, access completely resolved */\n\n\n return obj;\n }\n\n if ((0, _is.isObjectNode)(obj) && index.dimensions.length === 1 && (0, _is.isConstantNode)(index.dimensions[0])) {\n var key = index.dimensions[0].value;\n\n if (key in obj.properties) {\n return obj.properties[key];\n }\n\n return new ConstantNode(); // undefined\n }\n /* Don't know how to index this sort of obj, at least not with this index */\n\n\n return new AccessorNode(_ensureNode(obj), index);\n }\n /*\n * Create a binary tree from a list of Fractions and Nodes.\n * Tries to fold Fractions by evaluating them until the first Node in the list is hit, so\n * `args` should be sorted to have the Fractions at the start (if the operator is commutative).\n * @param args - list of Fractions and Nodes\n * @param fn - evaluator for the binary operation evaluator that accepts two Fractions\n * @param makeNode - creates a binary OperatorNode/FunctionNode from a list of child Nodes\n * if args.length is 1, returns args[0]\n * @return - Either a Node representing a binary expression or Fraction\n */\n\n\n function foldOp(fn, args, makeNode, options) {\n return args.reduce(function (a, b) {\n if (!(0, _is.isNode)(a) && !(0, _is.isNode)(b)) {\n try {\n return _eval(fn, [a, b], options);\n } catch (ignoreandcontinue) {}\n\n a = _toNode(a);\n b = _toNode(b);\n } else if (!(0, _is.isNode)(a)) {\n a = _toNode(a);\n } else if (!(0, _is.isNode)(b)) {\n b = _toNode(b);\n }\n\n return makeNode([a, b]);\n });\n } // destroys the original node and returns a folded one\n\n\n function foldFraction(node, options) {\n switch (node.type) {\n case 'SymbolNode':\n return node;\n\n case 'ConstantNode':\n switch ((0, _typeof2.default)(node.value)) {\n case 'number':\n return _toNumber(node.value, options);\n\n case 'string':\n return node.value;\n\n default:\n if (!isNaN(node.value)) return _toNumber(node.value, options);\n }\n\n return node;\n\n case 'FunctionNode':\n if (mathWithTransform[node.name] && mathWithTransform[node.name].rawArgs) {\n return node;\n }\n\n {\n // Process operators as OperatorNode\n var operatorFunctions = ['add', 'multiply'];\n\n if (operatorFunctions.indexOf(node.name) === -1) {\n var args = node.args.map(function (arg) {\n return foldFraction(arg, options);\n }); // If all args are numbers\n\n if (!args.some(_is.isNode)) {\n try {\n return _eval(node.name, args, options);\n } catch (ignoreandcontinue) {}\n } // Size of a matrix does not depend on entries\n\n\n if (node.name === 'size' && args.length === 1 && (0, _is.isArrayNode)(args[0])) {\n var sz = [];\n var section = args[0];\n\n while ((0, _is.isArrayNode)(section)) {\n sz.push(section.items.length);\n section = section.items[0];\n }\n\n return matrix(sz);\n } // Convert all args to nodes and construct a symbolic function call\n\n\n return new FunctionNode(node.name, args.map(_ensureNode));\n } else {// treat as operator\n }\n }\n\n /* falls through */\n\n case 'OperatorNode':\n {\n var fn = node.fn.toString();\n\n var _args;\n\n var res;\n var makeNode = createMakeNodeFunction(node);\n\n if ((0, _is.isOperatorNode)(node) && node.isUnary()) {\n _args = [foldFraction(node.args[0], options)];\n\n if (!(0, _is.isNode)(_args[0])) {\n res = _eval(fn, _args, options);\n } else {\n res = makeNode(_args);\n }\n } else if (isAssociative(node, options.context)) {\n _args = allChildren(node, options.context);\n _args = _args.map(function (arg) {\n return foldFraction(arg, options);\n });\n\n if (isCommutative(fn, options.context)) {\n // commutative binary operator\n var consts = [];\n var vars = [];\n\n for (var i = 0; i < _args.length; i++) {\n if (!(0, _is.isNode)(_args[i])) {\n consts.push(_args[i]);\n } else {\n vars.push(_args[i]);\n }\n }\n\n if (consts.length > 1) {\n res = foldOp(fn, consts, makeNode, options);\n vars.unshift(res);\n res = foldOp(fn, vars, makeNode, options);\n } else {\n // we won't change the children order since it's not neccessary\n res = foldOp(fn, _args, makeNode, options);\n }\n } else {\n // non-commutative binary operator\n res = foldOp(fn, _args, makeNode, options);\n }\n } else {\n // non-associative binary operator\n _args = node.args.map(function (arg) {\n return foldFraction(arg, options);\n });\n res = foldOp(fn, _args, makeNode, options);\n }\n\n return res;\n }\n\n case 'ParenthesisNode':\n // remove the uneccessary parenthesis\n return foldFraction(node.content, options);\n\n case 'AccessorNode':\n return _foldAccessor(foldFraction(node.object, options), foldFraction(node.index, options), options);\n\n case 'ArrayNode':\n {\n var foldItems = node.items.map(function (item) {\n return foldFraction(item, options);\n });\n\n if (foldItems.some(_is.isNode)) {\n return new ArrayNode(foldItems.map(_ensureNode));\n }\n /* All literals -- return a Matrix so we can operate on it */\n\n\n return matrix(foldItems);\n }\n\n case 'IndexNode':\n {\n return new IndexNode(node.dimensions.map(function (n) {\n return simplifyConstant(n, options);\n }));\n }\n\n case 'ObjectNode':\n {\n var foldProps = {};\n\n for (var prop in node.properties) {\n foldProps[prop] = simplifyConstant(node.properties[prop], options);\n }\n\n return new ObjectNode(foldProps);\n }\n\n case 'AssignmentNode':\n /* falls through */\n\n case 'BlockNode':\n /* falls through */\n\n case 'FunctionAssignmentNode':\n /* falls through */\n\n case 'RangeNode':\n /* falls through */\n\n case 'ConditionalNode':\n /* falls through */\n\n default:\n throw new Error(\"Unimplemented node type in simplifyConstant: \".concat(node.type));\n }\n }\n\n return simplifyConstant;\n});\nexports.createSimplifyConstant = createSimplifyConstant;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createUtil = void 0;\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _is = require(\"../../../utils/is.js\");\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _object = require(\"../../../utils/object.js\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); 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 = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nvar name = 'simplifyUtil';\nvar dependencies = ['FunctionNode', 'OperatorNode', 'SymbolNode'];\nvar createUtil = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var FunctionNode = _ref.FunctionNode,\n OperatorNode = _ref.OperatorNode,\n SymbolNode = _ref.SymbolNode;\n // TODO commutative/associative properties rely on the arguments\n // e.g. multiply is not commutative for matrices\n // The properties should be calculated from an argument to simplify, or possibly something in math.config\n // the other option is for typed() to specify a return type so that we can evaluate the type of arguments\n\n /* So that properties of an operator fit on one line: */\n var T = true;\n var F = false;\n var defaultName = 'defaultF';\n var defaultContext = {\n /* */\n add: {\n trivial: T,\n total: T,\n commutative: T,\n associative: T\n },\n\n /**/\n unaryPlus: {\n trivial: T,\n total: T,\n commutative: T,\n associative: T\n },\n\n /* */\n subtract: {\n trivial: F,\n total: T,\n commutative: F,\n associative: F\n },\n\n /* */\n multiply: {\n trivial: T,\n total: T,\n commutative: T,\n associative: T\n },\n\n /* */\n divide: {\n trivial: F,\n total: T,\n commutative: F,\n associative: F\n },\n\n /* */\n paren: {\n trivial: T,\n total: T,\n commutative: T,\n associative: F\n },\n\n /* */\n defaultF: {\n trivial: F,\n total: T,\n commutative: F,\n associative: F\n }\n };\n var realContext = {\n divide: {\n total: F\n },\n log: {\n total: F\n }\n };\n var positiveContext = {\n subtract: {\n total: F\n },\n abs: {\n trivial: T\n },\n log: {\n total: T\n }\n };\n\n function hasProperty(nodeOrName, property) {\n var context = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : defaultContext;\n var name = defaultName;\n\n if (typeof nodeOrName === 'string') {\n name = nodeOrName;\n } else if ((0, _is.isOperatorNode)(nodeOrName)) {\n name = nodeOrName.fn.toString();\n } else if ((0, _is.isFunctionNode)(nodeOrName)) {\n name = nodeOrName.name;\n } else if ((0, _is.isParenthesisNode)(nodeOrName)) {\n name = 'paren';\n }\n\n if ((0, _object.hasOwnProperty)(context, name)) {\n var properties = context[name];\n\n if ((0, _object.hasOwnProperty)(properties, property)) {\n return properties[property];\n }\n\n if ((0, _object.hasOwnProperty)(defaultContext, name)) {\n return defaultContext[name][property];\n }\n }\n\n if ((0, _object.hasOwnProperty)(context, defaultName)) {\n var _properties = context[defaultName];\n\n if ((0, _object.hasOwnProperty)(_properties, property)) {\n return _properties[property];\n }\n\n return defaultContext[defaultName][property];\n }\n /* name not found in context and context has no global default */\n\n /* So use default context. */\n\n\n if ((0, _object.hasOwnProperty)(defaultContext, name)) {\n var _properties2 = defaultContext[name];\n\n if ((0, _object.hasOwnProperty)(_properties2, property)) {\n return _properties2[property];\n }\n }\n\n return defaultContext[defaultName][property];\n }\n\n function isCommutative(node) {\n var context = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultContext;\n return hasProperty(node, 'commutative', context);\n }\n\n function isAssociative(node) {\n var context = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultContext;\n return hasProperty(node, 'associative', context);\n }\n /**\n * Merge the given contexts, with primary overriding secondary\n * wherever they might conflict\n */\n\n\n function mergeContext(primary, secondary) {\n var merged = _objectSpread({}, primary);\n\n for (var prop in secondary) {\n if ((0, _object.hasOwnProperty)(primary, prop)) {\n merged[prop] = _objectSpread(_objectSpread({}, secondary[prop]), primary[prop]);\n } else {\n merged[prop] = secondary[prop];\n }\n }\n\n return merged;\n }\n /**\n * Flatten all associative operators in an expression tree.\n * Assumes parentheses have already been removed.\n */\n\n\n function flatten(node, context) {\n if (!node.args || node.args.length === 0) {\n return node;\n }\n\n node.args = allChildren(node, context);\n\n for (var i = 0; i < node.args.length; i++) {\n flatten(node.args[i], context);\n }\n }\n /**\n * Get the children of a node as if it has been flattened.\n * TODO implement for FunctionNodes\n */\n\n\n function allChildren(node, context) {\n var op;\n var children = [];\n\n var findChildren = function findChildren(node) {\n for (var i = 0; i < node.args.length; i++) {\n var child = node.args[i];\n\n if ((0, _is.isOperatorNode)(child) && op === child.op) {\n findChildren(child);\n } else {\n children.push(child);\n }\n }\n };\n\n if (isAssociative(node, context)) {\n op = node.op;\n findChildren(node);\n return children;\n } else {\n return node.args;\n }\n }\n /**\n * Unflatten all flattened operators to a right-heavy binary tree.\n */\n\n\n function unflattenr(node, context) {\n if (!node.args || node.args.length === 0) {\n return;\n }\n\n var makeNode = createMakeNodeFunction(node);\n var l = node.args.length;\n\n for (var i = 0; i < l; i++) {\n unflattenr(node.args[i], context);\n }\n\n if (l > 2 && isAssociative(node, context)) {\n var curnode = node.args.pop();\n\n while (node.args.length > 0) {\n curnode = makeNode([node.args.pop(), curnode]);\n }\n\n node.args = curnode.args;\n }\n }\n /**\n * Unflatten all flattened operators to a left-heavy binary tree.\n */\n\n\n function unflattenl(node, context) {\n if (!node.args || node.args.length === 0) {\n return;\n }\n\n var makeNode = createMakeNodeFunction(node);\n var l = node.args.length;\n\n for (var i = 0; i < l; i++) {\n unflattenl(node.args[i], context);\n }\n\n if (l > 2 && isAssociative(node, context)) {\n var curnode = node.args.shift();\n\n while (node.args.length > 0) {\n curnode = makeNode([curnode, node.args.shift()]);\n }\n\n node.args = curnode.args;\n }\n }\n\n function createMakeNodeFunction(node) {\n if ((0, _is.isOperatorNode)(node)) {\n return function (args) {\n try {\n return new OperatorNode(node.op, node.fn, args, node.implicit);\n } catch (err) {\n console.error(err);\n return [];\n }\n };\n } else {\n return function (args) {\n return new FunctionNode(new SymbolNode(node.name), args);\n };\n }\n }\n\n return {\n createMakeNodeFunction: createMakeNodeFunction,\n hasProperty: hasProperty,\n isCommutative: isCommutative,\n isAssociative: isAssociative,\n mergeContext: mergeContext,\n flatten: flatten,\n allChildren: allChildren,\n unflattenr: unflattenr,\n unflattenl: unflattenl,\n defaultContext: defaultContext,\n realContext: realContext,\n positiveContext: positiveContext\n };\n});\nexports.createUtil = createUtil;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSimplifyCore = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _util = require(\"./simplify/util.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'simplifyCore';\nvar dependencies = ['equal', 'isZero', 'add', 'subtract', 'multiply', 'divide', 'pow', 'AccessorNode', 'ArrayNode', 'ConstantNode', 'FunctionNode', 'IndexNode', 'ObjectNode', 'OperatorNode', 'ParenthesisNode', 'SymbolNode'];\nvar createSimplifyCore = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var equal = _ref.equal,\n isZero = _ref.isZero,\n add = _ref.add,\n subtract = _ref.subtract,\n multiply = _ref.multiply,\n divide = _ref.divide,\n pow = _ref.pow,\n AccessorNode = _ref.AccessorNode,\n ArrayNode = _ref.ArrayNode,\n ConstantNode = _ref.ConstantNode,\n FunctionNode = _ref.FunctionNode,\n IndexNode = _ref.IndexNode,\n ObjectNode = _ref.ObjectNode,\n OperatorNode = _ref.OperatorNode,\n ParenthesisNode = _ref.ParenthesisNode,\n SymbolNode = _ref.SymbolNode;\n var node0 = new ConstantNode(0);\n var node1 = new ConstantNode(1);\n\n var _createUtil = (0, _util.createUtil)({\n FunctionNode: FunctionNode,\n OperatorNode: OperatorNode,\n SymbolNode: SymbolNode\n }),\n hasProperty = _createUtil.hasProperty,\n isCommutative = _createUtil.isCommutative;\n /**\n * simplifyCore() performs single pass simplification suitable for\n * applications requiring ultimate performance. In contrast, simplify()\n * extends simplifyCore() with additional passes to provide deeper\n * simplification.\n *\n * Syntax:\n *\n * simplifyCore(expr)\n *\n * Examples:\n *\n * const f = math.parse('2 * 1 * x ^ (2 - 1)')\n * math.simpifyCore(f) // Node {2 * x}\n * math.simplify('2 * 1 * x ^ (2 - 1)', [math.simplifyCore]) // Node {2 * x}\n *\n * See also:\n *\n * simplify, resolve, derivative\n *\n * @param {Node} node\n * The expression to be simplified\n * @param {Object} options\n * Simplification options, as per simplify()\n * @return {Node} Returns expression with basic simplifications applied\n */\n\n\n function simplifyCore(node, options) {\n var context = options ? options.context : undefined;\n\n if (hasProperty(node, 'trivial', context)) {\n // This node does nothing if it has only one argument, so if so,\n // return that argument simplified\n if ((0, _is.isFunctionNode)(node) && node.args.length === 1) {\n return simplifyCore(node.args[0], options);\n } // For other node types, we try the generic methods\n\n\n var simpChild = false;\n var childCount = 0;\n node.forEach(function (c) {\n ++childCount;\n\n if (childCount === 1) {\n simpChild = simplifyCore(c, options);\n }\n });\n\n if (childCount === 1) {\n return simpChild;\n }\n }\n\n if ((0, _is.isOperatorNode)(node) && node.isUnary()) {\n var a0 = simplifyCore(node.args[0], options);\n\n if (node.op === '-') {\n // unary minus\n if ((0, _is.isOperatorNode)(a0)) {\n if (a0.isUnary() && a0.op === '-') {\n return a0.args[0];\n } else if (a0.isBinary() && a0.fn === 'subtract') {\n return new OperatorNode('-', 'subtract', [a0.args[1], a0.args[0]]);\n }\n }\n\n return new OperatorNode(node.op, node.fn, [a0]);\n }\n } else if ((0, _is.isOperatorNode)(node) && node.isBinary()) {\n var _a = simplifyCore(node.args[0], options);\n\n var a1 = simplifyCore(node.args[1], options);\n\n if (node.op === '+') {\n if ((0, _is.isConstantNode)(_a)) {\n if (isZero(_a.value)) {\n return a1;\n } else if ((0, _is.isConstantNode)(a1)) {\n return new ConstantNode(add(_a.value, a1.value));\n }\n }\n\n if ((0, _is.isConstantNode)(a1) && isZero(a1.value)) {\n return _a;\n }\n\n if ((0, _is.isOperatorNode)(a1) && a1.isUnary() && a1.op === '-') {\n return new OperatorNode('-', 'subtract', [_a, a1.args[0]]);\n }\n\n return new OperatorNode(node.op, node.fn, a1 ? [_a, a1] : [_a]);\n } else if (node.op === '-') {\n if ((0, _is.isConstantNode)(_a) && a1) {\n if ((0, _is.isConstantNode)(a1)) {\n return new ConstantNode(subtract(_a.value, a1.value));\n } else if (isZero(_a.value)) {\n return new OperatorNode('-', 'unaryMinus', [a1]);\n }\n } // if (node.fn === \"subtract\" && node.args.length === 2) {\n\n\n if (node.fn === 'subtract') {\n if ((0, _is.isConstantNode)(a1) && isZero(a1.value)) {\n return _a;\n }\n\n if ((0, _is.isOperatorNode)(a1) && a1.isUnary() && a1.op === '-') {\n return simplifyCore(new OperatorNode('+', 'add', [_a, a1.args[0]]), options);\n }\n\n return new OperatorNode(node.op, node.fn, [_a, a1]);\n }\n } else if (node.op === '*') {\n if ((0, _is.isConstantNode)(_a)) {\n if (isZero(_a.value)) {\n return node0;\n } else if (equal(_a.value, 1)) {\n return a1;\n } else if ((0, _is.isConstantNode)(a1)) {\n return new ConstantNode(multiply(_a.value, a1.value));\n }\n }\n\n if ((0, _is.isConstantNode)(a1)) {\n if (isZero(a1.value)) {\n return node0;\n } else if (equal(a1.value, 1)) {\n return _a;\n } else if ((0, _is.isOperatorNode)(_a) && _a.isBinary() && _a.op === node.op && isCommutative(node, context)) {\n var a00 = _a.args[0];\n\n if ((0, _is.isConstantNode)(a00)) {\n var a00a1 = new ConstantNode(multiply(a00.value, a1.value));\n return new OperatorNode(node.op, node.fn, [a00a1, _a.args[1]], node.implicit); // constants on left\n }\n }\n\n if (isCommutative(node, context)) {\n return new OperatorNode(node.op, node.fn, [a1, _a], node.implicit); // constants on left\n } else {\n return new OperatorNode(node.op, node.fn, [_a, a1], node.implicit);\n }\n }\n\n return new OperatorNode(node.op, node.fn, [_a, a1], node.implicit);\n } else if (node.op === '/') {\n if ((0, _is.isConstantNode)(_a)) {\n if (isZero(_a.value)) {\n return node0;\n } else if ((0, _is.isConstantNode)(a1) && (equal(a1.value, 1) || equal(a1.value, 2) || equal(a1.value, 4))) {\n return new ConstantNode(divide(_a.value, a1.value));\n }\n }\n\n return new OperatorNode(node.op, node.fn, [_a, a1]);\n } else if (node.op === '^') {\n if ((0, _is.isConstantNode)(a1)) {\n if (isZero(a1.value)) {\n return node1;\n } else if (equal(a1.value, 1)) {\n return _a;\n } else {\n if ((0, _is.isConstantNode)(_a)) {\n // fold constant\n return new ConstantNode(pow(_a.value, a1.value));\n } else if ((0, _is.isOperatorNode)(_a) && _a.isBinary() && _a.op === '^') {\n var a01 = _a.args[1];\n\n if ((0, _is.isConstantNode)(a01)) {\n return new OperatorNode(node.op, node.fn, [_a.args[0], new ConstantNode(multiply(a01.value, a1.value))]);\n }\n }\n }\n }\n }\n\n return new OperatorNode(node.op, node.fn, [_a, a1]);\n } else if ((0, _is.isFunctionNode)(node)) {\n return new FunctionNode(simplifyCore(node.fn), node.args.map(function (n) {\n return simplifyCore(n, options);\n }));\n } else if ((0, _is.isArrayNode)(node)) {\n return new ArrayNode(node.items.map(function (n) {\n return simplifyCore(n, options);\n }));\n } else if ((0, _is.isAccessorNode)(node)) {\n return new AccessorNode(simplifyCore(node.object, options), simplifyCore(node.index, options));\n } else if ((0, _is.isIndexNode)(node)) {\n return new IndexNode(node.dimensions.map(function (n) {\n return simplifyCore(n, options);\n }));\n } else if ((0, _is.isObjectNode)(node)) {\n var newProps = {};\n\n for (var prop in node.properties) {\n newProps[prop] = simplifyCore(node.properties[prop], options);\n }\n\n return new ObjectNode(newProps);\n } else {// cannot simplify\n }\n\n return node;\n }\n\n return simplifyCore;\n});\nexports.createSimplifyCore = createSimplifyCore;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLsolve = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _solveValidation = require(\"./utils/solveValidation.js\");\n\nvar name = 'lsolve';\nvar dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtract', 'equalScalar', 'DenseMatrix'];\nvar createLsolve = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n divideScalar = _ref.divideScalar,\n multiplyScalar = _ref.multiplyScalar,\n subtract = _ref.subtract,\n equalScalar = _ref.equalScalar,\n DenseMatrix = _ref.DenseMatrix;\n var solveValidation = (0, _solveValidation.createSolveValidation)({\n DenseMatrix: DenseMatrix\n });\n /**\n * Finds one solution of a linear equation system by forwards substitution. Matrix must be a lower triangular matrix. Throws an error if there's no solution.\n *\n * `L * x = b`\n *\n * Syntax:\n *\n * math.lsolve(L, b)\n *\n * Examples:\n *\n * const a = [[-2, 3], [2, 1]]\n * const b = [11, 9]\n * const x = lsolve(a, b) // [[-5.5], [20]]\n *\n * See also:\n *\n * lsolveAll, lup, slu, usolve, lusolve\n *\n * @param {Matrix, Array} L A N x N matrix or array (L)\n * @param {Matrix, Array} b A column vector with the b values\n *\n * @return {DenseMatrix | Array} A column vector with the linear system solution (x)\n */\n\n return typed(name, {\n 'SparseMatrix, Array | Matrix': function SparseMatrixArrayMatrix(m, b) {\n return _sparseForwardSubstitution(m, b);\n },\n 'DenseMatrix, Array | Matrix': function DenseMatrixArrayMatrix(m, b) {\n return _denseForwardSubstitution(m, b);\n },\n 'Array, Array | Matrix': function ArrayArrayMatrix(a, b) {\n var m = matrix(a);\n\n var r = _denseForwardSubstitution(m, b);\n\n return r.valueOf();\n }\n });\n\n function _denseForwardSubstitution(m, b) {\n // validate matrix and vector, return copy of column vector b\n b = solveValidation(m, b, true);\n var bdata = b._data;\n var rows = m._size[0];\n var columns = m._size[1]; // result\n\n var x = [];\n var mdata = m._data; // loop columns\n\n for (var j = 0; j < columns; j++) {\n var bj = bdata[j][0] || 0;\n var xj = void 0;\n\n if (!equalScalar(bj, 0)) {\n // non-degenerate row, find solution\n var vjj = mdata[j][j];\n\n if (equalScalar(vjj, 0)) {\n throw new Error('Linear system cannot be solved since matrix is singular');\n }\n\n xj = divideScalar(bj, vjj); // loop rows\n\n for (var i = j + 1; i < rows; i++) {\n bdata[i] = [subtract(bdata[i][0] || 0, multiplyScalar(xj, mdata[i][j]))];\n }\n } else {\n // degenerate row, we can choose any value\n xj = 0;\n }\n\n x[j] = [xj];\n }\n\n return new DenseMatrix({\n data: x,\n size: [rows, 1]\n });\n }\n\n function _sparseForwardSubstitution(m, b) {\n // validate matrix and vector, return copy of column vector b\n b = solveValidation(m, b, true);\n var bdata = b._data;\n var rows = m._size[0];\n var columns = m._size[1];\n var values = m._values;\n var index = m._index;\n var ptr = m._ptr; // result\n\n var x = []; // loop columns\n\n for (var j = 0; j < columns; j++) {\n var bj = bdata[j][0] || 0;\n\n if (!equalScalar(bj, 0)) {\n // non-degenerate row, find solution\n var vjj = 0; // matrix values & indices (column j)\n\n var jValues = [];\n var jIndices = []; // first and last index in the column\n\n var firstIndex = ptr[j];\n var lastIndex = ptr[j + 1]; // values in column, find value at [j, j]\n\n for (var k = firstIndex; k < lastIndex; k++) {\n var i = index[k]; // check row (rows are not sorted!)\n\n if (i === j) {\n vjj = values[k];\n } else if (i > j) {\n // store lower triangular\n jValues.push(values[k]);\n jIndices.push(i);\n }\n } // at this point we must have a value in vjj\n\n\n if (equalScalar(vjj, 0)) {\n throw new Error('Linear system cannot be solved since matrix is singular');\n }\n\n var xj = divideScalar(bj, vjj);\n\n for (var _k = 0, l = jIndices.length; _k < l; _k++) {\n var _i = jIndices[_k];\n bdata[_i] = [subtract(bdata[_i][0] || 0, multiplyScalar(xj, jValues[_k]))];\n }\n\n x[j] = [xj];\n } else {\n // degenerate row, we can choose any value\n x[j] = [0];\n }\n }\n\n return new DenseMatrix({\n data: x,\n size: [rows, 1]\n });\n }\n});\nexports.createLsolve = createLsolve;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLsolveAll = void 0;\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _solveValidation = require(\"./utils/solveValidation.js\");\n\nvar name = 'lsolveAll';\nvar dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtract', 'equalScalar', 'DenseMatrix'];\nvar createLsolveAll = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n divideScalar = _ref.divideScalar,\n multiplyScalar = _ref.multiplyScalar,\n subtract = _ref.subtract,\n equalScalar = _ref.equalScalar,\n DenseMatrix = _ref.DenseMatrix;\n var solveValidation = (0, _solveValidation.createSolveValidation)({\n DenseMatrix: DenseMatrix\n });\n /**\n * Finds all solutions of a linear equation system by forwards substitution. Matrix must be a lower triangular matrix.\n *\n * `L * x = b`\n *\n * Syntax:\n *\n * math.lsolveAll(L, b)\n *\n * Examples:\n *\n * const a = [[-2, 3], [2, 1]]\n * const b = [11, 9]\n * const x = lsolveAll(a, b) // [ [[-5.5], [20]] ]\n *\n * See also:\n *\n * lsolve, lup, slu, usolve, lusolve\n *\n * @param {Matrix, Array} L A N x N matrix or array (L)\n * @param {Matrix, Array} b A column vector with the b values\n *\n * @return {DenseMatrix[] | Array[]} An array of affine-independent column vectors (x) that solve the linear system\n */\n\n return typed(name, {\n 'SparseMatrix, Array | Matrix': function SparseMatrixArrayMatrix(m, b) {\n return _sparseForwardSubstitution(m, b);\n },\n 'DenseMatrix, Array | Matrix': function DenseMatrixArrayMatrix(m, b) {\n return _denseForwardSubstitution(m, b);\n },\n 'Array, Array | Matrix': function ArrayArrayMatrix(a, b) {\n var m = matrix(a);\n\n var R = _denseForwardSubstitution(m, b);\n\n return R.map(function (r) {\n return r.valueOf();\n });\n }\n });\n\n function _denseForwardSubstitution(m, b_) {\n // the algorithm is derived from\n // https://www.overleaf.com/read/csvgqdxggyjv\n // array of right-hand sides\n var B = [solveValidation(m, b_, true)._data.map(function (e) {\n return e[0];\n })];\n var M = m._data;\n var rows = m._size[0];\n var columns = m._size[1]; // loop columns\n\n for (var i = 0; i < columns; i++) {\n var L = B.length; // loop right-hand sides\n\n for (var k = 0; k < L; k++) {\n var b = B[k];\n\n if (!equalScalar(M[i][i], 0)) {\n // non-singular row\n b[i] = divideScalar(b[i], M[i][i]);\n\n for (var j = i + 1; j < columns; j++) {\n // b[j] -= b[i] * M[j,i]\n b[j] = subtract(b[j], multiplyScalar(b[i], M[j][i]));\n }\n } else if (!equalScalar(b[i], 0)) {\n // singular row, nonzero RHS\n if (k === 0) {\n // There is no valid solution\n return [];\n } else {\n // This RHS is invalid but other solutions may still exist\n B.splice(k, 1);\n k -= 1;\n L -= 1;\n }\n } else if (k === 0) {\n // singular row, RHS is zero\n var bNew = (0, _toConsumableArray2.default)(b);\n bNew[i] = 1;\n\n for (var _j = i + 1; _j < columns; _j++) {\n bNew[_j] = subtract(bNew[_j], M[_j][i]);\n }\n\n B.push(bNew);\n }\n }\n }\n\n return B.map(function (x) {\n return new DenseMatrix({\n data: x.map(function (e) {\n return [e];\n }),\n size: [rows, 1]\n });\n });\n }\n\n function _sparseForwardSubstitution(m, b_) {\n // array of right-hand sides\n var B = [solveValidation(m, b_, true)._data.map(function (e) {\n return e[0];\n })];\n var rows = m._size[0];\n var columns = m._size[1];\n var values = m._values;\n var index = m._index;\n var ptr = m._ptr; // loop columns\n\n for (var i = 0; i < columns; i++) {\n var L = B.length; // loop right-hand sides\n\n for (var k = 0; k < L; k++) {\n var b = B[k]; // values & indices (column i)\n\n var iValues = [];\n var iIndices = []; // first & last indeces in column\n\n var firstIndex = ptr[i];\n var lastIndex = ptr[i + 1]; // find the value at [i, i]\n\n var Mii = 0;\n\n for (var j = firstIndex; j < lastIndex; j++) {\n var J = index[j]; // check row\n\n if (J === i) {\n Mii = values[j];\n } else if (J > i) {\n // store lower triangular\n iValues.push(values[j]);\n iIndices.push(J);\n }\n }\n\n if (!equalScalar(Mii, 0)) {\n // non-singular row\n b[i] = divideScalar(b[i], Mii);\n\n for (var _j2 = 0, _lastIndex = iIndices.length; _j2 < _lastIndex; _j2++) {\n var _J = iIndices[_j2];\n b[_J] = subtract(b[_J], multiplyScalar(b[i], iValues[_j2]));\n }\n } else if (!equalScalar(b[i], 0)) {\n // singular row, nonzero RHS\n if (k === 0) {\n // There is no valid solution\n return [];\n } else {\n // This RHS is invalid but other solutions may still exist\n B.splice(k, 1);\n k -= 1;\n L -= 1;\n }\n } else if (k === 0) {\n // singular row, RHS is zero\n var bNew = (0, _toConsumableArray2.default)(b);\n bNew[i] = 1;\n\n for (var _j3 = 0, _lastIndex2 = iIndices.length; _j3 < _lastIndex2; _j3++) {\n var _J2 = iIndices[_j3];\n bNew[_J2] = subtract(bNew[_J2], iValues[_j3]);\n }\n\n B.push(bNew);\n }\n }\n }\n\n return B.map(function (x) {\n return new DenseMatrix({\n data: x.map(function (e) {\n return [e];\n }),\n size: [rows, 1]\n });\n });\n }\n});\nexports.createLsolveAll = createLsolveAll;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLusolve = void 0;\n\nvar _is = require(\"../../../utils/is.js\");\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _solveValidation = require(\"./utils/solveValidation.js\");\n\nvar _csIpvec = require(\"../sparse/csIpvec.js\");\n\nvar name = 'lusolve';\nvar dependencies = ['typed', 'matrix', 'lup', 'slu', 'usolve', 'lsolve', 'DenseMatrix'];\nvar createLusolve = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n lup = _ref.lup,\n slu = _ref.slu,\n usolve = _ref.usolve,\n lsolve = _ref.lsolve,\n DenseMatrix = _ref.DenseMatrix;\n var solveValidation = (0, _solveValidation.createSolveValidation)({\n DenseMatrix: DenseMatrix\n });\n /**\n * Solves the linear system `A * x = b` where `A` is an [n x n] matrix and `b` is a [n] column vector.\n *\n * Syntax:\n *\n * math.lusolve(A, b) // returns column vector with the solution to the linear system A * x = b\n * math.lusolve(lup, b) // returns column vector with the solution to the linear system A * x = b, lup = math.lup(A)\n *\n * Examples:\n *\n * const m = [[1, 0, 0, 0], [0, 2, 0, 0], [0, 0, 3, 0], [0, 0, 0, 4]]\n *\n * const x = math.lusolve(m, [-1, -1, -1, -1]) // x = [[-1], [-0.5], [-1/3], [-0.25]]\n *\n * const f = math.lup(m)\n * const x1 = math.lusolve(f, [-1, -1, -1, -1]) // x1 = [[-1], [-0.5], [-1/3], [-0.25]]\n * const x2 = math.lusolve(f, [1, 2, 1, -1]) // x2 = [[1], [1], [1/3], [-0.25]]\n *\n * const a = [[-2, 3], [2, 1]]\n * const b = [11, 9]\n * const x = math.lusolve(a, b) // [[2], [5]]\n *\n * See also:\n *\n * lup, slu, lsolve, usolve\n *\n * @param {Matrix | Array | Object} A Invertible Matrix or the Matrix LU decomposition\n * @param {Matrix | Array} b Column Vector\n * @param {number} [order] The Symbolic Ordering and Analysis order, see slu for details. Matrix must be a SparseMatrix\n * @param {Number} [threshold] Partial pivoting threshold (1 for partial pivoting), see slu for details. Matrix must be a SparseMatrix.\n *\n * @return {DenseMatrix | Array} Column vector with the solution to the linear system A * x = b\n */\n\n return typed(name, {\n 'Array, Array | Matrix': function ArrayArrayMatrix(a, b) {\n a = matrix(a);\n var d = lup(a);\n\n var x = _lusolve(d.L, d.U, d.p, null, b);\n\n return x.valueOf();\n },\n 'DenseMatrix, Array | Matrix': function DenseMatrixArrayMatrix(a, b) {\n var d = lup(a);\n return _lusolve(d.L, d.U, d.p, null, b);\n },\n 'SparseMatrix, Array | Matrix': function SparseMatrixArrayMatrix(a, b) {\n var d = lup(a);\n return _lusolve(d.L, d.U, d.p, null, b);\n },\n 'SparseMatrix, Array | Matrix, number, number': function SparseMatrixArrayMatrixNumberNumber(a, b, order, threshold) {\n var d = slu(a, order, threshold);\n return _lusolve(d.L, d.U, d.p, d.q, b);\n },\n 'Object, Array | Matrix': function ObjectArrayMatrix(d, b) {\n return _lusolve(d.L, d.U, d.p, d.q, b);\n }\n });\n\n function _toMatrix(a) {\n if ((0, _is.isMatrix)(a)) {\n return a;\n }\n\n if ((0, _is.isArray)(a)) {\n return matrix(a);\n }\n\n throw new TypeError('Invalid Matrix LU decomposition');\n }\n\n function _lusolve(l, u, p, q, b) {\n // verify decomposition\n l = _toMatrix(l);\n u = _toMatrix(u); // apply row permutations if needed (b is a DenseMatrix)\n\n if (p) {\n b = solveValidation(l, b, true);\n b._data = (0, _csIpvec.csIpvec)(p, b._data);\n } // use forward substitution to resolve L * y = b\n\n\n var y = lsolve(l, b); // use backward substitution to resolve U * x = y\n\n var x = usolve(u, y); // apply column permutations if needed (x is a DenseMatrix)\n\n if (q) {\n x._data = (0, _csIpvec.csIpvec)(q, x._data);\n }\n\n return x;\n }\n});\nexports.createLusolve = createLusolve;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createUsolve = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _solveValidation = require(\"./utils/solveValidation.js\");\n\nvar name = 'usolve';\nvar dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtract', 'equalScalar', 'DenseMatrix'];\nvar createUsolve = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n divideScalar = _ref.divideScalar,\n multiplyScalar = _ref.multiplyScalar,\n subtract = _ref.subtract,\n equalScalar = _ref.equalScalar,\n DenseMatrix = _ref.DenseMatrix;\n var solveValidation = (0, _solveValidation.createSolveValidation)({\n DenseMatrix: DenseMatrix\n });\n /**\n * Finds one solution of a linear equation system by backward substitution. Matrix must be an upper triangular matrix. Throws an error if there's no solution.\n *\n * `U * x = b`\n *\n * Syntax:\n *\n * math.usolve(U, b)\n *\n * Examples:\n *\n * const a = [[-2, 3], [2, 1]]\n * const b = [11, 9]\n * const x = usolve(a, b) // [[8], [9]]\n *\n * See also:\n *\n * usolveAll, lup, slu, usolve, lusolve\n *\n * @param {Matrix, Array} U A N x N matrix or array (U)\n * @param {Matrix, Array} b A column vector with the b values\n *\n * @return {DenseMatrix | Array} A column vector with the linear system solution (x)\n */\n\n return typed(name, {\n 'SparseMatrix, Array | Matrix': function SparseMatrixArrayMatrix(m, b) {\n return _sparseBackwardSubstitution(m, b);\n },\n 'DenseMatrix, Array | Matrix': function DenseMatrixArrayMatrix(m, b) {\n return _denseBackwardSubstitution(m, b);\n },\n 'Array, Array | Matrix': function ArrayArrayMatrix(a, b) {\n var m = matrix(a);\n\n var r = _denseBackwardSubstitution(m, b);\n\n return r.valueOf();\n }\n });\n\n function _denseBackwardSubstitution(m, b) {\n // make b into a column vector\n b = solveValidation(m, b, true);\n var bdata = b._data;\n var rows = m._size[0];\n var columns = m._size[1]; // result\n\n var x = [];\n var mdata = m._data; // loop columns backwards\n\n for (var j = columns - 1; j >= 0; j--) {\n // b[j]\n var bj = bdata[j][0] || 0; // x[j]\n\n var xj = void 0;\n\n if (!equalScalar(bj, 0)) {\n // value at [j, j]\n var vjj = mdata[j][j];\n\n if (equalScalar(vjj, 0)) {\n // system cannot be solved\n throw new Error('Linear system cannot be solved since matrix is singular');\n }\n\n xj = divideScalar(bj, vjj); // loop rows\n\n for (var i = j - 1; i >= 0; i--) {\n // update copy of b\n bdata[i] = [subtract(bdata[i][0] || 0, multiplyScalar(xj, mdata[i][j]))];\n }\n } else {\n // zero value at j\n xj = 0;\n } // update x\n\n\n x[j] = [xj];\n }\n\n return new DenseMatrix({\n data: x,\n size: [rows, 1]\n });\n }\n\n function _sparseBackwardSubstitution(m, b) {\n // make b into a column vector\n b = solveValidation(m, b, true);\n var bdata = b._data;\n var rows = m._size[0];\n var columns = m._size[1];\n var values = m._values;\n var index = m._index;\n var ptr = m._ptr; // result\n\n var x = []; // loop columns backwards\n\n for (var j = columns - 1; j >= 0; j--) {\n var bj = bdata[j][0] || 0;\n\n if (!equalScalar(bj, 0)) {\n // non-degenerate row, find solution\n var vjj = 0; // upper triangular matrix values & index (column j)\n\n var jValues = [];\n var jIndices = []; // first & last indeces in column\n\n var firstIndex = ptr[j];\n var lastIndex = ptr[j + 1]; // values in column, find value at [j, j], loop backwards\n\n for (var k = lastIndex - 1; k >= firstIndex; k--) {\n var i = index[k]; // check row (rows are not sorted!)\n\n if (i === j) {\n vjj = values[k];\n } else if (i < j) {\n // store upper triangular\n jValues.push(values[k]);\n jIndices.push(i);\n }\n } // at this point we must have a value in vjj\n\n\n if (equalScalar(vjj, 0)) {\n throw new Error('Linear system cannot be solved since matrix is singular');\n }\n\n var xj = divideScalar(bj, vjj);\n\n for (var _k = 0, _lastIndex = jIndices.length; _k < _lastIndex; _k++) {\n var _i = jIndices[_k];\n bdata[_i] = [subtract(bdata[_i][0], multiplyScalar(xj, jValues[_k]))];\n }\n\n x[j] = [xj];\n } else {\n // degenerate row, we can choose any value\n x[j] = [0];\n }\n }\n\n return new DenseMatrix({\n data: x,\n size: [rows, 1]\n });\n }\n});\nexports.createUsolve = createUsolve;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createUsolveAll = void 0;\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _solveValidation = require(\"./utils/solveValidation.js\");\n\nvar name = 'usolveAll';\nvar dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtract', 'equalScalar', 'DenseMatrix'];\nvar createUsolveAll = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n divideScalar = _ref.divideScalar,\n multiplyScalar = _ref.multiplyScalar,\n subtract = _ref.subtract,\n equalScalar = _ref.equalScalar,\n DenseMatrix = _ref.DenseMatrix;\n var solveValidation = (0, _solveValidation.createSolveValidation)({\n DenseMatrix: DenseMatrix\n });\n /**\n * Finds all solutions of a linear equation system by backward substitution. Matrix must be an upper triangular matrix.\n *\n * `U * x = b`\n *\n * Syntax:\n *\n * math.usolveAll(U, b)\n *\n * Examples:\n *\n * const a = [[-2, 3], [2, 1]]\n * const b = [11, 9]\n * const x = usolveAll(a, b) // [ [[8], [9]] ]\n *\n * See also:\n *\n * usolve, lup, slu, usolve, lusolve\n *\n * @param {Matrix, Array} U A N x N matrix or array (U)\n * @param {Matrix, Array} b A column vector with the b values\n *\n * @return {DenseMatrix[] | Array[]} An array of affine-independent column vectors (x) that solve the linear system\n */\n\n return typed(name, {\n 'SparseMatrix, Array | Matrix': function SparseMatrixArrayMatrix(m, b) {\n return _sparseBackwardSubstitution(m, b);\n },\n 'DenseMatrix, Array | Matrix': function DenseMatrixArrayMatrix(m, b) {\n return _denseBackwardSubstitution(m, b);\n },\n 'Array, Array | Matrix': function ArrayArrayMatrix(a, b) {\n var m = matrix(a);\n\n var R = _denseBackwardSubstitution(m, b);\n\n return R.map(function (r) {\n return r.valueOf();\n });\n }\n });\n\n function _denseBackwardSubstitution(m, b_) {\n // the algorithm is derived from\n // https://www.overleaf.com/read/csvgqdxggyjv\n // array of right-hand sides\n var B = [solveValidation(m, b_, true)._data.map(function (e) {\n return e[0];\n })];\n var M = m._data;\n var rows = m._size[0];\n var columns = m._size[1]; // loop columns backwards\n\n for (var i = columns - 1; i >= 0; i--) {\n var L = B.length; // loop right-hand sides\n\n for (var k = 0; k < L; k++) {\n var b = B[k];\n\n if (!equalScalar(M[i][i], 0)) {\n // non-singular row\n b[i] = divideScalar(b[i], M[i][i]);\n\n for (var j = i - 1; j >= 0; j--) {\n // b[j] -= b[i] * M[j,i]\n b[j] = subtract(b[j], multiplyScalar(b[i], M[j][i]));\n }\n } else if (!equalScalar(b[i], 0)) {\n // singular row, nonzero RHS\n if (k === 0) {\n // There is no valid solution\n return [];\n } else {\n // This RHS is invalid but other solutions may still exist\n B.splice(k, 1);\n k -= 1;\n L -= 1;\n }\n } else if (k === 0) {\n // singular row, RHS is zero\n var bNew = (0, _toConsumableArray2.default)(b);\n bNew[i] = 1;\n\n for (var _j = i - 1; _j >= 0; _j--) {\n bNew[_j] = subtract(bNew[_j], M[_j][i]);\n }\n\n B.push(bNew);\n }\n }\n }\n\n return B.map(function (x) {\n return new DenseMatrix({\n data: x.map(function (e) {\n return [e];\n }),\n size: [rows, 1]\n });\n });\n }\n\n function _sparseBackwardSubstitution(m, b_) {\n // array of right-hand sides\n var B = [solveValidation(m, b_, true)._data.map(function (e) {\n return e[0];\n })];\n var rows = m._size[0];\n var columns = m._size[1];\n var values = m._values;\n var index = m._index;\n var ptr = m._ptr; // loop columns backwards\n\n for (var i = columns - 1; i >= 0; i--) {\n var L = B.length; // loop right-hand sides\n\n for (var k = 0; k < L; k++) {\n var b = B[k]; // values & indices (column i)\n\n var iValues = [];\n var iIndices = []; // first & last indeces in column\n\n var firstIndex = ptr[i];\n var lastIndex = ptr[i + 1]; // find the value at [i, i]\n\n var Mii = 0;\n\n for (var j = lastIndex - 1; j >= firstIndex; j--) {\n var J = index[j]; // check row\n\n if (J === i) {\n Mii = values[j];\n } else if (J < i) {\n // store upper triangular\n iValues.push(values[j]);\n iIndices.push(J);\n }\n }\n\n if (!equalScalar(Mii, 0)) {\n // non-singular row\n b[i] = divideScalar(b[i], Mii); // loop upper triangular\n\n for (var _j2 = 0, _lastIndex = iIndices.length; _j2 < _lastIndex; _j2++) {\n var _J = iIndices[_j2];\n b[_J] = subtract(b[_J], multiplyScalar(b[i], iValues[_j2]));\n }\n } else if (!equalScalar(b[i], 0)) {\n // singular row, nonzero RHS\n if (k === 0) {\n // There is no valid solution\n return [];\n } else {\n // This RHS is invalid but other solutions may still exist\n B.splice(k, 1);\n k -= 1;\n L -= 1;\n }\n } else if (k === 0) {\n // singular row, RHS is zero\n var bNew = (0, _toConsumableArray2.default)(b);\n bNew[i] = 1; // loop upper triangular\n\n for (var _j3 = 0, _lastIndex2 = iIndices.length; _j3 < _lastIndex2; _j3++) {\n var _J2 = iIndices[_j3];\n bNew[_J2] = subtract(bNew[_J2], iValues[_j3]);\n }\n\n B.push(bNew);\n }\n }\n }\n\n return B.map(function (x) {\n return new DenseMatrix({\n data: x.map(function (e) {\n return [e];\n }),\n size: [rows, 1]\n });\n });\n }\n});\nexports.createUsolveAll = createUsolveAll;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSolveValidation = createSolveValidation;\n\nvar _is = require(\"../../../../utils/is.js\");\n\nvar _array = require(\"../../../../utils/array.js\");\n\nvar _string = require(\"../../../../utils/string.js\");\n\nfunction createSolveValidation(_ref) {\n var DenseMatrix = _ref.DenseMatrix;\n\n /**\n * Validates matrix and column vector b for backward/forward substitution algorithms.\n *\n * @param {Matrix} m An N x N matrix\n * @param {Array | Matrix} b A column vector\n * @param {Boolean} copy Return a copy of vector b\n *\n * @return {DenseMatrix} Dense column vector b\n */\n return function solveValidation(m, b, copy) {\n var mSize = m.size();\n\n if (mSize.length !== 2) {\n throw new RangeError('Matrix must be two dimensional (size: ' + (0, _string.format)(mSize) + ')');\n }\n\n var rows = mSize[0];\n var columns = mSize[1];\n\n if (rows !== columns) {\n throw new RangeError('Matrix must be square (size: ' + (0, _string.format)(mSize) + ')');\n }\n\n var data = [];\n\n if ((0, _is.isMatrix)(b)) {\n var bSize = b.size();\n var bdata = b._data; // 1-dim vector\n\n if (bSize.length === 1) {\n if (bSize[0] !== rows) {\n throw new RangeError('Dimension mismatch. Matrix columns must match vector length.');\n }\n\n for (var i = 0; i < rows; i++) {\n data[i] = [bdata[i]];\n }\n\n return new DenseMatrix({\n data: data,\n size: [rows, 1],\n datatype: b._datatype\n });\n } // 2-dim column\n\n\n if (bSize.length === 2) {\n if (bSize[0] !== rows || bSize[1] !== 1) {\n throw new RangeError('Dimension mismatch. Matrix columns must match vector length.');\n }\n\n if ((0, _is.isDenseMatrix)(b)) {\n if (copy) {\n data = [];\n\n for (var _i = 0; _i < rows; _i++) {\n data[_i] = [bdata[_i][0]];\n }\n\n return new DenseMatrix({\n data: data,\n size: [rows, 1],\n datatype: b._datatype\n });\n }\n\n return b;\n }\n\n if ((0, _is.isSparseMatrix)(b)) {\n for (var _i2 = 0; _i2 < rows; _i2++) {\n data[_i2] = [0];\n }\n\n var values = b._values;\n var index = b._index;\n var ptr = b._ptr;\n\n for (var k1 = ptr[1], k = ptr[0]; k < k1; k++) {\n var _i3 = index[k];\n data[_i3][0] = values[k];\n }\n\n return new DenseMatrix({\n data: data,\n size: [rows, 1],\n datatype: b._datatype\n });\n }\n }\n\n throw new RangeError('Dimension mismatch. The right side has to be either 1- or 2-dimensional vector.');\n }\n\n if ((0, _is.isArray)(b)) {\n var bsize = (0, _array.arraySize)(b);\n\n if (bsize.length === 1) {\n if (bsize[0] !== rows) {\n throw new RangeError('Dimension mismatch. Matrix columns must match vector length.');\n }\n\n for (var _i4 = 0; _i4 < rows; _i4++) {\n data[_i4] = [b[_i4]];\n }\n\n return new DenseMatrix({\n data: data,\n size: [rows, 1]\n });\n }\n\n if (bsize.length === 2) {\n if (bsize[0] !== rows || bsize[1] !== 1) {\n throw new RangeError('Dimension mismatch. Matrix columns must match vector length.');\n }\n\n for (var _i5 = 0; _i5 < rows; _i5++) {\n data[_i5] = [b[_i5][0]];\n }\n\n return new DenseMatrix({\n data: data,\n size: [rows, 1]\n });\n }\n\n throw new RangeError('Dimension mismatch. The right side has to be either 1- or 2-dimensional vector.');\n }\n };\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCsAmd = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _csFkeep = require(\"./csFkeep.js\");\n\nvar _csFlip = require(\"./csFlip.js\");\n\nvar _csTdfs = require(\"./csTdfs.js\");\n\nvar name = 'csAmd';\nvar dependencies = ['add', 'multiply', 'transpose'];\nvar createCsAmd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var add = _ref.add,\n multiply = _ref.multiply,\n transpose = _ref.transpose;\n\n /**\n * Approximate minimum degree ordering. The minimum degree algorithm is a widely used\n * heuristic for finding a permutation P so that P*A*P' has fewer nonzeros in its factorization\n * than A. It is a gready method that selects the sparsest pivot row and column during the course\n * of a right looking sparse Cholesky factorization.\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n *\n * @param {Number} order 0: Natural, 1: Cholesky, 2: LU, 3: QR\n * @param {Matrix} m Sparse Matrix\n */\n return function csAmd(order, a) {\n // check input parameters\n if (!a || order <= 0 || order > 3) {\n return null;\n } // a matrix arrays\n\n\n var asize = a._size; // rows and columns\n\n var m = asize[0];\n var n = asize[1]; // initialize vars\n\n var lemax = 0; // dense threshold\n\n var dense = Math.max(16, 10 * Math.sqrt(n));\n dense = Math.min(n - 2, dense); // create target matrix C\n\n var cm = _createTargetMatrix(order, a, m, n, dense); // drop diagonal entries\n\n\n (0, _csFkeep.csFkeep)(cm, _diag, null); // C matrix arrays\n\n var cindex = cm._index;\n var cptr = cm._ptr; // number of nonzero elements in C\n\n var cnz = cptr[n]; // allocate result (n+1)\n\n var P = []; // create workspace (8 * (n + 1))\n\n var W = [];\n var len = 0; // first n + 1 entries\n\n var nv = n + 1; // next n + 1 entries\n\n var next = 2 * (n + 1); // next n + 1 entries\n\n var head = 3 * (n + 1); // next n + 1 entries\n\n var elen = 4 * (n + 1); // next n + 1 entries\n\n var degree = 5 * (n + 1); // next n + 1 entries\n\n var w = 6 * (n + 1); // next n + 1 entries\n\n var hhead = 7 * (n + 1); // last n + 1 entries\n // use P as workspace for last\n\n var last = P; // initialize quotient graph\n\n var mark = _initializeQuotientGraph(n, cptr, W, len, head, last, next, hhead, nv, w, elen, degree); // initialize degree lists\n\n\n var nel = _initializeDegreeLists(n, cptr, W, degree, elen, w, dense, nv, head, last, next); // minimum degree node\n\n\n var mindeg = 0; // vars\n\n var i, j, k, k1, k2, e, pj, ln, nvi, pk, eln, p1, p2, pn, h, d; // while (selecting pivots) do\n\n while (nel < n) {\n // select node of minimum approximate degree. amd() is now ready to start eliminating the graph. It first\n // finds a node k of minimum degree and removes it from its degree list. The variable nel keeps track of thow\n // many nodes have been eliminated.\n for (k = -1; mindeg < n && (k = W[head + mindeg]) === -1; mindeg++) {\n ;\n }\n\n if (W[next + k] !== -1) {\n last[W[next + k]] = -1;\n } // remove k from degree list\n\n\n W[head + mindeg] = W[next + k]; // elenk = |Ek|\n\n var elenk = W[elen + k]; // # of nodes k represents\n\n var nvk = W[nv + k]; // W[nv + k] nodes of A eliminated\n\n nel += nvk; // Construct a new element. The new element Lk is constructed in place if |Ek| = 0. nv[i] is\n // negated for all nodes i in Lk to flag them as members of this set. Each node i is removed from the\n // degree lists. All elements e in Ek are absorved into element k.\n\n var dk = 0; // flag k as in Lk\n\n W[nv + k] = -nvk;\n var p = cptr[k]; // do in place if W[elen + k] === 0\n\n var pk1 = elenk === 0 ? p : cnz;\n var pk2 = pk1;\n\n for (k1 = 1; k1 <= elenk + 1; k1++) {\n if (k1 > elenk) {\n // search the nodes in k\n e = k; // list of nodes starts at cindex[pj]\n\n pj = p; // length of list of nodes in k\n\n ln = W[len + k] - elenk;\n } else {\n // search the nodes in e\n e = cindex[p++];\n pj = cptr[e]; // length of list of nodes in e\n\n ln = W[len + e];\n }\n\n for (k2 = 1; k2 <= ln; k2++) {\n i = cindex[pj++]; // check node i dead, or seen\n\n if ((nvi = W[nv + i]) <= 0) {\n continue;\n } // W[degree + Lk] += size of node i\n\n\n dk += nvi; // negate W[nv + i] to denote i in Lk\n\n W[nv + i] = -nvi; // place i in Lk\n\n cindex[pk2++] = i;\n\n if (W[next + i] !== -1) {\n last[W[next + i]] = last[i];\n } // check we need to remove i from degree list\n\n\n if (last[i] !== -1) {\n W[next + last[i]] = W[next + i];\n } else {\n W[head + W[degree + i]] = W[next + i];\n }\n }\n\n if (e !== k) {\n // absorb e into k\n cptr[e] = (0, _csFlip.csFlip)(k); // e is now a dead element\n\n W[w + e] = 0;\n }\n } // cindex[cnz...nzmax] is free\n\n\n if (elenk !== 0) {\n cnz = pk2;\n } // external degree of k - |Lk\\i|\n\n\n W[degree + k] = dk; // element k is in cindex[pk1..pk2-1]\n\n cptr[k] = pk1;\n W[len + k] = pk2 - pk1; // k is now an element\n\n W[elen + k] = -2; // Find set differences. The scan1 function now computes the set differences |Le \\ Lk| for all elements e. At the start of the\n // scan, no entry in the w array is greater than or equal to mark.\n // clear w if necessary\n\n mark = _wclear(mark, lemax, W, w, n); // scan 1: find |Le\\Lk|\n\n for (pk = pk1; pk < pk2; pk++) {\n i = cindex[pk]; // check if W[elen + i] empty, skip it\n\n if ((eln = W[elen + i]) <= 0) {\n continue;\n } // W[nv + i] was negated\n\n\n nvi = -W[nv + i];\n var wnvi = mark - nvi; // scan Ei\n\n for (p = cptr[i], p1 = cptr[i] + eln - 1; p <= p1; p++) {\n e = cindex[p];\n\n if (W[w + e] >= mark) {\n // decrement |Le\\Lk|\n W[w + e] -= nvi;\n } else if (W[w + e] !== 0) {\n // ensure e is a live element, 1st time e seen in scan 1\n W[w + e] = W[degree + e] + wnvi;\n }\n }\n } // degree update\n // The second pass computes the approximate degree di, prunes the sets Ei and Ai, and computes a hash\n // function h(i) for all nodes in Lk.\n // scan2: degree update\n\n\n for (pk = pk1; pk < pk2; pk++) {\n // consider node i in Lk\n i = cindex[pk];\n p1 = cptr[i];\n p2 = p1 + W[elen + i] - 1;\n pn = p1; // scan Ei\n\n for (h = 0, d = 0, p = p1; p <= p2; p++) {\n e = cindex[p]; // check e is an unabsorbed element\n\n if (W[w + e] !== 0) {\n // dext = |Le\\Lk|\n var dext = W[w + e] - mark;\n\n if (dext > 0) {\n // sum up the set differences\n d += dext; // keep e in Ei\n\n cindex[pn++] = e; // compute the hash of node i\n\n h += e;\n } else {\n // aggressive absorb. e->k\n cptr[e] = (0, _csFlip.csFlip)(k); // e is a dead element\n\n W[w + e] = 0;\n }\n }\n } // W[elen + i] = |Ei|\n\n\n W[elen + i] = pn - p1 + 1;\n var p3 = pn;\n var p4 = p1 + W[len + i]; // prune edges in Ai\n\n for (p = p2 + 1; p < p4; p++) {\n j = cindex[p]; // check node j dead or in Lk\n\n var nvj = W[nv + j];\n\n if (nvj <= 0) {\n continue;\n } // degree(i) += |j|\n\n\n d += nvj; // place j in node list of i\n\n cindex[pn++] = j; // compute hash for node i\n\n h += j;\n } // check for mass elimination\n\n\n if (d === 0) {\n // absorb i into k\n cptr[i] = (0, _csFlip.csFlip)(k);\n nvi = -W[nv + i]; // |Lk| -= |i|\n\n dk -= nvi; // |k| += W[nv + i]\n\n nvk += nvi;\n nel += nvi;\n W[nv + i] = 0; // node i is dead\n\n W[elen + i] = -1;\n } else {\n // update degree(i)\n W[degree + i] = Math.min(W[degree + i], d); // move first node to end\n\n cindex[pn] = cindex[p3]; // move 1st el. to end of Ei\n\n cindex[p3] = cindex[p1]; // add k as 1st element in of Ei\n\n cindex[p1] = k; // new len of adj. list of node i\n\n W[len + i] = pn - p1 + 1; // finalize hash of i\n\n h = (h < 0 ? -h : h) % n; // place i in hash bucket\n\n W[next + i] = W[hhead + h];\n W[hhead + h] = i; // save hash of i in last[i]\n\n last[i] = h;\n }\n } // finalize |Lk|\n\n\n W[degree + k] = dk;\n lemax = Math.max(lemax, dk); // clear w\n\n mark = _wclear(mark + lemax, lemax, W, w, n); // Supernode detection. Supernode detection relies on the hash function h(i) computed for each node i.\n // If two nodes have identical adjacency lists, their hash functions wil be identical.\n\n for (pk = pk1; pk < pk2; pk++) {\n i = cindex[pk]; // check i is dead, skip it\n\n if (W[nv + i] >= 0) {\n continue;\n } // scan hash bucket of node i\n\n\n h = last[i];\n i = W[hhead + h]; // hash bucket will be empty\n\n W[hhead + h] = -1;\n\n for (; i !== -1 && W[next + i] !== -1; i = W[next + i], mark++) {\n ln = W[len + i];\n eln = W[elen + i];\n\n for (p = cptr[i] + 1; p <= cptr[i] + ln - 1; p++) {\n W[w + cindex[p]] = mark;\n }\n\n var jlast = i; // compare i with all j\n\n for (j = W[next + i]; j !== -1;) {\n var ok = W[len + j] === ln && W[elen + j] === eln;\n\n for (p = cptr[j] + 1; ok && p <= cptr[j] + ln - 1; p++) {\n // compare i and j\n if (W[w + cindex[p]] !== mark) {\n ok = 0;\n }\n } // check i and j are identical\n\n\n if (ok) {\n // absorb j into i\n cptr[j] = (0, _csFlip.csFlip)(i);\n W[nv + i] += W[nv + j];\n W[nv + j] = 0; // node j is dead\n\n W[elen + j] = -1; // delete j from hash bucket\n\n j = W[next + j];\n W[next + jlast] = j;\n } else {\n // j and i are different\n jlast = j;\n j = W[next + j];\n }\n }\n }\n } // Finalize new element. The elimination of node k is nearly complete. All nodes i in Lk are scanned one last time.\n // Node i is removed from Lk if it is dead. The flagged status of nv[i] is cleared.\n\n\n for (p = pk1, pk = pk1; pk < pk2; pk++) {\n i = cindex[pk]; // check i is dead, skip it\n\n if ((nvi = -W[nv + i]) <= 0) {\n continue;\n } // restore W[nv + i]\n\n\n W[nv + i] = nvi; // compute external degree(i)\n\n d = W[degree + i] + dk - nvi;\n d = Math.min(d, n - nel - nvi);\n\n if (W[head + d] !== -1) {\n last[W[head + d]] = i;\n } // put i back in degree list\n\n\n W[next + i] = W[head + d];\n last[i] = -1;\n W[head + d] = i; // find new minimum degree\n\n mindeg = Math.min(mindeg, d);\n W[degree + i] = d; // place i in Lk\n\n cindex[p++] = i;\n } // # nodes absorbed into k\n\n\n W[nv + k] = nvk; // length of adj list of element k\n\n if ((W[len + k] = p - pk1) === 0) {\n // k is a root of the tree\n cptr[k] = -1; // k is now a dead element\n\n W[w + k] = 0;\n }\n\n if (elenk !== 0) {\n // free unused space in Lk\n cnz = p;\n }\n } // Postordering. The elimination is complete, but no permutation has been computed. All that is left\n // of the graph is the assembly tree (ptr) and a set of dead nodes and elements (i is a dead node if\n // nv[i] is zero and a dead element if nv[i] > 0). It is from this information only that the final permutation\n // is computed. The tree is restored by unflipping all of ptr.\n // fix assembly tree\n\n\n for (i = 0; i < n; i++) {\n cptr[i] = (0, _csFlip.csFlip)(cptr[i]);\n }\n\n for (j = 0; j <= n; j++) {\n W[head + j] = -1;\n } // place unordered nodes in lists\n\n\n for (j = n; j >= 0; j--) {\n // skip if j is an element\n if (W[nv + j] > 0) {\n continue;\n } // place j in list of its parent\n\n\n W[next + j] = W[head + cptr[j]];\n W[head + cptr[j]] = j;\n } // place elements in lists\n\n\n for (e = n; e >= 0; e--) {\n // skip unless e is an element\n if (W[nv + e] <= 0) {\n continue;\n }\n\n if (cptr[e] !== -1) {\n // place e in list of its parent\n W[next + e] = W[head + cptr[e]];\n W[head + cptr[e]] = e;\n }\n } // postorder the assembly tree\n\n\n for (k = 0, i = 0; i <= n; i++) {\n if (cptr[i] === -1) {\n k = (0, _csTdfs.csTdfs)(i, k, W, head, next, P, w);\n }\n } // remove last item in array\n\n\n P.splice(P.length - 1, 1); // return P\n\n return P;\n };\n /**\n * Creates the matrix that will be used by the approximate minimum degree ordering algorithm. The function accepts the matrix M as input and returns a permutation\n * vector P. The amd algorithm operates on a symmetrix matrix, so one of three symmetric matrices is formed.\n *\n * Order: 0\n * A natural ordering P=null matrix is returned.\n *\n * Order: 1\n * Matrix must be square. This is appropriate for a Cholesky or LU factorization.\n * P = M + M'\n *\n * Order: 2\n * Dense columns from M' are dropped, M recreated from M'. This is appropriatefor LU factorization of unsymmetric matrices.\n * P = M' * M\n *\n * Order: 3\n * This is best used for QR factorization or LU factorization is matrix M has no dense rows. A dense row is a row with more than 10*sqr(columns) entries.\n * P = M' * M\n */\n\n function _createTargetMatrix(order, a, m, n, dense) {\n // compute A'\n var at = transpose(a); // check order = 1, matrix must be square\n\n if (order === 1 && n === m) {\n // C = A + A'\n return add(a, at);\n } // check order = 2, drop dense columns from M'\n\n\n if (order === 2) {\n // transpose arrays\n var tindex = at._index;\n var tptr = at._ptr; // new column index\n\n var p2 = 0; // loop A' columns (rows)\n\n for (var j = 0; j < m; j++) {\n // column j of AT starts here\n var p = tptr[j]; // new column j starts here\n\n tptr[j] = p2; // skip dense col j\n\n if (tptr[j + 1] - p > dense) {\n continue;\n } // map rows in column j of A\n\n\n for (var p1 = tptr[j + 1]; p < p1; p++) {\n tindex[p2++] = tindex[p];\n }\n } // finalize AT\n\n\n tptr[m] = p2; // recreate A from new transpose matrix\n\n a = transpose(at); // use A' * A\n\n return multiply(at, a);\n } // use A' * A, square or rectangular matrix\n\n\n return multiply(at, a);\n }\n /**\n * Initialize quotient graph. There are four kind of nodes and elements that must be represented:\n *\n * - A live node is a node i (or a supernode) that has not been selected as a pivot nad has not been merged into another supernode.\n * - A dead node i is one that has been removed from the graph, having been absorved into r = flip(ptr[i]).\n * - A live element e is one that is in the graph, having been formed when node e was selected as the pivot.\n * - A dead element e is one that has benn absorved into a subsequent element s = flip(ptr[e]).\n */\n\n\n function _initializeQuotientGraph(n, cptr, W, len, head, last, next, hhead, nv, w, elen, degree) {\n // Initialize quotient graph\n for (var k = 0; k < n; k++) {\n W[len + k] = cptr[k + 1] - cptr[k];\n }\n\n W[len + n] = 0; // initialize workspace\n\n for (var i = 0; i <= n; i++) {\n // degree list i is empty\n W[head + i] = -1;\n last[i] = -1;\n W[next + i] = -1; // hash list i is empty\n\n W[hhead + i] = -1; // node i is just one node\n\n W[nv + i] = 1; // node i is alive\n\n W[w + i] = 1; // Ek of node i is empty\n\n W[elen + i] = 0; // degree of node i\n\n W[degree + i] = W[len + i];\n } // clear w\n\n\n var mark = _wclear(0, 0, W, w, n); // n is a dead element\n\n\n W[elen + n] = -2; // n is a root of assembly tree\n\n cptr[n] = -1; // n is a dead element\n\n W[w + n] = 0; // return mark\n\n return mark;\n }\n /**\n * Initialize degree lists. Each node is placed in its degree lists. Nodes of zero degree are eliminated immediately. Nodes with\n * degree >= dense are alsol eliminated and merged into a placeholder node n, a dead element. Thes nodes will appera last in the\n * output permutation p.\n */\n\n\n function _initializeDegreeLists(n, cptr, W, degree, elen, w, dense, nv, head, last, next) {\n // result\n var nel = 0; // loop columns\n\n for (var i = 0; i < n; i++) {\n // degree @ i\n var d = W[degree + i]; // check node i is empty\n\n if (d === 0) {\n // element i is dead\n W[elen + i] = -2;\n nel++; // i is a root of assembly tree\n\n cptr[i] = -1;\n W[w + i] = 0;\n } else if (d > dense) {\n // absorb i into element n\n W[nv + i] = 0; // node i is dead\n\n W[elen + i] = -1;\n nel++;\n cptr[i] = (0, _csFlip.csFlip)(n);\n W[nv + n]++;\n } else {\n var h = W[head + d];\n\n if (h !== -1) {\n last[h] = i;\n } // put node i in degree list d\n\n\n W[next + i] = W[head + d];\n W[head + d] = i;\n }\n }\n\n return nel;\n }\n\n function _wclear(mark, lemax, W, w, n) {\n if (mark < 2 || mark + lemax < 0) {\n for (var k = 0; k < n; k++) {\n if (W[w + k] !== 0) {\n W[w + k] = 1;\n }\n }\n\n mark = 2;\n } // at this point, W [0..n-1] < mark holds\n\n\n return mark;\n }\n\n function _diag(i, j) {\n return i !== j;\n }\n});\nexports.createCsAmd = createCsAmd;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCsCounts = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _csLeaf = require(\"./csLeaf.js\");\n\nvar name = 'csCounts';\nvar dependencies = ['transpose'];\nvar createCsCounts = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var transpose = _ref.transpose;\n\n /**\n * Computes the column counts using the upper triangular part of A.\n * It transposes A internally, none of the input parameters are modified.\n *\n * @param {Matrix} a The sparse matrix A\n *\n * @param {Matrix} ata Count the columns of A'A instead\n *\n * @return An array of size n of the column counts or null on error\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\n return function (a, parent, post, ata) {\n // check inputs\n if (!a || !parent || !post) {\n return null;\n } // a matrix arrays\n\n\n var asize = a._size; // rows and columns\n\n var m = asize[0];\n var n = asize[1]; // variables\n\n var i, j, k, J, p, p0, p1; // workspace size\n\n var s = 4 * n + (ata ? n + m + 1 : 0); // allocate workspace\n\n var w = []; // (s)\n\n var ancestor = 0; // first n entries\n\n var maxfirst = n; // next n entries\n\n var prevleaf = 2 * n; // next n entries\n\n var first = 3 * n; // next n entries\n\n var head = 4 * n; // next n + 1 entries (used when ata is true)\n\n var next = 5 * n + 1; // last entries in workspace\n // clear workspace w[0..s-1]\n\n for (k = 0; k < s; k++) {\n w[k] = -1;\n } // allocate result\n\n\n var colcount = []; // (n)\n // AT = A'\n\n var at = transpose(a); // at arrays\n\n var tindex = at._index;\n var tptr = at._ptr; // find w[first + j]\n\n for (k = 0; k < n; k++) {\n j = post[k]; // colcount[j]=1 if j is a leaf\n\n colcount[j] = w[first + j] === -1 ? 1 : 0;\n\n for (; j !== -1 && w[first + j] === -1; j = parent[j]) {\n w[first + j] = k;\n }\n } // initialize ata if needed\n\n\n if (ata) {\n // invert post\n for (k = 0; k < n; k++) {\n w[post[k]] = k;\n } // loop rows (columns in AT)\n\n\n for (i = 0; i < m; i++) {\n // values in column i of AT\n for (k = n, p0 = tptr[i], p1 = tptr[i + 1], p = p0; p < p1; p++) {\n k = Math.min(k, w[tindex[p]]);\n } // place row i in linked list k\n\n\n w[next + i] = w[head + k];\n w[head + k] = i;\n }\n } // each node in its own set\n\n\n for (i = 0; i < n; i++) {\n w[ancestor + i] = i;\n }\n\n for (k = 0; k < n; k++) {\n // j is the kth node in postordered etree\n j = post[k]; // check j is not a root\n\n if (parent[j] !== -1) {\n colcount[parent[j]]--;\n } // J=j for LL'=A case\n\n\n for (J = ata ? w[head + k] : j; J !== -1; J = ata ? w[next + J] : -1) {\n for (p = tptr[J]; p < tptr[J + 1]; p++) {\n i = tindex[p];\n var r = (0, _csLeaf.csLeaf)(i, j, w, first, maxfirst, prevleaf, ancestor); // check A(i,j) is in skeleton\n\n if (r.jleaf >= 1) {\n colcount[j]++;\n } // check account for overlap in q\n\n\n if (r.jleaf === 2) {\n colcount[r.q]--;\n }\n }\n }\n\n if (parent[j] !== -1) {\n w[ancestor + j] = parent[j];\n }\n } // sum up colcount's of each child\n\n\n for (j = 0; j < n; j++) {\n if (parent[j] !== -1) {\n colcount[parent[j]] += colcount[j];\n }\n }\n\n return colcount;\n };\n});\nexports.createCsCounts = createCsCounts;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csDfs = csDfs;\n\nvar _csMarked = require(\"./csMarked.js\");\n\nvar _csMark = require(\"./csMark.js\");\n\nvar _csUnflip = require(\"./csUnflip.js\");\n\n/**\n * Depth-first search computes the nonzero pattern xi of the directed graph G (Matrix) starting\n * at nodes in B (see csReach()).\n *\n * @param {Number} j The starting node for the DFS algorithm\n * @param {Matrix} g The G matrix to search, ptr array modified, then restored\n * @param {Number} top Start index in stack xi[top..n-1]\n * @param {Number} k The kth column in B\n * @param {Array} xi The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n\n * The first n entries is the nonzero pattern, the last n entries is the stack\n * @param {Array} pinv The inverse row permutation vector, must be null for L * x = b\n *\n * @return {Number} New value of top\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\nfunction csDfs(j, g, top, xi, pinv) {\n // g arrays\n var index = g._index;\n var ptr = g._ptr;\n var size = g._size; // columns\n\n var n = size[1]; // vars\n\n var i, p, p2; // initialize head\n\n var head = 0; // initialize the recursion stack\n\n xi[0] = j; // loop\n\n while (head >= 0) {\n // get j from the top of the recursion stack\n j = xi[head]; // apply permutation vector\n\n var jnew = pinv ? pinv[j] : j; // check node j is marked\n\n if (!(0, _csMarked.csMarked)(ptr, j)) {\n // mark node j as visited\n (0, _csMark.csMark)(ptr, j); // update stack (last n entries in xi)\n\n xi[n + head] = jnew < 0 ? 0 : (0, _csUnflip.csUnflip)(ptr[jnew]);\n } // node j done if no unvisited neighbors\n\n\n var done = 1; // examine all neighbors of j, stack (last n entries in xi)\n\n for (p = xi[n + head], p2 = jnew < 0 ? 0 : (0, _csUnflip.csUnflip)(ptr[jnew + 1]); p < p2; p++) {\n // consider neighbor node i\n i = index[p]; // check we have visited node i, skip it\n\n if ((0, _csMarked.csMarked)(ptr, i)) {\n continue;\n } // pause depth-first search of node j, update stack (last n entries in xi)\n\n\n xi[n + head] = p; // start dfs at node i\n\n xi[++head] = i; // node j is not done\n\n done = 0; // break, to start dfs(i)\n\n break;\n } // check depth-first search at node j is done\n\n\n if (done) {\n // remove j from the recursion stack\n head--; // and place in the output stack\n\n xi[--top] = j;\n }\n }\n\n return top;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csEtree = csEtree;\n\n/**\n * Computes the elimination tree of Matrix A (using triu(A)) or the\n * elimination tree of A'A without forming A'A.\n *\n * @param {Matrix} a The A Matrix\n * @param {boolean} ata A value of true the function computes the etree of A'A\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\nfunction csEtree(a, ata) {\n // check inputs\n if (!a) {\n return null;\n } // a arrays\n\n\n var aindex = a._index;\n var aptr = a._ptr;\n var asize = a._size; // rows & columns\n\n var m = asize[0];\n var n = asize[1]; // allocate result\n\n var parent = []; // (n)\n // allocate workspace\n\n var w = []; // (n + (ata ? m : 0))\n\n var ancestor = 0; // first n entries in w\n\n var prev = n; // last m entries (ata = true)\n\n var i, inext; // check we are calculating A'A\n\n if (ata) {\n // initialize workspace\n for (i = 0; i < m; i++) {\n w[prev + i] = -1;\n }\n } // loop columns\n\n\n for (var k = 0; k < n; k++) {\n // node k has no parent yet\n parent[k] = -1; // nor does k have an ancestor\n\n w[ancestor + k] = -1; // values in column k\n\n for (var p0 = aptr[k], p1 = aptr[k + 1], p = p0; p < p1; p++) {\n // row\n var r = aindex[p]; // node\n\n i = ata ? w[prev + r] : r; // traverse from i to k\n\n for (; i !== -1 && i < k; i = inext) {\n // inext = ancestor of i\n inext = w[ancestor + i]; // path compression\n\n w[ancestor + i] = k; // check no anc., parent is k\n\n if (inext === -1) {\n parent[i] = k;\n }\n }\n\n if (ata) {\n w[prev + r] = k;\n }\n }\n }\n\n return parent;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csFkeep = csFkeep;\n\n/**\n * Keeps entries in the matrix when the callback function returns true, removes the entry otherwise\n *\n * @param {Matrix} a The sparse matrix\n * @param {function} callback The callback function, function will be invoked with the following args:\n * - The entry row\n * - The entry column\n * - The entry value\n * - The state parameter\n * @param {any} other The state\n *\n * @return The number of nonzero elements in the matrix\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\nfunction csFkeep(a, callback, other) {\n // a arrays\n var avalues = a._values;\n var aindex = a._index;\n var aptr = a._ptr;\n var asize = a._size; // columns\n\n var n = asize[1]; // nonzero items\n\n var nz = 0; // loop columns\n\n for (var j = 0; j < n; j++) {\n // get current location of col j\n var p = aptr[j]; // record new location of col j\n\n aptr[j] = nz;\n\n for (; p < aptr[j + 1]; p++) {\n // check we need to keep this item\n if (callback(aindex[p], j, avalues ? avalues[p] : 1, other)) {\n // keep A(i,j)\n aindex[nz] = aindex[p]; // check we need to process values (pattern only)\n\n if (avalues) {\n avalues[nz] = avalues[p];\n } // increment nonzero items\n\n\n nz++;\n }\n }\n } // finalize A\n\n\n aptr[n] = nz; // trim arrays\n\n aindex.splice(nz, aindex.length - nz); // check we need to process values (pattern only)\n\n if (avalues) {\n avalues.splice(nz, avalues.length - nz);\n } // return number of nonzero items\n\n\n return nz;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csFlip = csFlip;\n\n/**\n * This function \"flips\" its input about the integer -1.\n *\n * @param {Number} i The value to flip\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\nfunction csFlip(i) {\n // flip the value\n return -i - 2;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csIpvec = csIpvec;\n\n/**\n * Permutes a vector; x = P'b. In MATLAB notation, x(p)=b.\n *\n * @param {Array} p The permutation vector of length n. null value denotes identity\n * @param {Array} b The input vector\n *\n * @return {Array} The output vector x = P'b\n */\nfunction csIpvec(p, b) {\n // vars\n var k;\n var n = b.length;\n var x = []; // check permutation vector was provided, p = null denotes identity\n\n if (p) {\n // loop vector\n for (k = 0; k < n; k++) {\n // apply permutation\n x[p[k]] = b[k];\n }\n } else {\n // loop vector\n for (k = 0; k < n; k++) {\n // x[i] = b[i]\n x[k] = b[k];\n }\n }\n\n return x;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csLeaf = csLeaf;\n\n/**\n * This function determines if j is a leaf of the ith row subtree.\n * Consider A(i,j), node j in ith row subtree and return lca(jprev,j)\n *\n * @param {Number} i The ith row subtree\n * @param {Number} j The node to test\n * @param {Array} w The workspace array\n * @param {Number} first The index offset within the workspace for the first array\n * @param {Number} maxfirst The index offset within the workspace for the maxfirst array\n * @param {Number} prevleaf The index offset within the workspace for the prevleaf array\n * @param {Number} ancestor The index offset within the workspace for the ancestor array\n *\n * @return {Object}\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\nfunction csLeaf(i, j, w, first, maxfirst, prevleaf, ancestor) {\n var s, sparent; // our result\n\n var jleaf = 0;\n var q; // check j is a leaf\n\n if (i <= j || w[first + j] <= w[maxfirst + i]) {\n return -1;\n } // update max first[j] seen so far\n\n\n w[maxfirst + i] = w[first + j]; // jprev = previous leaf of ith subtree\n\n var jprev = w[prevleaf + i];\n w[prevleaf + i] = j; // check j is first or subsequent leaf\n\n if (jprev === -1) {\n // 1st leaf, q = root of ith subtree\n jleaf = 1;\n q = i;\n } else {\n // update jleaf\n jleaf = 2; // q = least common ancester (jprev,j)\n\n for (q = jprev; q !== w[ancestor + q]; q = w[ancestor + q]) {\n ;\n }\n\n for (s = jprev; s !== q; s = sparent) {\n // path compression\n sparent = w[ancestor + s];\n w[ancestor + s] = q;\n }\n }\n\n return {\n jleaf: jleaf,\n q: q\n };\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCsLu = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _csSpsolve = require(\"./csSpsolve.js\");\n\nvar name = 'csLu';\nvar dependencies = ['abs', 'divideScalar', 'multiply', 'subtract', 'larger', 'largerEq', 'SparseMatrix'];\nvar createCsLu = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var abs = _ref.abs,\n divideScalar = _ref.divideScalar,\n multiply = _ref.multiply,\n subtract = _ref.subtract,\n larger = _ref.larger,\n largerEq = _ref.largerEq,\n SparseMatrix = _ref.SparseMatrix;\n var csSpsolve = (0, _csSpsolve.createCsSpsolve)({\n divideScalar: divideScalar,\n multiply: multiply,\n subtract: subtract\n });\n /**\n * Computes the numeric LU factorization of the sparse matrix A. Implements a Left-looking LU factorization\n * algorithm that computes L and U one column at a tume. At the kth step, it access columns 1 to k-1 of L\n * and column k of A. Given the fill-reducing column ordering q (see parameter s) computes L, U and pinv so\n * L * U = A(p, q), where p is the inverse of pinv.\n *\n * @param {Matrix} m The A Matrix to factorize\n * @param {Object} s The symbolic analysis from csSqr(). Provides the fill-reducing\n * column ordering q\n * @param {Number} tol Partial pivoting threshold (1 for partial pivoting)\n *\n * @return {Number} The numeric LU factorization of A or null\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\n\n return function csLu(m, s, tol) {\n // validate input\n if (!m) {\n return null;\n } // m arrays\n\n\n var size = m._size; // columns\n\n var n = size[1]; // symbolic analysis result\n\n var q;\n var lnz = 100;\n var unz = 100; // update symbolic analysis parameters\n\n if (s) {\n q = s.q;\n lnz = s.lnz || lnz;\n unz = s.unz || unz;\n } // L arrays\n\n\n var lvalues = []; // (lnz)\n\n var lindex = []; // (lnz)\n\n var lptr = []; // (n + 1)\n // L\n\n var L = new SparseMatrix({\n values: lvalues,\n index: lindex,\n ptr: lptr,\n size: [n, n]\n }); // U arrays\n\n var uvalues = []; // (unz)\n\n var uindex = []; // (unz)\n\n var uptr = []; // (n + 1)\n // U\n\n var U = new SparseMatrix({\n values: uvalues,\n index: uindex,\n ptr: uptr,\n size: [n, n]\n }); // inverse of permutation vector\n\n var pinv = []; // (n)\n // vars\n\n var i, p; // allocate arrays\n\n var x = []; // (n)\n\n var xi = []; // (2 * n)\n // initialize variables\n\n for (i = 0; i < n; i++) {\n // clear workspace\n x[i] = 0; // no rows pivotal yet\n\n pinv[i] = -1; // no cols of L yet\n\n lptr[i + 1] = 0;\n } // reset number of nonzero elements in L and U\n\n\n lnz = 0;\n unz = 0; // compute L(:,k) and U(:,k)\n\n for (var k = 0; k < n; k++) {\n // update ptr\n lptr[k] = lnz;\n uptr[k] = unz; // apply column permutations if needed\n\n var col = q ? q[k] : k; // solve triangular system, x = L\\A(:,col)\n\n var top = csSpsolve(L, m, col, xi, x, pinv, 1); // find pivot\n\n var ipiv = -1;\n var a = -1; // loop xi[] from top -> n\n\n for (p = top; p < n; p++) {\n // x[i] is nonzero\n i = xi[p]; // check row i is not yet pivotal\n\n if (pinv[i] < 0) {\n // absolute value of x[i]\n var xabs = abs(x[i]); // check absoulte value is greater than pivot value\n\n if (larger(xabs, a)) {\n // largest pivot candidate so far\n a = xabs;\n ipiv = i;\n }\n } else {\n // x(i) is the entry U(pinv[i],k)\n uindex[unz] = pinv[i];\n uvalues[unz++] = x[i];\n }\n } // validate we found a valid pivot\n\n\n if (ipiv === -1 || a <= 0) {\n return null;\n } // update actual pivot column, give preference to diagonal value\n\n\n if (pinv[col] < 0 && largerEq(abs(x[col]), multiply(a, tol))) {\n ipiv = col;\n } // the chosen pivot\n\n\n var pivot = x[ipiv]; // last entry in U(:,k) is U(k,k)\n\n uindex[unz] = k;\n uvalues[unz++] = pivot; // ipiv is the kth pivot row\n\n pinv[ipiv] = k; // first entry in L(:,k) is L(k,k) = 1\n\n lindex[lnz] = ipiv;\n lvalues[lnz++] = 1; // L(k+1:n,k) = x / pivot\n\n for (p = top; p < n; p++) {\n // row\n i = xi[p]; // check x(i) is an entry in L(:,k)\n\n if (pinv[i] < 0) {\n // save unpermuted row in L\n lindex[lnz] = i; // scale pivot column\n\n lvalues[lnz++] = divideScalar(x[i], pivot);\n } // x[0..n-1] = 0 for next k\n\n\n x[i] = 0;\n }\n } // update ptr\n\n\n lptr[n] = lnz;\n uptr[n] = unz; // fix row indices of L for final pinv\n\n for (p = 0; p < lnz; p++) {\n lindex[p] = pinv[lindex[p]];\n } // trim arrays\n\n\n lvalues.splice(lnz, lvalues.length - lnz);\n lindex.splice(lnz, lindex.length - lnz);\n uvalues.splice(unz, uvalues.length - unz);\n uindex.splice(unz, uindex.length - unz); // return LU factor\n\n return {\n L: L,\n U: U,\n pinv: pinv\n };\n };\n});\nexports.createCsLu = createCsLu;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csMark = csMark;\n\nvar _csFlip = require(\"./csFlip.js\");\n\n/**\n * Marks the node at w[j]\n *\n * @param {Array} w The array\n * @param {Number} j The array index\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\nfunction csMark(w, j) {\n // mark w[j]\n w[j] = (0, _csFlip.csFlip)(w[j]);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csMarked = csMarked;\n\n/**\n * Checks if the node at w[j] is marked\n *\n * @param {Array} w The array\n * @param {Number} j The array index\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\nfunction csMarked(w, j) {\n // check node is marked\n return w[j] < 0;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csPermute = csPermute;\n\n/**\n * Permutes a sparse matrix C = P * A * Q\n *\n * @param {SparseMatrix} a The Matrix A\n * @param {Array} pinv The row permutation vector\n * @param {Array} q The column permutation vector\n * @param {boolean} values Create a pattern matrix (false), values and pattern otherwise\n *\n * @return {Matrix} C = P * A * Q, null on error\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\nfunction csPermute(a, pinv, q, values) {\n // a arrays\n var avalues = a._values;\n var aindex = a._index;\n var aptr = a._ptr;\n var asize = a._size;\n var adt = a._datatype; // rows & columns\n\n var m = asize[0];\n var n = asize[1]; // c arrays\n\n var cvalues = values && a._values ? [] : null;\n var cindex = []; // (aptr[n])\n\n var cptr = []; // (n + 1)\n // initialize vars\n\n var nz = 0; // loop columns\n\n for (var k = 0; k < n; k++) {\n // column k of C is column q[k] of A\n cptr[k] = nz; // apply column permutation\n\n var j = q ? q[k] : k; // loop values in column j of A\n\n for (var t0 = aptr[j], t1 = aptr[j + 1], t = t0; t < t1; t++) {\n // row i of A is row pinv[i] of C\n var r = pinv ? pinv[aindex[t]] : aindex[t]; // index\n\n cindex[nz] = r; // check we need to populate values\n\n if (cvalues) {\n cvalues[nz] = avalues[t];\n } // increment number of nonzero elements\n\n\n nz++;\n }\n } // finalize the last column of C\n\n\n cptr[n] = nz; // return C matrix\n\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [m, n],\n datatype: adt\n });\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csPost = csPost;\n\nvar _csTdfs = require(\"./csTdfs.js\");\n\n/**\n * Post order a tree of forest\n *\n * @param {Array} parent The tree or forest\n * @param {Number} n Number of columns\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\nfunction csPost(parent, n) {\n // check inputs\n if (!parent) {\n return null;\n } // vars\n\n\n var k = 0;\n var j; // allocate result\n\n var post = []; // (n)\n // workspace, head: first n entries, next: next n entries, stack: last n entries\n\n var w = []; // (3 * n)\n\n var head = 0;\n var next = n;\n var stack = 2 * n; // initialize workspace\n\n for (j = 0; j < n; j++) {\n // empty linked lists\n w[head + j] = -1;\n } // traverse nodes in reverse order\n\n\n for (j = n - 1; j >= 0; j--) {\n // check j is a root\n if (parent[j] === -1) {\n continue;\n } // add j to list of its parent\n\n\n w[next + j] = w[head + parent[j]];\n w[head + parent[j]] = j;\n } // loop nodes\n\n\n for (j = 0; j < n; j++) {\n // skip j if it is not a root\n if (parent[j] !== -1) {\n continue;\n } // depth-first search\n\n\n k = (0, _csTdfs.csTdfs)(j, k, w, head, next, post, stack);\n }\n\n return post;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csReach = csReach;\n\nvar _csMarked = require(\"./csMarked.js\");\n\nvar _csMark = require(\"./csMark.js\");\n\nvar _csDfs = require(\"./csDfs.js\");\n\n/**\n * The csReach function computes X = Reach(B), where B is the nonzero pattern of the n-by-1\n * sparse column of vector b. The function returns the set of nodes reachable from any node in B. The\n * nonzero pattern xi of the solution x to the sparse linear system Lx=b is given by X=Reach(B).\n *\n * @param {Matrix} g The G matrix\n * @param {Matrix} b The B matrix\n * @param {Number} k The kth column in B\n * @param {Array} xi The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n\n * The first n entries is the nonzero pattern, the last n entries is the stack\n * @param {Array} pinv The inverse row permutation vector\n *\n * @return {Number} The index for the nonzero pattern\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\nfunction csReach(g, b, k, xi, pinv) {\n // g arrays\n var gptr = g._ptr;\n var gsize = g._size; // b arrays\n\n var bindex = b._index;\n var bptr = b._ptr; // columns\n\n var n = gsize[1]; // vars\n\n var p, p0, p1; // initialize top\n\n var top = n; // loop column indeces in B\n\n for (p0 = bptr[k], p1 = bptr[k + 1], p = p0; p < p1; p++) {\n // node i\n var i = bindex[p]; // check node i is marked\n\n if (!(0, _csMarked.csMarked)(gptr, i)) {\n // start a dfs at unmarked node i\n top = (0, _csDfs.csDfs)(i, g, top, xi, pinv);\n }\n } // loop columns from top -> n - 1\n\n\n for (p = top; p < n; p++) {\n // restore G\n (0, _csMark.csMark)(gptr, xi[p]);\n }\n\n return top;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCsSpsolve = void 0;\n\nvar _csReach = require(\"./csReach.js\");\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar name = 'csSpsolve';\nvar dependencies = ['divideScalar', 'multiply', 'subtract'];\nvar createCsSpsolve = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var divideScalar = _ref.divideScalar,\n multiply = _ref.multiply,\n subtract = _ref.subtract;\n\n /**\n * The function csSpsolve() computes the solution to G * x = bk, where bk is the\n * kth column of B. When lo is true, the function assumes G = L is lower triangular with the\n * diagonal entry as the first entry in each column. When lo is true, the function assumes G = U\n * is upper triangular with the diagonal entry as the last entry in each column.\n *\n * @param {Matrix} g The G matrix\n * @param {Matrix} b The B matrix\n * @param {Number} k The kth column in B\n * @param {Array} xi The nonzero pattern xi[top] .. xi[n - 1], an array of size = 2 * n\n * The first n entries is the nonzero pattern, the last n entries is the stack\n * @param {Array} x The soluton to the linear system G * x = b\n * @param {Array} pinv The inverse row permutation vector, must be null for L * x = b\n * @param {boolean} lo The lower (true) upper triangular (false) flag\n *\n * @return {Number} The index for the nonzero pattern\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\n return function csSpsolve(g, b, k, xi, x, pinv, lo) {\n // g arrays\n var gvalues = g._values;\n var gindex = g._index;\n var gptr = g._ptr;\n var gsize = g._size; // columns\n\n var n = gsize[1]; // b arrays\n\n var bvalues = b._values;\n var bindex = b._index;\n var bptr = b._ptr; // vars\n\n var p, p0, p1, q; // xi[top..n-1] = csReach(B(:,k))\n\n var top = (0, _csReach.csReach)(g, b, k, xi, pinv); // clear x\n\n for (p = top; p < n; p++) {\n x[xi[p]] = 0;\n } // scatter b\n\n\n for (p0 = bptr[k], p1 = bptr[k + 1], p = p0; p < p1; p++) {\n x[bindex[p]] = bvalues[p];\n } // loop columns\n\n\n for (var px = top; px < n; px++) {\n // x array index for px\n var j = xi[px]; // apply permutation vector (U x = b), j maps to column J of G\n\n var J = pinv ? pinv[j] : j; // check column J is empty\n\n if (J < 0) {\n continue;\n } // column value indeces in G, p0 <= p < p1\n\n\n p0 = gptr[J];\n p1 = gptr[J + 1]; // x(j) /= G(j,j)\n\n x[j] = divideScalar(x[j], gvalues[lo ? p0 : p1 - 1]); // first entry L(j,j)\n\n p = lo ? p0 + 1 : p0;\n q = lo ? p1 : p1 - 1; // loop\n\n for (; p < q; p++) {\n // row\n var i = gindex[p]; // x(i) -= G(i,j) * x(j)\n\n x[i] = subtract(x[i], multiply(gvalues[p], x[j]));\n }\n } // return top of stack\n\n\n return top;\n };\n});\nexports.createCsSpsolve = createCsSpsolve;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCsSqr = void 0;\n\nvar _csPermute = require(\"./csPermute.js\");\n\nvar _csPost = require(\"./csPost.js\");\n\nvar _csEtree = require(\"./csEtree.js\");\n\nvar _csAmd = require(\"./csAmd.js\");\n\nvar _csCounts = require(\"./csCounts.js\");\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar name = 'csSqr';\nvar dependencies = ['add', 'multiply', 'transpose'];\nvar createCsSqr = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var add = _ref.add,\n multiply = _ref.multiply,\n transpose = _ref.transpose;\n var csAmd = (0, _csAmd.createCsAmd)({\n add: add,\n multiply: multiply,\n transpose: transpose\n });\n var csCounts = (0, _csCounts.createCsCounts)({\n transpose: transpose\n });\n /**\n * Symbolic ordering and analysis for QR and LU decompositions.\n *\n * @param {Number} order The ordering strategy (see csAmd for more details)\n * @param {Matrix} a The A matrix\n * @param {boolean} qr Symbolic ordering and analysis for QR decomposition (true) or\n * symbolic ordering and analysis for LU decomposition (false)\n *\n * @return {Object} The Symbolic ordering and analysis for matrix A\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\n\n return function csSqr(order, a, qr) {\n // a arrays\n var aptr = a._ptr;\n var asize = a._size; // columns\n\n var n = asize[1]; // vars\n\n var k; // symbolic analysis result\n\n var s = {}; // fill-reducing ordering\n\n s.q = csAmd(order, a); // validate results\n\n if (order && !s.q) {\n return null;\n } // QR symbolic analysis\n\n\n if (qr) {\n // apply permutations if needed\n var c = order ? (0, _csPermute.csPermute)(a, null, s.q, 0) : a; // etree of C'*C, where C=A(:,q)\n\n s.parent = (0, _csEtree.csEtree)(c, 1); // post order elimination tree\n\n var post = (0, _csPost.csPost)(s.parent, n); // col counts chol(C'*C)\n\n s.cp = csCounts(c, s.parent, post, 1); // check we have everything needed to calculate number of nonzero elements\n\n if (c && s.parent && s.cp && _vcount(c, s)) {\n // calculate number of nonzero elements\n for (s.unz = 0, k = 0; k < n; k++) {\n s.unz += s.cp[k];\n }\n }\n } else {\n // for LU factorization only, guess nnz(L) and nnz(U)\n s.unz = 4 * aptr[n] + n;\n s.lnz = s.unz;\n } // return result S\n\n\n return s;\n };\n /**\n * Compute nnz(V) = s.lnz, s.pinv, s.leftmost, s.m2 from A and s.parent\n */\n\n function _vcount(a, s) {\n // a arrays\n var aptr = a._ptr;\n var aindex = a._index;\n var asize = a._size; // rows & columns\n\n var m = asize[0];\n var n = asize[1]; // initialize s arrays\n\n s.pinv = []; // (m + n)\n\n s.leftmost = []; // (m)\n // vars\n\n var parent = s.parent;\n var pinv = s.pinv;\n var leftmost = s.leftmost; // workspace, next: first m entries, head: next n entries, tail: next n entries, nque: next n entries\n\n var w = []; // (m + 3 * n)\n\n var next = 0;\n var head = m;\n var tail = m + n;\n var nque = m + 2 * n; // vars\n\n var i, k, p, p0, p1; // initialize w\n\n for (k = 0; k < n; k++) {\n // queue k is empty\n w[head + k] = -1;\n w[tail + k] = -1;\n w[nque + k] = 0;\n } // initialize row arrays\n\n\n for (i = 0; i < m; i++) {\n leftmost[i] = -1;\n } // loop columns backwards\n\n\n for (k = n - 1; k >= 0; k--) {\n // values & index for column k\n for (p0 = aptr[k], p1 = aptr[k + 1], p = p0; p < p1; p++) {\n // leftmost[i] = min(find(A(i,:)))\n leftmost[aindex[p]] = k;\n }\n } // scan rows in reverse order\n\n\n for (i = m - 1; i >= 0; i--) {\n // row i is not yet ordered\n pinv[i] = -1;\n k = leftmost[i]; // check row i is empty\n\n if (k === -1) {\n continue;\n } // first row in queue k\n\n\n if (w[nque + k]++ === 0) {\n w[tail + k] = i;\n } // put i at head of queue k\n\n\n w[next + i] = w[head + k];\n w[head + k] = i;\n }\n\n s.lnz = 0;\n s.m2 = m; // find row permutation and nnz(V)\n\n for (k = 0; k < n; k++) {\n // remove row i from queue k\n i = w[head + k]; // count V(k,k) as nonzero\n\n s.lnz++; // add a fictitious row\n\n if (i < 0) {\n i = s.m2++;\n } // associate row i with V(:,k)\n\n\n pinv[i] = k; // skip if V(k+1:m,k) is empty\n\n if (--nque[k] <= 0) {\n continue;\n } // nque[k] is nnz (V(k+1:m,k))\n\n\n s.lnz += w[nque + k]; // move all rows to parent of k\n\n var pa = parent[k];\n\n if (pa !== -1) {\n if (w[nque + pa] === 0) {\n w[tail + pa] = w[tail + k];\n }\n\n w[next + w[tail + k]] = w[head + pa];\n w[head + pa] = w[next + i];\n w[nque + pa] += w[nque + k];\n }\n }\n\n for (i = 0; i < m; i++) {\n if (pinv[i] < 0) {\n pinv[i] = k++;\n }\n }\n\n return true;\n }\n});\nexports.createCsSqr = createCsSqr;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csTdfs = csTdfs;\n\n/**\n * Depth-first search and postorder of a tree rooted at node j\n *\n * @param {Number} j The tree node\n * @param {Number} k\n * @param {Array} w The workspace array\n * @param {Number} head The index offset within the workspace for the head array\n * @param {Number} next The index offset within the workspace for the next array\n * @param {Array} post The post ordering array\n * @param {Number} stack The index offset within the workspace for the stack array\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\nfunction csTdfs(j, k, w, head, next, post, stack) {\n // variables\n var top = 0; // place j on the stack\n\n w[stack] = j; // while (stack is not empty)\n\n while (top >= 0) {\n // p = top of stack\n var p = w[stack + top]; // i = youngest child of p\n\n var i = w[head + p];\n\n if (i === -1) {\n // p has no unordered children left\n top--; // node p is the kth postordered node\n\n post[k++] = p;\n } else {\n // remove i from children of p\n w[head + p] = w[next + i]; // increment top\n\n ++top; // start dfs on child node i\n\n w[stack + top] = i;\n }\n }\n\n return k;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.csUnflip = csUnflip;\n\nvar _csFlip = require(\"./csFlip.js\");\n\n/**\n * Flips the value if it is negative of returns the same value otherwise.\n *\n * @param {Number} i The value to flip\n *\n * Reference: http://faculty.cse.tamu.edu/davis/publications.html\n */\nfunction csUnflip(i) {\n // flip the value if it is negative\n return i < 0 ? (0, _csFlip.csFlip)(i) : i;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSymbolicEqual = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'symbolicEqual';\nvar dependencies = ['parse', 'simplify', 'typed', 'OperatorNode'];\nvar createSymbolicEqual = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var parse = _ref.parse,\n simplify = _ref.simplify,\n typed = _ref.typed,\n OperatorNode = _ref.OperatorNode;\n\n /**\n * Attempts to determine if two expressions are symbolically equal, i.e.\n * one is the result of valid algebraic manipulations on the other.\n * Currently, this simply checks if the difference of the two expressions\n * simplifies down to 0. So there are two important caveats:\n * 1. whether two expressions are symbolically equal depends on the\n * manipulations allowed. Therefore, this function takes an optional\n * third argument, which are the options that control the behavior\n * as documented for the `simplify()` function.\n * 2. it is in general intractable to find the minimal simplification of\n * an arbitrarily complicated expression. So while a `true` value\n * of `symbolicEqual` ensures that the two expressions can be manipulated\n * to match each other, a `false` value does not absolutely rule this out.\n *\n * Syntax:\n *\n * symbolicEqual(expr1, expr2)\n * symbolicEqual(expr1, expr2, options)\n *\n * Examples:\n *\n * symbolicEqual('x*y', 'y*x') // true\n * symbolicEqual('x*y', 'y*x', {context: {multiply: {commutative: false}}})\n * //false\n * symbolicEqual('x/y', '(y*x^(-1))^(-1)') // true\n * symbolicEqual('abs(x)','x') // false\n * symbolicEqual('abs(x)','x', simplify.positiveContext) // true\n *\n * See also:\n *\n * simplify, evaluate\n *\n * @param {Node|string} expr1 The first expression to compare\n * @param {Node|string} expr2 The second expression to compare\n * @param {Object} [options] Optional option object, passed to simplify\n * @returns {boolean}\n * Returns true if a valid manipulation making the expressions equal\n * is found.\n */\n return typed(name, {\n 'string, string': function stringString(s1, s2) {\n return this(parse(s1), parse(s2), {});\n },\n 'string, string, Object': function stringStringObject(s1, s2, options) {\n return this(parse(s1), parse(s2), options);\n },\n 'Node, string': function NodeString(e1, s2) {\n return this(e1, parse(s2), {});\n },\n 'Node, string, Object': function NodeStringObject(e1, s2, options) {\n return this(e1, parse(s2), options);\n },\n 'string, Node': function stringNode(s1, e2) {\n return this(parse(s1), e2, {});\n },\n 'string, Node, Object': function stringNodeObject(s1, e2, options) {\n return this(parse(s1), e2, options);\n },\n 'Node, Node': function NodeNode(e1, e2) {\n return this(e1, e2, {});\n },\n 'Node, Node, Object': function NodeNodeObject(e1, e2, options) {\n var diff = new OperatorNode('-', 'subtract', [e1, e2]);\n var simplified = simplify(diff, {}, options);\n return (0, _is.isConstantNode)(simplified) && !simplified.value;\n }\n });\n});\nexports.createSymbolicEqual = createSymbolicEqual;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAbs = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'abs';\nvar dependencies = ['typed'];\nvar createAbs = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Calculate the absolute value of a number. For matrices, the function is\n * evaluated element wise.\n *\n * Syntax:\n *\n * math.abs(x)\n *\n * Examples:\n *\n * math.abs(3.5) // returns number 3.5\n * math.abs(-4.2) // returns number 4.2\n *\n * math.abs([3, -5, -1, 0, 2]) // returns Array [3, 5, 1, 0, 2]\n *\n * See also:\n *\n * sign\n *\n * @param {number | BigNumber | Fraction | Complex | Array | Matrix | Unit} x\n * A number or matrix for which to get the absolute value\n * @return {number | BigNumber | Fraction | Complex | Array | Matrix | Unit}\n * Absolute value of `x`\n */\n return typed(name, {\n number: _index.absNumber,\n Complex: function Complex(x) {\n return x.abs();\n },\n BigNumber: function BigNumber(x) {\n return x.abs();\n },\n Fraction: function Fraction(x) {\n return x.abs();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since abs(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n },\n Unit: function Unit(x) {\n return x.abs();\n }\n });\n});\nexports.createAbs = createAbs;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAdd = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm01.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm04.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm10.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'add';\nvar dependencies = ['typed', 'matrix', 'addScalar', 'equalScalar', 'DenseMatrix', 'SparseMatrix'];\nvar createAdd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n addScalar = _ref.addScalar,\n equalScalar = _ref.equalScalar,\n DenseMatrix = _ref.DenseMatrix,\n SparseMatrix = _ref.SparseMatrix;\n var algorithm01 = (0, _algorithm.createAlgorithm01)({\n typed: typed\n });\n var algorithm04 = (0, _algorithm2.createAlgorithm04)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm10 = (0, _algorithm3.createAlgorithm10)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm4.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm5.createAlgorithm14)({\n typed: typed\n });\n /**\n * Add two or more values, `x + y`.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.add(x, y)\n * math.add(x, y, z, ...)\n *\n * Examples:\n *\n * math.add(2, 3) // returns number 5\n * math.add(2, 3, 4) // returns number 9\n *\n * const a = math.complex(2, 3)\n * const b = math.complex(-4, 1)\n * math.add(a, b) // returns Complex -2 + 4i\n *\n * math.add([1, 2, 3], 4) // returns Array [5, 6, 7]\n *\n * const c = math.unit('5 cm')\n * const d = math.unit('2.1 mm')\n * math.add(c, d) // returns Unit 52.1 mm\n *\n * math.add(\"2.3\", \"4\") // returns number 6.3\n *\n * See also:\n *\n * subtract, sum\n *\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x First value to add\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Second value to add\n * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Sum of `x` and `y`\n */\n\n return typed(name, (0, _object.extend)({\n // we extend the signatures of addScalar with signatures dealing with matrices\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, addScalar);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm01(x, y, addScalar, false);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm01(y, x, addScalar, true);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm04(x, y, addScalar);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, addScalar, false);\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm10(x, y, addScalar, false);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, addScalar, true);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm10(y, x, addScalar, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, addScalar, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, addScalar, true).valueOf();\n },\n 'any, any': addScalar,\n 'any, any, ...any': function anyAnyAny(x, y, rest) {\n var result = this(x, y);\n\n for (var i = 0; i < rest.length; i++) {\n result = this(result, rest[i]);\n }\n\n return result;\n }\n }, addScalar.signatures));\n});\nexports.createAdd = createAdd;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAddScalar = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'addScalar';\nvar dependencies = ['typed'];\nvar createAddScalar = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Add two scalar values, `x + y`.\n * This function is meant for internal use: it is used by the public function\n * `add`\n *\n * This function does not support collections (Array or Matrix).\n *\n * @param {number | BigNumber | Fraction | Complex | Unit} x First value to add\n * @param {number | BigNumber | Fraction | Complex} y Second value to add\n * @return {number | BigNumber | Fraction | Complex | Unit} Sum of `x` and `y`\n * @private\n */\n return typed(name, {\n 'number, number': _index.addNumber,\n 'Complex, Complex': function ComplexComplex(x, y) {\n return x.add(y);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return x.plus(y);\n },\n 'Fraction, Fraction': function FractionFraction(x, y) {\n return x.add(y);\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n if (x.value === null || x.value === undefined) throw new Error('Parameter x contains a unit with undefined value');\n if (y.value === null || y.value === undefined) throw new Error('Parameter y contains a unit with undefined value');\n if (!x.equalBase(y)) throw new Error('Units do not match');\n var res = x.clone();\n res.value = this(res.value, y.value);\n res.fixPrefix = false;\n return res;\n }\n });\n});\nexports.createAddScalar = createAddScalar;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCbrt = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'cbrt';\nvar dependencies = ['config', 'typed', 'isNegative', 'unaryMinus', 'matrix', 'Complex', 'BigNumber', 'Fraction'];\nvar createCbrt = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var config = _ref.config,\n typed = _ref.typed,\n isNegative = _ref.isNegative,\n unaryMinus = _ref.unaryMinus,\n matrix = _ref.matrix,\n Complex = _ref.Complex,\n BigNumber = _ref.BigNumber,\n Fraction = _ref.Fraction;\n\n /**\n * Calculate the cubic root of a value.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.cbrt(x)\n * math.cbrt(x, allRoots)\n *\n * Examples:\n *\n * math.cbrt(27) // returns 3\n * math.cube(3) // returns 27\n * math.cbrt(-64) // returns -4\n * math.cbrt(math.unit('27 m^3')) // returns Unit 3 m\n * math.cbrt([27, 64, 125]) // returns [3, 4, 5]\n *\n * const x = math.complex('8i')\n * math.cbrt(x) // returns Complex 1.7320508075689 + i\n * math.cbrt(x, true) // returns Matrix [\n * // 1.7320508075689 + i\n * // -1.7320508075689 + i\n * // -2i\n * // ]\n *\n * See also:\n *\n * square, sqrt, cube\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x\n * Value for which to calculate the cubic root.\n * @param {boolean} [allRoots] Optional, false by default. Only applicable\n * when `x` is a number or complex number. If true, all complex\n * roots are returned, if false (default) the principal root is\n * returned.\n * @return {number | BigNumber | Complex | Unit | Array | Matrix}\n * Returns the cubic root of `x`\n */\n return typed(name, {\n number: _index.cbrtNumber,\n // note: signature 'number, boolean' is also supported,\n // created by typed as it knows how to convert number to Complex\n Complex: _cbrtComplex,\n 'Complex, boolean': _cbrtComplex,\n BigNumber: function BigNumber(x) {\n return x.cbrt();\n },\n Unit: _cbrtUnit,\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since cbrt(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n }\n });\n /**\n * Calculate the cubic root for a complex number\n * @param {Complex} x\n * @param {boolean} [allRoots] If true, the function will return an array\n * with all three roots. If false or undefined,\n * the principal root is returned.\n * @returns {Complex | Array. | Matrix.} Returns the cubic root(s) of x\n * @private\n */\n\n function _cbrtComplex(x, allRoots) {\n // https://www.wikiwand.com/en/Cube_root#/Complex_numbers\n var arg3 = x.arg() / 3;\n var abs = x.abs(); // principal root:\n\n var principal = new Complex((0, _index.cbrtNumber)(abs), 0).mul(new Complex(0, arg3).exp());\n\n if (allRoots) {\n var all = [principal, new Complex((0, _index.cbrtNumber)(abs), 0).mul(new Complex(0, arg3 + Math.PI * 2 / 3).exp()), new Complex((0, _index.cbrtNumber)(abs), 0).mul(new Complex(0, arg3 - Math.PI * 2 / 3).exp())];\n return config.matrix === 'Array' ? all : matrix(all);\n } else {\n return principal;\n }\n }\n /**\n * Calculate the cubic root for a Unit\n * @param {Unit} x\n * @return {Unit} Returns the cubic root of x\n * @private\n */\n\n\n function _cbrtUnit(x) {\n if (x.value && (0, _is.isComplex)(x.value)) {\n var result = x.clone();\n result.value = 1.0;\n result = result.pow(1.0 / 3); // Compute the units\n\n result.value = _cbrtComplex(x.value); // Compute the value\n\n return result;\n } else {\n var negate = isNegative(x.value);\n\n if (negate) {\n x.value = unaryMinus(x.value);\n } // TODO: create a helper function for this\n\n\n var third;\n\n if ((0, _is.isBigNumber)(x.value)) {\n third = new BigNumber(1).div(3);\n } else if ((0, _is.isFraction)(x.value)) {\n third = new Fraction(1, 3);\n } else {\n third = 1 / 3;\n }\n\n var _result = x.pow(third);\n\n if (negate) {\n _result.value = unaryMinus(_result.value);\n }\n\n return _result;\n }\n }\n});\nexports.createCbrt = createCbrt;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCeilNumber = exports.createCeil = void 0;\n\nvar _slicedToArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/slicedToArray\"));\n\nvar _decimal = _interopRequireDefault(require(\"decimal.js\"));\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _nearlyEqual = require(\"../../utils/bignumber/nearlyEqual.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'ceil';\nvar dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix'];\nvar createCeilNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config', 'round'], function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n round = _ref.round;\n return typed(name, {\n number: function number(x) {\n if ((0, _number.nearlyEqual)(x, round(x), config.epsilon)) {\n return round(x);\n } else {\n return Math.ceil(x);\n }\n },\n 'number, number': function numberNumber(x, n) {\n if ((0, _number.nearlyEqual)(x, round(x, n), config.epsilon)) {\n return round(x, n);\n } else {\n var _split = \"\".concat(x, \"e\").split('e'),\n _split2 = (0, _slicedToArray2.default)(_split, 2),\n number = _split2[0],\n exponent = _split2[1];\n\n var result = Math.ceil(Number(\"\".concat(number, \"e\").concat(Number(exponent) + n)));\n\n var _split3 = \"\".concat(result, \"e\").split('e');\n\n var _split4 = (0, _slicedToArray2.default)(_split3, 2);\n\n number = _split4[0];\n exponent = _split4[1];\n return Number(\"\".concat(number, \"e\").concat(Number(exponent) - n));\n }\n }\n });\n});\nexports.createCeilNumber = createCeilNumber;\nvar createCeil = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref2) {\n var typed = _ref2.typed,\n config = _ref2.config,\n round = _ref2.round,\n matrix = _ref2.matrix,\n equalScalar = _ref2.equalScalar,\n zeros = _ref2.zeros,\n DenseMatrix = _ref2.DenseMatrix;\n var algorithm11 = (0, _algorithm.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm12 = (0, _algorithm2.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm14 = (0, _algorithm3.createAlgorithm14)({\n typed: typed\n });\n var ceilNumber = createCeilNumber({\n typed: typed,\n config: config,\n round: round\n });\n /**\n * Round a value towards plus infinity\n * If `x` is complex, both real and imaginary part are rounded towards plus infinity.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.ceil(x)\n * math.ceil(x, n)\n *\n * Examples:\n *\n * math.ceil(3.2) // returns number 4\n * math.ceil(3.8) // returns number 4\n * math.ceil(-4.2) // returns number -4\n * math.ceil(-4.7) // returns number -4\n *\n * math.ceil(3.212, 2) // returns number 3.22\n * math.ceil(3.288, 2) // returns number 3.29\n * math.ceil(-4.212, 2) // returns number -4.21\n * math.ceil(-4.782, 2) // returns number -4.78\n *\n * const c = math.complex(3.24, -2.71)\n * math.ceil(c) // returns Complex 4 - 2i\n * math.ceil(c, 1) // returns Complex 3.3 - 2.7i\n *\n * math.ceil([3.2, 3.8, -4.7]) // returns Array [4, 4, -4]\n * math.ceil([3.21, 3.82, -4.71], 1) // returns Array [3.3, 3.9, -4.7]\n *\n * See also:\n *\n * floor, fix, round\n *\n * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded\n * @param {number | BigNumber | Array} [n=0] Number of decimals\n * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value\n */\n\n return typed('ceil', {\n number: ceilNumber.signatures.number,\n 'number,number': ceilNumber.signatures['number,number'],\n Complex: function Complex(x) {\n return x.ceil();\n },\n 'Complex, number': function ComplexNumber(x, n) {\n return x.ceil(n);\n },\n 'Complex, BigNumber': function ComplexBigNumber(x, n) {\n return x.ceil(n.toNumber());\n },\n BigNumber: function BigNumber(x) {\n if ((0, _nearlyEqual.nearlyEqual)(x, round(x), config.epsilon)) {\n return round(x);\n } else {\n return x.ceil();\n }\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, n) {\n if ((0, _nearlyEqual.nearlyEqual)(x, round(x, n), config.epsilon)) {\n return round(x, n);\n } else {\n return x.toDecimalPlaces(n.toNumber(), _decimal.default.ROUND_CEIL);\n }\n },\n Fraction: function Fraction(x) {\n return x.ceil();\n },\n 'Fraction, number': function FractionNumber(x, n) {\n return x.ceil(n);\n },\n 'Fraction, BigNumber': function FractionBigNumber(x, n) {\n return x.ceil(n.toNumber());\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since ceil(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n },\n 'Array, number | BigNumber': function ArrayNumberBigNumber(x, n) {\n var _this = this;\n\n // deep map collection, skip zeros since ceil(0) = 0\n return (0, _collection.deepMap)(x, function (i) {\n return _this(i, n);\n }, true);\n },\n 'SparseMatrix, number | BigNumber': function SparseMatrixNumberBigNumber(x, y) {\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, number | BigNumber': function DenseMatrixNumberBigNumber(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'number | Complex | Fraction | BigNumber, Array': function numberComplexFractionBigNumberArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n },\n 'number | Complex | Fraction | BigNumber, Matrix': function numberComplexFractionBigNumberMatrix(x, y) {\n if (equalScalar(x, 0)) return zeros(y.size(), y.storage());\n\n if (y.storage() === 'dense') {\n return algorithm14(y, x, this, true);\n }\n\n return algorithm12(y, x, this, true);\n }\n });\n});\nexports.createCeil = createCeil;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCube = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'cube';\nvar dependencies = ['typed'];\nvar createCube = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Compute the cube of a value, `x * x * x`.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.cube(x)\n *\n * Examples:\n *\n * math.cube(2) // returns number 8\n * math.pow(2, 3) // returns number 8\n * math.cube(4) // returns number 64\n * 4 * 4 * 4 // returns number 64\n *\n * math.cube([1, 2, 3, 4]) // returns Array [1, 8, 27, 64]\n *\n * See also:\n *\n * multiply, square, pow, cbrt\n *\n * @param {number | BigNumber | Fraction | Complex | Array | Matrix | Unit} x Number for which to calculate the cube\n * @return {number | BigNumber | Fraction | Complex | Array | Matrix | Unit} Cube of x\n */\n return typed(name, {\n number: _index.cubeNumber,\n Complex: function Complex(x) {\n return x.mul(x).mul(x); // Is faster than pow(x, 3)\n },\n BigNumber: function BigNumber(x) {\n return x.times(x).times(x);\n },\n Fraction: function Fraction(x) {\n return x.pow(3); // Is faster than mul()mul()mul()\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since cube(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n },\n Unit: function Unit(x) {\n return x.pow(3);\n }\n });\n});\nexports.createCube = createCube;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDivide = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'divide';\nvar dependencies = ['typed', 'matrix', 'multiply', 'equalScalar', 'divideScalar', 'inv'];\nvar createDivide = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n multiply = _ref.multiply,\n equalScalar = _ref.equalScalar,\n divideScalar = _ref.divideScalar,\n inv = _ref.inv;\n var algorithm11 = (0, _algorithm.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm14 = (0, _algorithm2.createAlgorithm14)({\n typed: typed\n });\n /**\n * Divide two values, `x / y`.\n * To divide matrices, `x` is multiplied with the inverse of `y`: `x * inv(y)`.\n *\n * Syntax:\n *\n * math.divide(x, y)\n *\n * Examples:\n *\n * math.divide(2, 3) // returns number 0.6666666666666666\n *\n * const a = math.complex(5, 14)\n * const b = math.complex(4, 1)\n * math.divide(a, b) // returns Complex 2 + 3i\n *\n * const c = [[7, -6], [13, -4]]\n * const d = [[1, 2], [4, 3]]\n * math.divide(c, d) // returns Array [[-9, 4], [-11, 6]]\n *\n * const e = math.unit('18 km')\n * math.divide(e, 4.5) // returns Unit 4 km\n *\n * See also:\n *\n * multiply\n *\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Numerator\n * @param {number | BigNumber | Fraction | Complex | Array | Matrix} y Denominator\n * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Quotient, `x / y`\n */\n\n return typed('divide', (0, _object.extend)({\n // we extend the signatures of divideScalar with signatures dealing with matrices\n 'Array | Matrix, Array | Matrix': function ArrayMatrixArrayMatrix(x, y) {\n // TODO: implement matrix right division using pseudo inverse\n // https://www.mathworks.nl/help/matlab/ref/mrdivide.html\n // https://www.gnu.org/software/octave/doc/interpreter/Arithmetic-Ops.html\n // https://stackoverflow.com/questions/12263932/how-does-gnu-octave-matrix-division-work-getting-unexpected-behaviour\n return multiply(x, inv(y));\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, divideScalar, false);\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm11(x, y, divideScalar, false);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, divideScalar, false).valueOf();\n },\n 'any, Array | Matrix': function anyArrayMatrix(x, y) {\n return multiply(x, inv(y));\n }\n }, divideScalar.signatures));\n});\nexports.createDivide = createDivide;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDivideScalar = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar name = 'divideScalar';\nvar dependencies = ['typed', 'numeric'];\nvar createDivideScalar = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n numeric = _ref.numeric;\n\n /**\n * Divide two scalar values, `x / y`.\n * This function is meant for internal use: it is used by the public functions\n * `divide` and `inv`.\n *\n * This function does not support collections (Array or Matrix).\n *\n * @param {number | BigNumber | Fraction | Complex | Unit} x Numerator\n * @param {number | BigNumber | Fraction | Complex} y Denominator\n * @return {number | BigNumber | Fraction | Complex | Unit} Quotient, `x / y`\n * @private\n */\n return typed(name, {\n 'number, number': function numberNumber(x, y) {\n return x / y;\n },\n 'Complex, Complex': function ComplexComplex(x, y) {\n return x.div(y);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return x.div(y);\n },\n 'Fraction, Fraction': function FractionFraction(x, y) {\n return x.div(y);\n },\n 'Unit, number | Fraction | BigNumber': function UnitNumberFractionBigNumber(x, y) {\n var res = x.clone(); // TODO: move the divide function to Unit.js, it uses internals of Unit\n\n var one = numeric(1, (0, _is.typeOf)(y));\n res.value = this(res.value === null ? res._normalize(one) : res.value, y);\n return res;\n },\n 'number | Fraction | BigNumber, Unit': function numberFractionBigNumberUnit(x, y) {\n var res = y.clone();\n res = res.pow(-1); // TODO: move the divide function to Unit.js, it uses internals of Unit\n\n var one = numeric(1, (0, _is.typeOf)(x));\n res.value = this(x, y.value === null ? y._normalize(one) : y.value);\n return res;\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n return x.divide(y);\n }\n });\n});\nexports.createDivideScalar = createDivideScalar;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDotDivide = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm02.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm07.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm6 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm7 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'dotDivide';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'divideScalar', 'DenseMatrix'];\nvar createDotDivide = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n divideScalar = _ref.divideScalar,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm02 = (0, _algorithm.createAlgorithm02)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm03 = (0, _algorithm2.createAlgorithm03)({\n typed: typed\n });\n var algorithm07 = (0, _algorithm3.createAlgorithm07)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm11 = (0, _algorithm4.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm12 = (0, _algorithm5.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm6.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm7.createAlgorithm14)({\n typed: typed\n });\n /**\n * Divide two matrices element wise. The function accepts both matrices and\n * scalar values.\n *\n * Syntax:\n *\n * math.dotDivide(x, y)\n *\n * Examples:\n *\n * math.dotDivide(2, 4) // returns 0.5\n *\n * a = [[9, 5], [6, 1]]\n * b = [[3, 2], [5, 2]]\n *\n * math.dotDivide(a, b) // returns [[3, 2.5], [1.2, 0.5]]\n * math.divide(a, b) // returns [[1.75, 0.75], [-1.75, 2.25]]\n *\n * See also:\n *\n * divide, multiply, dotMultiply\n *\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Numerator\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Denominator\n * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Quotient, `x ./ y`\n */\n\n return typed(name, {\n 'any, any': divideScalar,\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm07(x, y, divideScalar, false);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm02(y, x, divideScalar, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, divideScalar, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, divideScalar);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm11(x, y, divideScalar, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, divideScalar, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, divideScalar, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, divideScalar, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, divideScalar, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, divideScalar, true).valueOf();\n }\n });\n});\nexports.createDotDivide = createDotDivide;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDotMultiply = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm02.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm09.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'dotMultiply';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'multiplyScalar'];\nvar createDotMultiply = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n multiplyScalar = _ref.multiplyScalar;\n var algorithm02 = (0, _algorithm.createAlgorithm02)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm09 = (0, _algorithm2.createAlgorithm09)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm11 = (0, _algorithm3.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm13 = (0, _algorithm4.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm5.createAlgorithm14)({\n typed: typed\n });\n /**\n * Multiply two matrices element wise. The function accepts both matrices and\n * scalar values.\n *\n * Syntax:\n *\n * math.dotMultiply(x, y)\n *\n * Examples:\n *\n * math.dotMultiply(2, 4) // returns 8\n *\n * a = [[9, 5], [6, 1]]\n * b = [[3, 2], [5, 2]]\n *\n * math.dotMultiply(a, b) // returns [[27, 10], [30, 2]]\n * math.multiply(a, b) // returns [[52, 28], [23, 14]]\n *\n * See also:\n *\n * multiply, divide, dotDivide\n *\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Left hand value\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Right hand value\n * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Multiplication of `x` and `y`\n */\n\n return typed(name, {\n 'any, any': multiplyScalar,\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm09(x, y, multiplyScalar, false);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm02(y, x, multiplyScalar, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm02(x, y, multiplyScalar, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, multiplyScalar);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm11(x, y, multiplyScalar, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, multiplyScalar, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm11(y, x, multiplyScalar, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, multiplyScalar, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, multiplyScalar, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, multiplyScalar, true).valueOf();\n }\n });\n});\nexports.createDotMultiply = createDotMultiply;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDotPow = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm07.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm6 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'dotPow';\nvar dependencies = ['typed', 'equalScalar', 'matrix', 'pow', 'DenseMatrix'];\nvar createDotPow = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n equalScalar = _ref.equalScalar,\n matrix = _ref.matrix,\n pow = _ref.pow,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm03 = (0, _algorithm.createAlgorithm03)({\n typed: typed\n });\n var algorithm07 = (0, _algorithm2.createAlgorithm07)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm11 = (0, _algorithm3.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm12 = (0, _algorithm4.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm5.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm6.createAlgorithm14)({\n typed: typed\n });\n /**\n * Calculates the power of x to y element wise.\n *\n * Syntax:\n *\n * math.dotPow(x, y)\n *\n * Examples:\n *\n * math.dotPow(2, 3) // returns number 8\n *\n * const a = [[1, 2], [4, 3]]\n * math.dotPow(a, 2) // returns Array [[1, 4], [16, 9]]\n * math.pow(a, 2) // returns Array [[9, 8], [16, 17]]\n *\n * See also:\n *\n * pow, sqrt, multiply\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x The base\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} y The exponent\n * @return {number | BigNumber | Complex | Unit | Array | Matrix} The value of `x` to the power `y`\n */\n\n return typed(name, {\n 'any, any': pow,\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm07(x, y, pow, false);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm03(y, x, pow, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, pow, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, pow);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createDotPow = createDotPow;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createExp = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'exp';\nvar dependencies = ['typed'];\nvar createExp = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Calculate the exponent of a value.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.exp(x)\n *\n * Examples:\n *\n * math.exp(2) // returns number 7.3890560989306495\n * math.pow(math.e, 2) // returns number 7.3890560989306495\n * math.log(math.exp(2)) // returns number 2\n *\n * math.exp([1, 2, 3])\n * // returns Array [\n * // 2.718281828459045,\n * // 7.3890560989306495,\n * // 20.085536923187668\n * // ]\n *\n * See also:\n *\n * expm1, log, pow\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x A number or matrix to exponentiate\n * @return {number | BigNumber | Complex | Array | Matrix} Exponent of `x`\n */\n return typed(name, {\n number: _index.expNumber,\n Complex: function Complex(x) {\n return x.exp();\n },\n BigNumber: function BigNumber(x) {\n return x.exp();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // TODO: exp(sparse) should return a dense matrix since exp(0)==1\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createExp = createExp;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createExpm1 = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'expm1';\nvar dependencies = ['typed', 'Complex'];\nvar createExpm1 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n _Complex = _ref.Complex;\n\n /**\n * Calculate the value of subtracting 1 from the exponential value.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.expm1(x)\n *\n * Examples:\n *\n * math.expm1(2) // returns number 6.38905609893065\n * math.pow(math.e, 2) - 1 // returns number 6.3890560989306495\n * math.log(math.expm1(2) + 1) // returns number 2\n *\n * math.expm1([1, 2, 3])\n * // returns Array [\n * // 1.718281828459045,\n * // 6.3890560989306495,\n * // 19.085536923187668\n * // ]\n *\n * See also:\n *\n * exp, log, pow\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x A number or matrix to apply expm1\n * @return {number | BigNumber | Complex | Array | Matrix} Exponent of `x`\n */\n return typed(name, {\n number: _index.expm1Number,\n Complex: function Complex(x) {\n var r = Math.exp(x.re);\n return new _Complex(r * Math.cos(x.im) - 1, r * Math.sin(x.im));\n },\n BigNumber: function BigNumber(x) {\n return x.exp().minus(1);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createExpm1 = createExpm1;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFixNumber = exports.createFix = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'fix';\nvar dependencies = ['typed', 'Complex', 'matrix', 'ceil', 'floor', 'equalScalar', 'zeros', 'DenseMatrix'];\nvar createFixNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'ceil', 'floor'], function (_ref) {\n var typed = _ref.typed,\n ceil = _ref.ceil,\n floor = _ref.floor;\n return typed(name, {\n number: function number(x) {\n return x > 0 ? floor(x) : ceil(x);\n },\n 'number, number': function numberNumber(x, n) {\n return x > 0 ? floor(x, n) : ceil(x, n);\n }\n });\n});\nexports.createFixNumber = createFixNumber;\nvar createFix = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref2) {\n var typed = _ref2.typed,\n _Complex = _ref2.Complex,\n matrix = _ref2.matrix,\n ceil = _ref2.ceil,\n floor = _ref2.floor,\n equalScalar = _ref2.equalScalar,\n zeros = _ref2.zeros,\n DenseMatrix = _ref2.DenseMatrix;\n var algorithm12 = (0, _algorithm.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm14 = (0, _algorithm2.createAlgorithm14)({\n typed: typed\n });\n var fixNumber = createFixNumber({\n typed: typed,\n ceil: ceil,\n floor: floor\n });\n /**\n * Round a value towards zero.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.fix(x)\n * math.fix(x,n)\n *\n * Examples:\n *\n * math.fix(3.2) // returns number 3\n * math.fix(3.8) // returns number 3\n * math.fix(-4.2) // returns number -4\n * math.fix(-4.7) // returns number -4\n *\n * math.fix(3.12, 1) // returns number 3.1\n * math.fix(3.18, 1) // returns number 3.1\n * math.fix(-4.12, 1) // returns number -4.1\n * math.fix(-4.17, 1) // returns number -4.1\n *\n * const c = math.complex(3.22, -2.78)\n * math.fix(c) // returns Complex 3 - 2i\n * math.fix(c, 1) // returns Complex 3.2 - 2.7i\n *\n * math.fix([3.2, 3.8, -4.7]) // returns Array [3, 3, -4]\n * math.fix([3.2, 3.8, -4.7], 1) // returns Array [3.2, 3.8, -4.7]\n *\n * See also:\n *\n * ceil, floor, round\n *\n * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded\n * @param {number | BigNumber | Array} [n=0] Number of decimals\n * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value\n */\n\n return typed('fix', {\n number: fixNumber.signatures.number,\n 'number, number | BigNumber': fixNumber.signatures['number,number'],\n Complex: function Complex(x) {\n return new _Complex(x.re > 0 ? Math.floor(x.re) : Math.ceil(x.re), x.im > 0 ? Math.floor(x.im) : Math.ceil(x.im));\n },\n 'Complex, number': function ComplexNumber(x, n) {\n return new _Complex(x.re > 0 ? floor(x.re, n) : ceil(x.re, n), x.im > 0 ? floor(x.im, n) : ceil(x.im, n));\n },\n 'Complex, BigNumber': function ComplexBigNumber(x, bn) {\n var n = bn.toNumber();\n return new _Complex(x.re > 0 ? floor(x.re, n) : ceil(x.re, n), x.im > 0 ? floor(x.im, n) : ceil(x.im, n));\n },\n BigNumber: function BigNumber(x) {\n return x.isNegative() ? ceil(x) : floor(x);\n },\n 'BigNumber, number | BigNumber': function BigNumberNumberBigNumber(x, n) {\n return x.isNegative() ? ceil(x, n) : floor(x, n);\n },\n Fraction: function Fraction(x) {\n return x.s < 0 ? x.ceil() : x.floor();\n },\n 'Fraction, number | BigNumber': function FractionNumberBigNumber(x, n) {\n return x.s < 0 ? ceil(x, n) : floor(x, n);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since fix(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n },\n 'Array | Matrix, number | BigNumber': function ArrayMatrixNumberBigNumber(x, n) {\n var _this = this;\n\n // deep map collection, skip zeros since fix(0) = 0\n return (0, _collection.deepMap)(x, function (i) {\n return _this(i, n);\n }, true);\n },\n 'number | Complex | Fraction | BigNumber, Array': function numberComplexFractionBigNumberArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n },\n 'number | Complex | Fraction | BigNumber, Matrix': function numberComplexFractionBigNumberMatrix(x, y) {\n if (equalScalar(x, 0)) return zeros(y.size(), y.storage());\n\n if (y.storage() === 'dense') {\n return algorithm14(y, x, this, true);\n }\n\n return algorithm12(y, x, this, true);\n }\n });\n});\nexports.createFix = createFix;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFloorNumber = exports.createFloor = void 0;\n\nvar _slicedToArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/slicedToArray\"));\n\nvar _decimal = _interopRequireDefault(require(\"decimal.js\"));\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _nearlyEqual = require(\"../../utils/bignumber/nearlyEqual.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'floor';\nvar dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix'];\nvar createFloorNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config', 'round'], function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n round = _ref.round;\n return typed(name, {\n number: function number(x) {\n if ((0, _number.nearlyEqual)(x, round(x), config.epsilon)) {\n return round(x);\n } else {\n return Math.floor(x);\n }\n },\n 'number, number': function numberNumber(x, n) {\n if ((0, _number.nearlyEqual)(x, round(x, n), config.epsilon)) {\n return round(x, n);\n } else {\n var _split = \"\".concat(x, \"e\").split('e'),\n _split2 = (0, _slicedToArray2.default)(_split, 2),\n number = _split2[0],\n exponent = _split2[1];\n\n var result = Math.floor(Number(\"\".concat(number, \"e\").concat(Number(exponent) + n)));\n\n var _split3 = \"\".concat(result, \"e\").split('e');\n\n var _split4 = (0, _slicedToArray2.default)(_split3, 2);\n\n number = _split4[0];\n exponent = _split4[1];\n return Number(\"\".concat(number, \"e\").concat(Number(exponent) - n));\n }\n }\n });\n});\nexports.createFloorNumber = createFloorNumber;\nvar createFloor = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref2) {\n var typed = _ref2.typed,\n config = _ref2.config,\n round = _ref2.round,\n matrix = _ref2.matrix,\n equalScalar = _ref2.equalScalar,\n zeros = _ref2.zeros,\n DenseMatrix = _ref2.DenseMatrix;\n var algorithm11 = (0, _algorithm.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm12 = (0, _algorithm2.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm14 = (0, _algorithm3.createAlgorithm14)({\n typed: typed\n });\n var floorNumber = createFloorNumber({\n typed: typed,\n config: config,\n round: round\n });\n /**\n * Round a value towards minus infinity.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.floor(x)\n * math.floor(x, n)\n *\n * Examples:\n *\n * math.floor(3.2) // returns number 3\n * math.floor(3.8) // returns number 3\n * math.floor(-4.2) // returns number -5\n * math.floor(-4.7) // returns number -5\n *\n * math.floor(3.212, 2) // returns number 3.21\n * math.floor(3.288, 2) // returns number 3.28\n * math.floor(-4.212, 2) // returns number -4.22\n * math.floor(-4.782, 2) // returns number -4.79\n *\n * const c = math.complex(3.24, -2.71)\n * math.floor(c) // returns Complex 3 - 3i\n * math.floor(c, 1) // returns Complex 3.2 - 2.8i\n *\n * math.floor([3.2, 3.8, -4.7]) // returns Array [3, 3, -5]\n * math.floor([3.21, 3.82, -4.71], 1) // returns Array [3.2, 3.8, -4.8]\n *\n * math.floor(math.tau, [2, 3]) // returns Array [6.28, 6.283]\n *\n * // Note that floor(array, array) currently not implemented.\n *\n * See also:\n *\n * ceil, fix, round\n *\n * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded\n * @param {number | BigNumber | Array} [n=0] Number of decimals\n * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value\n */\n\n return typed('floor', {\n number: floorNumber.signatures.number,\n 'number,number': floorNumber.signatures['number,number'],\n Complex: function Complex(x) {\n return x.floor();\n },\n 'Complex, number': function ComplexNumber(x, n) {\n return x.floor(n);\n },\n 'Complex, BigNumber': function ComplexBigNumber(x, n) {\n return x.floor(n.toNumber());\n },\n BigNumber: function BigNumber(x) {\n if ((0, _nearlyEqual.nearlyEqual)(x, round(x), config.epsilon)) {\n return round(x);\n } else {\n return x.floor();\n }\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, n) {\n if ((0, _nearlyEqual.nearlyEqual)(x, round(x, n), config.epsilon)) {\n return round(x, n);\n } else {\n return x.toDecimalPlaces(n.toNumber(), _decimal.default.ROUND_FLOOR);\n }\n },\n Fraction: function Fraction(x) {\n return x.floor();\n },\n 'Fraction, number': function FractionNumber(x, n) {\n return x.floor(n);\n },\n 'Fraction, BigNumber': function FractionBigNumber(x, n) {\n return x.floor(n.toNumber());\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since floor(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n },\n 'Array, number | BigNumber': function ArrayNumberBigNumber(x, n) {\n var _this = this;\n\n // deep map collection, skip zeros since ceil(0) = 0\n return (0, _collection.deepMap)(x, function (i) {\n return _this(i, n);\n }, true);\n },\n 'SparseMatrix, number | BigNumber': function SparseMatrixNumberBigNumber(x, y) {\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, number | BigNumber': function DenseMatrixNumberBigNumber(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'number | Complex | Fraction | BigNumber, Array': function numberComplexFractionBigNumberArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n },\n 'number | Complex | Fraction | BigNumber, Matrix': function numberComplexFractionBigNumberMatrix(x, y) {\n if (equalScalar(x, 0)) return zeros(y.size(), y.storage());\n\n if (y.storage() === 'dense') {\n return algorithm14(y, x, this, true);\n }\n\n return algorithm12(y, x, this, true);\n }\n });\n});\nexports.createFloor = createFloor;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createGcd = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm01.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm04.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm10.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'gcd';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'BigNumber', 'DenseMatrix'];\nvar createGcd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n BigNumber = _ref.BigNumber,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm01 = (0, _algorithm.createAlgorithm01)({\n typed: typed\n });\n var algorithm04 = (0, _algorithm2.createAlgorithm04)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm10 = (0, _algorithm3.createAlgorithm10)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm4.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm5.createAlgorithm14)({\n typed: typed\n });\n /**\n * Calculate the greatest common divisor for two or more values or arrays.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.gcd(a, b)\n * math.gcd(a, b, c, ...)\n *\n * Examples:\n *\n * math.gcd(8, 12) // returns 4\n * math.gcd(-4, 6) // returns 2\n * math.gcd(25, 15, -10) // returns 5\n *\n * math.gcd([8, -4], [12, 6]) // returns [4, 2]\n *\n * See also:\n *\n * lcm, xgcd\n *\n * @param {... number | BigNumber | Fraction | Array | Matrix} args Two or more integer numbers\n * @return {number | BigNumber | Fraction | Array | Matrix} The greatest common divisor\n */\n\n return typed(name, {\n 'number, number': _index.gcdNumber,\n 'BigNumber, BigNumber': _gcdBigNumber,\n 'Fraction, Fraction': function FractionFraction(x, y) {\n return x.gcd(y);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm04(x, y, this);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm01(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm01(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, number | BigNumber': function SparseMatrixNumberBigNumber(x, y) {\n return algorithm10(x, y, this, false);\n },\n 'DenseMatrix, number | BigNumber': function DenseMatrixNumberBigNumber(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'number | BigNumber, SparseMatrix': function numberBigNumberSparseMatrix(x, y) {\n return algorithm10(y, x, this, true);\n },\n 'number | BigNumber, DenseMatrix': function numberBigNumberDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, number | BigNumber': function ArrayNumberBigNumber(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'number | BigNumber, Array': function numberBigNumberArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n },\n // TODO: need a smarter notation here\n 'Array | Matrix | number | BigNumber, Array | Matrix | number | BigNumber, ...Array | Matrix | number | BigNumber': function ArrayMatrixNumberBigNumberArrayMatrixNumberBigNumberArrayMatrixNumberBigNumber(a, b, args) {\n var res = this(a, b);\n\n for (var i = 0; i < args.length; i++) {\n res = this(res, args[i]);\n }\n\n return res;\n }\n });\n /**\n * Calculate gcd for BigNumbers\n * @param {BigNumber} a\n * @param {BigNumber} b\n * @returns {BigNumber} Returns greatest common denominator of a and b\n * @private\n */\n\n function _gcdBigNumber(a, b) {\n if (!a.isInt() || !b.isInt()) {\n throw new Error('Parameters in function gcd must be integer numbers');\n } // https://en.wikipedia.org/wiki/Euclidean_algorithm\n\n\n var zero = new BigNumber(0);\n\n while (!b.isZero()) {\n var r = a.mod(b);\n a = b;\n b = r;\n }\n\n return a.lt(zero) ? a.neg() : a;\n }\n});\nexports.createGcd = createGcd;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createHypot = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar name = 'hypot';\nvar dependencies = ['typed', 'abs', 'addScalar', 'divideScalar', 'multiplyScalar', 'sqrt', 'smaller', 'isPositive'];\nvar createHypot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n abs = _ref.abs,\n addScalar = _ref.addScalar,\n divideScalar = _ref.divideScalar,\n multiplyScalar = _ref.multiplyScalar,\n sqrt = _ref.sqrt,\n smaller = _ref.smaller,\n isPositive = _ref.isPositive;\n\n /**\n * Calculate the hypotenusa of a list with values. The hypotenusa is defined as:\n *\n * hypot(a, b, c, ...) = sqrt(a^2 + b^2 + c^2 + ...)\n *\n * For matrix input, the hypotenusa is calculated for all values in the matrix.\n *\n * Syntax:\n *\n * math.hypot(a, b, ...)\n * math.hypot([a, b, c, ...])\n *\n * Examples:\n *\n * math.hypot(3, 4) // 5\n * math.hypot(3, 4, 5) // 7.0710678118654755\n * math.hypot([3, 4, 5]) // 7.0710678118654755\n * math.hypot(-2) // 2\n *\n * See also:\n *\n * abs, norm\n *\n * @param {... number | BigNumber | Array | Matrix} args A list with numeric values or an Array or Matrix.\n * Matrix and Array input is flattened and returns a\n * single number for the whole matrix.\n * @return {number | BigNumber} Returns the hypothenusa of the input values.\n */\n return typed(name, {\n '... number | BigNumber': _hypot,\n Array: function Array(x) {\n return this.apply(this, (0, _array.flatten)(x));\n },\n Matrix: function Matrix(x) {\n return this.apply(this, (0, _array.flatten)(x.toArray()));\n }\n });\n /**\n * Calculate the hypotenusa for an Array with values\n * @param {Array.} args\n * @return {number | BigNumber} Returns the result\n * @private\n */\n\n function _hypot(args) {\n // code based on `hypot` from es6-shim:\n // https://github.com/paulmillr/es6-shim/blob/master/es6-shim.js#L1619-L1633\n var result = 0;\n var largest = 0;\n\n for (var i = 0; i < args.length; i++) {\n var value = abs(args[i]);\n\n if (smaller(largest, value)) {\n result = multiplyScalar(result, multiplyScalar(divideScalar(largest, value), divideScalar(largest, value)));\n result = addScalar(result, 1);\n largest = value;\n } else {\n result = addScalar(result, isPositive(value) ? multiplyScalar(divideScalar(value, largest), divideScalar(value, largest)) : value);\n }\n }\n\n return multiplyScalar(largest, sqrt(result));\n }\n});\nexports.createHypot = createHypot;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createInvmod = void 0;\n\nvar _slicedToArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/slicedToArray\"));\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'invmod';\nvar dependencies = ['typed', 'config', 'BigNumber', 'xgcd', 'equal', 'smaller', 'mod', 'add', 'isInteger'];\nvar createInvmod = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n BigNumber = _ref.BigNumber,\n xgcd = _ref.xgcd,\n equal = _ref.equal,\n smaller = _ref.smaller,\n mod = _ref.mod,\n add = _ref.add,\n isInteger = _ref.isInteger;\n\n /**\n * Calculate the (modular) multiplicative inverse of a modulo b. Solution to the equation `ax ≣ 1 (mod b)`\n * See https://en.wikipedia.org/wiki/Modular_multiplicative_inverse.\n *\n * Syntax:\n *\n * math.invmod(a, b)\n *\n * Examples:\n *\n * math.invmod(8, 12) // returns NaN\n * math.invmod(7, 13) // return 2\n * math.invmod(15151, 15122) // returns 10429\n *\n * See also:\n *\n * gcd, xgcd\n *\n * @param {number | BigNumber} a An integer number\n * @param {number | BigNumber} b An integer number\n * @return {number | BigNumber } Returns an integer number\n * where `invmod(a,b)*a ≣ 1 (mod b)`\n */\n return typed(name, {\n 'number, number': invmod,\n 'BigNumber, BigNumber': invmod\n });\n\n function invmod(a, b) {\n if (!isInteger(a) || !isInteger(b)) throw new Error('Parameters in function invmod must be integer numbers');\n a = mod(a, b);\n if (equal(b, 0)) throw new Error('Divisor must be non zero');\n var res = xgcd(a, b);\n res = res.valueOf();\n\n var _res = res,\n _res2 = (0, _slicedToArray2.default)(_res, 2),\n gcd = _res2[0],\n inv = _res2[1];\n\n if (!equal(gcd, BigNumber(1))) return NaN;\n inv = mod(inv, b);\n if (smaller(inv, BigNumber(0))) inv = add(inv, b);\n return inv;\n }\n});\nexports.createInvmod = createInvmod;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLcm = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm02.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm06.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'lcm';\nvar dependencies = ['typed', 'matrix', 'equalScalar'];\nvar createLcm = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar;\n var algorithm02 = (0, _algorithm.createAlgorithm02)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm06 = (0, _algorithm2.createAlgorithm06)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm11 = (0, _algorithm3.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm13 = (0, _algorithm4.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm5.createAlgorithm14)({\n typed: typed\n });\n /**\n * Calculate the least common multiple for two or more values or arrays.\n *\n * lcm is defined as:\n *\n * lcm(a, b) = abs(a * b) / gcd(a, b)\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.lcm(a, b)\n * math.lcm(a, b, c, ...)\n *\n * Examples:\n *\n * math.lcm(4, 6) // returns 12\n * math.lcm(6, 21) // returns 42\n * math.lcm(6, 21, 5) // returns 210\n *\n * math.lcm([4, 6], [6, 21]) // returns [12, 42]\n *\n * See also:\n *\n * gcd, xgcd\n *\n * @param {... number | BigNumber | Array | Matrix} args Two or more integer numbers\n * @return {number | BigNumber | Array | Matrix} The least common multiple\n */\n\n return typed(name, {\n 'number, number': _index.lcmNumber,\n 'BigNumber, BigNumber': _lcmBigNumber,\n 'Fraction, Fraction': function FractionFraction(x, y) {\n return x.lcm(y);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm06(x, y, this);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm02(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm02(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, number | BigNumber': function SparseMatrixNumberBigNumber(x, y) {\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, number | BigNumber': function DenseMatrixNumberBigNumber(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'number | BigNumber, SparseMatrix': function numberBigNumberSparseMatrix(x, y) {\n return algorithm11(y, x, this, true);\n },\n 'number | BigNumber, DenseMatrix': function numberBigNumberDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, number | BigNumber': function ArrayNumberBigNumber(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'number | BigNumber, Array': function numberBigNumberArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n },\n // TODO: need a smarter notation here\n 'Array | Matrix | number | BigNumber, Array | Matrix | number | BigNumber, ...Array | Matrix | number | BigNumber': function ArrayMatrixNumberBigNumberArrayMatrixNumberBigNumberArrayMatrixNumberBigNumber(a, b, args) {\n var res = this(a, b);\n\n for (var i = 0; i < args.length; i++) {\n res = this(res, args[i]);\n }\n\n return res;\n }\n });\n /**\n * Calculate lcm for two BigNumbers\n * @param {BigNumber} a\n * @param {BigNumber} b\n * @returns {BigNumber} Returns the least common multiple of a and b\n * @private\n */\n\n function _lcmBigNumber(a, b) {\n if (!a.isInt() || !b.isInt()) {\n throw new Error('Parameters in function lcm must be integer numbers');\n }\n\n if (a.isZero()) {\n return a;\n }\n\n if (b.isZero()) {\n return b;\n } // https://en.wikipedia.org/wiki/Euclidean_algorithm\n // evaluate lcm here inline to reduce overhead\n\n\n var prod = a.times(b);\n\n while (!b.isZero()) {\n var t = b;\n b = a.mod(t);\n a = t;\n }\n\n return prod.div(a).abs();\n }\n});\nexports.createLcm = createLcm;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLog = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'log';\nvar dependencies = ['config', 'typed', 'divideScalar', 'Complex'];\nvar createLog = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n divideScalar = _ref.divideScalar,\n Complex = _ref.Complex;\n\n /**\n * Calculate the logarithm of a value.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.log(x)\n * math.log(x, base)\n *\n * Examples:\n *\n * math.log(3.5) // returns 1.252762968495368\n * math.exp(math.log(2.4)) // returns 2.4\n *\n * math.pow(10, 4) // returns 10000\n * math.log(10000, 10) // returns 4\n * math.log(10000) / math.log(10) // returns 4\n *\n * math.log(1024, 2) // returns 10\n * math.pow(2, 10) // returns 1024\n *\n * See also:\n *\n * exp, log2, log10, log1p\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * Value for which to calculate the logarithm.\n * @param {number | BigNumber | Complex} [base=e]\n * Optional base for the logarithm. If not provided, the natural\n * logarithm of `x` is calculated.\n * @return {number | BigNumber | Complex | Array | Matrix}\n * Returns the logarithm of `x`\n */\n return typed(name, {\n number: function number(x) {\n if (x >= 0 || config.predictable) {\n return (0, _index.logNumber)(x);\n } else {\n // negative value -> complex value computation\n return new Complex(x, 0).log();\n }\n },\n Complex: function Complex(x) {\n return x.log();\n },\n BigNumber: function BigNumber(x) {\n if (!x.isNegative() || config.predictable) {\n return x.ln();\n } else {\n // downgrade to number, return Complex valued result\n return new Complex(x.toNumber(), 0).log();\n }\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n },\n 'any, any': function anyAny(x, base) {\n // calculate logarithm for a specified base, log(x, base)\n return divideScalar(this(x), this(base));\n }\n });\n});\nexports.createLog = createLog;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLog10 = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'log10';\nvar dependencies = ['typed', 'config', 'Complex'];\nvar createLog10 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n _Complex = _ref.Complex;\n\n /**\n * Calculate the 10-base logarithm of a value. This is the same as calculating `log(x, 10)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.log10(x)\n *\n * Examples:\n *\n * math.log10(0.00001) // returns -5\n * math.log10(10000) // returns 4\n * math.log(10000) / math.log(10) // returns 4\n * math.pow(10, 4) // returns 10000\n *\n * See also:\n *\n * exp, log, log1p, log2\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * Value for which to calculate the logarithm.\n * @return {number | BigNumber | Complex | Array | Matrix}\n * Returns the 10-base logarithm of `x`\n */\n return typed(name, {\n number: function number(x) {\n if (x >= 0 || config.predictable) {\n return (0, _index.log10Number)(x);\n } else {\n // negative value -> complex value computation\n return new _Complex(x, 0).log().div(Math.LN10);\n }\n },\n Complex: function Complex(x) {\n return new _Complex(x).log().div(Math.LN10);\n },\n BigNumber: function BigNumber(x) {\n if (!x.isNegative() || config.predictable) {\n return x.log();\n } else {\n // downgrade to number, return Complex valued result\n return new _Complex(x.toNumber(), 0).log().div(Math.LN10);\n }\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createLog10 = createLog10;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLog1p = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar name = 'log1p';\nvar dependencies = ['typed', 'config', 'divideScalar', 'log', 'Complex'];\nvar createLog1p = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n divideScalar = _ref.divideScalar,\n log = _ref.log,\n Complex = _ref.Complex;\n\n /**\n * Calculate the logarithm of a `value+1`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.log1p(x)\n * math.log1p(x, base)\n *\n * Examples:\n *\n * math.log1p(2.5) // returns 1.252762968495368\n * math.exp(math.log1p(1.4)) // returns 2.4\n *\n * math.pow(10, 4) // returns 10000\n * math.log1p(9999, 10) // returns 4\n * math.log1p(9999) / math.log(10) // returns 4\n *\n * See also:\n *\n * exp, log, log2, log10\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * Value for which to calculate the logarithm of `x+1`.\n * @param {number | BigNumber | Complex} [base=e]\n * Optional base for the logarithm. If not provided, the natural\n * logarithm of `x+1` is calculated.\n * @return {number | BigNumber | Complex | Array | Matrix}\n * Returns the logarithm of `x+1`\n */\n return typed(name, {\n number: function number(x) {\n if (x >= -1 || config.predictable) {\n return (0, _number.log1p)(x);\n } else {\n // negative value -> complex value computation\n return _log1pComplex(new Complex(x, 0));\n }\n },\n Complex: _log1pComplex,\n BigNumber: function BigNumber(x) {\n var y = x.plus(1);\n\n if (!y.isNegative() || config.predictable) {\n return y.ln();\n } else {\n // downgrade to number, return Complex valued result\n return _log1pComplex(new Complex(x.toNumber(), 0));\n }\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n },\n 'any, any': function anyAny(x, base) {\n // calculate logarithm for a specified base, log1p(x, base)\n return divideScalar(this(x), log(base));\n }\n });\n /**\n * Calculate the natural logarithm of a complex number + 1\n * @param {Complex} x\n * @returns {Complex}\n * @private\n */\n\n function _log1pComplex(x) {\n var xRe1p = x.re + 1;\n return new Complex(Math.log(Math.sqrt(xRe1p * xRe1p + x.im * x.im)), Math.atan2(x.im, xRe1p));\n }\n});\nexports.createLog1p = createLog1p;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLog2 = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'log2';\nvar dependencies = ['typed', 'config', 'Complex'];\nvar createLog2 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n Complex = _ref.Complex;\n\n /**\n * Calculate the 2-base of a value. This is the same as calculating `log(x, 2)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.log2(x)\n *\n * Examples:\n *\n * math.log2(0.03125) // returns -5\n * math.log2(16) // returns 4\n * math.log2(16) / math.log2(2) // returns 4\n * math.pow(2, 4) // returns 16\n *\n * See also:\n *\n * exp, log, log1p, log10\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * Value for which to calculate the logarithm.\n * @return {number | BigNumber | Complex | Array | Matrix}\n * Returns the 2-base logarithm of `x`\n */\n return typed(name, {\n number: function number(x) {\n if (x >= 0 || config.predictable) {\n return (0, _index.log2Number)(x);\n } else {\n // negative value -> complex value computation\n return _log2Complex(new Complex(x, 0));\n }\n },\n Complex: _log2Complex,\n BigNumber: function BigNumber(x) {\n if (!x.isNegative() || config.predictable) {\n return x.log(2);\n } else {\n // downgrade to number, return Complex valued result\n return _log2Complex(new Complex(x.toNumber(), 0));\n }\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n /**\n * Calculate log2 for a complex value\n * @param {Complex} x\n * @returns {Complex}\n * @private\n */\n\n function _log2Complex(x) {\n var newX = Math.sqrt(x.re * x.re + x.im * x.im);\n return new Complex(Math.log2 ? Math.log2(newX) : Math.log(newX) / Math.LN2, Math.atan2(x.im, x.re) / Math.LN2);\n }\n});\nexports.createLog2 = createLog2;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMod = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm02.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm05.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm6 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm7 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'mod';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix'];\nvar createMod = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm02 = (0, _algorithm.createAlgorithm02)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm03 = (0, _algorithm2.createAlgorithm03)({\n typed: typed\n });\n var algorithm05 = (0, _algorithm3.createAlgorithm05)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm11 = (0, _algorithm4.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm12 = (0, _algorithm5.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm6.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm7.createAlgorithm14)({\n typed: typed\n });\n /**\n * Calculates the modulus, the remainder of an integer division.\n *\n * For matrices, the function is evaluated element wise.\n *\n * The modulus is defined as:\n *\n * x - y * floor(x / y)\n *\n * See https://en.wikipedia.org/wiki/Modulo_operation.\n *\n * Syntax:\n *\n * math.mod(x, y)\n *\n * Examples:\n *\n * math.mod(8, 3) // returns 2\n * math.mod(11, 2) // returns 1\n *\n * function isOdd(x) {\n * return math.mod(x, 2) != 0\n * }\n *\n * isOdd(2) // returns false\n * isOdd(3) // returns true\n *\n * See also:\n *\n * divide\n *\n * @param {number | BigNumber | Fraction | Array | Matrix} x Dividend\n * @param {number | BigNumber | Fraction | Array | Matrix} y Divisor\n * @return {number | BigNumber | Fraction | Array | Matrix} Returns the remainder of `x` divided by `y`.\n */\n\n return typed(name, {\n 'number, number': _index.modNumber,\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n if (y.isNeg()) {\n throw new Error('Cannot calculate mod for a negative divisor');\n }\n\n return y.isZero() ? x : x.mod(y);\n },\n 'Fraction, Fraction': function FractionFraction(x, y) {\n if (y.compare(0) < 0) {\n throw new Error('Cannot calculate mod for a negative divisor');\n } // Workaround suggested in Fraction.js library to calculate correct modulo for negative dividend\n\n\n return x.compare(0) >= 0 ? x.mod(y) : x.mod(y).add(y).mod(y);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm05(x, y, this, false);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm02(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createMod = createMod;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMultiply = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'multiply';\nvar dependencies = ['typed', 'matrix', 'addScalar', 'multiplyScalar', 'equalScalar', 'dot'];\nvar createMultiply = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n addScalar = _ref.addScalar,\n multiplyScalar = _ref.multiplyScalar,\n equalScalar = _ref.equalScalar,\n dot = _ref.dot;\n var algorithm11 = (0, _algorithm.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm14 = (0, _algorithm2.createAlgorithm14)({\n typed: typed\n });\n\n function _validateMatrixDimensions(size1, size2) {\n // check left operand dimensions\n switch (size1.length) {\n case 1:\n // check size2\n switch (size2.length) {\n case 1:\n // Vector x Vector\n if (size1[0] !== size2[0]) {\n // throw error\n throw new RangeError('Dimension mismatch in multiplication. Vectors must have the same length');\n }\n\n break;\n\n case 2:\n // Vector x Matrix\n if (size1[0] !== size2[0]) {\n // throw error\n throw new RangeError('Dimension mismatch in multiplication. Vector length (' + size1[0] + ') must match Matrix rows (' + size2[0] + ')');\n }\n\n break;\n\n default:\n throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix B has ' + size2.length + ' dimensions)');\n }\n\n break;\n\n case 2:\n // check size2\n switch (size2.length) {\n case 1:\n // Matrix x Vector\n if (size1[1] !== size2[0]) {\n // throw error\n throw new RangeError('Dimension mismatch in multiplication. Matrix columns (' + size1[1] + ') must match Vector length (' + size2[0] + ')');\n }\n\n break;\n\n case 2:\n // Matrix x Matrix\n if (size1[1] !== size2[0]) {\n // throw error\n throw new RangeError('Dimension mismatch in multiplication. Matrix A columns (' + size1[1] + ') must match Matrix B rows (' + size2[0] + ')');\n }\n\n break;\n\n default:\n throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix B has ' + size2.length + ' dimensions)');\n }\n\n break;\n\n default:\n throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix A has ' + size1.length + ' dimensions)');\n }\n }\n /**\n * C = A * B\n *\n * @param {Matrix} a Dense Vector (N)\n * @param {Matrix} b Dense Vector (N)\n *\n * @return {number} Scalar value\n */\n\n\n function _multiplyVectorVector(a, b, n) {\n // check empty vector\n if (n === 0) {\n throw new Error('Cannot multiply two empty vectors');\n }\n\n return dot(a, b);\n }\n /**\n * C = A * B\n *\n * @param {Matrix} a Dense Vector (M)\n * @param {Matrix} b Matrix (MxN)\n *\n * @return {Matrix} Dense Vector (N)\n */\n\n\n function _multiplyVectorMatrix(a, b) {\n // process storage\n if (b.storage() !== 'dense') {\n throw new Error('Support for SparseMatrix not implemented');\n }\n\n return _multiplyVectorDenseMatrix(a, b);\n }\n /**\n * C = A * B\n *\n * @param {Matrix} a Dense Vector (M)\n * @param {Matrix} b Dense Matrix (MxN)\n *\n * @return {Matrix} Dense Vector (N)\n */\n\n\n function _multiplyVectorDenseMatrix(a, b) {\n // a dense\n var adata = a._data;\n var asize = a._size;\n var adt = a._datatype; // b dense\n\n var bdata = b._data;\n var bsize = b._size;\n var bdt = b._datatype; // rows & columns\n\n var alength = asize[0];\n var bcolumns = bsize[1]; // datatype\n\n var dt; // addScalar signature to use\n\n var af = addScalar; // multiplyScalar signature to use\n\n var mf = multiplyScalar; // process data types\n\n if (adt && bdt && adt === bdt && typeof adt === 'string') {\n // datatype\n dt = adt; // find signatures that matches (dt, dt)\n\n af = typed.find(addScalar, [dt, dt]);\n mf = typed.find(multiplyScalar, [dt, dt]);\n } // result\n\n\n var c = []; // loop matrix columns\n\n for (var j = 0; j < bcolumns; j++) {\n // sum (do not initialize it with zero)\n var sum = mf(adata[0], bdata[0][j]); // loop vector\n\n for (var i = 1; i < alength; i++) {\n // multiply & accumulate\n sum = af(sum, mf(adata[i], bdata[i][j]));\n }\n\n c[j] = sum;\n } // return matrix\n\n\n return a.createDenseMatrix({\n data: c,\n size: [bcolumns],\n datatype: dt\n });\n }\n /**\n * C = A * B\n *\n * @param {Matrix} a Matrix (MxN)\n * @param {Matrix} b Dense Vector (N)\n *\n * @return {Matrix} Dense Vector (M)\n */\n\n\n var _multiplyMatrixVector = typed('_multiplyMatrixVector', {\n 'DenseMatrix, any': _multiplyDenseMatrixVector,\n 'SparseMatrix, any': _multiplySparseMatrixVector\n });\n /**\n * C = A * B\n *\n * @param {Matrix} a Matrix (MxN)\n * @param {Matrix} b Matrix (NxC)\n *\n * @return {Matrix} Matrix (MxC)\n */\n\n\n var _multiplyMatrixMatrix = typed('_multiplyMatrixMatrix', {\n 'DenseMatrix, DenseMatrix': _multiplyDenseMatrixDenseMatrix,\n 'DenseMatrix, SparseMatrix': _multiplyDenseMatrixSparseMatrix,\n 'SparseMatrix, DenseMatrix': _multiplySparseMatrixDenseMatrix,\n 'SparseMatrix, SparseMatrix': _multiplySparseMatrixSparseMatrix\n });\n /**\n * C = A * B\n *\n * @param {Matrix} a DenseMatrix (MxN)\n * @param {Matrix} b Dense Vector (N)\n *\n * @return {Matrix} Dense Vector (M)\n */\n\n\n function _multiplyDenseMatrixVector(a, b) {\n // a dense\n var adata = a._data;\n var asize = a._size;\n var adt = a._datatype; // b dense\n\n var bdata = b._data;\n var bdt = b._datatype; // rows & columns\n\n var arows = asize[0];\n var acolumns = asize[1]; // datatype\n\n var dt; // addScalar signature to use\n\n var af = addScalar; // multiplyScalar signature to use\n\n var mf = multiplyScalar; // process data types\n\n if (adt && bdt && adt === bdt && typeof adt === 'string') {\n // datatype\n dt = adt; // find signatures that matches (dt, dt)\n\n af = typed.find(addScalar, [dt, dt]);\n mf = typed.find(multiplyScalar, [dt, dt]);\n } // result\n\n\n var c = []; // loop matrix a rows\n\n for (var i = 0; i < arows; i++) {\n // current row\n var row = adata[i]; // sum (do not initialize it with zero)\n\n var sum = mf(row[0], bdata[0]); // loop matrix a columns\n\n for (var j = 1; j < acolumns; j++) {\n // multiply & accumulate\n sum = af(sum, mf(row[j], bdata[j]));\n }\n\n c[i] = sum;\n } // return matrix\n\n\n return a.createDenseMatrix({\n data: c,\n size: [arows],\n datatype: dt\n });\n }\n /**\n * C = A * B\n *\n * @param {Matrix} a DenseMatrix (MxN)\n * @param {Matrix} b DenseMatrix (NxC)\n *\n * @return {Matrix} DenseMatrix (MxC)\n */\n\n\n function _multiplyDenseMatrixDenseMatrix(a, b) {\n // a dense\n var adata = a._data;\n var asize = a._size;\n var adt = a._datatype; // b dense\n\n var bdata = b._data;\n var bsize = b._size;\n var bdt = b._datatype; // rows & columns\n\n var arows = asize[0];\n var acolumns = asize[1];\n var bcolumns = bsize[1]; // datatype\n\n var dt; // addScalar signature to use\n\n var af = addScalar; // multiplyScalar signature to use\n\n var mf = multiplyScalar; // process data types\n\n if (adt && bdt && adt === bdt && typeof adt === 'string') {\n // datatype\n dt = adt; // find signatures that matches (dt, dt)\n\n af = typed.find(addScalar, [dt, dt]);\n mf = typed.find(multiplyScalar, [dt, dt]);\n } // result\n\n\n var c = []; // loop matrix a rows\n\n for (var i = 0; i < arows; i++) {\n // current row\n var row = adata[i]; // initialize row array\n\n c[i] = []; // loop matrix b columns\n\n for (var j = 0; j < bcolumns; j++) {\n // sum (avoid initializing sum to zero)\n var sum = mf(row[0], bdata[0][j]); // loop matrix a columns\n\n for (var x = 1; x < acolumns; x++) {\n // multiply & accumulate\n sum = af(sum, mf(row[x], bdata[x][j]));\n }\n\n c[i][j] = sum;\n }\n } // return matrix\n\n\n return a.createDenseMatrix({\n data: c,\n size: [arows, bcolumns],\n datatype: dt\n });\n }\n /**\n * C = A * B\n *\n * @param {Matrix} a DenseMatrix (MxN)\n * @param {Matrix} b SparseMatrix (NxC)\n *\n * @return {Matrix} SparseMatrix (MxC)\n */\n\n\n function _multiplyDenseMatrixSparseMatrix(a, b) {\n // a dense\n var adata = a._data;\n var asize = a._size;\n var adt = a._datatype; // b sparse\n\n var bvalues = b._values;\n var bindex = b._index;\n var bptr = b._ptr;\n var bsize = b._size;\n var bdt = b._datatype; // validate b matrix\n\n if (!bvalues) {\n throw new Error('Cannot multiply Dense Matrix times Pattern only Matrix');\n } // rows & columns\n\n\n var arows = asize[0];\n var bcolumns = bsize[1]; // datatype\n\n var dt; // addScalar signature to use\n\n var af = addScalar; // multiplyScalar signature to use\n\n var mf = multiplyScalar; // equalScalar signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0; // process data types\n\n if (adt && bdt && adt === bdt && typeof adt === 'string') {\n // datatype\n dt = adt; // find signatures that matches (dt, dt)\n\n af = typed.find(addScalar, [dt, dt]);\n mf = typed.find(multiplyScalar, [dt, dt]);\n eq = typed.find(equalScalar, [dt, dt]); // convert 0 to the same datatype\n\n zero = typed.convert(0, dt);\n } // result\n\n\n var cvalues = [];\n var cindex = [];\n var cptr = []; // c matrix\n\n var c = b.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [arows, bcolumns],\n datatype: dt\n }); // loop b columns\n\n for (var jb = 0; jb < bcolumns; jb++) {\n // update ptr\n cptr[jb] = cindex.length; // indeces in column jb\n\n var kb0 = bptr[jb];\n var kb1 = bptr[jb + 1]; // do not process column jb if no data exists\n\n if (kb1 > kb0) {\n // last row mark processed\n var last = 0; // loop a rows\n\n for (var i = 0; i < arows; i++) {\n // column mark\n var mark = i + 1; // C[i, jb]\n\n var cij = void 0; // values in b column j\n\n for (var kb = kb0; kb < kb1; kb++) {\n // row\n var ib = bindex[kb]; // check value has been initialized\n\n if (last !== mark) {\n // first value in column jb\n cij = mf(adata[i][ib], bvalues[kb]); // update mark\n\n last = mark;\n } else {\n // accumulate value\n cij = af(cij, mf(adata[i][ib], bvalues[kb]));\n }\n } // check column has been processed and value != 0\n\n\n if (last === mark && !eq(cij, zero)) {\n // push row & value\n cindex.push(i);\n cvalues.push(cij);\n }\n }\n }\n } // update ptr\n\n\n cptr[bcolumns] = cindex.length; // return sparse matrix\n\n return c;\n }\n /**\n * C = A * B\n *\n * @param {Matrix} a SparseMatrix (MxN)\n * @param {Matrix} b Dense Vector (N)\n *\n * @return {Matrix} SparseMatrix (M, 1)\n */\n\n\n function _multiplySparseMatrixVector(a, b) {\n // a sparse\n var avalues = a._values;\n var aindex = a._index;\n var aptr = a._ptr;\n var adt = a._datatype; // validate a matrix\n\n if (!avalues) {\n throw new Error('Cannot multiply Pattern only Matrix times Dense Matrix');\n } // b dense\n\n\n var bdata = b._data;\n var bdt = b._datatype; // rows & columns\n\n var arows = a._size[0];\n var brows = b._size[0]; // result\n\n var cvalues = [];\n var cindex = [];\n var cptr = []; // datatype\n\n var dt; // addScalar signature to use\n\n var af = addScalar; // multiplyScalar signature to use\n\n var mf = multiplyScalar; // equalScalar signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0; // process data types\n\n if (adt && bdt && adt === bdt && typeof adt === 'string') {\n // datatype\n dt = adt; // find signatures that matches (dt, dt)\n\n af = typed.find(addScalar, [dt, dt]);\n mf = typed.find(multiplyScalar, [dt, dt]);\n eq = typed.find(equalScalar, [dt, dt]); // convert 0 to the same datatype\n\n zero = typed.convert(0, dt);\n } // workspace\n\n\n var x = []; // vector with marks indicating a value x[i] exists in a given column\n\n var w = []; // update ptr\n\n cptr[0] = 0; // rows in b\n\n for (var ib = 0; ib < brows; ib++) {\n // b[ib]\n var vbi = bdata[ib]; // check b[ib] != 0, avoid loops\n\n if (!eq(vbi, zero)) {\n // A values & index in ib column\n for (var ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) {\n // a row\n var ia = aindex[ka]; // check value exists in current j\n\n if (!w[ia]) {\n // ia is new entry in j\n w[ia] = true; // add i to pattern of C\n\n cindex.push(ia); // x(ia) = A\n\n x[ia] = mf(vbi, avalues[ka]);\n } else {\n // i exists in C already\n x[ia] = af(x[ia], mf(vbi, avalues[ka]));\n }\n }\n }\n } // copy values from x to column jb of c\n\n\n for (var p1 = cindex.length, p = 0; p < p1; p++) {\n // row\n var ic = cindex[p]; // copy value\n\n cvalues[p] = x[ic];\n } // update ptr\n\n\n cptr[1] = cindex.length; // return sparse matrix\n\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [arows, 1],\n datatype: dt\n });\n }\n /**\n * C = A * B\n *\n * @param {Matrix} a SparseMatrix (MxN)\n * @param {Matrix} b DenseMatrix (NxC)\n *\n * @return {Matrix} SparseMatrix (MxC)\n */\n\n\n function _multiplySparseMatrixDenseMatrix(a, b) {\n // a sparse\n var avalues = a._values;\n var aindex = a._index;\n var aptr = a._ptr;\n var adt = a._datatype; // validate a matrix\n\n if (!avalues) {\n throw new Error('Cannot multiply Pattern only Matrix times Dense Matrix');\n } // b dense\n\n\n var bdata = b._data;\n var bdt = b._datatype; // rows & columns\n\n var arows = a._size[0];\n var brows = b._size[0];\n var bcolumns = b._size[1]; // datatype\n\n var dt; // addScalar signature to use\n\n var af = addScalar; // multiplyScalar signature to use\n\n var mf = multiplyScalar; // equalScalar signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0; // process data types\n\n if (adt && bdt && adt === bdt && typeof adt === 'string') {\n // datatype\n dt = adt; // find signatures that matches (dt, dt)\n\n af = typed.find(addScalar, [dt, dt]);\n mf = typed.find(multiplyScalar, [dt, dt]);\n eq = typed.find(equalScalar, [dt, dt]); // convert 0 to the same datatype\n\n zero = typed.convert(0, dt);\n } // result\n\n\n var cvalues = [];\n var cindex = [];\n var cptr = []; // c matrix\n\n var c = a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [arows, bcolumns],\n datatype: dt\n }); // workspace\n\n var x = []; // vector with marks indicating a value x[i] exists in a given column\n\n var w = []; // loop b columns\n\n for (var jb = 0; jb < bcolumns; jb++) {\n // update ptr\n cptr[jb] = cindex.length; // mark in workspace for current column\n\n var mark = jb + 1; // rows in jb\n\n for (var ib = 0; ib < brows; ib++) {\n // b[ib, jb]\n var vbij = bdata[ib][jb]; // check b[ib, jb] != 0, avoid loops\n\n if (!eq(vbij, zero)) {\n // A values & index in ib column\n for (var ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) {\n // a row\n var ia = aindex[ka]; // check value exists in current j\n\n if (w[ia] !== mark) {\n // ia is new entry in j\n w[ia] = mark; // add i to pattern of C\n\n cindex.push(ia); // x(ia) = A\n\n x[ia] = mf(vbij, avalues[ka]);\n } else {\n // i exists in C already\n x[ia] = af(x[ia], mf(vbij, avalues[ka]));\n }\n }\n }\n } // copy values from x to column jb of c\n\n\n for (var p0 = cptr[jb], p1 = cindex.length, p = p0; p < p1; p++) {\n // row\n var ic = cindex[p]; // copy value\n\n cvalues[p] = x[ic];\n }\n } // update ptr\n\n\n cptr[bcolumns] = cindex.length; // return sparse matrix\n\n return c;\n }\n /**\n * C = A * B\n *\n * @param {Matrix} a SparseMatrix (MxN)\n * @param {Matrix} b SparseMatrix (NxC)\n *\n * @return {Matrix} SparseMatrix (MxC)\n */\n\n\n function _multiplySparseMatrixSparseMatrix(a, b) {\n // a sparse\n var avalues = a._values;\n var aindex = a._index;\n var aptr = a._ptr;\n var adt = a._datatype; // b sparse\n\n var bvalues = b._values;\n var bindex = b._index;\n var bptr = b._ptr;\n var bdt = b._datatype; // rows & columns\n\n var arows = a._size[0];\n var bcolumns = b._size[1]; // flag indicating both matrices (a & b) contain data\n\n var values = avalues && bvalues; // datatype\n\n var dt; // addScalar signature to use\n\n var af = addScalar; // multiplyScalar signature to use\n\n var mf = multiplyScalar; // process data types\n\n if (adt && bdt && adt === bdt && typeof adt === 'string') {\n // datatype\n dt = adt; // find signatures that matches (dt, dt)\n\n af = typed.find(addScalar, [dt, dt]);\n mf = typed.find(multiplyScalar, [dt, dt]);\n } // result\n\n\n var cvalues = values ? [] : undefined;\n var cindex = [];\n var cptr = []; // c matrix\n\n var c = a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [arows, bcolumns],\n datatype: dt\n }); // workspace\n\n var x = values ? [] : undefined; // vector with marks indicating a value x[i] exists in a given column\n\n var w = []; // variables\n\n var ka, ka0, ka1, kb, kb0, kb1, ia, ib; // loop b columns\n\n for (var jb = 0; jb < bcolumns; jb++) {\n // update ptr\n cptr[jb] = cindex.length; // mark in workspace for current column\n\n var mark = jb + 1; // B values & index in j\n\n for (kb0 = bptr[jb], kb1 = bptr[jb + 1], kb = kb0; kb < kb1; kb++) {\n // b row\n ib = bindex[kb]; // check we need to process values\n\n if (values) {\n // loop values in a[:,ib]\n for (ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) {\n // row\n ia = aindex[ka]; // check value exists in current j\n\n if (w[ia] !== mark) {\n // ia is new entry in j\n w[ia] = mark; // add i to pattern of C\n\n cindex.push(ia); // x(ia) = A\n\n x[ia] = mf(bvalues[kb], avalues[ka]);\n } else {\n // i exists in C already\n x[ia] = af(x[ia], mf(bvalues[kb], avalues[ka]));\n }\n }\n } else {\n // loop values in a[:,ib]\n for (ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) {\n // row\n ia = aindex[ka]; // check value exists in current j\n\n if (w[ia] !== mark) {\n // ia is new entry in j\n w[ia] = mark; // add i to pattern of C\n\n cindex.push(ia);\n }\n }\n }\n } // check we need to process matrix values (pattern matrix)\n\n\n if (values) {\n // copy values from x to column jb of c\n for (var p0 = cptr[jb], p1 = cindex.length, p = p0; p < p1; p++) {\n // row\n var ic = cindex[p]; // copy value\n\n cvalues[p] = x[ic];\n }\n }\n } // update ptr\n\n\n cptr[bcolumns] = cindex.length; // return sparse matrix\n\n return c;\n }\n /**\n * Multiply two or more values, `x * y`.\n * For matrices, the matrix product is calculated.\n *\n * Syntax:\n *\n * math.multiply(x, y)\n * math.multiply(x, y, z, ...)\n *\n * Examples:\n *\n * math.multiply(4, 5.2) // returns number 20.8\n * math.multiply(2, 3, 4) // returns number 24\n *\n * const a = math.complex(2, 3)\n * const b = math.complex(4, 1)\n * math.multiply(a, b) // returns Complex 5 + 14i\n *\n * const c = [[1, 2], [4, 3]]\n * const d = [[1, 2, 3], [3, -4, 7]]\n * math.multiply(c, d) // returns Array [[7, -6, 17], [13, -4, 33]]\n *\n * const e = math.unit('2.1 km')\n * math.multiply(3, e) // returns Unit 6.3 km\n *\n * See also:\n *\n * divide, prod, cross, dot\n *\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x First value to multiply\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Second value to multiply\n * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Multiplication of `x` and `y`\n */\n\n\n return typed(name, (0, _object.extend)({\n // we extend the signatures of multiplyScalar with signatures dealing with matrices\n 'Array, Array': function ArrayArray(x, y) {\n // check dimensions\n _validateMatrixDimensions((0, _array.arraySize)(x), (0, _array.arraySize)(y)); // use dense matrix implementation\n\n\n var m = this(matrix(x), matrix(y)); // return array or scalar\n\n return (0, _is.isMatrix)(m) ? m.valueOf() : m;\n },\n 'Matrix, Matrix': function MatrixMatrix(x, y) {\n // dimensions\n var xsize = x.size();\n var ysize = y.size(); // check dimensions\n\n _validateMatrixDimensions(xsize, ysize); // process dimensions\n\n\n if (xsize.length === 1) {\n // process y dimensions\n if (ysize.length === 1) {\n // Vector * Vector\n return _multiplyVectorVector(x, y, xsize[0]);\n } // Vector * Matrix\n\n\n return _multiplyVectorMatrix(x, y);\n } // process y dimensions\n\n\n if (ysize.length === 1) {\n // Matrix * Vector\n return _multiplyMatrixVector(x, y);\n } // Matrix * Matrix\n\n\n return _multiplyMatrixMatrix(x, y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use Matrix * Matrix implementation\n return this(x, matrix(y));\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use Matrix * Matrix implementation\n return this(matrix(x, y.storage()), y);\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm11(x, y, multiplyScalar, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, multiplyScalar, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm11(y, x, multiplyScalar, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, multiplyScalar, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, multiplyScalar, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, multiplyScalar, true).valueOf();\n },\n 'any, any': multiplyScalar,\n 'any, any, ...any': function anyAnyAny(x, y, rest) {\n var result = this(x, y);\n\n for (var i = 0; i < rest.length; i++) {\n result = this(result, rest[i]);\n }\n\n return result;\n }\n }, multiplyScalar.signatures));\n});\nexports.createMultiply = createMultiply;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMultiplyScalar = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'multiplyScalar';\nvar dependencies = ['typed'];\nvar createMultiplyScalar = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Multiply two scalar values, `x * y`.\n * This function is meant for internal use: it is used by the public function\n * `multiply`\n *\n * This function does not support collections (Array or Matrix).\n *\n * @param {number | BigNumber | Fraction | Complex | Unit} x First value to multiply\n * @param {number | BigNumber | Fraction | Complex} y Second value to multiply\n * @return {number | BigNumber | Fraction | Complex | Unit} Multiplication of `x` and `y`\n * @private\n */\n return typed('multiplyScalar', {\n 'number, number': _index.multiplyNumber,\n 'Complex, Complex': function ComplexComplex(x, y) {\n return x.mul(y);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return x.times(y);\n },\n 'Fraction, Fraction': function FractionFraction(x, y) {\n return x.mul(y);\n },\n 'number | Fraction | BigNumber | Complex, Unit': function numberFractionBigNumberComplexUnit(x, y) {\n var res = y.clone();\n res.value = res.value === null ? res._normalize(x) : this(res.value, x);\n return res;\n },\n 'Unit, number | Fraction | BigNumber | Complex': function UnitNumberFractionBigNumberComplex(x, y) {\n var res = x.clone();\n res.value = res.value === null ? res._normalize(y) : this(res.value, y);\n return res;\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n return x.multiply(y);\n }\n });\n});\nexports.createMultiplyScalar = createMultiplyScalar;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createNorm = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'norm';\nvar dependencies = ['typed', 'abs', 'add', 'pow', 'conj', 'sqrt', 'multiply', 'equalScalar', 'larger', 'smaller', 'matrix', 'ctranspose', 'eigs'];\nvar createNorm = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n abs = _ref.abs,\n add = _ref.add,\n pow = _ref.pow,\n conj = _ref.conj,\n sqrt = _ref.sqrt,\n multiply = _ref.multiply,\n equalScalar = _ref.equalScalar,\n larger = _ref.larger,\n smaller = _ref.smaller,\n matrix = _ref.matrix,\n ctranspose = _ref.ctranspose,\n eigs = _ref.eigs;\n\n /**\n * Calculate the norm of a number, vector or matrix.\n *\n * The second parameter p is optional. If not provided, it defaults to 2.\n *\n * Syntax:\n *\n * math.norm(x)\n * math.norm(x, p)\n *\n * Examples:\n *\n * math.abs(-3.5) // returns 3.5\n * math.norm(-3.5) // returns 3.5\n *\n * math.norm(math.complex(3, -4)) // returns 5\n *\n * math.norm([1, 2, -3], Infinity) // returns 3\n * math.norm([1, 2, -3], -Infinity) // returns 1\n *\n * math.norm([3, 4], 2) // returns 5\n *\n * math.norm([[1, 2], [3, 4]], 1) // returns 6\n * math.norm([[1, 2], [3, 4]], 'inf') // returns 7\n * math.norm([[1, 2], [3, 4]], 'fro') // returns 5.477225575051661\n *\n * See also:\n *\n * abs, hypot\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * Value for which to calculate the norm\n * @param {number | BigNumber | string} [p=2]\n * Vector space.\n * Supported numbers include Infinity and -Infinity.\n * Supported strings are: 'inf', '-inf', and 'fro' (The Frobenius norm)\n * @return {number | BigNumber} the p-norm\n */\n return typed(name, {\n number: Math.abs,\n Complex: function Complex(x) {\n return x.abs();\n },\n BigNumber: function BigNumber(x) {\n // norm(x) = abs(x)\n return x.abs();\n },\n boolean: function boolean(x) {\n // norm(x) = abs(x)\n return Math.abs(x);\n },\n Array: function Array(x) {\n return _norm(matrix(x), 2);\n },\n Matrix: function Matrix(x) {\n return _norm(x, 2);\n },\n 'number | Complex | BigNumber | boolean, number | BigNumber | string': function numberComplexBigNumberBooleanNumberBigNumberString(x) {\n // ignore second parameter, TODO: remove the option of second parameter for these types\n return this(x);\n },\n 'Array, number | BigNumber | string': function ArrayNumberBigNumberString(x, p) {\n return _norm(matrix(x), p);\n },\n 'Matrix, number | BigNumber | string': function MatrixNumberBigNumberString(x, p) {\n return _norm(x, p);\n }\n });\n /**\n * Calculate the plus infinity norm for a vector\n * @param {Matrix} x\n * @returns {number} Returns the norm\n * @private\n */\n\n function _vectorNormPlusInfinity(x) {\n // norm(x, Infinity) = max(abs(x))\n var pinf = 0; // skip zeros since abs(0) === 0\n\n x.forEach(function (value) {\n var v = abs(value);\n\n if (larger(v, pinf)) {\n pinf = v;\n }\n }, true);\n return pinf;\n }\n /**\n * Calculate the minus infinity norm for a vector\n * @param {Matrix} x\n * @returns {number} Returns the norm\n * @private\n */\n\n\n function _vectorNormMinusInfinity(x) {\n // norm(x, -Infinity) = min(abs(x))\n var ninf; // skip zeros since abs(0) === 0\n\n x.forEach(function (value) {\n var v = abs(value);\n\n if (!ninf || smaller(v, ninf)) {\n ninf = v;\n }\n }, true);\n return ninf || 0;\n }\n /**\n * Calculate the norm for a vector\n * @param {Matrix} x\n * @param {number | string} p\n * @returns {number} Returns the norm\n * @private\n */\n\n\n function _vectorNorm(x, p) {\n // check p\n if (p === Number.POSITIVE_INFINITY || p === 'inf') {\n return _vectorNormPlusInfinity(x);\n }\n\n if (p === Number.NEGATIVE_INFINITY || p === '-inf') {\n return _vectorNormMinusInfinity(x);\n }\n\n if (p === 'fro') {\n return _norm(x, 2);\n }\n\n if (typeof p === 'number' && !isNaN(p)) {\n // check p != 0\n if (!equalScalar(p, 0)) {\n // norm(x, p) = sum(abs(xi) ^ p) ^ 1/p\n var n = 0; // skip zeros since abs(0) === 0\n\n x.forEach(function (value) {\n n = add(pow(abs(value), p), n);\n }, true);\n return pow(n, 1 / p);\n }\n\n return Number.POSITIVE_INFINITY;\n } // invalid parameter value\n\n\n throw new Error('Unsupported parameter value');\n }\n /**\n * Calculate the Frobenius norm for a matrix\n * @param {Matrix} x\n * @returns {number} Returns the norm\n * @private\n */\n\n\n function _matrixNormFrobenius(x) {\n // norm(x) = sqrt(sum(diag(x'x)))\n var fro = 0;\n x.forEach(function (value, index) {\n fro = add(fro, multiply(value, conj(value)));\n });\n return abs(sqrt(fro));\n }\n /**\n * Calculate the norm L1 for a matrix\n * @param {Matrix} x\n * @returns {number} Returns the norm\n * @private\n */\n\n\n function _matrixNormOne(x) {\n // norm(x) = the largest column sum\n var c = []; // result\n\n var maxc = 0; // skip zeros since abs(0) == 0\n\n x.forEach(function (value, index) {\n var j = index[1];\n var cj = add(c[j] || 0, abs(value));\n\n if (larger(cj, maxc)) {\n maxc = cj;\n }\n\n c[j] = cj;\n }, true);\n return maxc;\n }\n /**\n * Calculate the norm L2 for a matrix\n * @param {Matrix} x\n * @returns {number} Returns the norm\n * @private\n */\n\n\n function _matrixNormTwo(x) {\n // norm(x) = sqrt( max eigenvalue of A*.A)\n var sizeX = x.size();\n\n if (sizeX[0] !== sizeX[1]) {\n throw new RangeError('Invalid matrix dimensions');\n }\n\n var tx = ctranspose(x);\n var squaredX = multiply(tx, x);\n var eigenVals = eigs(squaredX).values.toArray();\n var rho = eigenVals[eigenVals.length - 1];\n return abs(sqrt(rho));\n }\n /**\n * Calculate the infinity norm for a matrix\n * @param {Matrix} x\n * @returns {number} Returns the norm\n * @private\n */\n\n\n function _matrixNormInfinity(x) {\n // norm(x) = the largest row sum\n var r = []; // result\n\n var maxr = 0; // skip zeros since abs(0) == 0\n\n x.forEach(function (value, index) {\n var i = index[0];\n var ri = add(r[i] || 0, abs(value));\n\n if (larger(ri, maxr)) {\n maxr = ri;\n }\n\n r[i] = ri;\n }, true);\n return maxr;\n }\n /**\n * Calculate the norm for a 2D Matrix (M*N)\n * @param {Matrix} x\n * @param {number | string} p\n * @returns {number} Returns the norm\n * @private\n */\n\n\n function _matrixNorm(x, p) {\n // check p\n if (p === 1) {\n return _matrixNormOne(x);\n }\n\n if (p === Number.POSITIVE_INFINITY || p === 'inf') {\n return _matrixNormInfinity(x);\n }\n\n if (p === 'fro') {\n return _matrixNormFrobenius(x);\n }\n\n if (p === 2) {\n return _matrixNormTwo(x);\n } // invalid parameter value\n\n\n throw new Error('Unsupported parameter value ' + p);\n }\n /**\n * Calculate the norm for an array\n * @param {Matrix} x\n * @param {number | string} p\n * @returns {number} Returns the norm\n * @private\n */\n\n\n function _norm(x, p) {\n // size\n var sizeX = x.size(); // check if it is a vector\n\n if (sizeX.length === 1) {\n return _vectorNorm(x, p);\n } // MxN matrix\n\n\n if (sizeX.length === 2) {\n if (sizeX[0] && sizeX[1]) {\n return _matrixNorm(x, p);\n } else {\n throw new RangeError('Invalid matrix dimensions');\n }\n }\n }\n});\nexports.createNorm = createNorm;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createNthRootNumber = exports.createNthRoot = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm01.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm02.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm06.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm6 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'nthRoot';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'BigNumber'];\nvar createNthRoot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n _BigNumber = _ref.BigNumber;\n var algorithm01 = (0, _algorithm.createAlgorithm01)({\n typed: typed\n });\n var algorithm02 = (0, _algorithm2.createAlgorithm02)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm06 = (0, _algorithm3.createAlgorithm06)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm11 = (0, _algorithm4.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm13 = (0, _algorithm5.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm6.createAlgorithm14)({\n typed: typed\n });\n /**\n * Calculate the nth root of a value.\n * The principal nth root of a positive real number A, is the positive real\n * solution of the equation\n *\n * x^root = A\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.nthRoot(a)\n * math.nthRoot(a, root)\n *\n * Examples:\n *\n * math.nthRoot(9, 2) // returns 3, as 3^2 == 9\n * math.sqrt(9) // returns 3, as 3^2 == 9\n * math.nthRoot(64, 3) // returns 4, as 4^3 == 64\n *\n * See also:\n *\n * sqrt, pow\n *\n * @param {number | BigNumber | Array | Matrix | Complex} a\n * Value for which to calculate the nth root\n * @param {number | BigNumber} [root=2] The root.\n * @return {number | Complex | Array | Matrix} Returns the nth root of `a`\n */\n\n var complexErr = '' + 'Complex number not supported in function nthRoot. ' + 'Use nthRoots instead.';\n return typed(name, {\n number: _index.nthRootNumber,\n 'number, number': _index.nthRootNumber,\n BigNumber: function BigNumber(x) {\n return _bigNthRoot(x, new _BigNumber(2));\n },\n Complex: function Complex(x) {\n throw new Error(complexErr);\n },\n 'Complex, number': function ComplexNumber(x, y) {\n throw new Error(complexErr);\n },\n 'BigNumber, BigNumber': _bigNthRoot,\n 'Array | Matrix': function ArrayMatrix(x) {\n return this(x, 2);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n // density must be one (no zeros in matrix)\n if (y.density() === 1) {\n // sparse + sparse\n return algorithm06(x, y, this);\n } else {\n // throw exception\n throw new Error('Root must be non-zero');\n }\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm02(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n // density must be one (no zeros in matrix)\n if (y.density() === 1) {\n // dense + sparse\n return algorithm01(x, y, this, false);\n } else {\n // throw exception\n throw new Error('Root must be non-zero');\n }\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, number | BigNumber': function SparseMatrixNumberBigNumber(x, y) {\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, number | BigNumber': function DenseMatrixNumberBigNumber(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'number | BigNumber, SparseMatrix': function numberBigNumberSparseMatrix(x, y) {\n // density must be one (no zeros in matrix)\n if (y.density() === 1) {\n // sparse - scalar\n return algorithm11(y, x, this, true);\n } else {\n // throw exception\n throw new Error('Root must be non-zero');\n }\n },\n 'number | BigNumber, DenseMatrix': function numberBigNumberDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, number | BigNumber': function ArrayNumberBigNumber(x, y) {\n // use matrix implementation\n return this(matrix(x), y).valueOf();\n },\n 'number | BigNumber, Array': function numberBigNumberArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y)).valueOf();\n }\n });\n /**\n * Calculate the nth root of a for BigNumbers, solve x^root == a\n * https://rosettacode.org/wiki/Nth_root#JavaScript\n * @param {BigNumber} a\n * @param {BigNumber} root\n * @private\n */\n\n function _bigNthRoot(a, root) {\n var precision = _BigNumber.precision;\n\n var Big = _BigNumber.clone({\n precision: precision + 2\n });\n\n var zero = new _BigNumber(0);\n var one = new Big(1);\n var inv = root.isNegative();\n\n if (inv) {\n root = root.neg();\n }\n\n if (root.isZero()) {\n throw new Error('Root must be non-zero');\n }\n\n if (a.isNegative() && !root.abs().mod(2).equals(1)) {\n throw new Error('Root must be odd when a is negative.');\n } // edge cases zero and infinity\n\n\n if (a.isZero()) {\n return inv ? new Big(Infinity) : 0;\n }\n\n if (!a.isFinite()) {\n return inv ? zero : a;\n }\n\n var x = a.abs().pow(one.div(root)); // If a < 0, we require that root is an odd integer,\n // so (-1) ^ (1/root) = -1\n\n x = a.isNeg() ? x.neg() : x;\n return new _BigNumber((inv ? one.div(x) : x).toPrecision(precision));\n }\n});\nexports.createNthRoot = createNthRoot;\nvar createNthRootNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed'], function (_ref2) {\n var typed = _ref2.typed;\n return typed(name, {\n number: _index.nthRootNumber,\n 'number, number': _index.nthRootNumber\n });\n});\nexports.createNthRootNumber = createNthRootNumber;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createNthRoots = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'nthRoots';\nvar dependencies = ['config', 'typed', 'divideScalar', 'Complex'];\nvar createNthRoots = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n divideScalar = _ref.divideScalar,\n Complex = _ref.Complex;\n\n /**\n * Each function here returns a real multiple of i as a Complex value.\n * @param {number} val\n * @return {Complex} val, i*val, -val or -i*val for index 0, 1, 2, 3\n */\n // This is used to fix float artifacts for zero-valued components.\n var _calculateExactResult = [function realPos(val) {\n return new Complex(val, 0);\n }, function imagPos(val) {\n return new Complex(0, val);\n }, function realNeg(val) {\n return new Complex(-val, 0);\n }, function imagNeg(val) {\n return new Complex(0, -val);\n }];\n /**\n * Calculate the nth root of a Complex Number a using De Movire's Theorem.\n * @param {Complex} a\n * @param {number} root\n * @return {Array} array of n Complex Roots\n */\n\n function _nthComplexRoots(a, root) {\n if (root < 0) throw new Error('Root must be greater than zero');\n if (root === 0) throw new Error('Root must be non-zero');\n if (root % 1 !== 0) throw new Error('Root must be an integer');\n if (a === 0 || a.abs() === 0) return [new Complex(0, 0)];\n var aIsNumeric = typeof a === 'number';\n var offset; // determine the offset (argument of a)/(pi/2)\n\n if (aIsNumeric || a.re === 0 || a.im === 0) {\n if (aIsNumeric) {\n offset = 2 * +(a < 0); // numeric value on the real axis\n } else if (a.im === 0) {\n offset = 2 * +(a.re < 0); // complex value on the real axis\n } else {\n offset = 2 * +(a.im < 0) + 1; // complex value on the imaginary axis\n }\n }\n\n var arg = a.arg();\n var abs = a.abs();\n var roots = [];\n var r = Math.pow(abs, 1 / root);\n\n for (var k = 0; k < root; k++) {\n var halfPiFactor = (offset + 4 * k) / root;\n /**\n * If (offset + 4*k)/root is an integral multiple of pi/2\n * then we can produce a more exact result.\n */\n\n if (halfPiFactor === Math.round(halfPiFactor)) {\n roots.push(_calculateExactResult[halfPiFactor % 4](r));\n continue;\n }\n\n roots.push(new Complex({\n r: r,\n phi: (arg + 2 * Math.PI * k) / root\n }));\n }\n\n return roots;\n }\n /**\n * Calculate the nth roots of a value.\n * An nth root of a positive real number A,\n * is a positive real solution of the equation \"x^root = A\".\n * This function returns an array of complex values.\n *\n * Syntax:\n *\n * math.nthRoots(x)\n * math.nthRoots(x, root)\n *\n * Examples:\n *\n * math.nthRoots(1)\n * // returns [\n * // {re: 1, im: 0},\n * // {re: -1, im: 0}\n * // ]\n * nthRoots(1, 3)\n * // returns [\n * // { re: 1, im: 0 },\n * // { re: -0.4999999999999998, im: 0.8660254037844387 },\n * // { re: -0.5000000000000004, im: -0.8660254037844385 }\n * ]\n *\n * See also:\n *\n * nthRoot, pow, sqrt\n *\n * @param {number | BigNumber | Fraction | Complex} x Number to be rounded\n * @return {number | BigNumber | Fraction | Complex} Rounded value\n */\n\n\n return typed(name, {\n Complex: function Complex(x) {\n return _nthComplexRoots(x, 2);\n },\n 'Complex, number': _nthComplexRoots\n });\n});\nexports.createNthRoots = createNthRoots;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createPow = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'pow';\nvar dependencies = ['typed', 'config', 'identity', 'multiply', 'matrix', 'inv', 'fraction', 'number', 'Complex'];\nvar createPow = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n identity = _ref.identity,\n multiply = _ref.multiply,\n matrix = _ref.matrix,\n inv = _ref.inv,\n number = _ref.number,\n fraction = _ref.fraction,\n Complex = _ref.Complex;\n\n /**\n * Calculates the power of x to y, `x ^ y`.\n *\n * Matrix exponentiation is supported for square matrices `x` and integers `y`:\n * when `y` is nonnegative, `x` may be any square matrix; and when `y` is\n * negative, `x` must be invertible, and then this function returns\n * inv(x)^(-y).\n *\n * For cubic roots of negative numbers, the function returns the principal\n * root by default. In order to let the function return the real root,\n * math.js can be configured with `math.config({predictable: true})`.\n * To retrieve all cubic roots of a value, use `math.cbrt(x, true)`.\n *\n * Syntax:\n *\n * math.pow(x, y)\n *\n * Examples:\n *\n * math.pow(2, 3) // returns number 8\n *\n * const a = math.complex(2, 3)\n * math.pow(a, 2) // returns Complex -5 + 12i\n *\n * const b = [[1, 2], [4, 3]]\n * math.pow(b, 2) // returns Array [[9, 8], [16, 17]]\n *\n * const c = [[1, 2], [4, 3]]\n * math.pow(c, -1) // returns Array [[-0.6, 0.4], [0.8, -0.2]]\n *\n * See also:\n *\n * multiply, sqrt, cbrt, nthRoot\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x The base\n * @param {number | BigNumber | Complex} y The exponent\n * @return {number | BigNumber | Complex | Array | Matrix} The value of `x` to the power `y`\n */\n return typed(name, {\n 'number, number': _pow,\n 'Complex, Complex': function ComplexComplex(x, y) {\n return x.pow(y);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n if (y.isInteger() || x >= 0 || config.predictable) {\n return x.pow(y);\n } else {\n return new Complex(x.toNumber(), 0).pow(y.toNumber(), 0);\n }\n },\n 'Fraction, Fraction': function FractionFraction(x, y) {\n var result = x.pow(y);\n\n if (result != null) {\n return result;\n }\n\n if (config.predictable) {\n throw new Error('Result of pow is non-rational and cannot be expressed as a fraction');\n } else {\n return _pow(x.valueOf(), y.valueOf());\n }\n },\n 'Array, number': _powArray,\n 'Array, BigNumber': function ArrayBigNumber(x, y) {\n return _powArray(x, y.toNumber());\n },\n 'Matrix, number': _powMatrix,\n 'Matrix, BigNumber': function MatrixBigNumber(x, y) {\n return _powMatrix(x, y.toNumber());\n },\n 'Unit, number | BigNumber': function UnitNumberBigNumber(x, y) {\n return x.pow(y);\n }\n });\n /**\n * Calculates the power of x to y, x^y, for two numbers.\n * @param {number} x\n * @param {number} y\n * @return {number | Complex} res\n * @private\n */\n\n function _pow(x, y) {\n // Alternatively could define a 'realmode' config option or something, but\n // 'predictable' will work for now\n if (config.predictable && !(0, _number.isInteger)(y) && x < 0) {\n // Check to see if y can be represented as a fraction\n try {\n var yFrac = fraction(y);\n var yNum = number(yFrac);\n\n if (y === yNum || Math.abs((y - yNum) / y) < 1e-14) {\n if (yFrac.d % 2 === 1) {\n return (yFrac.n % 2 === 0 ? 1 : -1) * Math.pow(-x, y);\n }\n }\n } catch (ex) {// fraction() throws an error if y is Infinity, etc.\n } // Unable to express y as a fraction, so continue on\n\n } // **for predictable mode** x^Infinity === NaN if x < -1\n // N.B. this behavour is different from `Math.pow` which gives\n // (-2)^Infinity === Infinity\n\n\n if (config.predictable && (x < -1 && y === Infinity || x > -1 && x < 0 && y === -Infinity)) {\n return NaN;\n }\n\n if ((0, _number.isInteger)(y) || x >= 0 || config.predictable) {\n return (0, _index.powNumber)(x, y);\n } else {\n // TODO: the following infinity checks are duplicated from powNumber. Deduplicate this somehow\n // x^Infinity === 0 if -1 < x < 1\n // A real number 0 is returned instead of complex(0)\n if (x * x < 1 && y === Infinity || x * x > 1 && y === -Infinity) {\n return 0;\n }\n\n return new Complex(x, 0).pow(y, 0);\n }\n }\n /**\n * Calculate the power of a 2d array\n * @param {Array} x must be a 2 dimensional, square matrix\n * @param {number} y a integer value (positive if `x` is not invertible)\n * @returns {Array}\n * @private\n */\n\n\n function _powArray(x, y) {\n if (!(0, _number.isInteger)(y)) {\n throw new TypeError('For A^b, b must be an integer (value is ' + y + ')');\n } // verify that A is a 2 dimensional square matrix\n\n\n var s = (0, _array.arraySize)(x);\n\n if (s.length !== 2) {\n throw new Error('For A^b, A must be 2 dimensional (A has ' + s.length + ' dimensions)');\n }\n\n if (s[0] !== s[1]) {\n throw new Error('For A^b, A must be square (size is ' + s[0] + 'x' + s[1] + ')');\n }\n\n if (y < 0) {\n try {\n return _powArray(inv(x), -y);\n } catch (error) {\n if (error.message === 'Cannot calculate inverse, determinant is zero') {\n throw new TypeError('For A^b, when A is not invertible, b must be a positive integer (value is ' + y + ')');\n }\n\n throw error;\n }\n }\n\n var res = identity(s[0]).valueOf();\n var px = x;\n\n while (y >= 1) {\n if ((y & 1) === 1) {\n res = multiply(px, res);\n }\n\n y >>= 1;\n px = multiply(px, px);\n }\n\n return res;\n }\n /**\n * Calculate the power of a 2d matrix\n * @param {Matrix} x must be a 2 dimensional, square matrix\n * @param {number} y a positive, integer value\n * @returns {Matrix}\n * @private\n */\n\n\n function _powMatrix(x, y) {\n return matrix(_powArray(x.valueOf(), y));\n }\n});\nexports.createPow = createPow;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRound = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar NO_INT = 'Number of decimals in function round must be an integer';\nvar name = 'round';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'BigNumber', 'DenseMatrix'];\nvar createRound = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n zeros = _ref.zeros,\n BigNumber = _ref.BigNumber,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm11 = (0, _algorithm.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm12 = (0, _algorithm2.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm14 = (0, _algorithm3.createAlgorithm14)({\n typed: typed\n });\n /**\n * Round a value towards the nearest integer.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.round(x)\n * math.round(x, n)\n *\n * Examples:\n *\n * math.round(3.22) // returns number 3\n * math.round(3.82) // returns number 4\n * math.round(-4.2) // returns number -4\n * math.round(-4.7) // returns number -5\n * math.round(3.22, 1) // returns number 3.2\n * math.round(3.88, 1) // returns number 3.9\n * math.round(-4.21, 1) // returns number -4.2\n * math.round(-4.71, 1) // returns number -4.7\n * math.round(math.pi, 3) // returns number 3.142\n * math.round(123.45678, 2) // returns number 123.46\n *\n * const c = math.complex(3.2, -2.7)\n * math.round(c) // returns Complex 3 - 3i\n *\n * math.round([3.2, 3.8, -4.7]) // returns Array [3, 4, -5]\n *\n * See also:\n *\n * ceil, fix, floor\n *\n * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded\n * @param {number | BigNumber | Array} [n=0] Number of decimals\n * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value\n */\n\n return typed(name, {\n number: _index.roundNumber,\n 'number, number': _index.roundNumber,\n 'number, BigNumber': function numberBigNumber(x, n) {\n if (!n.isInteger()) {\n throw new TypeError(NO_INT);\n }\n\n return new BigNumber(x).toDecimalPlaces(n.toNumber());\n },\n Complex: function Complex(x) {\n return x.round();\n },\n 'Complex, number': function ComplexNumber(x, n) {\n if (n % 1) {\n throw new TypeError(NO_INT);\n }\n\n return x.round(n);\n },\n 'Complex, BigNumber': function ComplexBigNumber(x, n) {\n if (!n.isInteger()) {\n throw new TypeError(NO_INT);\n }\n\n var _n = n.toNumber();\n\n return x.round(_n);\n },\n BigNumber: function BigNumber(x) {\n return x.toDecimalPlaces(0);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, n) {\n if (!n.isInteger()) {\n throw new TypeError(NO_INT);\n }\n\n return x.toDecimalPlaces(n.toNumber());\n },\n Fraction: function Fraction(x) {\n return x.round();\n },\n 'Fraction, number': function FractionNumber(x, n) {\n if (n % 1) {\n throw new TypeError(NO_INT);\n }\n\n return x.round(n);\n },\n 'Fraction, BigNumber': function FractionBigNumber(x, n) {\n if (!n.isInteger()) {\n throw new TypeError(NO_INT);\n }\n\n return x.round(n.toNumber());\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since round(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n },\n 'SparseMatrix, number | BigNumber': function SparseMatrixNumberBigNumber(x, y) {\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, number | BigNumber': function DenseMatrixNumberBigNumber(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'Array, number | BigNumber': function ArrayNumberBigNumber(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'number | Complex | BigNumber | Fraction, SparseMatrix': function numberComplexBigNumberFractionSparseMatrix(x, y) {\n // check scalar is zero\n if (equalScalar(x, 0)) {\n // do not execute algorithm, result will be a zero matrix\n return zeros(y.size(), y.storage());\n }\n\n return algorithm12(y, x, this, true);\n },\n 'number | Complex | BigNumber | Fraction, DenseMatrix': function numberComplexBigNumberFractionDenseMatrix(x, y) {\n // check scalar is zero\n if (equalScalar(x, 0)) {\n // do not execute algorithm, result will be a zero matrix\n return zeros(y.size(), y.storage());\n }\n\n return algorithm14(y, x, this, true);\n },\n 'number | Complex | BigNumber | Fraction, Array': function numberComplexBigNumberFractionArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createRound = createRound;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSign = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'sign';\nvar dependencies = ['typed', 'BigNumber', 'Fraction', 'complex'];\nvar createSign = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n _BigNumber = _ref.BigNumber,\n complex = _ref.complex,\n _Fraction = _ref.Fraction;\n\n /**\n * Compute the sign of a value. The sign of a value x is:\n *\n * - 1 when x > 0\n * - -1 when x < 0\n * - 0 when x == 0\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.sign(x)\n *\n * Examples:\n *\n * math.sign(3.5) // returns 1\n * math.sign(-4.2) // returns -1\n * math.sign(0) // returns 0\n *\n * math.sign([3, 5, -2, 0, 2]) // returns [1, 1, -1, 0, 1]\n *\n * See also:\n *\n * abs\n *\n * @param {number | BigNumber | Fraction | Complex | Array | Matrix | Unit} x\n * The number for which to determine the sign\n * @return {number | BigNumber | Fraction | Complex | Array | Matrix | Unit}e\n * The sign of `x`\n */\n return typed(name, {\n number: _index.signNumber,\n Complex: function Complex(x) {\n return x.im === 0 ? complex((0, _index.signNumber)(x.re)) : x.sign();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(x.cmp(0));\n },\n Fraction: function Fraction(x) {\n return new _Fraction(x.s, 1);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since sign(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n },\n Unit: function Unit(x) {\n if (!x._isDerived() && x.units[0].unit.offset !== 0) {\n throw new TypeError('sign is ambiguous for units with offset');\n }\n\n return this(x.value);\n }\n });\n});\nexports.createSign = createSign;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSqrt = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar name = 'sqrt';\nvar dependencies = ['config', 'typed', 'Complex'];\nvar createSqrt = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var config = _ref.config,\n typed = _ref.typed,\n Complex = _ref.Complex;\n\n /**\n * Calculate the square root of a value.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.sqrt(x)\n *\n * Examples:\n *\n * math.sqrt(25) // returns 5\n * math.square(5) // returns 25\n * math.sqrt(-4) // returns Complex 2i\n *\n * See also:\n *\n * square, multiply, cube, cbrt, sqrtm\n *\n * @param {number | BigNumber | Complex | Array | Matrix | Unit} x\n * Value for which to calculate the square root.\n * @return {number | BigNumber | Complex | Array | Matrix | Unit}\n * Returns the square root of `x`\n */\n return typed('sqrt', {\n number: _sqrtNumber,\n Complex: function Complex(x) {\n return x.sqrt();\n },\n BigNumber: function BigNumber(x) {\n if (!x.isNegative() || config.predictable) {\n return x.sqrt();\n } else {\n // negative value -> downgrade to number to do complex value computation\n return _sqrtNumber(x.toNumber());\n }\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since sqrt(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n },\n Unit: function Unit(x) {\n // Someday will work for complex units when they are implemented\n return x.pow(0.5);\n }\n });\n /**\n * Calculate sqrt for a number\n * @param {number} x\n * @returns {number | Complex} Returns the square root of x\n * @private\n */\n\n function _sqrtNumber(x) {\n if (isNaN(x)) {\n return NaN;\n } else if (x >= 0 || config.predictable) {\n return Math.sqrt(x);\n } else {\n return new Complex(x, 0).sqrt();\n }\n }\n});\nexports.createSqrt = createSqrt;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSquare = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'square';\nvar dependencies = ['typed'];\nvar createSquare = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Compute the square of a value, `x * x`.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.square(x)\n *\n * Examples:\n *\n * math.square(2) // returns number 4\n * math.square(3) // returns number 9\n * math.pow(3, 2) // returns number 9\n * math.multiply(3, 3) // returns number 9\n *\n * math.square([1, 2, 3, 4]) // returns Array [1, 4, 9, 16]\n *\n * See also:\n *\n * multiply, cube, sqrt, pow\n *\n * @param {number | BigNumber | Fraction | Complex | Array | Matrix | Unit} x\n * Number for which to calculate the square\n * @return {number | BigNumber | Fraction | Complex | Array | Matrix | Unit}\n * Squared value\n */\n return typed(name, {\n number: _index.squareNumber,\n Complex: function Complex(x) {\n return x.mul(x);\n },\n BigNumber: function BigNumber(x) {\n return x.times(x);\n },\n Fraction: function Fraction(x) {\n return x.mul(x);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since square(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n },\n Unit: function Unit(x) {\n return x.pow(2);\n }\n });\n});\nexports.createSquare = createSquare;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSubtract = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _DimensionError = require(\"../../error/DimensionError.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm01.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm05.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm10.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm6 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'subtract';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'addScalar', 'unaryMinus', 'DenseMatrix'];\nvar createSubtract = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n addScalar = _ref.addScalar,\n unaryMinus = _ref.unaryMinus,\n DenseMatrix = _ref.DenseMatrix;\n // TODO: split function subtract in two: subtract and subtractScalar\n var algorithm01 = (0, _algorithm.createAlgorithm01)({\n typed: typed\n });\n var algorithm03 = (0, _algorithm2.createAlgorithm03)({\n typed: typed\n });\n var algorithm05 = (0, _algorithm3.createAlgorithm05)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm10 = (0, _algorithm4.createAlgorithm10)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm5.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm6.createAlgorithm14)({\n typed: typed\n });\n /**\n * Subtract two values, `x - y`.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.subtract(x, y)\n *\n * Examples:\n *\n * math.subtract(5.3, 2) // returns number 3.3\n *\n * const a = math.complex(2, 3)\n * const b = math.complex(4, 1)\n * math.subtract(a, b) // returns Complex -2 + 2i\n *\n * math.subtract([5, 7, 4], 4) // returns Array [1, 3, 0]\n *\n * const c = math.unit('2.1 km')\n * const d = math.unit('500m')\n * math.subtract(c, d) // returns Unit 1.6 km\n *\n * See also:\n *\n * add\n *\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x\n * Initial value\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y\n * Value to subtract from `x`\n * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix}\n * Subtraction of `x` and `y`\n */\n\n return typed(name, {\n 'number, number': function numberNumber(x, y) {\n return x - y;\n },\n 'Complex, Complex': function ComplexComplex(x, y) {\n return x.sub(y);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return x.minus(y);\n },\n 'Fraction, Fraction': function FractionFraction(x, y) {\n return x.sub(y);\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n if (x.value === null) {\n throw new Error('Parameter x contains a unit with undefined value');\n }\n\n if (y.value === null) {\n throw new Error('Parameter y contains a unit with undefined value');\n }\n\n if (!x.equalBase(y)) {\n throw new Error('Units do not match');\n }\n\n var res = x.clone();\n res.value = this(res.value, y.value);\n res.fixPrefix = false;\n return res;\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n checkEqualDimensions(x, y);\n return algorithm05(x, y, this);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n checkEqualDimensions(x, y);\n return algorithm03(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n checkEqualDimensions(x, y);\n return algorithm01(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n checkEqualDimensions(x, y);\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm10(x, unaryMinus(y), addScalar);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm10(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\n/**\n * Check whether matrix x and y have the same number of dimensions.\n * Throws a DimensionError when dimensions are not equal\n * @param {Matrix} x\n * @param {Matrix} y\n */\n\nexports.createSubtract = createSubtract;\n\nfunction checkEqualDimensions(x, y) {\n var xsize = x.size();\n var ysize = y.size();\n\n if (xsize.length !== ysize.length) {\n throw new _DimensionError.DimensionError(xsize.length, ysize.length);\n }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createUnaryMinus = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'unaryMinus';\nvar dependencies = ['typed'];\nvar createUnaryMinus = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Inverse the sign of a value, apply a unary minus operation.\n *\n * For matrices, the function is evaluated element wise. Boolean values and\n * strings will be converted to a number. For complex numbers, both real and\n * complex value are inverted.\n *\n * Syntax:\n *\n * math.unaryMinus(x)\n *\n * Examples:\n *\n * math.unaryMinus(3.5) // returns -3.5\n * math.unaryMinus(-4.2) // returns 4.2\n *\n * See also:\n *\n * add, subtract, unaryPlus\n *\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Number to be inverted.\n * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Returns the value with inverted sign.\n */\n return typed(name, {\n number: _index.unaryMinusNumber,\n Complex: function Complex(x) {\n return x.neg();\n },\n BigNumber: function BigNumber(x) {\n return x.neg();\n },\n Fraction: function Fraction(x) {\n return x.neg();\n },\n Unit: function Unit(x) {\n var res = x.clone();\n res.value = this(x.value);\n return res;\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since unaryMinus(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n } // TODO: add support for string\n\n });\n});\nexports.createUnaryMinus = createUnaryMinus;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createUnaryPlus = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'unaryPlus';\nvar dependencies = ['typed', 'config', 'BigNumber'];\nvar createUnaryPlus = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n BigNumber = _ref.BigNumber;\n\n /**\n * Unary plus operation.\n * Boolean values and strings will be converted to a number, numeric values will be returned as is.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.unaryPlus(x)\n *\n * Examples:\n *\n * math.unaryPlus(3.5) // returns 3.5\n * math.unaryPlus(1) // returns 1\n *\n * See also:\n *\n * unaryMinus, add, subtract\n *\n * @param {number | BigNumber | Fraction | string | Complex | Unit | Array | Matrix} x\n * Input value\n * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix}\n * Returns the input value when numeric, converts to a number when input is non-numeric.\n */\n return typed(name, {\n number: _index.unaryPlusNumber,\n Complex: function Complex(x) {\n return x; // complex numbers are immutable\n },\n BigNumber: function BigNumber(x) {\n return x; // bignumbers are immutable\n },\n Fraction: function Fraction(x) {\n return x; // fractions are immutable\n },\n Unit: function Unit(x) {\n return x.clone();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since unaryPlus(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n },\n 'boolean | string': function booleanString(x) {\n // convert to a number or bignumber\n return config.number === 'BigNumber' ? new BigNumber(+x) : +x;\n }\n });\n});\nexports.createUnaryPlus = createUnaryPlus;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createXgcd = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'xgcd';\nvar dependencies = ['typed', 'config', 'matrix', 'BigNumber'];\nvar createXgcd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n matrix = _ref.matrix,\n BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the extended greatest common divisor for two values.\n * See https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm.\n *\n * Syntax:\n *\n * math.xgcd(a, b)\n *\n * Examples:\n *\n * math.xgcd(8, 12) // returns [4, -1, 1]\n * math.gcd(8, 12) // returns 4\n * math.xgcd(36163, 21199) // returns [1247, -7, 12]\n *\n * See also:\n *\n * gcd, lcm\n *\n * @param {number | BigNumber} a An integer number\n * @param {number | BigNumber} b An integer number\n * @return {Array} Returns an array containing 3 integers `[div, m, n]`\n * where `div = gcd(a, b)` and `a*m + b*n = div`\n */\n return typed(name, {\n 'number, number': function numberNumber(a, b) {\n var res = (0, _index.xgcdNumber)(a, b);\n return config.matrix === 'Array' ? res : matrix(res);\n },\n 'BigNumber, BigNumber': _xgcdBigNumber // TODO: implement support for Fraction\n\n });\n /**\n * Calculate xgcd for two BigNumbers\n * @param {BigNumber} a\n * @param {BigNumber} b\n * @return {BigNumber[]} result\n * @private\n */\n\n function _xgcdBigNumber(a, b) {\n // source: https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm\n var // used to swap two variables\n t;\n var // quotient\n q;\n var // remainder\n r;\n var zero = new BigNumber(0);\n var one = new BigNumber(1);\n var x = zero;\n var lastx = one;\n var y = one;\n var lasty = zero;\n\n if (!a.isInt() || !b.isInt()) {\n throw new Error('Parameters in function xgcd must be integer numbers');\n }\n\n while (!b.isZero()) {\n q = a.div(b).floor();\n r = a.mod(b);\n t = x;\n x = lastx.minus(q.times(x));\n lastx = t;\n t = y;\n y = lasty.minus(q.times(y));\n lasty = t;\n a = b;\n b = r;\n }\n\n var res;\n\n if (a.lt(zero)) {\n res = [a.neg(), lastx.neg(), lasty.neg()];\n } else {\n res = [a, !a.isZero() ? lastx : 0, lasty];\n }\n\n return config.matrix === 'Array' ? res : matrix(res);\n }\n});\nexports.createXgcd = createXgcd;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createBitAnd = void 0;\n\nvar _bitwise = require(\"../../utils/bignumber/bitwise.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm02.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm06.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'bitAnd';\nvar dependencies = ['typed', 'matrix', 'equalScalar'];\nvar createBitAnd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar;\n var algorithm02 = (0, _algorithm.createAlgorithm02)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm06 = (0, _algorithm5.createAlgorithm06)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm11 = (0, _algorithm2.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm13 = (0, _algorithm3.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm4.createAlgorithm14)({\n typed: typed\n });\n /**\n * Bitwise AND two values, `x & y`.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.bitAnd(x, y)\n *\n * Examples:\n *\n * math.bitAnd(53, 131) // returns number 1\n *\n * math.bitAnd([1, 12, 31], 42) // returns Array [0, 8, 10]\n *\n * See also:\n *\n * bitNot, bitOr, bitXor, leftShift, rightArithShift, rightLogShift\n *\n * @param {number | BigNumber | Array | Matrix} x First value to and\n * @param {number | BigNumber | Array | Matrix} y Second value to and\n * @return {number | BigNumber | Array | Matrix} AND of `x` and `y`\n */\n\n return typed(name, {\n 'number, number': _index.bitAndNumber,\n 'BigNumber, BigNumber': _bitwise.bitAndBigNumber,\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm06(x, y, this, false);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm02(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm02(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm11(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createBitAnd = createBitAnd;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createBitNot = void 0;\n\nvar _bitwise = require(\"../../utils/bignumber/bitwise.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'bitNot';\nvar dependencies = ['typed'];\nvar createBitNot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Bitwise NOT value, `~x`.\n * For matrices, the function is evaluated element wise.\n * For units, the function is evaluated on the best prefix base.\n *\n * Syntax:\n *\n * math.bitNot(x)\n *\n * Examples:\n *\n * math.bitNot(1) // returns number -2\n *\n * math.bitNot([2, -3, 4]) // returns Array [-3, 2, 5]\n *\n * See also:\n *\n * bitAnd, bitOr, bitXor, leftShift, rightArithShift, rightLogShift\n *\n * @param {number | BigNumber | Array | Matrix} x Value to not\n * @return {number | BigNumber | Array | Matrix} NOT of `x`\n */\n return typed(name, {\n number: _index.bitNotNumber,\n BigNumber: _bitwise.bitNotBigNumber,\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createBitNot = createBitNot;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createBitOr = void 0;\n\nvar _bitwise = require(\"../../utils/bignumber/bitwise.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm10.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm04.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm01.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'bitOr';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix'];\nvar createBitOr = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm01 = (0, _algorithm5.createAlgorithm01)({\n typed: typed\n });\n var algorithm04 = (0, _algorithm4.createAlgorithm04)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm10 = (0, _algorithm3.createAlgorithm10)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm2.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm.createAlgorithm14)({\n typed: typed\n });\n /**\n * Bitwise OR two values, `x | y`.\n * For matrices, the function is evaluated element wise.\n * For units, the function is evaluated on the lowest print base.\n *\n * Syntax:\n *\n * math.bitOr(x, y)\n *\n * Examples:\n *\n * math.bitOr(1, 2) // returns number 3\n *\n * math.bitOr([1, 2, 3], 4) // returns Array [5, 6, 7]\n *\n * See also:\n *\n * bitAnd, bitNot, bitXor, leftShift, rightArithShift, rightLogShift\n *\n * @param {number | BigNumber | Array | Matrix} x First value to or\n * @param {number | BigNumber | Array | Matrix} y Second value to or\n * @return {number | BigNumber | Array | Matrix} OR of `x` and `y`\n */\n\n return typed(name, {\n 'number, number': _index.bitOrNumber,\n 'BigNumber, BigNumber': _bitwise.bitOrBigNumber,\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm04(x, y, this);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm01(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm01(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm10(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm10(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createBitOr = createBitOr;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createBitXor = void 0;\n\nvar _bitwise = require(\"../../utils/bignumber/bitwise.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm07.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'bitXor';\nvar dependencies = ['typed', 'matrix', 'DenseMatrix'];\nvar createBitXor = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm03 = (0, _algorithm.createAlgorithm03)({\n typed: typed\n });\n var algorithm07 = (0, _algorithm2.createAlgorithm07)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm12 = (0, _algorithm3.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm4.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm5.createAlgorithm14)({\n typed: typed\n });\n /**\n * Bitwise XOR two values, `x ^ y`.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.bitXor(x, y)\n *\n * Examples:\n *\n * math.bitXor(1, 2) // returns number 3\n *\n * math.bitXor([2, 3, 4], 4) // returns Array [6, 7, 0]\n *\n * See also:\n *\n * bitAnd, bitNot, bitOr, leftShift, rightArithShift, rightLogShift\n *\n * @param {number | BigNumber | Array | Matrix} x First value to xor\n * @param {number | BigNumber | Array | Matrix} y Second value to xor\n * @return {number | BigNumber | Array | Matrix} XOR of `x` and `y`\n */\n\n return typed(name, {\n 'number, number': _index.bitXorNumber,\n 'BigNumber, BigNumber': _bitwise.bitXor,\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm07(x, y, this);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm03(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm12(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createBitXor = createBitXor;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLeftShift = void 0;\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm02.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm01.js\");\n\nvar _algorithm6 = require(\"../../type/matrix/utils/algorithm10.js\");\n\nvar _algorithm7 = require(\"../../type/matrix/utils/algorithm08.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar _bitwise = require(\"../../utils/bignumber/bitwise.js\");\n\nvar name = 'leftShift';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix'];\nvar createLeftShift = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n zeros = _ref.zeros,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm01 = (0, _algorithm5.createAlgorithm01)({\n typed: typed\n });\n var algorithm02 = (0, _algorithm.createAlgorithm02)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm08 = (0, _algorithm7.createAlgorithm08)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm10 = (0, _algorithm6.createAlgorithm10)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm11 = (0, _algorithm2.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm13 = (0, _algorithm3.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm4.createAlgorithm14)({\n typed: typed\n });\n /**\n * Bitwise left logical shift of a value x by y number of bits, `x << y`.\n * For matrices, the function is evaluated element wise.\n * For units, the function is evaluated on the best prefix base.\n *\n * Syntax:\n *\n * math.leftShift(x, y)\n *\n * Examples:\n *\n * math.leftShift(1, 2) // returns number 4\n *\n * math.leftShift([1, 2, 3], 4) // returns Array [16, 32, 64]\n *\n * See also:\n *\n * leftShift, bitNot, bitOr, bitXor, rightArithShift, rightLogShift\n *\n * @param {number | BigNumber | Array | Matrix} x Value to be shifted\n * @param {number | BigNumber} y Amount of shifts\n * @return {number | BigNumber | Array | Matrix} `x` shifted left `y` times\n */\n\n return typed(name, {\n 'number, number': _index.leftShiftNumber,\n 'BigNumber, BigNumber': _bitwise.leftShiftBigNumber,\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm08(x, y, this, false);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm02(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm01(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, number | BigNumber': function SparseMatrixNumberBigNumber(x, y) {\n // check scalar\n if (equalScalar(y, 0)) {\n return x.clone();\n }\n\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, number | BigNumber': function DenseMatrixNumberBigNumber(x, y) {\n // check scalar\n if (equalScalar(y, 0)) {\n return x.clone();\n }\n\n return algorithm14(x, y, this, false);\n },\n 'number | BigNumber, SparseMatrix': function numberBigNumberSparseMatrix(x, y) {\n // check scalar\n if (equalScalar(x, 0)) {\n return zeros(y.size(), y.storage());\n }\n\n return algorithm10(y, x, this, true);\n },\n 'number | BigNumber, DenseMatrix': function numberBigNumberDenseMatrix(x, y) {\n // check scalar\n if (equalScalar(x, 0)) {\n return zeros(y.size(), y.storage());\n }\n\n return algorithm14(y, x, this, true);\n },\n 'Array, number | BigNumber': function ArrayNumberBigNumber(x, y) {\n // use matrix implementation\n return this(matrix(x), y).valueOf();\n },\n 'number | BigNumber, Array': function numberBigNumberArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y)).valueOf();\n }\n });\n});\nexports.createLeftShift = createLeftShift;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRightArithShift = void 0;\n\nvar _bitwise = require(\"../../utils/bignumber/bitwise.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm02.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm01.js\");\n\nvar _algorithm6 = require(\"../../type/matrix/utils/algorithm10.js\");\n\nvar _algorithm7 = require(\"../../type/matrix/utils/algorithm08.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'rightArithShift';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix'];\nvar createRightArithShift = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n zeros = _ref.zeros,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm01 = (0, _algorithm5.createAlgorithm01)({\n typed: typed\n });\n var algorithm02 = (0, _algorithm.createAlgorithm02)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm08 = (0, _algorithm7.createAlgorithm08)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm10 = (0, _algorithm6.createAlgorithm10)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm11 = (0, _algorithm2.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm13 = (0, _algorithm3.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm4.createAlgorithm14)({\n typed: typed\n });\n /**\n * Bitwise right arithmetic shift of a value x by y number of bits, `x >> y`.\n * For matrices, the function is evaluated element wise.\n * For units, the function is evaluated on the best prefix base.\n *\n * Syntax:\n *\n * math.rightArithShift(x, y)\n *\n * Examples:\n *\n * math.rightArithShift(4, 2) // returns number 1\n *\n * math.rightArithShift([16, -32, 64], 4) // returns Array [1, -2, 3]\n *\n * See also:\n *\n * bitAnd, bitNot, bitOr, bitXor, rightArithShift, rightLogShift\n *\n * @param {number | BigNumber | Array | Matrix} x Value to be shifted\n * @param {number | BigNumber} y Amount of shifts\n * @return {number | BigNumber | Array | Matrix} `x` sign-filled shifted right `y` times\n */\n\n return typed(name, {\n 'number, number': _index.rightArithShiftNumber,\n 'BigNumber, BigNumber': _bitwise.rightArithShiftBigNumber,\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm08(x, y, this, false);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm02(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm01(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, number | BigNumber': function SparseMatrixNumberBigNumber(x, y) {\n // check scalar\n if (equalScalar(y, 0)) {\n return x.clone();\n }\n\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, number | BigNumber': function DenseMatrixNumberBigNumber(x, y) {\n // check scalar\n if (equalScalar(y, 0)) {\n return x.clone();\n }\n\n return algorithm14(x, y, this, false);\n },\n 'number | BigNumber, SparseMatrix': function numberBigNumberSparseMatrix(x, y) {\n // check scalar\n if (equalScalar(x, 0)) {\n return zeros(y.size(), y.storage());\n }\n\n return algorithm10(y, x, this, true);\n },\n 'number | BigNumber, DenseMatrix': function numberBigNumberDenseMatrix(x, y) {\n // check scalar\n if (equalScalar(x, 0)) {\n return zeros(y.size(), y.storage());\n }\n\n return algorithm14(y, x, this, true);\n },\n 'Array, number | BigNumber': function ArrayNumberBigNumber(x, y) {\n // use matrix implementation\n return this(matrix(x), y).valueOf();\n },\n 'number | BigNumber, Array': function numberBigNumberArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y)).valueOf();\n }\n });\n});\nexports.createRightArithShift = createRightArithShift;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRightLogShift = void 0;\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm02.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm01.js\");\n\nvar _algorithm6 = require(\"../../type/matrix/utils/algorithm10.js\");\n\nvar _algorithm7 = require(\"../../type/matrix/utils/algorithm08.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'rightLogShift';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix'];\nvar createRightLogShift = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n zeros = _ref.zeros,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm01 = (0, _algorithm5.createAlgorithm01)({\n typed: typed\n });\n var algorithm02 = (0, _algorithm.createAlgorithm02)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm08 = (0, _algorithm7.createAlgorithm08)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm10 = (0, _algorithm6.createAlgorithm10)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm11 = (0, _algorithm2.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm13 = (0, _algorithm3.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm4.createAlgorithm14)({\n typed: typed\n });\n /**\n * Bitwise right logical shift of value x by y number of bits, `x >>> y`.\n * For matrices, the function is evaluated element wise.\n * For units, the function is evaluated on the best prefix base.\n *\n * Syntax:\n *\n * math.rightLogShift(x, y)\n *\n * Examples:\n *\n * math.rightLogShift(4, 2) // returns number 1\n *\n * math.rightLogShift([16, -32, 64], 4) // returns Array [1, 2, 3]\n *\n * See also:\n *\n * bitAnd, bitNot, bitOr, bitXor, leftShift, rightLogShift\n *\n * @param {number | Array | Matrix} x Value to be shifted\n * @param {number} y Amount of shifts\n * @return {number | Array | Matrix} `x` zero-filled shifted right `y` times\n */\n\n return typed(name, {\n 'number, number': _index.rightLogShiftNumber,\n // 'BigNumber, BigNumber': ..., // TODO: implement BigNumber support for rightLogShift\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm08(x, y, this, false);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm02(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm01(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, number | BigNumber': function SparseMatrixNumberBigNumber(x, y) {\n // check scalar\n if (equalScalar(y, 0)) {\n return x.clone();\n }\n\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, number | BigNumber': function DenseMatrixNumberBigNumber(x, y) {\n // check scalar\n if (equalScalar(y, 0)) {\n return x.clone();\n }\n\n return algorithm14(x, y, this, false);\n },\n 'number | BigNumber, SparseMatrix': function numberBigNumberSparseMatrix(x, y) {\n // check scalar\n if (equalScalar(x, 0)) {\n return zeros(y.size(), y.storage());\n }\n\n return algorithm10(y, x, this, true);\n },\n 'number | BigNumber, DenseMatrix': function numberBigNumberDenseMatrix(x, y) {\n // check scalar\n if (equalScalar(x, 0)) {\n return zeros(y.size(), y.storage());\n }\n\n return algorithm14(y, x, this, true);\n },\n 'Array, number | BigNumber': function ArrayNumberBigNumber(x, y) {\n // use matrix implementation\n return this(matrix(x), y).valueOf();\n },\n 'number | BigNumber, Array': function numberBigNumberArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y)).valueOf();\n }\n });\n});\nexports.createRightLogShift = createRightLogShift;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createBellNumbers = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'bellNumbers';\nvar dependencies = ['typed', 'addScalar', 'isNegative', 'isInteger', 'stirlingS2'];\nvar createBellNumbers = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n addScalar = _ref.addScalar,\n isNegative = _ref.isNegative,\n isInteger = _ref.isInteger,\n stirlingS2 = _ref.stirlingS2;\n\n /**\n * The Bell Numbers count the number of partitions of a set. A partition is a pairwise disjoint subset of S whose union is S.\n * bellNumbers only takes integer arguments.\n * The following condition must be enforced: n >= 0\n *\n * Syntax:\n *\n * math.bellNumbers(n)\n *\n * Examples:\n *\n * math.bellNumbers(3) // returns 5\n * math.bellNumbers(8) // returns 4140\n *\n * See also:\n *\n * stirlingS2\n *\n * @param {Number | BigNumber} n Total number of objects in the set\n * @return {Number | BigNumber} B(n)\n */\n return typed(name, {\n 'number | BigNumber': function numberBigNumber(n) {\n if (!isInteger(n) || isNegative(n)) {\n throw new TypeError('Non-negative integer value expected in function bellNumbers');\n } // Sum (k=0, n) S(n,k).\n\n\n var result = 0;\n\n for (var i = 0; i <= n; i++) {\n result = addScalar(result, stirlingS2(n, i));\n }\n\n return result;\n }\n });\n});\nexports.createBellNumbers = createBellNumbers;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCatalan = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'catalan';\nvar dependencies = ['typed', 'addScalar', 'divideScalar', 'multiplyScalar', 'combinations', 'isNegative', 'isInteger'];\nvar createCatalan = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n addScalar = _ref.addScalar,\n divideScalar = _ref.divideScalar,\n multiplyScalar = _ref.multiplyScalar,\n combinations = _ref.combinations,\n isNegative = _ref.isNegative,\n isInteger = _ref.isInteger;\n\n /**\n * The Catalan Numbers enumerate combinatorial structures of many different types.\n * catalan only takes integer arguments.\n * The following condition must be enforced: n >= 0\n *\n * Syntax:\n *\n * math.catalan(n)\n *\n * Examples:\n *\n * math.catalan(3) // returns 5\n * math.catalan(8) // returns 1430\n *\n * See also:\n *\n * bellNumbers\n *\n * @param {Number | BigNumber} n nth Catalan number\n * @return {Number | BigNumber} Cn(n)\n */\n return typed(name, {\n 'number | BigNumber': function numberBigNumber(n) {\n if (!isInteger(n) || isNegative(n)) {\n throw new TypeError('Non-negative integer value expected in function catalan');\n }\n\n return divideScalar(combinations(multiplyScalar(n, 2), n), addScalar(n, 1));\n }\n });\n});\nexports.createCatalan = createCatalan;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createComposition = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'composition';\nvar dependencies = ['typed', 'addScalar', 'combinations', 'isNegative', 'isPositive', 'isInteger', 'larger'];\nvar createComposition = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n addScalar = _ref.addScalar,\n combinations = _ref.combinations,\n isPositive = _ref.isPositive,\n isNegative = _ref.isNegative,\n isInteger = _ref.isInteger,\n larger = _ref.larger;\n\n /**\n * The composition counts of n into k parts.\n *\n * composition only takes integer arguments.\n * The following condition must be enforced: k <= n.\n *\n * Syntax:\n *\n * math.composition(n, k)\n *\n * Examples:\n *\n * math.composition(5, 3) // returns 6\n *\n * See also:\n *\n * combinations\n *\n * @param {Number | BigNumber} n Total number of objects in the set\n * @param {Number | BigNumber} k Number of objects in the subset\n * @return {Number | BigNumber} Returns the composition counts of n into k parts.\n */\n return typed(name, {\n 'number | BigNumber, number | BigNumber': function numberBigNumberNumberBigNumber(n, k) {\n if (!isInteger(n) || !isPositive(n) || !isInteger(k) || !isPositive(k)) {\n throw new TypeError('Positive integer value expected in function composition');\n } else if (larger(k, n)) {\n throw new TypeError('k must be less than or equal to n in function composition');\n }\n\n return combinations(addScalar(n, -1), addScalar(k, -1));\n }\n });\n});\nexports.createComposition = createComposition;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createStirlingS2 = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar name = 'stirlingS2';\nvar dependencies = ['typed', 'addScalar', 'subtract', 'multiplyScalar', 'divideScalar', 'pow', 'factorial', 'combinations', 'isNegative', 'isInteger', 'number', '?bignumber', 'larger'];\nvar createStirlingS2 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n addScalar = _ref.addScalar,\n subtract = _ref.subtract,\n multiplyScalar = _ref.multiplyScalar,\n divideScalar = _ref.divideScalar,\n pow = _ref.pow,\n factorial = _ref.factorial,\n combinations = _ref.combinations,\n isNegative = _ref.isNegative,\n isInteger = _ref.isInteger,\n number = _ref.number,\n bignumber = _ref.bignumber,\n larger = _ref.larger;\n var smallCache = [];\n var bigCache = [];\n /**\n * The Stirling numbers of the second kind, counts the number of ways to partition\n * a set of n labelled objects into k nonempty unlabelled subsets.\n * stirlingS2 only takes integer arguments.\n * The following condition must be enforced: k <= n.\n *\n * If n = k or k = 1 <= n, then s(n,k) = 1\n * If k = 0 < n, then s(n,k) = 0\n *\n * Note that if either n or k is supplied as a BigNumber, the result will be\n * as well.\n *\n * Syntax:\n *\n * math.stirlingS2(n, k)\n *\n * Examples:\n *\n * math.stirlingS2(5, 3) //returns 25\n *\n * See also:\n *\n * bellNumbers\n *\n * @param {Number | BigNumber} n Total number of objects in the set\n * @param {Number | BigNumber} k Number of objects in the subset\n * @return {Number | BigNumber} S(n,k)\n */\n\n return typed(name, {\n 'number | BigNumber, number | BigNumber': function numberBigNumberNumberBigNumber(n, k) {\n if (!isInteger(n) || isNegative(n) || !isInteger(k) || isNegative(k)) {\n throw new TypeError('Non-negative integer value expected in function stirlingS2');\n } else if (larger(k, n)) {\n throw new TypeError('k must be less than or equal to n in function stirlingS2');\n }\n\n var big = !((0, _is.isNumber)(n) && (0, _is.isNumber)(k));\n var cache = big ? bigCache : smallCache;\n var make = big ? bignumber : number;\n var nn = number(n);\n var nk = number(k);\n /* See if we already have the value: */\n\n if (cache[nn] && cache[nn].length > nk) {\n return cache[nn][nk];\n }\n /* Fill the cache */\n\n\n for (var m = 0; m <= nn; ++m) {\n if (!cache[m]) {\n cache[m] = [m === 0 ? make(1) : make(0)];\n }\n\n if (m === 0) continue;\n var row = cache[m];\n var prev = cache[m - 1];\n\n for (var i = row.length; i <= m && i <= nk; ++i) {\n if (i === m) {\n row[i] = 1;\n } else {\n row[i] = addScalar(multiplyScalar(make(i), prev[i]), prev[i - 1]);\n }\n }\n }\n\n return cache[nn][nk];\n }\n });\n});\nexports.createStirlingS2 = createStirlingS2;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createArg = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar name = 'arg';\nvar dependencies = ['typed'];\nvar createArg = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Compute the argument of a complex value.\n * For a complex number `a + bi`, the argument is computed as `atan2(b, a)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.arg(x)\n *\n * Examples:\n *\n * const a = math.complex(2, 2)\n * math.arg(a) / math.pi // returns number 0.25\n *\n * const b = math.complex('2 + 3i')\n * math.arg(b) // returns number 0.982793723247329\n * math.atan2(3, 2) // returns number 0.982793723247329\n *\n * See also:\n *\n * re, im, conj, abs\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * A complex number or array with complex numbers\n * @return {number | BigNumber | Array | Matrix} The argument of x\n */\n return typed(name, {\n number: function number(x) {\n return Math.atan2(0, x);\n },\n BigNumber: function BigNumber(x) {\n return x.constructor.atan2(0, x);\n },\n Complex: function Complex(x) {\n return x.arg();\n },\n // TODO: implement BigNumber support for function arg\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createArg = createArg;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createConj = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar name = 'conj';\nvar dependencies = ['typed'];\nvar createConj = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Compute the complex conjugate of a complex value.\n * If `x = a+bi`, the complex conjugate of `x` is `a - bi`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.conj(x)\n *\n * Examples:\n *\n * math.conj(math.complex('2 + 3i')) // returns Complex 2 - 3i\n * math.conj(math.complex('2 - 3i')) // returns Complex 2 + 3i\n * math.conj(math.complex('-5.2i')) // returns Complex 5.2i\n *\n * See also:\n *\n * re, im, arg, abs\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * A complex number or array with complex numbers\n * @return {number | BigNumber | Complex | Array | Matrix}\n * The complex conjugate of x\n */\n return typed(name, {\n number: function number(x) {\n return x;\n },\n BigNumber: function BigNumber(x) {\n return x;\n },\n Complex: function Complex(x) {\n return x.conjugate();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createConj = createConj;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIm = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar name = 'im';\nvar dependencies = ['typed'];\nvar createIm = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Get the imaginary part of a complex number.\n * For a complex number `a + bi`, the function returns `b`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.im(x)\n *\n * Examples:\n *\n * const a = math.complex(2, 3)\n * math.re(a) // returns number 2\n * math.im(a) // returns number 3\n *\n * math.re(math.complex('-5.2i')) // returns number -5.2\n * math.re(math.complex(2.4)) // returns number 0\n *\n * See also:\n *\n * re, conj, abs, arg\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * A complex number or array with complex numbers\n * @return {number | BigNumber | Array | Matrix} The imaginary part of x\n */\n return typed(name, {\n number: function number(x) {\n return 0;\n },\n BigNumber: function BigNumber(x) {\n return x.mul(0);\n },\n Fraction: function Fraction(x) {\n return x.mul(0);\n },\n Complex: function Complex(x) {\n return x.im;\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createIm = createIm;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRe = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar name = 're';\nvar dependencies = ['typed'];\nvar createRe = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Get the real part of a complex number.\n * For a complex number `a + bi`, the function returns `a`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.re(x)\n *\n * Examples:\n *\n * const a = math.complex(2, 3)\n * math.re(a) // returns number 2\n * math.im(a) // returns number 3\n *\n * math.re(math.complex('-5.2i')) // returns number 0\n * math.re(math.complex(2.4)) // returns number 2.4\n *\n * See also:\n *\n * im, conj, abs, arg\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x\n * A complex number or array with complex numbers\n * @return {number | BigNumber | Array | Matrix} The real part of x\n */\n return typed(name, {\n number: function number(x) {\n return x;\n },\n BigNumber: function BigNumber(x) {\n return x;\n },\n Fraction: function Fraction(x) {\n return x;\n },\n Complex: function Complex(x) {\n return x.re;\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createRe = createRe;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDistance = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'distance';\nvar dependencies = ['typed', 'addScalar', 'subtract', 'divideScalar', 'multiplyScalar', 'unaryMinus', 'sqrt', 'abs'];\nvar createDistance = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n addScalar = _ref.addScalar,\n subtract = _ref.subtract,\n multiplyScalar = _ref.multiplyScalar,\n divideScalar = _ref.divideScalar,\n unaryMinus = _ref.unaryMinus,\n sqrt = _ref.sqrt,\n abs = _ref.abs;\n\n /**\n * Calculates:\n * The eucledian distance between two points in N-dimensional spaces.\n * Distance between point and a line in 2 and 3 dimensional spaces.\n * Pairwise distance between a set of 2D or 3D points\n * NOTE:\n * When substituting coefficients of a line(a, b and c), use ax + by + c = 0 instead of ax + by = c\n * For parametric equation of a 3D line, x0, y0, z0, a, b, c are from: (x−x0, y−y0, z−z0) = t(a, b, c)\n *\n * Syntax:\n * math.distance([x1, y1], [x2, y2])\n *- math.distance({pointOneX: 4, pointOneY: 5}, {pointTwoX: 2, pointTwoY: 7})\n * math.distance([x1, y1, z1], [x2, y2, z2])\n * math.distance({pointOneX: 4, pointOneY: 5, pointOneZ: 8}, {pointTwoX: 2, pointTwoY: 7, pointTwoZ: 9})\n * math.distance([x1, y1, ... , N1], [x2, y2, ... , N2])\n * math.distance([[A], [B], [C]...])\n * math.distance([x1, y1], [LinePtX1, LinePtY1], [LinePtX2, LinePtY2])\n * math.distance({pointX: 1, pointY: 4}, {lineOnePtX: 6, lineOnePtY: 3}, {lineTwoPtX: 2, lineTwoPtY: 8})\n * math.distance([x1, y1, z1], [LinePtX1, LinePtY1, LinePtZ1], [LinePtX2, LinePtY2, LinePtZ2])\n * math.distance({pointX: 1, pointY: 4, pointZ: 7}, {lineOnePtX: 6, lineOnePtY: 3, lineOnePtZ: 4}, {lineTwoPtX: 2, lineTwoPtY: 8, lineTwoPtZ: 5})\n * math.distance([x1, y1], [xCoeffLine, yCoeffLine, constant])\n * math.distance({pointX: 10, pointY: 10}, {xCoeffLine: 8, yCoeffLine: 1, constant: 3})\n * math.distance([x1, y1, z1], [x0, y0, z0, a-tCoeff, b-tCoeff, c-tCoeff]) point and parametric equation of 3D line\n * math.distance([x, y, z], [x0, y0, z0, a, b, c])\n * math.distance({pointX: 2, pointY: 5, pointZ: 9}, {x0: 4, y0: 6, z0: 3, a: 4, b: 2, c: 0})\n *\n * Examples:\n * math.distance([0,0], [4,4]) // Returns 5.6569\n * math.distance(\n * {pointOneX: 0, pointOneY: 0},\n * {pointTwoX: 10, pointTwoY: 10}) // Returns 14.142135623730951\n * math.distance([1, 0, 1], [4, -2, 2]) // Returns 3.74166\n * math.distance(\n * {pointOneX: 4, pointOneY: 5, pointOneZ: 8},\n * {pointTwoX: 2, pointTwoY: 7, pointTwoZ: 9}) // Returns 3\n * math.distance([1, 0, 1, 0], [0, -1, 0, -1]) // Returns 2\n * math.distance([[1, 2], [1, 2], [1, 3]]) // Returns [0, 1, 1]\n * math.distance([[1,2,4], [1,2,6], [8,1,3]]) // Returns [2, 7.14142842854285, 7.681145747868608]\n * math.distance([10, 10], [8, 1, 3]) // Returns 11.535230316796387\n * math.distance([10, 10], [2, 3], [-8, 0]) // Returns 8.759953130362847\n * math.distance(\n * {pointX: 1, pointY: 4},\n * {lineOnePtX: 6, lineOnePtY: 3},\n * {lineTwoPtX: 2, lineTwoPtY: 8}) // Returns 2.720549372624744\n * math.distance([2, 3, 1], [1, 1, 2, 5, 0, 1]) // Returns 2.3204774044612857\n * math.distance(\n * {pointX: 2, pointY: 3, pointZ: 1},\n * {x0: 1, y0: 1, z0: 2, a: 5, b: 0, c: 1} // Returns 2.3204774044612857\n *\n * @param {Array | Matrix | Object} x Co-ordinates of first point\n * @param {Array | Matrix | Object} y Co-ordinates of second point\n * @return {Number | BigNumber} Returns the distance from two/three points\n */\n return typed(name, {\n 'Array, Array, Array': function ArrayArrayArray(x, y, z) {\n // Point to Line 2D (x=Point, y=LinePoint1, z=LinePoint2)\n if (x.length === 2 && y.length === 2 && z.length === 2) {\n if (!_2d(x)) {\n throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument');\n }\n\n if (!_2d(y)) {\n throw new TypeError('Array with 2 numbers or BigNumbers expected for second argument');\n }\n\n if (!_2d(z)) {\n throw new TypeError('Array with 2 numbers or BigNumbers expected for third argument');\n }\n\n var m = divideScalar(subtract(z[1], z[0]), subtract(y[1], y[0]));\n var xCoeff = multiplyScalar(multiplyScalar(m, m), y[0]);\n var yCoeff = unaryMinus(multiplyScalar(m, y[0]));\n var constant = x[1];\n return _distancePointLine2D(x[0], x[1], xCoeff, yCoeff, constant);\n } else {\n throw new TypeError('Invalid Arguments: Try again');\n }\n },\n 'Object, Object, Object': function ObjectObjectObject(x, y, z) {\n if (Object.keys(x).length === 2 && Object.keys(y).length === 2 && Object.keys(z).length === 2) {\n if (!_2d(x)) {\n throw new TypeError('Values of pointX and pointY should be numbers or BigNumbers');\n }\n\n if (!_2d(y)) {\n throw new TypeError('Values of lineOnePtX and lineOnePtY should be numbers or BigNumbers');\n }\n\n if (!_2d(z)) {\n throw new TypeError('Values of lineTwoPtX and lineTwoPtY should be numbers or BigNumbers');\n }\n\n if ('pointX' in x && 'pointY' in x && 'lineOnePtX' in y && 'lineOnePtY' in y && 'lineTwoPtX' in z && 'lineTwoPtY' in z) {\n var m = divideScalar(subtract(z.lineTwoPtY, z.lineTwoPtX), subtract(y.lineOnePtY, y.lineOnePtX));\n var xCoeff = multiplyScalar(multiplyScalar(m, m), y.lineOnePtX);\n var yCoeff = unaryMinus(multiplyScalar(m, y.lineOnePtX));\n var constant = x.pointX;\n return _distancePointLine2D(x.pointX, x.pointY, xCoeff, yCoeff, constant);\n } else {\n throw new TypeError('Key names do not match');\n }\n } else {\n throw new TypeError('Invalid Arguments: Try again');\n }\n },\n 'Array, Array': function ArrayArray(x, y) {\n // Point to Line 2D (x=[pointX, pointY], y=[x-coeff, y-coeff, const])\n if (x.length === 2 && y.length === 3) {\n if (!_2d(x)) {\n throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument');\n }\n\n if (!_3d(y)) {\n throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument');\n }\n\n return _distancePointLine2D(x[0], x[1], y[0], y[1], y[2]);\n } else if (x.length === 3 && y.length === 6) {\n // Point to Line 3D\n if (!_3d(x)) {\n throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument');\n }\n\n if (!_parametricLine(y)) {\n throw new TypeError('Array with 6 numbers or BigNumbers expected for second argument');\n }\n\n return _distancePointLine3D(x[0], x[1], x[2], y[0], y[1], y[2], y[3], y[4], y[5]);\n } else if (x.length === y.length && x.length > 0) {\n // Point to Point N-dimensions\n if (!_containsOnlyNumbers(x)) {\n throw new TypeError('All values of an array should be numbers or BigNumbers');\n }\n\n if (!_containsOnlyNumbers(y)) {\n throw new TypeError('All values of an array should be numbers or BigNumbers');\n }\n\n return _euclideanDistance(x, y);\n } else {\n throw new TypeError('Invalid Arguments: Try again');\n }\n },\n 'Object, Object': function ObjectObject(x, y) {\n if (Object.keys(x).length === 2 && Object.keys(y).length === 3) {\n if (!_2d(x)) {\n throw new TypeError('Values of pointX and pointY should be numbers or BigNumbers');\n }\n\n if (!_3d(y)) {\n throw new TypeError('Values of xCoeffLine, yCoeffLine and constant should be numbers or BigNumbers');\n }\n\n if ('pointX' in x && 'pointY' in x && 'xCoeffLine' in y && 'yCoeffLine' in y && 'constant' in y) {\n return _distancePointLine2D(x.pointX, x.pointY, y.xCoeffLine, y.yCoeffLine, y.constant);\n } else {\n throw new TypeError('Key names do not match');\n }\n } else if (Object.keys(x).length === 3 && Object.keys(y).length === 6) {\n // Point to Line 3D\n if (!_3d(x)) {\n throw new TypeError('Values of pointX, pointY and pointZ should be numbers or BigNumbers');\n }\n\n if (!_parametricLine(y)) {\n throw new TypeError('Values of x0, y0, z0, a, b and c should be numbers or BigNumbers');\n }\n\n if ('pointX' in x && 'pointY' in x && 'x0' in y && 'y0' in y && 'z0' in y && 'a' in y && 'b' in y && 'c' in y) {\n return _distancePointLine3D(x.pointX, x.pointY, x.pointZ, y.x0, y.y0, y.z0, y.a, y.b, y.c);\n } else {\n throw new TypeError('Key names do not match');\n }\n } else if (Object.keys(x).length === 2 && Object.keys(y).length === 2) {\n // Point to Point 2D\n if (!_2d(x)) {\n throw new TypeError('Values of pointOneX and pointOneY should be numbers or BigNumbers');\n }\n\n if (!_2d(y)) {\n throw new TypeError('Values of pointTwoX and pointTwoY should be numbers or BigNumbers');\n }\n\n if ('pointOneX' in x && 'pointOneY' in x && 'pointTwoX' in y && 'pointTwoY' in y) {\n return _euclideanDistance([x.pointOneX, x.pointOneY], [y.pointTwoX, y.pointTwoY]);\n } else {\n throw new TypeError('Key names do not match');\n }\n } else if (Object.keys(x).length === 3 && Object.keys(y).length === 3) {\n // Point to Point 3D\n if (!_3d(x)) {\n throw new TypeError('Values of pointOneX, pointOneY and pointOneZ should be numbers or BigNumbers');\n }\n\n if (!_3d(y)) {\n throw new TypeError('Values of pointTwoX, pointTwoY and pointTwoZ should be numbers or BigNumbers');\n }\n\n if ('pointOneX' in x && 'pointOneY' in x && 'pointOneZ' in x && 'pointTwoX' in y && 'pointTwoY' in y && 'pointTwoZ' in y) {\n return _euclideanDistance([x.pointOneX, x.pointOneY, x.pointOneZ], [y.pointTwoX, y.pointTwoY, y.pointTwoZ]);\n } else {\n throw new TypeError('Key names do not match');\n }\n } else {\n throw new TypeError('Invalid Arguments: Try again');\n }\n },\n Array: function Array(arr) {\n if (!_pairwise(arr)) {\n throw new TypeError('Incorrect array format entered for pairwise distance calculation');\n }\n\n return _distancePairwise(arr);\n }\n });\n\n function _isNumber(a) {\n // distance supports numbers and bignumbers\n return typeof a === 'number' || (0, _is.isBigNumber)(a);\n }\n\n function _2d(a) {\n // checks if the number of arguments are correct in count and are valid (should be numbers)\n if (a.constructor !== Array) {\n a = _objectToArray(a);\n }\n\n return _isNumber(a[0]) && _isNumber(a[1]);\n }\n\n function _3d(a) {\n // checks if the number of arguments are correct in count and are valid (should be numbers)\n if (a.constructor !== Array) {\n a = _objectToArray(a);\n }\n\n return _isNumber(a[0]) && _isNumber(a[1]) && _isNumber(a[2]);\n }\n\n function _containsOnlyNumbers(a) {\n // checks if the number of arguments are correct in count and are valid (should be numbers)\n if (!Array.isArray(a)) {\n a = _objectToArray(a);\n }\n\n return a.every(_isNumber);\n }\n\n function _parametricLine(a) {\n if (a.constructor !== Array) {\n a = _objectToArray(a);\n }\n\n return _isNumber(a[0]) && _isNumber(a[1]) && _isNumber(a[2]) && _isNumber(a[3]) && _isNumber(a[4]) && _isNumber(a[5]);\n }\n\n function _objectToArray(o) {\n var keys = Object.keys(o);\n var a = [];\n\n for (var i = 0; i < keys.length; i++) {\n a.push(o[keys[i]]);\n }\n\n return a;\n }\n\n function _pairwise(a) {\n // checks for valid arguments passed to _distancePairwise(Array)\n if (a[0].length === 2 && _isNumber(a[0][0]) && _isNumber(a[0][1])) {\n if (a.some(function (aI) {\n return aI.length !== 2 || !_isNumber(aI[0]) || !_isNumber(aI[1]);\n })) {\n return false;\n }\n } else if (a[0].length === 3 && _isNumber(a[0][0]) && _isNumber(a[0][1]) && _isNumber(a[0][2])) {\n if (a.some(function (aI) {\n return aI.length !== 3 || !_isNumber(aI[0]) || !_isNumber(aI[1]) || !_isNumber(aI[2]);\n })) {\n return false;\n }\n } else {\n return false;\n }\n\n return true;\n }\n\n function _distancePointLine2D(x, y, a, b, c) {\n var num = abs(addScalar(addScalar(multiplyScalar(a, x), multiplyScalar(b, y)), c));\n var den = sqrt(addScalar(multiplyScalar(a, a), multiplyScalar(b, b)));\n return divideScalar(num, den);\n }\n\n function _distancePointLine3D(x, y, z, x0, y0, z0, a, b, c) {\n var num = [subtract(multiplyScalar(subtract(y0, y), c), multiplyScalar(subtract(z0, z), b)), subtract(multiplyScalar(subtract(z0, z), a), multiplyScalar(subtract(x0, x), c)), subtract(multiplyScalar(subtract(x0, x), b), multiplyScalar(subtract(y0, y), a))];\n num = sqrt(addScalar(addScalar(multiplyScalar(num[0], num[0]), multiplyScalar(num[1], num[1])), multiplyScalar(num[2], num[2])));\n var den = sqrt(addScalar(addScalar(multiplyScalar(a, a), multiplyScalar(b, b)), multiplyScalar(c, c)));\n return divideScalar(num, den);\n }\n\n function _euclideanDistance(x, y) {\n var vectorSize = x.length;\n var result = 0;\n var diff = 0;\n\n for (var i = 0; i < vectorSize; i++) {\n diff = subtract(x[i], y[i]);\n result = addScalar(multiplyScalar(diff, diff), result);\n }\n\n return sqrt(result);\n }\n\n function _distancePairwise(a) {\n var result = [];\n var pointA = [];\n var pointB = [];\n\n for (var i = 0; i < a.length - 1; i++) {\n for (var j = i + 1; j < a.length; j++) {\n if (a[0].length === 2) {\n pointA = [a[i][0], a[i][1]];\n pointB = [a[j][0], a[j][1]];\n } else if (a[0].length === 3) {\n pointA = [a[i][0], a[i][1], a[i][2]];\n pointB = [a[j][0], a[j][1], a[j][2]];\n }\n\n result.push(_euclideanDistance(pointA, pointB));\n }\n }\n\n return result;\n }\n});\nexports.createDistance = createDistance;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIntersect = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'intersect';\nvar dependencies = ['typed', 'config', 'abs', 'add', 'addScalar', 'matrix', 'multiply', 'multiplyScalar', 'divideScalar', 'subtract', 'smaller', 'equalScalar', 'flatten', 'isZero', 'isNumeric'];\nvar createIntersect = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n abs = _ref.abs,\n add = _ref.add,\n addScalar = _ref.addScalar,\n matrix = _ref.matrix,\n multiply = _ref.multiply,\n multiplyScalar = _ref.multiplyScalar,\n divideScalar = _ref.divideScalar,\n subtract = _ref.subtract,\n smaller = _ref.smaller,\n equalScalar = _ref.equalScalar,\n flatten = _ref.flatten,\n isZero = _ref.isZero,\n isNumeric = _ref.isNumeric;\n\n /**\n * Calculates the point of intersection of two lines in two or three dimensions\n * and of a line and a plane in three dimensions. The inputs are in the form of\n * arrays or 1 dimensional matrices. The line intersection functions return null\n * if the lines do not meet.\n *\n * Note: Fill the plane coefficients as `x + y + z = c` and not as `x + y + z + c = 0`.\n *\n * Syntax:\n *\n * math.intersect(endPoint1Line1, endPoint2Line1, endPoint1Line2, endPoint2Line2)\n * math.intersect(endPoint1, endPoint2, planeCoefficients)\n *\n * Examples:\n *\n * math.intersect([0, 0], [10, 10], [10, 0], [0, 10]) // Returns [5, 5]\n * math.intersect([0, 0, 0], [10, 10, 0], [10, 0, 0], [0, 10, 0]) // Returns [5, 5, 0]\n * math.intersect([1, 0, 1], [4, -2, 2], [1, 1, 1, 6]) // Returns [7, -4, 3]\n *\n * @param {Array | Matrix} w Co-ordinates of first end-point of first line\n * @param {Array | Matrix} x Co-ordinates of second end-point of first line\n * @param {Array | Matrix} y Co-ordinates of first end-point of second line\n * OR Co-efficients of the plane's equation\n * @param {Array | Matrix} z Co-ordinates of second end-point of second line\n * OR undefined if the calculation is for line and plane\n * @return {Array} Returns the point of intersection of lines/lines-planes\n */\n return typed('intersect', {\n 'Array, Array, Array': _AAA,\n 'Array, Array, Array, Array': _AAAA,\n 'Matrix, Matrix, Matrix': function MatrixMatrixMatrix(x, y, plane) {\n var arr = _AAA(x.valueOf(), y.valueOf(), plane.valueOf());\n\n return arr === null ? null : matrix(arr);\n },\n 'Matrix, Matrix, Matrix, Matrix': function MatrixMatrixMatrixMatrix(w, x, y, z) {\n // TODO: output matrix type should match input matrix type\n var arr = _AAAA(w.valueOf(), x.valueOf(), y.valueOf(), z.valueOf());\n\n return arr === null ? null : matrix(arr);\n }\n });\n\n function _AAA(x, y, plane) {\n x = _coerceArr(x);\n y = _coerceArr(y);\n plane = _coerceArr(plane);\n\n if (!_3d(x)) {\n throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument');\n }\n\n if (!_3d(y)) {\n throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument');\n }\n\n if (!_4d(plane)) {\n throw new TypeError('Array with 4 numbers expected as third argument');\n }\n\n return _intersectLinePlane(x[0], x[1], x[2], y[0], y[1], y[2], plane[0], plane[1], plane[2], plane[3]);\n }\n\n function _AAAA(w, x, y, z) {\n w = _coerceArr(w);\n x = _coerceArr(x);\n y = _coerceArr(y);\n z = _coerceArr(z);\n\n if (w.length === 2) {\n if (!_2d(w)) {\n throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument');\n }\n\n if (!_2d(x)) {\n throw new TypeError('Array with 2 numbers or BigNumbers expected for second argument');\n }\n\n if (!_2d(y)) {\n throw new TypeError('Array with 2 numbers or BigNumbers expected for third argument');\n }\n\n if (!_2d(z)) {\n throw new TypeError('Array with 2 numbers or BigNumbers expected for fourth argument');\n }\n\n return _intersect2d(w, x, y, z);\n } else if (w.length === 3) {\n if (!_3d(w)) {\n throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument');\n }\n\n if (!_3d(x)) {\n throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument');\n }\n\n if (!_3d(y)) {\n throw new TypeError('Array with 3 numbers or BigNumbers expected for third argument');\n }\n\n if (!_3d(z)) {\n throw new TypeError('Array with 3 numbers or BigNumbers expected for fourth argument');\n }\n\n return _intersect3d(w[0], w[1], w[2], x[0], x[1], x[2], y[0], y[1], y[2], z[0], z[1], z[2]);\n } else {\n throw new TypeError('Arrays with two or thee dimensional points expected');\n }\n }\n /** Coerce row and column 2-dim arrays to 1-dim array */\n\n\n function _coerceArr(arr) {\n // row matrix\n if (arr.length === 1) return arr[0]; // column matrix\n\n if (arr.length > 1 && Array.isArray(arr[0])) {\n if (arr.every(function (el) {\n return Array.isArray(el) && el.length === 1;\n })) return flatten(arr);\n }\n\n return arr;\n }\n\n function _2d(x) {\n return x.length === 2 && isNumeric(x[0]) && isNumeric(x[1]);\n }\n\n function _3d(x) {\n return x.length === 3 && isNumeric(x[0]) && isNumeric(x[1]) && isNumeric(x[2]);\n }\n\n function _4d(x) {\n return x.length === 4 && isNumeric(x[0]) && isNumeric(x[1]) && isNumeric(x[2]) && isNumeric(x[3]);\n }\n\n function _intersect2d(p1a, p1b, p2a, p2b) {\n var o1 = p1a;\n var o2 = p2a;\n var d1 = subtract(o1, p1b);\n var d2 = subtract(o2, p2b);\n var det = subtract(multiplyScalar(d1[0], d2[1]), multiplyScalar(d2[0], d1[1]));\n if (isZero(det)) return null;\n\n if (smaller(abs(det), config.epsilon)) {\n return null;\n }\n\n var d20o11 = multiplyScalar(d2[0], o1[1]);\n var d21o10 = multiplyScalar(d2[1], o1[0]);\n var d20o21 = multiplyScalar(d2[0], o2[1]);\n var d21o20 = multiplyScalar(d2[1], o2[0]);\n var t = divideScalar(addScalar(subtract(subtract(d20o11, d21o10), d20o21), d21o20), det);\n return add(multiply(d1, t), o1);\n }\n\n function _intersect3dHelper(a, b, c, d, e, f, g, h, i, j, k, l) {\n // (a - b)*(c - d) + (e - f)*(g - h) + (i - j)*(k - l)\n var add1 = multiplyScalar(subtract(a, b), subtract(c, d));\n var add2 = multiplyScalar(subtract(e, f), subtract(g, h));\n var add3 = multiplyScalar(subtract(i, j), subtract(k, l));\n return addScalar(addScalar(add1, add2), add3);\n }\n\n function _intersect3d(x1, y1, z1, x2, y2, z2, x3, y3, z3, x4, y4, z4) {\n var d1343 = _intersect3dHelper(x1, x3, x4, x3, y1, y3, y4, y3, z1, z3, z4, z3);\n\n var d4321 = _intersect3dHelper(x4, x3, x2, x1, y4, y3, y2, y1, z4, z3, z2, z1);\n\n var d1321 = _intersect3dHelper(x1, x3, x2, x1, y1, y3, y2, y1, z1, z3, z2, z1);\n\n var d4343 = _intersect3dHelper(x4, x3, x4, x3, y4, y3, y4, y3, z4, z3, z4, z3);\n\n var d2121 = _intersect3dHelper(x2, x1, x2, x1, y2, y1, y2, y1, z2, z1, z2, z1);\n\n var numerator = subtract(multiplyScalar(d1343, d4321), multiplyScalar(d1321, d4343));\n var denominator = subtract(multiplyScalar(d2121, d4343), multiplyScalar(d4321, d4321));\n if (isZero(denominator)) return null;\n var ta = divideScalar(numerator, denominator);\n var tb = divideScalar(addScalar(d1343, multiplyScalar(ta, d4321)), d4343);\n var pax = addScalar(x1, multiplyScalar(ta, subtract(x2, x1)));\n var pay = addScalar(y1, multiplyScalar(ta, subtract(y2, y1)));\n var paz = addScalar(z1, multiplyScalar(ta, subtract(z2, z1)));\n var pbx = addScalar(x3, multiplyScalar(tb, subtract(x4, x3)));\n var pby = addScalar(y3, multiplyScalar(tb, subtract(y4, y3)));\n var pbz = addScalar(z3, multiplyScalar(tb, subtract(z4, z3)));\n\n if (equalScalar(pax, pbx) && equalScalar(pay, pby) && equalScalar(paz, pbz)) {\n return [pax, pay, paz];\n } else {\n return null;\n }\n }\n\n function _intersectLinePlane(x1, y1, z1, x2, y2, z2, x, y, z, c) {\n var x1x = multiplyScalar(x1, x);\n var x2x = multiplyScalar(x2, x);\n var y1y = multiplyScalar(y1, y);\n var y2y = multiplyScalar(y2, y);\n var z1z = multiplyScalar(z1, z);\n var z2z = multiplyScalar(z2, z);\n var numerator = subtract(subtract(subtract(c, x1x), y1y), z1z);\n var denominator = subtract(subtract(subtract(addScalar(addScalar(x2x, y2y), z2z), x1x), y1y), z1z);\n var t = divideScalar(numerator, denominator);\n var px = addScalar(x1, multiplyScalar(t, subtract(x2, x1)));\n var py = addScalar(y1, multiplyScalar(t, subtract(y2, y1)));\n var pz = addScalar(z1, multiplyScalar(t, subtract(z2, z1)));\n return [px, py, pz]; // TODO: Add cases when line is parallel to the plane:\n // (a) no intersection,\n // (b) line contained in plane\n }\n});\nexports.createIntersect = createIntersect;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAnd = void 0;\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm02.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm06.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'and';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'zeros', 'not'];\nvar createAnd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n zeros = _ref.zeros,\n not = _ref.not;\n var algorithm02 = (0, _algorithm.createAlgorithm02)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm06 = (0, _algorithm5.createAlgorithm06)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm11 = (0, _algorithm2.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm13 = (0, _algorithm3.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm4.createAlgorithm14)({\n typed: typed\n });\n /**\n * Logical `and`. Test whether two values are both defined with a nonzero/nonempty value.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.and(x, y)\n *\n * Examples:\n *\n * math.and(2, 4) // returns true\n *\n * a = [2, 0, 0]\n * b = [3, 7, 0]\n * c = 0\n *\n * math.and(a, b) // returns [true, false, false]\n * math.and(a, c) // returns [false, false, false]\n *\n * See also:\n *\n * not, or, xor\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x First value to check\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} y Second value to check\n * @return {boolean | Array | Matrix}\n * Returns true when both inputs are defined with a nonzero/nonempty value.\n */\n\n return typed(name, {\n 'number, number': _index.andNumber,\n 'Complex, Complex': function ComplexComplex(x, y) {\n return (x.re !== 0 || x.im !== 0) && (y.re !== 0 || y.im !== 0);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return !x.isZero() && !y.isZero() && !x.isNaN() && !y.isNaN();\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n return this(x.value || 0, y.value || 0);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm06(x, y, this, false);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm02(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm02(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n // check scalar\n if (not(y)) {\n // return zero matrix\n return zeros(x.size(), x.storage());\n }\n\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n // check scalar\n if (not(y)) {\n // return zero matrix\n return zeros(x.size(), x.storage());\n }\n\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n // check scalar\n if (not(x)) {\n // return zero matrix\n return zeros(x.size(), x.storage());\n }\n\n return algorithm11(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n // check scalar\n if (not(x)) {\n // return zero matrix\n return zeros(x.size(), x.storage());\n }\n\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return this(matrix(x), y).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y)).valueOf();\n }\n });\n});\nexports.createAnd = createAnd;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createNot = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'not';\nvar dependencies = ['typed'];\nvar createNot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Logical `not`. Flips boolean value of a given parameter.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.not(x)\n *\n * Examples:\n *\n * math.not(2) // returns false\n * math.not(0) // returns true\n * math.not(true) // returns false\n *\n * a = [2, -7, 0]\n * math.not(a) // returns [false, false, true]\n *\n * See also:\n *\n * and, or, xor\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x First value to check\n * @return {boolean | Array | Matrix}\n * Returns true when input is a zero or empty value.\n */\n return typed(name, {\n number: _index.notNumber,\n Complex: function Complex(x) {\n return x.re === 0 && x.im === 0;\n },\n BigNumber: function BigNumber(x) {\n return x.isZero() || x.isNaN();\n },\n Unit: function Unit(x) {\n return x.value !== null ? this(x.value) : true;\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createNot = createNot;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createOr = void 0;\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm05.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'or';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix'];\nvar createOr = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm03 = (0, _algorithm.createAlgorithm03)({\n typed: typed\n });\n var algorithm05 = (0, _algorithm5.createAlgorithm05)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm12 = (0, _algorithm2.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm3.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm4.createAlgorithm14)({\n typed: typed\n });\n /**\n * Logical `or`. Test if at least one value is defined with a nonzero/nonempty value.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.or(x, y)\n *\n * Examples:\n *\n * math.or(2, 4) // returns true\n *\n * a = [2, 5, 0]\n * b = [0, 22, 0]\n * c = 0\n *\n * math.or(a, b) // returns [true, true, false]\n * math.or(b, c) // returns [false, true, false]\n *\n * See also:\n *\n * and, not, xor\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x First value to check\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} y Second value to check\n * @return {boolean | Array | Matrix}\n * Returns true when one of the inputs is defined with a nonzero/nonempty value.\n */\n\n return typed(name, {\n 'number, number': _index.orNumber,\n 'Complex, Complex': function ComplexComplex(x, y) {\n return x.re !== 0 || x.im !== 0 || y.re !== 0 || y.im !== 0;\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return !x.isZero() && !x.isNaN() || !y.isZero() && !y.isNaN();\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n return this(x.value || 0, y.value || 0);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm05(x, y, this);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm03(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm12(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createOr = createOr;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createXor = void 0;\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm07.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'xor';\nvar dependencies = ['typed', 'matrix', 'DenseMatrix'];\nvar createXor = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm03 = (0, _algorithm.createAlgorithm03)({\n typed: typed\n });\n var algorithm07 = (0, _algorithm2.createAlgorithm07)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm12 = (0, _algorithm3.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm4.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm5.createAlgorithm14)({\n typed: typed\n });\n /**\n * Logical `xor`. Test whether one and only one value is defined with a nonzero/nonempty value.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.xor(x, y)\n *\n * Examples:\n *\n * math.xor(2, 4) // returns false\n *\n * a = [2, 0, 0]\n * b = [2, 7, 0]\n * c = 0\n *\n * math.xor(a, b) // returns [false, true, false]\n * math.xor(a, c) // returns [true, false, false]\n *\n * See also:\n *\n * and, not, or\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x First value to check\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} y Second value to check\n * @return {boolean | Array | Matrix}\n * Returns true when one and only one input is defined with a nonzero/nonempty value.\n */\n\n return typed(name, {\n 'number, number': _index.xorNumber,\n 'Complex, Complex': function ComplexComplex(x, y) {\n return (x.re !== 0 || x.im !== 0) !== (y.re !== 0 || y.im !== 0);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return (!x.isZero() && !x.isNaN()) !== (!y.isZero() && !y.isNaN());\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n return this(x.value || 0, y.value || 0);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm07(x, y, this);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm03(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm12(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createXor = createXor;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createApply = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _IndexError = require(\"../../error/IndexError.js\");\n\nvar name = 'apply';\nvar dependencies = ['typed', 'isInteger'];\nvar createApply = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n isInteger = _ref.isInteger;\n\n /**\n * Apply a function that maps an array to a scalar\n * along a given axis of a matrix or array.\n * Returns a new matrix or array with one less dimension than the input.\n *\n * Syntax:\n *\n * math.apply(A, dim, callback)\n *\n * Where:\n *\n * - `dim: number` is a zero-based dimension over which to concatenate the matrices.\n *\n * Examples:\n *\n * const A = [[1, 2], [3, 4]]\n * const sum = math.sum\n *\n * math.apply(A, 0, sum) // returns [4, 6]\n * math.apply(A, 1, sum) // returns [3, 7]\n *\n * See also:\n *\n * map, filter, forEach\n *\n * @param {Array | Matrix} array The input Matrix\n * @param {number} dim The dimension along which the callback is applied\n * @param {Function} callback The callback function that is applied. This Function\n * should take an array or 1-d matrix as an input and\n * return a number.\n * @return {Array | Matrix} res The residual matrix with the function applied over some dimension.\n */\n return typed(name, {\n 'Array | Matrix, number | BigNumber, function': function ArrayMatrixNumberBigNumberFunction(mat, dim, callback) {\n if (!isInteger(dim)) {\n throw new TypeError('Integer number expected for dimension');\n }\n\n var size = Array.isArray(mat) ? (0, _array.arraySize)(mat) : mat.size();\n\n if (dim < 0 || dim >= size.length) {\n throw new _IndexError.IndexError(dim, size.length);\n }\n\n if ((0, _is.isMatrix)(mat)) {\n return mat.create(_apply(mat.valueOf(), dim, callback));\n } else {\n return _apply(mat, dim, callback);\n }\n }\n });\n});\n/**\n * Recursively reduce a matrix\n * @param {Array} mat\n * @param {number} dim\n * @param {Function} callback\n * @returns {Array} ret\n * @private\n */\n\nexports.createApply = createApply;\n\nfunction _apply(mat, dim, callback) {\n var i, ret, tran;\n\n if (dim <= 0) {\n if (!Array.isArray(mat[0])) {\n return callback(mat);\n } else {\n tran = _switch(mat);\n ret = [];\n\n for (i = 0; i < tran.length; i++) {\n ret[i] = _apply(tran[i], dim - 1, callback);\n }\n\n return ret;\n }\n } else {\n ret = [];\n\n for (i = 0; i < mat.length; i++) {\n ret[i] = _apply(mat[i], dim - 1, callback);\n }\n\n return ret;\n }\n}\n/**\n * Transpose a matrix\n * @param {Array} mat\n * @returns {Array} ret\n * @private\n */\n\n\nfunction _switch(mat) {\n var I = mat.length;\n var J = mat[0].length;\n var i, j;\n var ret = [];\n\n for (j = 0; j < J; j++) {\n var tmp = [];\n\n for (i = 0; i < I; i++) {\n tmp.push(mat[i][j]);\n }\n\n ret.push(tmp);\n }\n\n return ret;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createColumn = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar name = 'column';\nvar dependencies = ['typed', 'Index', 'matrix', 'range'];\nvar createColumn = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Index = _ref.Index,\n matrix = _ref.matrix,\n range = _ref.range;\n\n /**\n * Return a column from a Matrix.\n *\n * Syntax:\n *\n * math.column(value, index)\n *\n * Example:\n *\n * // get a column\n * const d = [[1, 2], [3, 4]]\n * math.column(d, 1) // returns [[2], [4]]\n *\n * See also:\n *\n * row\n *\n * @param {Array | Matrix } value An array or matrix\n * @param {number} column The index of the column\n * @return {Array | Matrix} The retrieved column\n */\n return typed(name, {\n 'Matrix, number': _column,\n 'Array, number': function ArrayNumber(value, column) {\n return _column(matrix((0, _object.clone)(value)), column).valueOf();\n }\n });\n /**\n * Retrieve a column of a matrix\n * @param {Matrix } value A matrix\n * @param {number} column The index of the column\n * @return {Matrix} The retrieved column\n */\n\n function _column(value, column) {\n // check dimensions\n if (value.size().length !== 2) {\n throw new Error('Only two dimensional matrix is supported');\n }\n\n (0, _array.validateIndex)(column, value.size()[1]);\n var rowRange = range(0, value.size()[0]);\n var index = new Index(rowRange, column);\n return value.subset(index);\n }\n});\nexports.createColumn = createColumn;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createConcat = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _IndexError = require(\"../../error/IndexError.js\");\n\nvar _DimensionError = require(\"../../error/DimensionError.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'concat';\nvar dependencies = ['typed', 'matrix', 'isInteger'];\nvar createConcat = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n isInteger = _ref.isInteger;\n\n /**\n * Concatenate two or more matrices.\n *\n * Syntax:\n *\n * math.concat(A, B, C, ...)\n * math.concat(A, B, C, ..., dim)\n *\n * Where:\n *\n * - `dim: number` is a zero-based dimension over which to concatenate the matrices.\n * By default the last dimension of the matrices.\n *\n * Examples:\n *\n * const A = [[1, 2], [5, 6]]\n * const B = [[3, 4], [7, 8]]\n *\n * math.concat(A, B) // returns [[1, 2, 3, 4], [5, 6, 7, 8]]\n * math.concat(A, B, 0) // returns [[1, 2], [5, 6], [3, 4], [7, 8]]\n * math.concat('hello', ' ', 'world') // returns 'hello world'\n *\n * See also:\n *\n * size, squeeze, subset, transpose\n *\n * @param {... Array | Matrix} args Two or more matrices\n * @return {Array | Matrix} Concatenated matrix\n */\n return typed(name, {\n // TODO: change signature to '...Array | Matrix, dim?' when supported\n '...Array | Matrix | number | BigNumber': function ArrayMatrixNumberBigNumber(args) {\n var i;\n var len = args.length;\n var dim = -1; // zero-based dimension\n\n var prevDim;\n var asMatrix = false;\n var matrices = []; // contains multi dimensional arrays\n\n for (i = 0; i < len; i++) {\n var arg = args[i]; // test whether we need to return a Matrix (if not we return an Array)\n\n if ((0, _is.isMatrix)(arg)) {\n asMatrix = true;\n }\n\n if ((0, _is.isNumber)(arg) || (0, _is.isBigNumber)(arg)) {\n if (i !== len - 1) {\n throw new Error('Dimension must be specified as last argument');\n } // last argument contains the dimension on which to concatenate\n\n\n prevDim = dim;\n dim = arg.valueOf(); // change BigNumber to number\n\n if (!isInteger(dim)) {\n throw new TypeError('Integer number expected for dimension');\n }\n\n if (dim < 0 || i > 0 && dim > prevDim) {\n // TODO: would be more clear when throwing a DimensionError here\n throw new _IndexError.IndexError(dim, prevDim + 1);\n }\n } else {\n // this is a matrix or array\n var m = (0, _object.clone)(arg).valueOf();\n var size = (0, _array.arraySize)(m);\n matrices[i] = m;\n prevDim = dim;\n dim = size.length - 1; // verify whether each of the matrices has the same number of dimensions\n\n if (i > 0 && dim !== prevDim) {\n throw new _DimensionError.DimensionError(prevDim + 1, dim + 1);\n }\n }\n }\n\n if (matrices.length === 0) {\n throw new SyntaxError('At least one matrix expected');\n }\n\n var res = matrices.shift();\n\n while (matrices.length) {\n res = _concat(res, matrices.shift(), dim, 0);\n }\n\n return asMatrix ? matrix(res) : res;\n },\n '...string': function string(args) {\n return args.join('');\n }\n });\n});\n/**\n * Recursively concatenate two matrices.\n * The contents of the matrices is not cloned.\n * @param {Array} a Multi dimensional array\n * @param {Array} b Multi dimensional array\n * @param {number} concatDim The dimension on which to concatenate (zero-based)\n * @param {number} dim The current dim (zero-based)\n * @return {Array} c The concatenated matrix\n * @private\n */\n\nexports.createConcat = createConcat;\n\nfunction _concat(a, b, concatDim, dim) {\n if (dim < concatDim) {\n // recurse into next dimension\n if (a.length !== b.length) {\n throw new _DimensionError.DimensionError(a.length, b.length);\n }\n\n var c = [];\n\n for (var i = 0; i < a.length; i++) {\n c[i] = _concat(a[i], b[i], concatDim, dim + 1);\n }\n\n return c;\n } else {\n // concatenate this dimension\n return a.concat(b);\n }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCount = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'count';\nvar dependencies = ['typed', 'size', 'prod'];\nvar createCount = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n size = _ref.size,\n prod = _ref.prod;\n\n /**\n * Count the number of elements of a matrix, array or string.\n *\n * Syntax:\n *\n * math.count(x)\n *\n * Examples:\n *\n * math.count('hello world') // returns 11\n * const A = [[1, 2, 3], [4, 5, 6]]\n * math.count(A) // returns 6\n * math.count(math.range(1,6)) // returns 5\n *\n * See also:\n *\n * size\n *\n * @param {string | Array | Matrix} x A matrix or string\n * @return {number} An integer with the elements in `x`.\n */\n return typed(name, {\n string: function string(x) {\n return x.length;\n },\n 'Matrix | Array': function MatrixArray(x) {\n return prod(size(x));\n }\n });\n});\nexports.createCount = createCount;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCross = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'cross';\nvar dependencies = ['typed', 'matrix', 'subtract', 'multiply'];\nvar createCross = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n subtract = _ref.subtract,\n multiply = _ref.multiply;\n\n /**\n * Calculate the cross product for two vectors in three dimensional space.\n * The cross product of `A = [a1, a2, a3]` and `B = [b1, b2, b3]` is defined\n * as:\n *\n * cross(A, B) = [\n * a2 * b3 - a3 * b2,\n * a3 * b1 - a1 * b3,\n * a1 * b2 - a2 * b1\n * ]\n *\n * If one of the input vectors has a dimension greater than 1, the output\n * vector will be a 1x3 (2-dimensional) matrix.\n *\n * Syntax:\n *\n * math.cross(x, y)\n *\n * Examples:\n *\n * math.cross([1, 1, 0], [0, 1, 1]) // Returns [1, -1, 1]\n * math.cross([3, -3, 1], [4, 9, 2]) // Returns [-15, -2, 39]\n * math.cross([2, 3, 4], [5, 6, 7]) // Returns [-3, 6, -3]\n * math.cross([[1, 2, 3]], [[4], [5], [6]]) // Returns [[-3, 6, -3]]\n *\n * See also:\n *\n * dot, multiply\n *\n * @param {Array | Matrix} x First vector\n * @param {Array | Matrix} y Second vector\n * @return {Array | Matrix} Returns the cross product of `x` and `y`\n */\n return typed(name, {\n 'Matrix, Matrix': function MatrixMatrix(x, y) {\n return matrix(_cross(x.toArray(), y.toArray()));\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n return matrix(_cross(x.toArray(), y));\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n return matrix(_cross(x, y.toArray()));\n },\n 'Array, Array': _cross\n });\n /**\n * Calculate the cross product for two arrays\n * @param {Array} x First vector\n * @param {Array} y Second vector\n * @returns {Array} Returns the cross product of x and y\n * @private\n */\n\n function _cross(x, y) {\n var highestDimension = Math.max((0, _array.arraySize)(x).length, (0, _array.arraySize)(y).length);\n x = (0, _array.squeeze)(x);\n y = (0, _array.squeeze)(y);\n var xSize = (0, _array.arraySize)(x);\n var ySize = (0, _array.arraySize)(y);\n\n if (xSize.length !== 1 || ySize.length !== 1 || xSize[0] !== 3 || ySize[0] !== 3) {\n throw new RangeError('Vectors with length 3 expected ' + '(Size A = [' + xSize.join(', ') + '], B = [' + ySize.join(', ') + '])');\n }\n\n var product = [subtract(multiply(x[1], y[2]), multiply(x[2], y[1])), subtract(multiply(x[2], y[0]), multiply(x[0], y[2])), subtract(multiply(x[0], y[1]), multiply(x[1], y[0]))];\n\n if (highestDimension > 1) {\n return [product];\n } else {\n return product;\n }\n }\n});\nexports.createCross = createCross;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCtranspose = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'ctranspose';\nvar dependencies = ['typed', 'transpose', 'conj'];\nvar createCtranspose = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n transpose = _ref.transpose,\n conj = _ref.conj;\n\n /**\n * Transpose and complex conjugate a matrix. All values of the matrix are\n * reflected over its main diagonal and then the complex conjugate is\n * taken. This is equivalent to complex conjugation for scalars and\n * vectors.\n *\n * Syntax:\n *\n * math.ctranspose(x)\n *\n * Examples:\n *\n * const A = [[1, 2, 3], [4, 5, math.complex(6,7)]]\n * math.ctranspose(A) // returns [[1, 4], [2, 5], [3, {re:6,im:7}]]\n *\n * See also:\n *\n * transpose, diag, inv, subset, squeeze\n *\n * @param {Array | Matrix} x Matrix to be ctransposed\n * @return {Array | Matrix} The ctransposed matrix\n */\n return typed(name, {\n any: function any(x) {\n return conj(transpose(x));\n }\n });\n});\nexports.createCtranspose = createCtranspose;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDet = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'det';\nvar dependencies = ['typed', 'matrix', 'subtract', 'multiply', 'divideScalar', 'isZero', 'unaryMinus'];\nvar createDet = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n subtract = _ref.subtract,\n multiply = _ref.multiply,\n divideScalar = _ref.divideScalar,\n isZero = _ref.isZero,\n unaryMinus = _ref.unaryMinus;\n\n /**\n * Calculate the determinant of a matrix.\n *\n * Syntax:\n *\n * math.det(x)\n *\n * Examples:\n *\n * math.det([[1, 2], [3, 4]]) // returns -2\n *\n * const A = [\n * [-2, 2, 3],\n * [-1, 1, 3],\n * [2, 0, -1]\n * ]\n * math.det(A) // returns 6\n *\n * See also:\n *\n * inv\n *\n * @param {Array | Matrix} x A matrix\n * @return {number} The determinant of `x`\n */\n return typed(name, {\n any: function any(x) {\n return (0, _object.clone)(x);\n },\n 'Array | Matrix': function det(x) {\n var size;\n\n if ((0, _is.isMatrix)(x)) {\n size = x.size();\n } else if (Array.isArray(x)) {\n x = matrix(x);\n size = x.size();\n } else {\n // a scalar\n size = [];\n }\n\n switch (size.length) {\n case 0:\n // scalar\n return (0, _object.clone)(x);\n\n case 1:\n // vector\n if (size[0] === 1) {\n return (0, _object.clone)(x.valueOf()[0]);\n } else {\n throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n\n case 2:\n {\n // two dimensional array\n var rows = size[0];\n var cols = size[1];\n\n if (rows === cols) {\n return _det(x.clone().valueOf(), rows, cols);\n } else {\n throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n }\n\n default:\n // multi dimensional array\n throw new RangeError('Matrix must be two dimensional ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n }\n });\n /**\n * Calculate the determinant of a matrix\n * @param {Array[]} matrix A square, two dimensional matrix\n * @param {number} rows Number of rows of the matrix (zero-based)\n * @param {number} cols Number of columns of the matrix (zero-based)\n * @returns {number} det\n * @private\n */\n\n function _det(matrix, rows, cols) {\n if (rows === 1) {\n // this is a 1 x 1 matrix\n return (0, _object.clone)(matrix[0][0]);\n } else if (rows === 2) {\n // this is a 2 x 2 matrix\n // the determinant of [a11,a12;a21,a22] is det = a11*a22-a21*a12\n return subtract(multiply(matrix[0][0], matrix[1][1]), multiply(matrix[1][0], matrix[0][1]));\n } else {\n // Bareiss algorithm\n // this algorithm have same complexity as LUP decomposition (O(n^3))\n // but it preserve precision of floating point more relative to the LUP decomposition\n var negated = false;\n var rowIndices = new Array(rows).fill(0).map(function (_, i) {\n return i;\n }); // matrix index of row i\n\n for (var k = 0; k < rows; k++) {\n var k_ = rowIndices[k];\n\n if (isZero(matrix[k_][k])) {\n var _k = void 0;\n\n for (_k = k + 1; _k < rows; _k++) {\n if (!isZero(matrix[rowIndices[_k]][k])) {\n k_ = rowIndices[_k];\n rowIndices[_k] = rowIndices[k];\n rowIndices[k] = k_;\n negated = !negated;\n break;\n }\n }\n\n if (_k === rows) return matrix[k_][k]; // some zero of the type\n }\n\n var piv = matrix[k_][k];\n var piv_ = k === 0 ? 1 : matrix[rowIndices[k - 1]][k - 1];\n\n for (var i = k + 1; i < rows; i++) {\n var i_ = rowIndices[i];\n\n for (var j = k + 1; j < rows; j++) {\n matrix[i_][j] = divideScalar(subtract(multiply(matrix[i_][j], piv), multiply(matrix[i_][k], matrix[k_][j])), piv_);\n }\n }\n }\n\n var det = matrix[rowIndices[rows - 1]][rows - 1];\n return negated ? unaryMinus(det) : det;\n }\n }\n});\nexports.createDet = createDet;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDiag = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'diag';\nvar dependencies = ['typed', 'matrix', 'DenseMatrix', 'SparseMatrix'];\nvar createDiag = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n DenseMatrix = _ref.DenseMatrix,\n SparseMatrix = _ref.SparseMatrix;\n\n /**\n * Create a diagonal matrix or retrieve the diagonal of a matrix\n *\n * When `x` is a vector, a matrix with vector `x` on the diagonal will be returned.\n * When `x` is a two dimensional matrix, the matrixes `k`th diagonal will be returned as vector.\n * When k is positive, the values are placed on the super diagonal.\n * When k is negative, the values are placed on the sub diagonal.\n *\n * Syntax:\n *\n * math.diag(X)\n * math.diag(X, format)\n * math.diag(X, k)\n * math.diag(X, k, format)\n *\n * Examples:\n *\n * // create a diagonal matrix\n * math.diag([1, 2, 3]) // returns [[1, 0, 0], [0, 2, 0], [0, 0, 3]]\n * math.diag([1, 2, 3], 1) // returns [[0, 1, 0, 0], [0, 0, 2, 0], [0, 0, 0, 3]]\n * math.diag([1, 2, 3], -1) // returns [[0, 0, 0], [1, 0, 0], [0, 2, 0], [0, 0, 3]]\n *\n * // retrieve the diagonal from a matrix\n * const a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]\n * math.diag(a) // returns [1, 5, 9]\n *\n * See also:\n *\n * ones, zeros, identity\n *\n * @param {Matrix | Array} x A two dimensional matrix or a vector\n * @param {number | BigNumber} [k=0] The diagonal where the vector will be filled\n * in or retrieved.\n * @param {string} [format='dense'] The matrix storage format.\n *\n * @returns {Matrix | Array} Diagonal matrix from input vector, or diagonal from input matrix.\n */\n return typed(name, {\n // FIXME: simplify this huge amount of signatures as soon as typed-function supports optional arguments\n Array: function Array(x) {\n return _diag(x, 0, (0, _array.arraySize)(x), null);\n },\n 'Array, number': function ArrayNumber(x, k) {\n return _diag(x, k, (0, _array.arraySize)(x), null);\n },\n 'Array, BigNumber': function ArrayBigNumber(x, k) {\n return _diag(x, k.toNumber(), (0, _array.arraySize)(x), null);\n },\n 'Array, string': function ArrayString(x, format) {\n return _diag(x, 0, (0, _array.arraySize)(x), format);\n },\n 'Array, number, string': function ArrayNumberString(x, k, format) {\n return _diag(x, k, (0, _array.arraySize)(x), format);\n },\n 'Array, BigNumber, string': function ArrayBigNumberString(x, k, format) {\n return _diag(x, k.toNumber(), (0, _array.arraySize)(x), format);\n },\n Matrix: function Matrix(x) {\n return _diag(x, 0, x.size(), x.storage());\n },\n 'Matrix, number': function MatrixNumber(x, k) {\n return _diag(x, k, x.size(), x.storage());\n },\n 'Matrix, BigNumber': function MatrixBigNumber(x, k) {\n return _diag(x, k.toNumber(), x.size(), x.storage());\n },\n 'Matrix, string': function MatrixString(x, format) {\n return _diag(x, 0, x.size(), format);\n },\n 'Matrix, number, string': function MatrixNumberString(x, k, format) {\n return _diag(x, k, x.size(), format);\n },\n 'Matrix, BigNumber, string': function MatrixBigNumberString(x, k, format) {\n return _diag(x, k.toNumber(), x.size(), format);\n }\n });\n /**\n * Creeate diagonal matrix from a vector or vice versa\n * @param {Array | Matrix} x\n * @param {number} k\n * @param {string} format Storage format for matrix. If null,\n * an Array is returned\n * @returns {Array | Matrix}\n * @private\n */\n\n function _diag(x, k, size, format) {\n if (!(0, _number.isInteger)(k)) {\n throw new TypeError('Second parameter in function diag must be an integer');\n }\n\n var kSuper = k > 0 ? k : 0;\n var kSub = k < 0 ? -k : 0; // check dimensions\n\n switch (size.length) {\n case 1:\n return _createDiagonalMatrix(x, k, format, size[0], kSub, kSuper);\n\n case 2:\n return _getDiagonal(x, k, format, size, kSub, kSuper);\n }\n\n throw new RangeError('Matrix for function diag must be 2 dimensional');\n }\n\n function _createDiagonalMatrix(x, k, format, l, kSub, kSuper) {\n // matrix size\n var ms = [l + kSub, l + kSuper];\n\n if (format && format !== 'sparse' && format !== 'dense') {\n throw new TypeError(\"Unknown matrix type \".concat(format, \"\\\"\"));\n } // create diagonal matrix\n\n\n var m = format === 'sparse' ? SparseMatrix.diagonal(ms, x, k) : DenseMatrix.diagonal(ms, x, k); // check we need to return a matrix\n\n return format !== null ? m : m.valueOf();\n }\n\n function _getDiagonal(x, k, format, s, kSub, kSuper) {\n // check x is a Matrix\n if ((0, _is.isMatrix)(x)) {\n // get diagonal matrix\n var dm = x.diagonal(k); // check we need to return a matrix\n\n if (format !== null) {\n // check we need to change matrix format\n if (format !== dm.storage()) {\n return matrix(dm, format);\n }\n\n return dm;\n }\n\n return dm.valueOf();\n } // vector size\n\n\n var n = Math.min(s[0] - kSub, s[1] - kSuper); // diagonal values\n\n var vector = []; // loop diagonal\n\n for (var i = 0; i < n; i++) {\n vector[i] = x[i + kSub][i + kSuper];\n } // check we need to return a matrix\n\n\n return format !== null ? matrix(vector) : vector;\n }\n});\nexports.createDiag = createDiag;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDiff = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar name = 'diff';\nvar dependencies = ['typed', 'matrix', 'subtract', 'number'];\nvar createDiff = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n subtract = _ref.subtract,\n number = _ref.number;\n\n /**\n * Create a new matrix or array of the difference between elements of the given array\n * The optional dim parameter lets you specify the dimension to evaluate the difference of\n * If no dimension parameter is passed it is assumed as dimension 0\n *\n * Dimension is zero-based in javascript and one-based in the parser and can be a number or bignumber\n * Arrays must be 'rectangular' meaning arrays like [1, 2]\n * If something is passed as a matrix it will be returned as a matrix but other than that all matrices are converted to arrays\n *\n * Syntax:\n *\n * math.diff(arr)\n * math.diff(arr, dim)\n *\n * Examples:\n *\n * const arr = [1, 2, 4, 7, 0]\n * math.diff(arr) // returns [1, 2, 3, -7] (no dimension passed so 0 is assumed)\n * math.diff(math.matrix(arr)) // returns math.matrix([1, 2, 3, -7])\n *\n * const arr = [[1, 2, 3, 4, 5], [1, 2, 3, 4, 5], [9, 8, 7, 6, 4]]\n * math.diff(arr) // returns [[0, 0, 0, 0, 0], [8, 6, 4, 2, -1]]\n * math.diff(arr, 0) // returns [[0, 0, 0, 0, 0], [8, 6, 4, 2, -1]]\n * math.diff(arr, 1) // returns [[1, 1, 1, 1], [1, 1, 1, 1], [-1, -1, -1, -2]]\n * math.diff(arr, math.bignumber(1)) // returns [[1, 1, 1, 1], [1, 1, 1, 1], [-1, -1, -1, -2]]\n *\n * math.diff(arr, 2) // throws RangeError as arr is 2 dimensional not 3\n * math.diff(arr, -1) // throws RangeError as negative dimensions are not allowed\n *\n * // These will all produce the same result\n * math.diff([[1, 2], [3, 4]])\n * math.diff([math.matrix([1, 2]), math.matrix([3, 4])])\n * math.diff([[1, 2], math.matrix([3, 4])])\n * math.diff([math.matrix([1, 2]), [3, 4]])\n * // They do not produce the same result as math.diff(math.matrix([[1, 2], [3, 4]])) as this returns a matrix\n *\n * See Also:\n *\n * sum\n * subtract\n * partitionSelect\n *\n * @param {Array | Matrix} arr An array or matrix\n * @param {number} dim Dimension\n * @return {Array | Matrix} Difference between array elements in given dimension\n */\n return typed(name, {\n 'Array | Matrix': function ArrayMatrix(arr) {\n // No dimension specified => assume dimension 0\n if ((0, _is.isMatrix)(arr)) {\n return matrix(_diff(arr.toArray()));\n } else {\n return _diff(arr);\n }\n },\n 'Array | Matrix, number': function ArrayMatrixNumber(arr, dim) {\n if (!(0, _number.isInteger)(dim)) throw new RangeError('Dimension must be a whole number');\n\n if ((0, _is.isMatrix)(arr)) {\n return matrix(_recursive(arr.toArray(), dim));\n } else {\n return _recursive(arr, dim);\n }\n },\n 'Array | Matrix, BigNumber': function ArrayMatrixBigNumber(arr, dim) {\n return this(arr, number(dim));\n }\n });\n /**\n * Recursively find the correct dimension in the array/matrix\n * Then Apply _diff to that dimension\n *\n * @param {Array} arr The array\n * @param {number} dim Dimension\n * @return {Array} resulting array\n */\n\n function _recursive(arr, dim) {\n if ((0, _is.isMatrix)(arr)) {\n arr = arr.toArray(); // Makes sure arrays like [ matrix([0, 1]), matrix([1, 0]) ] are processed properly\n }\n\n if (!Array.isArray(arr)) {\n throw RangeError('Array/Matrix does not have that many dimensions');\n }\n\n if (dim > 0) {\n var result = [];\n arr.forEach(function (element) {\n result.push(_recursive(element, dim - 1));\n });\n return result;\n } else if (dim === 0) {\n return _diff(arr);\n } else {\n throw RangeError('Cannot have negative dimension');\n }\n }\n /**\n * Difference between elements in the array\n *\n * @param {Array} arr An array\n * @return {Array} resulting array\n */\n\n\n function _diff(arr) {\n var result = [];\n var size = arr.length;\n\n if (size < 2) {\n return arr;\n }\n\n for (var i = 1; i < size; i++) {\n result.push(_ElementDiff(arr[i - 1], arr[i]));\n }\n\n return result;\n }\n /**\n * Difference between 2 objects\n *\n * @param {Object} obj1 First object\n * @param {Object} obj2 Second object\n * @return {Array} resulting array\n */\n\n\n function _ElementDiff(obj1, obj2) {\n // Convert matrices to arrays\n if ((0, _is.isMatrix)(obj1)) obj1 = obj1.toArray();\n if ((0, _is.isMatrix)(obj2)) obj2 = obj2.toArray();\n var obj1IsArray = Array.isArray(obj1);\n var obj2IsArray = Array.isArray(obj2);\n\n if (obj1IsArray && obj2IsArray) {\n return _ArrayDiff(obj1, obj2);\n }\n\n if (!obj1IsArray && !obj2IsArray) {\n return subtract(obj2, obj1); // Difference is (second - first) NOT (first - second)\n }\n\n throw TypeError('Cannot calculate difference between 1 array and 1 non-array');\n }\n /**\n * Difference of elements in 2 arrays\n *\n * @param {Array} arr1 Array 1\n * @param {Array} arr2 Array 2\n * @return {Array} resulting array\n */\n\n\n function _ArrayDiff(arr1, arr2) {\n if (arr1.length !== arr2.length) {\n throw RangeError('Not all sub-arrays have the same length');\n }\n\n var result = [];\n var size = arr1.length;\n\n for (var i = 0; i < size; i++) {\n result.push(_ElementDiff(arr1[i], arr2[i]));\n }\n\n return result;\n }\n});\nexports.createDiff = createDiff;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDot = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar name = 'dot';\nvar dependencies = ['typed', 'addScalar', 'multiplyScalar', 'conj', 'size'];\nvar createDot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n addScalar = _ref.addScalar,\n multiplyScalar = _ref.multiplyScalar,\n conj = _ref.conj,\n size = _ref.size;\n\n /**\n * Calculate the dot product of two vectors. The dot product of\n * `A = [a1, a2, ..., an]` and `B = [b1, b2, ..., bn]` is defined as:\n *\n * dot(A, B) = conj(a1) * b1 + conj(a2) * b2 + ... + conj(an) * bn\n *\n * Syntax:\n *\n * math.dot(x, y)\n *\n * Examples:\n *\n * math.dot([2, 4, 1], [2, 2, 3]) // returns number 15\n * math.multiply([2, 4, 1], [2, 2, 3]) // returns number 15\n *\n * See also:\n *\n * multiply, cross\n *\n * @param {Array | Matrix} x First vector\n * @param {Array | Matrix} y Second vector\n * @return {number} Returns the dot product of `x` and `y`\n */\n return typed(name, {\n 'Array | DenseMatrix, Array | DenseMatrix': _denseDot,\n 'SparseMatrix, SparseMatrix': _sparseDot\n });\n\n function _validateDim(x, y) {\n var xSize = _size(x);\n\n var ySize = _size(y);\n\n var xLen, yLen;\n\n if (xSize.length === 1) {\n xLen = xSize[0];\n } else if (xSize.length === 2 && xSize[1] === 1) {\n xLen = xSize[0];\n } else {\n throw new RangeError('Expected a column vector, instead got a matrix of size (' + xSize.join(', ') + ')');\n }\n\n if (ySize.length === 1) {\n yLen = ySize[0];\n } else if (ySize.length === 2 && ySize[1] === 1) {\n yLen = ySize[0];\n } else {\n throw new RangeError('Expected a column vector, instead got a matrix of size (' + ySize.join(', ') + ')');\n }\n\n if (xLen !== yLen) throw new RangeError('Vectors must have equal length (' + xLen + ' != ' + yLen + ')');\n if (xLen === 0) throw new RangeError('Cannot calculate the dot product of empty vectors');\n return xLen;\n }\n\n function _denseDot(a, b) {\n var N = _validateDim(a, b);\n\n var adata = (0, _is.isMatrix)(a) ? a._data : a;\n var adt = (0, _is.isMatrix)(a) ? a._datatype : undefined;\n var bdata = (0, _is.isMatrix)(b) ? b._data : b;\n var bdt = (0, _is.isMatrix)(b) ? b._datatype : undefined; // are these 2-dimensional column vectors? (as opposed to 1-dimensional vectors)\n\n var aIsColumn = _size(a).length === 2;\n var bIsColumn = _size(b).length === 2;\n var add = addScalar;\n var mul = multiplyScalar; // process data types\n\n if (adt && bdt && adt === bdt && typeof adt === 'string') {\n var dt = adt; // find signatures that matches (dt, dt)\n\n add = typed.find(addScalar, [dt, dt]);\n mul = typed.find(multiplyScalar, [dt, dt]);\n } // both vectors 1-dimensional\n\n\n if (!aIsColumn && !bIsColumn) {\n var c = mul(conj(adata[0]), bdata[0]);\n\n for (var i = 1; i < N; i++) {\n c = add(c, mul(conj(adata[i]), bdata[i]));\n }\n\n return c;\n } // a is 1-dim, b is column\n\n\n if (!aIsColumn && bIsColumn) {\n var _c = mul(conj(adata[0]), bdata[0][0]);\n\n for (var _i = 1; _i < N; _i++) {\n _c = add(_c, mul(conj(adata[_i]), bdata[_i][0]));\n }\n\n return _c;\n } // a is column, b is 1-dim\n\n\n if (aIsColumn && !bIsColumn) {\n var _c2 = mul(conj(adata[0][0]), bdata[0]);\n\n for (var _i2 = 1; _i2 < N; _i2++) {\n _c2 = add(_c2, mul(conj(adata[_i2][0]), bdata[_i2]));\n }\n\n return _c2;\n } // both vectors are column\n\n\n if (aIsColumn && bIsColumn) {\n var _c3 = mul(conj(adata[0][0]), bdata[0][0]);\n\n for (var _i3 = 1; _i3 < N; _i3++) {\n _c3 = add(_c3, mul(conj(adata[_i3][0]), bdata[_i3][0]));\n }\n\n return _c3;\n }\n }\n\n function _sparseDot(x, y) {\n _validateDim(x, y);\n\n var xindex = x._index;\n var xvalues = x._values;\n var yindex = y._index;\n var yvalues = y._values; // TODO optimize add & mul using datatype\n\n var c = 0;\n var add = addScalar;\n var mul = multiplyScalar;\n var i = 0;\n var j = 0;\n\n while (i < xindex.length && j < yindex.length) {\n var I = xindex[i];\n var J = yindex[j];\n\n if (I < J) {\n i++;\n continue;\n }\n\n if (I > J) {\n j++;\n continue;\n }\n\n if (I === J) {\n c = add(c, mul(xvalues[i], yvalues[j]));\n i++;\n j++;\n }\n }\n\n return c;\n } // TODO remove this once #1771 is fixed\n\n\n function _size(x) {\n return (0, _is.isMatrix)(x) ? x.size() : size(x);\n }\n});\nexports.createDot = createDot;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createEigs = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _complexEigs = require(\"./eigs/complexEigs.js\");\n\nvar _realSymetric = require(\"./eigs/realSymetric.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar name = 'eigs'; // The absolute state of math.js's dependency system:\n\nvar dependencies = ['config', 'typed', 'matrix', 'addScalar', 'equal', 'subtract', 'abs', 'atan', 'cos', 'sin', 'multiplyScalar', 'divideScalar', 'inv', 'bignumber', 'multiply', 'add', 'larger', 'column', 'flatten', 'number', 'complex', 'sqrt', 'diag', 'qr', 'usolve', 'usolveAll', 'im', 're', 'smaller', 'matrixFromColumns', 'dot'];\nvar createEigs = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var config = _ref.config,\n typed = _ref.typed,\n matrix = _ref.matrix,\n addScalar = _ref.addScalar,\n subtract = _ref.subtract,\n equal = _ref.equal,\n abs = _ref.abs,\n atan = _ref.atan,\n cos = _ref.cos,\n sin = _ref.sin,\n multiplyScalar = _ref.multiplyScalar,\n divideScalar = _ref.divideScalar,\n inv = _ref.inv,\n bignumber = _ref.bignumber,\n multiply = _ref.multiply,\n add = _ref.add,\n larger = _ref.larger,\n column = _ref.column,\n flatten = _ref.flatten,\n number = _ref.number,\n complex = _ref.complex,\n sqrt = _ref.sqrt,\n diag = _ref.diag,\n qr = _ref.qr,\n usolve = _ref.usolve,\n usolveAll = _ref.usolveAll,\n im = _ref.im,\n re = _ref.re,\n smaller = _ref.smaller,\n matrixFromColumns = _ref.matrixFromColumns,\n dot = _ref.dot;\n var doRealSymetric = (0, _realSymetric.createRealSymmetric)({\n config: config,\n addScalar: addScalar,\n subtract: subtract,\n column: column,\n flatten: flatten,\n equal: equal,\n abs: abs,\n atan: atan,\n cos: cos,\n sin: sin,\n multiplyScalar: multiplyScalar,\n inv: inv,\n bignumber: bignumber,\n complex: complex,\n multiply: multiply,\n add: add\n });\n var doComplexEigs = (0, _complexEigs.createComplexEigs)({\n config: config,\n addScalar: addScalar,\n subtract: subtract,\n multiply: multiply,\n multiplyScalar: multiplyScalar,\n flatten: flatten,\n divideScalar: divideScalar,\n sqrt: sqrt,\n abs: abs,\n bignumber: bignumber,\n diag: diag,\n qr: qr,\n inv: inv,\n usolve: usolve,\n usolveAll: usolveAll,\n equal: equal,\n complex: complex,\n larger: larger,\n smaller: smaller,\n matrixFromColumns: matrixFromColumns,\n dot: dot\n });\n /**\n * Compute eigenvalues and eigenvectors of a matrix. The eigenvalues are sorted by their absolute value, ascending.\n * An eigenvalue with multiplicity k will be listed k times. The eigenvectors are returned as columns of a matrix –\n * the eigenvector that belongs to the j-th eigenvalue in the list (eg. `values[j]`) is the j-th column (eg. `column(vectors, j)`).\n * If the algorithm fails to converge, it will throw an error – in that case, however, you may still find useful information\n * in `err.values` and `err.vectors`.\n *\n * Syntax:\n *\n * math.eigs(x, [prec])\n *\n * Examples:\n *\n * const { eigs, multiply, column, transpose } = math\n * const H = [[5, 2.3], [2.3, 1]]\n * const ans = eigs(H) // returns {values: [E1,E2...sorted], vectors: [v1,v2.... corresponding vectors as columns]}\n * const E = ans.values\n * const U = ans.vectors\n * multiply(H, column(U, 0)) // returns multiply(E[0], column(U, 0))\n * const UTxHxU = multiply(transpose(U), H, U) // diagonalizes H\n * E[0] == UTxHxU[0][0] // returns true\n *\n * See also:\n *\n * inv\n *\n * @param {Array | Matrix} x Matrix to be diagonalized\n *\n * @param {number | BigNumber} [prec] Precision, default value: 1e-15\n * @return {{values: Array|Matrix, vectors: Array|Matrix}} Object containing an array of eigenvalues and a matrix with eigenvectors as columns.\n *\n */\n\n return typed('eigs', {\n Array: function Array(x) {\n var mat = matrix(x);\n return computeValuesAndVectors(mat);\n },\n 'Array, number|BigNumber': function ArrayNumberBigNumber(x, prec) {\n var mat = matrix(x);\n return computeValuesAndVectors(mat, prec);\n },\n Matrix: function Matrix(mat) {\n var _computeValuesAndVect = computeValuesAndVectors(mat),\n values = _computeValuesAndVect.values,\n vectors = _computeValuesAndVect.vectors;\n\n return {\n values: matrix(values),\n vectors: matrix(vectors)\n };\n },\n 'Matrix, number|BigNumber': function MatrixNumberBigNumber(mat, prec) {\n var _computeValuesAndVect2 = computeValuesAndVectors(mat, prec),\n values = _computeValuesAndVect2.values,\n vectors = _computeValuesAndVect2.vectors;\n\n return {\n values: matrix(values),\n vectors: matrix(vectors)\n };\n }\n });\n\n function computeValuesAndVectors(mat, prec) {\n if (prec === undefined) {\n prec = config.epsilon;\n }\n\n var size = mat.size();\n\n if (size.length !== 2 || size[0] !== size[1]) {\n throw new RangeError('Matrix must be square (size: ' + (0, _string.format)(size) + ')');\n }\n\n var arr = mat.toArray();\n var N = size[0];\n\n if (isReal(arr, N, prec)) {\n coerceReal(arr, N);\n\n if (isSymmetric(arr, N, prec)) {\n var _type = coerceTypes(mat, arr, N);\n\n return doRealSymetric(arr, N, prec, _type);\n }\n }\n\n var type = coerceTypes(mat, arr, N);\n return doComplexEigs(arr, N, prec, type);\n }\n /** @return {boolean} */\n\n\n function isSymmetric(arr, N, prec) {\n for (var i = 0; i < N; i++) {\n for (var j = i; j < N; j++) {\n // TODO proper comparison of bignum and frac\n if (larger(bignumber(abs(subtract(arr[i][j], arr[j][i]))), prec)) {\n return false;\n }\n }\n }\n\n return true;\n }\n /** @return {boolean} */\n\n\n function isReal(arr, N, prec) {\n for (var i = 0; i < N; i++) {\n for (var j = 0; j < N; j++) {\n // TODO proper comparison of bignum and frac\n if (larger(bignumber(abs(im(arr[i][j]))), prec)) {\n return false;\n }\n }\n }\n\n return true;\n }\n\n function coerceReal(arr, N) {\n for (var i = 0; i < N; i++) {\n for (var j = 0; j < N; j++) {\n arr[i][j] = re(arr[i][j]);\n }\n }\n }\n /** @return {'number' | 'BigNumber' | 'Complex'} */\n\n\n function coerceTypes(mat, arr, N) {\n /** @type {string} */\n var type = mat.datatype();\n\n if (type === 'number' || type === 'BigNumber' || type === 'Complex') {\n return type;\n }\n\n var hasNumber = false;\n var hasBig = false;\n var hasComplex = false;\n\n for (var i = 0; i < N; i++) {\n for (var j = 0; j < N; j++) {\n var el = arr[i][j];\n\n if ((0, _is.isNumber)(el) || (0, _is.isFraction)(el)) {\n hasNumber = true;\n } else if ((0, _is.isBigNumber)(el)) {\n hasBig = true;\n } else if ((0, _is.isComplex)(el)) {\n hasComplex = true;\n } else {\n throw TypeError('Unsupported type in Matrix: ' + (0, _is.typeOf)(el));\n }\n }\n }\n\n if (hasBig && hasComplex) {\n console.warn('Complex BigNumbers not supported, this operation will lose precission.');\n }\n\n if (hasComplex) {\n for (var _i = 0; _i < N; _i++) {\n for (var _j = 0; _j < N; _j++) {\n arr[_i][_j] = complex(arr[_i][_j]);\n }\n }\n\n return 'Complex';\n }\n\n if (hasBig) {\n for (var _i2 = 0; _i2 < N; _i2++) {\n for (var _j2 = 0; _j2 < N; _j2++) {\n arr[_i2][_j2] = bignumber(arr[_i2][_j2]);\n }\n }\n\n return 'BigNumber';\n }\n\n if (hasNumber) {\n for (var _i3 = 0; _i3 < N; _i3++) {\n for (var _j3 = 0; _j3 < N; _j3++) {\n arr[_i3][_j3] = number(arr[_i3][_j3]);\n }\n }\n\n return 'number';\n } else {\n throw TypeError('Matrix contains unsupported types only.');\n }\n }\n});\nexports.createEigs = createEigs;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createComplexEigs = createComplexEigs;\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _object = require(\"../../../utils/object.js\");\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { 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 = it.call(o); }, 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\nfunction createComplexEigs(_ref) {\n var addScalar = _ref.addScalar,\n subtract = _ref.subtract,\n flatten = _ref.flatten,\n multiply = _ref.multiply,\n multiplyScalar = _ref.multiplyScalar,\n divideScalar = _ref.divideScalar,\n sqrt = _ref.sqrt,\n abs = _ref.abs,\n bignumber = _ref.bignumber,\n diag = _ref.diag,\n inv = _ref.inv,\n qr = _ref.qr,\n usolve = _ref.usolve,\n usolveAll = _ref.usolveAll,\n equal = _ref.equal,\n complex = _ref.complex,\n larger = _ref.larger,\n smaller = _ref.smaller,\n matrixFromColumns = _ref.matrixFromColumns,\n dot = _ref.dot;\n\n /**\n * @param {number[][]} arr the matrix to find eigenvalues of\n * @param {number} N size of the matrix\n * @param {number|BigNumber} prec precision, anything lower will be considered zero\n * @param {'number'|'BigNumber'|'Complex'} type\n * @param {boolean} findVectors should we find eigenvectors?\n *\n * @returns {{ values: number[], vectors: number[][] }}\n */\n function complexEigs(arr, N, prec, type, findVectors) {\n if (findVectors === undefined) {\n findVectors = true;\n } // TODO check if any row/col are zero except the diagonal\n // make sure corresponding rows and columns have similar magnitude\n // important because of numerical stability\n // MODIFIES arr by side effect!\n\n\n var R = balance(arr, N, prec, type, findVectors); // R is the row transformation matrix\n // arr = A' = R A R⁻¹, A is the original matrix\n // (if findVectors is false, R is undefined)\n // (And so to return to original matrix: A = R⁻¹ arr R)\n // TODO if magnitudes of elements vary over many orders,\n // move greatest elements to the top left corner\n // using similarity transformations, reduce the matrix\n // to Hessenberg form (upper triangular plus one subdiagonal row)\n // updates the transformation matrix R with new row operationsq\n // MODIFIES arr by side effect!\n\n reduceToHessenberg(arr, N, prec, type, findVectors, R); // still true that original A = R⁻¹ arr R)\n // find eigenvalues\n\n var _iterateUntilTriangul = iterateUntilTriangular(arr, N, prec, type, findVectors),\n values = _iterateUntilTriangul.values,\n C = _iterateUntilTriangul.C; // values is the list of eigenvalues, C is the column\n // transformation matrix that transforms arr, the hessenberg\n // matrix, to upper triangular\n // (So U = C⁻¹ arr C and the relationship between current arr\n // and original A is unchanged.)\n\n\n var vectors;\n\n if (findVectors) {\n vectors = findEigenvectors(arr, N, C, R, values, prec, type);\n vectors = matrixFromColumns.apply(void 0, (0, _toConsumableArray2.default)(vectors));\n }\n\n return {\n values: values,\n vectors: vectors\n };\n }\n /**\n * @param {number[][]} arr\n * @param {number} N\n * @param {number} prec\n * @param {'number'|'BigNumber'|'Complex'} type\n * @returns {number[][]}\n */\n\n\n function balance(arr, N, prec, type, findVectors) {\n var big = type === 'BigNumber';\n var cplx = type === 'Complex';\n var realzero = big ? bignumber(0) : 0;\n var one = big ? bignumber(1) : cplx ? complex(1) : 1;\n var realone = big ? bignumber(1) : 1; // base of the floating-point arithmetic\n\n var radix = big ? bignumber(10) : 2;\n var radixSq = multiplyScalar(radix, radix); // the diagonal transformation matrix R\n\n var Rdiag;\n\n if (findVectors) {\n Rdiag = Array(N).fill(one);\n } // this isn't the only time we loop thru the matrix...\n\n\n var last = false;\n\n while (!last) {\n // ...haha I'm joking! unless...\n last = true;\n\n for (var i = 0; i < N; i++) {\n // compute the taxicab norm of i-th column and row\n // TODO optimize for complex numbers\n var colNorm = realzero;\n var rowNorm = realzero;\n\n for (var j = 0; j < N; j++) {\n if (i === j) continue;\n var c = abs(arr[i][j]); // should be real\n\n colNorm = addScalar(colNorm, c);\n rowNorm = addScalar(rowNorm, c);\n }\n\n if (!equal(colNorm, 0) && !equal(rowNorm, 0)) {\n // find integer power closest to balancing the matrix\n // (we want to scale only by integer powers of radix,\n // so that we don't lose any precision due to round-off)\n var f = realone;\n var _c = colNorm;\n var rowDivRadix = divideScalar(rowNorm, radix);\n var rowMulRadix = multiplyScalar(rowNorm, radix);\n\n while (smaller(_c, rowDivRadix)) {\n _c = multiplyScalar(_c, radixSq);\n f = multiplyScalar(f, radix);\n }\n\n while (larger(_c, rowMulRadix)) {\n _c = divideScalar(_c, radixSq);\n f = divideScalar(f, radix);\n } // check whether balancing is needed\n // condition = (c + rowNorm) / f < 0.95 * (colNorm + rowNorm)\n\n\n var condition = smaller(divideScalar(addScalar(_c, rowNorm), f), multiplyScalar(addScalar(colNorm, rowNorm), 0.95)); // apply balancing similarity transformation\n\n if (condition) {\n // we should loop once again to check whether\n // another rebalancing is needed\n last = false;\n var g = divideScalar(1, f);\n\n for (var _j = 0; _j < N; _j++) {\n if (i === _j) {\n continue;\n }\n\n arr[i][_j] = multiplyScalar(arr[i][_j], f);\n arr[_j][i] = multiplyScalar(arr[_j][i], g);\n } // keep track of transformations\n\n\n if (findVectors) {\n Rdiag[i] = multiplyScalar(Rdiag[i], f);\n }\n }\n }\n }\n } // return the diagonal row transformation matrix\n\n\n return diag(Rdiag);\n }\n /**\n * @param {number[][]} arr\n * @param {number} N\n * @param {number} prec\n * @param {'number'|'BigNumber'|'Complex'} type\n * @param {boolean} findVectors\n * @param {number[][]} R the row transformation matrix that will be modified\n */\n\n\n function reduceToHessenberg(arr, N, prec, type, findVectors, R) {\n var big = type === 'BigNumber';\n var cplx = type === 'Complex';\n var zero = big ? bignumber(0) : cplx ? complex(0) : 0;\n\n if (big) {\n prec = bignumber(prec);\n }\n\n for (var i = 0; i < N - 2; i++) {\n // Find the largest subdiag element in the i-th col\n var maxIndex = 0;\n var max = zero;\n\n for (var j = i + 1; j < N; j++) {\n var el = arr[j][i];\n\n if (smaller(abs(max), abs(el))) {\n max = el;\n maxIndex = j;\n }\n } // This col is pivoted, no need to do anything\n\n\n if (smaller(abs(max), prec)) {\n continue;\n }\n\n if (maxIndex !== i + 1) {\n // Interchange maxIndex-th and (i+1)-th row\n var tmp1 = arr[maxIndex];\n arr[maxIndex] = arr[i + 1];\n arr[i + 1] = tmp1; // Interchange maxIndex-th and (i+1)-th column\n\n for (var _j2 = 0; _j2 < N; _j2++) {\n var tmp2 = arr[_j2][maxIndex];\n arr[_j2][maxIndex] = arr[_j2][i + 1];\n arr[_j2][i + 1] = tmp2;\n } // keep track of transformations\n\n\n if (findVectors) {\n var tmp3 = R[maxIndex];\n R[maxIndex] = R[i + 1];\n R[i + 1] = tmp3;\n }\n } // Reduce following rows and columns\n\n\n for (var _j3 = i + 2; _j3 < N; _j3++) {\n var n = divideScalar(arr[_j3][i], max);\n\n if (n === 0) {\n continue;\n } // from j-th row subtract n-times (i+1)th row\n\n\n for (var k = 0; k < N; k++) {\n arr[_j3][k] = subtract(arr[_j3][k], multiplyScalar(n, arr[i + 1][k]));\n } // to (i+1)th column add n-times j-th column\n\n\n for (var _k = 0; _k < N; _k++) {\n arr[_k][i + 1] = addScalar(arr[_k][i + 1], multiplyScalar(n, arr[_k][_j3]));\n } // keep track of transformations\n\n\n if (findVectors) {\n for (var _k2 = 0; _k2 < N; _k2++) {\n R[_j3][_k2] = subtract(R[_j3][_k2], multiplyScalar(n, R[i + 1][_k2]));\n }\n }\n }\n }\n\n return R;\n }\n /**\n * @returns {{values: values, C: Matrix}}\n * @see Press, Wiliams: Numerical recipes in Fortran 77\n * @see https://en.wikipedia.org/wiki/QR_algorithm\n */\n\n\n function iterateUntilTriangular(A, N, prec, type, findVectors) {\n var big = type === 'BigNumber';\n var cplx = type === 'Complex';\n var one = big ? bignumber(1) : cplx ? complex(1) : 1;\n\n if (big) {\n prec = bignumber(prec);\n } // The Francis Algorithm\n // The core idea of this algorithm is that doing successive\n // A' = Q⁺AQ transformations will eventually converge to block-\n // upper-triangular with diagonal blocks either 1x1 or 2x2.\n // The Q here is the one from the QR decomposition, A = QR.\n // Since the eigenvalues of a block-upper-triangular matrix are\n // the eigenvalues of its diagonal blocks and we know how to find\n // eigenvalues of a 2x2 matrix, we know the eigenvalues of A.\n\n\n var arr = (0, _object.clone)(A); // the list of converged eigenvalues\n\n var lambdas = []; // size of arr, which will get smaller as eigenvalues converge\n\n var n = N; // the diagonal of the block-diagonal matrix that turns\n // converged 2x2 matrices into upper triangular matrices\n\n var Sdiag = []; // N×N matrix describing the overall transformation done during the QR algorithm\n\n var Qtotal = findVectors ? diag(Array(N).fill(one)) : undefined; // n×n matrix describing the QR transformations done since last convergence\n\n var Qpartial = findVectors ? diag(Array(n).fill(one)) : undefined; // last eigenvalue converged before this many steps\n\n var lastConvergenceBefore = 0;\n\n while (lastConvergenceBefore <= 100) {\n lastConvergenceBefore += 1; // TODO if the convergence is slow, do something clever\n // Perform the factorization\n\n var k = 0; // TODO set close to an eigenvalue\n\n for (var i = 0; i < n; i++) {\n arr[i][i] = subtract(arr[i][i], k);\n } // TODO do an implicit QR transformation\n\n\n var _qr = qr(arr),\n Q = _qr.Q,\n R = _qr.R;\n\n arr = multiply(R, Q);\n\n for (var _i = 0; _i < n; _i++) {\n arr[_i][_i] = addScalar(arr[_i][_i], k);\n } // keep track of transformations\n\n\n if (findVectors) {\n Qpartial = multiply(Qpartial, Q);\n } // The rightmost diagonal element converged to an eigenvalue\n\n\n if (n === 1 || smaller(abs(arr[n - 1][n - 2]), prec)) {\n lastConvergenceBefore = 0;\n lambdas.push(arr[n - 1][n - 1]); // keep track of transformations\n\n if (findVectors) {\n Sdiag.unshift([[1]]);\n inflateMatrix(Qpartial, N);\n Qtotal = multiply(Qtotal, Qpartial);\n\n if (n > 1) {\n Qpartial = diag(Array(n - 1).fill(one));\n }\n } // reduce the matrix size\n\n\n n -= 1;\n arr.pop();\n\n for (var _i2 = 0; _i2 < n; _i2++) {\n arr[_i2].pop();\n } // The rightmost diagonal 2x2 block converged\n\n } else if (n === 2 || smaller(abs(arr[n - 2][n - 3]), prec)) {\n lastConvergenceBefore = 0;\n var ll = eigenvalues2x2(arr[n - 2][n - 2], arr[n - 2][n - 1], arr[n - 1][n - 2], arr[n - 1][n - 1]);\n lambdas.push.apply(lambdas, (0, _toConsumableArray2.default)(ll)); // keep track of transformations\n\n if (findVectors) {\n Sdiag.unshift(jordanBase2x2(arr[n - 2][n - 2], arr[n - 2][n - 1], arr[n - 1][n - 2], arr[n - 1][n - 1], ll[0], ll[1], prec, type));\n inflateMatrix(Qpartial, N);\n Qtotal = multiply(Qtotal, Qpartial);\n\n if (n > 2) {\n Qpartial = diag(Array(n - 2).fill(one));\n }\n } // reduce the matrix size\n\n\n n -= 2;\n arr.pop();\n arr.pop();\n\n for (var _i3 = 0; _i3 < n; _i3++) {\n arr[_i3].pop();\n\n arr[_i3].pop();\n }\n }\n\n if (n === 0) {\n break;\n }\n } // standard sorting\n\n\n lambdas.sort(function (a, b) {\n return +subtract(abs(a), abs(b));\n }); // the algorithm didn't converge\n\n if (lastConvergenceBefore > 100) {\n var err = Error('The eigenvalues failed to converge. Only found these eigenvalues: ' + lambdas.join(', '));\n err.values = lambdas;\n err.vectors = [];\n throw err;\n } // combine the overall QR transformation Qtotal with the subsequent\n // transformation S that turns the diagonal 2x2 blocks to upper triangular\n\n\n var C = findVectors ? multiply(Qtotal, blockDiag(Sdiag, N)) : undefined;\n return {\n values: lambdas,\n C: C\n };\n }\n /**\n * @param {Matrix} A hessenberg-form matrix\n * @param {number} N size of A\n * @param {Matrix} C column transformation matrix that turns A into upper triangular\n * @param {Matrix} R similarity that turns original matrix into A\n * @param {number[]} values array of eigenvalues of A\n * @param {'number'|'BigNumber'|'Complex'} type\n * @returns {number[][]} eigenvalues\n */\n\n\n function findEigenvectors(A, N, C, R, values, prec, type) {\n var Cinv = inv(C);\n var U = multiply(Cinv, A, C);\n var big = type === 'BigNumber';\n var cplx = type === 'Complex';\n var zero = big ? bignumber(0) : cplx ? complex(0) : 0;\n var one = big ? bignumber(1) : cplx ? complex(1) : 1; // turn values into a kind of \"multiset\"\n // this way it is easier to find eigenvectors\n\n var uniqueValues = [];\n var multiplicities = [];\n\n var _iterator = _createForOfIteratorHelper(values),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var λ = _step.value;\n\n var _i4 = indexOf(uniqueValues, λ, equal);\n\n if (_i4 === -1) {\n uniqueValues.push(λ);\n multiplicities.push(1);\n } else {\n multiplicities[_i4] += 1;\n }\n } // find eigenvectors by solving U − λE = 0\n // TODO replace with an iterative eigenvector algorithm\n // (this one might fail for imprecise eigenvalues)\n\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n var vectors = [];\n var len = uniqueValues.length;\n var b = Array(N).fill(zero);\n var E = diag(Array(N).fill(one)); // eigenvalues for which usolve failed (due to numerical error)\n\n var failedLambdas = [];\n\n var _loop = function _loop(i) {\n var λ = uniqueValues[i];\n var S = subtract(U, multiply(λ, E)); // the characteristic matrix\n\n var solutions = usolveAll(S, b);\n solutions.shift(); // ignore the null vector\n // looks like we missed something, try inverse iteration\n\n while (solutions.length < multiplicities[i]) {\n var approxVec = inverseIterate(S, N, solutions, prec, type);\n\n if (approxVec == null) {\n // no more vectors were found\n failedLambdas.push(λ);\n break;\n }\n\n solutions.push(approxVec);\n } // Transform back into original array coordinates\n\n\n var correction = multiply(inv(R), C);\n solutions = solutions.map(function (v) {\n return multiply(correction, v);\n });\n vectors.push.apply(vectors, (0, _toConsumableArray2.default)(solutions.map(function (v) {\n return flatten(v);\n })));\n };\n\n for (var i = 0; i < len; i++) {\n _loop(i);\n }\n\n if (failedLambdas.length !== 0) {\n var err = new Error('Failed to find eigenvectors for the following eigenvalues: ' + failedLambdas.join(', '));\n err.values = values;\n err.vectors = vectors;\n throw err;\n }\n\n return vectors;\n }\n /**\n * Compute the eigenvalues of an 2x2 matrix\n * @return {[number,number]}\n */\n\n\n function eigenvalues2x2(a, b, c, d) {\n // λ± = ½ trA ± ½ √( tr²A - 4 detA )\n var trA = addScalar(a, d);\n var detA = subtract(multiplyScalar(a, d), multiplyScalar(b, c));\n var x = multiplyScalar(trA, 0.5);\n var y = multiplyScalar(sqrt(subtract(multiplyScalar(trA, trA), multiplyScalar(4, detA))), 0.5);\n return [addScalar(x, y), subtract(x, y)];\n }\n /**\n * For an 2x2 matrix compute the transformation matrix S,\n * so that SAS⁻¹ is an upper triangular matrix\n * @return {[[number,number],[number,number]]}\n * @see https://math.berkeley.edu/~ogus/old/Math_54-05/webfoils/jordan.pdf\n * @see http://people.math.harvard.edu/~knill/teaching/math21b2004/exhibits/2dmatrices/index.html\n */\n\n\n function jordanBase2x2(a, b, c, d, l1, l2, prec, type) {\n var big = type === 'BigNumber';\n var cplx = type === 'Complex';\n var zero = big ? bignumber(0) : cplx ? complex(0) : 0;\n var one = big ? bignumber(1) : cplx ? complex(1) : 1; // matrix is already upper triangular\n // return an identity matrix\n\n if (smaller(abs(c), prec)) {\n return [[one, zero], [zero, one]];\n } // matrix is diagonalizable\n // return its eigenvectors as columns\n\n\n if (larger(abs(subtract(l1, l2)), prec)) {\n return [[subtract(l1, d), subtract(l2, d)], [c, c]];\n } // matrix is not diagonalizable\n // compute off-diagonal elements of N = A - λI\n // N₁₂ = 0 ⇒ S = ( N⃗₁, I⃗₁ )\n // N₁₂ ≠ 0 ⇒ S = ( N⃗₂, I⃗₂ )\n\n\n var na = subtract(a, l1);\n var nb = subtract(b, l1);\n var nc = subtract(c, l1);\n var nd = subtract(d, l1);\n\n if (smaller(abs(nb), prec)) {\n return [[na, one], [nc, zero]];\n } else {\n return [[nb, zero], [nd, one]];\n }\n }\n /**\n * Enlarge the matrix from n×n to N×N, setting the new\n * elements to 1 on diagonal and 0 elsewhere\n */\n\n\n function inflateMatrix(arr, N) {\n // add columns\n for (var i = 0; i < arr.length; i++) {\n var _arr$i;\n\n (_arr$i = arr[i]).push.apply(_arr$i, (0, _toConsumableArray2.default)(Array(N - arr[i].length).fill(0)));\n } // add rows\n\n\n for (var _i5 = arr.length; _i5 < N; _i5++) {\n arr.push(Array(N).fill(0));\n arr[_i5][_i5] = 1;\n }\n\n return arr;\n }\n /**\n * Create a block-diagonal matrix with the given square matrices on the diagonal\n * @param {Matrix[] | number[][][]} arr array of matrices to be placed on the diagonal\n * @param {number} N the size of the resulting matrix\n */\n\n\n function blockDiag(arr, N) {\n var M = [];\n\n for (var i = 0; i < N; i++) {\n M[i] = Array(N).fill(0);\n }\n\n var I = 0;\n\n var _iterator2 = _createForOfIteratorHelper(arr),\n _step2;\n\n try {\n for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n var sub = _step2.value;\n var n = sub.length;\n\n for (var _i6 = 0; _i6 < n; _i6++) {\n for (var j = 0; j < n; j++) {\n M[I + _i6][I + j] = sub[_i6][j];\n }\n }\n\n I += n;\n }\n } catch (err) {\n _iterator2.e(err);\n } finally {\n _iterator2.f();\n }\n\n return M;\n }\n /**\n * Finds the index of an element in an array using a custom equality function\n * @template T\n * @param {Array} arr array in which to search\n * @param {T} el the element to find\n * @param {function(T, T): boolean} fn the equality function, first argument is an element of `arr`, the second is always `el`\n * @returns {number} the index of `el`, or -1 when it's not in `arr`\n */\n\n\n function indexOf(arr, el, fn) {\n for (var i = 0; i < arr.length; i++) {\n if (fn(arr[i], el)) {\n return i;\n }\n }\n\n return -1;\n }\n /**\n * Provided a near-singular upper-triangular matrix A and a list of vectors,\n * finds an eigenvector of A with the smallest eigenvalue, which is orthogonal\n * to each vector in the list\n * @template T\n * @param {T[][]} A near-singular square matrix\n * @param {number} N dimension\n * @param {T[][]} orthog list of vectors\n * @param {number} prec epsilon\n * @param {'number'|'BigNumber'|'Complex'} type\n * @return {T[] | null} eigenvector\n *\n * @see Numerical Recipes for Fortran 77 – 11.7 Eigenvalues or Eigenvectors by Inverse Iteration\n */\n\n\n function inverseIterate(A, N, orthog, prec, type) {\n var largeNum = type === 'BigNumber' ? bignumber(1000) : 1000;\n var b; // the vector\n // you better choose a random vector before I count to five\n\n var i = 0;\n\n while (true) {\n b = randomOrthogonalVector(N, orthog, type);\n b = usolve(A, b);\n\n if (larger(norm(b), largeNum)) {\n break;\n }\n\n if (++i >= 5) {\n return null;\n }\n } // you better converge before I count to ten\n\n\n i = 0;\n\n while (true) {\n var c = usolve(A, b);\n\n if (smaller(norm(orthogonalComplement(b, [c])), prec)) {\n break;\n }\n\n if (++i >= 10) {\n return null;\n }\n\n b = normalize(c);\n }\n\n return b;\n }\n /**\n * Generates a random unit vector of dimension N, orthogonal to each vector in the list\n * @template T\n * @param {number} N dimension\n * @param {T[][]} orthog list of vectors\n * @param {'number'|'BigNumber'|'Complex'} type\n * @returns {T[]} random vector\n */\n\n\n function randomOrthogonalVector(N, orthog, type) {\n var big = type === 'BigNumber';\n var cplx = type === 'Complex'; // generate random vector with the correct type\n\n var v = Array(N).fill(0).map(function (_) {\n return 2 * Math.random() - 1;\n });\n\n if (big) {\n v = v.map(function (n) {\n return bignumber(n);\n });\n }\n\n if (cplx) {\n v = v.map(function (n) {\n return complex(n);\n });\n } // project to orthogonal complement\n\n\n v = orthogonalComplement(v, orthog); // normalize\n\n return normalize(v, type);\n }\n /**\n * Project vector v to the orthogonal complement of an array of vectors\n */\n\n\n function orthogonalComplement(v, orthog) {\n var _iterator3 = _createForOfIteratorHelper(orthog),\n _step3;\n\n try {\n for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {\n var w = _step3.value;\n // v := v − (w, v)/∥w∥² w\n v = subtract(v, multiply(divideScalar(dot(w, v), dot(w, w)), w));\n }\n } catch (err) {\n _iterator3.e(err);\n } finally {\n _iterator3.f();\n }\n\n return v;\n }\n /**\n * Calculate the norm of a vector.\n * We can't use math.norm because factory can't handle circular dependency.\n * Seriously, I'm really fed up with factory.\n */\n\n\n function norm(v) {\n return abs(sqrt(dot(v, v)));\n }\n /**\n * Normalize a vector\n * @template T\n * @param {T[]} v\n * @param {'number'|'BigNumber'|'Complex'} type\n * @returns {T[]} normalized vec\n */\n\n\n function normalize(v, type) {\n var big = type === 'BigNumber';\n var cplx = type === 'Complex';\n var one = big ? bignumber(1) : cplx ? complex(1) : 1;\n return multiply(divideScalar(one, norm(v)), v);\n }\n\n return complexEigs;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRealSymmetric = createRealSymmetric;\n\nvar _object = require(\"../../../utils/object.js\");\n\nfunction createRealSymmetric(_ref) {\n var config = _ref.config,\n addScalar = _ref.addScalar,\n subtract = _ref.subtract,\n abs = _ref.abs,\n atan = _ref.atan,\n cos = _ref.cos,\n sin = _ref.sin,\n multiplyScalar = _ref.multiplyScalar,\n inv = _ref.inv,\n bignumber = _ref.bignumber,\n multiply = _ref.multiply,\n add = _ref.add;\n\n /**\n * @param {number[] | BigNumber[]} arr\n * @param {number} N\n * @param {number} prec\n * @param {'number' | 'BigNumber'} type\n */\n function main(arr, N) {\n var prec = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : config.epsilon;\n var type = arguments.length > 3 ? arguments[3] : undefined;\n\n if (type === 'number') {\n return diag(arr, prec);\n }\n\n if (type === 'BigNumber') {\n return diagBig(arr, prec);\n }\n\n throw TypeError('Unsupported data type: ' + type);\n } // diagonalization implementation for number (efficient)\n\n\n function diag(x, precision) {\n var N = x.length;\n var e0 = Math.abs(precision / N);\n var psi;\n var Sij = new Array(N); // Sij is Identity Matrix\n\n for (var i = 0; i < N; i++) {\n Sij[i] = createArray(N, 0);\n Sij[i][i] = 1.0;\n } // initial error\n\n\n var Vab = getAij(x);\n\n while (Math.abs(Vab[1]) >= Math.abs(e0)) {\n var _i = Vab[0][0];\n var j = Vab[0][1];\n psi = getTheta(x[_i][_i], x[j][j], x[_i][j]);\n x = x1(x, psi, _i, j);\n Sij = Sij1(Sij, psi, _i, j);\n Vab = getAij(x);\n }\n\n var Ei = createArray(N, 0); // eigenvalues\n\n for (var _i2 = 0; _i2 < N; _i2++) {\n Ei[_i2] = x[_i2][_i2];\n }\n\n return sorting((0, _object.clone)(Ei), (0, _object.clone)(Sij));\n } // diagonalization implementation for bigNumber\n\n\n function diagBig(x, precision) {\n var N = x.length;\n var e0 = abs(precision / N);\n var psi;\n var Sij = new Array(N); // Sij is Identity Matrix\n\n for (var i = 0; i < N; i++) {\n Sij[i] = createArray(N, 0);\n Sij[i][i] = 1.0;\n } // initial error\n\n\n var Vab = getAijBig(x);\n\n while (abs(Vab[1]) >= abs(e0)) {\n var _i3 = Vab[0][0];\n var j = Vab[0][1];\n psi = getThetaBig(x[_i3][_i3], x[j][j], x[_i3][j]);\n x = x1Big(x, psi, _i3, j);\n Sij = Sij1Big(Sij, psi, _i3, j);\n Vab = getAijBig(x);\n }\n\n var Ei = createArray(N, 0); // eigenvalues\n\n for (var _i4 = 0; _i4 < N; _i4++) {\n Ei[_i4] = x[_i4][_i4];\n } // return [clone(Ei), clone(Sij)]\n\n\n return sorting((0, _object.clone)(Ei), (0, _object.clone)(Sij));\n } // get angle\n\n\n function getTheta(aii, ajj, aij) {\n var denom = ajj - aii;\n\n if (Math.abs(denom) <= config.epsilon) {\n return Math.PI / 4.0;\n } else {\n return 0.5 * Math.atan(2.0 * aij / (ajj - aii));\n }\n } // get angle\n\n\n function getThetaBig(aii, ajj, aij) {\n var denom = subtract(ajj, aii);\n\n if (abs(denom) <= config.epsilon) {\n return bignumber(-1).acos().div(4);\n } else {\n return multiplyScalar(0.5, atan(multiply(2.0, aij, inv(denom))));\n }\n } // update eigvec\n\n\n function Sij1(Sij, theta, i, j) {\n var N = Sij.length;\n var c = Math.cos(theta);\n var s = Math.sin(theta);\n var Ski = createArray(N, 0);\n var Skj = createArray(N, 0);\n\n for (var k = 0; k < N; k++) {\n Ski[k] = c * Sij[k][i] - s * Sij[k][j];\n Skj[k] = s * Sij[k][i] + c * Sij[k][j];\n }\n\n for (var _k = 0; _k < N; _k++) {\n Sij[_k][i] = Ski[_k];\n Sij[_k][j] = Skj[_k];\n }\n\n return Sij;\n } // update eigvec for overlap\n\n\n function Sij1Big(Sij, theta, i, j) {\n var N = Sij.length;\n var c = cos(theta);\n var s = sin(theta);\n var Ski = createArray(N, bignumber(0));\n var Skj = createArray(N, bignumber(0));\n\n for (var k = 0; k < N; k++) {\n Ski[k] = subtract(multiplyScalar(c, Sij[k][i]), multiplyScalar(s, Sij[k][j]));\n Skj[k] = addScalar(multiplyScalar(s, Sij[k][i]), multiplyScalar(c, Sij[k][j]));\n }\n\n for (var _k2 = 0; _k2 < N; _k2++) {\n Sij[_k2][i] = Ski[_k2];\n Sij[_k2][j] = Skj[_k2];\n }\n\n return Sij;\n } // update matrix\n\n\n function x1Big(Hij, theta, i, j) {\n var N = Hij.length;\n var c = bignumber(cos(theta));\n var s = bignumber(sin(theta));\n var c2 = multiplyScalar(c, c);\n var s2 = multiplyScalar(s, s);\n var Aki = createArray(N, bignumber(0));\n var Akj = createArray(N, bignumber(0)); // 2cs Hij\n\n var csHij = multiply(bignumber(2), c, s, Hij[i][j]); // Aii\n\n var Aii = addScalar(subtract(multiplyScalar(c2, Hij[i][i]), csHij), multiplyScalar(s2, Hij[j][j]));\n var Ajj = add(multiplyScalar(s2, Hij[i][i]), csHij, multiplyScalar(c2, Hij[j][j])); // 0 to i\n\n for (var k = 0; k < N; k++) {\n Aki[k] = subtract(multiplyScalar(c, Hij[i][k]), multiplyScalar(s, Hij[j][k]));\n Akj[k] = addScalar(multiplyScalar(s, Hij[i][k]), multiplyScalar(c, Hij[j][k]));\n } // Modify Hij\n\n\n Hij[i][i] = Aii;\n Hij[j][j] = Ajj;\n Hij[i][j] = bignumber(0);\n Hij[j][i] = bignumber(0); // 0 to i\n\n for (var _k3 = 0; _k3 < N; _k3++) {\n if (_k3 !== i && _k3 !== j) {\n Hij[i][_k3] = Aki[_k3];\n Hij[_k3][i] = Aki[_k3];\n Hij[j][_k3] = Akj[_k3];\n Hij[_k3][j] = Akj[_k3];\n }\n }\n\n return Hij;\n } // update matrix\n\n\n function x1(Hij, theta, i, j) {\n var N = Hij.length;\n var c = Math.cos(theta);\n var s = Math.sin(theta);\n var c2 = c * c;\n var s2 = s * s;\n var Aki = createArray(N, 0);\n var Akj = createArray(N, 0); // Aii\n\n var Aii = c2 * Hij[i][i] - 2 * c * s * Hij[i][j] + s2 * Hij[j][j];\n var Ajj = s2 * Hij[i][i] + 2 * c * s * Hij[i][j] + c2 * Hij[j][j]; // 0 to i\n\n for (var k = 0; k < N; k++) {\n Aki[k] = c * Hij[i][k] - s * Hij[j][k];\n Akj[k] = s * Hij[i][k] + c * Hij[j][k];\n } // Modify Hij\n\n\n Hij[i][i] = Aii;\n Hij[j][j] = Ajj;\n Hij[i][j] = 0;\n Hij[j][i] = 0; // 0 to i\n\n for (var _k4 = 0; _k4 < N; _k4++) {\n if (_k4 !== i && _k4 !== j) {\n Hij[i][_k4] = Aki[_k4];\n Hij[_k4][i] = Aki[_k4];\n Hij[j][_k4] = Akj[_k4];\n Hij[_k4][j] = Akj[_k4];\n }\n }\n\n return Hij;\n } // get max off-diagonal value from Upper Diagonal\n\n\n function getAij(Mij) {\n var N = Mij.length;\n var maxMij = 0;\n var maxIJ = [0, 1];\n\n for (var i = 0; i < N; i++) {\n for (var j = i + 1; j < N; j++) {\n if (Math.abs(maxMij) < Math.abs(Mij[i][j])) {\n maxMij = Math.abs(Mij[i][j]);\n maxIJ = [i, j];\n }\n }\n }\n\n return [maxIJ, maxMij];\n } // get max off-diagonal value from Upper Diagonal\n\n\n function getAijBig(Mij) {\n var N = Mij.length;\n var maxMij = 0;\n var maxIJ = [0, 1];\n\n for (var i = 0; i < N; i++) {\n for (var j = i + 1; j < N; j++) {\n if (abs(maxMij) < abs(Mij[i][j])) {\n maxMij = abs(Mij[i][j]);\n maxIJ = [i, j];\n }\n }\n }\n\n return [maxIJ, maxMij];\n } // sort results\n\n\n function sorting(E, S) {\n var N = E.length;\n var values = Array(N);\n var vectors = Array(N);\n\n for (var k = 0; k < N; k++) {\n vectors[k] = Array(N);\n }\n\n for (var i = 0; i < N; i++) {\n var minID = 0;\n var minE = E[0];\n\n for (var j = 0; j < E.length; j++) {\n if (abs(E[j]) < abs(minE)) {\n minID = j;\n minE = E[minID];\n }\n }\n\n values[i] = E.splice(minID, 1)[0];\n\n for (var _k5 = 0; _k5 < N; _k5++) {\n vectors[_k5][i] = S[_k5][minID];\n\n S[_k5].splice(minID, 1);\n }\n }\n\n return {\n values: values,\n vectors: vectors\n };\n }\n /**\n * Create an array of a certain size and fill all items with an initial value\n * @param {number} size\n * @param {number} value\n * @return {number[]}\n */\n\n\n function createArray(size, value) {\n // TODO: as soon as all browsers support Array.fill, use that instead (IE doesn't support it)\n var array = new Array(size);\n\n for (var i = 0; i < size; i++) {\n array[i] = value;\n }\n\n return array;\n }\n\n return main;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createExpm = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'expm';\nvar dependencies = ['typed', 'abs', 'add', 'identity', 'inv', 'multiply'];\nvar createExpm = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n abs = _ref.abs,\n add = _ref.add,\n identity = _ref.identity,\n inv = _ref.inv,\n multiply = _ref.multiply;\n\n /**\n * Compute the matrix exponential, expm(A) = e^A. The matrix must be square.\n * Not to be confused with exp(a), which performs element-wise\n * exponentiation.\n *\n * The exponential is calculated using the Padé approximant with scaling and\n * squaring; see \"Nineteen Dubious Ways to Compute the Exponential of a\n * Matrix,\" by Moler and Van Loan.\n *\n * Syntax:\n *\n * math.expm(x)\n *\n * Examples:\n *\n * const A = [[0,2],[0,0]]\n * math.expm(A) // returns [[1,2],[0,1]]\n *\n * See also:\n *\n * exp\n *\n * @param {Matrix} x A square Matrix\n * @return {Matrix} The exponential of x\n */\n return typed(name, {\n Matrix: function Matrix(A) {\n // Check matrix size\n var size = A.size();\n\n if (size.length !== 2 || size[0] !== size[1]) {\n throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n\n var n = size[0]; // Desired accuracy of the approximant (The actual accuracy\n // will be affected by round-off error)\n\n var eps = 1e-15; // The Padé approximant is not so accurate when the values of A\n // are \"large\", so scale A by powers of two. Then compute the\n // exponential, and square the result repeatedly according to\n // the identity e^A = (e^(A/m))^m\n // Compute infinity-norm of A, ||A||, to see how \"big\" it is\n\n var infNorm = infinityNorm(A); // Find the optimal scaling factor and number of terms in the\n // Padé approximant to reach the desired accuracy\n\n var params = findParams(infNorm, eps);\n var q = params.q;\n var j = params.j; // The Pade approximation to e^A is:\n // Rqq(A) = Dqq(A) ^ -1 * Nqq(A)\n // where\n // Nqq(A) = sum(i=0, q, (2q-i)!p! / [ (2q)!i!(q-i)! ] A^i\n // Dqq(A) = sum(i=0, q, (2q-i)!q! / [ (2q)!i!(q-i)! ] (-A)^i\n // Scale A by 1 / 2^j\n\n var Apos = multiply(A, Math.pow(2, -j)); // The i=0 term is just the identity matrix\n\n var N = identity(n);\n var D = identity(n); // Initialization (i=0)\n\n var factor = 1; // Initialization (i=1)\n\n var AposToI = Apos; // Cloning not necessary\n\n var alternate = -1;\n\n for (var i = 1; i <= q; i++) {\n if (i > 1) {\n AposToI = multiply(AposToI, Apos);\n alternate = -alternate;\n }\n\n factor = factor * (q - i + 1) / ((2 * q - i + 1) * i);\n N = add(N, multiply(factor, AposToI));\n D = add(D, multiply(factor * alternate, AposToI));\n }\n\n var R = multiply(inv(D), N); // Square j times\n\n for (var _i = 0; _i < j; _i++) {\n R = multiply(R, R);\n }\n\n return (0, _is.isSparseMatrix)(A) ? A.createSparseMatrix(R) : R;\n }\n });\n\n function infinityNorm(A) {\n var n = A.size()[0];\n var infNorm = 0;\n\n for (var i = 0; i < n; i++) {\n var rowSum = 0;\n\n for (var j = 0; j < n; j++) {\n rowSum += abs(A.get([i, j]));\n }\n\n infNorm = Math.max(rowSum, infNorm);\n }\n\n return infNorm;\n }\n /**\n * Find the best parameters for the Pade approximant given\n * the matrix norm and desired accuracy. Returns the first acceptable\n * combination in order of increasing computational load.\n */\n\n\n function findParams(infNorm, eps) {\n var maxSearchSize = 30;\n\n for (var k = 0; k < maxSearchSize; k++) {\n for (var q = 0; q <= k; q++) {\n var j = k - q;\n\n if (errorEstimate(infNorm, q, j) < eps) {\n return {\n q: q,\n j: j\n };\n }\n }\n }\n\n throw new Error('Could not find acceptable parameters to compute the matrix exponential (try increasing maxSearchSize in expm.js)');\n }\n /**\n * Returns the estimated error of the Pade approximant for the given\n * parameters.\n */\n\n\n function errorEstimate(infNorm, q, j) {\n var qfac = 1;\n\n for (var i = 2; i <= q; i++) {\n qfac *= i;\n }\n\n var twoqfac = qfac;\n\n for (var _i2 = q + 1; _i2 <= 2 * q; _i2++) {\n twoqfac *= _i2;\n }\n\n var twoqp1fac = twoqfac * (2 * q + 1);\n return 8.0 * Math.pow(infNorm / Math.pow(2, j), 2 * q) * qfac * qfac / (twoqfac * twoqp1fac);\n }\n});\nexports.createExpm = createExpm;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFft = void 0;\n\nvar _toConsumableArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'fft';\nvar dependencies = ['typed', 'matrix', 'addScalar', 'multiplyScalar', 'divideScalar', 'exp', 'tau', 'i'];\nvar createFft = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n addScalar = _ref.addScalar,\n multiplyScalar = _ref.multiplyScalar,\n divideScalar = _ref.divideScalar,\n exp = _ref.exp,\n tau = _ref.tau,\n I = _ref.i;\n\n /**\n * Calculate N-dimensional fourier transform\n *\n * Syntax:\n *\n * math.fft(arr)\n *\n * Examples:\n *\n * math.fft([[1, 0], [1, 0]]) // returns [[{re:2, im:0}, {re:2, im:0}], [{re:0, im:0}, {re:0, im:0}]]\n *\n *\n * See Also:\n *\n * ifft\n *\n * @param {Array | Matrix} arr An array or matrix\n * @return {Array | Matrix} N-dimensional fourier transformation of the array\n */\n return typed(name, {\n Array: _ndFft,\n Matrix: function Matrix(matrix) {\n return matrix.create(_ndFft(matrix.toArray()));\n }\n });\n /**\n * Perform an N-dimensional Fourier transform\n *\n * @param {Array} arr The array\n * @return {Array} resulting array\n */\n\n function _ndFft(arr) {\n var size = (0, _array.arraySize)(arr);\n if (size.length === 1) return _fft(arr, size[0]); // ndFft along dimension 1,...,N-1 then 1dFft along dimension 0\n\n return _1dFft(arr.map(function (slice) {\n return _ndFft(slice, size.slice(1));\n }), 0);\n }\n /**\n * Perform an 1-dimensional Fourier transform\n *\n * @param {Array} arr The array\n * @param {number} dim dimension of the array to perform on\n * @return {Array} resulting array\n */\n\n\n function _1dFft(arr, dim) {\n var size = (0, _array.arraySize)(arr);\n if (dim !== 0) return new Array(size[0]).fill(0).map(function (_, i) {\n return _1dFft(arr[i], dim - 1);\n });\n if (size.length === 1) return _fft(arr);\n\n function _transpose(arr) {\n // Swap first 2 dimensions\n var size = (0, _array.arraySize)(arr);\n return new Array(size[1]).fill(0).map(function (_, j) {\n return new Array(size[0]).fill(0).map(function (_, i) {\n return arr[i][j];\n });\n });\n }\n\n return _transpose(_1dFft(_transpose(arr), 1));\n }\n /**\n * Perform an 1-dimensional Fourier transform\n *\n * @param {Array} arr The array\n * @return {Array} resulting array\n */\n\n\n function _fft(arr) {\n var len = arr.length;\n if (len === 1) return [arr[0]];\n\n if (len % 2 === 0) {\n var ret = [].concat((0, _toConsumableArray2.default)(_fft(arr.filter(function (_, i) {\n return i % 2 === 0;\n }), len / 2)), (0, _toConsumableArray2.default)(_fft(arr.filter(function (_, i) {\n return i % 2 === 1;\n }), len / 2)));\n\n for (var k = 0; k < len / 2; k++) {\n var p = ret[k];\n var q = multiplyScalar(ret[k + len / 2], exp(multiplyScalar(multiplyScalar(tau, I), divideScalar(-k, len))));\n ret[k] = addScalar(p, q);\n ret[k + len / 2] = addScalar(p, multiplyScalar(-1, q));\n }\n\n return ret;\n }\n\n throw new Error('Can only calculate FFT of power-of-two size');\n }\n});\nexports.createFft = createFft;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFilter = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _function = require(\"../../utils/function.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'filter';\nvar dependencies = ['typed'];\nvar createFilter = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Filter the items in an array or one dimensional matrix.\n *\n * Syntax:\n *\n * math.filter(x, test)\n *\n * Examples:\n *\n * function isPositive (x) {\n * return x > 0\n * }\n * math.filter([6, -2, -1, 4, 3], isPositive) // returns [6, 4, 3]\n *\n * math.filter([\"23\", \"foo\", \"100\", \"55\", \"bar\"], /[0-9]+/) // returns [\"23\", \"100\", \"55\"]\n *\n * See also:\n *\n * forEach, map, sort\n *\n * @param {Matrix | Array} x A one dimensional matrix or array to filter\n * @param {Function | RegExp} test\n * A function or regular expression to test items.\n * All entries for which `test` returns true are returned.\n * When `test` is a function, it is invoked with three parameters:\n * the value of the element, the index of the element, and the\n * matrix/array being traversed. The function must return a boolean.\n * @return {Matrix | Array} Returns the filtered matrix.\n */\n return typed('filter', {\n 'Array, function': _filterCallback,\n 'Matrix, function': function MatrixFunction(x, test) {\n return x.create(_filterCallback(x.toArray(), test));\n },\n 'Array, RegExp': _array.filterRegExp,\n 'Matrix, RegExp': function MatrixRegExp(x, test) {\n return x.create((0, _array.filterRegExp)(x.toArray(), test));\n }\n });\n});\n/**\n * Filter values in a callback given a callback function\n * @param {Array} x\n * @param {Function} callback\n * @return {Array} Returns the filtered array\n * @private\n */\n\nexports.createFilter = createFilter;\n\nfunction _filterCallback(x, callback) {\n // figure out what number of arguments the callback function expects\n var args = (0, _function.maxArgumentCount)(callback);\n return (0, _array.filter)(x, function (value, index, array) {\n // invoke the callback function with the right number of arguments\n if (args === 1) {\n return callback(value);\n } else if (args === 2) {\n return callback(value, [index]);\n } else {\n // 3 or -1\n return callback(value, [index], array);\n }\n });\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFlatten = void 0;\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'flatten';\nvar dependencies = ['typed', 'matrix'];\nvar createFlatten = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix;\n\n /**\n * Flatten a multi dimensional matrix into a single dimensional matrix.\n * It is guaranteed to always return a clone of the argument.\n *\n * Syntax:\n *\n * math.flatten(x)\n *\n * Examples:\n *\n * math.flatten([[1,2], [3,4]]) // returns [1, 2, 3, 4]\n *\n * See also:\n *\n * concat, resize, size, squeeze\n *\n * @param {Matrix | Array} x Matrix to be flattened\n * @return {Matrix | Array} Returns the flattened matrix\n */\n return typed(name, {\n Array: function Array(x) {\n return (0, _array.flatten)((0, _object.clone)(x));\n },\n Matrix: function Matrix(x) {\n var flat = (0, _array.flatten)((0, _object.clone)(x.toArray())); // TODO: return the same matrix type as x\n\n return matrix(flat);\n }\n });\n});\nexports.createFlatten = createFlatten;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createForEach = void 0;\n\nvar _function = require(\"../../utils/function.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'forEach';\nvar dependencies = ['typed'];\nvar createForEach = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Iterate over all elements of a matrix/array, and executes the given callback function.\n *\n * Syntax:\n *\n * math.forEach(x, callback)\n *\n * Examples:\n *\n * math.forEach([1, 2, 3], function(value) {\n * console.log(value)\n * })\n * // outputs 1, 2, 3\n *\n * See also:\n *\n * filter, map, sort\n *\n * @param {Matrix | Array} x The matrix to iterate on.\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix/array being traversed.\n */\n return typed(name, {\n 'Array, function': _forEach,\n 'Matrix, function': function MatrixFunction(x, callback) {\n return x.forEach(callback);\n }\n });\n});\n/**\n * forEach for a multi dimensional array\n * @param {Array} array\n * @param {Function} callback\n * @private\n */\n\nexports.createForEach = createForEach;\n\nfunction _forEach(array, callback) {\n // figure out what number of arguments the callback function expects\n var args = (0, _function.maxArgumentCount)(callback);\n\n var recurse = function recurse(value, index) {\n if (Array.isArray(value)) {\n (0, _array.forEach)(value, function (child, i) {\n // we create a copy of the index array and append the new index value\n recurse(child, index.concat(i));\n });\n } else {\n // invoke the callback function with the right number of arguments\n if (args === 1) {\n callback(value);\n } else if (args === 2) {\n callback(value, index);\n } else {\n // 3 or -1\n callback(value, index, array);\n }\n }\n };\n\n recurse(array, []);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createGetMatrixDataType = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar name = 'getMatrixDataType';\nvar dependencies = ['typed'];\nvar createGetMatrixDataType = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Find the data type of all elements in a matrix or array,\n * for example 'number' if all items are a number and 'Complex' if all values\n * are complex numbers.\n * If a matrix contains more than one data type, it will return 'mixed'.\n *\n * Syntax:\n *\n * math.getMatrixDataType(x)\n *\n * Examples:\n *\n * const x = [ [1, 2, 3], [4, 5, 6] ]\n * const mixedX = [ [1, true], [2, 3] ]\n * const fractionX = [ [math.fraction(1, 3)], [math.fraction(1, 3] ]\n * const unitX = [ [math.unit('5cm')], [math.unit('5cm')] ]\n * const bigNumberX = [ [math.bignumber(1)], [math.bignumber(0)] ]\n * const sparse = math.sparse(x)\n * const dense = math.matrix(x)\n * math.getMatrixDataType(x) // returns 'number'\n * math.getMatrixDataType(sparse) // returns 'number'\n * math.getMatrixDataType(dense) // returns 'number'\n * math.getMatrixDataType(mixedX) // returns 'mixed'\n * math.getMatrixDataType(fractionX) // returns 'Fraction'\n * math.getMatrixDataType(unitX) // returns 'Unit'\n * math.getMatrixDataType(bigNumberX) // return 'BigNumber'\n *\n * See also:\n * SparseMatrix, DenseMatrix\n *\n * @param {...Matrix | Array} x The Matrix with values.\n *\n * @return {string} A string representation of the matrix type\n */\n return typed(name, {\n Array: function Array(x) {\n return (0, _array.getArrayDataType)(x, _is.typeOf);\n },\n Matrix: function Matrix(x) {\n return x.getDataType();\n }\n });\n});\nexports.createGetMatrixDataType = createGetMatrixDataType;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIdentity = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'identity';\nvar dependencies = ['typed', 'config', 'matrix', 'BigNumber', 'DenseMatrix', 'SparseMatrix'];\nvar createIdentity = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n matrix = _ref.matrix,\n BigNumber = _ref.BigNumber,\n DenseMatrix = _ref.DenseMatrix,\n SparseMatrix = _ref.SparseMatrix;\n\n /**\n * Create a 2-dimensional identity matrix with size m x n or n x n.\n * The matrix has ones on the diagonal and zeros elsewhere.\n *\n * Syntax:\n *\n * math.identity(n)\n * math.identity(n, format)\n * math.identity(m, n)\n * math.identity(m, n, format)\n * math.identity([m, n])\n * math.identity([m, n], format)\n *\n * Examples:\n *\n * math.identity(3) // returns [[1, 0, 0], [0, 1, 0], [0, 0, 1]]\n * math.identity(3, 2) // returns [[1, 0], [0, 1], [0, 0]]\n *\n * const A = [[1, 2, 3], [4, 5, 6]]\n * math.identity(math.size(A)) // returns [[1, 0, 0], [0, 1, 0]]\n *\n * See also:\n *\n * diag, ones, zeros, size, range\n *\n * @param {...number | Matrix | Array} size The size for the matrix\n * @param {string} [format] The Matrix storage format\n *\n * @return {Matrix | Array | number} A matrix with ones on the diagonal.\n */\n return typed(name, {\n '': function _() {\n return config.matrix === 'Matrix' ? matrix([]) : [];\n },\n string: function string(format) {\n return matrix(format);\n },\n 'number | BigNumber': function numberBigNumber(rows) {\n return _identity(rows, rows, config.matrix === 'Matrix' ? 'dense' : undefined);\n },\n 'number | BigNumber, string': function numberBigNumberString(rows, format) {\n return _identity(rows, rows, format);\n },\n 'number | BigNumber, number | BigNumber': function numberBigNumberNumberBigNumber(rows, cols) {\n return _identity(rows, cols, config.matrix === 'Matrix' ? 'dense' : undefined);\n },\n 'number | BigNumber, number | BigNumber, string': function numberBigNumberNumberBigNumberString(rows, cols, format) {\n return _identity(rows, cols, format);\n },\n Array: function Array(size) {\n return _identityVector(size);\n },\n 'Array, string': function ArrayString(size, format) {\n return _identityVector(size, format);\n },\n Matrix: function Matrix(size) {\n return _identityVector(size.valueOf(), size.storage());\n },\n 'Matrix, string': function MatrixString(size, format) {\n return _identityVector(size.valueOf(), format);\n }\n });\n\n function _identityVector(size, format) {\n switch (size.length) {\n case 0:\n return format ? matrix(format) : [];\n\n case 1:\n return _identity(size[0], size[0], format);\n\n case 2:\n return _identity(size[0], size[1], format);\n\n default:\n throw new Error('Vector containing two values expected');\n }\n }\n /**\n * Create an identity matrix\n * @param {number | BigNumber} rows\n * @param {number | BigNumber} cols\n * @param {string} [format]\n * @returns {Matrix}\n * @private\n */\n\n\n function _identity(rows, cols, format) {\n // BigNumber constructor with the right precision\n var Big = (0, _is.isBigNumber)(rows) || (0, _is.isBigNumber)(cols) ? BigNumber : null;\n if ((0, _is.isBigNumber)(rows)) rows = rows.toNumber();\n if ((0, _is.isBigNumber)(cols)) cols = cols.toNumber();\n\n if (!(0, _number.isInteger)(rows) || rows < 1) {\n throw new Error('Parameters in function identity must be positive integers');\n }\n\n if (!(0, _number.isInteger)(cols) || cols < 1) {\n throw new Error('Parameters in function identity must be positive integers');\n }\n\n var one = Big ? new BigNumber(1) : 1;\n var defaultValue = Big ? new Big(0) : 0;\n var size = [rows, cols]; // check we need to return a matrix\n\n if (format) {\n // create diagonal matrix (use optimized implementation for storage format)\n if (format === 'sparse') {\n return SparseMatrix.diagonal(size, one, 0, defaultValue);\n }\n\n if (format === 'dense') {\n return DenseMatrix.diagonal(size, one, 0, defaultValue);\n }\n\n throw new TypeError(\"Unknown matrix type \\\"\".concat(format, \"\\\"\"));\n } // create and resize array\n\n\n var res = (0, _array.resize)([], size, defaultValue); // fill in ones on the diagonal\n\n var minimum = rows < cols ? rows : cols; // fill diagonal\n\n for (var d = 0; d < minimum; d++) {\n res[d][d] = one;\n }\n\n return res;\n }\n});\nexports.createIdentity = createIdentity;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIfft = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar name = 'ifft';\nvar dependencies = ['typed', 'fft', 'dotDivide', 'conj'];\nvar createIfft = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n fft = _ref.fft,\n dotDivide = _ref.dotDivide,\n conj = _ref.conj;\n\n /**\n * Calculate N-dimensional inverse fourier transform\n *\n * Syntax:\n *\n * math.ifft(arr)\n *\n * Examples:\n *\n * math.ifft([[2, 2], [0, 0]]) // returns [[{re:1, im:0}, {re:0, im:0}], [{re:1, im:0}, {re:0, im:0}]]\n *\n * See Also:\n *\n * fft\n *\n * @param {Array | Matrix} arr An array or matrix\n * @return {Array | Matrix} N-dimensional fourier transformation of the array\n */\n return typed(name, {\n 'Array | Matrix': function ArrayMatrix(arr) {\n var size = (0, _is.isMatrix)(arr) ? arr.size() : (0, _array.arraySize)(arr);\n return dotDivide(conj(fft(conj(arr))), size.reduce(function (acc, curr) {\n return acc * curr;\n }, 1));\n }\n });\n});\nexports.createIfft = createIfft;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createInv = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar name = 'inv';\nvar dependencies = ['typed', 'matrix', 'divideScalar', 'addScalar', 'multiply', 'unaryMinus', 'det', 'identity', 'abs'];\nvar createInv = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n divideScalar = _ref.divideScalar,\n addScalar = _ref.addScalar,\n multiply = _ref.multiply,\n unaryMinus = _ref.unaryMinus,\n det = _ref.det,\n identity = _ref.identity,\n abs = _ref.abs;\n\n /**\n * Calculate the inverse of a square matrix.\n *\n * Syntax:\n *\n * math.inv(x)\n *\n * Examples:\n *\n * math.inv([[1, 2], [3, 4]]) // returns [[-2, 1], [1.5, -0.5]]\n * math.inv(4) // returns 0.25\n * 1 / 4 // returns 0.25\n *\n * See also:\n *\n * det, transpose\n *\n * @param {number | Complex | Array | Matrix} x Matrix to be inversed\n * @return {number | Complex | Array | Matrix} The inverse of `x`.\n */\n return typed(name, {\n 'Array | Matrix': function ArrayMatrix(x) {\n var size = (0, _is.isMatrix)(x) ? x.size() : (0, _array.arraySize)(x);\n\n switch (size.length) {\n case 1:\n // vector\n if (size[0] === 1) {\n if ((0, _is.isMatrix)(x)) {\n return matrix([divideScalar(1, x.valueOf()[0])]);\n } else {\n return [divideScalar(1, x[0])];\n }\n } else {\n throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n\n case 2:\n // two dimensional array\n {\n var rows = size[0];\n var cols = size[1];\n\n if (rows === cols) {\n if ((0, _is.isMatrix)(x)) {\n return matrix(_inv(x.valueOf(), rows, cols), x.storage());\n } else {\n // return an Array\n return _inv(x, rows, cols);\n }\n } else {\n throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n }\n\n default:\n // multi dimensional array\n throw new RangeError('Matrix must be two dimensional ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n },\n any: function any(x) {\n // scalar\n return divideScalar(1, x); // FIXME: create a BigNumber one when configured for bignumbers\n }\n });\n /**\n * Calculate the inverse of a square matrix\n * @param {Array[]} mat A square matrix\n * @param {number} rows Number of rows\n * @param {number} cols Number of columns, must equal rows\n * @return {Array[]} inv Inverse matrix\n * @private\n */\n\n function _inv(mat, rows, cols) {\n var r, s, f, value, temp;\n\n if (rows === 1) {\n // this is a 1 x 1 matrix\n value = mat[0][0];\n\n if (value === 0) {\n throw Error('Cannot calculate inverse, determinant is zero');\n }\n\n return [[divideScalar(1, value)]];\n } else if (rows === 2) {\n // this is a 2 x 2 matrix\n var d = det(mat);\n\n if (d === 0) {\n throw Error('Cannot calculate inverse, determinant is zero');\n }\n\n return [[divideScalar(mat[1][1], d), divideScalar(unaryMinus(mat[0][1]), d)], [divideScalar(unaryMinus(mat[1][0]), d), divideScalar(mat[0][0], d)]];\n } else {\n // this is a matrix of 3 x 3 or larger\n // calculate inverse using gauss-jordan elimination\n // https://en.wikipedia.org/wiki/Gaussian_elimination\n // http://mathworld.wolfram.com/MatrixInverse.html\n // http://math.uww.edu/~mcfarlat/inverse.htm\n // make a copy of the matrix (only the arrays, not of the elements)\n var A = mat.concat();\n\n for (r = 0; r < rows; r++) {\n A[r] = A[r].concat();\n } // create an identity matrix which in the end will contain the\n // matrix inverse\n\n\n var B = identity(rows).valueOf(); // loop over all columns, and perform row reductions\n\n for (var c = 0; c < cols; c++) {\n // Pivoting: Swap row c with row r, where row r contains the largest element A[r][c]\n var ABig = abs(A[c][c]);\n var rBig = c;\n r = c + 1;\n\n while (r < rows) {\n if (abs(A[r][c]) > ABig) {\n ABig = abs(A[r][c]);\n rBig = r;\n }\n\n r++;\n }\n\n if (ABig === 0) {\n throw Error('Cannot calculate inverse, determinant is zero');\n }\n\n r = rBig;\n\n if (r !== c) {\n temp = A[c];\n A[c] = A[r];\n A[r] = temp;\n temp = B[c];\n B[c] = B[r];\n B[r] = temp;\n } // eliminate non-zero values on the other rows at column c\n\n\n var Ac = A[c];\n var Bc = B[c];\n\n for (r = 0; r < rows; r++) {\n var Ar = A[r];\n var Br = B[r];\n\n if (r !== c) {\n // eliminate value at column c and row r\n if (Ar[c] !== 0) {\n f = divideScalar(unaryMinus(Ar[c]), Ac[c]); // add (f * row c) to row r to eliminate the value\n // at column c\n\n for (s = c; s < cols; s++) {\n Ar[s] = addScalar(Ar[s], multiply(f, Ac[s]));\n }\n\n for (s = 0; s < cols; s++) {\n Br[s] = addScalar(Br[s], multiply(f, Bc[s]));\n }\n }\n } else {\n // normalize value at Acc to 1,\n // divide each value on row r with the value at Acc\n f = Ac[c];\n\n for (s = c; s < cols; s++) {\n Ar[s] = divideScalar(Ar[s], f);\n }\n\n for (s = 0; s < cols; s++) {\n Br[s] = divideScalar(Br[s], f);\n }\n }\n }\n }\n\n return B;\n }\n }\n});\nexports.createInv = createInv;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createKron = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'kron';\nvar dependencies = ['typed', 'matrix', 'multiplyScalar'];\nvar createKron = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n multiplyScalar = _ref.multiplyScalar;\n\n /**\n * Calculates the kronecker product of 2 matrices or vectors.\n *\n * NOTE: If a one dimensional vector / matrix is given, it will be\n * wrapped so its two dimensions.\n * See the examples.\n *\n * Syntax:\n *\n * math.kron(x, y)\n *\n * Examples:\n *\n * math.kron([[1, 0], [0, 1]], [[1, 2], [3, 4]])\n * // returns [ [ 1, 2, 0, 0 ], [ 3, 4, 0, 0 ], [ 0, 0, 1, 2 ], [ 0, 0, 3, 4 ] ]\n *\n * math.kron([1,1], [2,3,4])\n * // returns [ [ 2, 3, 4, 2, 3, 4 ] ]\n *\n * See also:\n *\n * multiply, dot, cross\n *\n * @param {Array | Matrix} x First vector\n * @param {Array | Matrix} y Second vector\n * @return {Array | Matrix} Returns the kronecker product of `x` and `y`\n */\n return typed(name, {\n 'Matrix, Matrix': function MatrixMatrix(x, y) {\n return matrix(_kron(x.toArray(), y.toArray()));\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n return matrix(_kron(x.toArray(), y));\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n return matrix(_kron(x, y.toArray()));\n },\n 'Array, Array': _kron\n });\n /**\n * Calculate the kronecker product of two matrices / vectors\n * @param {Array} a First vector\n * @param {Array} b Second vector\n * @returns {Array} Returns the kronecker product of x and y\n * @private\n */\n\n function _kron(a, b) {\n // Deal with the dimensions of the matricies.\n if ((0, _array.arraySize)(a).length === 1) {\n // Wrap it in a 2D Matrix\n a = [a];\n }\n\n if ((0, _array.arraySize)(b).length === 1) {\n // Wrap it in a 2D Matrix\n b = [b];\n }\n\n if ((0, _array.arraySize)(a).length > 2 || (0, _array.arraySize)(b).length > 2) {\n throw new RangeError('Vectors with dimensions greater then 2 are not supported expected ' + '(Size x = ' + JSON.stringify(a.length) + ', y = ' + JSON.stringify(b.length) + ')');\n }\n\n var t = [];\n var r = [];\n return a.map(function (a) {\n return b.map(function (b) {\n r = [];\n t.push(r);\n return a.map(function (y) {\n return b.map(function (x) {\n return r.push(multiplyScalar(y, x));\n });\n });\n });\n }) && t;\n }\n});\nexports.createKron = createKron;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMap = void 0;\n\nvar _function = require(\"../../utils/function.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'map';\nvar dependencies = ['typed'];\nvar createMap = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Create a new matrix or array with the results of a callback function executed on\n * each entry of a given matrix/array.\n *\n * For each entry of the input, the callback is invoked with three arguments:\n * the value of the entry, the index at which that entry occurs, and the full\n * matrix/array being traversed. Note that because the matrix/array might be\n * multidimensional, the \"index\" argument is always an array of numbers giving\n * the index in each dimension. This is true even for vectors: the \"index\"\n * argument is an array of length 1, rather than simply a number.\n *\n * Syntax:\n *\n * math.map(x, callback)\n *\n * Examples:\n *\n * math.map([1, 2, 3], function(value) {\n * return value * value\n * }) // returns [1, 4, 9]\n *\n * // The calling convention for the callback can cause subtleties:\n * math.map([1, 2, 3], math.format)\n * // throws TypeError: map attempted to call 'format(1,[0])' but argument 2 of type Array does not match expected type number or function or Object or string or boolean\n * // [This happens because `format` _can_ take a second argument,\n * // but its semantics don't match that of the 2nd argument `map` provides]\n *\n * // To avoid this error, use a function that takes exactly the\n * // desired arguments:\n * math.map([1, 2, 3], x => math.format(x)) // returns ['1', '2', '3']\n *\n * See also:\n *\n * filter, forEach, sort\n *\n * @param {Matrix | Array} x The input to iterate on.\n * @param {Function} callback\n * The function to call (as described above) on each entry of the input\n * @return {Matrix | array}\n * Transformed map of x; always has the same type and shape as x\n */\n return typed(name, {\n 'Array, function': _map,\n 'Matrix, function': function MatrixFunction(x, callback) {\n return x.map(callback);\n }\n });\n});\n/**\n * Map for a multi dimensional array\n * @param {Array} array\n * @param {Function} callback\n * @return {Array}\n * @private\n */\n\nexports.createMap = createMap;\n\nfunction _map(array, callback) {\n // figure out what number of arguments the callback function expects\n var args = (0, _function.maxArgumentCount)(callback);\n\n var recurse = function recurse(value, index) {\n if (Array.isArray(value)) {\n return value.map(function (child, i) {\n // we create a copy of the index array and append the new index value\n return recurse(child, index.concat(i));\n });\n } else {\n try {\n // invoke the callback function with the right number of arguments\n if (args === 1) {\n return callback(value);\n } else if (args === 2) {\n return callback(value, index);\n } else {\n // 3 or -1\n return callback(value, index, array);\n }\n } catch (err) {\n // But maybe the arguments still weren't right\n if (err instanceof TypeError && 'data' in err && err.data.category === 'wrongType') {\n var newmsg = \"map attempted to call '\".concat(err.data.fn, \"(\").concat(value);\n var indexString = JSON.stringify(index);\n\n if (args === 2) {\n newmsg += ',' + indexString;\n } else if (args !== 1) {\n newmsg += \",\".concat(indexString, \",\").concat(array);\n }\n\n newmsg += \")' but argument \".concat(err.data.index + 1, \" of type \");\n newmsg += \"\".concat(err.data.actual, \" does not match expected type \");\n newmsg += err.data.expected.join(' or ');\n throw new TypeError(newmsg);\n }\n\n throw err;\n }\n }\n };\n\n return recurse(array, []);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMatrixFromColumns = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { 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 = it.call(o); }, 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\nvar name = 'matrixFromColumns';\nvar dependencies = ['typed', 'matrix', 'flatten', 'size'];\nvar createMatrixFromColumns = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n flatten = _ref.flatten,\n size = _ref.size;\n\n /**\n * Create a dense matrix from vectors as individual columns.\n * If you pass row vectors, they will be transposed (but not conjugated!)\n *\n * Syntax:\n *\n * math.matrixFromColumns(...arr)\n * math.matrixFromColumns(col1, col2)\n * math.matrixFromColumns(col1, col2, col3)\n *\n * Examples:\n *\n * math.matrixFromColumns([1, 2, 3], [[4],[5],[6]])\n * math.matrixFromColumns(...vectors)\n *\n * See also:\n *\n * matrix, matrixFromRows, matrixFromFunction, zeros\n *\n * @param {... Array | Matrix} cols Multiple columns\n * @return { number[][] | Matrix } if at least one of the arguments is an array, an array will be returned\n */\n return typed(name, {\n '...Array': function Array(arr) {\n return _createArray(arr);\n },\n '...Matrix': function Matrix(arr) {\n return matrix(_createArray(arr.map(function (m) {\n return m.toArray();\n })));\n } // TODO implement this properly for SparseMatrix\n\n });\n\n function _createArray(arr) {\n if (arr.length === 0) throw new TypeError('At least one column is needed to construct a matrix.');\n var N = checkVectorTypeAndReturnLength(arr[0]); // create an array with empty rows\n\n var result = [];\n\n for (var i = 0; i < N; i++) {\n result[i] = [];\n } // loop columns\n\n\n var _iterator = _createForOfIteratorHelper(arr),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var col = _step.value;\n var colLength = checkVectorTypeAndReturnLength(col);\n\n if (colLength !== N) {\n throw new TypeError('The vectors had different length: ' + (N | 0) + ' ≠ ' + (colLength | 0));\n }\n\n var f = flatten(col); // push a value to each row\n\n for (var _i = 0; _i < N; _i++) {\n result[_i].push(f[_i]);\n }\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n return result;\n }\n\n function checkVectorTypeAndReturnLength(vec) {\n var s = size(vec);\n\n if (s.length === 1) {\n // 1D vector\n return s[0];\n } else if (s.length === 2) {\n // 2D vector\n if (s[0] === 1) {\n // row vector\n return s[1];\n } else if (s[1] === 1) {\n // col vector\n return s[0];\n } else {\n throw new TypeError('At least one of the arguments is not a vector.');\n }\n } else {\n throw new TypeError('Only one- or two-dimensional vectors are supported.');\n }\n }\n});\nexports.createMatrixFromColumns = createMatrixFromColumns;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMatrixFromFunction = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'matrixFromFunction';\nvar dependencies = ['typed', 'matrix', 'isZero'];\nvar createMatrixFromFunction = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n isZero = _ref.isZero;\n\n /**\n * Create a matrix by evaluating a generating function at each index.\n * The simplest overload returns a multi-dimensional array as long as `size` is an array.\n * Passing `size` as a Matrix or specifying a `format` will result in returning a Matrix.\n *\n * Syntax:\n *\n * math.matrixFromFunction(size, fn)\n * math.matrixFromFunction(size, fn, format)\n * math.matrixFromFunction(size, fn, format, datatype)\n * math.matrixFromFunction(size, format, fn)\n * math.matrixFromFunction(size, format, datatype, fn)\n *\n * Examples:\n *\n * math.matrixFromFunction([3,3], i => i[0] - i[1]) // an antisymmetric matrix\n * math.matrixFromFunction([100, 100], 'sparse', i => i[0] - i[1] === 1 ? 4 : 0) // a sparse subdiagonal matrix\n * math.matrixFromFunction([5], i => math.random()) // a random vector\n *\n * See also:\n *\n * matrix, zeros\n *\n * @param {Array | Matrix} size The size of the matrix to be created\n * @param {function} fn Callback function invoked for every entry in the matrix\n * @param {string} [format] The Matrix storage format, either `'dense'` or `'sparse'`\n * @param {string} [datatype] Type of the values\n * @return {Array | Matrix} Returns the created matrix\n */\n return typed(name, {\n 'Array | Matrix, function, string, string': function ArrayMatrixFunctionStringString(size, fn, format, datatype) {\n return _create(size, fn, format, datatype);\n },\n 'Array | Matrix, function, string': function ArrayMatrixFunctionString(size, fn, format) {\n return _create(size, fn, format);\n },\n 'Matrix, function': function MatrixFunction(size, fn) {\n return _create(size, fn, 'dense');\n },\n 'Array, function': function ArrayFunction(size, fn) {\n return _create(size, fn, 'dense').toArray();\n },\n 'Array | Matrix, string, function': function ArrayMatrixStringFunction(size, format, fn) {\n return _create(size, fn, format);\n },\n 'Array | Matrix, string, string, function': function ArrayMatrixStringStringFunction(size, format, datatype, fn) {\n return _create(size, fn, format, datatype);\n }\n });\n\n function _create(size, fn, format, datatype) {\n var m;\n\n if (datatype !== undefined) {\n m = matrix(format, datatype);\n } else {\n m = matrix(format);\n }\n\n m.resize(size);\n m.forEach(function (_, index) {\n var val = fn(index);\n if (isZero(val)) return;\n m.set(index, val);\n });\n return m;\n }\n});\nexports.createMatrixFromFunction = createMatrixFromFunction;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMatrixFromRows = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { 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 = it.call(o); }, 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\nvar name = 'matrixFromRows';\nvar dependencies = ['typed', 'matrix', 'flatten', 'size'];\nvar createMatrixFromRows = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n flatten = _ref.flatten,\n size = _ref.size;\n\n /**\n * Create a dense matrix from vectors as individual rows.\n * If you pass column vectors, they will be transposed (but not conjugated!)\n *\n * Syntax:\n *\n * math.matrixFromRows(...arr)\n * math.matrixFromRows(row1, row2)\n * math.matrixFromRows(row1, row2, row3)\n *\n * Examples:\n *\n * math.matrixFromRows([1, 2, 3], [[4],[5],[6]])\n * math.matrixFromRows(...vectors)\n *\n * See also:\n *\n * matrix, matrixFromColumns, matrixFromFunction, zeros\n *\n * @param {... Array | Matrix} rows Multiple rows\n * @return { number[][] | Matrix } if at least one of the arguments is an array, an array will be returned\n */\n return typed(name, {\n '...Array': function Array(arr) {\n return _createArray(arr);\n },\n '...Matrix': function Matrix(arr) {\n return matrix(_createArray(arr.map(function (m) {\n return m.toArray();\n })));\n } // TODO implement this properly for SparseMatrix\n\n });\n\n function _createArray(arr) {\n if (arr.length === 0) throw new TypeError('At least one row is needed to construct a matrix.');\n var N = checkVectorTypeAndReturnLength(arr[0]);\n var result = [];\n\n var _iterator = _createForOfIteratorHelper(arr),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var row = _step.value;\n var rowLength = checkVectorTypeAndReturnLength(row);\n\n if (rowLength !== N) {\n throw new TypeError('The vectors had different length: ' + (N | 0) + ' ≠ ' + (rowLength | 0));\n }\n\n result.push(flatten(row));\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n return result;\n }\n\n function checkVectorTypeAndReturnLength(vec) {\n var s = size(vec);\n\n if (s.length === 1) {\n // 1D vector\n return s[0];\n } else if (s.length === 2) {\n // 2D vector\n if (s[0] === 1) {\n // row vector\n return s[1];\n } else if (s[1] === 1) {\n // col vector\n return s[0];\n } else {\n throw new TypeError('At least one of the arguments is not a vector.');\n }\n } else {\n throw new TypeError('Only one- or two-dimensional vectors are supported.');\n }\n }\n});\nexports.createMatrixFromRows = createMatrixFromRows;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createOnes = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'ones';\nvar dependencies = ['typed', 'config', 'matrix', 'BigNumber'];\nvar createOnes = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n matrix = _ref.matrix,\n BigNumber = _ref.BigNumber;\n\n /**\n * Create a matrix filled with ones. The created matrix can have one or\n * multiple dimensions.\n *\n * Syntax:\n *\n * math.ones(m)\n * math.ones(m, format)\n * math.ones(m, n)\n * math.ones(m, n, format)\n * math.ones([m, n])\n * math.ones([m, n], format)\n * math.ones([m, n, p, ...])\n * math.ones([m, n, p, ...], format)\n *\n * Examples:\n *\n * math.ones(3) // returns [1, 1, 1]\n * math.ones(3, 2) // returns [[1, 1], [1, 1], [1, 1]]\n * math.ones(3, 2, 'dense') // returns Dense Matrix [[1, 1], [1, 1], [1, 1]]\n *\n * const A = [[1, 2, 3], [4, 5, 6]]\n * math.ones(math.size(A)) // returns [[1, 1, 1], [1, 1, 1]]\n *\n * See also:\n *\n * zeros, identity, size, range\n *\n * @param {...number | Array} size The size of each dimension of the matrix\n * @param {string} [format] The Matrix storage format\n *\n * @return {Array | Matrix | number} A matrix filled with ones\n */\n return typed('ones', {\n '': function _() {\n return config.matrix === 'Array' ? _ones([]) : _ones([], 'default');\n },\n // math.ones(m, n, p, ..., format)\n // TODO: more accurate signature '...number | BigNumber, string' as soon as typed-function supports this\n '...number | BigNumber | string': function numberBigNumberString(size) {\n var last = size[size.length - 1];\n\n if (typeof last === 'string') {\n var format = size.pop();\n return _ones(size, format);\n } else if (config.matrix === 'Array') {\n return _ones(size);\n } else {\n return _ones(size, 'default');\n }\n },\n Array: _ones,\n Matrix: function Matrix(size) {\n var format = size.storage();\n return _ones(size.valueOf(), format);\n },\n 'Array | Matrix, string': function ArrayMatrixString(size, format) {\n return _ones(size.valueOf(), format);\n }\n });\n /**\n * Create an Array or Matrix with ones\n * @param {Array} size\n * @param {string} [format='default']\n * @return {Array | Matrix}\n * @private\n */\n\n function _ones(size, format) {\n var hasBigNumbers = _normalize(size);\n\n var defaultValue = hasBigNumbers ? new BigNumber(1) : 1;\n\n _validate(size);\n\n if (format) {\n // return a matrix\n var m = matrix(format);\n\n if (size.length > 0) {\n return m.resize(size, defaultValue);\n }\n\n return m;\n } else {\n // return an Array\n var arr = [];\n\n if (size.length > 0) {\n return (0, _array.resize)(arr, size, defaultValue);\n }\n\n return arr;\n }\n } // replace BigNumbers with numbers, returns true if size contained BigNumbers\n\n\n function _normalize(size) {\n var hasBigNumbers = false;\n size.forEach(function (value, index, arr) {\n if ((0, _is.isBigNumber)(value)) {\n hasBigNumbers = true;\n arr[index] = value.toNumber();\n }\n });\n return hasBigNumbers;\n } // validate arguments\n\n\n function _validate(size) {\n size.forEach(function (value) {\n if (typeof value !== 'number' || !(0, _number.isInteger)(value) || value < 0) {\n throw new Error('Parameters in function ones must be positive integers');\n }\n });\n }\n});\nexports.createOnes = createOnes;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createPartitionSelect = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'partitionSelect';\nvar dependencies = ['typed', 'isNumeric', 'isNaN', 'compare'];\nvar createPartitionSelect = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n isNumeric = _ref.isNumeric,\n isNaN = _ref.isNaN,\n compare = _ref.compare;\n var asc = compare;\n\n var desc = function desc(a, b) {\n return -compare(a, b);\n };\n /**\n * Partition-based selection of an array or 1D matrix.\n * Will find the kth smallest value, and mutates the input array.\n * Uses Quickselect.\n *\n * Syntax:\n *\n * math.partitionSelect(x, k)\n * math.partitionSelect(x, k, compare)\n *\n * Examples:\n *\n * math.partitionSelect([5, 10, 1], 2) // returns 10\n * math.partitionSelect(['C', 'B', 'A', 'D'], 1) // returns 'B'\n *\n * function sortByLength (a, b) {\n * return a.length - b.length\n * }\n * math.partitionSelect(['Langdon', 'Tom', 'Sara'], 2, sortByLength) // returns 'Langdon'\n *\n * See also:\n *\n * sort\n *\n * @param {Matrix | Array} x A one dimensional matrix or array to sort\n * @param {Number} k The kth smallest value to be retrieved zero-based index\n * @param {Function | 'asc' | 'desc'} [compare='asc']\n * An optional comparator function. The function is called as\n * `compare(a, b)`, and must return 1 when a > b, -1 when a < b,\n * and 0 when a == b.\n * @return {*} Returns the kth lowest value.\n */\n\n\n return typed(name, {\n 'Array | Matrix, number': function ArrayMatrixNumber(x, k) {\n return _partitionSelect(x, k, asc);\n },\n 'Array | Matrix, number, string': function ArrayMatrixNumberString(x, k, compare) {\n if (compare === 'asc') {\n return _partitionSelect(x, k, asc);\n } else if (compare === 'desc') {\n return _partitionSelect(x, k, desc);\n } else {\n throw new Error('Compare string must be \"asc\" or \"desc\"');\n }\n },\n 'Array | Matrix, number, function': _partitionSelect\n });\n\n function _partitionSelect(x, k, compare) {\n if (!(0, _number.isInteger)(k) || k < 0) {\n throw new Error('k must be a non-negative integer');\n }\n\n if ((0, _is.isMatrix)(x)) {\n var size = x.size();\n\n if (size.length > 1) {\n throw new Error('Only one dimensional matrices supported');\n }\n\n return quickSelect(x.valueOf(), k, compare);\n }\n\n if (Array.isArray(x)) {\n return quickSelect(x, k, compare);\n }\n }\n /**\n * Quickselect algorithm.\n * Code adapted from:\n * https://blog.teamleadnet.com/2012/07/quick-select-algorithm-find-kth-element.html\n *\n * @param {Array} arr\n * @param {Number} k\n * @param {Function} compare\n * @private\n */\n\n\n function quickSelect(arr, k, compare) {\n if (k >= arr.length) {\n throw new Error('k out of bounds');\n } // check for NaN values since these can cause an infinite while loop\n\n\n for (var i = 0; i < arr.length; i++) {\n if (isNumeric(arr[i]) && isNaN(arr[i])) {\n return arr[i]; // return NaN\n }\n }\n\n var from = 0;\n var to = arr.length - 1; // if from == to we reached the kth element\n\n while (from < to) {\n var r = from;\n var w = to;\n var pivot = arr[Math.floor(Math.random() * (to - from + 1)) + from]; // stop if the reader and writer meets\n\n while (r < w) {\n // arr[r] >= pivot\n if (compare(arr[r], pivot) >= 0) {\n // put the large values at the end\n var tmp = arr[w];\n arr[w] = arr[r];\n arr[r] = tmp;\n --w;\n } else {\n // the value is smaller than the pivot, skip\n ++r;\n }\n } // if we stepped up (r++) we need to step one down (arr[r] > pivot)\n\n\n if (compare(arr[r], pivot) > 0) {\n --r;\n } // the r pointer is on the end of the first k elements\n\n\n if (k <= r) {\n to = r;\n } else {\n from = r + 1;\n }\n }\n\n return arr[k];\n }\n});\nexports.createPartitionSelect = createPartitionSelect;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createPinv = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar name = 'pinv';\nvar dependencies = ['typed', 'matrix', 'inv', 'deepEqual', 'equal', 'dotDivide', 'dot', 'ctranspose', 'divideScalar', 'multiply', 'add', 'Complex'];\nvar createPinv = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n inv = _ref.inv,\n deepEqual = _ref.deepEqual,\n equal = _ref.equal,\n dotDivide = _ref.dotDivide,\n dot = _ref.dot,\n ctranspose = _ref.ctranspose,\n divideScalar = _ref.divideScalar,\n multiply = _ref.multiply,\n add = _ref.add,\n Complex = _ref.Complex;\n\n /**\n * Calculate the Moore–Penrose inverse of a matrix.\n *\n * Syntax:\n *\n * math.pinv(x)\n *\n * Examples:\n *\n * math.pinv([[1, 2], [3, 4]]) // returns [[-2, 1], [1.5, -0.5]]\n * math.pinv([[1, 0], [0, 1], [0, 1]]) // returns [[1, 0, 0], [0, 0.5, 0.5]]\n * math.pinv(4) // returns 0.25\n *\n * See also:\n *\n * inv\n *\n * @param {number | Complex | Array | Matrix} x Matrix to be inversed\n * @return {number | Complex | Array | Matrix} The inverse of `x`.\n */\n return typed(name, {\n 'Array | Matrix': function ArrayMatrix(x) {\n var size = (0, _is.isMatrix)(x) ? x.size() : (0, _array.arraySize)(x);\n\n switch (size.length) {\n case 1:\n // vector\n if (_isZeros(x)) return ctranspose(x); // null vector\n\n if (size[0] === 1) {\n return inv(x); // invertible matrix\n } else {\n return dotDivide(ctranspose(x), dot(x, x));\n }\n\n case 2:\n // two dimensional array\n {\n if (_isZeros(x)) return ctranspose(x); // zero matrixx\n\n var rows = size[0];\n var cols = size[1];\n\n if (rows === cols) {\n try {\n return inv(x); // invertible matrix\n } catch (err) {\n if (err instanceof Error && err.message.match(/Cannot calculate inverse, determinant is zero/)) {// Expected\n } else {\n throw err;\n }\n }\n }\n\n if ((0, _is.isMatrix)(x)) {\n return matrix(_pinv(x.valueOf(), rows, cols), x.storage());\n } else {\n // return an Array\n return _pinv(x, rows, cols);\n }\n }\n\n default:\n // multi dimensional array\n throw new RangeError('Matrix must be two dimensional ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n },\n any: function any(x) {\n // scalar\n if (equal(x, 0)) return (0, _object.clone)(x); // zero\n\n return divideScalar(1, x);\n }\n });\n /**\n * Calculate the Moore–Penrose inverse of a matrix\n * @param {Array[]} mat A matrix\n * @param {number} rows Number of rows\n * @param {number} cols Number of columns\n * @return {Array[]} pinv Pseudoinverse matrix\n * @private\n */\n\n function _pinv(mat, rows, cols) {\n var _rankFact2 = _rankFact(mat, rows, cols),\n C = _rankFact2.C,\n F = _rankFact2.F; // TODO: Use SVD instead (may improve precision)\n\n\n var Cpinv = multiply(inv(multiply(ctranspose(C), C)), ctranspose(C));\n var Fpinv = multiply(ctranspose(F), inv(multiply(F, ctranspose(F))));\n return multiply(Fpinv, Cpinv);\n }\n /**\n * Calculate the reduced row echelon form of a matrix\n *\n * Modified from https://rosettacode.org/wiki/Reduced_row_echelon_form\n *\n * @param {Array[]} mat A matrix\n * @param {number} rows Number of rows\n * @param {number} cols Number of columns\n * @return {Array[]} Reduced row echelon form\n * @private\n */\n\n\n function _rref(mat, rows, cols) {\n var M = (0, _object.clone)(mat);\n var lead = 0;\n\n for (var r = 0; r < rows; r++) {\n if (cols <= lead) {\n return M;\n }\n\n var i = r;\n\n while (_isZero(M[i][lead])) {\n i++;\n\n if (rows === i) {\n i = r;\n lead++;\n\n if (cols === lead) {\n return M;\n }\n }\n }\n\n var _ref2 = [M[r], M[i]];\n M[i] = _ref2[0];\n M[r] = _ref2[1];\n var val = M[r][lead];\n\n for (var j = 0; j < cols; j++) {\n M[r][j] = dotDivide(M[r][j], val);\n }\n\n for (var _i = 0; _i < rows; _i++) {\n if (_i === r) continue;\n val = M[_i][lead];\n\n for (var _j = 0; _j < cols; _j++) {\n M[_i][_j] = add(M[_i][_j], multiply(-1, multiply(val, M[r][_j])));\n }\n }\n\n lead++;\n }\n\n return M;\n }\n /**\n * Calculate the rank factorization of a matrix\n *\n * @param {Array[]} mat A matrix (M)\n * @param {number} rows Number of rows\n * @param {number} cols Number of columns\n * @return {{C: Array, F: Array}} rank factorization where M = C F\n * @private\n */\n\n\n function _rankFact(mat, rows, cols) {\n var rref = _rref(mat, rows, cols);\n\n var C = mat.map(function (_, i) {\n return _.filter(function (_, j) {\n return j < rows && !_isZero(dot(rref[j], rref[j]));\n });\n });\n var F = rref.filter(function (_, i) {\n return !_isZero(dot(rref[i], rref[i]));\n });\n return {\n C: C,\n F: F\n };\n }\n\n function _isZero(x) {\n return equal(add(x, Complex(1, 1)), add(0, Complex(1, 1)));\n }\n\n function _isZeros(arr) {\n return deepEqual(add(arr, Complex(1, 1)), add(multiply(arr, 0), Complex(1, 1)));\n }\n});\nexports.createPinv = createPinv;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRange = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _noop = require(\"../../utils/noop.js\");\n\nvar name = 'range';\nvar dependencies = ['typed', 'config', '?matrix', '?bignumber', 'smaller', 'smallerEq', 'larger', 'largerEq'];\nvar createRange = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n matrix = _ref.matrix,\n bignumber = _ref.bignumber,\n smaller = _ref.smaller,\n smallerEq = _ref.smallerEq,\n larger = _ref.larger,\n largerEq = _ref.largerEq;\n\n /**\n * Create an array from a range.\n * By default, the range end is excluded. This can be customized by providing\n * an extra parameter `includeEnd`.\n *\n * Syntax:\n *\n * math.range(str [, includeEnd]) // Create a range from a string,\n * // where the string contains the\n * // start, optional step, and end,\n * // separated by a colon.\n * math.range(start, end [, includeEnd]) // Create a range with start and\n * // end and a step size of 1.\n * math.range(start, end, step [, includeEnd]) // Create a range with start, step,\n * // and end.\n *\n * Where:\n *\n * - `str: string`\n * A string 'start:end' or 'start:step:end'\n * - `start: {number | BigNumber}`\n * Start of the range\n * - `end: number | BigNumber`\n * End of the range, excluded by default, included when parameter includeEnd=true\n * - `step: number | BigNumber`\n * Step size. Default value is 1.\n * - `includeEnd: boolean`\n * Option to specify whether to include the end or not. False by default.\n *\n * Examples:\n *\n * math.range(2, 6) // [2, 3, 4, 5]\n * math.range(2, -3, -1) // [2, 1, 0, -1, -2]\n * math.range('2:1:6') // [2, 3, 4, 5]\n * math.range(2, 6, true) // [2, 3, 4, 5, 6]\n *\n * See also:\n *\n * ones, zeros, size, subset\n *\n * @param {*} args Parameters describing the ranges `start`, `end`, and optional `step`.\n * @return {Array | Matrix} range\n */\n return typed(name, {\n // TODO: simplify signatures when typed-function supports default values and optional arguments\n // TODO: a number or boolean should not be converted to string here\n string: _strRange,\n 'string, boolean': _strRange,\n 'number, number': function numberNumber(start, end) {\n return _out(_rangeEx(start, end, 1));\n },\n 'number, number, number': function numberNumberNumber(start, end, step) {\n return _out(_rangeEx(start, end, step));\n },\n 'number, number, boolean': function numberNumberBoolean(start, end, includeEnd) {\n return includeEnd ? _out(_rangeInc(start, end, 1)) : _out(_rangeEx(start, end, 1));\n },\n 'number, number, number, boolean': function numberNumberNumberBoolean(start, end, step, includeEnd) {\n return includeEnd ? _out(_rangeInc(start, end, step)) : _out(_rangeEx(start, end, step));\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(start, end) {\n var BigNumber = start.constructor;\n return _out(_bigRangeEx(start, end, new BigNumber(1)));\n },\n 'BigNumber, BigNumber, BigNumber': function BigNumberBigNumberBigNumber(start, end, step) {\n return _out(_bigRangeEx(start, end, step));\n },\n 'BigNumber, BigNumber, boolean': function BigNumberBigNumberBoolean(start, end, includeEnd) {\n var BigNumber = start.constructor;\n return includeEnd ? _out(_bigRangeInc(start, end, new BigNumber(1))) : _out(_bigRangeEx(start, end, new BigNumber(1)));\n },\n 'BigNumber, BigNumber, BigNumber, boolean': function BigNumberBigNumberBigNumberBoolean(start, end, step, includeEnd) {\n return includeEnd ? _out(_bigRangeInc(start, end, step)) : _out(_bigRangeEx(start, end, step));\n }\n });\n\n function _out(arr) {\n if (config.matrix === 'Matrix') {\n return matrix ? matrix(arr) : (0, _noop.noMatrix)();\n }\n\n return arr;\n }\n\n function _strRange(str, includeEnd) {\n var r = _parse(str);\n\n if (!r) {\n throw new SyntaxError('String \"' + str + '\" is no valid range');\n }\n\n var fn;\n\n if (config.number === 'BigNumber') {\n if (bignumber === undefined) {\n (0, _noop.noBignumber)();\n }\n\n fn = includeEnd ? _bigRangeInc : _bigRangeEx;\n return _out(fn(bignumber(r.start), bignumber(r.end), bignumber(r.step)));\n } else {\n fn = includeEnd ? _rangeInc : _rangeEx;\n return _out(fn(r.start, r.end, r.step));\n }\n }\n /**\n * Create a range with numbers. End is excluded\n * @param {number} start\n * @param {number} end\n * @param {number} step\n * @returns {Array} range\n * @private\n */\n\n\n function _rangeEx(start, end, step) {\n var array = [];\n var x = start;\n\n if (step > 0) {\n while (smaller(x, end)) {\n array.push(x);\n x += step;\n }\n } else if (step < 0) {\n while (larger(x, end)) {\n array.push(x);\n x += step;\n }\n }\n\n return array;\n }\n /**\n * Create a range with numbers. End is included\n * @param {number} start\n * @param {number} end\n * @param {number} step\n * @returns {Array} range\n * @private\n */\n\n\n function _rangeInc(start, end, step) {\n var array = [];\n var x = start;\n\n if (step > 0) {\n while (smallerEq(x, end)) {\n array.push(x);\n x += step;\n }\n } else if (step < 0) {\n while (largerEq(x, end)) {\n array.push(x);\n x += step;\n }\n }\n\n return array;\n }\n /**\n * Create a range with big numbers. End is excluded\n * @param {BigNumber} start\n * @param {BigNumber} end\n * @param {BigNumber} step\n * @returns {Array} range\n * @private\n */\n\n\n function _bigRangeEx(start, end, step) {\n var zero = bignumber(0);\n var array = [];\n var x = start;\n\n if (step.gt(zero)) {\n while (smaller(x, end)) {\n array.push(x);\n x = x.plus(step);\n }\n } else if (step.lt(zero)) {\n while (larger(x, end)) {\n array.push(x);\n x = x.plus(step);\n }\n }\n\n return array;\n }\n /**\n * Create a range with big numbers. End is included\n * @param {BigNumber} start\n * @param {BigNumber} end\n * @param {BigNumber} step\n * @returns {Array} range\n * @private\n */\n\n\n function _bigRangeInc(start, end, step) {\n var zero = bignumber(0);\n var array = [];\n var x = start;\n\n if (step.gt(zero)) {\n while (smallerEq(x, end)) {\n array.push(x);\n x = x.plus(step);\n }\n } else if (step.lt(zero)) {\n while (largerEq(x, end)) {\n array.push(x);\n x = x.plus(step);\n }\n }\n\n return array;\n }\n /**\n * Parse a string into a range,\n * The string contains the start, optional step, and end, separated by a colon.\n * If the string does not contain a valid range, null is returned.\n * For example str='0:2:11'.\n * @param {string} str\n * @return {{start: number, end: number, step: number} | null} range Object containing properties start, end, step\n * @private\n */\n\n\n function _parse(str) {\n var args = str.split(':'); // number\n\n var nums = args.map(function (arg) {\n // use Number and not parseFloat as Number returns NaN on invalid garbage in the string\n return Number(arg);\n });\n var invalid = nums.some(function (num) {\n return isNaN(num);\n });\n\n if (invalid) {\n return null;\n }\n\n switch (nums.length) {\n case 2:\n return {\n start: nums[0],\n end: nums[1],\n step: 1\n };\n\n case 3:\n return {\n start: nums[0],\n end: nums[2],\n step: nums[1]\n };\n\n default:\n return null;\n }\n }\n});\nexports.createRange = createRange;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createReshape = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'reshape';\nvar dependencies = ['typed', 'isInteger', 'matrix'];\nvar createReshape = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n isInteger = _ref.isInteger;\n\n /**\n * Reshape a multi dimensional array to fit the specified dimensions\n *\n * Syntax:\n *\n * math.reshape(x, sizes)\n *\n * Examples:\n *\n * math.reshape([1, 2, 3, 4, 5, 6], [2, 3])\n * // returns Array [[1, 2, 3], [4, 5, 6]]\n *\n * math.reshape([[1, 2], [3, 4]], [1, 4])\n * // returns Array [[1, 2, 3, 4]]\n *\n * math.reshape([[1, 2], [3, 4]], [4])\n * // returns Array [1, 2, 3, 4]\n *\n * const x = math.matrix([1, 2, 3, 4, 5, 6, 7, 8])\n * math.reshape(x, [2, 2, 2])\n * // returns Matrix [[[1, 2], [3, 4]], [[5, 6], [7, 8]]]\n *\n * math.reshape([1, 2, 3, 4], [-1, 2])\n * // returns Matrix [[1, 2], [3, 4]]\n *\n * See also:\n *\n * size, squeeze, resize\n *\n * @param {Array | Matrix | *} x Matrix to be reshaped\n * @param {number[]} sizes One dimensional array with integral sizes for\n * each dimension. One -1 is allowed as wildcard,\n * which calculates this dimension automatically.\n *\n * @return {* | Array | Matrix} A reshaped clone of matrix `x`\n *\n * @throws {TypeError} If `sizes` does not contain solely integers\n * @throws {DimensionError} If the product of the new dimension sizes does\n * not equal that of the old ones\n */\n return typed(name, {\n 'Matrix, Array': function MatrixArray(x, sizes) {\n return x.reshape(sizes);\n },\n 'Array, Array': function ArrayArray(x, sizes) {\n sizes.forEach(function (size) {\n if (!isInteger(size)) {\n throw new TypeError('Invalid size for dimension: ' + size);\n }\n });\n return (0, _array.reshape)(x, sizes);\n }\n });\n});\nexports.createReshape = createReshape;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createResize = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _DimensionError = require(\"../../error/DimensionError.js\");\n\nvar _ArgumentsError = require(\"../../error/ArgumentsError.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'resize';\nvar dependencies = ['config', 'matrix'];\nvar createResize = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var config = _ref.config,\n matrix = _ref.matrix;\n\n /**\n * Resize a matrix\n *\n * Syntax:\n *\n * math.resize(x, size)\n * math.resize(x, size, defaultValue)\n *\n * Examples:\n *\n * math.resize([1, 2, 3, 4, 5], [3]) // returns Array [1, 2, 3]\n * math.resize([1, 2, 3], [5], 0) // returns Array [1, 2, 3, 0, 0]\n * math.resize(2, [2, 3], 0) // returns Matrix [[2, 0, 0], [0, 0, 0]]\n * math.resize(\"hello\", [8], \"!\") // returns string 'hello!!!'\n *\n * See also:\n *\n * size, squeeze, subset, reshape\n *\n * @param {Array | Matrix | *} x Matrix to be resized\n * @param {Array | Matrix} size One dimensional array with numbers\n * @param {number | string} [defaultValue=0] Zero by default, except in\n * case of a string, in that case\n * defaultValue = ' '\n * @return {* | Array | Matrix} A resized clone of matrix `x`\n */\n // TODO: rework resize to a typed-function\n return function resize(x, size, defaultValue) {\n if (arguments.length !== 2 && arguments.length !== 3) {\n throw new _ArgumentsError.ArgumentsError('resize', arguments.length, 2, 3);\n }\n\n if ((0, _is.isMatrix)(size)) {\n size = size.valueOf(); // get Array\n }\n\n if ((0, _is.isBigNumber)(size[0])) {\n // convert bignumbers to numbers\n size = size.map(function (value) {\n return !(0, _is.isBigNumber)(value) ? value : value.toNumber();\n });\n } // check x is a Matrix\n\n\n if ((0, _is.isMatrix)(x)) {\n // use optimized matrix implementation, return copy\n return x.resize(size, defaultValue, true);\n }\n\n if (typeof x === 'string') {\n // resize string\n return _resizeString(x, size, defaultValue);\n } // check result should be a matrix\n\n\n var asMatrix = Array.isArray(x) ? false : config.matrix !== 'Array';\n\n if (size.length === 0) {\n // output a scalar\n while (Array.isArray(x)) {\n x = x[0];\n }\n\n return (0, _object.clone)(x);\n } else {\n // output an array/matrix\n if (!Array.isArray(x)) {\n x = [x];\n }\n\n x = (0, _object.clone)(x);\n var res = (0, _array.resize)(x, size, defaultValue);\n return asMatrix ? matrix(res) : res;\n }\n };\n /**\n * Resize a string\n * @param {string} str\n * @param {number[]} size\n * @param {string} [defaultChar=' ']\n * @private\n */\n\n function _resizeString(str, size, defaultChar) {\n if (defaultChar !== undefined) {\n if (typeof defaultChar !== 'string' || defaultChar.length !== 1) {\n throw new TypeError('Single character expected as defaultValue');\n }\n } else {\n defaultChar = ' ';\n }\n\n if (size.length !== 1) {\n throw new _DimensionError.DimensionError(size.length, 1);\n }\n\n var len = size[0];\n\n if (typeof len !== 'number' || !(0, _number.isInteger)(len)) {\n throw new TypeError('Invalid size, must contain positive integers ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n\n if (str.length > len) {\n return str.substring(0, len);\n } else if (str.length < len) {\n var res = str;\n\n for (var i = 0, ii = len - str.length; i < ii; i++) {\n res += defaultChar;\n }\n\n return res;\n } else {\n return str;\n }\n }\n});\nexports.createResize = createResize;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRotate = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar name = 'rotate';\nvar dependencies = ['typed', 'multiply', 'rotationMatrix'];\nvar createRotate = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n multiply = _ref.multiply,\n rotationMatrix = _ref.rotationMatrix;\n\n /**\n * Rotate a vector of size 1x2 counter-clockwise by a given angle\n * Rotate a vector of size 1x3 counter-clockwise by a given angle around the given axis\n *\n * Syntax:\n *\n * math.rotate(w, theta)\n * math.rotate(w, theta, v)\n *\n * Examples:\n *\n * math.rotate([11, 12], math.pi / 2) // returns matrix([-12, 11])\n * math.rotate(matrix([11, 12]), math.pi / 2) // returns matrix([-12, 11])\n *\n * math.rotate([1, 0, 0], unit('90deg'), [0, 0, 1]) // returns matrix([0, 1, 0])\n * math.rotate(matrix([1, 0, 0]), unit('90deg'), [0, 0, 1]) // returns matrix([0, 1, 0])\n *\n * math.rotate([1, 0], math.complex(1 + i)) // returns matrix([cos(1 + i) - sin(1 + i), sin(1 + i) + cos(1 + i)])\n *\n * See also:\n *\n * matrix, rotationMatrix\n *\n * @param {Array | Matrix} w Vector to rotate\n * @param {number | BigNumber | Complex | Unit} theta Rotation angle\n * @param {Array | Matrix} [v] Rotation axis\n * @return {Array | Matrix} Multiplication of the rotation matrix and w\n */\n return typed(name, {\n 'Array , number | BigNumber | Complex | Unit': function ArrayNumberBigNumberComplexUnit(w, theta) {\n _validateSize(w, 2);\n\n var matrixRes = multiply(rotationMatrix(theta), w);\n return matrixRes.toArray();\n },\n 'Matrix , number | BigNumber | Complex | Unit': function MatrixNumberBigNumberComplexUnit(w, theta) {\n _validateSize(w, 2);\n\n return multiply(rotationMatrix(theta), w);\n },\n 'Array, number | BigNumber | Complex | Unit, Array | Matrix': function ArrayNumberBigNumberComplexUnitArrayMatrix(w, theta, v) {\n _validateSize(w, 3);\n\n var matrixRes = multiply(rotationMatrix(theta, v), w);\n return matrixRes;\n },\n 'Matrix, number | BigNumber | Complex | Unit, Array | Matrix': function MatrixNumberBigNumberComplexUnitArrayMatrix(w, theta, v) {\n _validateSize(w, 3);\n\n return multiply(rotationMatrix(theta, v), w);\n }\n });\n\n function _validateSize(v, expectedSize) {\n var actualSize = Array.isArray(v) ? (0, _array.arraySize)(v) : v.size();\n\n if (actualSize.length > 2) {\n throw new RangeError(\"Vector must be of dimensions 1x\".concat(expectedSize));\n }\n\n if (actualSize.length === 2 && actualSize[1] !== 1) {\n throw new RangeError(\"Vector must be of dimensions 1x\".concat(expectedSize));\n }\n\n if (actualSize[0] !== expectedSize) {\n throw new RangeError(\"Vector must be of dimensions 1x\".concat(expectedSize));\n }\n }\n});\nexports.createRotate = createRotate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRotationMatrix = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'rotationMatrix';\nvar dependencies = ['typed', 'config', 'multiplyScalar', 'addScalar', 'unaryMinus', 'norm', 'matrix', 'BigNumber', 'DenseMatrix', 'SparseMatrix', 'cos', 'sin'];\nvar createRotationMatrix = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n multiplyScalar = _ref.multiplyScalar,\n addScalar = _ref.addScalar,\n unaryMinus = _ref.unaryMinus,\n norm = _ref.norm,\n BigNumber = _ref.BigNumber,\n matrix = _ref.matrix,\n DenseMatrix = _ref.DenseMatrix,\n SparseMatrix = _ref.SparseMatrix,\n cos = _ref.cos,\n sin = _ref.sin;\n\n /**\n * Create a 2-dimensional counter-clockwise rotation matrix (2x2) for a given angle (expressed in radians).\n * Create a 2-dimensional counter-clockwise rotation matrix (3x3) by a given angle (expressed in radians) around a given axis (1x3).\n *\n * Syntax:\n *\n * math.rotationMatrix(theta)\n * math.rotationMatrix(theta, format)\n * math.rotationMatrix(theta, [v])\n * math.rotationMatrix(theta, [v], format)\n *\n * Examples:\n *\n * math.rotationMatrix(math.pi / 2) // returns [[0, -1], [1, 0]]\n * math.rotationMatrix(math.bignumber(1)) // returns [[bignumber(cos(1)), bignumber(-sin(1))], [bignumber(sin(1)), bignumber(cos(1))]]\n * math.rotationMatrix(math.complex(1 + i)) // returns [[cos(1 + i), -sin(1 + i)], [sin(1 + i), cos(1 + i)]]\n * math.rotationMatrix(math.unit('1rad')) // returns [[cos(1), -sin(1)], [sin(1), cos(1)]]\n *\n * math.rotationMatrix(math.pi / 2, [0, 1, 0]) // returns [[0, 0, 1], [0, 1, 0], [-1, 0, 0]]\n * math.rotationMatrix(math.pi / 2, matrix([0, 1, 0])) // returns matrix([[0, 0, 1], [0, 1, 0], [-1, 0, 0]])\n *\n *\n * See also:\n *\n * matrix, cos, sin\n *\n *\n * @param {number | BigNumber | Complex | Unit} theta Rotation angle\n * @param {Array | Matrix} [v] Rotation axis\n * @param {string} [format] Result Matrix storage format\n * @return {Array | Matrix} Rotation matrix\n */\n return typed(name, {\n '': function _() {\n return config.matrix === 'Matrix' ? matrix([]) : [];\n },\n string: function string(format) {\n return matrix(format);\n },\n 'number | BigNumber | Complex | Unit': function numberBigNumberComplexUnit(theta) {\n return _rotationMatrix2x2(theta, config.matrix === 'Matrix' ? 'dense' : undefined);\n },\n 'number | BigNumber | Complex | Unit, string': function numberBigNumberComplexUnitString(theta, format) {\n return _rotationMatrix2x2(theta, format);\n },\n 'number | BigNumber | Complex | Unit, Array': function numberBigNumberComplexUnitArray(theta, v) {\n var matrixV = matrix(v);\n\n _validateVector(matrixV);\n\n return _rotationMatrix3x3(theta, matrixV, undefined);\n },\n 'number | BigNumber | Complex | Unit, Matrix': function numberBigNumberComplexUnitMatrix(theta, v) {\n _validateVector(v);\n\n var storageType = v.storage() || (config.matrix === 'Matrix' ? 'dense' : undefined);\n return _rotationMatrix3x3(theta, v, storageType);\n },\n 'number | BigNumber | Complex | Unit, Array, string': function numberBigNumberComplexUnitArrayString(theta, v, format) {\n var matrixV = matrix(v);\n\n _validateVector(matrixV);\n\n return _rotationMatrix3x3(theta, matrixV, format);\n },\n 'number | BigNumber | Complex | Unit, Matrix, string': function numberBigNumberComplexUnitMatrixString(theta, v, format) {\n _validateVector(v);\n\n return _rotationMatrix3x3(theta, v, format);\n }\n });\n /**\n * Returns 2x2 matrix of 2D rotation of angle theta\n *\n * @param {number | BigNumber | Complex | Unit} theta The rotation angle\n * @param {string} format The result Matrix storage format\n * @returns {Matrix}\n * @private\n */\n\n function _rotationMatrix2x2(theta, format) {\n var Big = (0, _is.isBigNumber)(theta);\n var minusOne = Big ? new BigNumber(-1) : -1;\n var cosTheta = cos(theta);\n var sinTheta = sin(theta);\n var data = [[cosTheta, multiplyScalar(minusOne, sinTheta)], [sinTheta, cosTheta]];\n return _convertToFormat(data, format);\n }\n\n function _validateVector(v) {\n var size = v.size();\n\n if (size.length < 1 || size[0] !== 3) {\n throw new RangeError('Vector must be of dimensions 1x3');\n }\n }\n\n function _mul(array) {\n return array.reduce(function (p, curr) {\n return multiplyScalar(p, curr);\n });\n }\n\n function _convertToFormat(data, format) {\n if (format) {\n if (format === 'sparse') {\n return new SparseMatrix(data);\n }\n\n if (format === 'dense') {\n return new DenseMatrix(data);\n }\n\n throw new TypeError(\"Unknown matrix type \\\"\".concat(format, \"\\\"\"));\n }\n\n return data;\n }\n /**\n * Returns a 3x3 matrix of rotation of angle theta around vector v\n *\n * @param {number | BigNumber | Complex | Unit} theta The rotation angle\n * @param {Matrix} v The rotation axis vector\n * @param {string} format The storage format of the resulting matrix\n * @returns {Matrix}\n * @private\n */\n\n\n function _rotationMatrix3x3(theta, v, format) {\n var normV = norm(v);\n\n if (normV === 0) {\n throw new RangeError('Rotation around zero vector');\n }\n\n var Big = (0, _is.isBigNumber)(theta) ? BigNumber : null;\n var one = Big ? new Big(1) : 1;\n var minusOne = Big ? new Big(-1) : -1;\n var vx = Big ? new Big(v.get([0]) / normV) : v.get([0]) / normV;\n var vy = Big ? new Big(v.get([1]) / normV) : v.get([1]) / normV;\n var vz = Big ? new Big(v.get([2]) / normV) : v.get([2]) / normV;\n var c = cos(theta);\n var oneMinusC = addScalar(one, unaryMinus(c));\n var s = sin(theta);\n var r11 = addScalar(c, _mul([vx, vx, oneMinusC]));\n var r12 = addScalar(_mul([vx, vy, oneMinusC]), _mul([minusOne, vz, s]));\n var r13 = addScalar(_mul([vx, vz, oneMinusC]), _mul([vy, s]));\n var r21 = addScalar(_mul([vx, vy, oneMinusC]), _mul([vz, s]));\n var r22 = addScalar(c, _mul([vy, vy, oneMinusC]));\n var r23 = addScalar(_mul([vy, vz, oneMinusC]), _mul([minusOne, vx, s]));\n var r31 = addScalar(_mul([vx, vz, oneMinusC]), _mul([minusOne, vy, s]));\n var r32 = addScalar(_mul([vy, vz, oneMinusC]), _mul([vx, s]));\n var r33 = addScalar(c, _mul([vz, vz, oneMinusC]));\n var data = [[r11, r12, r13], [r21, r22, r23], [r31, r32, r33]];\n return _convertToFormat(data, format);\n }\n});\nexports.createRotationMatrix = createRotationMatrix;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRow = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar name = 'row';\nvar dependencies = ['typed', 'Index', 'matrix', 'range'];\nvar createRow = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Index = _ref.Index,\n matrix = _ref.matrix,\n range = _ref.range;\n\n /**\n * Return a row from a Matrix.\n *\n * Syntax:\n *\n * math.row(value, index)\n *\n * Example:\n *\n * // get a row\n * const d = [[1, 2], [3, 4]]\n * math.row(d, 1) // returns [[3, 4]]\n *\n * See also:\n *\n * column\n *\n * @param {Array | Matrix } value An array or matrix\n * @param {number} row The index of the row\n * @return {Array | Matrix} The retrieved row\n */\n return typed(name, {\n 'Matrix, number': _row,\n 'Array, number': function ArrayNumber(value, row) {\n return _row(matrix((0, _object.clone)(value)), row).valueOf();\n }\n });\n /**\n * Retrieve a row of a matrix\n * @param {Matrix } value A matrix\n * @param {number} row The index of the row\n * @return {Matrix} The retrieved row\n */\n\n function _row(value, row) {\n // check dimensions\n if (value.size().length !== 2) {\n throw new Error('Only two dimensional matrix is supported');\n }\n\n (0, _array.validateIndex)(row, value.size()[0]);\n var columnRange = range(0, value.size()[1]);\n var index = new Index(row, columnRange);\n return value.subset(index);\n }\n});\nexports.createRow = createRow;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSize = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _noop = require(\"../../utils/noop.js\");\n\nvar name = 'size';\nvar dependencies = ['typed', 'config', '?matrix'];\nvar createSize = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n matrix = _ref.matrix;\n\n /**\n * Calculate the size of a matrix or scalar.\n *\n * Syntax:\n *\n * math.size(x)\n *\n * Examples:\n *\n * math.size(2.3) // returns []\n * math.size('hello world') // returns [11]\n *\n * const A = [[1, 2, 3], [4, 5, 6]]\n * math.size(A) // returns [2, 3]\n * math.size(math.range(1,6)) // returns [5]\n *\n * See also:\n *\n * count, resize, squeeze, subset\n *\n * @param {boolean | number | Complex | Unit | string | Array | Matrix} x A matrix\n * @return {Array | Matrix} A vector with size of `x`.\n */\n return typed(name, {\n Matrix: function Matrix(x) {\n return x.create(x.size());\n },\n Array: _array.arraySize,\n string: function string(x) {\n return config.matrix === 'Array' ? [x.length] : matrix([x.length]);\n },\n 'number | Complex | BigNumber | Unit | boolean | null': function numberComplexBigNumberUnitBooleanNull(x) {\n // scalar\n return config.matrix === 'Array' ? [] : matrix ? matrix([]) : (0, _noop.noMatrix)();\n }\n });\n});\nexports.createSize = createSize;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSort = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'sort';\nvar dependencies = ['typed', 'matrix', 'compare', 'compareNatural'];\nvar createSort = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n compare = _ref.compare,\n compareNatural = _ref.compareNatural;\n var compareAsc = compare;\n\n var compareDesc = function compareDesc(a, b) {\n return -compare(a, b);\n };\n /**\n * Sort the items in a matrix.\n *\n * Syntax:\n *\n * math.sort(x)\n * math.sort(x, compare)\n *\n * Examples:\n *\n * math.sort([5, 10, 1]) // returns [1, 5, 10]\n * math.sort(['C', 'B', 'A', 'D'], math.compareNatural)\n * // returns ['A', 'B', 'C', 'D']\n *\n * function sortByLength (a, b) {\n * return a.length - b.length\n * }\n * math.sort(['Langdon', 'Tom', 'Sara'], sortByLength)\n * // returns ['Tom', 'Sara', 'Langdon']\n *\n * See also:\n *\n * filter, forEach, map, compare, compareNatural\n *\n * @param {Matrix | Array} x A one dimensional matrix or array to sort\n * @param {Function | 'asc' | 'desc' | 'natural'} [compare='asc']\n * An optional _comparator function or name. The function is called as\n * `compare(a, b)`, and must return 1 when a > b, -1 when a < b,\n * and 0 when a == b.\n * @return {Matrix | Array} Returns the sorted matrix.\n */\n\n\n return typed(name, {\n Array: function Array(x) {\n _arrayIsVector(x);\n\n return x.sort(compareAsc);\n },\n Matrix: function Matrix(x) {\n _matrixIsVector(x);\n\n return matrix(x.toArray().sort(compareAsc), x.storage());\n },\n 'Array, function': function ArrayFunction(x, _comparator) {\n _arrayIsVector(x);\n\n return x.sort(_comparator);\n },\n 'Matrix, function': function MatrixFunction(x, _comparator) {\n _matrixIsVector(x);\n\n return matrix(x.toArray().sort(_comparator), x.storage());\n },\n 'Array, string': function ArrayString(x, order) {\n _arrayIsVector(x);\n\n return x.sort(_comparator(order));\n },\n 'Matrix, string': function MatrixString(x, order) {\n _matrixIsVector(x);\n\n return matrix(x.toArray().sort(_comparator(order)), x.storage());\n }\n });\n /**\n * Get the comparator for given order ('asc', 'desc', 'natural')\n * @param {'asc' | 'desc' | 'natural'} order\n * @return {Function} Returns a _comparator function\n */\n\n function _comparator(order) {\n if (order === 'asc') {\n return compareAsc;\n } else if (order === 'desc') {\n return compareDesc;\n } else if (order === 'natural') {\n return compareNatural;\n } else {\n throw new Error('String \"asc\", \"desc\", or \"natural\" expected');\n }\n }\n /**\n * Validate whether an array is one dimensional\n * Throws an error when this is not the case\n * @param {Array} array\n * @private\n */\n\n\n function _arrayIsVector(array) {\n if ((0, _array.arraySize)(array).length !== 1) {\n throw new Error('One dimensional array expected');\n }\n }\n /**\n * Validate whether a matrix is one dimensional\n * Throws an error when this is not the case\n * @param {Matrix} matrix\n * @private\n */\n\n\n function _matrixIsVector(matrix) {\n if (matrix.size().length !== 1) {\n throw new Error('One dimensional matrix expected');\n }\n }\n});\nexports.createSort = createSort;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSqrtm = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'sqrtm';\nvar dependencies = ['typed', 'abs', 'add', 'multiply', 'sqrt', 'subtract', 'inv', 'size', 'max', 'identity'];\nvar createSqrtm = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n abs = _ref.abs,\n add = _ref.add,\n multiply = _ref.multiply,\n sqrt = _ref.sqrt,\n subtract = _ref.subtract,\n inv = _ref.inv,\n size = _ref.size,\n max = _ref.max,\n identity = _ref.identity;\n var _maxIterations = 1e3;\n var _tolerance = 1e-6;\n /**\n * Calculate the principal square root matrix using the Denman–Beavers iterative method\n *\n * https://en.wikipedia.org/wiki/Square_root_of_a_matrix#By_Denman–Beavers_iteration\n *\n * @param {Array | Matrix} A The square matrix `A`\n * @return {Array | Matrix} The principal square root of matrix `A`\n * @private\n */\n\n function _denmanBeavers(A) {\n var error;\n var iterations = 0;\n var Y = A;\n var Z = identity(size(A));\n\n do {\n var Yk = Y;\n Y = multiply(0.5, add(Yk, inv(Z)));\n Z = multiply(0.5, add(Z, inv(Yk)));\n error = max(abs(subtract(Y, Yk)));\n\n if (error > _tolerance && ++iterations > _maxIterations) {\n throw new Error('computing square root of matrix: iterative method could not converge');\n }\n } while (error > _tolerance);\n\n return Y;\n }\n /**\n * Calculate the principal square root of a square matrix.\n * The principal square root matrix `X` of another matrix `A` is such that `X * X = A`.\n *\n * https://en.wikipedia.org/wiki/Square_root_of_a_matrix\n *\n * Syntax:\n *\n * X = math.sqrtm(A)\n *\n * Examples:\n *\n * math.sqrtm([[1, 2], [3, 4]]) // returns [[-2, 1], [1.5, -0.5]]\n *\n * See also:\n *\n * sqrt, pow\n *\n * @param {Array | Matrix} A The square matrix `A`\n * @return {Array | Matrix} The principal square root of matrix `A`\n */\n\n\n return typed(name, {\n 'Array | Matrix': function ArrayMatrix(A) {\n var size = (0, _is.isMatrix)(A) ? A.size() : (0, _array.arraySize)(A);\n\n switch (size.length) {\n case 1:\n // Single element Array | Matrix\n if (size[0] === 1) {\n return sqrt(A);\n } else {\n throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n\n case 2:\n {\n // Two-dimensional Array | Matrix\n var rows = size[0];\n var cols = size[1];\n\n if (rows === cols) {\n return _denmanBeavers(A);\n } else {\n throw new RangeError('Matrix must be square ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n }\n\n default:\n // Multi dimensional array\n throw new RangeError('Matrix must be at most two dimensional ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n }\n });\n});\nexports.createSqrtm = createSqrtm;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSqueeze = void 0;\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'squeeze';\nvar dependencies = ['typed', 'matrix'];\nvar createSqueeze = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix;\n\n /**\n * Squeeze a matrix, remove inner and outer singleton dimensions from a matrix.\n *\n * Syntax:\n *\n * math.squeeze(x)\n *\n * Examples:\n *\n * math.squeeze([3]) // returns 3\n * math.squeeze([[3]]) // returns 3\n *\n * const A = math.zeros(3, 1) // returns [[0], [0], [0]] (size 3x1)\n * math.squeeze(A) // returns [0, 0, 0] (size 3)\n *\n * const B = math.zeros(1, 3) // returns [[0, 0, 0]] (size 1x3)\n * math.squeeze(B) // returns [0, 0, 0] (size 3)\n *\n * // only inner and outer dimensions are removed\n * const C = math.zeros(2, 1, 3) // returns [[[0, 0, 0]], [[0, 0, 0]]] (size 2x1x3)\n * math.squeeze(C) // returns [[[0, 0, 0]], [[0, 0, 0]]] (size 2x1x3)\n *\n * See also:\n *\n * subset\n *\n * @param {Matrix | Array} x Matrix to be squeezed\n * @return {Matrix | Array} Squeezed matrix\n */\n return typed(name, {\n Array: function Array(x) {\n return (0, _array.squeeze)((0, _object.clone)(x));\n },\n Matrix: function Matrix(x) {\n var res = (0, _array.squeeze)(x.toArray()); // FIXME: return the same type of matrix as the input\n\n return Array.isArray(res) ? matrix(res) : res;\n },\n any: function any(x) {\n // scalar\n return (0, _object.clone)(x);\n }\n });\n});\nexports.createSqueeze = createSqueeze;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSubset = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _customs = require(\"../../utils/customs.js\");\n\nvar _DimensionError = require(\"../../error/DimensionError.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'subset';\nvar dependencies = ['typed', 'matrix'];\nvar createSubset = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix;\n\n /**\n * Get or set a subset of a matrix or string.\n *\n * Syntax:\n * math.subset(value, index) // retrieve a subset\n * math.subset(value, index, replacement [, defaultValue]) // replace a subset\n *\n * Examples:\n *\n * // get a subset\n * const d = [[1, 2], [3, 4]]\n * math.subset(d, math.index(1, 0)) // returns 3\n * math.subset(d, math.index([0, 1], 1)) // returns [[2], [4]]\n *\n * // replace a subset\n * const e = []\n * const f = math.subset(e, math.index(0, [0, 2]), [5, 6]) // f = [[5, 6]] and e = [[5, 0, 6]]\n * const g = math.subset(f, math.index(1, 1), 7, 0) // g = [[5, 6], [0, 7]]\n *\n * // get submatrix using ranges\n * const M = [\n * [1,2,3],\n * [4,5,6],\n * [7,8,9]\n * ]\n * math.subset(M, math.index(math.range(0,2), math.range(0,3))) // [[1,2,3],[4,5,6]]\n *\n * See also:\n *\n * size, resize, squeeze, index\n *\n * @param {Array | Matrix | string} matrix An array, matrix, or string\n * @param {Index} index\n * For each dimension of the target, specifies an index or a list of\n * indices to fetch or set. `subset` uses the cartesian product of\n * the indices specified in each dimension.\n * @param {*} [replacement] An array, matrix, or scalar.\n * If provided, the subset is replaced with replacement.\n * If not provided, the subset is returned\n * @param {*} [defaultValue=undefined] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * math.matrix elements will be left undefined.\n * @return {Array | Matrix | string} Either the retrieved subset or the updated matrix.\n */\n return typed(name, {\n // get subset\n 'Array, Index': function ArrayIndex(value, index) {\n var m = matrix(value);\n var subset = m.subset(index); // returns a Matrix\n\n return index.isScalar() ? subset : subset.valueOf(); // return an Array (like the input)\n },\n 'Matrix, Index': function MatrixIndex(value, index) {\n return value.subset(index);\n },\n 'Object, Index': _getObjectProperty,\n 'string, Index': _getSubstring,\n // set subset\n 'Array, Index, any': function ArrayIndexAny(value, index, replacement) {\n return matrix((0, _object.clone)(value)).subset(index, replacement, undefined).valueOf();\n },\n 'Array, Index, any, any': function ArrayIndexAnyAny(value, index, replacement, defaultValue) {\n return matrix((0, _object.clone)(value)).subset(index, replacement, defaultValue).valueOf();\n },\n 'Matrix, Index, any': function MatrixIndexAny(value, index, replacement) {\n return value.clone().subset(index, replacement);\n },\n 'Matrix, Index, any, any': function MatrixIndexAnyAny(value, index, replacement, defaultValue) {\n return value.clone().subset(index, replacement, defaultValue);\n },\n 'string, Index, string': _setSubstring,\n 'string, Index, string, string': _setSubstring,\n 'Object, Index, any': _setObjectProperty\n });\n});\n/**\n * Retrieve a subset of a string\n * @param {string} str string from which to get a substring\n * @param {Index} index An index or list of indices (character positions)\n * @returns {string} substring\n * @private\n */\n\nexports.createSubset = createSubset;\n\nfunction _getSubstring(str, index) {\n if (!(0, _is.isIndex)(index)) {\n // TODO: better error message\n throw new TypeError('Index expected');\n }\n\n if (index.size().length !== 1) {\n throw new _DimensionError.DimensionError(index.size().length, 1);\n } // validate whether the range is out of range\n\n\n var strLen = str.length;\n (0, _array.validateIndex)(index.min()[0], strLen);\n (0, _array.validateIndex)(index.max()[0], strLen);\n var range = index.dimension(0);\n var substr = '';\n range.forEach(function (v) {\n substr += str.charAt(v);\n });\n return substr;\n}\n/**\n * Replace a substring in a string\n * @param {string} str string to be replaced\n * @param {Index} index An index or list of indices (character positions)\n * @param {string} replacement Replacement string\n * @param {string} [defaultValue] Default value to be uses when resizing\n * the string. is ' ' by default\n * @returns {string} result\n * @private\n */\n\n\nfunction _setSubstring(str, index, replacement, defaultValue) {\n if (!index || index.isIndex !== true) {\n // TODO: better error message\n throw new TypeError('Index expected');\n }\n\n if (index.size().length !== 1) {\n throw new _DimensionError.DimensionError(index.size().length, 1);\n }\n\n if (defaultValue !== undefined) {\n if (typeof defaultValue !== 'string' || defaultValue.length !== 1) {\n throw new TypeError('Single character expected as defaultValue');\n }\n } else {\n defaultValue = ' ';\n }\n\n var range = index.dimension(0);\n var len = range.size()[0];\n\n if (len !== replacement.length) {\n throw new _DimensionError.DimensionError(range.size()[0], replacement.length);\n } // validate whether the range is out of range\n\n\n var strLen = str.length;\n (0, _array.validateIndex)(index.min()[0]);\n (0, _array.validateIndex)(index.max()[0]); // copy the string into an array with characters\n\n var chars = [];\n\n for (var i = 0; i < strLen; i++) {\n chars[i] = str.charAt(i);\n }\n\n range.forEach(function (v, i) {\n chars[v] = replacement.charAt(i[0]);\n }); // initialize undefined characters with a space\n\n if (chars.length > strLen) {\n for (var _i = strLen - 1, _len = chars.length; _i < _len; _i++) {\n if (!chars[_i]) {\n chars[_i] = defaultValue;\n }\n }\n }\n\n return chars.join('');\n}\n/**\n * Retrieve a property from an object\n * @param {Object} object\n * @param {Index} index\n * @return {*} Returns the value of the property\n * @private\n */\n\n\nfunction _getObjectProperty(object, index) {\n if (index.size().length !== 1) {\n throw new _DimensionError.DimensionError(index.size(), 1);\n }\n\n var key = index.dimension(0);\n\n if (typeof key !== 'string') {\n throw new TypeError('String expected as index to retrieve an object property');\n }\n\n return (0, _customs.getSafeProperty)(object, key);\n}\n/**\n * Set a property on an object\n * @param {Object} object\n * @param {Index} index\n * @param {*} replacement\n * @return {*} Returns the updated object\n * @private\n */\n\n\nfunction _setObjectProperty(object, index, replacement) {\n if (index.size().length !== 1) {\n throw new _DimensionError.DimensionError(index.size(), 1);\n }\n\n var key = index.dimension(0);\n\n if (typeof key !== 'string') {\n throw new TypeError('String expected as index to retrieve an object property');\n } // clone the object, and apply the property to the clone\n\n\n var updated = (0, _object.clone)(object);\n (0, _customs.setSafeProperty)(updated, key, replacement);\n return updated;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createTrace = void 0;\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'trace';\nvar dependencies = ['typed', 'matrix', 'add'];\nvar createTrace = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n add = _ref.add;\n\n /**\n * Calculate the trace of a matrix: the sum of the elements on the main\n * diagonal of a square matrix.\n *\n * Syntax:\n *\n * math.trace(x)\n *\n * Examples:\n *\n * math.trace([[1, 2], [3, 4]]) // returns 5\n *\n * const A = [\n * [1, 2, 3],\n * [-1, 2, 3],\n * [2, 0, 3]\n * ]\n * math.trace(A) // returns 6\n *\n * See also:\n *\n * diag\n *\n * @param {Array | Matrix} x A matrix\n *\n * @return {number} The trace of `x`\n */\n return typed('trace', {\n Array: function _arrayTrace(x) {\n // use dense matrix implementation\n return _denseTrace(matrix(x));\n },\n SparseMatrix: _sparseTrace,\n DenseMatrix: _denseTrace,\n any: _object.clone\n });\n\n function _denseTrace(m) {\n // matrix size & data\n var size = m._size;\n var data = m._data; // process dimensions\n\n switch (size.length) {\n case 1:\n // vector\n if (size[0] === 1) {\n // return data[0]\n return (0, _object.clone)(data[0]);\n }\n\n throw new RangeError('Matrix must be square (size: ' + (0, _string.format)(size) + ')');\n\n case 2:\n {\n // two dimensional\n var rows = size[0];\n var cols = size[1];\n\n if (rows === cols) {\n // calulate sum\n var sum = 0; // loop diagonal\n\n for (var i = 0; i < rows; i++) {\n sum = add(sum, data[i][i]);\n } // return trace\n\n\n return sum;\n } else {\n throw new RangeError('Matrix must be square (size: ' + (0, _string.format)(size) + ')');\n }\n }\n\n default:\n // multi dimensional\n throw new RangeError('Matrix must be two dimensional (size: ' + (0, _string.format)(size) + ')');\n }\n }\n\n function _sparseTrace(m) {\n // matrix arrays\n var values = m._values;\n var index = m._index;\n var ptr = m._ptr;\n var size = m._size; // check dimensions\n\n var rows = size[0];\n var columns = size[1]; // matrix must be square\n\n if (rows === columns) {\n // calulate sum\n var sum = 0; // check we have data (avoid looping columns)\n\n if (values.length > 0) {\n // loop columns\n for (var j = 0; j < columns; j++) {\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n var k0 = ptr[j];\n var k1 = ptr[j + 1]; // loop k within [k0, k1[\n\n for (var k = k0; k < k1; k++) {\n // row index\n var i = index[k]; // check row\n\n if (i === j) {\n // accumulate value\n sum = add(sum, values[k]); // exit loop\n\n break;\n }\n\n if (i > j) {\n // exit loop, no value on the diagonal for column j\n break;\n }\n }\n }\n } // return trace\n\n\n return sum;\n }\n\n throw new RangeError('Matrix must be square (size: ' + (0, _string.format)(size) + ')');\n }\n});\nexports.createTrace = createTrace;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createTranspose = void 0;\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'transpose';\nvar dependencies = ['typed', 'matrix'];\nvar createTranspose = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix;\n\n /**\n * Transpose a matrix. All values of the matrix are reflected over its\n * main diagonal. Only applicable to two dimensional matrices containing\n * a vector (i.e. having size `[1,n]` or `[n,1]`). One dimensional\n * vectors and scalars return the input unchanged.\n *\n * Syntax:\n *\n * math.transpose(x)\n *\n * Examples:\n *\n * const A = [[1, 2, 3], [4, 5, 6]]\n * math.transpose(A) // returns [[1, 4], [2, 5], [3, 6]]\n *\n * See also:\n *\n * diag, inv, subset, squeeze\n *\n * @param {Array | Matrix} x Matrix to be transposed\n * @return {Array | Matrix} The transposed matrix\n */\n return typed('transpose', {\n Array: function Array(x) {\n // use dense matrix implementation\n return this(matrix(x)).valueOf();\n },\n Matrix: function Matrix(x) {\n // matrix size\n var size = x.size(); // result\n\n var c; // process dimensions\n\n switch (size.length) {\n case 1:\n // vector\n c = x.clone();\n break;\n\n case 2:\n {\n // rows and columns\n var rows = size[0];\n var columns = size[1]; // check columns\n\n if (columns === 0) {\n // throw exception\n throw new RangeError('Cannot transpose a 2D matrix with no columns (size: ' + (0, _string.format)(size) + ')');\n } // process storage format\n\n\n switch (x.storage()) {\n case 'dense':\n c = _denseTranspose(x, rows, columns);\n break;\n\n case 'sparse':\n c = _sparseTranspose(x, rows, columns);\n break;\n }\n }\n break;\n\n default:\n // multi dimensional\n throw new RangeError('Matrix must be a vector or two dimensional (size: ' + (0, _string.format)(this._size) + ')');\n }\n\n return c;\n },\n // scalars\n any: function any(x) {\n return (0, _object.clone)(x);\n }\n });\n\n function _denseTranspose(m, rows, columns) {\n // matrix array\n var data = m._data; // transposed matrix data\n\n var transposed = [];\n var transposedRow; // loop columns\n\n for (var j = 0; j < columns; j++) {\n // initialize row\n transposedRow = transposed[j] = []; // loop rows\n\n for (var i = 0; i < rows; i++) {\n // set data\n transposedRow[i] = (0, _object.clone)(data[i][j]);\n }\n } // return matrix\n\n\n return m.createDenseMatrix({\n data: transposed,\n size: [columns, rows],\n datatype: m._datatype\n });\n }\n\n function _sparseTranspose(m, rows, columns) {\n // matrix arrays\n var values = m._values;\n var index = m._index;\n var ptr = m._ptr; // result matrices\n\n var cvalues = values ? [] : undefined;\n var cindex = [];\n var cptr = []; // row counts\n\n var w = [];\n\n for (var x = 0; x < rows; x++) {\n w[x] = 0;\n } // vars\n\n\n var p, l, j; // loop values in matrix\n\n for (p = 0, l = index.length; p < l; p++) {\n // number of values in row\n w[index[p]]++;\n } // cumulative sum\n\n\n var sum = 0; // initialize cptr with the cummulative sum of row counts\n\n for (var i = 0; i < rows; i++) {\n // update cptr\n cptr.push(sum); // update sum\n\n sum += w[i]; // update w\n\n w[i] = cptr[i];\n } // update cptr\n\n\n cptr.push(sum); // loop columns\n\n for (j = 0; j < columns; j++) {\n // values & index in column\n for (var k0 = ptr[j], k1 = ptr[j + 1], k = k0; k < k1; k++) {\n // C values & index\n var q = w[index[k]]++; // C[j, i] = A[i, j]\n\n cindex[q] = j; // check we need to process values (pattern matrix)\n\n if (values) {\n cvalues[q] = (0, _object.clone)(values[k]);\n }\n }\n } // return matrix\n\n\n return m.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [columns, rows],\n datatype: m._datatype\n });\n }\n});\nexports.createTranspose = createTranspose;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createZeros = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'zeros';\nvar dependencies = ['typed', 'config', 'matrix', 'BigNumber'];\nvar createZeros = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n matrix = _ref.matrix,\n BigNumber = _ref.BigNumber;\n\n /**\n * Create a matrix filled with zeros. The created matrix can have one or\n * multiple dimensions.\n *\n * Syntax:\n *\n * math.zeros(m)\n * math.zeros(m, format)\n * math.zeros(m, n)\n * math.zeros(m, n, format)\n * math.zeros([m, n])\n * math.zeros([m, n], format)\n *\n * Examples:\n *\n * math.zeros(3) // returns [0, 0, 0]\n * math.zeros(3, 2) // returns [[0, 0], [0, 0], [0, 0]]\n * math.zeros(3, 'dense') // returns [0, 0, 0]\n *\n * const A = [[1, 2, 3], [4, 5, 6]]\n * math.zeros(math.size(A)) // returns [[0, 0, 0], [0, 0, 0]]\n *\n * See also:\n *\n * ones, identity, size, range\n *\n * @param {...number | Array} size The size of each dimension of the matrix\n * @param {string} [format] The Matrix storage format\n *\n * @return {Array | Matrix} A matrix filled with zeros\n */\n return typed(name, {\n '': function _() {\n return config.matrix === 'Array' ? _zeros([]) : _zeros([], 'default');\n },\n // math.zeros(m, n, p, ..., format)\n // TODO: more accurate signature '...number | BigNumber, string' as soon as typed-function supports this\n '...number | BigNumber | string': function numberBigNumberString(size) {\n var last = size[size.length - 1];\n\n if (typeof last === 'string') {\n var format = size.pop();\n return _zeros(size, format);\n } else if (config.matrix === 'Array') {\n return _zeros(size);\n } else {\n return _zeros(size, 'default');\n }\n },\n Array: _zeros,\n Matrix: function Matrix(size) {\n var format = size.storage();\n return _zeros(size.valueOf(), format);\n },\n 'Array | Matrix, string': function ArrayMatrixString(size, format) {\n return _zeros(size.valueOf(), format);\n }\n });\n /**\n * Create an Array or Matrix with zeros\n * @param {Array} size\n * @param {string} [format='default']\n * @return {Array | Matrix}\n * @private\n */\n\n function _zeros(size, format) {\n var hasBigNumbers = _normalize(size);\n\n var defaultValue = hasBigNumbers ? new BigNumber(0) : 0;\n\n _validate(size);\n\n if (format) {\n // return a matrix\n var m = matrix(format);\n\n if (size.length > 0) {\n return m.resize(size, defaultValue);\n }\n\n return m;\n } else {\n // return an Array\n var arr = [];\n\n if (size.length > 0) {\n return (0, _array.resize)(arr, size, defaultValue);\n }\n\n return arr;\n }\n } // replace BigNumbers with numbers, returns true if size contained BigNumbers\n\n\n function _normalize(size) {\n var hasBigNumbers = false;\n size.forEach(function (value, index, arr) {\n if ((0, _is.isBigNumber)(value)) {\n hasBigNumbers = true;\n arr[index] = value.toNumber();\n }\n });\n return hasBigNumbers;\n } // validate arguments\n\n\n function _validate(size) {\n size.forEach(function (value) {\n if (typeof value !== 'number' || !(0, _number.isInteger)(value) || value < 0) {\n throw new Error('Parameters in function zeros must be positive integers');\n }\n });\n }\n}); // TODO: zeros contains almost the same code as ones. Reuse this?\n\nexports.createZeros = createZeros;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCombinations = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _combinations = require(\"../../plain/number/combinations.js\");\n\nvar name = 'combinations';\nvar dependencies = ['typed'];\nvar createCombinations = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Compute the number of ways of picking `k` unordered outcomes from `n`\n * possibilities.\n *\n * Combinations only takes integer arguments.\n * The following condition must be enforced: k <= n.\n *\n * Syntax:\n *\n * math.combinations(n, k)\n *\n * Examples:\n *\n * math.combinations(7, 5) // returns 21\n *\n * See also:\n *\n * combinationsWithRep, permutations, factorial\n *\n * @param {number | BigNumber} n Total number of objects in the set\n * @param {number | BigNumber} k Number of objects in the subset\n * @return {number | BigNumber} Number of possible combinations.\n */\n return typed(name, {\n 'number, number': _combinations.combinationsNumber,\n 'BigNumber, BigNumber': function BigNumberBigNumber(n, k) {\n var BigNumber = n.constructor;\n var result, i;\n var nMinusk = n.minus(k);\n var one = new BigNumber(1);\n\n if (!isPositiveInteger(n) || !isPositiveInteger(k)) {\n throw new TypeError('Positive integer value expected in function combinations');\n }\n\n if (k.gt(n)) {\n throw new TypeError('k must be less than n in function combinations');\n }\n\n result = one;\n\n if (k.lt(nMinusk)) {\n for (i = one; i.lte(nMinusk); i = i.plus(one)) {\n result = result.times(k.plus(i)).dividedBy(i);\n }\n } else {\n for (i = one; i.lte(k); i = i.plus(one)) {\n result = result.times(nMinusk.plus(i)).dividedBy(i);\n }\n }\n\n return result;\n } // TODO: implement support for collection in combinations\n\n });\n});\n/**\n * Test whether BigNumber n is a positive integer\n * @param {BigNumber} n\n * @returns {boolean} isPositiveInteger\n */\n\nexports.createCombinations = createCombinations;\n\nfunction isPositiveInteger(n) {\n return n.isInteger() && n.gte(0);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCombinationsWithRep = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _product = require(\"../../utils/product.js\");\n\nvar name = 'combinationsWithRep';\nvar dependencies = ['typed'];\nvar createCombinationsWithRep = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Compute the number of ways of picking `k` unordered outcomes from `n`\n * possibilities, allowing individual outcomes to be repeated more than once.\n *\n * CombinationsWithRep only takes integer arguments.\n * The following condition must be enforced: k <= n + k -1.\n *\n * Syntax:\n *\n * math.combinationsWithRep(n, k)\n *\n * Examples:\n *\n * math.combinationsWithRep(7, 5) // returns 462\n *\n * See also:\n *\n * combinations, permutations, factorial\n *\n * @param {number | BigNumber} n Total number of objects in the set\n * @param {number | BigNumber} k Number of objects in the subset\n * @return {number | BigNumber} Number of possible combinations with replacement.\n */\n return typed(name, {\n 'number, number': function numberNumber(n, k) {\n if (!(0, _number.isInteger)(n) || n < 0) {\n throw new TypeError('Positive integer value expected in function combinationsWithRep');\n }\n\n if (!(0, _number.isInteger)(k) || k < 0) {\n throw new TypeError('Positive integer value expected in function combinationsWithRep');\n }\n\n if (n < 1) {\n throw new TypeError('k must be less than or equal to n + k - 1');\n }\n\n if (k < n - 1) {\n var _prodrange = (0, _product.product)(n, n + k - 1);\n\n return _prodrange / (0, _product.product)(1, k);\n }\n\n var prodrange = (0, _product.product)(k + 1, n + k - 1);\n return prodrange / (0, _product.product)(1, n - 1);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(n, k) {\n var BigNumber = n.constructor;\n var result, i;\n var one = new BigNumber(1);\n var nMinusOne = n.minus(one);\n\n if (!isPositiveInteger(n) || !isPositiveInteger(k)) {\n throw new TypeError('Positive integer value expected in function combinationsWithRep');\n }\n\n if (n.lt(one)) {\n throw new TypeError('k must be less than or equal to n + k - 1 in function combinationsWithRep');\n }\n\n result = one;\n\n if (k.lt(nMinusOne)) {\n for (i = one; i.lte(nMinusOne); i = i.plus(one)) {\n result = result.times(k.plus(i)).dividedBy(i);\n }\n } else {\n for (i = one; i.lte(k); i = i.plus(one)) {\n result = result.times(nMinusOne.plus(i)).dividedBy(i);\n }\n }\n\n return result;\n }\n });\n});\n/**\n * Test whether BigNumber n is a positive integer\n * @param {BigNumber} n\n * @returns {boolean} isPositiveInteger\n */\n\nexports.createCombinationsWithRep = createCombinationsWithRep;\n\nfunction isPositiveInteger(n) {\n return n.isInteger() && n.gte(0);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFactorial = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'factorial';\nvar dependencies = ['typed', 'gamma'];\nvar createFactorial = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n gamma = _ref.gamma;\n\n /**\n * Compute the factorial of a value\n *\n * Factorial only supports an integer value as argument.\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.factorial(n)\n *\n * Examples:\n *\n * math.factorial(5) // returns 120\n * math.factorial(3) // returns 6\n *\n * See also:\n *\n * combinations, combinationsWithRep, gamma, permutations\n *\n * @param {number | BigNumber | Array | Matrix} n An integer number\n * @return {number | BigNumber | Array | Matrix} The factorial of `n`\n */\n return typed(name, {\n number: function number(n) {\n if (n < 0) {\n throw new Error('Value must be non-negative');\n }\n\n return gamma(n + 1);\n },\n BigNumber: function BigNumber(n) {\n if (n.isNegative()) {\n throw new Error('Value must be non-negative');\n }\n\n return gamma(n.plus(1));\n },\n 'Array | Matrix': function ArrayMatrix(n) {\n return (0, _collection.deepMap)(n, this);\n }\n });\n});\nexports.createFactorial = createFactorial;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createGamma = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'gamma';\nvar dependencies = ['typed', 'config', 'multiplyScalar', 'pow', 'BigNumber', 'Complex'];\nvar createGamma = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n multiplyScalar = _ref.multiplyScalar,\n pow = _ref.pow,\n _BigNumber = _ref.BigNumber,\n _Complex = _ref.Complex;\n\n /**\n * Compute the gamma function of a value using Lanczos approximation for\n * small values, and an extended Stirling approximation for large values.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.gamma(n)\n *\n * Examples:\n *\n * math.gamma(5) // returns 24\n * math.gamma(-0.5) // returns -3.5449077018110335\n * math.gamma(math.i) // returns -0.15494982830180973 - 0.49801566811835596i\n *\n * See also:\n *\n * combinations, factorial, permutations\n *\n * @param {number | Array | Matrix} n A real or complex number\n * @return {number | Array | Matrix} The gamma of `n`\n */\n return typed(name, {\n number: _index.gammaNumber,\n Complex: function Complex(n) {\n if (n.im === 0) {\n return this(n.re);\n } // Lanczos approximation doesn't work well with real part lower than 0.5\n // So reflection formula is required\n\n\n if (n.re < 0.5) {\n // Euler's reflection formula\n // gamma(1-z) * gamma(z) = PI / sin(PI * z)\n // real part of Z should not be integer [sin(PI) == 0 -> 1/0 - undefined]\n // thanks to imperfect sin implementation sin(PI * n) != 0\n // we can safely use it anyway\n var _t = new _Complex(1 - n.re, -n.im);\n\n var r = new _Complex(Math.PI * n.re, Math.PI * n.im);\n return new _Complex(Math.PI).div(r.sin()).div(this(_t));\n } // Lanczos approximation\n // z -= 1\n\n\n n = new _Complex(n.re - 1, n.im); // x = gammaPval[0]\n\n var x = new _Complex(_index.gammaP[0], 0); // for (i, gammaPval) in enumerate(gammaP):\n\n for (var i = 1; i < _index.gammaP.length; ++i) {\n // x += gammaPval / (z + i)\n var gammaPval = new _Complex(_index.gammaP[i], 0);\n x = x.add(gammaPval.div(n.add(i)));\n } // t = z + gammaG + 0.5\n\n\n var t = new _Complex(n.re + _index.gammaG + 0.5, n.im); // y = sqrt(2 * pi) * t ** (z + 0.5) * exp(-t) * x\n\n var twoPiSqrt = Math.sqrt(2 * Math.PI);\n var tpow = t.pow(n.add(0.5));\n var expt = t.neg().exp(); // y = [x] * [sqrt(2 * pi)] * [t ** (z + 0.5)] * [exp(-t)]\n\n return x.mul(twoPiSqrt).mul(tpow).mul(expt);\n },\n BigNumber: function BigNumber(n) {\n if (n.isInteger()) {\n return n.isNegative() || n.isZero() ? new _BigNumber(Infinity) : bigFactorial(n.minus(1));\n }\n\n if (!n.isFinite()) {\n return new _BigNumber(n.isNegative() ? NaN : Infinity);\n }\n\n throw new Error('Integer BigNumber expected');\n },\n 'Array | Matrix': function ArrayMatrix(n) {\n return (0, _collection.deepMap)(n, this);\n }\n });\n /**\n * Calculate factorial for a BigNumber\n * @param {BigNumber} n\n * @returns {BigNumber} Returns the factorial of n\n */\n\n function bigFactorial(n) {\n if (n < 8) {\n return new _BigNumber([1, 1, 2, 6, 24, 120, 720, 5040][n]);\n }\n\n var precision = config.precision + (Math.log(n.toNumber()) | 0);\n\n var Big = _BigNumber.clone({\n precision: precision\n });\n\n if (n % 2 === 1) {\n return n.times(bigFactorial(new _BigNumber(n - 1)));\n }\n\n var p = n;\n var prod = new Big(n);\n var sum = n.toNumber();\n\n while (p > 2) {\n p -= 2;\n sum += p;\n prod = prod.times(sum);\n }\n\n return new _BigNumber(prod.toPrecision(_BigNumber.precision));\n }\n});\nexports.createGamma = createGamma;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createKldivergence = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'kldivergence';\nvar dependencies = ['typed', 'matrix', 'divide', 'sum', 'multiply', 'dotDivide', 'log', 'isNumeric'];\nvar createKldivergence = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n divide = _ref.divide,\n sum = _ref.sum,\n multiply = _ref.multiply,\n dotDivide = _ref.dotDivide,\n log = _ref.log,\n isNumeric = _ref.isNumeric;\n\n /**\n * Calculate the Kullback-Leibler (KL) divergence between two distributions\n *\n * Syntax:\n *\n * math.kldivergence(x, y)\n *\n * Examples:\n *\n * math.kldivergence([0.7,0.5,0.4], [0.2,0.9,0.5]) //returns 0.24376698773121153\n *\n *\n * @param {Array | Matrix} q First vector\n * @param {Array | Matrix} p Second vector\n * @return {number} Returns distance between q and p\n */\n return typed(name, {\n 'Array, Array': function ArrayArray(q, p) {\n return _kldiv(matrix(q), matrix(p));\n },\n 'Matrix, Array': function MatrixArray(q, p) {\n return _kldiv(q, matrix(p));\n },\n 'Array, Matrix': function ArrayMatrix(q, p) {\n return _kldiv(matrix(q), p);\n },\n 'Matrix, Matrix': function MatrixMatrix(q, p) {\n return _kldiv(q, p);\n }\n });\n\n function _kldiv(q, p) {\n var plength = p.size().length;\n var qlength = q.size().length;\n\n if (plength > 1) {\n throw new Error('first object must be one dimensional');\n }\n\n if (qlength > 1) {\n throw new Error('second object must be one dimensional');\n }\n\n if (plength !== qlength) {\n throw new Error('Length of two vectors must be equal');\n } // Before calculation, apply normalization\n\n\n var sumq = sum(q);\n\n if (sumq === 0) {\n throw new Error('Sum of elements in first object must be non zero');\n }\n\n var sump = sum(p);\n\n if (sump === 0) {\n throw new Error('Sum of elements in second object must be non zero');\n }\n\n var qnorm = divide(q, sum(q));\n var pnorm = divide(p, sum(p));\n var result = sum(multiply(qnorm, log(dotDivide(qnorm, pnorm))));\n\n if (isNumeric(result)) {\n return result;\n } else {\n return Number.NaN;\n }\n }\n});\nexports.createKldivergence = createKldivergence;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLgamma = void 0;\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\n/* eslint-disable no-loss-of-precision */\n// References\n// ----------\n// [1] Hare, \"Computing the Principal Branch of log-Gamma\", Journal of Algorithms, 1997.\n// [2] https://math.stackexchange.com/questions/1338753/how-do-i-calculate-values-for-gamma-function-with-complex-arguments\nvar name = 'lgamma';\nvar dependencies = ['Complex', 'typed'];\nvar createLgamma = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var _Complex = _ref.Complex,\n typed = _ref.typed;\n // Stirling series is non-convergent, we need to use the recurrence `lgamma(z) = lgamma(z+1) - log z` to get\n // sufficient accuracy.\n //\n // These two values are copied from Scipy implementation:\n // https://github.com/scipy/scipy/blob/v1.8.0/scipy/special/_loggamma.pxd#L37\n var SMALL_RE = 7;\n var SMALL_IM = 7;\n /**\n * The coefficients are B[2*n]/(2*n*(2*n - 1)) where B[2*n] is the (2*n)th Bernoulli number. See (1.1) in [1].\n *\n * If you cannot access the paper, can also get these values from the formula in [2].\n *\n * 1 / 12 = 0.00833333333333333333333333333333\n * 1 / 360 = 0.00277777777777777777777777777778\n * ...\n * 3617 / 133400 = 0.02955065359477124183006535947712\n */\n\n var coeffs = [-2.955065359477124183e-2, 6.4102564102564102564e-3, -1.9175269175269175269e-3, 8.4175084175084175084e-4, -5.952380952380952381e-4, 7.9365079365079365079e-4, -2.7777777777777777778e-3, 8.3333333333333333333e-2];\n /**\n * Logarithm of the gamma function for real, positive numbers and complex numbers,\n * using Lanczos approximation for numbers and Stirling series for complex numbers.\n *\n * Syntax:\n *\n * math.lgamma(n)\n *\n * Examples:\n *\n * math.lgamma(5) // returns 3.178053830347945\n * math.lgamma(0) // returns Infinity\n * math.lgamma(-0.5) // returns NaN\n * math.lgamma(math.i) // returns -0.6509231993018536 - 1.8724366472624294i\n *\n * See also:\n *\n * gamma\n *\n * @param {number | Complex} n A real or complex number\n * @return {number | Complex} The log gamma of `n`\n */\n\n return typed(name, {\n number: _index.lgammaNumber,\n Complex: function Complex(n) {\n var TWOPI = 6.2831853071795864769252842; // 2*pi\n\n var LOGPI = 1.1447298858494001741434262; // log(pi)\n\n var REFLECTION = 0.1;\n\n if (n.isNaN()) {\n return new _Complex(NaN, NaN);\n } else if (n.im === 0) {\n return new _Complex((0, _index.lgammaNumber)(n.re), 0);\n } else if (n.re >= SMALL_RE || Math.abs(n.im) >= SMALL_IM) {\n return lgammaStirling(n);\n } else if (n.re <= REFLECTION) {\n // Reflection formula. see Proposition 3.1 in [1]\n var tmp = (0, _number.copysign)(TWOPI, n.im) * Math.floor(0.5 * n.re + 0.25); // TODO: `complex.js sin` doesn't have extremely high precision, so this value `a` may lose a little precision,\n // causing the computation results to be less accurate than the lgamma of real numbers\n\n var a = n.mul(Math.PI).sin().log();\n var b = this(new _Complex(1 - n.re, -n.im));\n return new _Complex(LOGPI, tmp).sub(a).sub(b);\n } else if (n.im >= 0) {\n return lgammaRecurrence(n);\n } else {\n return lgammaRecurrence(n.conjugate()).conjugate();\n }\n },\n BigNumber: function BigNumber() {\n throw new Error(\"mathjs doesn't yet provide an implementation of the algorithm lgamma for BigNumber\");\n }\n });\n\n function lgammaStirling(z) {\n // formula ref in [2]\n // computation ref:\n // https://github.com/scipy/scipy/blob/v1.8.0/scipy/special/_loggamma.pxd#L101\n // left part\n // x (log(x) - 1) + 1/2 (log(2PI) - log(x))\n // => (x - 0.5) * log(x) - x + log(2PI) / 2\n var leftPart = z.sub(0.5).mul(z.log()).sub(z).add(_index.lnSqrt2PI); // right part\n\n var rz = new _Complex(1, 0).div(z);\n var rzz = rz.div(z);\n var a = coeffs[0];\n var b = coeffs[1];\n var r = 2 * rzz.re;\n var s = rzz.re * rzz.re + rzz.im * rzz.im;\n\n for (var i = 2; i < 8; i++) {\n var tmp = b;\n b = -s * a + coeffs[i];\n a = r * a + tmp;\n }\n\n var rightPart = rz.mul(rzz.mul(a).add(b)); // plus left and right\n\n return leftPart.add(rightPart);\n }\n\n function lgammaRecurrence(z) {\n // computation ref:\n // https://github.com/scipy/scipy/blob/v1.8.0/scipy/special/_loggamma.pxd#L78\n var signflips = 0;\n var sb = 0;\n var shiftprod = z;\n z = z.add(1);\n\n while (z.re <= SMALL_RE) {\n shiftprod = shiftprod.mul(z);\n var nsb = shiftprod.im < 0 ? 1 : 0;\n if (nsb !== 0 && sb === 0) signflips++;\n sb = nsb;\n z = z.add(1);\n }\n\n return lgammaStirling(z).sub(shiftprod.log()).sub(new _Complex(0, signflips * 2 * Math.PI * 1));\n }\n});\nexports.createLgamma = createLgamma;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMultinomial = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'multinomial';\nvar dependencies = ['typed', 'add', 'divide', 'multiply', 'factorial', 'isInteger', 'isPositive'];\nvar createMultinomial = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n add = _ref.add,\n divide = _ref.divide,\n multiply = _ref.multiply,\n factorial = _ref.factorial,\n isInteger = _ref.isInteger,\n isPositive = _ref.isPositive;\n\n /**\n * Multinomial Coefficients compute the number of ways of picking a1, a2, ..., ai unordered outcomes from `n` possibilities.\n *\n * multinomial takes one array of integers as an argument.\n * The following condition must be enforced: every ai <= 0\n *\n * Syntax:\n *\n * math.multinomial(a) // a is an array type\n *\n * Examples:\n *\n * math.multinomial([1,2,1]) // returns 12\n *\n * See also:\n *\n * combinations, factorial\n *\n * @param {number[] | BigNumber[]} a Integer numbers of objects in the subset\n * @return {Number | BigNumber} Multinomial coefficient.\n */\n return typed(name, {\n 'Array | Matrix': function ArrayMatrix(a) {\n var sum = 0;\n var denom = 1;\n (0, _collection.deepForEach)(a, function (ai) {\n if (!isInteger(ai) || !isPositive(ai)) {\n throw new TypeError('Positive integer value expected in function multinomial');\n }\n\n sum = add(sum, ai);\n denom = multiply(denom, factorial(ai));\n });\n return divide(factorial(sum), denom);\n }\n });\n});\nexports.createMultinomial = createMultinomial;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createPermutations = void 0;\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _product = require(\"../../utils/product.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'permutations';\nvar dependencies = ['typed', 'factorial'];\nvar createPermutations = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n factorial = _ref.factorial;\n\n /**\n * Compute the number of ways of obtaining an ordered subset of `k` elements\n * from a set of `n` elements.\n *\n * Permutations only takes integer arguments.\n * The following condition must be enforced: k <= n.\n *\n * Syntax:\n *\n * math.permutations(n)\n * math.permutations(n, k)\n *\n * Examples:\n *\n * math.permutations(5) // 120\n * math.permutations(5, 3) // 60\n *\n * See also:\n *\n * combinations, combinationsWithRep, factorial\n *\n * @param {number | BigNumber} n The number of objects in total\n * @param {number | BigNumber} [k] The number of objects in the subset\n * @return {number | BigNumber} The number of permutations\n */\n return typed(name, {\n 'number | BigNumber': factorial,\n 'number, number': function numberNumber(n, k) {\n if (!(0, _number.isInteger)(n) || n < 0) {\n throw new TypeError('Positive integer value expected in function permutations');\n }\n\n if (!(0, _number.isInteger)(k) || k < 0) {\n throw new TypeError('Positive integer value expected in function permutations');\n }\n\n if (k > n) {\n throw new TypeError('second argument k must be less than or equal to first argument n');\n } // Permute n objects, k at a time\n\n\n return (0, _product.product)(n - k + 1, n);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(n, k) {\n var result, i;\n\n if (!isPositiveInteger(n) || !isPositiveInteger(k)) {\n throw new TypeError('Positive integer value expected in function permutations');\n }\n\n if (k.gt(n)) {\n throw new TypeError('second argument k must be less than or equal to first argument n');\n }\n\n var one = n.mul(0).add(1);\n result = one;\n\n for (i = n.minus(k).plus(1); i.lte(n); i = i.plus(1)) {\n result = result.times(i);\n }\n\n return result;\n } // TODO: implement support for collection in permutations\n\n });\n});\n/**\n * Test whether BigNumber n is a positive integer\n * @param {BigNumber} n\n * @returns {boolean} isPositiveInteger\n */\n\nexports.createPermutations = createPermutations;\n\nfunction isPositiveInteger(n) {\n return n.isInteger() && n.gte(0);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createPickRandom = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _seededRNG = require(\"./util/seededRNG.js\");\n\nvar name = 'pickRandom';\nvar dependencies = ['typed', 'config', '?on'];\nvar createPickRandom = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n on = _ref.on;\n // seeded pseudo random number generator\n var rng = (0, _seededRNG.createRng)(config.randomSeed);\n\n if (on) {\n on('config', function (curr, prev) {\n if (curr.randomSeed !== prev.randomSeed) {\n rng = (0, _seededRNG.createRng)(curr.randomSeed);\n }\n });\n }\n /**\n * Random pick one or more values from a one dimensional array.\n * Array elements are picked using a random function with uniform or weighted distribution.\n *\n * Syntax:\n *\n * math.pickRandom(array)\n * math.pickRandom(array, number)\n * math.pickRandom(array, weights)\n * math.pickRandom(array, number, weights)\n * math.pickRandom(array, weights, number)\n * math.pickRandom(array, { weights, number, elementWise })\n *\n * Examples:\n *\n * math.pickRandom([3, 6, 12, 2]) // returns one of the values in the array\n * math.pickRandom([3, 6, 12, 2], 2) // returns an array of two of the values in the array\n * math.pickRandom([3, 6, 12, 2], { number: 2 }) // returns an array of two of the values in the array\n * math.pickRandom([3, 6, 12, 2], [1, 3, 2, 1]) // returns one of the values in the array with weighted distribution\n * math.pickRandom([3, 6, 12, 2], 2, [1, 3, 2, 1]) // returns an array of two of the values in the array with weighted distribution\n * math.pickRandom([3, 6, 12, 2], [1, 3, 2, 1], 2) // returns an array of two of the values in the array with weighted distribution\n *\n * math.pickRandom([{x: 1.0, y: 2.0}, {x: 1.1, y: 2.0}], { elementWise: false })\n * // returns one of the items in the array\n *\n * See also:\n *\n * random, randomInt\n *\n * @param {Array | Matrix} array A one dimensional array\n * @param {Int} number An int or float\n * @param {Array | Matrix} weights An array of ints or floats\n * @return {number | Array} Returns a single random value from array when number is 1 or undefined.\n * Returns an array with the configured number of elements when number is > 1.\n */\n\n\n return typed(name, {\n 'Array | Matrix': function ArrayMatrix(possibles) {\n return _pickRandom(possibles, {});\n },\n 'Array | Matrix, Object': function ArrayMatrixObject(possibles, options) {\n return _pickRandom(possibles, options);\n },\n 'Array | Matrix, number': function ArrayMatrixNumber(possibles, number) {\n return _pickRandom(possibles, {\n number: number\n });\n },\n 'Array | Matrix, Array | Matrix': function ArrayMatrixArrayMatrix(possibles, weights) {\n return _pickRandom(possibles, {\n weights: weights\n });\n },\n 'Array | Matrix, Array | Matrix, number': function ArrayMatrixArrayMatrixNumber(possibles, weights, number) {\n return _pickRandom(possibles, {\n number: number,\n weights: weights\n });\n },\n 'Array | Matrix, number, Array | Matrix': function ArrayMatrixNumberArrayMatrix(possibles, number, weights) {\n return _pickRandom(possibles, {\n number: number,\n weights: weights\n });\n }\n });\n /**\n * @param {Array | Matrix} possibles\n * @param {{\n * number?: number,\n * weights?: Array | Matrix,\n * elementWise: boolean\n * }} options\n * @returns {number | Array}\n * @private\n */\n\n function _pickRandom(possibles, _ref2) {\n var number = _ref2.number,\n weights = _ref2.weights,\n _ref2$elementWise = _ref2.elementWise,\n elementWise = _ref2$elementWise === void 0 ? true : _ref2$elementWise;\n var single = typeof number === 'undefined';\n\n if (single) {\n number = 1;\n }\n\n var createMatrix = (0, _is.isMatrix)(possibles) ? possibles.create : (0, _is.isMatrix)(weights) ? weights.create : null;\n possibles = possibles.valueOf(); // get Array\n\n if (weights) {\n weights = weights.valueOf(); // get Array\n }\n\n if (elementWise === true) {\n possibles = (0, _array.flatten)(possibles);\n weights = (0, _array.flatten)(weights);\n }\n\n var totalWeights = 0;\n\n if (typeof weights !== 'undefined') {\n if (weights.length !== possibles.length) {\n throw new Error('Weights must have the same length as possibles');\n }\n\n for (var i = 0, len = weights.length; i < len; i++) {\n if (!(0, _is.isNumber)(weights[i]) || weights[i] < 0) {\n throw new Error('Weights must be an array of positive numbers');\n }\n\n totalWeights += weights[i];\n }\n }\n\n var length = possibles.length;\n var result = [];\n var pick;\n\n while (result.length < number) {\n if (typeof weights === 'undefined') {\n pick = possibles[Math.floor(rng() * length)];\n } else {\n var randKey = rng() * totalWeights;\n\n for (var _i = 0, _len = possibles.length; _i < _len; _i++) {\n randKey -= weights[_i];\n\n if (randKey < 0) {\n pick = possibles[_i];\n break;\n }\n }\n }\n\n result.push(pick);\n }\n\n return single ? result[0] : createMatrix ? createMatrix(result) : result;\n }\n});\nexports.createPickRandom = createPickRandom;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRandomNumber = exports.createRandom = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _seededRNG = require(\"./util/seededRNG.js\");\n\nvar _randomMatrix2 = require(\"./util/randomMatrix.js\");\n\nvar name = 'random';\nvar dependencies = ['typed', 'config', '?on'];\nvar createRandom = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n on = _ref.on;\n // seeded pseudo random number generator\n var rng = (0, _seededRNG.createRng)(config.randomSeed);\n\n if (on) {\n on('config', function (curr, prev) {\n if (curr.randomSeed !== prev.randomSeed) {\n rng = (0, _seededRNG.createRng)(curr.randomSeed);\n }\n });\n }\n /**\n * Return a random number larger or equal to `min` and smaller than `max`\n * using a uniform distribution.\n *\n * Syntax:\n *\n * math.random() // generate a random number between 0 and 1\n * math.random(max) // generate a random number between 0 and max\n * math.random(min, max) // generate a random number between min and max\n * math.random(size) // generate a matrix with random numbers between 0 and 1\n * math.random(size, max) // generate a matrix with random numbers between 0 and max\n * math.random(size, min, max) // generate a matrix with random numbers between min and max\n *\n * Examples:\n *\n * math.random() // returns a random number between 0 and 1\n * math.random(100) // returns a random number between 0 and 100\n * math.random(30, 40) // returns a random number between 30 and 40\n * math.random([2, 3]) // returns a 2x3 matrix with random numbers between 0 and 1\n *\n * See also:\n *\n * randomInt, pickRandom\n *\n * @param {Array | Matrix} [size] If provided, an array or matrix with given\n * size and filled with random values is returned\n * @param {number} [min] Minimum boundary for the random value, included\n * @param {number} [max] Maximum boundary for the random value, excluded\n * @return {number | Array | Matrix} A random number\n */\n\n\n return typed(name, {\n '': function _() {\n return _random(0, 1);\n },\n number: function number(max) {\n return _random(0, max);\n },\n 'number, number': function numberNumber(min, max) {\n return _random(min, max);\n },\n 'Array | Matrix': function ArrayMatrix(size) {\n return _randomMatrix(size, 0, 1);\n },\n 'Array | Matrix, number': function ArrayMatrixNumber(size, max) {\n return _randomMatrix(size, 0, max);\n },\n 'Array | Matrix, number, number': function ArrayMatrixNumberNumber(size, min, max) {\n return _randomMatrix(size, min, max);\n }\n });\n\n function _randomMatrix(size, min, max) {\n var res = (0, _randomMatrix2.randomMatrix)(size.valueOf(), function () {\n return _random(min, max);\n });\n return (0, _is.isMatrix)(size) ? size.create(res) : res;\n }\n\n function _random(min, max) {\n return min + rng() * (max - min);\n }\n}); // number only implementation of random, no matrix support\n// TODO: there is quite some duplicate code in both createRandom and createRandomNumber, can we improve that?\n\nexports.createRandom = createRandom;\nvar createRandomNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config', '?on'], function (_ref2) {\n var typed = _ref2.typed,\n config = _ref2.config,\n on = _ref2.on,\n matrix = _ref2.matrix;\n // seeded pseudo random number generator1\n var rng = (0, _seededRNG.createRng)(config.randomSeed);\n\n if (on) {\n on('config', function (curr, prev) {\n if (curr.randomSeed !== prev.randomSeed) {\n rng = (0, _seededRNG.createRng)(curr.randomSeed);\n }\n });\n }\n\n return typed(name, {\n '': function _() {\n return _random(0, 1);\n },\n number: function number(max) {\n return _random(0, max);\n },\n 'number, number': function numberNumber(min, max) {\n return _random(min, max);\n }\n });\n\n function _random(min, max) {\n return min + rng() * (max - min);\n }\n});\nexports.createRandomNumber = createRandomNumber;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRandomInt = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _randomMatrix = require(\"./util/randomMatrix.js\");\n\nvar _seededRNG = require(\"./util/seededRNG.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar name = 'randomInt';\nvar dependencies = ['typed', 'config', '?on'];\nvar createRandomInt = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n on = _ref.on;\n // seeded pseudo random number generator\n var rng = (0, _seededRNG.createRng)(config.randomSeed);\n\n if (on) {\n on('config', function (curr, prev) {\n if (curr.randomSeed !== prev.randomSeed) {\n rng = (0, _seededRNG.createRng)(curr.randomSeed);\n }\n });\n }\n /**\n * Return a random integer number larger or equal to `min` and smaller than `max`\n * using a uniform distribution.\n *\n * Syntax:\n *\n * math.randomInt() // generate a random integer between 0 and 1\n * math.randomInt(max) // generate a random integer between 0 and max\n * math.randomInt(min, max) // generate a random integer between min and max\n * math.randomInt(size) // generate a matrix with random integer between 0 and 1\n * math.randomInt(size, max) // generate a matrix with random integer between 0 and max\n * math.randomInt(size, min, max) // generate a matrix with random integer between min and max\n *\n * Examples:\n *\n * math.randomInt(100) // returns a random integer between 0 and 100\n * math.randomInt(30, 40) // returns a random integer between 30 and 40\n * math.randomInt([2, 3]) // returns a 2x3 matrix with random integers between 0 and 1\n *\n * See also:\n *\n * random, pickRandom\n *\n * @param {Array | Matrix} [size] If provided, an array or matrix with given\n * size and filled with random values is returned\n * @param {number} [min] Minimum boundary for the random value, included\n * @param {number} [max] Maximum boundary for the random value, excluded\n * @return {number | Array | Matrix} A random integer value\n */\n\n\n return typed(name, {\n '': function _() {\n return _randomInt(0, 1);\n },\n number: function number(max) {\n return _randomInt(0, max);\n },\n 'number, number': function numberNumber(min, max) {\n return _randomInt(min, max);\n },\n 'Array | Matrix': function ArrayMatrix(size) {\n return _randomIntMatrix(size, 0, 1);\n },\n 'Array | Matrix, number': function ArrayMatrixNumber(size, max) {\n return _randomIntMatrix(size, 0, max);\n },\n 'Array | Matrix, number, number': function ArrayMatrixNumberNumber(size, min, max) {\n return _randomIntMatrix(size, min, max);\n }\n });\n\n function _randomIntMatrix(size, min, max) {\n var res = (0, _randomMatrix.randomMatrix)(size.valueOf(), function () {\n return _randomInt(min, max);\n });\n return (0, _is.isMatrix)(size) ? size.create(res) : res;\n }\n\n function _randomInt(min, max) {\n return Math.floor(min + rng() * (max - min));\n }\n});\nexports.createRandomInt = createRandomInt;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.randomMatrix = randomMatrix;\n\n/**\n * This is a util function for generating a random matrix recursively.\n * @param {number[]} size\n * @param {function} random\n * @returns {Array}\n */\nfunction randomMatrix(size, random) {\n var data = [];\n size = size.slice(0);\n\n if (size.length > 1) {\n for (var i = 0, length = size.shift(); i < length; i++) {\n data.push(randomMatrix(size, random));\n }\n } else {\n for (var _i = 0, _length = size.shift(); _i < _length; _i++) {\n data.push(random());\n }\n }\n\n return data;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRng = createRng;\n\nvar _seedrandom = _interopRequireDefault(require(\"seedrandom\"));\n\nvar singletonRandom = /* #__PURE__ */(0, _seedrandom.default)(Date.now());\n\nfunction createRng(randomSeed) {\n var random; // create a new random generator with given seed\n\n function setSeed(seed) {\n random = seed === null ? singletonRandom : (0, _seedrandom.default)(String(seed));\n } // initialize a seeded pseudo random number generator with config's random seed\n\n\n setSeed(randomSeed); // wrapper function so the rng can be updated via generator\n\n function rng() {\n return random();\n }\n\n return rng;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCompareNumber = exports.createCompare = void 0;\n\nvar _nearlyEqual = require(\"../../utils/bignumber/nearlyEqual.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm05.js\");\n\nvar name = 'compare';\nvar dependencies = ['typed', 'config', 'matrix', 'equalScalar', 'BigNumber', 'Fraction', 'DenseMatrix'];\nvar createCompare = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n equalScalar = _ref.equalScalar,\n matrix = _ref.matrix,\n BigNumber = _ref.BigNumber,\n Fraction = _ref.Fraction,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm03 = (0, _algorithm.createAlgorithm03)({\n typed: typed\n });\n var algorithm05 = (0, _algorithm5.createAlgorithm05)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm12 = (0, _algorithm2.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm4.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm3.createAlgorithm14)({\n typed: typed\n });\n /**\n * Compare two values. Returns 1 when x > y, -1 when x < y, and 0 when x == y.\n *\n * x and y are considered equal when the relative difference between x and y\n * is smaller than the configured epsilon. The function cannot be used to\n * compare values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.compare(x, y)\n *\n * Examples:\n *\n * math.compare(6, 1) // returns 1\n * math.compare(2, 3) // returns -1\n * math.compare(7, 7) // returns 0\n * math.compare('10', '2') // returns 1\n * math.compare('1000', '1e3') // returns 0\n *\n * const a = math.unit('5 cm')\n * const b = math.unit('40 mm')\n * math.compare(a, b) // returns 1\n *\n * math.compare(2, [1, 2, 3]) // returns [1, 0, -1]\n *\n * See also:\n *\n * equal, unequal, smaller, smallerEq, larger, largerEq, compareNatural, compareText\n *\n * @param {number | BigNumber | Fraction | Unit | string | Array | Matrix} x First value to compare\n * @param {number | BigNumber | Fraction | Unit | string | Array | Matrix} y Second value to compare\n * @return {number | BigNumber | Fraction | Array | Matrix} Returns the result of the comparison:\n * 1 when x > y, -1 when x < y, and 0 when x == y.\n */\n\n return typed(name, {\n 'boolean, boolean': function booleanBoolean(x, y) {\n return x === y ? 0 : x > y ? 1 : -1;\n },\n 'number, number': function numberNumber(x, y) {\n return (0, _number.nearlyEqual)(x, y, config.epsilon) ? 0 : x > y ? 1 : -1;\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return (0, _nearlyEqual.nearlyEqual)(x, y, config.epsilon) ? new BigNumber(0) : new BigNumber(x.cmp(y));\n },\n 'Fraction, Fraction': function FractionFraction(x, y) {\n return new Fraction(x.compare(y));\n },\n 'Complex, Complex': function ComplexComplex() {\n throw new TypeError('No ordering relation is defined for complex numbers');\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n if (!x.equalBase(y)) {\n throw new Error('Cannot compare units with different base');\n }\n\n return this(x.value, y.value);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm05(x, y, this);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm03(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm12(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createCompare = createCompare;\nvar createCompareNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config'], function (_ref2) {\n var typed = _ref2.typed,\n config = _ref2.config;\n return typed(name, {\n 'number, number': function numberNumber(x, y) {\n return (0, _number.nearlyEqual)(x, y, config.epsilon) ? 0 : x > y ? 1 : -1;\n }\n });\n});\nexports.createCompareNumber = createCompareNumber;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCompareNatural = void 0;\n\nvar _javascriptNaturalSort = _interopRequireDefault(require(\"javascript-natural-sort\"));\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'compareNatural';\nvar dependencies = ['typed', 'compare'];\nvar createCompareNatural = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n compare = _ref.compare;\n var compareBooleans = compare.signatures['boolean,boolean'];\n /**\n * Compare two values of any type in a deterministic, natural way.\n *\n * For numeric values, the function works the same as `math.compare`.\n * For types of values that can't be compared mathematically,\n * the function compares in a natural way.\n *\n * For numeric values, x and y are considered equal when the relative\n * difference between x and y is smaller than the configured epsilon.\n * The function cannot be used to compare values smaller than\n * approximately 2.22e-16.\n *\n * For Complex numbers, first the real parts are compared. If equal,\n * the imaginary parts are compared.\n *\n * Strings are compared with a natural sorting algorithm, which\n * orders strings in a \"logic\" way following some heuristics.\n * This differs from the function `compare`, which converts the string\n * into a numeric value and compares that. The function `compareText`\n * on the other hand compares text lexically.\n *\n * Arrays and Matrices are compared value by value until there is an\n * unequal pair of values encountered. Objects are compared by sorted\n * keys until the keys or their values are unequal.\n *\n * Syntax:\n *\n * math.compareNatural(x, y)\n *\n * Examples:\n *\n * math.compareNatural(6, 1) // returns 1\n * math.compareNatural(2, 3) // returns -1\n * math.compareNatural(7, 7) // returns 0\n *\n * math.compareNatural('10', '2') // returns 1\n * math.compareText('10', '2') // returns -1\n * math.compare('10', '2') // returns 1\n *\n * math.compareNatural('Answer: 10', 'Answer: 2') // returns 1\n * math.compareText('Answer: 10', 'Answer: 2') // returns -1\n * math.compare('Answer: 10', 'Answer: 2')\n * // Error: Cannot convert \"Answer: 10\" to a number\n *\n * const a = math.unit('5 cm')\n * const b = math.unit('40 mm')\n * math.compareNatural(a, b) // returns 1\n *\n * const c = math.complex('2 + 3i')\n * const d = math.complex('2 + 4i')\n * math.compareNatural(c, d) // returns -1\n *\n * math.compareNatural([1, 2, 4], [1, 2, 3]) // returns 1\n * math.compareNatural([1, 2, 3], [1, 2]) // returns 1\n * math.compareNatural([1, 5], [1, 2, 3]) // returns 1\n * math.compareNatural([1, 2], [1, 2]) // returns 0\n *\n * math.compareNatural({a: 2}, {a: 4}) // returns -1\n *\n * See also:\n *\n * compare, compareText\n *\n * @param {*} x First value to compare\n * @param {*} y Second value to compare\n * @return {number} Returns the result of the comparison:\n * 1 when x > y, -1 when x < y, and 0 when x == y.\n */\n\n return typed(name, {\n 'any, any': function anyAny(x, y) {\n var typeX = (0, _is.typeOf)(x);\n var typeY = (0, _is.typeOf)(y);\n var c; // numeric types\n\n if ((typeX === 'number' || typeX === 'BigNumber' || typeX === 'Fraction') && (typeY === 'number' || typeY === 'BigNumber' || typeY === 'Fraction')) {\n c = compare(x, y);\n\n if (c.toString() !== '0') {\n // c can be number, BigNumber, or Fraction\n return c > 0 ? 1 : -1; // return a number\n } else {\n return (0, _javascriptNaturalSort.default)(typeX, typeY);\n }\n } // matrix types\n\n\n if (typeX === 'Array' || typeX === 'Matrix' || typeY === 'Array' || typeY === 'Matrix') {\n c = compareMatricesAndArrays(this, x, y);\n\n if (c !== 0) {\n return c;\n } else {\n return (0, _javascriptNaturalSort.default)(typeX, typeY);\n }\n } // in case of different types, order by name of type, i.e. 'BigNumber' < 'Complex'\n\n\n if (typeX !== typeY) {\n return (0, _javascriptNaturalSort.default)(typeX, typeY);\n }\n\n if (typeX === 'Complex') {\n return compareComplexNumbers(x, y);\n }\n\n if (typeX === 'Unit') {\n if (x.equalBase(y)) {\n return this(x.value, y.value);\n } // compare by units\n\n\n return compareArrays(this, x.formatUnits(), y.formatUnits());\n }\n\n if (typeX === 'boolean') {\n return compareBooleans(x, y);\n }\n\n if (typeX === 'string') {\n return (0, _javascriptNaturalSort.default)(x, y);\n }\n\n if (typeX === 'Object') {\n return compareObjects(this, x, y);\n }\n\n if (typeX === 'null') {\n return 0;\n }\n\n if (typeX === 'undefined') {\n return 0;\n } // this should not occur...\n\n\n throw new TypeError('Unsupported type of value \"' + typeX + '\"');\n }\n });\n /**\n * Compare mixed matrix/array types, by converting to same-shaped array.\n * This comparator is non-deterministic regarding input types.\n * @param {Array | SparseMatrix | DenseMatrix | *} x\n * @param {Array | SparseMatrix | DenseMatrix | *} y\n * @returns {number} Returns the comparison result: -1, 0, or 1\n */\n\n function compareMatricesAndArrays(compareNatural, x, y) {\n if ((0, _is.isSparseMatrix)(x) && (0, _is.isSparseMatrix)(y)) {\n return compareArrays(compareNatural, x.toJSON().values, y.toJSON().values);\n }\n\n if ((0, _is.isSparseMatrix)(x)) {\n // note: convert to array is expensive\n return compareMatricesAndArrays(compareNatural, x.toArray(), y);\n }\n\n if ((0, _is.isSparseMatrix)(y)) {\n // note: convert to array is expensive\n return compareMatricesAndArrays(compareNatural, x, y.toArray());\n } // convert DenseArray into Array\n\n\n if ((0, _is.isDenseMatrix)(x)) {\n return compareMatricesAndArrays(compareNatural, x.toJSON().data, y);\n }\n\n if ((0, _is.isDenseMatrix)(y)) {\n return compareMatricesAndArrays(compareNatural, x, y.toJSON().data);\n } // convert scalars to array\n\n\n if (!Array.isArray(x)) {\n return compareMatricesAndArrays(compareNatural, [x], y);\n }\n\n if (!Array.isArray(y)) {\n return compareMatricesAndArrays(compareNatural, x, [y]);\n }\n\n return compareArrays(compareNatural, x, y);\n }\n /**\n * Compare two Arrays\n *\n * - First, compares value by value\n * - Next, if all corresponding values are equal,\n * look at the length: longest array will be considered largest\n *\n * @param {Array} x\n * @param {Array} y\n * @returns {number} Returns the comparison result: -1, 0, or 1\n */\n\n\n function compareArrays(compareNatural, x, y) {\n // compare each value\n for (var i = 0, ii = Math.min(x.length, y.length); i < ii; i++) {\n var v = compareNatural(x[i], y[i]);\n\n if (v !== 0) {\n return v;\n }\n } // compare the size of the arrays\n\n\n if (x.length > y.length) {\n return 1;\n }\n\n if (x.length < y.length) {\n return -1;\n } // both Arrays have equal size and content\n\n\n return 0;\n }\n /**\n * Compare two objects\n *\n * - First, compare sorted property names\n * - Next, compare the property values\n *\n * @param {Object} x\n * @param {Object} y\n * @returns {number} Returns the comparison result: -1, 0, or 1\n */\n\n\n function compareObjects(compareNatural, x, y) {\n var keysX = Object.keys(x);\n var keysY = Object.keys(y); // compare keys\n\n keysX.sort(_javascriptNaturalSort.default);\n keysY.sort(_javascriptNaturalSort.default);\n var c = compareArrays(compareNatural, keysX, keysY);\n\n if (c !== 0) {\n return c;\n } // compare values\n\n\n for (var i = 0; i < keysX.length; i++) {\n var v = compareNatural(x[keysX[i]], y[keysY[i]]);\n\n if (v !== 0) {\n return v;\n }\n }\n\n return 0;\n }\n});\n/**\n * Compare two complex numbers, `x` and `y`:\n *\n * - First, compare the real values of `x` and `y`\n * - If equal, compare the imaginary values of `x` and `y`\n *\n * @params {Complex} x\n * @params {Complex} y\n * @returns {number} Returns the comparison result: -1, 0, or 1\n */\n\nexports.createCompareNatural = createCompareNatural;\n\nfunction compareComplexNumbers(x, y) {\n if (x.re > y.re) {\n return 1;\n }\n\n if (x.re < y.re) {\n return -1;\n }\n\n if (x.im > y.im) {\n return 1;\n }\n\n if (x.im < y.im) {\n return -1;\n }\n\n return 0;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCompareTextNumber = exports.createCompareText = void 0;\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar name = 'compareText';\nvar dependencies = ['typed', 'matrix'];\nvar createCompareText = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix;\n var algorithm13 = (0, _algorithm2.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm.createAlgorithm14)({\n typed: typed\n });\n /**\n * Compare two strings lexically. Comparison is case sensitive.\n * Returns 1 when x > y, -1 when x < y, and 0 when x == y.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.compareText(x, y)\n *\n * Examples:\n *\n * math.compareText('B', 'A') // returns 1\n * math.compareText('2', '10') // returns 1\n * math.compare('2', '10') // returns -1\n * math.compareNatural('2', '10') // returns -1\n *\n * math.compareText('B', ['A', 'B', 'C']) // returns [1, 0, -1]\n *\n * See also:\n *\n * equal, equalText, compare, compareNatural\n *\n * @param {string | Array | DenseMatrix} x First string to compare\n * @param {string | Array | DenseMatrix} y Second string to compare\n * @return {number | Array | DenseMatrix} Returns the result of the comparison:\n * 1 when x > y, -1 when x < y, and 0 when x == y.\n */\n\n return typed(name, {\n 'any, any': _string.compareText,\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, _string.compareText);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, _string.compareText, false);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, _string.compareText, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, _string.compareText, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, _string.compareText, true).valueOf();\n }\n });\n});\nexports.createCompareText = createCompareText;\nvar createCompareTextNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed'], function (_ref2) {\n var typed = _ref2.typed;\n return typed(name, {\n 'any, any': _string.compareText\n });\n});\nexports.createCompareTextNumber = createCompareTextNumber;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDeepEqual = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'deepEqual';\nvar dependencies = ['typed', 'equal'];\nvar createDeepEqual = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n equal = _ref.equal;\n\n /**\n * Test element wise whether two matrices are equal.\n * The function accepts both matrices and scalar values.\n *\n * Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.deepEqual(x, y)\n *\n * Examples:\n *\n * math.deepEqual(2, 4) // returns false\n *\n * a = [2, 5, 1]\n * b = [2, 7, 1]\n *\n * math.deepEqual(a, b) // returns false\n * math.equal(a, b) // returns [true, false, true]\n *\n * See also:\n *\n * equal, unequal\n *\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x First matrix to compare\n * @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Second matrix to compare\n * @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix}\n * Returns true when the input matrices have the same size and each of their elements is equal.\n */\n return typed(name, {\n 'any, any': function anyAny(x, y) {\n return _deepEqual(x.valueOf(), y.valueOf());\n }\n });\n /**\n * Test whether two arrays have the same size and all elements are equal\n * @param {Array | *} x\n * @param {Array | *} y\n * @return {boolean} Returns true if both arrays are deep equal\n */\n\n function _deepEqual(x, y) {\n if (Array.isArray(x)) {\n if (Array.isArray(y)) {\n var len = x.length;\n\n if (len !== y.length) {\n return false;\n }\n\n for (var i = 0; i < len; i++) {\n if (!_deepEqual(x[i], y[i])) {\n return false;\n }\n }\n\n return true;\n } else {\n return false;\n }\n } else {\n if (Array.isArray(y)) {\n return false;\n } else {\n return equal(x, y);\n }\n }\n }\n});\nexports.createDeepEqual = createDeepEqual;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createEqualNumber = exports.createEqual = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm07.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'equal';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix'];\nvar createEqual = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm03 = (0, _algorithm.createAlgorithm03)({\n typed: typed\n });\n var algorithm07 = (0, _algorithm2.createAlgorithm07)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm12 = (0, _algorithm3.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm4.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm5.createAlgorithm14)({\n typed: typed\n });\n /**\n * Test whether two values are equal.\n *\n * The function tests whether the relative difference between x and y is\n * smaller than the configured epsilon. The function cannot be used to\n * compare values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * In case of complex numbers, x.re must equal y.re, and x.im must equal y.im.\n *\n * Values `null` and `undefined` are compared strictly, thus `null` is only\n * equal to `null` and nothing else, and `undefined` is only equal to\n * `undefined` and nothing else. Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.equal(x, y)\n *\n * Examples:\n *\n * math.equal(2 + 2, 3) // returns false\n * math.equal(2 + 2, 4) // returns true\n *\n * const a = math.unit('50 cm')\n * const b = math.unit('5 m')\n * math.equal(a, b) // returns true\n *\n * const c = [2, 5, 1]\n * const d = [2, 7, 1]\n *\n * math.equal(c, d) // returns [true, false, true]\n * math.deepEqual(c, d) // returns false\n *\n * math.equal(\"1000\", \"1e3\") // returns true\n * math.equal(0, null) // returns false\n *\n * See also:\n *\n * unequal, smaller, smallerEq, larger, largerEq, compare, deepEqual, equalText\n *\n * @param {number | BigNumber | boolean | Complex | Unit | string | Array | Matrix} x First value to compare\n * @param {number | BigNumber | boolean | Complex | Unit | string | Array | Matrix} y Second value to compare\n * @return {boolean | Array | Matrix} Returns true when the compared values are equal, else returns false\n */\n\n return typed(name, {\n 'any, any': function anyAny(x, y) {\n // strict equality for null and undefined?\n if (x === null) {\n return y === null;\n }\n\n if (y === null) {\n return x === null;\n }\n\n if (x === undefined) {\n return y === undefined;\n }\n\n if (y === undefined) {\n return x === undefined;\n }\n\n return equalScalar(x, y);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm07(x, y, equalScalar);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm03(y, x, equalScalar, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, equalScalar, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, equalScalar);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm12(x, y, equalScalar, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, equalScalar, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, equalScalar, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, equalScalar, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, equalScalar, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, equalScalar, true).valueOf();\n }\n });\n});\nexports.createEqual = createEqual;\nvar createEqualNumber = (0, _factory.factory)(name, ['typed', 'equalScalar'], function (_ref2) {\n var typed = _ref2.typed,\n equalScalar = _ref2.equalScalar;\n return typed(name, {\n 'any, any': function anyAny(x, y) {\n // strict equality for null and undefined?\n if (x === null) {\n return y === null;\n }\n\n if (y === null) {\n return x === null;\n }\n\n if (x === undefined) {\n return y === undefined;\n }\n\n if (y === undefined) {\n return x === undefined;\n }\n\n return equalScalar(x, y);\n }\n });\n});\nexports.createEqualNumber = createEqualNumber;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createEqualScalarNumber = exports.createEqualScalar = void 0;\n\nvar _nearlyEqual = require(\"../../utils/bignumber/nearlyEqual.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _complex = require(\"../../utils/complex.js\");\n\nvar name = 'equalScalar';\nvar dependencies = ['typed', 'config'];\nvar createEqualScalar = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config;\n\n /**\n * Test whether two scalar values are nearly equal.\n *\n * @param {number | BigNumber | Fraction | boolean | Complex | Unit} x First value to compare\n * @param {number | BigNumber | Fraction | boolean | Complex} y Second value to compare\n * @return {boolean} Returns true when the compared values are equal, else returns false\n * @private\n */\n return typed(name, {\n 'boolean, boolean': function booleanBoolean(x, y) {\n return x === y;\n },\n 'number, number': function numberNumber(x, y) {\n return (0, _number.nearlyEqual)(x, y, config.epsilon);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return x.eq(y) || (0, _nearlyEqual.nearlyEqual)(x, y, config.epsilon);\n },\n 'Fraction, Fraction': function FractionFraction(x, y) {\n return x.equals(y);\n },\n 'Complex, Complex': function ComplexComplex(x, y) {\n return (0, _complex.complexEquals)(x, y, config.epsilon);\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n if (!x.equalBase(y)) {\n throw new Error('Cannot compare units with different base');\n }\n\n return this(x.value, y.value);\n }\n });\n});\nexports.createEqualScalar = createEqualScalar;\nvar createEqualScalarNumber = (0, _factory.factory)(name, ['typed', 'config'], function (_ref2) {\n var typed = _ref2.typed,\n config = _ref2.config;\n return typed(name, {\n 'number, number': function numberNumber(x, y) {\n return (0, _number.nearlyEqual)(x, y, config.epsilon);\n }\n });\n});\nexports.createEqualScalarNumber = createEqualScalarNumber;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createEqualText = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'equalText';\nvar dependencies = ['typed', 'compareText', 'isZero'];\nvar createEqualText = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n compareText = _ref.compareText,\n isZero = _ref.isZero;\n\n /**\n * Check equality of two strings. Comparison is case sensitive.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.equalText(x, y)\n *\n * Examples:\n *\n * math.equalText('Hello', 'Hello') // returns true\n * math.equalText('a', 'A') // returns false\n * math.equal('2e3', '2000') // returns true\n * math.equalText('2e3', '2000') // returns false\n *\n * math.equalText('B', ['A', 'B', 'C']) // returns [false, true, false]\n *\n * See also:\n *\n * equal, compareText, compare, compareNatural\n *\n * @param {string | Array | DenseMatrix} x First string to compare\n * @param {string | Array | DenseMatrix} y Second string to compare\n * @return {number | Array | DenseMatrix} Returns true if the values are equal, and false if not.\n */\n return typed(name, {\n 'any, any': function anyAny(x, y) {\n return isZero(compareText(x, y));\n }\n });\n});\nexports.createEqualText = createEqualText;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLargerNumber = exports.createLarger = void 0;\n\nvar _nearlyEqual = require(\"../../utils/bignumber/nearlyEqual.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm07.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar name = 'larger';\nvar dependencies = ['typed', 'config', 'matrix', 'DenseMatrix'];\nvar createLarger = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n matrix = _ref.matrix,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm03 = (0, _algorithm.createAlgorithm03)({\n typed: typed\n });\n var algorithm07 = (0, _algorithm2.createAlgorithm07)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm12 = (0, _algorithm3.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm5.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm4.createAlgorithm14)({\n typed: typed\n });\n /**\n * Test whether value x is larger than y.\n *\n * The function returns true when x is larger than y and the relative\n * difference between x and y is larger than the configured epsilon. The\n * function cannot be used to compare values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.larger(x, y)\n *\n * Examples:\n *\n * math.larger(2, 3) // returns false\n * math.larger(5, 2 + 2) // returns true\n *\n * const a = math.unit('5 cm')\n * const b = math.unit('2 inch')\n * math.larger(a, b) // returns false\n *\n * See also:\n *\n * equal, unequal, smaller, smallerEq, largerEq, compare\n *\n * @param {number | BigNumber | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare\n * @param {number | BigNumber | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare\n * @return {boolean | Array | Matrix} Returns true when the x is larger than y, else returns false\n */\n\n return typed(name, {\n 'boolean, boolean': function booleanBoolean(x, y) {\n return x > y;\n },\n 'number, number': function numberNumber(x, y) {\n return x > y && !(0, _number.nearlyEqual)(x, y, config.epsilon);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return x.gt(y) && !(0, _nearlyEqual.nearlyEqual)(x, y, config.epsilon);\n },\n 'Fraction, Fraction': function FractionFraction(x, y) {\n return x.compare(y) === 1;\n },\n 'Complex, Complex': function ComplexComplex() {\n throw new TypeError('No ordering relation is defined for complex numbers');\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n if (!x.equalBase(y)) {\n throw new Error('Cannot compare units with different base');\n }\n\n return this(x.value, y.value);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm07(x, y, this);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm03(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm12(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createLarger = createLarger;\nvar createLargerNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config'], function (_ref2) {\n var typed = _ref2.typed,\n config = _ref2.config;\n return typed(name, {\n 'number, number': function numberNumber(x, y) {\n return x > y && !(0, _number.nearlyEqual)(x, y, config.epsilon);\n }\n });\n});\nexports.createLargerNumber = createLargerNumber;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createLargerEqNumber = exports.createLargerEq = void 0;\n\nvar _nearlyEqual = require(\"../../utils/bignumber/nearlyEqual.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm07.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar name = 'largerEq';\nvar dependencies = ['typed', 'config', 'matrix', 'DenseMatrix'];\nvar createLargerEq = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n matrix = _ref.matrix,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm03 = (0, _algorithm.createAlgorithm03)({\n typed: typed\n });\n var algorithm07 = (0, _algorithm2.createAlgorithm07)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm12 = (0, _algorithm3.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm5.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm4.createAlgorithm14)({\n typed: typed\n });\n /**\n * Test whether value x is larger or equal to y.\n *\n * The function returns true when x is larger than y or the relative\n * difference between x and y is smaller than the configured epsilon. The\n * function cannot be used to compare values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.largerEq(x, y)\n *\n * Examples:\n *\n * math.larger(2, 1 + 1) // returns false\n * math.largerEq(2, 1 + 1) // returns true\n *\n * See also:\n *\n * equal, unequal, smaller, smallerEq, larger, compare\n *\n * @param {number | BigNumber | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare\n * @param {number | BigNumber | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare\n * @return {boolean | Array | Matrix} Returns true when the x is larger or equal to y, else returns false\n */\n\n return typed(name, {\n 'boolean, boolean': function booleanBoolean(x, y) {\n return x >= y;\n },\n 'number, number': function numberNumber(x, y) {\n return x >= y || (0, _number.nearlyEqual)(x, y, config.epsilon);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return x.gte(y) || (0, _nearlyEqual.nearlyEqual)(x, y, config.epsilon);\n },\n 'Fraction, Fraction': function FractionFraction(x, y) {\n return x.compare(y) !== -1;\n },\n 'Complex, Complex': function ComplexComplex() {\n throw new TypeError('No ordering relation is defined for complex numbers');\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n if (!x.equalBase(y)) {\n throw new Error('Cannot compare units with different base');\n }\n\n return this(x.value, y.value);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm07(x, y, this);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm03(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm12(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createLargerEq = createLargerEq;\nvar createLargerEqNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config'], function (_ref2) {\n var typed = _ref2.typed,\n config = _ref2.config;\n return typed(name, {\n 'number, number': function numberNumber(x, y) {\n return x >= y || (0, _number.nearlyEqual)(x, y, config.epsilon);\n }\n });\n});\nexports.createLargerEqNumber = createLargerEqNumber;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSmallerNumber = exports.createSmaller = void 0;\n\nvar _nearlyEqual = require(\"../../utils/bignumber/nearlyEqual.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm07.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar name = 'smaller';\nvar dependencies = ['typed', 'config', 'matrix', 'DenseMatrix'];\nvar createSmaller = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n matrix = _ref.matrix,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm03 = (0, _algorithm.createAlgorithm03)({\n typed: typed\n });\n var algorithm07 = (0, _algorithm2.createAlgorithm07)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm12 = (0, _algorithm3.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm5.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm4.createAlgorithm14)({\n typed: typed\n });\n /**\n * Test whether value x is smaller than y.\n *\n * The function returns true when x is smaller than y and the relative\n * difference between x and y is smaller than the configured epsilon. The\n * function cannot be used to compare values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.smaller(x, y)\n *\n * Examples:\n *\n * math.smaller(2, 3) // returns true\n * math.smaller(5, 2 * 2) // returns false\n *\n * const a = math.unit('5 cm')\n * const b = math.unit('2 inch')\n * math.smaller(a, b) // returns true\n *\n * See also:\n *\n * equal, unequal, smallerEq, smaller, smallerEq, compare\n *\n * @param {number | BigNumber | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare\n * @param {number | BigNumber | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare\n * @return {boolean | Array | Matrix} Returns true when the x is smaller than y, else returns false\n */\n\n return typed(name, {\n 'boolean, boolean': function booleanBoolean(x, y) {\n return x < y;\n },\n 'number, number': function numberNumber(x, y) {\n return x < y && !(0, _number.nearlyEqual)(x, y, config.epsilon);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return x.lt(y) && !(0, _nearlyEqual.nearlyEqual)(x, y, config.epsilon);\n },\n 'Fraction, Fraction': function FractionFraction(x, y) {\n return x.compare(y) === -1;\n },\n 'Complex, Complex': function ComplexComplex(x, y) {\n throw new TypeError('No ordering relation is defined for complex numbers');\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n if (!x.equalBase(y)) {\n throw new Error('Cannot compare units with different base');\n }\n\n return this(x.value, y.value);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm07(x, y, this);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm03(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm12(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createSmaller = createSmaller;\nvar createSmallerNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config'], function (_ref2) {\n var typed = _ref2.typed,\n config = _ref2.config;\n return typed(name, {\n 'number, number': function numberNumber(x, y) {\n return x < y && !(0, _number.nearlyEqual)(x, y, config.epsilon);\n }\n });\n});\nexports.createSmallerNumber = createSmallerNumber;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSmallerEqNumber = exports.createSmallerEq = void 0;\n\nvar _nearlyEqual = require(\"../../utils/bignumber/nearlyEqual.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm07.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar name = 'smallerEq';\nvar dependencies = ['typed', 'config', 'matrix', 'DenseMatrix'];\nvar createSmallerEq = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n matrix = _ref.matrix,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm03 = (0, _algorithm.createAlgorithm03)({\n typed: typed\n });\n var algorithm07 = (0, _algorithm2.createAlgorithm07)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm12 = (0, _algorithm3.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm5.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm4.createAlgorithm14)({\n typed: typed\n });\n /**\n * Test whether value x is smaller or equal to y.\n *\n * The function returns true when x is smaller than y or the relative\n * difference between x and y is smaller than the configured epsilon. The\n * function cannot be used to compare values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * Strings are compared by their numerical value.\n *\n * Syntax:\n *\n * math.smallerEq(x, y)\n *\n * Examples:\n *\n * math.smaller(1 + 2, 3) // returns false\n * math.smallerEq(1 + 2, 3) // returns true\n *\n * See also:\n *\n * equal, unequal, smaller, larger, largerEq, compare\n *\n * @param {number | BigNumber | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare\n * @param {number | BigNumber | Fraction | boolean | Unit | string | Array | Matrix} y Second value to compare\n * @return {boolean | Array | Matrix} Returns true when the x is smaller than y, else returns false\n */\n\n return typed(name, {\n 'boolean, boolean': function booleanBoolean(x, y) {\n return x <= y;\n },\n 'number, number': function numberNumber(x, y) {\n return x <= y || (0, _number.nearlyEqual)(x, y, config.epsilon);\n },\n 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {\n return x.lte(y) || (0, _nearlyEqual.nearlyEqual)(x, y, config.epsilon);\n },\n 'Fraction, Fraction': function FractionFraction(x, y) {\n return x.compare(y) !== 1;\n },\n 'Complex, Complex': function ComplexComplex() {\n throw new TypeError('No ordering relation is defined for complex numbers');\n },\n 'Unit, Unit': function UnitUnit(x, y) {\n if (!x.equalBase(y)) {\n throw new Error('Cannot compare units with different base');\n }\n\n return this(x.value, y.value);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm07(x, y, this);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm03(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm12(x, y, this, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, this, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createSmallerEq = createSmallerEq;\nvar createSmallerEqNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config'], function (_ref2) {\n var typed = _ref2.typed,\n config = _ref2.config;\n return typed(name, {\n 'number, number': function numberNumber(x, y) {\n return x <= y || (0, _number.nearlyEqual)(x, y, config.epsilon);\n }\n });\n});\nexports.createSmallerEqNumber = createSmallerEqNumber;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createUnequalNumber = exports.createUnequal = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm07.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar name = 'unequal';\nvar dependencies = ['typed', 'config', 'equalScalar', 'matrix', 'DenseMatrix'];\nvar createUnequal = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n equalScalar = _ref.equalScalar,\n matrix = _ref.matrix,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm03 = (0, _algorithm.createAlgorithm03)({\n typed: typed\n });\n var algorithm07 = (0, _algorithm2.createAlgorithm07)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm12 = (0, _algorithm3.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm5.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm4.createAlgorithm14)({\n typed: typed\n });\n /**\n * Test whether two values are unequal.\n *\n * The function tests whether the relative difference between x and y is\n * larger than the configured epsilon. The function cannot be used to compare\n * values smaller than approximately 2.22e-16.\n *\n * For matrices, the function is evaluated element wise.\n * In case of complex numbers, x.re must unequal y.re, or x.im must unequal y.im.\n * Strings are compared by their numerical value.\n *\n * Values `null` and `undefined` are compared strictly, thus `null` is unequal\n * with everything except `null`, and `undefined` is unequal with everything\n * except `undefined`.\n *\n * Syntax:\n *\n * math.unequal(x, y)\n *\n * Examples:\n *\n * math.unequal(2 + 2, 3) // returns true\n * math.unequal(2 + 2, 4) // returns false\n *\n * const a = math.unit('50 cm')\n * const b = math.unit('5 m')\n * math.unequal(a, b) // returns false\n *\n * const c = [2, 5, 1]\n * const d = [2, 7, 1]\n *\n * math.unequal(c, d) // returns [false, true, false]\n * math.deepEqual(c, d) // returns false\n *\n * math.unequal(0, null) // returns true\n * See also:\n *\n * equal, deepEqual, smaller, smallerEq, larger, largerEq, compare\n *\n * @param {number | BigNumber | Fraction | boolean | Complex | Unit | string | Array | Matrix | undefined} x First value to compare\n * @param {number | BigNumber | Fraction | boolean | Complex | Unit | string | Array | Matrix | undefined} y Second value to compare\n * @return {boolean | Array | Matrix} Returns true when the compared values are unequal, else returns false\n */\n\n return typed('unequal', {\n 'any, any': function anyAny(x, y) {\n // strict equality for null and undefined?\n if (x === null) {\n return y !== null;\n }\n\n if (y === null) {\n return x !== null;\n }\n\n if (x === undefined) {\n return y !== undefined;\n }\n\n if (y === undefined) {\n return x !== undefined;\n }\n\n return _unequal(x, y);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm07(x, y, _unequal);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n return algorithm03(y, x, _unequal, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, _unequal, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, _unequal);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'SparseMatrix, any': function SparseMatrixAny(x, y) {\n return algorithm12(x, y, _unequal, false);\n },\n 'DenseMatrix, any': function DenseMatrixAny(x, y) {\n return algorithm14(x, y, _unequal, false);\n },\n 'any, SparseMatrix': function anySparseMatrix(x, y) {\n return algorithm12(y, x, _unequal, true);\n },\n 'any, DenseMatrix': function anyDenseMatrix(x, y) {\n return algorithm14(y, x, _unequal, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, _unequal, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, _unequal, true).valueOf();\n }\n });\n\n function _unequal(x, y) {\n return !equalScalar(x, y);\n }\n});\nexports.createUnequal = createUnequal;\nvar createUnequalNumber = (0, _factory.factory)(name, ['typed', 'equalScalar'], function (_ref2) {\n var typed = _ref2.typed,\n equalScalar = _ref2.equalScalar;\n return typed(name, {\n 'any, any': function anyAny(x, y) {\n // strict equality for null and undefined?\n if (x === null) {\n return y !== null;\n }\n\n if (y === null) {\n return x !== null;\n }\n\n if (x === undefined) {\n return y !== undefined;\n }\n\n if (y === undefined) {\n return x !== undefined;\n }\n\n return !equalScalar(x, y);\n }\n });\n});\nexports.createUnequalNumber = createUnequalNumber;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSetCartesian = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'setCartesian';\nvar dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix'];\nvar createSetCartesian = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n size = _ref.size,\n subset = _ref.subset,\n compareNatural = _ref.compareNatural,\n Index = _ref.Index,\n DenseMatrix = _ref.DenseMatrix;\n\n /**\n * Create the cartesian product of two (multi)sets.\n * Multi-dimension arrays will be converted to single-dimension arrays\n * and the values will be sorted in ascending order before the operation.\n *\n * Syntax:\n *\n * math.setCartesian(set1, set2)\n *\n * Examples:\n *\n * math.setCartesian([1, 2], [3, 4]) // returns [[1, 3], [1, 4], [2, 3], [2, 4]]\n * math.setCartesian([4, 3], [2, 1]) // returns [[3, 1], [3, 2], [4, 1], [4, 2]]\n *\n * See also:\n *\n * setUnion, setIntersect, setDifference, setPowerset\n *\n * @param {Array | Matrix} a1 A (multi)set\n * @param {Array | Matrix} a2 A (multi)set\n * @return {Array | Matrix} The cartesian product of two (multi)sets\n */\n return typed(name, {\n 'Array | Matrix, Array | Matrix': function ArrayMatrixArrayMatrix(a1, a2) {\n var result = [];\n\n if (subset(size(a1), new Index(0)) !== 0 && subset(size(a2), new Index(0)) !== 0) {\n // if any of them is empty, return empty\n var b1 = (0, _array.flatten)(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural);\n var b2 = (0, _array.flatten)(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural);\n result = [];\n\n for (var i = 0; i < b1.length; i++) {\n for (var j = 0; j < b2.length; j++) {\n result.push([b1[i], b2[j]]);\n }\n }\n } // return an array, if both inputs were arrays\n\n\n if (Array.isArray(a1) && Array.isArray(a2)) {\n return result;\n } // return a matrix otherwise\n\n\n return new DenseMatrix(result);\n }\n });\n});\nexports.createSetCartesian = createSetCartesian;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSetDifference = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'setDifference';\nvar dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix'];\nvar createSetDifference = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n size = _ref.size,\n subset = _ref.subset,\n compareNatural = _ref.compareNatural,\n Index = _ref.Index,\n DenseMatrix = _ref.DenseMatrix;\n\n /**\n * Create the difference of two (multi)sets: every element of set1, that is not the element of set2.\n * Multi-dimension arrays will be converted to single-dimension arrays before the operation.\n *\n * Syntax:\n *\n * math.setDifference(set1, set2)\n *\n * Examples:\n *\n * math.setDifference([1, 2, 3, 4], [3, 4, 5, 6]) // returns [1, 2]\n * math.setDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [1, 2]\n *\n * See also:\n *\n * setUnion, setIntersect, setSymDifference\n *\n * @param {Array | Matrix} a1 A (multi)set\n * @param {Array | Matrix} a2 A (multi)set\n * @return {Array | Matrix} The difference of two (multi)sets\n */\n return typed(name, {\n 'Array | Matrix, Array | Matrix': function ArrayMatrixArrayMatrix(a1, a2) {\n var result;\n\n if (subset(size(a1), new Index(0)) === 0) {\n // empty-anything=empty\n result = [];\n } else if (subset(size(a2), new Index(0)) === 0) {\n // anything-empty=anything\n return (0, _array.flatten)(a1.toArray());\n } else {\n var b1 = (0, _array.identify)((0, _array.flatten)(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural));\n var b2 = (0, _array.identify)((0, _array.flatten)(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural));\n result = [];\n var inb2;\n\n for (var i = 0; i < b1.length; i++) {\n inb2 = false;\n\n for (var j = 0; j < b2.length; j++) {\n if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) {\n // the identifier is always a decimal int\n inb2 = true;\n break;\n }\n }\n\n if (!inb2) {\n result.push(b1[i]);\n }\n }\n } // return an array, if both inputs were arrays\n\n\n if (Array.isArray(a1) && Array.isArray(a2)) {\n return (0, _array.generalize)(result);\n } // return a matrix otherwise\n\n\n return new DenseMatrix((0, _array.generalize)(result));\n }\n });\n});\nexports.createSetDifference = createSetDifference;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSetDistinct = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'setDistinct';\nvar dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix'];\nvar createSetDistinct = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n size = _ref.size,\n subset = _ref.subset,\n compareNatural = _ref.compareNatural,\n Index = _ref.Index,\n DenseMatrix = _ref.DenseMatrix;\n\n /**\n * Collect the distinct elements of a multiset.\n * A multi-dimension array will be converted to a single-dimension array before the operation.\n *\n * Syntax:\n *\n * math.setDistinct(set)\n *\n * Examples:\n *\n * math.setDistinct([1, 1, 1, 2, 2, 3]) // returns [1, 2, 3]\n *\n * See also:\n *\n * setMultiplicity\n *\n * @param {Array | Matrix} a A multiset\n * @return {Array | Matrix} A set containing the distinc elements of the multiset\n */\n return typed(name, {\n 'Array | Matrix': function ArrayMatrix(a) {\n var result;\n\n if (subset(size(a), new Index(0)) === 0) {\n // if empty, return empty\n result = [];\n } else {\n var b = (0, _array.flatten)(Array.isArray(a) ? a : a.toArray()).sort(compareNatural);\n result = [];\n result.push(b[0]);\n\n for (var i = 1; i < b.length; i++) {\n if (compareNatural(b[i], b[i - 1]) !== 0) {\n result.push(b[i]);\n }\n }\n } // return an array, if the input was an array\n\n\n if (Array.isArray(a)) {\n return result;\n } // return a matrix otherwise\n\n\n return new DenseMatrix(result);\n }\n });\n});\nexports.createSetDistinct = createSetDistinct;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSetIntersect = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'setIntersect';\nvar dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix'];\nvar createSetIntersect = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n size = _ref.size,\n subset = _ref.subset,\n compareNatural = _ref.compareNatural,\n Index = _ref.Index,\n DenseMatrix = _ref.DenseMatrix;\n\n /**\n * Create the intersection of two (multi)sets.\n * Multi-dimension arrays will be converted to single-dimension arrays before the operation.\n *\n * Syntax:\n *\n * math.setIntersect(set1, set2)\n *\n * Examples:\n *\n * math.setIntersect([1, 2, 3, 4], [3, 4, 5, 6]) // returns [3, 4]\n * math.setIntersect([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [3, 4]\n *\n * See also:\n *\n * setUnion, setDifference\n *\n * @param {Array | Matrix} a1 A (multi)set\n * @param {Array | Matrix} a2 A (multi)set\n * @return {Array | Matrix} The intersection of two (multi)sets\n */\n return typed(name, {\n 'Array | Matrix, Array | Matrix': function ArrayMatrixArrayMatrix(a1, a2) {\n var result;\n\n if (subset(size(a1), new Index(0)) === 0 || subset(size(a2), new Index(0)) === 0) {\n // of any of them is empty, return empty\n result = [];\n } else {\n var b1 = (0, _array.identify)((0, _array.flatten)(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural));\n var b2 = (0, _array.identify)((0, _array.flatten)(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural));\n result = [];\n\n for (var i = 0; i < b1.length; i++) {\n for (var j = 0; j < b2.length; j++) {\n if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) {\n // the identifier is always a decimal int\n result.push(b1[i]);\n break;\n }\n }\n }\n } // return an array, if both inputs were arrays\n\n\n if (Array.isArray(a1) && Array.isArray(a2)) {\n return (0, _array.generalize)(result);\n } // return a matrix otherwise\n\n\n return new DenseMatrix((0, _array.generalize)(result));\n }\n });\n});\nexports.createSetIntersect = createSetIntersect;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSetIsSubset = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'setIsSubset';\nvar dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index'];\nvar createSetIsSubset = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n size = _ref.size,\n subset = _ref.subset,\n compareNatural = _ref.compareNatural,\n Index = _ref.Index;\n\n /**\n * Check whether a (multi)set is a subset of another (multi)set. (Every element of set1 is the element of set2.)\n * Multi-dimension arrays will be converted to single-dimension arrays before the operation.\n *\n * Syntax:\n *\n * math.setIsSubset(set1, set2)\n *\n * Examples:\n *\n * math.setIsSubset([1, 2], [3, 4, 5, 6]) // returns false\n * math.setIsSubset([3, 4], [3, 4, 5, 6]) // returns true\n *\n * See also:\n *\n * setUnion, setIntersect, setDifference\n *\n * @param {Array | Matrix} a1 A (multi)set\n * @param {Array | Matrix} a2 A (multi)set\n * @return {boolean} true | false\n */\n return typed(name, {\n 'Array | Matrix, Array | Matrix': function ArrayMatrixArrayMatrix(a1, a2) {\n if (subset(size(a1), new Index(0)) === 0) {\n // empty is a subset of anything\n return true;\n } else if (subset(size(a2), new Index(0)) === 0) {\n // anything is not a subset of empty\n return false;\n }\n\n var b1 = (0, _array.identify)((0, _array.flatten)(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural));\n var b2 = (0, _array.identify)((0, _array.flatten)(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural));\n var inb2;\n\n for (var i = 0; i < b1.length; i++) {\n inb2 = false;\n\n for (var j = 0; j < b2.length; j++) {\n if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) {\n // the identifier is always a decimal int\n inb2 = true;\n break;\n }\n }\n\n if (inb2 === false) {\n return false;\n }\n }\n\n return true;\n }\n });\n});\nexports.createSetIsSubset = createSetIsSubset;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSetMultiplicity = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'setMultiplicity';\nvar dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index'];\nvar createSetMultiplicity = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n size = _ref.size,\n subset = _ref.subset,\n compareNatural = _ref.compareNatural,\n Index = _ref.Index;\n\n /**\n * Count the multiplicity of an element in a multiset.\n * A multi-dimension array will be converted to a single-dimension array before the operation.\n *\n * Syntax:\n *\n * math.setMultiplicity(element, set)\n *\n * Examples:\n *\n * math.setMultiplicity(1, [1, 2, 2, 4]) // returns 1\n * math.setMultiplicity(2, [1, 2, 2, 4]) // returns 2\n *\n * See also:\n *\n * setDistinct, setSize\n *\n * @param {number | BigNumber | Fraction | Complex} e An element in the multiset\n * @param {Array | Matrix} a A multiset\n * @return {number} The number of how many times the multiset contains the element\n */\n return typed(name, {\n 'number | BigNumber | Fraction | Complex, Array | Matrix': function numberBigNumberFractionComplexArrayMatrix(e, a) {\n if (subset(size(a), new Index(0)) === 0) {\n // if empty, return 0\n return 0;\n }\n\n var b = (0, _array.flatten)(Array.isArray(a) ? a : a.toArray());\n var count = 0;\n\n for (var i = 0; i < b.length; i++) {\n if (compareNatural(b[i], e) === 0) {\n count++;\n }\n }\n\n return count;\n }\n });\n});\nexports.createSetMultiplicity = createSetMultiplicity;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSetPowerset = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'setPowerset';\nvar dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index'];\nvar createSetPowerset = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n size = _ref.size,\n subset = _ref.subset,\n compareNatural = _ref.compareNatural,\n Index = _ref.Index;\n\n /**\n * Create the powerset of a (multi)set. (The powerset contains very possible subsets of a (multi)set.)\n * A multi-dimension array will be converted to a single-dimension array before the operation.\n *\n * Syntax:\n *\n * math.setPowerset(set)\n *\n * Examples:\n *\n * math.setPowerset([1, 2, 3]) // returns [[], [1], [2], [3], [1, 2], [1, 3], [2, 3], [1, 2, 3]]\n *\n * See also:\n *\n * setCartesian\n *\n * @param {Array | Matrix} a A (multi)set\n * @return {Array} The powerset of the (multi)set\n */\n return typed(name, {\n 'Array | Matrix': function ArrayMatrix(a) {\n if (subset(size(a), new Index(0)) === 0) {\n // if empty, return empty\n return [];\n }\n\n var b = (0, _array.flatten)(Array.isArray(a) ? a : a.toArray()).sort(compareNatural);\n var result = [];\n var number = 0;\n\n while (number.toString(2).length <= b.length) {\n result.push(_subset(b, number.toString(2).split('').reverse()));\n number++;\n } // can not return a matrix, because of the different size of the subarrays\n\n\n return _sort(result);\n }\n }); // create subset\n\n function _subset(array, bitarray) {\n var result = [];\n\n for (var i = 0; i < bitarray.length; i++) {\n if (bitarray[i] === '1') {\n result.push(array[i]);\n }\n }\n\n return result;\n } // sort subsests by length\n\n\n function _sort(array) {\n var temp = [];\n\n for (var i = array.length - 1; i > 0; i--) {\n for (var j = 0; j < i; j++) {\n if (array[j].length > array[j + 1].length) {\n temp = array[j];\n array[j] = array[j + 1];\n array[j + 1] = temp;\n }\n }\n }\n\n return array;\n }\n});\nexports.createSetPowerset = createSetPowerset;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSetSize = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'setSize';\nvar dependencies = ['typed', 'compareNatural'];\nvar createSetSize = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n compareNatural = _ref.compareNatural;\n\n /**\n * Count the number of elements of a (multi)set. When a second parameter is 'true', count only the unique values.\n * A multi-dimension array will be converted to a single-dimension array before the operation.\n *\n * Syntax:\n *\n * math.setSize(set)\n * math.setSize(set, unique)\n *\n * Examples:\n *\n * math.setSize([1, 2, 2, 4]) // returns 4\n * math.setSize([1, 2, 2, 4], true) // returns 3\n *\n * See also:\n *\n * setUnion, setIntersect, setDifference\n *\n * @param {Array | Matrix} a A multiset\n * @return {number} The number of elements of the (multi)set\n */\n return typed(name, {\n 'Array | Matrix': function ArrayMatrix(a) {\n return Array.isArray(a) ? (0, _array.flatten)(a).length : (0, _array.flatten)(a.toArray()).length;\n },\n 'Array | Matrix, boolean': function ArrayMatrixBoolean(a, unique) {\n if (unique === false || a.length === 0) {\n return Array.isArray(a) ? (0, _array.flatten)(a).length : (0, _array.flatten)(a.toArray()).length;\n } else {\n var b = (0, _array.flatten)(Array.isArray(a) ? a : a.toArray()).sort(compareNatural);\n var count = 1;\n\n for (var i = 1; i < b.length; i++) {\n if (compareNatural(b[i], b[i - 1]) !== 0) {\n count++;\n }\n }\n\n return count;\n }\n }\n });\n});\nexports.createSetSize = createSetSize;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSetSymDifference = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'setSymDifference';\nvar dependencies = ['typed', 'size', 'concat', 'subset', 'setDifference', 'Index'];\nvar createSetSymDifference = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n size = _ref.size,\n concat = _ref.concat,\n subset = _ref.subset,\n setDifference = _ref.setDifference,\n Index = _ref.Index;\n\n /**\n * Create the symmetric difference of two (multi)sets.\n * Multi-dimension arrays will be converted to single-dimension arrays before the operation.\n *\n * Syntax:\n *\n * math.setSymDifference(set1, set2)\n *\n * Examples:\n *\n * math.setSymDifference([1, 2, 3, 4], [3, 4, 5, 6]) // returns [1, 2, 5, 6]\n * math.setSymDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [1, 2, 5, 6]\n *\n * See also:\n *\n * setUnion, setIntersect, setDifference\n *\n * @param {Array | Matrix} a1 A (multi)set\n * @param {Array | Matrix} a2 A (multi)set\n * @return {Array | Matrix} The symmetric difference of two (multi)sets\n */\n return typed(name, {\n 'Array | Matrix, Array | Matrix': function ArrayMatrixArrayMatrix(a1, a2) {\n if (subset(size(a1), new Index(0)) === 0) {\n // if any of them is empty, return the other one\n return (0, _array.flatten)(a2);\n } else if (subset(size(a2), new Index(0)) === 0) {\n return (0, _array.flatten)(a1);\n }\n\n var b1 = (0, _array.flatten)(a1);\n var b2 = (0, _array.flatten)(a2);\n return concat(setDifference(b1, b2), setDifference(b2, b1));\n }\n });\n});\nexports.createSetSymDifference = createSetSymDifference;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSetUnion = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'setUnion';\nvar dependencies = ['typed', 'size', 'concat', 'subset', 'setIntersect', 'setSymDifference', 'Index'];\nvar createSetUnion = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n size = _ref.size,\n concat = _ref.concat,\n subset = _ref.subset,\n setIntersect = _ref.setIntersect,\n setSymDifference = _ref.setSymDifference,\n Index = _ref.Index;\n\n /**\n * Create the union of two (multi)sets.\n * Multi-dimension arrays will be converted to single-dimension arrays before the operation.\n *\n * Syntax:\n *\n * math.setUnion(set1, set2)\n *\n * Examples:\n *\n * math.setUnion([1, 2, 3, 4], [3, 4, 5, 6]) // returns [1, 2, 3, 4, 5, 6]\n * math.setUnion([[1, 2], [3, 4]], [[3, 4], [5, 6]]) // returns [1, 2, 3, 4, 5, 6]\n *\n * See also:\n *\n * setIntersect, setDifference\n *\n * @param {Array | Matrix} a1 A (multi)set\n * @param {Array | Matrix} a2 A (multi)set\n * @return {Array | Matrix} The union of two (multi)sets\n */\n return typed(name, {\n 'Array | Matrix, Array | Matrix': function ArrayMatrixArrayMatrix(a1, a2) {\n if (subset(size(a1), new Index(0)) === 0) {\n // if any of them is empty, return the other one\n return (0, _array.flatten)(a2);\n } else if (subset(size(a2), new Index(0)) === 0) {\n return (0, _array.flatten)(a1);\n }\n\n var b1 = (0, _array.flatten)(a1);\n var b2 = (0, _array.flatten)(a2);\n return concat(setSymDifference(b1, b2), setIntersect(b1, b2));\n }\n });\n});\nexports.createSetUnion = createSetUnion;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createErf = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\n/* eslint-disable no-loss-of-precision */\nvar name = 'erf';\nvar dependencies = ['typed'];\nvar createErf = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Compute the erf function of a value using a rational Chebyshev\n * approximations for different intervals of x.\n *\n * This is a translation of W. J. Cody's Fortran implementation from 1987\n * ( https://www.netlib.org/specfun/erf ). See the AMS publication\n * \"Rational Chebyshev Approximations for the Error Function\" by W. J. Cody\n * for an explanation of this process.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.erf(x)\n *\n * Examples:\n *\n * math.erf(0.2) // returns 0.22270258921047847\n * math.erf(-0.5) // returns -0.5204998778130465\n * math.erf(4) // returns 0.9999999845827421\n *\n * @param {number | Array | Matrix} x A real number\n * @return {number | Array | Matrix} The erf of `x`\n */\n return typed('name', {\n number: function number(x) {\n var y = Math.abs(x);\n\n if (y >= MAX_NUM) {\n return (0, _number.sign)(x);\n }\n\n if (y <= THRESH) {\n return (0, _number.sign)(x) * erf1(y);\n }\n\n if (y <= 4.0) {\n return (0, _number.sign)(x) * (1 - erfc2(y));\n }\n\n return (0, _number.sign)(x) * (1 - erfc3(y));\n },\n 'Array | Matrix': function ArrayMatrix(n) {\n return (0, _collection.deepMap)(n, this);\n } // TODO: For complex numbers, use the approximation for the Faddeeva function\n // from \"More Efficient Computation of the Complex Error Function\" (AMS)\n\n });\n /**\n * Approximates the error function erf() for x <= 0.46875 using this function:\n * n\n * erf(x) = x * sum (p_j * x^(2j)) / (q_j * x^(2j))\n * j=0\n */\n\n function erf1(y) {\n var ysq = y * y;\n var xnum = P[0][4] * ysq;\n var xden = ysq;\n var i;\n\n for (i = 0; i < 3; i += 1) {\n xnum = (xnum + P[0][i]) * ysq;\n xden = (xden + Q[0][i]) * ysq;\n }\n\n return y * (xnum + P[0][3]) / (xden + Q[0][3]);\n }\n /**\n * Approximates the complement of the error function erfc() for\n * 0.46875 <= x <= 4.0 using this function:\n * n\n * erfc(x) = e^(-x^2) * sum (p_j * x^j) / (q_j * x^j)\n * j=0\n */\n\n\n function erfc2(y) {\n var xnum = P[1][8] * y;\n var xden = y;\n var i;\n\n for (i = 0; i < 7; i += 1) {\n xnum = (xnum + P[1][i]) * y;\n xden = (xden + Q[1][i]) * y;\n }\n\n var result = (xnum + P[1][7]) / (xden + Q[1][7]);\n var ysq = parseInt(y * 16) / 16;\n var del = (y - ysq) * (y + ysq);\n return Math.exp(-ysq * ysq) * Math.exp(-del) * result;\n }\n /**\n * Approximates the complement of the error function erfc() for x > 4.0 using\n * this function:\n *\n * erfc(x) = (e^(-x^2) / x) * [ 1/sqrt(pi) +\n * n\n * 1/(x^2) * sum (p_j * x^(-2j)) / (q_j * x^(-2j)) ]\n * j=0\n */\n\n\n function erfc3(y) {\n var ysq = 1 / (y * y);\n var xnum = P[2][5] * ysq;\n var xden = ysq;\n var i;\n\n for (i = 0; i < 4; i += 1) {\n xnum = (xnum + P[2][i]) * ysq;\n xden = (xden + Q[2][i]) * ysq;\n }\n\n var result = ysq * (xnum + P[2][4]) / (xden + Q[2][4]);\n result = (SQRPI - result) / y;\n ysq = parseInt(y * 16) / 16;\n var del = (y - ysq) * (y + ysq);\n return Math.exp(-ysq * ysq) * Math.exp(-del) * result;\n }\n});\n/**\n * Upper bound for the first approximation interval, 0 <= x <= THRESH\n * @constant\n */\n\nexports.createErf = createErf;\nvar THRESH = 0.46875;\n/**\n * Constant used by W. J. Cody's Fortran77 implementation to denote sqrt(pi)\n * @constant\n */\n\nvar SQRPI = 5.6418958354775628695e-1;\n/**\n * Coefficients for each term of the numerator sum (p_j) for each approximation\n * interval (see W. J. Cody's paper for more details)\n * @constant\n */\n\nvar P = [[3.16112374387056560e00, 1.13864154151050156e02, 3.77485237685302021e02, 3.20937758913846947e03, 1.85777706184603153e-1], [5.64188496988670089e-1, 8.88314979438837594e00, 6.61191906371416295e01, 2.98635138197400131e02, 8.81952221241769090e02, 1.71204761263407058e03, 2.05107837782607147e03, 1.23033935479799725e03, 2.15311535474403846e-8], [3.05326634961232344e-1, 3.60344899949804439e-1, 1.25781726111229246e-1, 1.60837851487422766e-2, 6.58749161529837803e-4, 1.63153871373020978e-2]];\n/**\n * Coefficients for each term of the denominator sum (q_j) for each approximation\n * interval (see W. J. Cody's paper for more details)\n * @constant\n */\n\nvar Q = [[2.36012909523441209e01, 2.44024637934444173e02, 1.28261652607737228e03, 2.84423683343917062e03], [1.57449261107098347e01, 1.17693950891312499e02, 5.37181101862009858e02, 1.62138957456669019e03, 3.29079923573345963e03, 4.36261909014324716e03, 3.43936767414372164e03, 1.23033935480374942e03], [2.56852019228982242e00, 1.87295284992346047e00, 5.27905102951428412e-1, 6.05183413124413191e-2, 2.33520497626869185e-3]];\n/**\n * Maximum/minimum safe numbers to input to erf() (in ES6+, this number is\n * Number.[MAX|MIN]_SAFE_INTEGER). erf() for all numbers beyond this limit will\n * return 1\n */\n\nvar MAX_NUM = Math.pow(2, 53);","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCumSum = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _switch2 = require(\"../../utils/switch.js\");\n\nvar _improveErrorMessage = require(\"./utils/improveErrorMessage.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _IndexError = require(\"../../error/IndexError.js\");\n\nvar name = 'cumsum';\nvar dependencies = ['typed', 'add', 'unaryPlus'];\nvar createCumSum = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n add = _ref.add,\n unaryPlus = _ref.unaryPlus;\n\n /**\n * Compute the cumulative sum of a matrix or a list with values.\n * In case of a (multi dimensional) array or matrix, the cumulative sums\n * along a specified dimension (defaulting to the first) will be calculated.\n *\n * Syntax:\n *\n * math.cumsum(a, b, c, ...)\n * math.cumsum(A)\n *\n * Examples:\n *\n * math.cumsum(2, 1, 4, 3) // returns [2, 3, 7, 10]\n * math.cumsum([2, 1, 4, 3]) // returns [2, 3, 7, 10]\n * math.cumsum([[1, 2], [3, 4]]) // returns [[1, 2], [4, 6]]\n * math.cumsum([[1, 2], [3, 4]], 0) // returns [[1, 2], [4, 6]]\n * math.cumsum([[1, 2], [3, 4]], 1) // returns [[1, 3], [3, 7]]\n * math.cumsum([[2, 5], [4, 3], [1, 7]]) // returns [[2, 5], [6, 8], [7, 15]]\n *\n * See also:\n *\n * mean, median, min, max, prod, std, variance, sum\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The cumulative sum of all values\n */\n return typed(name, {\n // sum([a, b, c, d, ...])\n Array: _cumsum,\n Matrix: function Matrix(matrix) {\n return matrix.create(_cumsum(matrix.valueOf()));\n },\n // sum([a, b, c, d, ...], dim)\n 'Array, number | BigNumber': _ncumSumDim,\n 'Matrix, number | BigNumber': function MatrixNumberBigNumber(matrix, dim) {\n return matrix.create(_ncumSumDim(matrix.valueOf(), dim));\n },\n // cumsum(a, b, c, d, ...)\n '...': function _(args) {\n if ((0, _collection.containsCollections)(args)) {\n throw new TypeError('All values expected to be scalar in function cumsum');\n }\n\n return _cumsum(args);\n }\n });\n /**\n * Recursively calculate the cumulative sum of an n-dimensional array\n * @param {Array} array\n * @return {number} cumsum\n * @private\n */\n\n function _cumsum(array) {\n try {\n return _cumsummap(array);\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, name);\n }\n }\n\n function _cumsummap(array) {\n if (array.length === 0) {\n return [];\n }\n\n var sums = [unaryPlus(array[0])]; // unaryPlus converts to number if need be\n\n for (var i = 1; i < array.length; ++i) {\n // Must use add below and not addScalar for the case of summing a\n // 2+-dimensional array along the 0th dimension (the row vectors,\n // or higher-d analogues, are literally added to each other).\n sums.push(add(sums[i - 1], array[i]));\n }\n\n return sums;\n }\n\n function _ncumSumDim(array, dim) {\n var size = (0, _array.arraySize)(array);\n\n if (dim < 0 || dim >= size.length) {\n // TODO: would be more clear when throwing a DimensionError here\n throw new _IndexError.IndexError(dim, size.length);\n }\n\n try {\n return _cumsumDimensional(array, dim);\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, name);\n }\n }\n /* Possible TODO: Refactor _reduce in collection.js to be able to work here as well */\n\n\n function _cumsumDimensional(mat, dim) {\n var i, ret, tran;\n\n if (dim <= 0) {\n var initialValue = mat[0][0];\n\n if (!Array.isArray(initialValue)) {\n return _cumsummap(mat);\n } else {\n tran = (0, _switch2._switch)(mat);\n ret = [];\n\n for (i = 0; i < tran.length; i++) {\n ret[i] = _cumsumDimensional(tran[i], dim - 1);\n }\n\n return ret;\n }\n } else {\n ret = [];\n\n for (i = 0; i < mat.length; i++) {\n ret[i] = _cumsumDimensional(mat[i], dim - 1);\n }\n\n return ret;\n }\n }\n});\nexports.createCumSum = createCumSum;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMad = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _improveErrorMessage = require(\"./utils/improveErrorMessage.js\");\n\nvar name = 'mad';\nvar dependencies = ['typed', 'abs', 'map', 'median', 'subtract'];\nvar createMad = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n abs = _ref.abs,\n map = _ref.map,\n median = _ref.median,\n subtract = _ref.subtract;\n\n /**\n * Compute the median absolute deviation of a matrix or a list with values.\n * The median absolute deviation is defined as the median of the absolute\n * deviations from the median.\n *\n * Syntax:\n *\n * math.mad(a, b, c, ...)\n * math.mad(A)\n *\n * Examples:\n *\n * math.mad(10, 20, 30) // returns 10\n * math.mad([1, 2, 3]) // returns 1\n * math.mad([[1, 2, 3], [4, 5, 6]]) // returns 1.5\n *\n * See also:\n *\n * median, mean, std, abs\n *\n * @param {Array | Matrix} array\n * A single matrix or multiple scalar values.\n * @return {*} The median absolute deviation.\n */\n return typed(name, {\n // mad([a, b, c, d, ...])\n 'Array | Matrix': _mad,\n // mad(a, b, c, d, ...)\n '...': function _(args) {\n return _mad(args);\n }\n });\n\n function _mad(array) {\n array = (0, _array.flatten)(array.valueOf());\n\n if (array.length === 0) {\n throw new Error('Cannot calculate median absolute deviation (mad) of an empty array');\n }\n\n try {\n var med = median(array);\n return median(map(array, function (value) {\n return abs(subtract(value, med));\n }));\n } catch (err) {\n if (err instanceof TypeError && err.message.indexOf('median') !== -1) {\n throw new TypeError(err.message.replace('median', 'mad'));\n } else {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'mad');\n }\n }\n }\n});\nexports.createMad = createMad;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMax = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _improveErrorMessage = require(\"./utils/improveErrorMessage.js\");\n\nvar name = 'max';\nvar dependencies = ['typed', 'config', 'numeric', 'larger'];\nvar createMax = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n numeric = _ref.numeric,\n larger = _ref.larger;\n\n /**\n * Compute the maximum value of a matrix or a list with values.\n * In case of a multi dimensional array, the maximum of the flattened array\n * will be calculated. When `dim` is provided, the maximum over the selected\n * dimension will be calculated. Parameter `dim` is zero-based.\n *\n * Syntax:\n *\n * math.max(a, b, c, ...)\n * math.max(A)\n * math.max(A, dim)\n *\n * Examples:\n *\n * math.max(2, 1, 4, 3) // returns 4\n * math.max([2, 1, 4, 3]) // returns 4\n *\n * // maximum over a specified dimension (zero-based)\n * math.max([[2, 5], [4, 3], [1, 7]], 0) // returns [4, 7]\n * math.max([[2, 5], [4, 3]], [1, 7], 1) // returns [5, 4, 7]\n *\n * math.max(2.7, 7.1, -4.5, 2.0, 4.1) // returns 7.1\n * math.min(2.7, 7.1, -4.5, 2.0, 4.1) // returns -4.5\n *\n * See also:\n *\n * mean, median, min, prod, std, sum, variance\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The maximum value\n */\n return typed(name, {\n // max([a, b, c, d, ...])\n 'Array | Matrix': _max,\n // max([a, b, c, d, ...], dim)\n 'Array | Matrix, number | BigNumber': function ArrayMatrixNumberBigNumber(array, dim) {\n return (0, _collection.reduce)(array, dim.valueOf(), _largest);\n },\n // max(a, b, c, d, ...)\n '...': function _(args) {\n if ((0, _collection.containsCollections)(args)) {\n throw new TypeError('Scalar values expected in function max');\n }\n\n return _max(args);\n }\n });\n /**\n * Return the largest of two values\n * @param {*} x\n * @param {*} y\n * @returns {*} Returns x when x is largest, or y when y is largest\n * @private\n */\n\n function _largest(x, y) {\n try {\n return larger(x, y) ? x : y;\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'max', y);\n }\n }\n /**\n * Recursively calculate the maximum value in an n-dimensional array\n * @param {Array} array\n * @return {number} max\n * @private\n */\n\n\n function _max(array) {\n var res;\n (0, _collection.deepForEach)(array, function (value) {\n try {\n if (isNaN(value) && typeof value === 'number') {\n res = NaN;\n } else if (res === undefined || larger(value, res)) {\n res = value;\n }\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'max', value);\n }\n });\n\n if (res === undefined) {\n throw new Error('Cannot calculate max of an empty array');\n } // make sure returning numeric value: parse a string into a numeric value\n\n\n if (typeof res === 'string') {\n res = numeric(res, config.number);\n }\n\n return res;\n }\n});\nexports.createMax = createMax;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMean = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _improveErrorMessage = require(\"./utils/improveErrorMessage.js\");\n\nvar name = 'mean';\nvar dependencies = ['typed', 'add', 'divide'];\nvar createMean = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n add = _ref.add,\n divide = _ref.divide;\n\n /**\n * Compute the mean value of matrix or a list with values.\n * In case of a multi dimensional array, the mean of the flattened array\n * will be calculated. When `dim` is provided, the maximum over the selected\n * dimension will be calculated. Parameter `dim` is zero-based.\n *\n * Syntax:\n *\n * math.mean(a, b, c, ...)\n * math.mean(A)\n * math.mean(A, dim)\n *\n * Examples:\n *\n * math.mean(2, 1, 4, 3) // returns 2.5\n * math.mean([1, 2.7, 3.2, 4]) // returns 2.725\n *\n * math.mean([[2, 5], [6, 3], [1, 7]], 0) // returns [3, 5]\n * math.mean([[2, 5], [6, 3], [1, 7]], 1) // returns [3.5, 4.5, 4]\n *\n * See also:\n *\n * median, min, max, sum, prod, std, variance\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The mean of all values\n */\n return typed(name, {\n // mean([a, b, c, d, ...])\n 'Array | Matrix': _mean,\n // mean([a, b, c, d, ...], dim)\n 'Array | Matrix, number | BigNumber': _nmeanDim,\n // mean(a, b, c, d, ...)\n '...': function _(args) {\n if ((0, _collection.containsCollections)(args)) {\n throw new TypeError('Scalar values expected in function mean');\n }\n\n return _mean(args);\n }\n });\n /**\n * Calculate the mean value in an n-dimensional array, returning a\n * n-1 dimensional array\n * @param {Array} array\n * @param {number} dim\n * @return {number} mean\n * @private\n */\n\n function _nmeanDim(array, dim) {\n try {\n var sum = (0, _collection.reduce)(array, dim, add);\n var s = Array.isArray(array) ? (0, _array.arraySize)(array) : array.size();\n return divide(sum, s[dim]);\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'mean');\n }\n }\n /**\n * Recursively calculate the mean value in an n-dimensional array\n * @param {Array} array\n * @return {number} mean\n * @private\n */\n\n\n function _mean(array) {\n var sum;\n var num = 0;\n (0, _collection.deepForEach)(array, function (value) {\n try {\n sum = sum === undefined ? value : add(sum, value);\n num++;\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'mean', value);\n }\n });\n\n if (num === 0) {\n throw new Error('Cannot calculate the mean of an empty array');\n }\n\n return divide(sum, num);\n }\n});\nexports.createMean = createMean;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMedian = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _improveErrorMessage = require(\"./utils/improveErrorMessage.js\");\n\nvar name = 'median';\nvar dependencies = ['typed', 'add', 'divide', 'compare', 'partitionSelect'];\nvar createMedian = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n add = _ref.add,\n divide = _ref.divide,\n compare = _ref.compare,\n partitionSelect = _ref.partitionSelect;\n\n /**\n * Recursively calculate the median of an n-dimensional array\n * @param {Array} array\n * @return {Number} median\n * @private\n */\n function _median(array) {\n try {\n array = (0, _array.flatten)(array.valueOf());\n var num = array.length;\n\n if (num === 0) {\n throw new Error('Cannot calculate median of an empty array');\n }\n\n if (num % 2 === 0) {\n // even: return the average of the two middle values\n var mid = num / 2 - 1;\n var right = partitionSelect(array, mid + 1); // array now partitioned at mid + 1, take max of left part\n\n var left = array[mid];\n\n for (var i = 0; i < mid; ++i) {\n if (compare(array[i], left) > 0) {\n left = array[i];\n }\n }\n\n return middle2(left, right);\n } else {\n // odd: return the middle value\n var m = partitionSelect(array, (num - 1) / 2);\n return middle(m);\n }\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'median');\n }\n } // helper function to type check the middle value of the array\n\n\n var middle = typed({\n 'number | BigNumber | Complex | Unit': function numberBigNumberComplexUnit(value) {\n return value;\n }\n }); // helper function to type check the two middle value of the array\n\n var middle2 = typed({\n 'number | BigNumber | Complex | Unit, number | BigNumber | Complex | Unit': function numberBigNumberComplexUnitNumberBigNumberComplexUnit(left, right) {\n return divide(add(left, right), 2);\n }\n });\n /**\n * Compute the median of a matrix or a list with values. The values are\n * sorted and the middle value is returned. In case of an even number of\n * values, the average of the two middle values is returned.\n * Supported types of values are: Number, BigNumber, Unit\n *\n * In case of a (multi dimensional) array or matrix, the median of all\n * elements will be calculated.\n *\n * Syntax:\n *\n * math.median(a, b, c, ...)\n * math.median(A)\n *\n * Examples:\n *\n * math.median(5, 2, 7) // returns 5\n * math.median([3, -1, 5, 7]) // returns 4\n *\n * See also:\n *\n * mean, min, max, sum, prod, std, variance, quantileSeq\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The median\n */\n\n return typed(name, {\n // median([a, b, c, d, ...])\n 'Array | Matrix': _median,\n // median([a, b, c, d, ...], dim)\n 'Array | Matrix, number | BigNumber': function ArrayMatrixNumberBigNumber(array, dim) {\n // TODO: implement median(A, dim)\n throw new Error('median(A, dim) is not yet supported'); // return reduce(arguments[0], arguments[1], ...)\n },\n // median(a, b, c, d, ...)\n '...': function _(args) {\n if ((0, _collection.containsCollections)(args)) {\n throw new TypeError('Scalar values expected in function median');\n }\n\n return _median(args);\n }\n });\n});\nexports.createMedian = createMedian;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMin = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _improveErrorMessage = require(\"./utils/improveErrorMessage.js\");\n\nvar name = 'min';\nvar dependencies = ['typed', 'config', 'numeric', 'smaller'];\nvar createMin = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n numeric = _ref.numeric,\n smaller = _ref.smaller;\n\n /**\n * Compute the minimum value of a matrix or a list of values.\n * In case of a multi dimensional array, the minimum of the flattened array\n * will be calculated. When `dim` is provided, the minimum over the selected\n * dimension will be calculated. Parameter `dim` is zero-based.\n *\n * Syntax:\n *\n * math.min(a, b, c, ...)\n * math.min(A)\n * math.min(A, dim)\n *\n * Examples:\n *\n * math.min(2, 1, 4, 3) // returns 1\n * math.min([2, 1, 4, 3]) // returns 1\n *\n * // minimum over a specified dimension (zero-based)\n * math.min([[2, 5], [4, 3], [1, 7]], 0) // returns [1, 3]\n * math.min([[2, 5], [4, 3], [1, 7]], 1) // returns [2, 3, 1]\n *\n * math.max(2.7, 7.1, -4.5, 2.0, 4.1) // returns 7.1\n * math.min(2.7, 7.1, -4.5, 2.0, 4.1) // returns -4.5\n *\n * See also:\n *\n * mean, median, max, prod, std, sum, variance\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The minimum value\n */\n return typed(name, {\n // min([a, b, c, d, ...])\n 'Array | Matrix': _min,\n // min([a, b, c, d, ...], dim)\n 'Array | Matrix, number | BigNumber': function ArrayMatrixNumberBigNumber(array, dim) {\n return (0, _collection.reduce)(array, dim.valueOf(), _smallest);\n },\n // min(a, b, c, d, ...)\n '...': function _(args) {\n if ((0, _collection.containsCollections)(args)) {\n throw new TypeError('Scalar values expected in function min');\n }\n\n return _min(args);\n }\n });\n /**\n * Return the smallest of two values\n * @param {*} x\n * @param {*} y\n * @returns {*} Returns x when x is smallest, or y when y is smallest\n * @private\n */\n\n function _smallest(x, y) {\n try {\n return smaller(x, y) ? x : y;\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'min', y);\n }\n }\n /**\n * Recursively calculate the minimum value in an n-dimensional array\n * @param {Array} array\n * @return {number} min\n * @private\n */\n\n\n function _min(array) {\n var min;\n (0, _collection.deepForEach)(array, function (value) {\n try {\n if (isNaN(value) && typeof value === 'number') {\n min = NaN;\n } else if (min === undefined || smaller(value, min)) {\n min = value;\n }\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'min', value);\n }\n });\n\n if (min === undefined) {\n throw new Error('Cannot calculate min of an empty array');\n } // make sure returning numeric value: parse a string into a numeric value\n\n\n if (typeof min === 'string') {\n min = numeric(min, config.number);\n }\n\n return min;\n }\n});\nexports.createMin = createMin;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMode = void 0;\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'mode';\nvar dependencies = ['typed', 'isNaN', 'isNumeric'];\nvar createMode = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n isNaN = _ref.isNaN,\n isNumeric = _ref.isNumeric;\n\n /**\n * Computes the mode of a set of numbers or a list with values(numbers or characters).\n * If there are more than one modes, it returns a list of those values.\n *\n * Syntax:\n *\n * math.mode(a, b, c, ...)\n * math.mode(A)\n *\n * Examples:\n *\n * math.mode(2, 1, 4, 3, 1) // returns [1]\n * math.mode([1, 2.7, 3.2, 4, 2.7]) // returns [2.7]\n * math.mode(1, 4, 6, 1, 6) // returns [1, 6]\n * math.mode('a','a','b','c') // returns [\"a\"]\n * math.mode(1, 1.5, 'abc') // returns [1, 1.5, \"abc\"]\n *\n * See also:\n *\n * median,\n * mean\n *\n * @param {... *} args A single matrix\n * @return {*} The mode of all values\n */\n return typed(name, {\n 'Array | Matrix': _mode,\n '...': function _(args) {\n return _mode(args);\n }\n });\n /**\n * Calculates the mode in an 1-dimensional array\n * @param {Array} values\n * @return {Array} mode\n * @private\n */\n\n function _mode(values) {\n values = (0, _array.flatten)(values.valueOf());\n var num = values.length;\n\n if (num === 0) {\n throw new Error('Cannot calculate mode of an empty array');\n }\n\n var count = {};\n var mode = [];\n var max = 0;\n\n for (var i = 0; i < values.length; i++) {\n var value = values[i];\n\n if (isNumeric(value) && isNaN(value)) {\n throw new Error('Cannot calculate mode of an array containing NaN values');\n }\n\n if (!(value in count)) {\n count[value] = 0;\n }\n\n count[value]++;\n\n if (count[value] === max) {\n mode.push(value);\n } else if (count[value] > max) {\n max = count[value];\n mode = [value];\n }\n }\n\n return mode;\n }\n});\nexports.createMode = createMode;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createProd = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _improveErrorMessage = require(\"./utils/improveErrorMessage.js\");\n\nvar name = 'prod';\nvar dependencies = ['typed', 'config', 'multiplyScalar', 'numeric'];\nvar createProd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n multiplyScalar = _ref.multiplyScalar,\n numeric = _ref.numeric;\n\n /**\n * Compute the product of a matrix or a list with values.\n * In case of a (multi dimensional) array or matrix, the sum of all\n * elements will be calculated.\n *\n * Syntax:\n *\n * math.prod(a, b, c, ...)\n * math.prod(A)\n *\n * Examples:\n *\n * math.multiply(2, 3) // returns 6\n * math.prod(2, 3) // returns 6\n * math.prod(2, 3, 4) // returns 24\n * math.prod([2, 3, 4]) // returns 24\n * math.prod([[2, 5], [4, 3]]) // returns 120\n *\n * See also:\n *\n * mean, median, min, max, sum, std, variance\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The product of all values\n */\n return typed(name, {\n // prod([a, b, c, d, ...])\n 'Array | Matrix': _prod,\n // prod([a, b, c, d, ...], dim)\n 'Array | Matrix, number | BigNumber': function ArrayMatrixNumberBigNumber(array, dim) {\n // TODO: implement prod(A, dim)\n throw new Error('prod(A, dim) is not yet supported'); // return reduce(arguments[0], arguments[1], math.prod)\n },\n // prod(a, b, c, d, ...)\n '...': function _(args) {\n return _prod(args);\n }\n });\n /**\n * Recursively calculate the product of an n-dimensional array\n * @param {Array} array\n * @return {number} prod\n * @private\n */\n\n function _prod(array) {\n var prod;\n (0, _collection.deepForEach)(array, function (value) {\n try {\n prod = prod === undefined ? value : multiplyScalar(prod, value);\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'prod', value);\n }\n }); // make sure returning numeric value: parse a string into a numeric value\n\n if (typeof prod === 'string') {\n prod = numeric(prod, config.number);\n }\n\n if (prod === undefined) {\n throw new Error('Cannot calculate prod of an empty array');\n }\n\n return prod;\n }\n});\nexports.createProd = createProd;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createQuantileSeq = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'quantileSeq';\nvar dependencies = ['typed', 'add', 'multiply', 'partitionSelect', 'compare'];\nvar createQuantileSeq = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n add = _ref.add,\n multiply = _ref.multiply,\n partitionSelect = _ref.partitionSelect,\n compare = _ref.compare;\n\n /**\n * Compute the prob order quantile of a matrix or a list with values.\n * The sequence is sorted and the middle value is returned.\n * Supported types of sequence values are: Number, BigNumber, Unit\n * Supported types of probability are: Number, BigNumber\n *\n * In case of a (multi dimensional) array or matrix, the prob order quantile\n * of all elements will be calculated.\n *\n * Syntax:\n *\n * math.quantileSeq(A, prob[, sorted])\n * math.quantileSeq(A, [prob1, prob2, ...][, sorted])\n * math.quantileSeq(A, N[, sorted])\n *\n * Examples:\n *\n * math.quantileSeq([3, -1, 5, 7], 0.5) // returns 4\n * math.quantileSeq([3, -1, 5, 7], [1/3, 2/3]) // returns [3, 5]\n * math.quantileSeq([3, -1, 5, 7], 2) // returns [3, 5]\n * math.quantileSeq([-1, 3, 5, 7], 0.5, true) // returns 4\n *\n * See also:\n *\n * median, mean, min, max, sum, prod, std, variance\n *\n * @param {Array, Matrix} data A single matrix or Array\n * @param {Number, BigNumber, Array} probOrN prob is the order of the quantile, while N is\n * the amount of evenly distributed steps of\n * probabilities; only one of these options can\n * be provided\n * @param {Boolean} sorted=false is data sorted in ascending order\n * @return {Number, BigNumber, Unit, Array} Quantile(s)\n */\n function quantileSeq(data, probOrN, sorted) {\n var probArr, dataArr, one;\n\n if (arguments.length < 2 || arguments.length > 3) {\n throw new SyntaxError('Function quantileSeq requires two or three parameters');\n }\n\n if ((0, _is.isCollection)(data)) {\n sorted = sorted || false;\n\n if (typeof sorted === 'boolean') {\n dataArr = data.valueOf();\n\n if ((0, _is.isNumber)(probOrN)) {\n if (probOrN < 0) {\n throw new Error('N/prob must be non-negative');\n }\n\n if (probOrN <= 1) {\n // quantileSeq([a, b, c, d, ...], prob[,sorted])\n return _quantileSeq(dataArr, probOrN, sorted);\n }\n\n if (probOrN > 1) {\n // quantileSeq([a, b, c, d, ...], N[,sorted])\n if (!(0, _number.isInteger)(probOrN)) {\n throw new Error('N must be a positive integer');\n }\n\n var nPlusOne = probOrN + 1;\n probArr = new Array(probOrN);\n\n for (var i = 0; i < probOrN;) {\n probArr[i] = _quantileSeq(dataArr, ++i / nPlusOne, sorted);\n }\n\n return probArr;\n }\n }\n\n if ((0, _is.isBigNumber)(probOrN)) {\n var BigNumber = probOrN.constructor;\n\n if (probOrN.isNegative()) {\n throw new Error('N/prob must be non-negative');\n }\n\n one = new BigNumber(1);\n\n if (probOrN.lte(one)) {\n // quantileSeq([a, b, c, d, ...], prob[,sorted])\n return new BigNumber(_quantileSeq(dataArr, probOrN, sorted));\n }\n\n if (probOrN.gt(one)) {\n // quantileSeq([a, b, c, d, ...], N[,sorted])\n if (!probOrN.isInteger()) {\n throw new Error('N must be a positive integer');\n } // largest possible Array length is 2^32-1\n // 2^32 < 10^15, thus safe conversion guaranteed\n\n\n var intN = probOrN.toNumber();\n\n if (intN > 4294967295) {\n throw new Error('N must be less than or equal to 2^32-1, as that is the maximum length of an Array');\n }\n\n var _nPlusOne = new BigNumber(intN + 1);\n\n probArr = new Array(intN);\n\n for (var _i = 0; _i < intN;) {\n probArr[_i] = new BigNumber(_quantileSeq(dataArr, new BigNumber(++_i).div(_nPlusOne), sorted));\n }\n\n return probArr;\n }\n }\n\n if (Array.isArray(probOrN)) {\n // quantileSeq([a, b, c, d, ...], [prob1, prob2, ...][,sorted])\n probArr = new Array(probOrN.length);\n\n for (var _i2 = 0; _i2 < probArr.length; ++_i2) {\n var currProb = probOrN[_i2];\n\n if ((0, _is.isNumber)(currProb)) {\n if (currProb < 0 || currProb > 1) {\n throw new Error('Probability must be between 0 and 1, inclusive');\n }\n } else if ((0, _is.isBigNumber)(currProb)) {\n one = new currProb.constructor(1);\n\n if (currProb.isNegative() || currProb.gt(one)) {\n throw new Error('Probability must be between 0 and 1, inclusive');\n }\n } else {\n throw new TypeError('Unexpected type of argument in function quantileSeq'); // FIXME: becomes redundant when converted to typed-function\n }\n\n probArr[_i2] = _quantileSeq(dataArr, currProb, sorted);\n }\n\n return probArr;\n }\n\n throw new TypeError('Unexpected type of argument in function quantileSeq'); // FIXME: becomes redundant when converted to typed-function\n }\n\n throw new TypeError('Unexpected type of argument in function quantileSeq'); // FIXME: becomes redundant when converted to typed-function\n }\n\n throw new TypeError('Unexpected type of argument in function quantileSeq'); // FIXME: becomes redundant when converted to typed-function\n }\n /**\n * Calculate the prob order quantile of an n-dimensional array.\n *\n * @param {Array} array\n * @param {Number, BigNumber} prob\n * @param {Boolean} sorted\n * @return {Number, BigNumber, Unit} prob order quantile\n * @private\n */\n\n\n function _quantileSeq(array, prob, sorted) {\n var flat = (0, _array.flatten)(array);\n var len = flat.length;\n\n if (len === 0) {\n throw new Error('Cannot calculate quantile of an empty sequence');\n }\n\n if ((0, _is.isNumber)(prob)) {\n var _index = prob * (len - 1);\n\n var _fracPart = _index % 1;\n\n if (_fracPart === 0) {\n var value = sorted ? flat[_index] : partitionSelect(flat, _index);\n validate(value);\n return value;\n }\n\n var _integerPart = Math.floor(_index);\n\n var _left;\n\n var _right;\n\n if (sorted) {\n _left = flat[_integerPart];\n _right = flat[_integerPart + 1];\n } else {\n _right = partitionSelect(flat, _integerPart + 1); // max of partition is kth largest\n\n _left = flat[_integerPart];\n\n for (var i = 0; i < _integerPart; ++i) {\n if (compare(flat[i], _left) > 0) {\n _left = flat[i];\n }\n }\n }\n\n validate(_left);\n validate(_right); // Q(prob) = (1-f)*A[floor(index)] + f*A[floor(index)+1]\n\n return add(multiply(_left, 1 - _fracPart), multiply(_right, _fracPart));\n } // If prob is a BigNumber\n\n\n var index = prob.times(len - 1);\n\n if (index.isInteger()) {\n index = index.toNumber();\n\n var _value = sorted ? flat[index] : partitionSelect(flat, index);\n\n validate(_value);\n return _value;\n }\n\n var integerPart = index.floor();\n var fracPart = index.minus(integerPart);\n var integerPartNumber = integerPart.toNumber();\n var left;\n var right;\n\n if (sorted) {\n left = flat[integerPartNumber];\n right = flat[integerPartNumber + 1];\n } else {\n right = partitionSelect(flat, integerPartNumber + 1); // max of partition is kth largest\n\n left = flat[integerPartNumber];\n\n for (var _i3 = 0; _i3 < integerPartNumber; ++_i3) {\n if (compare(flat[_i3], left) > 0) {\n left = flat[_i3];\n }\n }\n }\n\n validate(left);\n validate(right); // Q(prob) = (1-f)*A[floor(index)] + f*A[floor(index)+1]\n\n var one = new fracPart.constructor(1);\n return add(multiply(left, one.minus(fracPart)), multiply(right, fracPart));\n }\n /**\n * Check if array value types are valid, throw error otherwise.\n * @param {number | BigNumber | Unit} x\n * @param {number | BigNumber | Unit} x\n * @private\n */\n\n\n var validate = typed({\n 'number | BigNumber | Unit': function numberBigNumberUnit(x) {\n return x;\n }\n });\n return quantileSeq;\n});\nexports.createQuantileSeq = createQuantileSeq;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createStd = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'std';\nvar dependencies = ['typed', 'sqrt', 'variance'];\nvar createStd = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n sqrt = _ref.sqrt,\n variance = _ref.variance;\n\n /**\n * Compute the standard deviation of a matrix or a list with values.\n * The standard deviations is defined as the square root of the variance:\n * `std(A) = sqrt(variance(A))`.\n * In case of a (multi dimensional) array or matrix, the standard deviation\n * over all elements will be calculated by default, unless an axis is specified\n * in which case the standard deviation will be computed along that axis.\n *\n * Additionally, it is possible to compute the standard deviation along the rows\n * or columns of a matrix by specifying the dimension as the second argument.\n *\n * Optionally, the type of normalization can be specified as the final\n * parameter. The parameter `normalization` can be one of the following values:\n *\n * - 'unbiased' (default) The sum of squared errors is divided by (n - 1)\n * - 'uncorrected' The sum of squared errors is divided by n\n * - 'biased' The sum of squared errors is divided by (n + 1)\n *\n *\n * Syntax:\n *\n * math.std(a, b, c, ...)\n * math.std(A)\n * math.std(A, normalization)\n * math.std(A, dimension)\n * math.std(A, dimension, normalization)\n *\n * Examples:\n *\n * math.std(2, 4, 6) // returns 2\n * math.std([2, 4, 6, 8]) // returns 2.581988897471611\n * math.std([2, 4, 6, 8], 'uncorrected') // returns 2.23606797749979\n * math.std([2, 4, 6, 8], 'biased') // returns 2\n *\n * math.std([[1, 2, 3], [4, 5, 6]]) // returns 1.8708286933869707\n * math.std([[1, 2, 3], [4, 6, 8]], 0) // returns [2.1213203435596424, 2.8284271247461903, 3.5355339059327378]\n * math.std([[1, 2, 3], [4, 6, 8]], 1) // returns [1, 2]\n * math.std([[1, 2, 3], [4, 6, 8]], 1, 'biased') // returns [0.7071067811865476, 1.4142135623730951]\n *\n * See also:\n *\n * mean, median, max, min, prod, sum, variance\n *\n * @param {Array | Matrix} array\n * A single matrix or or multiple scalar values\n * @param {string} [normalization='unbiased']\n * Determines how to normalize the variance.\n * Choose 'unbiased' (default), 'uncorrected', or 'biased'.\n * @param dimension {number | BigNumber}\n * Determines the axis to compute the standard deviation for a matrix\n * @return {*} The standard deviation\n */\n return typed(name, {\n // std([a, b, c, d, ...])\n 'Array | Matrix': _std,\n // std([a, b, c, d, ...], normalization)\n 'Array | Matrix, string': _std,\n // std([a, b, c, c, ...], dim)\n 'Array | Matrix, number | BigNumber': _std,\n // std([a, b, c, c, ...], dim, normalization)\n 'Array | Matrix, number | BigNumber, string': _std,\n // std(a, b, c, d, ...)\n '...': function _(args) {\n return _std(args);\n }\n });\n\n function _std(array, normalization) {\n if (array.length === 0) {\n throw new SyntaxError('Function std requires one or more parameters (0 provided)');\n }\n\n try {\n return sqrt(variance.apply(null, arguments));\n } catch (err) {\n if (err instanceof TypeError && err.message.indexOf(' variance') !== -1) {\n throw new TypeError(err.message.replace(' variance', ' std'));\n } else {\n throw err;\n }\n }\n }\n});\nexports.createStd = createStd;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSum = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _improveErrorMessage = require(\"./utils/improveErrorMessage.js\");\n\nvar name = 'sum';\nvar dependencies = ['typed', 'config', 'add', 'numeric'];\nvar createSum = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n add = _ref.add,\n numeric = _ref.numeric;\n\n /**\n * Compute the sum of a matrix or a list with values.\n * In case of a (multi dimensional) array or matrix, the sum of all\n * elements will be calculated.\n *\n * Syntax:\n *\n * math.sum(a, b, c, ...)\n * math.sum(A)\n *\n * Examples:\n *\n * math.sum(2, 1, 4, 3) // returns 10\n * math.sum([2, 1, 4, 3]) // returns 10\n * math.sum([[2, 5], [4, 3], [1, 7]]) // returns 22\n *\n * See also:\n *\n * mean, median, min, max, prod, std, variance, cumsum\n *\n * @param {... *} args A single matrix or or multiple scalar values\n * @return {*} The sum of all values\n */\n return typed(name, {\n // sum([a, b, c, d, ...])\n 'Array | Matrix': _sum,\n // sum([a, b, c, d, ...], dim)\n 'Array | Matrix, number | BigNumber': _nsumDim,\n // sum(a, b, c, d, ...)\n '...': function _(args) {\n if ((0, _collection.containsCollections)(args)) {\n throw new TypeError('Scalar values expected in function sum');\n }\n\n return _sum(args);\n }\n });\n /**\n * Recursively calculate the sum of an n-dimensional array\n * @param {Array | Matrix} array\n * @return {number} sum\n * @private\n */\n\n function _sum(array) {\n var sum;\n (0, _collection.deepForEach)(array, function (value) {\n try {\n sum = sum === undefined ? value : add(sum, value);\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'sum', value);\n }\n }); // make sure returning numeric value: parse a string into a numeric value\n\n if (sum === undefined) {\n sum = numeric(0, config.number);\n }\n\n if (typeof sum === 'string') {\n sum = numeric(sum, config.number);\n }\n\n return sum;\n }\n\n function _nsumDim(array, dim) {\n try {\n var sum = (0, _collection.reduce)(array, dim, add);\n return sum;\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'sum');\n }\n }\n});\nexports.createSum = createSum;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.improveErrorMessage = improveErrorMessage;\n\nvar _is = require(\"../../../utils/is.js\");\n\n/**\n * Improve error messages for statistics functions. Errors are typically\n * thrown in an internally used function like larger, causing the error\n * not to mention the function (like max) which is actually used by the user.\n *\n * @param {Error} err\n * @param {String} fnName\n * @param {*} [value]\n * @return {Error}\n */\nfunction improveErrorMessage(err, fnName, value) {\n // TODO: add information with the index (also needs transform in expression parser)\n var details;\n\n if (String(err).indexOf('Unexpected type') !== -1) {\n details = arguments.length > 2 ? ' (type: ' + (0, _is.typeOf)(value) + ', value: ' + JSON.stringify(value) + ')' : ' (type: ' + err.data.actual + ')';\n return new TypeError('Cannot calculate ' + fnName + ', unexpected type of argument' + details);\n }\n\n if (String(err).indexOf('complex numbers') !== -1) {\n details = arguments.length > 2 ? ' (type: ' + (0, _is.typeOf)(value) + ', value: ' + JSON.stringify(value) + ')' : '';\n return new TypeError('Cannot calculate ' + fnName + ', no ordering relation is defined for complex numbers' + details);\n }\n\n return err;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createVariance = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _improveErrorMessage = require(\"./utils/improveErrorMessage.js\");\n\nvar DEFAULT_NORMALIZATION = 'unbiased';\nvar name = 'variance';\nvar dependencies = ['typed', 'add', 'subtract', 'multiply', 'divide', 'apply', 'isNaN'];\nvar createVariance = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n add = _ref.add,\n subtract = _ref.subtract,\n multiply = _ref.multiply,\n divide = _ref.divide,\n apply = _ref.apply,\n isNaN = _ref.isNaN;\n\n /**\n * Compute the variance of a matrix or a list with values.\n * In case of a (multi dimensional) array or matrix, the variance over all\n * elements will be calculated.\n *\n * Additionally, it is possible to compute the variance along the rows\n * or columns of a matrix by specifying the dimension as the second argument.\n *\n * Optionally, the type of normalization can be specified as the final\n * parameter. The parameter `normalization` can be one of the following values:\n *\n * - 'unbiased' (default) The sum of squared errors is divided by (n - 1)\n * - 'uncorrected' The sum of squared errors is divided by n\n * - 'biased' The sum of squared errors is divided by (n + 1)\n *\n *\n * Note that older browser may not like the variable name `var`. In that\n * case, the function can be called as `math['var'](...)` instead of\n * `math.var(...)`.\n *\n * Syntax:\n *\n * math.variance(a, b, c, ...)\n * math.variance(A)\n * math.variance(A, normalization)\n * math.variance(A, dimension)\n * math.variance(A, dimension, normalization)\n *\n * Examples:\n *\n * math.variance(2, 4, 6) // returns 4\n * math.variance([2, 4, 6, 8]) // returns 6.666666666666667\n * math.variance([2, 4, 6, 8], 'uncorrected') // returns 5\n * math.variance([2, 4, 6, 8], 'biased') // returns 4\n *\n * math.variance([[1, 2, 3], [4, 5, 6]]) // returns 3.5\n * math.variance([[1, 2, 3], [4, 6, 8]], 0) // returns [4.5, 8, 12.5]\n * math.variance([[1, 2, 3], [4, 6, 8]], 1) // returns [1, 4]\n * math.variance([[1, 2, 3], [4, 6, 8]], 1, 'biased') // returns [0.5, 2]\n *\n * See also:\n *\n * mean, median, max, min, prod, std, sum\n *\n * @param {Array | Matrix} array\n * A single matrix or or multiple scalar values\n * @param {string} [normalization='unbiased']\n * Determines how to normalize the variance.\n * Choose 'unbiased' (default), 'uncorrected', or 'biased'.\n * @param dimension {number | BigNumber}\n * Determines the axis to compute the variance for a matrix\n * @return {*} The variance\n */\n return typed(name, {\n // variance([a, b, c, d, ...])\n 'Array | Matrix': function ArrayMatrix(array) {\n return _var(array, DEFAULT_NORMALIZATION);\n },\n // variance([a, b, c, d, ...], normalization)\n 'Array | Matrix, string': _var,\n // variance([a, b, c, c, ...], dim)\n 'Array | Matrix, number | BigNumber': function ArrayMatrixNumberBigNumber(array, dim) {\n return _varDim(array, dim, DEFAULT_NORMALIZATION);\n },\n // variance([a, b, c, c, ...], dim, normalization)\n 'Array | Matrix, number | BigNumber, string': _varDim,\n // variance(a, b, c, d, ...)\n '...': function _(args) {\n return _var(args, DEFAULT_NORMALIZATION);\n }\n });\n /**\n * Recursively calculate the variance of an n-dimensional array\n * @param {Array} array\n * @param {string} normalization\n * Determines how to normalize the variance:\n * - 'unbiased' The sum of squared errors is divided by (n - 1)\n * - 'uncorrected' The sum of squared errors is divided by n\n * - 'biased' The sum of squared errors is divided by (n + 1)\n * @return {number | BigNumber} variance\n * @private\n */\n\n function _var(array, normalization) {\n var sum;\n var num = 0;\n\n if (array.length === 0) {\n throw new SyntaxError('Function variance requires one or more parameters (0 provided)');\n } // calculate the mean and number of elements\n\n\n (0, _collection.deepForEach)(array, function (value) {\n try {\n sum = sum === undefined ? value : add(sum, value);\n num++;\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'variance', value);\n }\n });\n if (num === 0) throw new Error('Cannot calculate variance of an empty array');\n var mean = divide(sum, num); // calculate the variance\n\n sum = undefined;\n (0, _collection.deepForEach)(array, function (value) {\n var diff = subtract(value, mean);\n sum = sum === undefined ? multiply(diff, diff) : add(sum, multiply(diff, diff));\n });\n\n if (isNaN(sum)) {\n return sum;\n }\n\n switch (normalization) {\n case 'uncorrected':\n return divide(sum, num);\n\n case 'biased':\n return divide(sum, num + 1);\n\n case 'unbiased':\n {\n var zero = (0, _is.isBigNumber)(sum) ? sum.mul(0) : 0;\n return num === 1 ? zero : divide(sum, num - 1);\n }\n\n default:\n throw new Error('Unknown normalization \"' + normalization + '\". ' + 'Choose \"unbiased\" (default), \"uncorrected\", or \"biased\".');\n }\n }\n\n function _varDim(array, dim, normalization) {\n try {\n if (array.length === 0) {\n throw new SyntaxError('Function variance requires one or more parameters (0 provided)');\n }\n\n return apply(array, dim, function (x) {\n return _var(x, normalization);\n });\n } catch (err) {\n throw (0, _improveErrorMessage.improveErrorMessage)(err, 'variance');\n }\n }\n});\nexports.createVariance = createVariance;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createBin = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'bin';\nvar dependencies = ['typed', 'format'];\n/**\n * Format a number as binary.\n *\n * Syntax:\n *\n * math.bin(value)\n *\n * Examples:\n *\n * //the following outputs \"0b10\"\n * math.bin(2)\n *\n * See also:\n *\n * oct\n * hex\n *\n * @param {number} value Value to be stringified\n * @param {number} wordSize Optional word size (see `format`)\n * @return {string} The formatted value\n */\n\nvar createBin = (0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n format = _ref.format;\n return typed(name, {\n 'number | BigNumber': function numberBigNumber(n) {\n return format(n, {\n notation: 'bin'\n });\n },\n 'number | BigNumber, number': function numberBigNumberNumber(n, wordSize) {\n return format(n, {\n notation: 'bin',\n wordSize: wordSize\n });\n }\n });\n});\nexports.createBin = createBin;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFormat = void 0;\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'format';\nvar dependencies = ['typed'];\nvar createFormat = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Format a value of any type into a string.\n *\n * Syntax:\n *\n * math.format(value)\n * math.format(value, options)\n * math.format(value, precision)\n * math.format(value, callback)\n *\n * Where:\n *\n * - `value: *`\n * The value to be formatted\n * - `options: Object`\n * An object with formatting options. Available options:\n * - `notation: string`\n * Number notation. Choose from:\n * - 'fixed'\n * Always use regular number notation.\n * For example '123.40' and '14000000'\n * - 'exponential'\n * Always use exponential notation.\n * For example '1.234e+2' and '1.4e+7'\n * - 'engineering'\n * Always use engineering notation: always have exponential notation,\n * and select the exponent to be a multiple of 3.\n * For example '123.4e+0' and '14.0e+6'\n * - 'auto' (default)\n * Regular number notation for numbers having an absolute value between\n * `lower` and `upper` bounds, and uses exponential notation elsewhere.\n * Lower bound is included, upper bound is excluded.\n * For example '123.4' and '1.4e7'.\n * - 'bin', 'oct, or 'hex'\n * Format the number using binary, octal, or hexadecimal notation.\n * For example '0b1101' and '0x10fe'.\n * - `wordSize: number`\n * The word size in bits to use for formatting in binary, octal, or\n * hexadecimal notation. To be used only with 'bin', 'oct', or 'hex'\n * values for 'notation' option. When this option is defined the value\n * is formatted as a signed twos complement integer of the given word\n * size and the size suffix is appended to the output.\n * For example format(-1, {notation: 'hex', wordSize: 8}) === '0xffi8'.\n * Default value is undefined.\n * - `precision: number`\n * Limit the number of digits of the formatted value.\n * For regular numbers, must be a number between 0 and 16.\n * For bignumbers, the maximum depends on the configured precision,\n * see function `config()`.\n * In case of notations 'exponential', 'engineering', and 'auto', `precision`\n * defines the total number of significant digits returned.\n * In case of notation 'fixed', `precision` defines the number of\n * significant digits after the decimal point.\n * `precision` is undefined by default.\n * - `lowerExp: number`\n * Exponent determining the lower boundary for formatting a value with\n * an exponent when `notation='auto`. Default value is `-3`.\n * - `upperExp: number`\n * Exponent determining the upper boundary for formatting a value with\n * an exponent when `notation='auto`. Default value is `5`.\n * - `fraction: string`. Available values: 'ratio' (default) or 'decimal'.\n * For example `format(fraction(1, 3))` will output '1/3' when 'ratio' is\n * configured, and will output `0.(3)` when 'decimal' is configured.\n * - `truncate: number`. Specifies the maximum allowed length of the\n * returned string. If it would have been longer, the excess characters\n * are deleted and replaced with `'...'`.\n * - `callback: function`\n * A custom formatting function, invoked for all numeric elements in `value`,\n * for example all elements of a matrix, or the real and imaginary\n * parts of a complex number. This callback can be used to override the\n * built-in numeric notation with any type of formatting. Function `callback`\n * is called with `value` as parameter and must return a string.\n *\n * When `value` is an Object:\n *\n * - When the object contains a property `format` being a function, this function\n * is invoked as `value.format(options)` and the result is returned.\n * - When the object has its own `toString` method, this method is invoked\n * and the result is returned.\n * - In other cases the function will loop over all object properties and\n * return JSON object notation like '{\"a\": 2, \"b\": 3}'.\n *\n * When value is a function:\n *\n * - When the function has a property `syntax`, it returns this\n * syntax description.\n * - In other cases, a string `'function'` is returned.\n *\n * Examples:\n *\n * math.format(6.4) // returns '6.4'\n * math.format(1240000) // returns '1.24e6'\n * math.format(1/3) // returns '0.3333333333333333'\n * math.format(1/3, 3) // returns '0.333'\n * math.format(21385, 2) // returns '21000'\n * math.format(12e8, {notation: 'fixed'}) // returns '1200000000'\n * math.format(2.3, {notation: 'fixed', precision: 4}) // returns '2.3000'\n * math.format(52.8, {notation: 'exponential'}) // returns '5.28e+1'\n * math.format(12400,{notation: 'engineering'}) // returns '12.400e+3'\n * math.format(2000, {lowerExp: -2, upperExp: 2}) // returns '2e+3'\n *\n * function formatCurrency(value) {\n * // return currency notation with two digits:\n * return '$' + value.toFixed(2)\n *\n * // you could also use math.format inside the callback:\n * // return '$' + math.format(value, {notation: 'fixed', precision: 2})\n * }\n * math.format([2.1, 3, 0.016], formatCurrency) // returns '[$2.10, $3.00, $0.02]'\n *\n * See also:\n *\n * print\n *\n * @param {*} value Value to be stringified\n * @param {Object | Function | number} [options] Formatting options\n * @return {string} The formatted value\n */\n return typed(name, {\n any: _string.format,\n 'any, Object | function | number': _string.format\n });\n});\nexports.createFormat = createFormat;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createHex = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'hex';\nvar dependencies = ['typed', 'format'];\n/**\n * Format a number as hexadecimal.\n *\n * Syntax:\n *\n * math.hex(value)\n *\n * Examples:\n *\n * //the following outputs \"0xF0\"\n * math.hex(240)\n *\n * See also:\n *\n * oct\n * bin\n *\n * @param {number} value Value to be stringified\n * @param {number} wordSize Optional word size (see `format`)\n * @return {string} The formatted value\n */\n\nvar createHex = (0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n format = _ref.format;\n return typed(name, {\n 'number | BigNumber': function numberBigNumber(n) {\n return format(n, {\n notation: 'hex'\n });\n },\n 'number | BigNumber, number': function numberBigNumberNumber(n, wordSize) {\n return format(n, {\n notation: 'hex',\n wordSize: wordSize\n });\n }\n });\n});\nexports.createHex = createHex;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createOct = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'oct';\nvar dependencies = ['typed', 'format'];\n/**\n * Format a number as octal.\n *\n * Syntax:\n *\n * math.oct(value)\n *\n * Examples:\n *\n * //the following outputs \"0o70\"\n * math.oct(56)\n *\n * See also:\n *\n * bin\n * hex\n *\n * @param {number} value Value to be stringified\n * @param {number} wordSize Optional word size (see `format`)\n * @return {string} The formatted value\n */\n\nvar createOct = (0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n format = _ref.format;\n return typed(name, {\n 'number | BigNumber': function numberBigNumber(n) {\n return format(n, {\n notation: 'oct'\n });\n },\n 'number | BigNumber, number': function numberBigNumberNumber(n, wordSize) {\n return format(n, {\n notation: 'oct',\n wordSize: wordSize\n });\n }\n });\n});\nexports.createOct = createOct;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createPrint = void 0;\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'print';\nvar dependencies = ['typed'];\nvar createPrint = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Interpolate values into a string template.\n *\n * Syntax:\n *\n * math.print(template, values)\n * math.print(template, values, precision)\n * math.print(template, values, options)\n *\n * Example usage:\n *\n * // the following outputs: 'Lucy is 5 years old'\n * math.print('Lucy is $age years old', {age: 5})\n *\n * // the following outputs: 'The value of pi is 3.141592654'\n * math.print('The value of pi is $pi', {pi: math.pi}, 10)\n *\n * // the following outputs: 'hello Mary! The date is 2013-03-23'\n * math.print('Hello $user.name! The date is $date', {\n * user: {\n * name: 'Mary',\n * },\n * date: new Date(2013, 2, 23).toISOString().substring(0, 10)\n * })\n *\n * // the following outputs: 'My favorite fruits are apples and bananas !'\n * math.print('My favorite fruits are $0 and $1 !', [\n * 'apples',\n * 'bananas'\n * ])\n *\n * See also:\n *\n * format\n *\n * @param {string} template A string containing variable placeholders.\n * @param {Object | Array | Matrix} values An object or array containing variables\n * which will be filled in in the template.\n * @param {number | Object} [options] Formatting options,\n * or the number of digits to format numbers.\n * See function math.format for a description\n * of all options.\n * @return {string} Interpolated string\n */\n return typed(name, {\n // note: Matrix will be converted automatically to an Array\n 'string, Object | Array': _print,\n 'string, Object | Array, number | Object': _print\n });\n});\n/**\n * Interpolate values into a string template.\n * @param {string} template\n * @param {Object} values\n * @param {number | Object} [options]\n * @returns {string} Interpolated string\n * @private\n */\n\nexports.createPrint = createPrint;\n\nfunction _print(template, values, options) {\n return template.replace(/\\$([\\w.]+)/g, function (original, key) {\n var keys = key.split('.');\n var value = values[keys.shift()];\n\n while (keys.length && value !== undefined) {\n var k = keys.shift();\n value = k ? value[k] : value + '.';\n }\n\n if (value !== undefined) {\n if (!(0, _is.isString)(value)) {\n return (0, _string.format)(value, options);\n } else {\n return value;\n }\n }\n\n return original;\n });\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAcos = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar name = 'acos';\nvar dependencies = ['typed', 'config', 'Complex'];\nvar createAcos = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n Complex = _ref.Complex;\n\n /**\n * Calculate the inverse cosine of a value.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.acos(x)\n *\n * Examples:\n *\n * math.acos(0.5) // returns number 1.0471975511965979\n * math.acos(math.cos(1.5)) // returns number 1.5\n *\n * math.acos(2) // returns Complex 0 + 1.3169578969248166 i\n *\n * See also:\n *\n * cos, atan, asin\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x Function input\n * @return {number | BigNumber | Complex | Array | Matrix} The arc cosine of x\n */\n return typed(name, {\n number: function number(x) {\n if (x >= -1 && x <= 1 || config.predictable) {\n return Math.acos(x);\n } else {\n return new Complex(x, 0).acos();\n }\n },\n Complex: function Complex(x) {\n return x.acos();\n },\n BigNumber: function BigNumber(x) {\n return x.acos();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createAcos = createAcos;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAcosh = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'acosh';\nvar dependencies = ['typed', 'config', 'Complex'];\nvar createAcosh = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n Complex = _ref.Complex;\n\n /**\n * Calculate the hyperbolic arccos of a value,\n * defined as `acosh(x) = ln(sqrt(x^2 - 1) + x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.acosh(x)\n *\n * Examples:\n *\n * math.acosh(1.5) // returns 0.9624236501192069\n *\n * See also:\n *\n * cosh, asinh, atanh\n *\n * @param {number | Complex | Unit | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Hyperbolic arccosine of x\n */\n return typed(name, {\n number: function number(x) {\n if (x >= 1 || config.predictable) {\n return (0, _index.acoshNumber)(x);\n }\n\n if (x <= -1) {\n return new Complex(Math.log(Math.sqrt(x * x - 1) - x), Math.PI);\n }\n\n return new Complex(x, 0).acosh();\n },\n Complex: function Complex(x) {\n return x.acosh();\n },\n BigNumber: function BigNumber(x) {\n return x.acosh();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createAcosh = createAcosh;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAcot = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'acot';\nvar dependencies = ['typed', 'BigNumber'];\nvar createAcot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n _BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the inverse cotangent of a value, defined as `acot(x) = atan(1/x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.acot(x)\n *\n * Examples:\n *\n * math.acot(0.5) // returns number 0.4636476090008061\n * math.acot(math.cot(1.5)) // returns number 1.5\n *\n * math.acot(2) // returns Complex 1.5707963267948966 -1.3169578969248166 i\n *\n * See also:\n *\n * cot, atan\n *\n * @param {number | Complex | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} The arc cotangent of x\n */\n return typed(name, {\n number: _index.acotNumber,\n Complex: function Complex(x) {\n return x.acot();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(1).div(x).atan();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createAcot = createAcot;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAcoth = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'acoth';\nvar dependencies = ['typed', 'config', 'Complex', 'BigNumber'];\nvar createAcoth = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n Complex = _ref.Complex,\n _BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the hyperbolic arccotangent of a value,\n * defined as `acoth(x) = atanh(1/x) = (ln((x+1)/x) + ln(x/(x-1))) / 2`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.acoth(x)\n *\n * Examples:\n *\n * math.acoth(0.5) // returns 0.8047189562170503\n *\n * See also:\n *\n * acsch, asech\n *\n * @param {number | Complex | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Hyperbolic arccotangent of x\n */\n return typed(name, {\n number: function number(x) {\n if (x >= 1 || x <= -1 || config.predictable) {\n return (0, _index.acothNumber)(x);\n }\n\n return new Complex(x, 0).acoth();\n },\n Complex: function Complex(x) {\n return x.acoth();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(1).div(x).atanh();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createAcoth = createAcoth;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAcsc = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'acsc';\nvar dependencies = ['typed', 'config', 'Complex', 'BigNumber'];\nvar createAcsc = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n Complex = _ref.Complex,\n _BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the inverse cosecant of a value, defined as `acsc(x) = asin(1/x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.acsc(x)\n *\n * Examples:\n *\n * math.acsc(0.5) // returns number 0.5235987755982989\n * math.acsc(math.csc(1.5)) // returns number ~1.5\n *\n * math.acsc(2) // returns Complex 1.5707963267948966 -1.3169578969248166 i\n *\n * See also:\n *\n * csc, asin, asec\n *\n * @param {number | Complex | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} The arc cosecant of x\n */\n return typed(name, {\n number: function number(x) {\n if (x <= -1 || x >= 1 || config.predictable) {\n return (0, _index.acscNumber)(x);\n }\n\n return new Complex(x, 0).acsc();\n },\n Complex: function Complex(x) {\n return x.acsc();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(1).div(x).asin();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createAcsc = createAcsc;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAcsch = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'acsch';\nvar dependencies = ['typed', 'BigNumber'];\nvar createAcsch = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n _BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the hyperbolic arccosecant of a value,\n * defined as `acsch(x) = asinh(1/x) = ln(1/x + sqrt(1/x^2 + 1))`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.acsch(x)\n *\n * Examples:\n *\n * math.acsch(0.5) // returns 1.4436354751788103\n *\n * See also:\n *\n * asech, acoth\n *\n * @param {number | Complex | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Hyperbolic arccosecant of x\n */\n return typed(name, {\n number: _index.acschNumber,\n Complex: function Complex(x) {\n return x.acsch();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(1).div(x).asinh();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createAcsch = createAcsch;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAsec = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'asec';\nvar dependencies = ['typed', 'config', 'Complex', 'BigNumber'];\nvar createAsec = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n Complex = _ref.Complex,\n _BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the inverse secant of a value. Defined as `asec(x) = acos(1/x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.asec(x)\n *\n * Examples:\n *\n * math.asec(0.5) // returns 1.0471975511965979\n * math.asec(math.sec(1.5)) // returns 1.5\n *\n * math.asec(2) // returns 0 + 1.3169578969248166 i\n *\n * See also:\n *\n * acos, acot, acsc\n *\n * @param {number | Complex | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} The arc secant of x\n */\n return typed(name, {\n number: function number(x) {\n if (x <= -1 || x >= 1 || config.predictable) {\n return (0, _index.asecNumber)(x);\n }\n\n return new Complex(x, 0).asec();\n },\n Complex: function Complex(x) {\n return x.asec();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(1).div(x).acos();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createAsec = createAsec;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAsech = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'asech';\nvar dependencies = ['typed', 'config', 'Complex', 'BigNumber'];\nvar createAsech = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n Complex = _ref.Complex,\n _BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the hyperbolic arcsecant of a value,\n * defined as `asech(x) = acosh(1/x) = ln(sqrt(1/x^2 - 1) + 1/x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.asech(x)\n *\n * Examples:\n *\n * math.asech(0.5) // returns 1.3169578969248166\n *\n * See also:\n *\n * acsch, acoth\n *\n * @param {number | Complex | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Hyperbolic arcsecant of x\n */\n return typed(name, {\n number: function number(x) {\n if (x <= 1 && x >= -1 || config.predictable) {\n var xInv = 1 / x;\n\n if (xInv > 0 || config.predictable) {\n return (0, _index.asechNumber)(x);\n }\n\n var ret = Math.sqrt(xInv * xInv - 1);\n return new Complex(Math.log(ret - xInv), Math.PI);\n }\n\n return new Complex(x, 0).asech();\n },\n Complex: function Complex(x) {\n return x.asech();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(1).div(x).acosh();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createAsech = createAsech;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAsin = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar name = 'asin';\nvar dependencies = ['typed', 'config', 'Complex'];\nvar createAsin = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n Complex = _ref.Complex;\n\n /**\n * Calculate the inverse sine of a value.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.asin(x)\n *\n * Examples:\n *\n * math.asin(0.5) // returns number 0.5235987755982989\n * math.asin(math.sin(1.5)) // returns number ~1.5\n *\n * math.asin(2) // returns Complex 1.5707963267948966 -1.3169578969248166 i\n *\n * See also:\n *\n * sin, atan, acos\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x Function input\n * @return {number | BigNumber | Complex | Array | Matrix} The arc sine of x\n */\n return typed(name, {\n number: function number(x) {\n if (x >= -1 && x <= 1 || config.predictable) {\n return Math.asin(x);\n } else {\n return new Complex(x, 0).asin();\n }\n },\n Complex: function Complex(x) {\n return x.asin();\n },\n BigNumber: function BigNumber(x) {\n return x.asin();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since asin(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n }\n });\n});\nexports.createAsin = createAsin;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAsinh = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'asinh';\nvar dependencies = ['typed'];\nvar createAsinh = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Calculate the hyperbolic arcsine of a value,\n * defined as `asinh(x) = ln(x + sqrt(x^2 + 1))`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.asinh(x)\n *\n * Examples:\n *\n * math.asinh(0.5) // returns 0.48121182505960347\n *\n * See also:\n *\n * acosh, atanh\n *\n * @param {number | Complex | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Hyperbolic arcsine of x\n */\n return typed('asinh', {\n number: _index.asinhNumber,\n Complex: function Complex(x) {\n return x.asinh();\n },\n BigNumber: function BigNumber(x) {\n return x.asinh();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since asinh(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n }\n });\n});\nexports.createAsinh = createAsinh;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAtan = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar name = 'atan';\nvar dependencies = ['typed'];\nvar createAtan = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Calculate the inverse tangent of a value.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.atan(x)\n *\n * Examples:\n *\n * math.atan(0.5) // returns number 0.4636476090008061\n * math.atan(math.tan(1.5)) // returns number 1.5\n *\n * math.atan(2) // returns Complex 1.5707963267948966 -1.3169578969248166 i\n *\n * See also:\n *\n * tan, asin, acos\n *\n * @param {number | BigNumber | Complex | Array | Matrix} x Function input\n * @return {number | BigNumber | Complex | Array | Matrix} The arc tangent of x\n */\n return typed('atan', {\n number: function number(x) {\n return Math.atan(x);\n },\n Complex: function Complex(x) {\n return x.atan();\n },\n BigNumber: function BigNumber(x) {\n return x.atan();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since atan(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n }\n });\n});\nexports.createAtan = createAtan;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAtan2 = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm02.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm03.js\");\n\nvar _algorithm3 = require(\"../../type/matrix/utils/algorithm09.js\");\n\nvar _algorithm4 = require(\"../../type/matrix/utils/algorithm11.js\");\n\nvar _algorithm5 = require(\"../../type/matrix/utils/algorithm12.js\");\n\nvar _algorithm6 = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm7 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'atan2';\nvar dependencies = ['typed', 'matrix', 'equalScalar', 'BigNumber', 'DenseMatrix'];\nvar createAtan2 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix,\n equalScalar = _ref.equalScalar,\n BigNumber = _ref.BigNumber,\n DenseMatrix = _ref.DenseMatrix;\n var algorithm02 = (0, _algorithm.createAlgorithm02)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm03 = (0, _algorithm2.createAlgorithm03)({\n typed: typed\n });\n var algorithm09 = (0, _algorithm3.createAlgorithm09)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm11 = (0, _algorithm4.createAlgorithm11)({\n typed: typed,\n equalScalar: equalScalar\n });\n var algorithm12 = (0, _algorithm5.createAlgorithm12)({\n typed: typed,\n DenseMatrix: DenseMatrix\n });\n var algorithm13 = (0, _algorithm6.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm7.createAlgorithm14)({\n typed: typed\n });\n /**\n * Calculate the inverse tangent function with two arguments, y/x.\n * By providing two arguments, the right quadrant of the computed angle can be\n * determined.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.atan2(y, x)\n *\n * Examples:\n *\n * math.atan2(2, 2) / math.pi // returns number 0.25\n *\n * const angle = math.unit(60, 'deg') // returns Unit 60 deg\n * const x = math.cos(angle)\n * const y = math.sin(angle)\n *\n * math.atan(2) // returns Complex 1.5707963267948966 -1.3169578969248166 i\n *\n * See also:\n *\n * tan, atan, sin, cos\n *\n * @param {number | Array | Matrix} y Second dimension\n * @param {number | Array | Matrix} x First dimension\n * @return {number | Array | Matrix} Four-quadrant inverse tangent\n */\n\n return typed(name, {\n 'number, number': Math.atan2,\n // Complex numbers doesn't seem to have a reasonable implementation of\n // atan2(). Even Matlab removed the support, after they only calculated\n // the atan only on base of the real part of the numbers and ignored the imaginary.\n 'BigNumber, BigNumber': function BigNumberBigNumber(y, x) {\n return BigNumber.atan2(y, x);\n },\n 'SparseMatrix, SparseMatrix': function SparseMatrixSparseMatrix(x, y) {\n return algorithm09(x, y, this, false);\n },\n 'SparseMatrix, DenseMatrix': function SparseMatrixDenseMatrix(x, y) {\n // mind the order of y and x!\n return algorithm02(y, x, this, true);\n },\n 'DenseMatrix, SparseMatrix': function DenseMatrixSparseMatrix(x, y) {\n return algorithm03(x, y, this, false);\n },\n 'DenseMatrix, DenseMatrix': function DenseMatrixDenseMatrix(x, y) {\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n return this(x, matrix(y));\n },\n 'SparseMatrix, number | BigNumber': function SparseMatrixNumberBigNumber(x, y) {\n return algorithm11(x, y, this, false);\n },\n 'DenseMatrix, number | BigNumber': function DenseMatrixNumberBigNumber(x, y) {\n return algorithm14(x, y, this, false);\n },\n 'number | BigNumber, SparseMatrix': function numberBigNumberSparseMatrix(x, y) {\n // mind the order of y and x\n return algorithm12(y, x, this, true);\n },\n 'number | BigNumber, DenseMatrix': function numberBigNumberDenseMatrix(x, y) {\n // mind the order of y and x\n return algorithm14(y, x, this, true);\n },\n 'Array, number | BigNumber': function ArrayNumberBigNumber(x, y) {\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'number | BigNumber, Array': function numberBigNumberArray(x, y) {\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createAtan2 = createAtan2;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAtanh = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'atanh';\nvar dependencies = ['typed', 'config', 'Complex'];\nvar createAtanh = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n config = _ref.config,\n Complex = _ref.Complex;\n\n /**\n * Calculate the hyperbolic arctangent of a value,\n * defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.atanh(x)\n *\n * Examples:\n *\n * math.atanh(0.5) // returns 0.5493061443340549\n *\n * See also:\n *\n * acosh, asinh\n *\n * @param {number | Complex | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Hyperbolic arctangent of x\n */\n return typed(name, {\n number: function number(x) {\n if (x <= 1 && x >= -1 || config.predictable) {\n return (0, _index.atanhNumber)(x);\n }\n\n return new Complex(x, 0).atanh();\n },\n Complex: function Complex(x) {\n return x.atanh();\n },\n BigNumber: function BigNumber(x) {\n return x.atanh();\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since atanh(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n }\n });\n});\nexports.createAtanh = createAtanh;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCos = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar name = 'cos';\nvar dependencies = ['typed'];\nvar createCos = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Calculate the cosine of a value.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.cos(x)\n *\n * Examples:\n *\n * math.cos(2) // returns number -0.4161468365471422\n * math.cos(math.pi / 4) // returns number 0.7071067811865475\n * math.cos(math.unit(180, 'deg')) // returns number -1\n * math.cos(math.unit(60, 'deg')) // returns number 0.5\n *\n * const angle = 0.2\n * math.pow(math.sin(angle), 2) + math.pow(math.cos(angle), 2) // returns number ~1\n *\n * See also:\n *\n * cos, tan\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x Function input\n * @return {number | BigNumber | Complex | Array | Matrix} Cosine of x\n */\n return typed(name, {\n number: Math.cos,\n Complex: function Complex(x) {\n return x.cos();\n },\n BigNumber: function BigNumber(x) {\n return x.cos();\n },\n Unit: function Unit(x) {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function cos is no angle');\n }\n\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createCos = createCos;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCosh = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar name = 'cosh';\nvar dependencies = ['typed'];\nvar createCosh = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Calculate the hyperbolic cosine of a value,\n * defined as `cosh(x) = 1/2 * (exp(x) + exp(-x))`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.cosh(x)\n *\n * Examples:\n *\n * math.cosh(0.5) // returns number 1.1276259652063807\n *\n * See also:\n *\n * sinh, tanh\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x Function input\n * @return {number | BigNumber | Complex | Array | Matrix} Hyperbolic cosine of x\n */\n return typed(name, {\n number: _number.cosh,\n Complex: function Complex(x) {\n return x.cosh();\n },\n BigNumber: function BigNumber(x) {\n return x.cosh();\n },\n Unit: function Unit(x) {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function cosh is no angle');\n }\n\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createCosh = createCosh;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCot = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'cot';\nvar dependencies = ['typed', 'BigNumber'];\nvar createCot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n _BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the cotangent of a value. Defined as `cot(x) = 1 / tan(x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.cot(x)\n *\n * Examples:\n *\n * math.cot(2) // returns number -0.45765755436028577\n * 1 / math.tan(2) // returns number -0.45765755436028577\n *\n * See also:\n *\n * tan, sec, csc\n *\n * @param {number | Complex | Unit | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Cotangent of x\n */\n return typed(name, {\n number: _index.cotNumber,\n Complex: function Complex(x) {\n return x.cot();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(1).div(x.tan());\n },\n Unit: function Unit(x) {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function cot is no angle');\n }\n\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createCot = createCot;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCoth = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'coth';\nvar dependencies = ['typed', 'BigNumber'];\nvar createCoth = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n _BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the hyperbolic cotangent of a value,\n * defined as `coth(x) = 1 / tanh(x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.coth(x)\n *\n * Examples:\n *\n * // coth(x) = 1 / tanh(x)\n * math.coth(2) // returns 1.0373147207275482\n * 1 / math.tanh(2) // returns 1.0373147207275482\n *\n * See also:\n *\n * sinh, tanh, cosh\n *\n * @param {number | Complex | Unit | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Hyperbolic cotangent of x\n */\n return typed(name, {\n number: _index.cothNumber,\n Complex: function Complex(x) {\n return x.coth();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(1).div(x.tanh());\n },\n Unit: function Unit(x) {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function coth is no angle');\n }\n\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createCoth = createCoth;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCsc = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'csc';\nvar dependencies = ['typed', 'BigNumber'];\nvar createCsc = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n _BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the cosecant of a value, defined as `csc(x) = 1/sin(x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.csc(x)\n *\n * Examples:\n *\n * math.csc(2) // returns number 1.099750170294617\n * 1 / math.sin(2) // returns number 1.099750170294617\n *\n * See also:\n *\n * sin, sec, cot\n *\n * @param {number | Complex | Unit | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Cosecant of x\n */\n return typed(name, {\n number: _index.cscNumber,\n Complex: function Complex(x) {\n return x.csc();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(1).div(x.sin());\n },\n Unit: function Unit(x) {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function csc is no angle');\n }\n\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createCsc = createCsc;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCsch = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'csch';\nvar dependencies = ['typed', 'BigNumber'];\nvar createCsch = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n _BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the hyperbolic cosecant of a value,\n * defined as `csch(x) = 1 / sinh(x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.csch(x)\n *\n * Examples:\n *\n * // csch(x) = 1/ sinh(x)\n * math.csch(0.5) // returns 1.9190347513349437\n * 1 / math.sinh(0.5) // returns 1.9190347513349437\n *\n * See also:\n *\n * sinh, sech, coth\n *\n * @param {number | Complex | Unit | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Hyperbolic cosecant of x\n */\n return typed(name, {\n number: _index.cschNumber,\n Complex: function Complex(x) {\n return x.csch();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(1).div(x.sinh());\n },\n Unit: function Unit(x) {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function csch is no angle');\n }\n\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createCsch = createCsch;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSec = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'sec';\nvar dependencies = ['typed', 'BigNumber'];\nvar createSec = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n _BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the secant of a value, defined as `sec(x) = 1/cos(x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.sec(x)\n *\n * Examples:\n *\n * math.sec(2) // returns number -2.4029979617223822\n * 1 / math.cos(2) // returns number -2.4029979617223822\n *\n * See also:\n *\n * cos, csc, cot\n *\n * @param {number | Complex | Unit | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Secant of x\n */\n return typed(name, {\n number: _index.secNumber,\n Complex: function Complex(x) {\n return x.sec();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(1).div(x.cos());\n },\n Unit: function Unit(x) {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function sec is no angle');\n }\n\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createSec = createSec;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSech = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'sech';\nvar dependencies = ['typed', 'BigNumber'];\nvar createSech = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n _BigNumber = _ref.BigNumber;\n\n /**\n * Calculate the hyperbolic secant of a value,\n * defined as `sech(x) = 1 / cosh(x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.sech(x)\n *\n * Examples:\n *\n * // sech(x) = 1/ cosh(x)\n * math.sech(0.5) // returns 0.886818883970074\n * 1 / math.cosh(0.5) // returns 0.886818883970074\n *\n * See also:\n *\n * cosh, csch, coth\n *\n * @param {number | Complex | Unit | Array | Matrix} x Function input\n * @return {number | Complex | Array | Matrix} Hyperbolic secant of x\n */\n return typed(name, {\n number: _index.sechNumber,\n Complex: function Complex(x) {\n return x.sech();\n },\n BigNumber: function BigNumber(x) {\n return new _BigNumber(1).div(x.cosh());\n },\n Unit: function Unit(x) {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function sech is no angle');\n }\n\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createSech = createSech;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSin = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar name = 'sin';\nvar dependencies = ['typed'];\nvar createSin = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Calculate the sine of a value.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.sin(x)\n *\n * Examples:\n *\n * math.sin(2) // returns number 0.9092974268256813\n * math.sin(math.pi / 4) // returns number 0.7071067811865475\n * math.sin(math.unit(90, 'deg')) // returns number 1\n * math.sin(math.unit(30, 'deg')) // returns number 0.5\n *\n * const angle = 0.2\n * math.pow(math.sin(angle), 2) + math.pow(math.cos(angle), 2) // returns number ~1\n *\n * See also:\n *\n * cos, tan\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x Function input\n * @return {number | BigNumber | Complex | Array | Matrix} Sine of x\n */\n return typed(name, {\n number: Math.sin,\n Complex: function Complex(x) {\n return x.sin();\n },\n BigNumber: function BigNumber(x) {\n return x.sin();\n },\n Unit: function Unit(x) {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function sin is no angle');\n }\n\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since sin(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n }\n });\n});\nexports.createSin = createSin;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSinh = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'sinh';\nvar dependencies = ['typed'];\nvar createSinh = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Calculate the hyperbolic sine of a value,\n * defined as `sinh(x) = 1/2 * (exp(x) - exp(-x))`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.sinh(x)\n *\n * Examples:\n *\n * math.sinh(0.5) // returns number 0.5210953054937474\n *\n * See also:\n *\n * cosh, tanh\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x Function input\n * @return {number | BigNumber | Complex | Array | Matrix} Hyperbolic sine of x\n */\n return typed(name, {\n number: _index.sinhNumber,\n Complex: function Complex(x) {\n return x.sinh();\n },\n BigNumber: function BigNumber(x) {\n return x.sinh();\n },\n Unit: function Unit(x) {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function sinh is no angle');\n }\n\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since sinh(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n }\n });\n});\nexports.createSinh = createSinh;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createTan = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar name = 'tan';\nvar dependencies = ['typed'];\nvar createTan = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Calculate the tangent of a value. `tan(x)` is equal to `sin(x) / cos(x)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.tan(x)\n *\n * Examples:\n *\n * math.tan(0.5) // returns number 0.5463024898437905\n * math.sin(0.5) / math.cos(0.5) // returns number 0.5463024898437905\n * math.tan(math.pi / 4) // returns number 1\n * math.tan(math.unit(45, 'deg')) // returns number 1\n *\n * See also:\n *\n * atan, sin, cos\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x Function input\n * @return {number | BigNumber | Complex | Array | Matrix} Tangent of x\n */\n return typed(name, {\n number: Math.tan,\n Complex: function Complex(x) {\n return x.tan();\n },\n BigNumber: function BigNumber(x) {\n return x.tan();\n },\n Unit: function Unit(x) {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function tan is no angle');\n }\n\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since tan(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n }\n });\n});\nexports.createTan = createTan;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createTanh = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar name = 'tanh';\nvar dependencies = ['typed'];\nvar createTanh = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Calculate the hyperbolic tangent of a value,\n * defined as `tanh(x) = (exp(2 * x) - 1) / (exp(2 * x) + 1)`.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.tanh(x)\n *\n * Examples:\n *\n * // tanh(x) = sinh(x) / cosh(x) = 1 / coth(x)\n * math.tanh(0.5) // returns 0.46211715726000974\n * math.sinh(0.5) / math.cosh(0.5) // returns 0.46211715726000974\n * 1 / math.coth(0.5) // returns 0.46211715726000974\n *\n * See also:\n *\n * sinh, cosh, coth\n *\n * @param {number | BigNumber | Complex | Unit | Array | Matrix} x Function input\n * @return {number | BigNumber | Complex | Array | Matrix} Hyperbolic tangent of x\n */\n return typed('tanh', {\n number: _number.tanh,\n Complex: function Complex(x) {\n return x.tanh();\n },\n BigNumber: function BigNumber(x) {\n return x.tanh();\n },\n Unit: function Unit(x) {\n if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n throw new TypeError('Unit in function tanh is no angle');\n }\n\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n // deep map collection, skip zeros since tanh(0) = 0\n return (0, _collection.deepMap)(x, this, true);\n }\n });\n});\nexports.createTanh = createTanh;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createTo = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _algorithm = require(\"../../type/matrix/utils/algorithm13.js\");\n\nvar _algorithm2 = require(\"../../type/matrix/utils/algorithm14.js\");\n\nvar name = 'to';\nvar dependencies = ['typed', 'matrix'];\nvar createTo = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n matrix = _ref.matrix;\n var algorithm13 = (0, _algorithm.createAlgorithm13)({\n typed: typed\n });\n var algorithm14 = (0, _algorithm2.createAlgorithm14)({\n typed: typed\n });\n /**\n * Change the unit of a value.\n *\n * For matrices, the function is evaluated element wise.\n *\n * Syntax:\n *\n * math.to(x, unit)\n *\n * Examples:\n *\n * math.to(math.unit('2 inch'), 'cm') // returns Unit 5.08 cm\n * math.to(math.unit('2 inch'), math.unit(null, 'cm')) // returns Unit 5.08 cm\n * math.to(math.unit(16, 'bytes'), 'bits') // returns Unit 128 bits\n *\n * See also:\n *\n * unit\n *\n * @param {Unit | Array | Matrix} x The unit to be converted.\n * @param {Unit | Array | Matrix} unit New unit. Can be a string like \"cm\"\n * or a unit without value.\n * @return {Unit | Array | Matrix} value with changed, fixed unit.\n */\n\n return typed(name, {\n 'Unit, Unit | string': function UnitUnitString(x, unit) {\n return x.to(unit);\n },\n 'Matrix, Matrix': function MatrixMatrix(x, y) {\n // SparseMatrix does not support Units\n return algorithm13(x, y, this);\n },\n 'Array, Array': function ArrayArray(x, y) {\n // use matrix implementation\n return this(matrix(x), matrix(y)).valueOf();\n },\n 'Array, Matrix': function ArrayMatrix(x, y) {\n // use matrix implementation\n return this(matrix(x), y);\n },\n 'Matrix, Array': function MatrixArray(x, y) {\n // use matrix implementation\n return this(x, matrix(y));\n },\n 'Matrix, any': function MatrixAny(x, y) {\n // SparseMatrix does not support Units\n return algorithm14(x, y, this, false);\n },\n 'any, Matrix': function anyMatrix(x, y) {\n // SparseMatrix does not support Units\n return algorithm14(y, x, this, true);\n },\n 'Array, any': function ArrayAny(x, y) {\n // use matrix implementation\n return algorithm14(matrix(x), y, this, false).valueOf();\n },\n 'any, Array': function anyArray(x, y) {\n // use matrix implementation\n return algorithm14(matrix(y), x, this, true).valueOf();\n }\n });\n});\nexports.createTo = createTo;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createClone = void 0;\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'clone';\nvar dependencies = ['typed'];\nvar createClone = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Clone an object. Will make a deep copy of the data.\n *\n * Syntax:\n *\n * math.clone(x)\n *\n * Examples:\n *\n * math.clone(3.5) // returns number 3.5\n * math.clone(math.complex('2-4i') // returns Complex 2 - 4i\n * math.clone(math.unit(45, 'deg')) // returns Unit 45 deg\n * math.clone([[1, 2], [3, 4]]) // returns Array [[1, 2], [3, 4]]\n * math.clone(\"hello world\") // returns string \"hello world\"\n *\n * @param {*} x Object to be cloned\n * @return {*} A clone of object x\n */\n return typed(name, {\n any: _object.clone\n });\n});\nexports.createClone = createClone;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createHasNumericValue = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'hasNumericValue';\nvar dependencies = ['typed', 'isNumeric'];\nvar createHasNumericValue = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n isNumeric = _ref.isNumeric;\n\n /**\n * Test whether a value is an numeric value.\n *\n * In case of a string, true is returned if the string contains a numeric value.\n *\n * Syntax:\n *\n * math.hasNumericValue(x)\n *\n * Examples:\n *\n * math.hasNumericValue(2) // returns true\n * math.hasNumericValue('2') // returns true\n * math.isNumeric('2') // returns false\n * math.hasNumericValue(0) // returns true\n * math.hasNumericValue(math.bignumber(500)) // returns true\n * math.hasNumericValue(math.fraction(4)) // returns true\n * math.hasNumericValue(math.complex('2-4i') // returns false\n * math.hasNumericValue([2.3, 'foo', false]) // returns [true, false, true]\n *\n * See also:\n *\n * isZero, isPositive, isNegative, isInteger, isNumeric\n *\n * @param {*} x Value to be tested\n * @return {boolean} Returns true when `x` is a `number`, `BigNumber`,\n * `Fraction`, `Boolean`, or a `String` containing number. Returns false for other types.\n * Throws an error in case of unknown types.\n */\n return typed(name, {\n string: function string(x) {\n return x.trim().length > 0 && !isNaN(Number(x));\n },\n any: function any(x) {\n return isNumeric(x);\n }\n });\n});\nexports.createHasNumericValue = createHasNumericValue;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIsInteger = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'isInteger';\nvar dependencies = ['typed'];\nvar createIsInteger = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Test whether a value is an integer number.\n * The function supports `number`, `BigNumber`, and `Fraction`.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isInteger(x)\n *\n * Examples:\n *\n * math.isInteger(2) // returns true\n * math.isInteger(0) // returns true\n * math.isInteger(0.5) // returns false\n * math.isInteger(math.bignumber(500)) // returns true\n * math.isInteger(math.fraction(4)) // returns true\n * math.isInteger('3') // returns true\n * math.isInteger([3, 0.5, -2]) // returns [true, false, true]\n * math.isInteger(math.complex('2-4i') // throws an error\n *\n * See also:\n *\n * isNumeric, isPositive, isNegative, isZero\n *\n * @param {number | BigNumber | Fraction | Array | Matrix} x Value to be tested\n * @return {boolean} Returns true when `x` contains a numeric, integer value.\n * Throws an error in case of an unknown data type.\n */\n return typed(name, {\n number: _number.isInteger,\n // TODO: what to do with isInteger(add(0.1, 0.2)) ?\n BigNumber: function BigNumber(x) {\n return x.isInt();\n },\n Fraction: function Fraction(x) {\n return x.d === 1 && isFinite(x.n);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createIsInteger = createIsInteger;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIsNaN = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'isNaN';\nvar dependencies = ['typed'];\nvar createIsNaN = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Test whether a value is NaN (not a number).\n * The function supports types `number`, `BigNumber`, `Fraction`, `Unit` and `Complex`.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isNaN(x)\n *\n * Examples:\n *\n * math.isNaN(3) // returns false\n * math.isNaN(NaN) // returns true\n * math.isNaN(0) // returns false\n * math.isNaN(math.bignumber(NaN)) // returns true\n * math.isNaN(math.bignumber(0)) // returns false\n * math.isNaN(math.fraction(-2, 5)) // returns false\n * math.isNaN('-2') // returns false\n * math.isNaN([2, 0, -3, NaN]') // returns [false, false, false, true]\n *\n * See also:\n *\n * isNumeric, isNegative, isPositive, isZero, isInteger\n *\n * @param {number | BigNumber | Fraction | Unit | Array | Matrix} x Value to be tested\n * @return {boolean} Returns true when `x` is NaN.\n * Throws an error in case of an unknown data type.\n */\n return typed(name, {\n number: _index.isNaNNumber,\n BigNumber: function BigNumber(x) {\n return x.isNaN();\n },\n Fraction: function Fraction(x) {\n return false;\n },\n Complex: function Complex(x) {\n return x.isNaN();\n },\n Unit: function Unit(x) {\n return Number.isNaN(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, Number.isNaN);\n }\n });\n});\nexports.createIsNaN = createIsNaN;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIsNegative = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'isNegative';\nvar dependencies = ['typed'];\nvar createIsNegative = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Test whether a value is negative: smaller than zero.\n * The function supports types `number`, `BigNumber`, `Fraction`, and `Unit`.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isNegative(x)\n *\n * Examples:\n *\n * math.isNegative(3) // returns false\n * math.isNegative(-2) // returns true\n * math.isNegative(0) // returns false\n * math.isNegative(-0) // returns false\n * math.isNegative(math.bignumber(2)) // returns false\n * math.isNegative(math.fraction(-2, 5)) // returns true\n * math.isNegative('-2') // returns true\n * math.isNegative([2, 0, -3]') // returns [false, false, true]\n *\n * See also:\n *\n * isNumeric, isPositive, isZero, isInteger\n *\n * @param {number | BigNumber | Fraction | Unit | Array | Matrix} x Value to be tested\n * @return {boolean} Returns true when `x` is larger than zero.\n * Throws an error in case of an unknown data type.\n */\n return typed(name, {\n number: _index.isNegativeNumber,\n BigNumber: function BigNumber(x) {\n return x.isNeg() && !x.isZero() && !x.isNaN();\n },\n Fraction: function Fraction(x) {\n return x.s < 0; // It's enough to decide on the sign\n },\n Unit: function Unit(x) {\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createIsNegative = createIsNegative;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIsNumeric = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'isNumeric';\nvar dependencies = ['typed'];\nvar createIsNumeric = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Test whether a value is an numeric value.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isNumeric(x)\n *\n * Examples:\n *\n * math.isNumeric(2) // returns true\n * math.isNumeric('2') // returns false\n * math.hasNumericValue('2') // returns true\n * math.isNumeric(0) // returns true\n * math.isNumeric(math.bignumber(500)) // returns true\n * math.isNumeric(math.fraction(4)) // returns true\n * math.isNumeric(math.complex('2-4i') // returns false\n * math.isNumeric([2.3, 'foo', false]) // returns [true, false, true]\n *\n * See also:\n *\n * isZero, isPositive, isNegative, isInteger, hasNumericValue\n *\n * @param {*} x Value to be tested\n * @return {boolean} Returns true when `x` is a `number`, `BigNumber`,\n * `Fraction`, or `boolean`. Returns false for other types.\n * Throws an error in case of unknown types.\n */\n return typed(name, {\n 'number | BigNumber | Fraction | boolean': function numberBigNumberFractionBoolean() {\n return true;\n },\n 'Complex | Unit | string | null | undefined | Node': function ComplexUnitStringNullUndefinedNode() {\n return false;\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createIsNumeric = createIsNumeric;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIsPositive = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'isPositive';\nvar dependencies = ['typed'];\nvar createIsPositive = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Test whether a value is positive: larger than zero.\n * The function supports types `number`, `BigNumber`, `Fraction`, and `Unit`.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isPositive(x)\n *\n * Examples:\n *\n * math.isPositive(3) // returns true\n * math.isPositive(-2) // returns false\n * math.isPositive(0) // returns false\n * math.isPositive(-0) // returns false\n * math.isPositive(0.5) // returns true\n * math.isPositive(math.bignumber(2)) // returns true\n * math.isPositive(math.fraction(-2, 5)) // returns false\n * math.isPositive(math.fraction(1,3)) // returns false\n * math.isPositive('2') // returns true\n * math.isPositive([2, 0, -3]) // returns [true, false, false]\n *\n * See also:\n *\n * isNumeric, isZero, isNegative, isInteger\n *\n * @param {number | BigNumber | Fraction | Unit | Array | Matrix} x Value to be tested\n * @return {boolean} Returns true when `x` is larger than zero.\n * Throws an error in case of an unknown data type.\n */\n return typed(name, {\n number: _index.isPositiveNumber,\n BigNumber: function BigNumber(x) {\n return !x.isNeg() && !x.isZero() && !x.isNaN();\n },\n Fraction: function Fraction(x) {\n return x.s > 0 && x.n > 0;\n },\n Unit: function Unit(x) {\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createIsPositive = createIsPositive;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIsPrime = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'isPrime';\nvar dependencies = ['typed'];\nvar createIsPrime = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Test whether a value is prime: has no divisors other than itself and one.\n * The function supports type `number`, `bignumber`.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isPrime(x)\n *\n * Examples:\n *\n * math.isPrime(3) // returns true\n * math.isPrime(-2) // returns false\n * math.isPrime(0) // returns false\n * math.isPrime(-0) // returns false\n * math.isPrime(0.5) // returns false\n * math.isPrime('2') // returns true\n * math.isPrime([2, 17, 100]) // returns [true, true, false]\n *\n * See also:\n *\n * isNumeric, isZero, isNegative, isInteger\n *\n * @param {number | BigNumber | Array | Matrix} x Value to be tested\n * @return {boolean} Returns true when `x` is larger than zero.\n * Throws an error in case of an unknown data type.\n */\n return typed(name, {\n number: function number(x) {\n if (x * 0 !== 0) {\n return false;\n }\n\n if (x <= 3) {\n return x > 1;\n }\n\n if (x % 2 === 0 || x % 3 === 0) {\n return false;\n }\n\n for (var i = 5; i * i <= x; i += 6) {\n if (x % i === 0 || x % (i + 2) === 0) {\n return false;\n }\n }\n\n return true;\n },\n BigNumber: function BigNumber(n) {\n if (n.toNumber() * 0 !== 0) {\n return false;\n }\n\n if (n.lte(3)) return n.gt(1);\n if (n.mod(2).eq(0) || n.mod(3).eq(0)) return false;\n\n if (n.lt(Math.pow(2, 32))) {\n var x = n.toNumber();\n\n for (var i = 5; i * i <= x; i += 6) {\n if (x % i === 0 || x % (i + 2) === 0) {\n return false;\n }\n }\n\n return true;\n }\n\n function modPow(base, exponent, modulus) {\n // exponent can be huge, use non-recursive variant\n var accumulator = 1;\n\n while (!exponent.eq(0)) {\n if (exponent.mod(2).eq(0)) {\n exponent = exponent.div(2);\n base = base.mul(base).mod(modulus);\n } else {\n exponent = exponent.sub(1);\n accumulator = base.mul(accumulator).mod(modulus);\n }\n }\n\n return accumulator;\n } // https://en.wikipedia.org/wiki/Miller%E2%80%93Rabin_primality_test#Deterministic_variants\n\n\n var Decimal = n.constructor.clone({\n precision: n.toFixed(0).length * 2\n });\n n = new Decimal(n);\n var r = 0;\n var d = n.sub(1);\n\n while (d.mod(2).eq(0)) {\n d = d.div(2);\n r += 1;\n }\n\n var bases = null; // https://en.wikipedia.org/wiki/Miller–Rabin_primality_test#Testing_against_small_sets_of_bases\n\n if (n.lt('3317044064679887385961981')) {\n bases = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41].filter(function (x) {\n return x < n;\n });\n } else {\n var max = Math.min(n.toNumber() - 2, Math.floor(2 * Math.pow(n.toFixed(0).length * Math.log(10), 2)));\n bases = [];\n\n for (var _i = 2; _i <= max; _i += 1) {\n bases.push(max);\n }\n }\n\n for (var _i2 = 0; _i2 < bases.length; _i2 += 1) {\n var a = bases[_i2];\n var adn = modPow(n.sub(n).add(a), d, n);\n\n if (!adn.eq(1)) {\n for (var _i3 = 0, _x = adn; !_x.eq(n.sub(1)); _i3 += 1, _x = _x.mul(_x).mod(n)) {\n if (_i3 === r - 1) {\n return false;\n }\n }\n }\n }\n\n return true;\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createIsPrime = createIsPrime;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIsZero = void 0;\n\nvar _collection = require(\"../../utils/collection.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _index = require(\"../../plain/number/index.js\");\n\nvar name = 'isZero';\nvar dependencies = ['typed'];\nvar createIsZero = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Test whether a value is zero.\n * The function can check for zero for types `number`, `BigNumber`, `Fraction`,\n * `Complex`, and `Unit`.\n *\n * The function is evaluated element-wise in case of Array or Matrix input.\n *\n * Syntax:\n *\n * math.isZero(x)\n *\n * Examples:\n *\n * math.isZero(0) // returns true\n * math.isZero(2) // returns false\n * math.isZero(0.5) // returns false\n * math.isZero(math.bignumber(0)) // returns true\n * math.isZero(math.fraction(0)) // returns true\n * math.isZero(math.fraction(1,3)) // returns false\n * math.isZero(math.complex('2 - 4i') // returns false\n * math.isZero(math.complex('0i') // returns true\n * math.isZero('0') // returns true\n * math.isZero('2') // returns false\n * math.isZero([2, 0, -3]') // returns [false, true, false]\n *\n * See also:\n *\n * isNumeric, isPositive, isNegative, isInteger\n *\n * @param {number | BigNumber | Complex | Fraction | Unit | Array | Matrix} x Value to be tested\n * @return {boolean} Returns true when `x` is zero.\n * Throws an error in case of an unknown data type.\n */\n return typed(name, {\n number: _index.isZeroNumber,\n BigNumber: function BigNumber(x) {\n return x.isZero();\n },\n Complex: function Complex(x) {\n return x.re === 0 && x.im === 0;\n },\n Fraction: function Fraction(x) {\n return x.d === 1 && x.n === 0;\n },\n Unit: function Unit(x) {\n return this(x.value);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createIsZero = createIsZero;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createNumeric = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _noop = require(\"../../utils/noop.js\");\n\nvar name = 'numeric';\nvar dependencies = ['number', '?bignumber', '?fraction'];\nvar createNumeric = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var _number = _ref.number,\n bignumber = _ref.bignumber,\n fraction = _ref.fraction;\n var validInputTypes = {\n string: true,\n number: true,\n BigNumber: true,\n Fraction: true\n }; // Load the conversion functions for each output type\n\n var validOutputTypes = {\n number: function number(x) {\n return _number(x);\n },\n BigNumber: bignumber ? function (x) {\n return bignumber(x);\n } : _noop.noBignumber,\n Fraction: fraction ? function (x) {\n return fraction(x);\n } : _noop.noFraction\n };\n /**\n * Convert a numeric input to a specific numeric type: number, BigNumber, or Fraction.\n *\n * Syntax:\n *\n * math.numeric(x)\n *\n * Examples:\n *\n * math.numeric('4') // returns number 4\n * math.numeric('4', 'number') // returns number 4\n * math.numeric('4', 'BigNumber') // returns BigNumber 4\n * math.numeric('4', 'Fraction') // returns Fraction 4\n * math.numeric(4, 'Fraction') // returns Fraction 4\n * math.numeric(math.fraction(2, 5), 'number') // returns number 0.4\n *\n * See also:\n *\n * number, fraction, bignumber, string, format\n *\n * @param {string | number | BigNumber | Fraction } value\n * A numeric value or a string containing a numeric value\n * @param {string} outputType\n * Desired numeric output type.\n * Available values: 'number', 'BigNumber', or 'Fraction'\n * @return {number | BigNumber | Fraction}\n * Returns an instance of the numeric in the requested type\n */\n\n return function numeric(value, outputType) {\n var inputType = (0, _is.typeOf)(value);\n\n if (!(inputType in validInputTypes)) {\n throw new TypeError('Cannot convert ' + value + ' of type \"' + inputType + '\"; valid input types are ' + Object.keys(validInputTypes).join(', '));\n }\n\n if (!(outputType in validOutputTypes)) {\n throw new TypeError('Cannot convert ' + value + ' to type \"' + outputType + '\"; valid output types are ' + Object.keys(validOutputTypes).join(', '));\n }\n\n if (outputType === inputType) {\n return value;\n } else {\n return validOutputTypes[outputType](value);\n }\n };\n});\nexports.createNumeric = createNumeric;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createTypeOf = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar name = 'typeOf';\nvar dependencies = ['typed'];\nvar createTypeOf = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Determine the type of a variable.\n *\n * Function `typeOf` recognizes the following types of objects:\n *\n * Object | Returns | Example\n * ---------------------- | ------------- | ------------------------------------------\n * null | `'null'` | `math.typeOf(null)`\n * number | `'number'` | `math.typeOf(3.5)`\n * boolean | `'boolean'` | `math.typeOf(true)`\n * string | `'string'` | `math.typeOf('hello world')`\n * Array | `'Array'` | `math.typeOf([1, 2, 3])`\n * Date | `'Date'` | `math.typeOf(new Date())`\n * Function | `'Function'` | `math.typeOf(function () {})`\n * Object | `'Object'` | `math.typeOf({a: 2, b: 3})`\n * RegExp | `'RegExp'` | `math.typeOf(/a regexp/)`\n * undefined | `'undefined'` | `math.typeOf(undefined)`\n * math.BigNumber | `'BigNumber'` | `math.typeOf(math.bignumber('2.3e500'))`\n * math.Chain | `'Chain'` | `math.typeOf(math.chain(2))`\n * math.Complex | `'Complex'` | `math.typeOf(math.complex(2, 3))`\n * math.Fraction | `'Fraction'` | `math.typeOf(math.fraction(1, 3))`\n * math.Help | `'Help'` | `math.typeOf(math.help('sqrt'))`\n * math.Help | `'Help'` | `math.typeOf(math.help('sqrt'))`\n * math.Index | `'Index'` | `math.typeOf(math.index(1, 3))`\n * math.Matrix | `'Matrix'` | `math.typeOf(math.matrix([[1,2], [3, 4]]))`\n * math.Range | `'Range'` | `math.typeOf(math.range(0, 10))`\n * math.ResultSet | `'ResultSet'` | `math.typeOf(math.evaluate('a=2\\nb=3'))`\n * math.Unit | `'Unit'` | `math.typeOf(math.unit('45 deg'))`\n * math.AccessorNode | `'AccessorNode'` | `math.typeOf(math.parse('A[2]'))`\n * math.ArrayNode | `'ArrayNode'` | `math.typeOf(math.parse('[1,2,3]'))`\n * math.AssignmentNode | `'AssignmentNode'` | `math.typeOf(math.parse('x=2'))`\n * math.BlockNode | `'BlockNode'` | `math.typeOf(math.parse('a=2; b=3'))`\n * math.ConditionalNode | `'ConditionalNode'` | `math.typeOf(math.parse('x<0 ? -x : x'))`\n * math.ConstantNode | `'ConstantNode'` | `math.typeOf(math.parse('2.3'))`\n * math.FunctionAssignmentNode | `'FunctionAssignmentNode'` | `math.typeOf(math.parse('f(x)=x^2'))`\n * math.FunctionNode | `'FunctionNode'` | `math.typeOf(math.parse('sqrt(4)'))`\n * math.IndexNode | `'IndexNode'` | `math.typeOf(math.parse('A[2]').index)`\n * math.ObjectNode | `'ObjectNode'` | `math.typeOf(math.parse('{a:2}'))`\n * math.ParenthesisNode | `'ParenthesisNode'` | `math.typeOf(math.parse('(2+3)'))`\n * math.RangeNode | `'RangeNode'` | `math.typeOf(math.parse('1:10'))`\n * math.SymbolNode | `'SymbolNode'` | `math.typeOf(math.parse('x'))`\n *\n * Syntax:\n *\n * math.typeOf(x)\n *\n * Examples:\n *\n * math.typeOf(3.5) // returns 'number'\n * math.typeOf(math.complex('2-4i')) // returns 'Complex'\n * math.typeOf(math.unit('45 deg')) // returns 'Unit'\n * math.typeOf('hello world') // returns 'string'\n *\n * @param {*} x The variable for which to test the type.\n * @return {string} Returns the name of the type. Primitive types are lower case,\n * non-primitive types are upper-camel-case.\n * For example 'number', 'string', 'Array', 'Date'.\n */\n return typed(name, {\n any: _is.typeOf\n });\n});\nexports.createTypeOf = createTypeOf;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _mainAny = require(\"./entry/mainAny.js\");\n\nObject.keys(_mainAny).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (key in exports && exports[key] === _mainAny[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _mainAny[key];\n }\n });\n});","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createReplacer = void 0;\n\nvar _factory = require(\"../utils/factory.js\");\n\nvar name = 'replacer';\nvar dependencies = [];\nvar createReplacer = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function () {\n /**\n * Stringify data types into their JSON representation.\n * Most data types can be serialized using their `.toJSON` method,\n * but not all, for example the number `Infinity`. For these cases you have\n * to use the replacer. Example usage:\n *\n * JSON.stringify([2, Infinity], math.replacer)\n *\n * @param {string} key\n * @param {*} value\n * @returns {*} Returns the replaced object\n */\n return function replacer(key, value) {\n // the numeric values Infinitiy, -Infinity, and NaN cannot be serialized to JSON\n if (typeof value === 'number' && (!isFinite(value) || isNaN(value))) {\n return {\n mathjs: 'number',\n value: String(value)\n };\n }\n\n return value;\n };\n});\nexports.createReplacer = createReplacer;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createReviver = void 0;\n\nvar _factory = require(\"../utils/factory.js\");\n\nvar name = 'reviver';\nvar dependencies = ['classes'];\nvar createReviver = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var classes = _ref.classes;\n\n /**\n * Instantiate mathjs data types from their JSON representation\n * @param {string} key\n * @param {*} value\n * @returns {*} Returns the revived object\n */\n return function reviver(key, value) {\n var constructor = classes[value && value.mathjs];\n\n if (constructor && typeof constructor.fromJSON === 'function') {\n return constructor.fromJSON(value);\n }\n\n return value;\n };\n});\nexports.createReviver = createReviver;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.absNumber = absNumber;\nexports.addNumber = addNumber;\nexports.cbrtNumber = cbrtNumber;\nexports.cubeNumber = cubeNumber;\nexports.divideNumber = divideNumber;\nexports.expNumber = expNumber;\nexports.expm1Number = expm1Number;\nexports.gcdNumber = gcdNumber;\nexports.lcmNumber = lcmNumber;\nexports.log10Number = log10Number;\nexports.log1pNumber = log1pNumber;\nexports.log2Number = log2Number;\nexports.logNumber = logNumber;\nexports.modNumber = modNumber;\nexports.multiplyNumber = multiplyNumber;\nexports.normNumber = normNumber;\nexports.nthRootNumber = nthRootNumber;\nexports.powNumber = powNumber;\nexports.roundNumber = roundNumber;\nexports.signNumber = signNumber;\nexports.sqrtNumber = sqrtNumber;\nexports.squareNumber = squareNumber;\nexports.subtractNumber = subtractNumber;\nexports.unaryMinusNumber = unaryMinusNumber;\nexports.unaryPlusNumber = unaryPlusNumber;\nexports.xgcdNumber = xgcdNumber;\n\nvar _number = require(\"../../utils/number.js\");\n\nvar n1 = 'number';\nvar n2 = 'number, number';\n\nfunction absNumber(a) {\n return Math.abs(a);\n}\n\nabsNumber.signature = n1;\n\nfunction addNumber(a, b) {\n return a + b;\n}\n\naddNumber.signature = n2;\n\nfunction subtractNumber(a, b) {\n return a - b;\n}\n\nsubtractNumber.signature = n2;\n\nfunction multiplyNumber(a, b) {\n return a * b;\n}\n\nmultiplyNumber.signature = n2;\n\nfunction divideNumber(a, b) {\n return a / b;\n}\n\ndivideNumber.signature = n2;\n\nfunction unaryMinusNumber(x) {\n return -x;\n}\n\nunaryMinusNumber.signature = n1;\n\nfunction unaryPlusNumber(x) {\n return x;\n}\n\nunaryPlusNumber.signature = n1;\n\nfunction cbrtNumber(x) {\n return (0, _number.cbrt)(x);\n}\n\ncbrtNumber.signature = n1;\n\nfunction cubeNumber(x) {\n return x * x * x;\n}\n\ncubeNumber.signature = n1;\n\nfunction expNumber(x) {\n return Math.exp(x);\n}\n\nexpNumber.signature = n1;\n\nfunction expm1Number(x) {\n return (0, _number.expm1)(x);\n}\n\nexpm1Number.signature = n1;\n/**\n * Calculate gcd for numbers\n * @param {number} a\n * @param {number} b\n * @returns {number} Returns the greatest common denominator of a and b\n */\n\nfunction gcdNumber(a, b) {\n if (!(0, _number.isInteger)(a) || !(0, _number.isInteger)(b)) {\n throw new Error('Parameters in function gcd must be integer numbers');\n } // https://en.wikipedia.org/wiki/Euclidean_algorithm\n\n\n var r;\n\n while (b !== 0) {\n r = a % b;\n a = b;\n b = r;\n }\n\n return a < 0 ? -a : a;\n}\n\ngcdNumber.signature = n2;\n/**\n * Calculate lcm for two numbers\n * @param {number} a\n * @param {number} b\n * @returns {number} Returns the least common multiple of a and b\n */\n\nfunction lcmNumber(a, b) {\n if (!(0, _number.isInteger)(a) || !(0, _number.isInteger)(b)) {\n throw new Error('Parameters in function lcm must be integer numbers');\n }\n\n if (a === 0 || b === 0) {\n return 0;\n } // https://en.wikipedia.org/wiki/Euclidean_algorithm\n // evaluate lcm here inline to reduce overhead\n\n\n var t;\n var prod = a * b;\n\n while (b !== 0) {\n t = b;\n b = a % t;\n a = t;\n }\n\n return Math.abs(prod / a);\n}\n\nlcmNumber.signature = n2;\n/**\n * Calculate the logarithm of a value, optionally to a given base.\n * @param {number} x\n * @param {number | null | undefined} base\n * @return {number}\n */\n\nfunction logNumber(x, y) {\n if (y) {\n return Math.log(x) / Math.log(y);\n }\n\n return Math.log(x);\n}\n/**\n * Calculate the 10-base logarithm of a number\n * @param {number} x\n * @return {number}\n */\n\n\nfunction log10Number(x) {\n return (0, _number.log10)(x);\n}\n\nlog10Number.signature = n1;\n/**\n * Calculate the 2-base logarithm of a number\n * @param {number} x\n * @return {number}\n */\n\nfunction log2Number(x) {\n return (0, _number.log2)(x);\n}\n\nlog2Number.signature = n1;\n/**\n * Calculate the natural logarithm of a `number+1`\n * @param {number} x\n * @returns {number}\n */\n\nfunction log1pNumber(x) {\n return (0, _number.log1p)(x);\n}\n\nlog1pNumber.signature = n1;\n/**\n * Calculate the modulus of two numbers\n * @param {number} x\n * @param {number} y\n * @returns {number} res\n * @private\n */\n\nfunction modNumber(x, y) {\n if (y > 0) {\n // We don't use JavaScript's % operator here as this doesn't work\n // correctly for x < 0 and x === 0\n // see https://en.wikipedia.org/wiki/Modulo_operation\n return x - y * Math.floor(x / y);\n } else if (y === 0) {\n return x;\n } else {\n // y < 0\n // TODO: implement mod for a negative divisor\n throw new Error('Cannot calculate mod for a negative divisor');\n }\n}\n\nmodNumber.signature = n2;\n/**\n * Calculate the nth root of a, solve x^root == a\n * http://rosettacode.org/wiki/Nth_root#JavaScript\n * @param {number} a\n * @param {number} [2] root\n * @private\n */\n\nfunction nthRootNumber(a) {\n var root = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 2;\n var inv = root < 0;\n\n if (inv) {\n root = -root;\n }\n\n if (root === 0) {\n throw new Error('Root must be non-zero');\n }\n\n if (a < 0 && Math.abs(root) % 2 !== 1) {\n throw new Error('Root must be odd when a is negative.');\n } // edge cases zero and infinity\n\n\n if (a === 0) {\n return inv ? Infinity : 0;\n }\n\n if (!isFinite(a)) {\n return inv ? 0 : a;\n }\n\n var x = Math.pow(Math.abs(a), 1 / root); // If a < 0, we require that root is an odd integer,\n // so (-1) ^ (1/root) = -1\n\n x = a < 0 ? -x : x;\n return inv ? 1 / x : x; // Very nice algorithm, but fails with nthRoot(-2, 3).\n // Newton's method has some well-known problems at times:\n // https://en.wikipedia.org/wiki/Newton%27s_method#Failure_analysis\n\n /*\n let x = 1 // Initial guess\n let xPrev = 1\n let i = 0\n const iMax = 10000\n do {\n const delta = (a / Math.pow(x, root - 1) - x) / root\n xPrev = x\n x = x + delta\n i++\n }\n while (xPrev !== x && i < iMax)\n if (xPrev !== x) {\n throw new Error('Function nthRoot failed to converge')\n }\n return inv ? 1 / x : x\n */\n}\n\nfunction signNumber(x) {\n return (0, _number.sign)(x);\n}\n\nsignNumber.signature = n1;\n\nfunction sqrtNumber(x) {\n return Math.sqrt(x);\n}\n\nsqrtNumber.signature = n1;\n\nfunction squareNumber(x) {\n return x * x;\n}\n\nsquareNumber.signature = n1;\n/**\n * Calculate xgcd for two numbers\n * @param {number} a\n * @param {number} b\n * @return {number} result\n * @private\n */\n\nfunction xgcdNumber(a, b) {\n // source: https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm\n var t; // used to swap two variables\n\n var q; // quotient\n\n var r; // remainder\n\n var x = 0;\n var lastx = 1;\n var y = 1;\n var lasty = 0;\n\n if (!(0, _number.isInteger)(a) || !(0, _number.isInteger)(b)) {\n throw new Error('Parameters in function xgcd must be integer numbers');\n }\n\n while (b) {\n q = Math.floor(a / b);\n r = a - q * b;\n t = x;\n x = lastx - q * x;\n lastx = t;\n t = y;\n y = lasty - q * y;\n lasty = t;\n a = b;\n b = r;\n }\n\n var res;\n\n if (a < 0) {\n res = [-a, -lastx, -lasty];\n } else {\n res = [a, a ? lastx : 0, lasty];\n }\n\n return res;\n}\n\nxgcdNumber.signature = n2;\n/**\n * Calculates the power of x to y, x^y, for two numbers.\n * @param {number} x\n * @param {number} y\n * @return {number} res\n */\n\nfunction powNumber(x, y) {\n // x^Infinity === 0 if -1 < x < 1\n // A real number 0 is returned instead of complex(0)\n if (x * x < 1 && y === Infinity || x * x > 1 && y === -Infinity) {\n return 0;\n }\n\n return Math.pow(x, y);\n}\n\npowNumber.signature = n2;\n/**\n * round a number to the given number of decimals, or to zero if decimals is\n * not provided\n * @param {number} value\n * @param {number} decimals number of decimals, between 0 and 15 (0 by default)\n * @return {number} roundedValue\n */\n\nfunction roundNumber(value) {\n var decimals = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n\n if (!(0, _number.isInteger)(decimals) || decimals < 0 || decimals > 15) {\n throw new Error('Number of decimals in function round must be an integer from 0 to 15 inclusive');\n }\n\n return parseFloat((0, _number.toFixed)(value, decimals));\n}\n/**\n * Calculate the norm of a number, the absolute value.\n * @param {number} x\n * @return {number}\n */\n\n\nfunction normNumber(x) {\n return Math.abs(x);\n}\n\nnormNumber.signature = n1;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bitAndNumber = bitAndNumber;\nexports.bitNotNumber = bitNotNumber;\nexports.bitOrNumber = bitOrNumber;\nexports.bitXorNumber = bitXorNumber;\nexports.leftShiftNumber = leftShiftNumber;\nexports.rightArithShiftNumber = rightArithShiftNumber;\nexports.rightLogShiftNumber = rightLogShiftNumber;\n\nvar _number = require(\"../../utils/number.js\");\n\nvar n1 = 'number';\nvar n2 = 'number, number';\n\nfunction bitAndNumber(x, y) {\n if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) {\n throw new Error('Integers expected in function bitAnd');\n }\n\n return x & y;\n}\n\nbitAndNumber.signature = n2;\n\nfunction bitNotNumber(x) {\n if (!(0, _number.isInteger)(x)) {\n throw new Error('Integer expected in function bitNot');\n }\n\n return ~x;\n}\n\nbitNotNumber.signature = n1;\n\nfunction bitOrNumber(x, y) {\n if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) {\n throw new Error('Integers expected in function bitOr');\n }\n\n return x | y;\n}\n\nbitOrNumber.signature = n2;\n\nfunction bitXorNumber(x, y) {\n if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) {\n throw new Error('Integers expected in function bitXor');\n }\n\n return x ^ y;\n}\n\nbitXorNumber.signature = n2;\n\nfunction leftShiftNumber(x, y) {\n if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) {\n throw new Error('Integers expected in function leftShift');\n }\n\n return x << y;\n}\n\nleftShiftNumber.signature = n2;\n\nfunction rightArithShiftNumber(x, y) {\n if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) {\n throw new Error('Integers expected in function rightArithShift');\n }\n\n return x >> y;\n}\n\nrightArithShiftNumber.signature = n2;\n\nfunction rightLogShiftNumber(x, y) {\n if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) {\n throw new Error('Integers expected in function rightLogShift');\n }\n\n return x >>> y;\n}\n\nrightLogShiftNumber.signature = n2;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.combinationsNumber = combinationsNumber;\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _product = require(\"../../utils/product.js\");\n\nfunction combinationsNumber(n, k) {\n if (!(0, _number.isInteger)(n) || n < 0) {\n throw new TypeError('Positive integer value expected in function combinations');\n }\n\n if (!(0, _number.isInteger)(k) || k < 0) {\n throw new TypeError('Positive integer value expected in function combinations');\n }\n\n if (k > n) {\n throw new TypeError('k must be less than or equal to n');\n }\n\n var nMinusk = n - k;\n var answer = 1;\n var firstnumerator = k < nMinusk ? nMinusk + 1 : k + 1;\n var nextdivisor = 2;\n var lastdivisor = k < nMinusk ? k : nMinusk; // balance multiplications and divisions to try to keep intermediate values\n // in exact-integer range as long as possible\n\n for (var nextnumerator = firstnumerator; nextnumerator <= n; ++nextnumerator) {\n answer *= nextnumerator;\n\n while (nextdivisor <= lastdivisor && answer % nextdivisor === 0) {\n answer /= nextdivisor;\n ++nextdivisor;\n }\n } // for big n, k, floating point may have caused weirdness in remainder\n\n\n if (nextdivisor <= lastdivisor) {\n answer /= (0, _product.product)(nextdivisor, lastdivisor);\n }\n\n return answer;\n}\n\ncombinationsNumber.signature = 'number, number';","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.tau = exports.pi = exports.phi = exports.e = void 0;\nvar pi = Math.PI;\nexports.pi = pi;\nvar tau = 2 * Math.PI;\nexports.tau = tau;\nvar e = Math.E;\nexports.e = e;\nvar phi = 1.6180339887498948; // eslint-disable-line no-loss-of-precision\n\nexports.phi = phi;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _arithmetic = require(\"./arithmetic.js\");\n\nObject.keys(_arithmetic).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (key in exports && exports[key] === _arithmetic[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _arithmetic[key];\n }\n });\n});\n\nvar _bitwise = require(\"./bitwise.js\");\n\nObject.keys(_bitwise).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (key in exports && exports[key] === _bitwise[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _bitwise[key];\n }\n });\n});\n\nvar _combinations = require(\"./combinations.js\");\n\nObject.keys(_combinations).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (key in exports && exports[key] === _combinations[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _combinations[key];\n }\n });\n});\n\nvar _constants = require(\"./constants.js\");\n\nObject.keys(_constants).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (key in exports && exports[key] === _constants[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _constants[key];\n }\n });\n});\n\nvar _logical = require(\"./logical.js\");\n\nObject.keys(_logical).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (key in exports && exports[key] === _logical[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _logical[key];\n }\n });\n});\n\nvar _relational = require(\"./relational.js\");\n\nObject.keys(_relational).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (key in exports && exports[key] === _relational[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _relational[key];\n }\n });\n});\n\nvar _probability = require(\"./probability.js\");\n\nObject.keys(_probability).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (key in exports && exports[key] === _probability[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _probability[key];\n }\n });\n});\n\nvar _trigonometry = require(\"./trigonometry.js\");\n\nObject.keys(_trigonometry).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (key in exports && exports[key] === _trigonometry[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _trigonometry[key];\n }\n });\n});\n\nvar _utils = require(\"./utils.js\");\n\nObject.keys(_utils).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (key in exports && exports[key] === _utils[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _utils[key];\n }\n });\n});","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.andNumber = andNumber;\nexports.notNumber = notNumber;\nexports.orNumber = orNumber;\nexports.xorNumber = xorNumber;\nvar n1 = 'number';\nvar n2 = 'number, number';\n\nfunction notNumber(x) {\n return !x;\n}\n\nnotNumber.signature = n1;\n\nfunction orNumber(x, y) {\n return !!(x || y);\n}\n\norNumber.signature = n2;\n\nfunction xorNumber(x, y) {\n return !!x !== !!y;\n}\n\nxorNumber.signature = n2;\n\nfunction andNumber(x, y) {\n return !!(x && y);\n}\n\nandNumber.signature = n2;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.gammaG = void 0;\nexports.gammaNumber = gammaNumber;\nexports.lgammaN = exports.lgammaG = exports.gammaP = void 0;\nexports.lgammaNumber = lgammaNumber;\nexports.lnSqrt2PI = exports.lgammaSeries = void 0;\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _product = require(\"../../utils/product.js\");\n\n/* eslint-disable no-loss-of-precision */\nfunction gammaNumber(n) {\n var x;\n\n if ((0, _number.isInteger)(n)) {\n if (n <= 0) {\n return isFinite(n) ? Infinity : NaN;\n }\n\n if (n > 171) {\n return Infinity; // Will overflow\n }\n\n return (0, _product.product)(1, n - 1);\n }\n\n if (n < 0.5) {\n return Math.PI / (Math.sin(Math.PI * n) * gammaNumber(1 - n));\n }\n\n if (n >= 171.35) {\n return Infinity; // will overflow\n }\n\n if (n > 85.0) {\n // Extended Stirling Approx\n var twoN = n * n;\n var threeN = twoN * n;\n var fourN = threeN * n;\n var fiveN = fourN * n;\n return Math.sqrt(2 * Math.PI / n) * Math.pow(n / Math.E, n) * (1 + 1 / (12 * n) + 1 / (288 * twoN) - 139 / (51840 * threeN) - 571 / (2488320 * fourN) + 163879 / (209018880 * fiveN) + 5246819 / (75246796800 * fiveN * n));\n }\n\n --n;\n x = gammaP[0];\n\n for (var i = 1; i < gammaP.length; ++i) {\n x += gammaP[i] / (n + i);\n }\n\n var t = n + gammaG + 0.5;\n return Math.sqrt(2 * Math.PI) * Math.pow(t, n + 0.5) * Math.exp(-t) * x;\n}\n\ngammaNumber.signature = 'number'; // TODO: comment on the variables g and p\n\nvar gammaG = 4.7421875;\nexports.gammaG = gammaG;\nvar gammaP = [0.99999999999999709182, 57.156235665862923517, -59.597960355475491248, 14.136097974741747174, -0.49191381609762019978, 0.33994649984811888699e-4, 0.46523628927048575665e-4, -0.98374475304879564677e-4, 0.15808870322491248884e-3, -0.21026444172410488319e-3, 0.21743961811521264320e-3, -0.16431810653676389022e-3, 0.84418223983852743293e-4, -0.26190838401581408670e-4, 0.36899182659531622704e-5]; // lgamma implementation ref: https://mrob.com/pub/ries/lanczos-gamma.html#code\n// log(2 * pi) / 2\n\nexports.gammaP = gammaP;\nvar lnSqrt2PI = 0.91893853320467274178;\nexports.lnSqrt2PI = lnSqrt2PI;\nvar lgammaG = 5; // Lanczos parameter \"g\"\n\nexports.lgammaG = lgammaG;\nvar lgammaN = 7; // Range of coefficients \"n\"\n\nexports.lgammaN = lgammaN;\nvar lgammaSeries = [1.000000000190015, 76.18009172947146, -86.50532032941677, 24.01409824083091, -1.231739572450155, 0.1208650973866179e-2, -0.5395239384953e-5];\nexports.lgammaSeries = lgammaSeries;\n\nfunction lgammaNumber(n) {\n if (n < 0) return NaN;\n if (n === 0) return Infinity;\n if (!isFinite(n)) return n;\n\n if (n < 0.5) {\n // Use Euler's reflection formula:\n // gamma(z) = PI / (sin(PI * z) * gamma(1 - z))\n return Math.log(Math.PI / Math.sin(Math.PI * n)) - lgammaNumber(1 - n);\n } // Compute the logarithm of the Gamma function using the Lanczos method\n\n\n n = n - 1;\n var base = n + lgammaG + 0.5; // Base of the Lanczos exponential\n\n var sum = lgammaSeries[0]; // We start with the terms that have the smallest coefficients and largest denominator\n\n for (var i = lgammaN - 1; i >= 1; i--) {\n sum += lgammaSeries[i] / (n + i);\n }\n\n return lnSqrt2PI + (n + 0.5) * Math.log(base) - base + Math.log(sum);\n}\n\nlgammaNumber.signature = 'number';","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.acosNumber = acosNumber;\nexports.acoshNumber = acoshNumber;\nexports.acotNumber = acotNumber;\nexports.acothNumber = acothNumber;\nexports.acscNumber = acscNumber;\nexports.acschNumber = acschNumber;\nexports.asecNumber = asecNumber;\nexports.asechNumber = asechNumber;\nexports.asinNumber = asinNumber;\nexports.asinhNumber = asinhNumber;\nexports.atan2Number = atan2Number;\nexports.atanNumber = atanNumber;\nexports.atanhNumber = atanhNumber;\nexports.cosNumber = cosNumber;\nexports.coshNumber = coshNumber;\nexports.cotNumber = cotNumber;\nexports.cothNumber = cothNumber;\nexports.cscNumber = cscNumber;\nexports.cschNumber = cschNumber;\nexports.secNumber = secNumber;\nexports.sechNumber = sechNumber;\nexports.sinNumber = sinNumber;\nexports.sinhNumber = sinhNumber;\nexports.tanNumber = tanNumber;\nexports.tanhNumber = tanhNumber;\n\nvar _number = require(\"../../utils/number.js\");\n\nvar n1 = 'number';\nvar n2 = 'number, number';\n\nfunction acosNumber(x) {\n return Math.acos(x);\n}\n\nacosNumber.signature = n1;\n\nfunction acoshNumber(x) {\n return (0, _number.acosh)(x);\n}\n\nacoshNumber.signature = n1;\n\nfunction acotNumber(x) {\n return Math.atan(1 / x);\n}\n\nacotNumber.signature = n1;\n\nfunction acothNumber(x) {\n return isFinite(x) ? (Math.log((x + 1) / x) + Math.log(x / (x - 1))) / 2 : 0;\n}\n\nacothNumber.signature = n1;\n\nfunction acscNumber(x) {\n return Math.asin(1 / x);\n}\n\nacscNumber.signature = n1;\n\nfunction acschNumber(x) {\n var xInv = 1 / x;\n return Math.log(xInv + Math.sqrt(xInv * xInv + 1));\n}\n\nacschNumber.signature = n1;\n\nfunction asecNumber(x) {\n return Math.acos(1 / x);\n}\n\nasecNumber.signature = n1;\n\nfunction asechNumber(x) {\n var xInv = 1 / x;\n var ret = Math.sqrt(xInv * xInv - 1);\n return Math.log(ret + xInv);\n}\n\nasechNumber.signature = n1;\n\nfunction asinNumber(x) {\n return Math.asin(x);\n}\n\nasinNumber.signature = n1;\n\nfunction asinhNumber(x) {\n return (0, _number.asinh)(x);\n}\n\nasinhNumber.signature = n1;\n\nfunction atanNumber(x) {\n return Math.atan(x);\n}\n\natanNumber.signature = n1;\n\nfunction atan2Number(y, x) {\n return Math.atan2(y, x);\n}\n\natan2Number.signature = n2;\n\nfunction atanhNumber(x) {\n return (0, _number.atanh)(x);\n}\n\natanhNumber.signature = n1;\n\nfunction cosNumber(x) {\n return Math.cos(x);\n}\n\ncosNumber.signature = n1;\n\nfunction coshNumber(x) {\n return (0, _number.cosh)(x);\n}\n\ncoshNumber.signature = n1;\n\nfunction cotNumber(x) {\n return 1 / Math.tan(x);\n}\n\ncotNumber.signature = n1;\n\nfunction cothNumber(x) {\n var e = Math.exp(2 * x);\n return (e + 1) / (e - 1);\n}\n\ncothNumber.signature = n1;\n\nfunction cscNumber(x) {\n return 1 / Math.sin(x);\n}\n\ncscNumber.signature = n1;\n\nfunction cschNumber(x) {\n // consider values close to zero (+/-)\n if (x === 0) {\n return Number.POSITIVE_INFINITY;\n } else {\n return Math.abs(2 / (Math.exp(x) - Math.exp(-x))) * (0, _number.sign)(x);\n }\n}\n\ncschNumber.signature = n1;\n\nfunction secNumber(x) {\n return 1 / Math.cos(x);\n}\n\nsecNumber.signature = n1;\n\nfunction sechNumber(x) {\n return 2 / (Math.exp(x) + Math.exp(-x));\n}\n\nsechNumber.signature = n1;\n\nfunction sinNumber(x) {\n return Math.sin(x);\n}\n\nsinNumber.signature = n1;\n\nfunction sinhNumber(x) {\n return (0, _number.sinh)(x);\n}\n\nsinhNumber.signature = n1;\n\nfunction tanNumber(x) {\n return Math.tan(x);\n}\n\ntanNumber.signature = n1;\n\nfunction tanhNumber(x) {\n return (0, _number.tanh)(x);\n}\n\ntanhNumber.signature = n1;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isIntegerNumber = isIntegerNumber;\nexports.isNaNNumber = isNaNNumber;\nexports.isNegativeNumber = isNegativeNumber;\nexports.isPositiveNumber = isPositiveNumber;\nexports.isZeroNumber = isZeroNumber;\n\nvar _number = require(\"../../utils/number.js\");\n\nvar n1 = 'number';\n\nfunction isIntegerNumber(x) {\n return (0, _number.isInteger)(x);\n}\n\nisIntegerNumber.signature = n1;\n\nfunction isNegativeNumber(x) {\n return x < 0;\n}\n\nisNegativeNumber.signature = n1;\n\nfunction isPositiveNumber(x) {\n return x > 0;\n}\n\nisPositiveNumber.signature = n1;\n\nfunction isZeroNumber(x) {\n return x === 0;\n}\n\nisZeroNumber.signature = n1;\n\nfunction isNaNNumber(x) {\n return Number.isNaN(x);\n}\n\nisNaNNumber.signature = n1;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createBigNumberClass = void 0;\n\nvar _decimal = _interopRequireDefault(require(\"decimal.js\"));\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'BigNumber';\nvar dependencies = ['?on', 'config'];\nvar createBigNumberClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var on = _ref.on,\n config = _ref.config;\n\n var BigNumber = _decimal.default.clone({\n precision: config.precision,\n modulo: _decimal.default.EUCLID\n });\n\n BigNumber.prototype = Object.create(BigNumber.prototype);\n /**\n * Attach type information\n */\n\n BigNumber.prototype.type = 'BigNumber';\n BigNumber.prototype.isBigNumber = true;\n /**\n * Get a JSON representation of a BigNumber containing\n * type information\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"BigNumber\", \"value\": \"0.2\"}`\n */\n\n BigNumber.prototype.toJSON = function () {\n return {\n mathjs: 'BigNumber',\n value: this.toString()\n };\n };\n /**\n * Instantiate a BigNumber from a JSON object\n * @param {Object} json a JSON object structured as:\n * `{\"mathjs\": \"BigNumber\", \"value\": \"0.2\"}`\n * @return {BigNumber}\n */\n\n\n BigNumber.fromJSON = function (json) {\n return new BigNumber(json.value);\n };\n\n if (on) {\n // listen for changed in the configuration, automatically apply changed precision\n on('config', function (curr, prev) {\n if (curr.precision !== prev.precision) {\n BigNumber.config({\n precision: curr.precision\n });\n }\n });\n }\n\n return BigNumber;\n}, {\n isClass: true\n});\nexports.createBigNumberClass = createBigNumberClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createBignumber = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _collection = require(\"../../../utils/collection.js\");\n\nvar name = 'bignumber';\nvar dependencies = ['typed', 'BigNumber'];\nvar createBignumber = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n BigNumber = _ref.BigNumber;\n\n /**\n * Create a BigNumber, which can store numbers with arbitrary precision.\n * When a matrix is provided, all elements will be converted to BigNumber.\n *\n * Syntax:\n *\n * math.bignumber(x)\n *\n * Examples:\n *\n * 0.1 + 0.2 // returns number 0.30000000000000004\n * math.bignumber(0.1) + math.bignumber(0.2) // returns BigNumber 0.3\n *\n *\n * 7.2e500 // returns number Infinity\n * math.bignumber('7.2e500') // returns BigNumber 7.2e500\n *\n * See also:\n *\n * boolean, complex, index, matrix, string, unit\n *\n * @param {number | string | Fraction | BigNumber | Array | Matrix | boolean | null} [value] Value for the big number,\n * 0 by default.\n * @returns {BigNumber} The created bignumber\n */\n return typed('bignumber', {\n '': function _() {\n return new BigNumber(0);\n },\n number: function number(x) {\n // convert to string to prevent errors in case of >15 digits\n return new BigNumber(x + '');\n },\n string: function string(x) {\n var wordSizeSuffixMatch = x.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/);\n\n if (wordSizeSuffixMatch) {\n // x has a word size suffix\n var size = wordSizeSuffixMatch[2];\n var n = BigNumber(wordSizeSuffixMatch[1]);\n var twoPowSize = new BigNumber(2).pow(Number(size));\n\n if (n.gt(twoPowSize.sub(1))) {\n throw new SyntaxError(\"String \\\"\".concat(x, \"\\\" is out of range\"));\n }\n\n var twoPowSizeSubOne = new BigNumber(2).pow(Number(size) - 1);\n\n if (n.gte(twoPowSizeSubOne)) {\n return n.sub(twoPowSize);\n } else {\n return n;\n }\n }\n\n return new BigNumber(x);\n },\n BigNumber: function BigNumber(x) {\n // we assume a BigNumber is immutable\n return x;\n },\n Fraction: function Fraction(x) {\n return new BigNumber(x.n).div(x.d).times(x.s);\n },\n null: function _null(x) {\n return new BigNumber(0);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createBignumber = createBignumber;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createBoolean = void 0;\n\nvar _factory = require(\"../utils/factory.js\");\n\nvar _collection = require(\"../utils/collection.js\");\n\nvar name = 'boolean';\nvar dependencies = ['typed'];\nvar createBoolean = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Create a boolean or convert a string or number to a boolean.\n * In case of a number, `true` is returned for non-zero numbers, and `false` in\n * case of zero.\n * Strings can be `'true'` or `'false'`, or can contain a number.\n * When value is a matrix, all elements will be converted to boolean.\n *\n * Syntax:\n *\n * math.boolean(x)\n *\n * Examples:\n *\n * math.boolean(0) // returns false\n * math.boolean(1) // returns true\n * math.boolean(-3) // returns true\n * math.boolean('true') // returns true\n * math.boolean('false') // returns false\n * math.boolean([1, 0, 1, 1]) // returns [true, false, true, true]\n *\n * See also:\n *\n * bignumber, complex, index, matrix, string, unit\n *\n * @param {string | number | boolean | Array | Matrix | null} value A value of any type\n * @return {boolean | Array | Matrix} The boolean value\n */\n return typed(name, {\n '': function _() {\n return false;\n },\n boolean: function boolean(x) {\n return x;\n },\n number: function number(x) {\n return !!x;\n },\n null: function _null(x) {\n return false;\n },\n BigNumber: function BigNumber(x) {\n return !x.isZero();\n },\n string: function string(x) {\n // try case insensitive\n var lcase = x.toLowerCase();\n\n if (lcase === 'true') {\n return true;\n } else if (lcase === 'false') {\n return false;\n } // test whether value is a valid number\n\n\n var num = Number(x);\n\n if (x !== '' && !isNaN(num)) {\n return !!num;\n }\n\n throw new Error('Cannot convert \"' + x + '\" to a boolean');\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createBoolean = createBoolean;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createChainClass = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'Chain';\nvar dependencies = ['?on', 'math'];\nvar createChainClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var on = _ref.on,\n math = _ref.math;\n\n /**\n * @constructor Chain\n * Wrap any value in a chain, allowing to perform chained operations on\n * the value.\n *\n * All methods available in the math.js library can be called upon the chain,\n * and then will be evaluated with the value itself as first argument.\n * The chain can be closed by executing chain.done(), which will return\n * the final value.\n *\n * The Chain has a number of special functions:\n * - done() Finalize the chained operation and return the\n * chain's value.\n * - valueOf() The same as done()\n * - toString() Returns a string representation of the chain's value.\n *\n * @param {*} [value]\n */\n function Chain(value) {\n if (!(this instanceof Chain)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n if ((0, _is.isChain)(value)) {\n this.value = value.value;\n } else {\n this.value = value;\n }\n }\n /**\n * Attach type information\n */\n\n\n Chain.prototype.type = 'Chain';\n Chain.prototype.isChain = true;\n /**\n * Close the chain. Returns the final value.\n * Does the same as method valueOf()\n * @returns {*} value\n */\n\n Chain.prototype.done = function () {\n return this.value;\n };\n /**\n * Close the chain. Returns the final value.\n * Does the same as method done()\n * @returns {*} value\n */\n\n\n Chain.prototype.valueOf = function () {\n return this.value;\n };\n /**\n * Get a string representation of the value in the chain\n * @returns {string}\n */\n\n\n Chain.prototype.toString = function () {\n return (0, _string.format)(this.value);\n };\n /**\n * Get a JSON representation of the chain\n * @returns {Object}\n */\n\n\n Chain.prototype.toJSON = function () {\n return {\n mathjs: 'Chain',\n value: this.value\n };\n };\n /**\n * Instantiate a Chain from its JSON representation\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"Chain\", value: ...}`,\n * where mathjs is optional\n * @returns {Chain}\n */\n\n\n Chain.fromJSON = function (json) {\n return new Chain(json.value);\n };\n /**\n * Create a proxy method for the chain\n * @param {string} name\n * @param {Function} fn The function to be proxied\n * If fn is no function, it is silently ignored.\n * @private\n */\n\n\n function createProxy(name, fn) {\n if (typeof fn === 'function') {\n Chain.prototype[name] = chainify(fn);\n }\n }\n /**\n * Create a proxy method for the chain\n * @param {string} name\n * @param {function} resolver The function resolving with the\n * function to be proxied\n * @private\n */\n\n\n function createLazyProxy(name, resolver) {\n (0, _object.lazy)(Chain.prototype, name, function outerResolver() {\n var fn = resolver();\n\n if (typeof fn === 'function') {\n return chainify(fn);\n }\n\n return undefined; // if not a function, ignore\n });\n }\n /**\n * Make a function chainable\n * @param {function} fn\n * @return {Function} chain function\n * @private\n */\n\n\n function chainify(fn) {\n return function () {\n var args = [this.value]; // `this` will be the context of a Chain instance\n\n for (var i = 0; i < arguments.length; i++) {\n args[i + 1] = arguments[i];\n }\n\n return new Chain(fn.apply(fn, args));\n };\n }\n /**\n * Create a proxy for a single method, or an object with multiple methods.\n * Example usage:\n *\n * Chain.createProxy('add', function add (x, y) {...})\n * Chain.createProxy({\n * add: function add (x, y) {...},\n * subtract: function subtract (x, y) {...}\n * }\n *\n * @param {string | Object} arg0 A name (string), or an object with\n * functions\n * @param {*} [arg1] A function, when arg0 is a name\n */\n\n\n Chain.createProxy = function (arg0, arg1) {\n if (typeof arg0 === 'string') {\n // createProxy(name, value)\n createProxy(arg0, arg1);\n } else {\n var _loop = function _loop(_name) {\n if ((0, _object.hasOwnProperty)(arg0, _name) && excludedNames[_name] === undefined) {\n createLazyProxy(_name, function () {\n return arg0[_name];\n });\n }\n };\n\n // createProxy(values)\n for (var _name in arg0) {\n _loop(_name);\n }\n }\n };\n\n var excludedNames = {\n expression: true,\n docs: true,\n type: true,\n classes: true,\n json: true,\n error: true,\n isChain: true // conflicts with the property isChain of a Chain instance\n\n }; // create proxy for everything that is in math.js\n\n Chain.createProxy(math); // register on the import event, automatically add a proxy for every imported function.\n\n if (on) {\n on('import', function (name, resolver, path) {\n if (!path) {\n // an imported function (not a data type or something special)\n createLazyProxy(name, resolver);\n }\n });\n }\n\n return Chain;\n}, {\n isClass: true\n});\nexports.createChainClass = createChainClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createChain = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar name = 'chain';\nvar dependencies = ['typed', 'Chain'];\nvar createChain = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Chain = _ref.Chain;\n\n /**\n * Wrap any value in a chain, allowing to perform chained operations on\n * the value.\n *\n * All methods available in the math.js library can be called upon the chain,\n * and then will be evaluated with the value itself as first argument.\n * The chain can be closed by executing `chain.done()`, which returns\n * the final value.\n *\n * The chain has a number of special functions:\n *\n * - `done()` Finalize the chain and return the chain's value.\n * - `valueOf()` The same as `done()`\n * - `toString()` Executes `math.format()` onto the chain's value, returning\n * a string representation of the value.\n *\n * Syntax:\n *\n * math.chain(value)\n *\n * Examples:\n *\n * math.chain(3)\n * .add(4)\n * .subtract(2)\n * .done() // 5\n *\n * math.chain( [[1, 2], [3, 4]] )\n * .subset(math.index(0, 0), 8)\n * .multiply(3)\n * .done() // [[24, 6], [9, 12]]\n *\n * @param {*} [value] A value of any type on which to start a chained operation.\n * @return {math.Chain} The created chain\n */\n return typed(name, {\n '': function _() {\n return new Chain();\n },\n any: function any(value) {\n return new Chain(value);\n }\n });\n});\nexports.createChain = createChain;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createComplexClass = void 0;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _complex = _interopRequireDefault(require(\"complex.js\"));\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'Complex';\nvar dependencies = [];\nvar createComplexClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function () {\n /**\n * Attach type information\n */\n _complex.default.prototype.type = 'Complex';\n _complex.default.prototype.isComplex = true;\n /**\n * Get a JSON representation of the complex number\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"Complex\", \"re\": 2, \"im\": 3}`\n */\n\n _complex.default.prototype.toJSON = function () {\n return {\n mathjs: 'Complex',\n re: this.re,\n im: this.im\n };\n };\n /*\n * Return the value of the complex number in polar notation\n * The angle phi will be set in the interval of [-pi, pi].\n * @return {{r: number, phi: number}} Returns and object with properties r and phi.\n */\n\n\n _complex.default.prototype.toPolar = function () {\n return {\n r: this.abs(),\n phi: this.arg()\n };\n };\n /**\n * Get a string representation of the complex number,\n * with optional formatting options.\n * @param {Object | number | Function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @return {string} str\n */\n\n\n _complex.default.prototype.format = function (options) {\n var str = '';\n var im = this.im;\n var re = this.re;\n var strRe = (0, _number.format)(this.re, options);\n var strIm = (0, _number.format)(this.im, options); // round either re or im when smaller than the configured precision\n\n var precision = (0, _is.isNumber)(options) ? options : options ? options.precision : null;\n\n if (precision !== null) {\n var epsilon = Math.pow(10, -precision);\n\n if (Math.abs(re / im) < epsilon) {\n re = 0;\n }\n\n if (Math.abs(im / re) < epsilon) {\n im = 0;\n }\n }\n\n if (im === 0) {\n // real value\n str = strRe;\n } else if (re === 0) {\n // purely complex value\n if (im === 1) {\n str = 'i';\n } else if (im === -1) {\n str = '-i';\n } else {\n str = strIm + 'i';\n }\n } else {\n // complex value\n if (im < 0) {\n if (im === -1) {\n str = strRe + ' - i';\n } else {\n str = strRe + ' - ' + strIm.substring(1) + 'i';\n }\n } else {\n if (im === 1) {\n str = strRe + ' + i';\n } else {\n str = strRe + ' + ' + strIm + 'i';\n }\n }\n }\n\n return str;\n };\n /**\n * Create a complex number from polar coordinates\n *\n * Usage:\n *\n * Complex.fromPolar(r: number, phi: number) : Complex\n * Complex.fromPolar({r: number, phi: number}) : Complex\n *\n * @param {*} args...\n * @return {Complex}\n */\n\n\n _complex.default.fromPolar = function (args) {\n switch (arguments.length) {\n case 1:\n {\n var arg = arguments[0];\n\n if ((0, _typeof2.default)(arg) === 'object') {\n return (0, _complex.default)(arg);\n } else {\n throw new TypeError('Input has to be an object with r and phi keys.');\n }\n }\n\n case 2:\n {\n var r = arguments[0];\n var phi = arguments[1];\n\n if ((0, _is.isNumber)(r)) {\n if ((0, _is.isUnit)(phi) && phi.hasBase('ANGLE')) {\n // convert unit to a number in radians\n phi = phi.toNumber('rad');\n }\n\n if ((0, _is.isNumber)(phi)) {\n return new _complex.default({\n r: r,\n phi: phi\n });\n }\n\n throw new TypeError('Phi is not a number nor an angle unit.');\n } else {\n throw new TypeError('Radius r is not a number.');\n }\n }\n\n default:\n throw new SyntaxError('Wrong number of arguments in function fromPolar');\n }\n };\n\n _complex.default.prototype.valueOf = _complex.default.prototype.toString;\n /**\n * Create a Complex number from a JSON object\n * @param {Object} json A JSON Object structured as\n * {\"mathjs\": \"Complex\", \"re\": 2, \"im\": 3}\n * All properties are optional, default values\n * for `re` and `im` are 0.\n * @return {Complex} Returns a new Complex number\n */\n\n _complex.default.fromJSON = function (json) {\n return new _complex.default(json);\n };\n /**\n * Compare two complex numbers, `a` and `b`:\n *\n * - Returns 1 when the real part of `a` is larger than the real part of `b`\n * - Returns -1 when the real part of `a` is smaller than the real part of `b`\n * - Returns 1 when the real parts are equal\n * and the imaginary part of `a` is larger than the imaginary part of `b`\n * - Returns -1 when the real parts are equal\n * and the imaginary part of `a` is smaller than the imaginary part of `b`\n * - Returns 0 when both real and imaginary parts are equal.\n *\n * @params {Complex} a\n * @params {Complex} b\n * @returns {number} Returns the comparison result: -1, 0, or 1\n */\n\n\n _complex.default.compare = function (a, b) {\n if (a.re > b.re) {\n return 1;\n }\n\n if (a.re < b.re) {\n return -1;\n }\n\n if (a.im > b.im) {\n return 1;\n }\n\n if (a.im < b.im) {\n return -1;\n }\n\n return 0;\n };\n\n return _complex.default;\n}, {\n isClass: true\n});\nexports.createComplexClass = createComplexClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createComplex = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _collection = require(\"../../../utils/collection.js\");\n\nvar name = 'complex';\nvar dependencies = ['typed', 'Complex'];\nvar createComplex = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Complex = _ref.Complex;\n\n /**\n * Create a complex value or convert a value to a complex value.\n *\n * Syntax:\n *\n * math.complex() // creates a complex value with zero\n * // as real and imaginary part.\n * math.complex(re : number, im : string) // creates a complex value with provided\n * // values for real and imaginary part.\n * math.complex(re : number) // creates a complex value with provided\n * // real value and zero imaginary part.\n * math.complex(complex : Complex) // clones the provided complex value.\n * math.complex(arg : string) // parses a string into a complex value.\n * math.complex(array : Array) // converts the elements of the array\n * // or matrix element wise into a\n * // complex value.\n * math.complex({re: number, im: number}) // creates a complex value with provided\n * // values for real an imaginary part.\n * math.complex({r: number, phi: number}) // creates a complex value with provided\n * // polar coordinates\n *\n * Examples:\n *\n * const a = math.complex(3, -4) // a = Complex 3 - 4i\n * a.re = 5 // a = Complex 5 - 4i\n * const i = a.im // Number -4\n * const b = math.complex('2 + 6i') // Complex 2 + 6i\n * const c = math.complex() // Complex 0 + 0i\n * const d = math.add(a, b) // Complex 5 + 2i\n *\n * See also:\n *\n * bignumber, boolean, index, matrix, number, string, unit\n *\n * @param {* | Array | Matrix} [args]\n * Arguments specifying the real and imaginary part of the complex number\n * @return {Complex | Array | Matrix} Returns a complex value\n */\n return typed('complex', {\n '': function _() {\n return Complex.ZERO;\n },\n number: function number(x) {\n return new Complex(x, 0);\n },\n 'number, number': function numberNumber(re, im) {\n return new Complex(re, im);\n },\n // TODO: this signature should be redundant\n 'BigNumber, BigNumber': function BigNumberBigNumber(re, im) {\n return new Complex(re.toNumber(), im.toNumber());\n },\n Fraction: function Fraction(x) {\n return new Complex(x.valueOf(), 0);\n },\n Complex: function Complex(x) {\n return x.clone();\n },\n string: function string(x) {\n return Complex(x); // for example '2 + 3i'\n },\n null: function _null(x) {\n return Complex(0);\n },\n Object: function Object(x) {\n if ('re' in x && 'im' in x) {\n return new Complex(x.re, x.im);\n }\n\n if ('r' in x && 'phi' in x || 'abs' in x && 'arg' in x) {\n return new Complex(x);\n }\n\n throw new Error('Expected object with properties (re and im) or (r and phi) or (abs and arg)');\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createComplex = createComplex;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFractionClass = void 0;\n\nvar _fraction = _interopRequireDefault(require(\"fraction.js\"));\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'Fraction';\nvar dependencies = [];\nvar createFractionClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function () {\n /**\n * Attach type information\n */\n _fraction.default.prototype.type = 'Fraction';\n _fraction.default.prototype.isFraction = true;\n /**\n * Get a JSON representation of a Fraction containing type information\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"Fraction\", \"n\": 3, \"d\": 8}`\n */\n\n _fraction.default.prototype.toJSON = function () {\n return {\n mathjs: 'Fraction',\n n: this.s * this.n,\n d: this.d\n };\n };\n /**\n * Instantiate a Fraction from a JSON object\n * @param {Object} json a JSON object structured as:\n * `{\"mathjs\": \"Fraction\", \"n\": 3, \"d\": 8}`\n * @return {BigNumber}\n */\n\n\n _fraction.default.fromJSON = function (json) {\n return new _fraction.default(json);\n };\n\n return _fraction.default;\n}, {\n isClass: true\n});\nexports.createFractionClass = createFractionClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFraction = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _collection = require(\"../../../utils/collection.js\");\n\nvar name = 'fraction';\nvar dependencies = ['typed', 'Fraction'];\nvar createFraction = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Fraction = _ref.Fraction;\n\n /**\n * Create a fraction or convert a value to a fraction.\n *\n * With one numeric argument, produces the closest rational approximation to the\n * input.\n * With two arguments, the first is the numerator and the second is the denominator,\n * and creates the corresponding fraction. Both numerator and denominator must be\n * integers.\n * With one object argument, looks for the integer numerator as the value of property\n * 'n' and the integer denominator as the value of property 'd'.\n * With a matrix argument, creates a matrix of the same shape with entries\n * converted into fractions.\n *\n * Syntax:\n * math.fraction(value)\n * math.fraction(numerator, denominator)\n * math.fraction({n: numerator, d: denominator})\n * math.fraction(matrix: Array | Matrix)\n *\n * Examples:\n *\n * math.fraction(6.283) // returns Fraction 6283/1000\n * math.fraction(1, 3) // returns Fraction 1/3\n * math.fraction('2/3') // returns Fraction 2/3\n * math.fraction({n: 2, d: 3}) // returns Fraction 2/3\n * math.fraction([0.2, 0.25, 1.25]) // returns Array [1/5, 1/4, 5/4]\n * math.fraction(4, 5.1) // throws Error: Parameters must be integer\n *\n * See also:\n *\n * bignumber, number, string, unit\n *\n * @param {number | string | Fraction | BigNumber | Array | Matrix} [args]\n * Arguments specifying the value, or numerator and denominator of\n * the fraction\n * @return {Fraction | Array | Matrix} Returns a fraction\n */\n return typed('fraction', {\n number: function number(x) {\n if (!isFinite(x) || isNaN(x)) {\n throw new Error(x + ' cannot be represented as a fraction');\n }\n\n return new Fraction(x);\n },\n string: function string(x) {\n return new Fraction(x);\n },\n 'number, number': function numberNumber(numerator, denominator) {\n return new Fraction(numerator, denominator);\n },\n null: function _null(x) {\n return new Fraction(0);\n },\n BigNumber: function BigNumber(x) {\n return new Fraction(x.toString());\n },\n Fraction: function Fraction(x) {\n return x; // fractions are immutable\n },\n Object: function Object(x) {\n return new Fraction(x);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createFraction = createFraction;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDenseMatrixClass = void 0;\n\nvar _regenerator = _interopRequireDefault(require(\"@babel/runtime/regenerator\"));\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _DimensionError = require(\"../../error/DimensionError.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { 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 = it.call(o); }, 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\nvar name = 'DenseMatrix';\nvar dependencies = ['Matrix'];\nvar createDenseMatrixClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var Matrix = _ref.Matrix;\n\n /**\n * Dense Matrix implementation. A regular, dense matrix, supporting multi-dimensional matrices. This is the default matrix type.\n * @class DenseMatrix\n * @enum {{ value, index: number[] }}\n */\n function DenseMatrix(data, datatype) {\n if (!(this instanceof DenseMatrix)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n if (datatype && !(0, _is.isString)(datatype)) {\n throw new Error('Invalid datatype: ' + datatype);\n }\n\n if ((0, _is.isMatrix)(data)) {\n // check data is a DenseMatrix\n if (data.type === 'DenseMatrix') {\n // clone data & size\n this._data = (0, _object.clone)(data._data);\n this._size = (0, _object.clone)(data._size);\n this._datatype = datatype || data._datatype;\n } else {\n // build data from existing matrix\n this._data = data.toArray();\n this._size = data.size();\n this._datatype = datatype || data._datatype;\n }\n } else if (data && (0, _is.isArray)(data.data) && (0, _is.isArray)(data.size)) {\n // initialize fields from JSON representation\n this._data = data.data;\n this._size = data.size; // verify the dimensions of the array\n\n (0, _array.validate)(this._data, this._size);\n this._datatype = datatype || data.datatype;\n } else if ((0, _is.isArray)(data)) {\n // replace nested Matrices with Arrays\n this._data = preprocess(data); // get the dimensions of the array\n\n this._size = (0, _array.arraySize)(this._data); // verify the dimensions of the array, TODO: compute size while processing array\n\n (0, _array.validate)(this._data, this._size); // data type unknown\n\n this._datatype = datatype;\n } else if (data) {\n // unsupported type\n throw new TypeError('Unsupported type of data (' + (0, _is.typeOf)(data) + ')');\n } else {\n // nothing provided\n this._data = [];\n this._size = [0];\n this._datatype = datatype;\n }\n }\n\n DenseMatrix.prototype = new Matrix();\n /**\n * Create a new DenseMatrix\n */\n\n DenseMatrix.prototype.createDenseMatrix = function (data, datatype) {\n return new DenseMatrix(data, datatype);\n };\n /**\n * Attach type information\n */\n\n\n DenseMatrix.prototype.type = 'DenseMatrix';\n DenseMatrix.prototype.isDenseMatrix = true;\n /**\n * Get the matrix type\n *\n * Usage:\n * const matrixType = matrix.getDataType() // retrieves the matrix type\n *\n * @memberOf DenseMatrix\n * @return {string} type information; if multiple types are found from the Matrix, it will return \"mixed\"\n */\n\n DenseMatrix.prototype.getDataType = function () {\n return (0, _array.getArrayDataType)(this._data, _is.typeOf);\n };\n /**\n * Get the storage format used by the matrix.\n *\n * Usage:\n * const format = matrix.storage() // retrieve storage format\n *\n * @memberof DenseMatrix\n * @return {string} The storage format.\n */\n\n\n DenseMatrix.prototype.storage = function () {\n return 'dense';\n };\n /**\n * Get the datatype of the data stored in the matrix.\n *\n * Usage:\n * const format = matrix.datatype() // retrieve matrix datatype\n *\n * @memberof DenseMatrix\n * @return {string} The datatype.\n */\n\n\n DenseMatrix.prototype.datatype = function () {\n return this._datatype;\n };\n /**\n * Create a new DenseMatrix\n * @memberof DenseMatrix\n * @param {Array} data\n * @param {string} [datatype]\n */\n\n\n DenseMatrix.prototype.create = function (data, datatype) {\n return new DenseMatrix(data, datatype);\n };\n /**\n * Get a subset of the matrix, or replace a subset of the matrix.\n *\n * Usage:\n * const subset = matrix.subset(index) // retrieve subset\n * const value = matrix.subset(index, replacement) // replace subset\n *\n * @memberof DenseMatrix\n * @param {Index} index\n * @param {Array | Matrix | *} [replacement]\n * @param {*} [defaultValue=0] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be filled with zeros.\n */\n\n\n DenseMatrix.prototype.subset = function (index, replacement, defaultValue) {\n switch (arguments.length) {\n case 1:\n return _get(this, index);\n // intentional fall through\n\n case 2:\n case 3:\n return _set(this, index, replacement, defaultValue);\n\n default:\n throw new SyntaxError('Wrong number of arguments');\n }\n };\n /**\n * Get a single element from the matrix.\n * @memberof DenseMatrix\n * @param {number[]} index Zero-based index\n * @return {*} value\n */\n\n\n DenseMatrix.prototype.get = function (index) {\n if (!(0, _is.isArray)(index)) {\n throw new TypeError('Array expected');\n }\n\n if (index.length !== this._size.length) {\n throw new _DimensionError.DimensionError(index.length, this._size.length);\n } // check index\n\n\n for (var x = 0; x < index.length; x++) {\n (0, _array.validateIndex)(index[x], this._size[x]);\n }\n\n var data = this._data;\n\n for (var i = 0, ii = index.length; i < ii; i++) {\n var indexI = index[i];\n (0, _array.validateIndex)(indexI, data.length);\n data = data[indexI];\n }\n\n return data;\n };\n /**\n * Replace a single element in the matrix.\n * @memberof DenseMatrix\n * @param {number[]} index Zero-based index\n * @param {*} value\n * @param {*} [defaultValue] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be left undefined.\n * @return {DenseMatrix} self\n */\n\n\n DenseMatrix.prototype.set = function (index, value, defaultValue) {\n if (!(0, _is.isArray)(index)) {\n throw new TypeError('Array expected');\n }\n\n if (index.length < this._size.length) {\n throw new _DimensionError.DimensionError(index.length, this._size.length, '<');\n }\n\n var i, ii, indexI; // enlarge matrix when needed\n\n var size = index.map(function (i) {\n return i + 1;\n });\n\n _fit(this, size, defaultValue); // traverse over the dimensions\n\n\n var data = this._data;\n\n for (i = 0, ii = index.length - 1; i < ii; i++) {\n indexI = index[i];\n (0, _array.validateIndex)(indexI, data.length);\n data = data[indexI];\n } // set new value\n\n\n indexI = index[index.length - 1];\n (0, _array.validateIndex)(indexI, data.length);\n data[indexI] = value;\n return this;\n };\n /**\n * Get a submatrix of this matrix\n * @memberof DenseMatrix\n * @param {DenseMatrix} matrix\n * @param {Index} index Zero-based index\n * @private\n */\n\n\n function _get(matrix, index) {\n if (!(0, _is.isIndex)(index)) {\n throw new TypeError('Invalid index');\n }\n\n var isScalar = index.isScalar();\n\n if (isScalar) {\n // return a scalar\n return matrix.get(index.min());\n } else {\n // validate dimensions\n var size = index.size();\n\n if (size.length !== matrix._size.length) {\n throw new _DimensionError.DimensionError(size.length, matrix._size.length);\n } // validate if any of the ranges in the index is out of range\n\n\n var min = index.min();\n var max = index.max();\n\n for (var i = 0, ii = matrix._size.length; i < ii; i++) {\n (0, _array.validateIndex)(min[i], matrix._size[i]);\n (0, _array.validateIndex)(max[i], matrix._size[i]);\n } // retrieve submatrix\n // TODO: more efficient when creating an empty matrix and setting _data and _size manually\n\n\n return new DenseMatrix(_getSubmatrix(matrix._data, index, size.length, 0), matrix._datatype);\n }\n }\n /**\n * Recursively get a submatrix of a multi dimensional matrix.\n * Index is not checked for correct number or length of dimensions.\n * @memberof DenseMatrix\n * @param {Array} data\n * @param {Index} index\n * @param {number} dims Total number of dimensions\n * @param {number} dim Current dimension\n * @return {Array} submatrix\n * @private\n */\n\n\n function _getSubmatrix(data, index, dims, dim) {\n var last = dim === dims - 1;\n var range = index.dimension(dim);\n\n if (last) {\n return range.map(function (i) {\n (0, _array.validateIndex)(i, data.length);\n return data[i];\n }).valueOf();\n } else {\n return range.map(function (i) {\n (0, _array.validateIndex)(i, data.length);\n var child = data[i];\n return _getSubmatrix(child, index, dims, dim + 1);\n }).valueOf();\n }\n }\n /**\n * Replace a submatrix in this matrix\n * Indexes are zero-based.\n * @memberof DenseMatrix\n * @param {DenseMatrix} matrix\n * @param {Index} index\n * @param {DenseMatrix | Array | *} submatrix\n * @param {*} defaultValue Default value, filled in on new entries when\n * the matrix is resized.\n * @return {DenseMatrix} matrix\n * @private\n */\n\n\n function _set(matrix, index, submatrix, defaultValue) {\n if (!index || index.isIndex !== true) {\n throw new TypeError('Invalid index');\n } // get index size and check whether the index contains a single value\n\n\n var iSize = index.size();\n var isScalar = index.isScalar(); // calculate the size of the submatrix, and convert it into an Array if needed\n\n var sSize;\n\n if ((0, _is.isMatrix)(submatrix)) {\n sSize = submatrix.size();\n submatrix = submatrix.valueOf();\n } else {\n sSize = (0, _array.arraySize)(submatrix);\n }\n\n if (isScalar) {\n // set a scalar\n // check whether submatrix is a scalar\n if (sSize.length !== 0) {\n throw new TypeError('Scalar expected');\n }\n\n matrix.set(index.min(), submatrix, defaultValue);\n } else {\n // set a submatrix\n // validate dimensions\n if (iSize.length < matrix._size.length) {\n throw new _DimensionError.DimensionError(iSize.length, matrix._size.length, '<');\n }\n\n if (sSize.length < iSize.length) {\n // calculate number of missing outer dimensions\n var i = 0;\n var outer = 0;\n\n while (iSize[i] === 1 && sSize[i] === 1) {\n i++;\n }\n\n while (iSize[i] === 1) {\n outer++;\n i++;\n } // unsqueeze both outer and inner dimensions\n\n\n submatrix = (0, _array.unsqueeze)(submatrix, iSize.length, outer, sSize);\n } // check whether the size of the submatrix matches the index size\n\n\n if (!(0, _object.deepStrictEqual)(iSize, sSize)) {\n throw new _DimensionError.DimensionError(iSize, sSize, '>');\n } // enlarge matrix when needed\n\n\n var size = index.max().map(function (i) {\n return i + 1;\n });\n\n _fit(matrix, size, defaultValue); // insert the sub matrix\n\n\n var dims = iSize.length;\n var dim = 0;\n\n _setSubmatrix(matrix._data, index, submatrix, dims, dim);\n }\n\n return matrix;\n }\n /**\n * Replace a submatrix of a multi dimensional matrix.\n * @memberof DenseMatrix\n * @param {Array} data\n * @param {Index} index\n * @param {Array} submatrix\n * @param {number} dims Total number of dimensions\n * @param {number} dim\n * @private\n */\n\n\n function _setSubmatrix(data, index, submatrix, dims, dim) {\n var last = dim === dims - 1;\n var range = index.dimension(dim);\n\n if (last) {\n range.forEach(function (dataIndex, subIndex) {\n (0, _array.validateIndex)(dataIndex);\n data[dataIndex] = submatrix[subIndex[0]];\n });\n } else {\n range.forEach(function (dataIndex, subIndex) {\n (0, _array.validateIndex)(dataIndex);\n\n _setSubmatrix(data[dataIndex], index, submatrix[subIndex[0]], dims, dim + 1);\n });\n }\n }\n /**\n * Resize the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (resize in place).\n *\n * @memberof DenseMatrix\n * @param {number[] || Matrix} size The new size the matrix should have.\n * @param {*} [defaultValue=0] Default value, filled in on new entries.\n * If not provided, the matrix elements will\n * be filled with zeros.\n * @param {boolean} [copy] Return a resized copy of the matrix\n *\n * @return {Matrix} The resized matrix\n */\n\n\n DenseMatrix.prototype.resize = function (size, defaultValue, copy) {\n // validate arguments\n if (!(0, _is.isCollection)(size)) {\n throw new TypeError('Array or Matrix expected');\n } // SparseMatrix input is always 2d, flatten this into 1d if it's indeed a vector\n\n\n var sizeArray = size.valueOf().map(function (value) {\n return Array.isArray(value) && value.length === 1 ? value[0] : value;\n }); // matrix to resize\n\n var m = copy ? this.clone() : this; // resize matrix\n\n return _resize(m, sizeArray, defaultValue);\n };\n\n function _resize(matrix, size, defaultValue) {\n // check size\n if (size.length === 0) {\n // first value in matrix\n var v = matrix._data; // go deep\n\n while ((0, _is.isArray)(v)) {\n v = v[0];\n }\n\n return v;\n } // resize matrix\n\n\n matrix._size = size.slice(0); // copy the array\n\n matrix._data = (0, _array.resize)(matrix._data, matrix._size, defaultValue); // return matrix\n\n return matrix;\n }\n /**\n * Reshape the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (reshape in place).\n *\n * NOTE: This might be better suited to copy by default, instead of modifying\n * in place. For now, it operates in place to remain consistent with\n * resize().\n *\n * @memberof DenseMatrix\n * @param {number[]} size The new size the matrix should have.\n * @param {boolean} [copy] Return a reshaped copy of the matrix\n *\n * @return {Matrix} The reshaped matrix\n */\n\n\n DenseMatrix.prototype.reshape = function (size, copy) {\n var m = copy ? this.clone() : this;\n m._data = (0, _array.reshape)(m._data, size);\n\n var currentLength = m._size.reduce(function (length, size) {\n return length * size;\n });\n\n m._size = (0, _array.processSizesWildcard)(size, currentLength);\n return m;\n };\n /**\n * Enlarge the matrix when it is smaller than given size.\n * If the matrix is larger or equal sized, nothing is done.\n * @memberof DenseMatrix\n * @param {DenseMatrix} matrix The matrix to be resized\n * @param {number[]} size\n * @param {*} defaultValue Default value, filled in on new entries.\n * @private\n */\n\n\n function _fit(matrix, size, defaultValue) {\n var // copy the array\n newSize = matrix._size.slice(0);\n\n var changed = false; // add dimensions when needed\n\n while (newSize.length < size.length) {\n newSize.push(0);\n changed = true;\n } // enlarge size when needed\n\n\n for (var i = 0, ii = size.length; i < ii; i++) {\n if (size[i] > newSize[i]) {\n newSize[i] = size[i];\n changed = true;\n }\n }\n\n if (changed) {\n // resize only when size is changed\n _resize(matrix, newSize, defaultValue);\n }\n }\n /**\n * Create a clone of the matrix\n * @memberof DenseMatrix\n * @return {DenseMatrix} clone\n */\n\n\n DenseMatrix.prototype.clone = function () {\n var m = new DenseMatrix({\n data: (0, _object.clone)(this._data),\n size: (0, _object.clone)(this._size),\n datatype: this._datatype\n });\n return m;\n };\n /**\n * Retrieve the size of the matrix.\n * @memberof DenseMatrix\n * @returns {number[]} size\n */\n\n\n DenseMatrix.prototype.size = function () {\n return this._size.slice(0); // return a clone of _size\n };\n /**\n * Create a new matrix with the results of the callback function executed on\n * each entry of the matrix.\n * @memberof DenseMatrix\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n *\n * @return {DenseMatrix} matrix\n */\n\n\n DenseMatrix.prototype.map = function (callback) {\n // matrix instance\n var me = this;\n\n var recurse = function recurse(value, index) {\n if ((0, _is.isArray)(value)) {\n return value.map(function (child, i) {\n return recurse(child, index.concat(i));\n });\n } else {\n return callback(value, index, me);\n }\n }; // determine the new datatype when the original matrix has datatype defined\n // TODO: should be done in matrix constructor instead\n\n\n var data = recurse(this._data, []);\n var datatype = this._datatype !== undefined ? (0, _array.getArrayDataType)(data, _is.typeOf) : undefined;\n return new DenseMatrix(data, datatype);\n };\n /**\n * Execute a callback function on each entry of the matrix.\n * @memberof DenseMatrix\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n */\n\n\n DenseMatrix.prototype.forEach = function (callback) {\n // matrix instance\n var me = this;\n\n var recurse = function recurse(value, index) {\n if ((0, _is.isArray)(value)) {\n value.forEach(function (child, i) {\n recurse(child, index.concat(i));\n });\n } else {\n callback(value, index, me);\n }\n };\n\n recurse(this._data, []);\n };\n /**\n * Iterate over the matrix elements\n * @return {Iterable<{ value, index: number[] }>}\n */\n\n\n DenseMatrix.prototype[Symbol.iterator] = /*#__PURE__*/_regenerator.default.mark(function _callee() {\n var recurse;\n return _regenerator.default.wrap(function _callee$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n recurse = /*#__PURE__*/_regenerator.default.mark(function recurse(value, index) {\n var i;\n return _regenerator.default.wrap(function recurse$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (!(0, _is.isArray)(value)) {\n _context.next = 9;\n break;\n }\n\n i = 0;\n\n case 2:\n if (!(i < value.length)) {\n _context.next = 7;\n break;\n }\n\n return _context.delegateYield(recurse(value[i], index.concat(i)), \"t0\", 4);\n\n case 4:\n i++;\n _context.next = 2;\n break;\n\n case 7:\n _context.next = 11;\n break;\n\n case 9:\n _context.next = 11;\n return {\n value: value,\n index: index\n };\n\n case 11:\n case \"end\":\n return _context.stop();\n }\n }\n }, recurse);\n });\n return _context2.delegateYield(recurse(this._data, []), \"t0\", 2);\n\n case 2:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee, this);\n });\n /**\n * Returns an array containing the rows of a 2D matrix\n * @returns {Array}\n */\n\n DenseMatrix.prototype.rows = function () {\n var result = [];\n var s = this.size();\n\n if (s.length !== 2) {\n throw new TypeError('Rows can only be returned for a 2D matrix.');\n }\n\n var data = this._data;\n\n var _iterator = _createForOfIteratorHelper(data),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var row = _step.value;\n result.push(new DenseMatrix([row], this._datatype));\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n return result;\n };\n /**\n * Returns an array containing the columns of a 2D matrix\n * @returns {Array}\n */\n\n\n DenseMatrix.prototype.columns = function () {\n var _this = this;\n\n var result = [];\n var s = this.size();\n\n if (s.length !== 2) {\n throw new TypeError('Rows can only be returned for a 2D matrix.');\n }\n\n var data = this._data;\n\n var _loop = function _loop(i) {\n var col = data.map(function (row) {\n return [row[i]];\n });\n result.push(new DenseMatrix(col, _this._datatype));\n };\n\n for (var i = 0; i < s[1]; i++) {\n _loop(i);\n }\n\n return result;\n };\n /**\n * Create an Array with a copy of the data of the DenseMatrix\n * @memberof DenseMatrix\n * @returns {Array} array\n */\n\n\n DenseMatrix.prototype.toArray = function () {\n return (0, _object.clone)(this._data);\n };\n /**\n * Get the primitive value of the DenseMatrix: a multidimensional array\n * @memberof DenseMatrix\n * @returns {Array} array\n */\n\n\n DenseMatrix.prototype.valueOf = function () {\n return this._data;\n };\n /**\n * Get a string representation of the matrix, with optional formatting options.\n * @memberof DenseMatrix\n * @param {Object | number | Function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @returns {string} str\n */\n\n\n DenseMatrix.prototype.format = function (options) {\n return (0, _string.format)(this._data, options);\n };\n /**\n * Get a string representation of the matrix\n * @memberof DenseMatrix\n * @returns {string} str\n */\n\n\n DenseMatrix.prototype.toString = function () {\n return (0, _string.format)(this._data);\n };\n /**\n * Get a JSON representation of the matrix\n * @memberof DenseMatrix\n * @returns {Object}\n */\n\n\n DenseMatrix.prototype.toJSON = function () {\n return {\n mathjs: 'DenseMatrix',\n data: this._data,\n size: this._size,\n datatype: this._datatype\n };\n };\n /**\n * Get the kth Matrix diagonal.\n *\n * @memberof DenseMatrix\n * @param {number | BigNumber} [k=0] The kth diagonal where the vector will retrieved.\n *\n * @returns {Matrix} The matrix with the diagonal values.\n */\n\n\n DenseMatrix.prototype.diagonal = function (k) {\n // validate k if any\n if (k) {\n // convert BigNumber to a number\n if ((0, _is.isBigNumber)(k)) {\n k = k.toNumber();\n } // is must be an integer\n\n\n if (!(0, _is.isNumber)(k) || !(0, _number.isInteger)(k)) {\n throw new TypeError('The parameter k must be an integer number');\n }\n } else {\n // default value\n k = 0;\n }\n\n var kSuper = k > 0 ? k : 0;\n var kSub = k < 0 ? -k : 0; // rows & columns\n\n var rows = this._size[0];\n var columns = this._size[1]; // number diagonal values\n\n var n = Math.min(rows - kSub, columns - kSuper); // x is a matrix get diagonal from matrix\n\n var data = []; // loop rows\n\n for (var i = 0; i < n; i++) {\n data[i] = this._data[i + kSub][i + kSuper];\n } // create DenseMatrix\n\n\n return new DenseMatrix({\n data: data,\n size: [n],\n datatype: this._datatype\n });\n };\n /**\n * Create a diagonal matrix.\n *\n * @memberof DenseMatrix\n * @param {Array} size The matrix size.\n * @param {number | Matrix | Array } value The values for the diagonal.\n * @param {number | BigNumber} [k=0] The kth diagonal where the vector will be filled in.\n * @param {number} [defaultValue] The default value for non-diagonal\n * @param {string} [datatype] The datatype for the diagonal\n *\n * @returns {DenseMatrix}\n */\n\n\n DenseMatrix.diagonal = function (size, value, k, defaultValue) {\n if (!(0, _is.isArray)(size)) {\n throw new TypeError('Array expected, size parameter');\n }\n\n if (size.length !== 2) {\n throw new Error('Only two dimensions matrix are supported');\n } // map size & validate\n\n\n size = size.map(function (s) {\n // check it is a big number\n if ((0, _is.isBigNumber)(s)) {\n // convert it\n s = s.toNumber();\n } // validate arguments\n\n\n if (!(0, _is.isNumber)(s) || !(0, _number.isInteger)(s) || s < 1) {\n throw new Error('Size values must be positive integers');\n }\n\n return s;\n }); // validate k if any\n\n if (k) {\n // convert BigNumber to a number\n if ((0, _is.isBigNumber)(k)) {\n k = k.toNumber();\n } // is must be an integer\n\n\n if (!(0, _is.isNumber)(k) || !(0, _number.isInteger)(k)) {\n throw new TypeError('The parameter k must be an integer number');\n }\n } else {\n // default value\n k = 0;\n }\n\n var kSuper = k > 0 ? k : 0;\n var kSub = k < 0 ? -k : 0; // rows and columns\n\n var rows = size[0];\n var columns = size[1]; // number of non-zero items\n\n var n = Math.min(rows - kSub, columns - kSuper); // value extraction function\n\n var _value; // check value\n\n\n if ((0, _is.isArray)(value)) {\n // validate array\n if (value.length !== n) {\n // number of values in array must be n\n throw new Error('Invalid value array length');\n } // define function\n\n\n _value = function _value(i) {\n // return value @ i\n return value[i];\n };\n } else if ((0, _is.isMatrix)(value)) {\n // matrix size\n var ms = value.size(); // validate matrix\n\n if (ms.length !== 1 || ms[0] !== n) {\n // number of values in array must be n\n throw new Error('Invalid matrix length');\n } // define function\n\n\n _value = function _value(i) {\n // return value @ i\n return value.get([i]);\n };\n } else {\n // define function\n _value = function _value() {\n // return value\n return value;\n };\n } // discover default value if needed\n\n\n if (!defaultValue) {\n // check first value in array\n defaultValue = (0, _is.isBigNumber)(_value(0)) ? _value(0).mul(0) // trick to create a BigNumber with value zero\n : 0;\n } // empty array\n\n\n var data = []; // check we need to resize array\n\n if (size.length > 0) {\n // resize array\n data = (0, _array.resize)(data, size, defaultValue); // fill diagonal\n\n for (var d = 0; d < n; d++) {\n data[d + kSub][d + kSuper] = _value(d);\n }\n } // create DenseMatrix\n\n\n return new DenseMatrix({\n data: data,\n size: [rows, columns]\n });\n };\n /**\n * Generate a matrix from a JSON object\n * @memberof DenseMatrix\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"DenseMatrix\", data: [], size: []}`,\n * where mathjs is optional\n * @returns {DenseMatrix}\n */\n\n\n DenseMatrix.fromJSON = function (json) {\n return new DenseMatrix(json);\n };\n /**\n * Swap rows i and j in Matrix.\n *\n * @memberof DenseMatrix\n * @param {number} i Matrix row index 1\n * @param {number} j Matrix row index 2\n *\n * @return {Matrix} The matrix reference\n */\n\n\n DenseMatrix.prototype.swapRows = function (i, j) {\n // check index\n if (!(0, _is.isNumber)(i) || !(0, _number.isInteger)(i) || !(0, _is.isNumber)(j) || !(0, _number.isInteger)(j)) {\n throw new Error('Row index must be positive integers');\n } // check dimensions\n\n\n if (this._size.length !== 2) {\n throw new Error('Only two dimensional matrix is supported');\n } // validate index\n\n\n (0, _array.validateIndex)(i, this._size[0]);\n (0, _array.validateIndex)(j, this._size[0]); // swap rows\n\n DenseMatrix._swapRows(i, j, this._data); // return current instance\n\n\n return this;\n };\n /**\n * Swap rows i and j in Dense Matrix data structure.\n *\n * @param {number} i Matrix row index 1\n * @param {number} j Matrix row index 2\n * @param {Array} data Matrix data\n */\n\n\n DenseMatrix._swapRows = function (i, j, data) {\n // swap values i <-> j\n var vi = data[i];\n data[i] = data[j];\n data[j] = vi;\n };\n /**\n * Preprocess data, which can be an Array or DenseMatrix with nested Arrays and\n * Matrices. Replaces all nested Matrices with Arrays\n * @memberof DenseMatrix\n * @param {Array} data\n * @return {Array} data\n */\n\n\n function preprocess(data) {\n for (var i = 0, ii = data.length; i < ii; i++) {\n var elem = data[i];\n\n if ((0, _is.isArray)(elem)) {\n data[i] = preprocess(elem);\n } else if (elem && elem.isMatrix === true) {\n data[i] = preprocess(elem.valueOf());\n }\n }\n\n return data;\n }\n\n return DenseMatrix;\n}, {\n isClass: true\n});\nexports.createDenseMatrixClass = createDenseMatrixClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createFibonacciHeapClass = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'FibonacciHeap';\nvar dependencies = ['smaller', 'larger'];\nvar createFibonacciHeapClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var smaller = _ref.smaller,\n larger = _ref.larger;\n var oneOverLogPhi = 1.0 / Math.log((1.0 + Math.sqrt(5.0)) / 2.0);\n /**\n * Fibonacci Heap implementation, used interally for Matrix math.\n * @class FibonacciHeap\n * @constructor FibonacciHeap\n */\n\n function FibonacciHeap() {\n if (!(this instanceof FibonacciHeap)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n } // initialize fields\n\n\n this._minimum = null;\n this._size = 0;\n }\n /**\n * Attach type information\n */\n\n\n FibonacciHeap.prototype.type = 'FibonacciHeap';\n FibonacciHeap.prototype.isFibonacciHeap = true;\n /**\n * Inserts a new data element into the heap. No heap consolidation is\n * performed at this time, the new node is simply inserted into the root\n * list of this heap. Running time: O(1) actual.\n * @memberof FibonacciHeap\n */\n\n FibonacciHeap.prototype.insert = function (key, value) {\n // create node\n var node = {\n key: key,\n value: value,\n degree: 0\n }; // check we have a node in the minimum\n\n if (this._minimum) {\n // minimum node\n var minimum = this._minimum; // update left & right of node\n\n node.left = minimum;\n node.right = minimum.right;\n minimum.right = node;\n node.right.left = node; // update minimum node in heap if needed\n\n if (smaller(key, minimum.key)) {\n // node has a smaller key, use it as minimum\n this._minimum = node;\n }\n } else {\n // set left & right\n node.left = node;\n node.right = node; // this is the first node\n\n this._minimum = node;\n } // increment number of nodes in heap\n\n\n this._size++; // return node\n\n return node;\n };\n /**\n * Returns the number of nodes in heap. Running time: O(1) actual.\n * @memberof FibonacciHeap\n */\n\n\n FibonacciHeap.prototype.size = function () {\n return this._size;\n };\n /**\n * Removes all elements from this heap.\n * @memberof FibonacciHeap\n */\n\n\n FibonacciHeap.prototype.clear = function () {\n this._minimum = null;\n this._size = 0;\n };\n /**\n * Returns true if the heap is empty, otherwise false.\n * @memberof FibonacciHeap\n */\n\n\n FibonacciHeap.prototype.isEmpty = function () {\n return this._size === 0;\n };\n /**\n * Extracts the node with minimum key from heap. Amortized running\n * time: O(log n).\n * @memberof FibonacciHeap\n */\n\n\n FibonacciHeap.prototype.extractMinimum = function () {\n // node to remove\n var node = this._minimum; // check we have a minimum\n\n if (node === null) {\n return node;\n } // current minimum\n\n\n var minimum = this._minimum; // get number of children\n\n var numberOfChildren = node.degree; // pointer to the first child\n\n var x = node.child; // for each child of node do...\n\n while (numberOfChildren > 0) {\n // store node in right side\n var tempRight = x.right; // remove x from child list\n\n x.left.right = x.right;\n x.right.left = x.left; // add x to root list of heap\n\n x.left = minimum;\n x.right = minimum.right;\n minimum.right = x;\n x.right.left = x; // set Parent[x] to null\n\n x.parent = null;\n x = tempRight;\n numberOfChildren--;\n } // remove node from root list of heap\n\n\n node.left.right = node.right;\n node.right.left = node.left; // update minimum\n\n if (node === node.right) {\n // empty\n minimum = null;\n } else {\n // update minimum\n minimum = node.right; // we need to update the pointer to the root with minimum key\n\n minimum = _findMinimumNode(minimum, this._size);\n } // decrement size of heap\n\n\n this._size--; // update minimum\n\n this._minimum = minimum; // return node\n\n return node;\n };\n /**\n * Removes a node from the heap given the reference to the node. The trees\n * in the heap will be consolidated, if necessary. This operation may fail\n * to remove the correct element if there are nodes with key value -Infinity.\n * Running time: O(log n) amortized.\n * @memberof FibonacciHeap\n */\n\n\n FibonacciHeap.prototype.remove = function (node) {\n // decrease key value\n this._minimum = _decreaseKey(this._minimum, node, -1); // remove the smallest\n\n this.extractMinimum();\n };\n /**\n * Decreases the key value for a heap node, given the new value to take on.\n * The structure of the heap may be changed and will not be consolidated.\n * Running time: O(1) amortized.\n * @memberof FibonacciHeap\n */\n\n\n function _decreaseKey(minimum, node, key) {\n // set node key\n node.key = key; // get parent node\n\n var parent = node.parent;\n\n if (parent && smaller(node.key, parent.key)) {\n // remove node from parent\n _cut(minimum, node, parent); // remove all nodes from parent to the root parent\n\n\n _cascadingCut(minimum, parent);\n } // update minimum node if needed\n\n\n if (smaller(node.key, minimum.key)) {\n minimum = node;\n } // return minimum\n\n\n return minimum;\n }\n /**\n * The reverse of the link operation: removes node from the child list of parent.\n * This method assumes that min is non-null. Running time: O(1).\n * @memberof FibonacciHeap\n */\n\n\n function _cut(minimum, node, parent) {\n // remove node from parent children and decrement Degree[parent]\n node.left.right = node.right;\n node.right.left = node.left;\n parent.degree--; // reset y.child if necessary\n\n if (parent.child === node) {\n parent.child = node.right;\n } // remove child if degree is 0\n\n\n if (parent.degree === 0) {\n parent.child = null;\n } // add node to root list of heap\n\n\n node.left = minimum;\n node.right = minimum.right;\n minimum.right = node;\n node.right.left = node; // set parent[node] to null\n\n node.parent = null; // set mark[node] to false\n\n node.mark = false;\n }\n /**\n * Performs a cascading cut operation. This cuts node from its parent and then\n * does the same for its parent, and so on up the tree.\n * Running time: O(log n); O(1) excluding the recursion.\n * @memberof FibonacciHeap\n */\n\n\n function _cascadingCut(minimum, node) {\n // store parent node\n var parent = node.parent; // if there's a parent...\n\n if (!parent) {\n return;\n } // if node is unmarked, set it marked\n\n\n if (!node.mark) {\n node.mark = true;\n } else {\n // it's marked, cut it from parent\n _cut(minimum, node, parent); // cut its parent as well\n\n\n _cascadingCut(parent);\n }\n }\n /**\n * Make the first node a child of the second one. Running time: O(1) actual.\n * @memberof FibonacciHeap\n */\n\n\n var _linkNodes = function _linkNodes(node, parent) {\n // remove node from root list of heap\n node.left.right = node.right;\n node.right.left = node.left; // make node a Child of parent\n\n node.parent = parent;\n\n if (!parent.child) {\n parent.child = node;\n node.right = node;\n node.left = node;\n } else {\n node.left = parent.child;\n node.right = parent.child.right;\n parent.child.right = node;\n node.right.left = node;\n } // increase degree[parent]\n\n\n parent.degree++; // set mark[node] false\n\n node.mark = false;\n };\n\n function _findMinimumNode(minimum, size) {\n // to find trees of the same degree efficiently we use an array of length O(log n) in which we keep a pointer to one root of each degree\n var arraySize = Math.floor(Math.log(size) * oneOverLogPhi) + 1; // create list with initial capacity\n\n var array = new Array(arraySize); // find the number of root nodes.\n\n var numRoots = 0;\n var x = minimum;\n\n if (x) {\n numRoots++;\n x = x.right;\n\n while (x !== minimum) {\n numRoots++;\n x = x.right;\n }\n } // vars\n\n\n var y; // For each node in root list do...\n\n while (numRoots > 0) {\n // access this node's degree..\n var d = x.degree; // get next node\n\n var next = x.right; // check if there is a node already in array with the same degree\n\n while (true) {\n // get node with the same degree is any\n y = array[d];\n\n if (!y) {\n break;\n } // make one node with the same degree a child of the other, do this based on the key value.\n\n\n if (larger(x.key, y.key)) {\n var temp = y;\n y = x;\n x = temp;\n } // make y a child of x\n\n\n _linkNodes(y, x); // we have handled this degree, go to next one.\n\n\n array[d] = null;\n d++;\n } // save this node for later when we might encounter another of the same degree.\n\n\n array[d] = x; // move forward through list.\n\n x = next;\n numRoots--;\n } // Set min to null (effectively losing the root list) and reconstruct the root list from the array entries in array[].\n\n\n minimum = null; // loop nodes in array\n\n for (var i = 0; i < arraySize; i++) {\n // get current node\n y = array[i];\n\n if (!y) {\n continue;\n } // check if we have a linked list\n\n\n if (minimum) {\n // First remove node from root list.\n y.left.right = y.right;\n y.right.left = y.left; // now add to root list, again.\n\n y.left = minimum;\n y.right = minimum.right;\n minimum.right = y;\n y.right.left = y; // check if this is a new min.\n\n if (smaller(y.key, minimum.key)) {\n minimum = y;\n }\n } else {\n minimum = y;\n }\n }\n\n return minimum;\n }\n\n return FibonacciHeap;\n}, {\n isClass: true\n});\nexports.createFibonacciHeapClass = createFibonacciHeapClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createImmutableDenseMatrixClass = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'ImmutableDenseMatrix';\nvar dependencies = ['smaller', 'DenseMatrix'];\nvar createImmutableDenseMatrixClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var smaller = _ref.smaller,\n DenseMatrix = _ref.DenseMatrix;\n\n function ImmutableDenseMatrix(data, datatype) {\n if (!(this instanceof ImmutableDenseMatrix)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n if (datatype && !(0, _is.isString)(datatype)) {\n throw new Error('Invalid datatype: ' + datatype);\n }\n\n if ((0, _is.isMatrix)(data) || (0, _is.isArray)(data)) {\n // use DenseMatrix implementation\n var matrix = new DenseMatrix(data, datatype); // internal structures\n\n this._data = matrix._data;\n this._size = matrix._size;\n this._datatype = matrix._datatype;\n this._min = null;\n this._max = null;\n } else if (data && (0, _is.isArray)(data.data) && (0, _is.isArray)(data.size)) {\n // initialize fields from JSON representation\n this._data = data.data;\n this._size = data.size;\n this._datatype = data.datatype;\n this._min = typeof data.min !== 'undefined' ? data.min : null;\n this._max = typeof data.max !== 'undefined' ? data.max : null;\n } else if (data) {\n // unsupported type\n throw new TypeError('Unsupported type of data (' + (0, _is.typeOf)(data) + ')');\n } else {\n // nothing provided\n this._data = [];\n this._size = [0];\n this._datatype = datatype;\n this._min = null;\n this._max = null;\n }\n }\n\n ImmutableDenseMatrix.prototype = new DenseMatrix();\n /**\n * Attach type information\n */\n\n ImmutableDenseMatrix.prototype.type = 'ImmutableDenseMatrix';\n ImmutableDenseMatrix.prototype.isImmutableDenseMatrix = true;\n /**\n * Get a subset of the matrix, or replace a subset of the matrix.\n *\n * Usage:\n * const subset = matrix.subset(index) // retrieve subset\n * const value = matrix.subset(index, replacement) // replace subset\n *\n * @param {Index} index\n * @param {Array | ImmutableDenseMatrix | *} [replacement]\n * @param {*} [defaultValue=0] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be filled with zeros.\n */\n\n ImmutableDenseMatrix.prototype.subset = function (index) {\n switch (arguments.length) {\n case 1:\n {\n // use base implementation\n var m = DenseMatrix.prototype.subset.call(this, index); // check result is a matrix\n\n if ((0, _is.isMatrix)(m)) {\n // return immutable matrix\n return new ImmutableDenseMatrix({\n data: m._data,\n size: m._size,\n datatype: m._datatype\n });\n }\n\n return m;\n }\n // intentional fall through\n\n case 2:\n case 3:\n throw new Error('Cannot invoke set subset on an Immutable Matrix instance');\n\n default:\n throw new SyntaxError('Wrong number of arguments');\n }\n };\n /**\n * Replace a single element in the matrix.\n * @param {Number[]} index Zero-based index\n * @param {*} value\n * @param {*} [defaultValue] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be left undefined.\n * @return {ImmutableDenseMatrix} self\n */\n\n\n ImmutableDenseMatrix.prototype.set = function () {\n throw new Error('Cannot invoke set on an Immutable Matrix instance');\n };\n /**\n * Resize the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (resize in place).\n *\n * @param {Number[]} size The new size the matrix should have.\n * @param {*} [defaultValue=0] Default value, filled in on new entries.\n * If not provided, the matrix elements will\n * be filled with zeros.\n * @param {boolean} [copy] Return a resized copy of the matrix\n *\n * @return {Matrix} The resized matrix\n */\n\n\n ImmutableDenseMatrix.prototype.resize = function () {\n throw new Error('Cannot invoke resize on an Immutable Matrix instance');\n };\n /**\n * Disallows reshaping in favor of immutability.\n *\n * @throws {Error} Operation not allowed\n */\n\n\n ImmutableDenseMatrix.prototype.reshape = function () {\n throw new Error('Cannot invoke reshape on an Immutable Matrix instance');\n };\n /**\n * Create a clone of the matrix\n * @return {ImmutableDenseMatrix} clone\n */\n\n\n ImmutableDenseMatrix.prototype.clone = function () {\n return new ImmutableDenseMatrix({\n data: (0, _object.clone)(this._data),\n size: (0, _object.clone)(this._size),\n datatype: this._datatype\n });\n };\n /**\n * Get a JSON representation of the matrix\n * @returns {Object}\n */\n\n\n ImmutableDenseMatrix.prototype.toJSON = function () {\n return {\n mathjs: 'ImmutableDenseMatrix',\n data: this._data,\n size: this._size,\n datatype: this._datatype\n };\n };\n /**\n * Generate a matrix from a JSON object\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"ImmutableDenseMatrix\", data: [], size: []}`,\n * where mathjs is optional\n * @returns {ImmutableDenseMatrix}\n */\n\n\n ImmutableDenseMatrix.fromJSON = function (json) {\n return new ImmutableDenseMatrix(json);\n };\n /**\n * Swap rows i and j in Matrix.\n *\n * @param {Number} i Matrix row index 1\n * @param {Number} j Matrix row index 2\n *\n * @return {Matrix} The matrix reference\n */\n\n\n ImmutableDenseMatrix.prototype.swapRows = function () {\n throw new Error('Cannot invoke swapRows on an Immutable Matrix instance');\n };\n /**\n * Calculate the minimum value in the set\n * @return {Number | undefined} min\n */\n\n\n ImmutableDenseMatrix.prototype.min = function () {\n // check min has been calculated before\n if (this._min === null) {\n // minimum\n var m = null; // compute min\n\n this.forEach(function (v) {\n if (m === null || smaller(v, m)) {\n m = v;\n }\n });\n this._min = m !== null ? m : undefined;\n }\n\n return this._min;\n };\n /**\n * Calculate the maximum value in the set\n * @return {Number | undefined} max\n */\n\n\n ImmutableDenseMatrix.prototype.max = function () {\n // check max has been calculated before\n if (this._max === null) {\n // maximum\n var m = null; // compute max\n\n this.forEach(function (v) {\n if (m === null || smaller(m, v)) {\n m = v;\n }\n });\n this._max = m !== null ? m : undefined;\n }\n\n return this._max;\n };\n\n return ImmutableDenseMatrix;\n}, {\n isClass: true\n});\nexports.createImmutableDenseMatrixClass = createImmutableDenseMatrixClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMatrixClass = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'Matrix';\nvar dependencies = [];\nvar createMatrixClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function () {\n /**\n * @constructor Matrix\n *\n * A Matrix is a wrapper around an Array. A matrix can hold a multi dimensional\n * array. A matrix can be constructed as:\n *\n * let matrix = math.matrix(data)\n *\n * Matrix contains the functions to resize, get and set values, get the size,\n * clone the matrix and to convert the matrix to a vector, array, or scalar.\n * Furthermore, one can iterate over the matrix using map and forEach.\n * The internal Array of the Matrix can be accessed using the function valueOf.\n *\n * Example usage:\n *\n * let matrix = math.matrix([[1, 2], [3, 4]])\n * matix.size() // [2, 2]\n * matrix.resize([3, 2], 5)\n * matrix.valueOf() // [[1, 2], [3, 4], [5, 5]]\n * matrix.subset([1,2]) // 3 (indexes are zero-based)\n *\n */\n function Matrix() {\n if (!(this instanceof Matrix)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n }\n /**\n * Attach type information\n */\n\n\n Matrix.prototype.type = 'Matrix';\n Matrix.prototype.isMatrix = true;\n /**\n * Get the storage format used by the matrix.\n *\n * Usage:\n * const format = matrix.storage() // retrieve storage format\n *\n * @return {string} The storage format.\n */\n\n Matrix.prototype.storage = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke storage on a Matrix interface');\n };\n /**\n * Get the datatype of the data stored in the matrix.\n *\n * Usage:\n * const format = matrix.datatype() // retrieve matrix datatype\n *\n * @return {string} The datatype.\n */\n\n\n Matrix.prototype.datatype = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke datatype on a Matrix interface');\n };\n /**\n * Create a new Matrix With the type of the current matrix instance\n * @param {Array | Object} data\n * @param {string} [datatype]\n */\n\n\n Matrix.prototype.create = function (data, datatype) {\n throw new Error('Cannot invoke create on a Matrix interface');\n };\n /**\n * Get a subset of the matrix, or replace a subset of the matrix.\n *\n * Usage:\n * const subset = matrix.subset(index) // retrieve subset\n * const value = matrix.subset(index, replacement) // replace subset\n *\n * @param {Index} index\n * @param {Array | Matrix | *} [replacement]\n * @param {*} [defaultValue=0] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be filled with zeros.\n */\n\n\n Matrix.prototype.subset = function (index, replacement, defaultValue) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke subset on a Matrix interface');\n };\n /**\n * Get a single element from the matrix.\n * @param {number[]} index Zero-based index\n * @return {*} value\n */\n\n\n Matrix.prototype.get = function (index) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke get on a Matrix interface');\n };\n /**\n * Replace a single element in the matrix.\n * @param {number[]} index Zero-based index\n * @param {*} value\n * @param {*} [defaultValue] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be left undefined.\n * @return {Matrix} self\n */\n\n\n Matrix.prototype.set = function (index, value, defaultValue) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke set on a Matrix interface');\n };\n /**\n * Resize the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (resize in place).\n *\n * @param {number[]} size The new size the matrix should have.\n * @param {*} [defaultValue=0] Default value, filled in on new entries.\n * If not provided, the matrix elements will\n * be filled with zeros.\n * @param {boolean} [copy] Return a resized copy of the matrix\n *\n * @return {Matrix} The resized matrix\n */\n\n\n Matrix.prototype.resize = function (size, defaultValue) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke resize on a Matrix interface');\n };\n /**\n * Reshape the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (reshape in place).\n *\n * @param {number[]} size The new size the matrix should have.\n * @param {boolean} [copy] Return a reshaped copy of the matrix\n *\n * @return {Matrix} The reshaped matrix\n */\n\n\n Matrix.prototype.reshape = function (size, defaultValue) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke reshape on a Matrix interface');\n };\n /**\n * Create a clone of the matrix\n * @return {Matrix} clone\n */\n\n\n Matrix.prototype.clone = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke clone on a Matrix interface');\n };\n /**\n * Retrieve the size of the matrix.\n * @returns {number[]} size\n */\n\n\n Matrix.prototype.size = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke size on a Matrix interface');\n };\n /**\n * Create a new matrix with the results of the callback function executed on\n * each entry of the matrix.\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n * @param {boolean} [skipZeros] Invoke callback function for non-zero values only.\n *\n * @return {Matrix} matrix\n */\n\n\n Matrix.prototype.map = function (callback, skipZeros) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke map on a Matrix interface');\n };\n /**\n * Execute a callback function on each entry of the matrix.\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n */\n\n\n Matrix.prototype.forEach = function (callback) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke forEach on a Matrix interface');\n };\n /**\n * Iterate over the matrix elements\n * @return {Iterable<{ value, index: number[] }>}\n */\n\n\n Matrix.prototype[Symbol.iterator] = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot iterate a Matrix interface');\n };\n /**\n * Create an Array with a copy of the data of the Matrix\n * @returns {Array} array\n */\n\n\n Matrix.prototype.toArray = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke toArray on a Matrix interface');\n };\n /**\n * Get the primitive value of the Matrix: a multidimensional array\n * @returns {Array} array\n */\n\n\n Matrix.prototype.valueOf = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke valueOf on a Matrix interface');\n };\n /**\n * Get a string representation of the matrix, with optional formatting options.\n * @param {Object | number | Function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @returns {string} str\n */\n\n\n Matrix.prototype.format = function (options) {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke format on a Matrix interface');\n };\n /**\n * Get a string representation of the matrix\n * @returns {string} str\n */\n\n\n Matrix.prototype.toString = function () {\n // must be implemented by each of the Matrix implementations\n throw new Error('Cannot invoke toString on a Matrix interface');\n };\n\n return Matrix;\n}, {\n isClass: true\n});\nexports.createMatrixClass = createMatrixClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIndexClass = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'Index';\nvar dependencies = ['ImmutableDenseMatrix'];\nvar createIndexClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var ImmutableDenseMatrix = _ref.ImmutableDenseMatrix;\n\n /**\n * Create an index. An Index can store ranges and sets for multiple dimensions.\n * Matrix.get, Matrix.set, and math.subset accept an Index as input.\n *\n * Usage:\n * const index = new Index(range1, range2, matrix1, array1, ...)\n *\n * Where each parameter can be any of:\n * A number\n * A string (containing a name of an object property)\n * An instance of Range\n * An Array with the Set values\n * A Matrix with the Set values\n *\n * The parameters start, end, and step must be integer numbers.\n *\n * @class Index\n * @Constructor Index\n * @param {...*} ranges\n */\n function Index(ranges) {\n if (!(this instanceof Index)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n this._dimensions = [];\n this._isScalar = true;\n\n for (var i = 0, ii = arguments.length; i < ii; i++) {\n var arg = arguments[i];\n\n if ((0, _is.isRange)(arg)) {\n this._dimensions.push(arg);\n\n this._isScalar = false;\n } else if (Array.isArray(arg) || (0, _is.isMatrix)(arg)) {\n // create matrix\n var m = _createImmutableMatrix(arg.valueOf());\n\n this._dimensions.push(m); // size\n\n\n var size = m.size(); // scalar\n\n if (size.length !== 1 || size[0] !== 1) {\n this._isScalar = false;\n }\n } else if (typeof arg === 'number') {\n this._dimensions.push(_createImmutableMatrix([arg]));\n } else if (typeof arg === 'string') {\n // object property (arguments.count should be 1)\n this._dimensions.push(arg);\n } else {\n throw new TypeError('Dimension must be an Array, Matrix, number, string, or Range');\n } // TODO: implement support for wildcard '*'\n\n }\n }\n /**\n * Attach type information\n */\n\n\n Index.prototype.type = 'Index';\n Index.prototype.isIndex = true;\n\n function _createImmutableMatrix(arg) {\n // loop array elements\n for (var i = 0, l = arg.length; i < l; i++) {\n if (typeof arg[i] !== 'number' || !(0, _number.isInteger)(arg[i])) {\n throw new TypeError('Index parameters must be positive integer numbers');\n }\n } // create matrix\n\n\n return new ImmutableDenseMatrix(arg);\n }\n /**\n * Create a clone of the index\n * @memberof Index\n * @return {Index} clone\n */\n\n\n Index.prototype.clone = function () {\n var index = new Index();\n index._dimensions = (0, _object.clone)(this._dimensions);\n index._isScalar = this._isScalar;\n return index;\n };\n /**\n * Create an index from an array with ranges/numbers\n * @memberof Index\n * @param {Array.} ranges\n * @return {Index} index\n * @private\n */\n\n\n Index.create = function (ranges) {\n var index = new Index();\n Index.apply(index, ranges);\n return index;\n };\n /**\n * Retrieve the size of the index, the number of elements for each dimension.\n * @memberof Index\n * @returns {number[]} size\n */\n\n\n Index.prototype.size = function () {\n var size = [];\n\n for (var i = 0, ii = this._dimensions.length; i < ii; i++) {\n var d = this._dimensions[i];\n size[i] = typeof d === 'string' ? 1 : d.size()[0];\n }\n\n return size;\n };\n /**\n * Get the maximum value for each of the indexes ranges.\n * @memberof Index\n * @returns {number[]} max\n */\n\n\n Index.prototype.max = function () {\n var values = [];\n\n for (var i = 0, ii = this._dimensions.length; i < ii; i++) {\n var range = this._dimensions[i];\n values[i] = typeof range === 'string' ? range : range.max();\n }\n\n return values;\n };\n /**\n * Get the minimum value for each of the indexes ranges.\n * @memberof Index\n * @returns {number[]} min\n */\n\n\n Index.prototype.min = function () {\n var values = [];\n\n for (var i = 0, ii = this._dimensions.length; i < ii; i++) {\n var range = this._dimensions[i];\n values[i] = typeof range === 'string' ? range : range.min();\n }\n\n return values;\n };\n /**\n * Loop over each of the ranges of the index\n * @memberof Index\n * @param {Function} callback Called for each range with a Range as first\n * argument, the dimension as second, and the\n * index object as third.\n */\n\n\n Index.prototype.forEach = function (callback) {\n for (var i = 0, ii = this._dimensions.length; i < ii; i++) {\n callback(this._dimensions[i], i, this);\n }\n };\n /**\n * Retrieve the dimension for the given index\n * @memberof Index\n * @param {Number} dim Number of the dimension\n * @returns {Range | null} range\n */\n\n\n Index.prototype.dimension = function (dim) {\n return this._dimensions[dim] || null;\n };\n /**\n * Test whether this index contains an object property\n * @returns {boolean} Returns true if the index is an object property\n */\n\n\n Index.prototype.isObjectProperty = function () {\n return this._dimensions.length === 1 && typeof this._dimensions[0] === 'string';\n };\n /**\n * Returns the object property name when the Index holds a single object property,\n * else returns null\n * @returns {string | null}\n */\n\n\n Index.prototype.getObjectProperty = function () {\n return this.isObjectProperty() ? this._dimensions[0] : null;\n };\n /**\n * Test whether this index contains only a single value.\n *\n * This is the case when the index is created with only scalar values as ranges,\n * not for ranges resolving into a single value.\n * @memberof Index\n * @return {boolean} isScalar\n */\n\n\n Index.prototype.isScalar = function () {\n return this._isScalar;\n };\n /**\n * Expand the Index into an array.\n * For example new Index([0,3], [2,7]) returns [[0,1,2], [2,3,4,5,6]]\n * @memberof Index\n * @returns {Array} array\n */\n\n\n Index.prototype.toArray = function () {\n var array = [];\n\n for (var i = 0, ii = this._dimensions.length; i < ii; i++) {\n var dimension = this._dimensions[i];\n array.push(typeof dimension === 'string' ? dimension : dimension.toArray());\n }\n\n return array;\n };\n /**\n * Get the primitive value of the Index, a two dimensional array.\n * Equivalent to Index.toArray().\n * @memberof Index\n * @returns {Array} array\n */\n\n\n Index.prototype.valueOf = Index.prototype.toArray;\n /**\n * Get the string representation of the index, for example '[2:6]' or '[0:2:10, 4:7, [1,2,3]]'\n * @memberof Index\n * @returns {String} str\n */\n\n Index.prototype.toString = function () {\n var strings = [];\n\n for (var i = 0, ii = this._dimensions.length; i < ii; i++) {\n var dimension = this._dimensions[i];\n\n if (typeof dimension === 'string') {\n strings.push(JSON.stringify(dimension));\n } else {\n strings.push(dimension.toString());\n }\n }\n\n return '[' + strings.join(', ') + ']';\n };\n /**\n * Get a JSON representation of the Index\n * @memberof Index\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"Index\", \"ranges\": [{\"mathjs\": \"Range\", start: 0, end: 10, step:1}, ...]}`\n */\n\n\n Index.prototype.toJSON = function () {\n return {\n mathjs: 'Index',\n dimensions: this._dimensions\n };\n };\n /**\n * Instantiate an Index from a JSON object\n * @memberof Index\n * @param {Object} json A JSON object structured as:\n * `{\"mathjs\": \"Index\", \"dimensions\": [{\"mathjs\": \"Range\", start: 0, end: 10, step:1}, ...]}`\n * @return {Index}\n */\n\n\n Index.fromJSON = function (json) {\n return Index.create(json.dimensions);\n };\n\n return Index;\n}, {\n isClass: true\n});\nexports.createIndexClass = createIndexClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createRangeClass = void 0;\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'Range';\nvar dependencies = [];\nvar createRangeClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function () {\n /**\n * Create a range. A range has a start, step, and end, and contains functions\n * to iterate over the range.\n *\n * A range can be constructed as:\n *\n * const range = new Range(start, end)\n * const range = new Range(start, end, step)\n *\n * To get the result of the range:\n * range.forEach(function (x) {\n * console.log(x)\n * })\n * range.map(function (x) {\n * return math.sin(x)\n * })\n * range.toArray()\n *\n * Example usage:\n *\n * const c = new Range(2, 6) // 2:1:5\n * c.toArray() // [2, 3, 4, 5]\n * const d = new Range(2, -3, -1) // 2:-1:-2\n * d.toArray() // [2, 1, 0, -1, -2]\n *\n * @class Range\n * @constructor Range\n * @param {number} start included lower bound\n * @param {number} end excluded upper bound\n * @param {number} [step] step size, default value is 1\n */\n function Range(start, end, step) {\n if (!(this instanceof Range)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n var hasStart = start !== null && start !== undefined;\n var hasEnd = end !== null && end !== undefined;\n var hasStep = step !== null && step !== undefined;\n\n if (hasStart) {\n if ((0, _is.isBigNumber)(start)) {\n start = start.toNumber();\n } else if (typeof start !== 'number') {\n throw new TypeError('Parameter start must be a number');\n }\n }\n\n if (hasEnd) {\n if ((0, _is.isBigNumber)(end)) {\n end = end.toNumber();\n } else if (typeof end !== 'number') {\n throw new TypeError('Parameter end must be a number');\n }\n }\n\n if (hasStep) {\n if ((0, _is.isBigNumber)(step)) {\n step = step.toNumber();\n } else if (typeof step !== 'number') {\n throw new TypeError('Parameter step must be a number');\n }\n }\n\n this.start = hasStart ? parseFloat(start) : 0;\n this.end = hasEnd ? parseFloat(end) : 0;\n this.step = hasStep ? parseFloat(step) : 1;\n }\n /**\n * Attach type information\n */\n\n\n Range.prototype.type = 'Range';\n Range.prototype.isRange = true;\n /**\n * Parse a string into a range,\n * The string contains the start, optional step, and end, separated by a colon.\n * If the string does not contain a valid range, null is returned.\n * For example str='0:2:11'.\n * @memberof Range\n * @param {string} str\n * @return {Range | null} range\n */\n\n Range.parse = function (str) {\n if (typeof str !== 'string') {\n return null;\n }\n\n var args = str.split(':');\n var nums = args.map(function (arg) {\n return parseFloat(arg);\n });\n var invalid = nums.some(function (num) {\n return isNaN(num);\n });\n\n if (invalid) {\n return null;\n }\n\n switch (nums.length) {\n case 2:\n return new Range(nums[0], nums[1]);\n\n case 3:\n return new Range(nums[0], nums[2], nums[1]);\n\n default:\n return null;\n }\n };\n /**\n * Create a clone of the range\n * @return {Range} clone\n */\n\n\n Range.prototype.clone = function () {\n return new Range(this.start, this.end, this.step);\n };\n /**\n * Retrieve the size of the range.\n * Returns an array containing one number, the number of elements in the range.\n * @memberof Range\n * @returns {number[]} size\n */\n\n\n Range.prototype.size = function () {\n var len = 0;\n var start = this.start;\n var step = this.step;\n var end = this.end;\n var diff = end - start;\n\n if ((0, _number.sign)(step) === (0, _number.sign)(diff)) {\n len = Math.ceil(diff / step);\n } else if (diff === 0) {\n len = 0;\n }\n\n if (isNaN(len)) {\n len = 0;\n }\n\n return [len];\n };\n /**\n * Calculate the minimum value in the range\n * @memberof Range\n * @return {number | undefined} min\n */\n\n\n Range.prototype.min = function () {\n var size = this.size()[0];\n\n if (size > 0) {\n if (this.step > 0) {\n // positive step\n return this.start;\n } else {\n // negative step\n return this.start + (size - 1) * this.step;\n }\n } else {\n return undefined;\n }\n };\n /**\n * Calculate the maximum value in the range\n * @memberof Range\n * @return {number | undefined} max\n */\n\n\n Range.prototype.max = function () {\n var size = this.size()[0];\n\n if (size > 0) {\n if (this.step > 0) {\n // positive step\n return this.start + (size - 1) * this.step;\n } else {\n // negative step\n return this.start;\n }\n } else {\n return undefined;\n }\n };\n /**\n * Execute a callback function for each value in the range.\n * @memberof Range\n * @param {function} callback The callback method is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Range being traversed.\n */\n\n\n Range.prototype.forEach = function (callback) {\n var x = this.start;\n var step = this.step;\n var end = this.end;\n var i = 0;\n\n if (step > 0) {\n while (x < end) {\n callback(x, [i], this);\n x += step;\n i++;\n }\n } else if (step < 0) {\n while (x > end) {\n callback(x, [i], this);\n x += step;\n i++;\n }\n }\n };\n /**\n * Execute a callback function for each value in the Range, and return the\n * results as an array\n * @memberof Range\n * @param {function} callback The callback method is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n * @returns {Array} array\n */\n\n\n Range.prototype.map = function (callback) {\n var array = [];\n this.forEach(function (value, index, obj) {\n array[index[0]] = callback(value, index, obj);\n });\n return array;\n };\n /**\n * Create an Array with a copy of the Ranges data\n * @memberof Range\n * @returns {Array} array\n */\n\n\n Range.prototype.toArray = function () {\n var array = [];\n this.forEach(function (value, index) {\n array[index[0]] = value;\n });\n return array;\n };\n /**\n * Get the primitive value of the Range, a one dimensional array\n * @memberof Range\n * @returns {Array} array\n */\n\n\n Range.prototype.valueOf = function () {\n // TODO: implement a caching mechanism for range.valueOf()\n return this.toArray();\n };\n /**\n * Get a string representation of the range, with optional formatting options.\n * Output is formatted as 'start:step:end', for example '2:6' or '0:0.2:11'\n * @memberof Range\n * @param {Object | number | function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @returns {string} str\n */\n\n\n Range.prototype.format = function (options) {\n var str = (0, _number.format)(this.start, options);\n\n if (this.step !== 1) {\n str += ':' + (0, _number.format)(this.step, options);\n }\n\n str += ':' + (0, _number.format)(this.end, options);\n return str;\n };\n /**\n * Get a string representation of the range.\n * @memberof Range\n * @returns {string}\n */\n\n\n Range.prototype.toString = function () {\n return this.format();\n };\n /**\n * Get a JSON representation of the range\n * @memberof Range\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"Range\", \"start\": 2, \"end\": 4, \"step\": 1}`\n */\n\n\n Range.prototype.toJSON = function () {\n return {\n mathjs: 'Range',\n start: this.start,\n end: this.end,\n step: this.step\n };\n };\n /**\n * Instantiate a Range from a JSON object\n * @memberof Range\n * @param {Object} json A JSON object structured as:\n * `{\"mathjs\": \"Range\", \"start\": 2, \"end\": 4, \"step\": 1}`\n * @return {Range}\n */\n\n\n Range.fromJSON = function (json) {\n return new Range(json.start, json.end, json.step);\n };\n\n return Range;\n}, {\n isClass: true\n});\nexports.createRangeClass = createRangeClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSpaClass = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'Spa';\nvar dependencies = ['addScalar', 'equalScalar', 'FibonacciHeap'];\nvar createSpaClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var addScalar = _ref.addScalar,\n equalScalar = _ref.equalScalar,\n FibonacciHeap = _ref.FibonacciHeap;\n\n /**\n * An ordered Sparse Accumulator is a representation for a sparse vector that includes a dense array\n * of the vector elements and an ordered list of non-zero elements.\n */\n function Spa() {\n if (!(this instanceof Spa)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n } // allocate vector, TODO use typed arrays\n\n\n this._values = [];\n this._heap = new FibonacciHeap();\n }\n /**\n * Attach type information\n */\n\n\n Spa.prototype.type = 'Spa';\n Spa.prototype.isSpa = true;\n /**\n * Set the value for index i.\n *\n * @param {number} i The index\n * @param {number | BigNumber | Complex} The value at index i\n */\n\n Spa.prototype.set = function (i, v) {\n // check we have a value @ i\n if (!this._values[i]) {\n // insert in heap\n var node = this._heap.insert(i, v); // set the value @ i\n\n\n this._values[i] = node;\n } else {\n // update the value @ i\n this._values[i].value = v;\n }\n };\n\n Spa.prototype.get = function (i) {\n var node = this._values[i];\n\n if (node) {\n return node.value;\n }\n\n return 0;\n };\n\n Spa.prototype.accumulate = function (i, v) {\n // node @ i\n var node = this._values[i];\n\n if (!node) {\n // insert in heap\n node = this._heap.insert(i, v); // initialize value\n\n this._values[i] = node;\n } else {\n // accumulate value\n node.value = addScalar(node.value, v);\n }\n };\n\n Spa.prototype.forEach = function (from, to, callback) {\n // references\n var heap = this._heap;\n var values = this._values; // nodes\n\n var nodes = []; // node with minimum key, save it\n\n var node = heap.extractMinimum();\n\n if (node) {\n nodes.push(node);\n } // extract nodes from heap (ordered)\n\n\n while (node && node.key <= to) {\n // check it is in range\n if (node.key >= from) {\n // check value is not zero\n if (!equalScalar(node.value, 0)) {\n // invoke callback\n callback(node.key, node.value, this);\n }\n } // extract next node, save it\n\n\n node = heap.extractMinimum();\n\n if (node) {\n nodes.push(node);\n }\n } // reinsert all nodes in heap\n\n\n for (var i = 0; i < nodes.length; i++) {\n // current node\n var n = nodes[i]; // insert node in heap\n\n node = heap.insert(n.key, n.value); // update values\n\n values[node.key] = node;\n }\n };\n\n Spa.prototype.swap = function (i, j) {\n // node @ i and j\n var nodei = this._values[i];\n var nodej = this._values[j]; // check we need to insert indeces\n\n if (!nodei && nodej) {\n // insert in heap\n nodei = this._heap.insert(i, nodej.value); // remove from heap\n\n this._heap.remove(nodej); // set values\n\n\n this._values[i] = nodei;\n this._values[j] = undefined;\n } else if (nodei && !nodej) {\n // insert in heap\n nodej = this._heap.insert(j, nodei.value); // remove from heap\n\n this._heap.remove(nodei); // set values\n\n\n this._values[j] = nodej;\n this._values[i] = undefined;\n } else if (nodei && nodej) {\n // swap values\n var v = nodei.value;\n nodei.value = nodej.value;\n nodej.value = v;\n }\n };\n\n return Spa;\n}, {\n isClass: true\n});\nexports.createSpaClass = createSpaClass;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSparseMatrixClass = void 0;\n\nvar _regenerator = _interopRequireDefault(require(\"@babel/runtime/regenerator\"));\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _number = require(\"../../utils/number.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _array = require(\"../../utils/array.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _DimensionError = require(\"../../error/DimensionError.js\");\n\nvar name = 'SparseMatrix';\nvar dependencies = ['typed', 'equalScalar', 'Matrix'];\nvar createSparseMatrixClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n equalScalar = _ref.equalScalar,\n Matrix = _ref.Matrix;\n\n /**\n * Sparse Matrix implementation. This type implements\n * a [Compressed Column Storage](https://en.wikipedia.org/wiki/Sparse_matrix#Compressed_sparse_column_(CSC_or_CCS))\n * format for two-dimensional sparse matrices.\n * @class SparseMatrix\n */\n function SparseMatrix(data, datatype) {\n if (!(this instanceof SparseMatrix)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n if (datatype && !(0, _is.isString)(datatype)) {\n throw new Error('Invalid datatype: ' + datatype);\n }\n\n if ((0, _is.isMatrix)(data)) {\n // create from matrix\n _createFromMatrix(this, data, datatype);\n } else if (data && (0, _is.isArray)(data.index) && (0, _is.isArray)(data.ptr) && (0, _is.isArray)(data.size)) {\n // initialize fields\n this._values = data.values;\n this._index = data.index;\n this._ptr = data.ptr;\n this._size = data.size;\n this._datatype = datatype || data.datatype;\n } else if ((0, _is.isArray)(data)) {\n // create from array\n _createFromArray(this, data, datatype);\n } else if (data) {\n // unsupported type\n throw new TypeError('Unsupported type of data (' + (0, _is.typeOf)(data) + ')');\n } else {\n // nothing provided\n this._values = [];\n this._index = [];\n this._ptr = [0];\n this._size = [0, 0];\n this._datatype = datatype;\n }\n }\n\n function _createFromMatrix(matrix, source, datatype) {\n // check matrix type\n if (source.type === 'SparseMatrix') {\n // clone arrays\n matrix._values = source._values ? (0, _object.clone)(source._values) : undefined;\n matrix._index = (0, _object.clone)(source._index);\n matrix._ptr = (0, _object.clone)(source._ptr);\n matrix._size = (0, _object.clone)(source._size);\n matrix._datatype = datatype || source._datatype;\n } else {\n // build from matrix data\n _createFromArray(matrix, source.valueOf(), datatype || source._datatype);\n }\n }\n\n function _createFromArray(matrix, data, datatype) {\n // initialize fields\n matrix._values = [];\n matrix._index = [];\n matrix._ptr = [];\n matrix._datatype = datatype; // discover rows & columns, do not use math.size() to avoid looping array twice\n\n var rows = data.length;\n var columns = 0; // equal signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0;\n\n if ((0, _is.isString)(datatype)) {\n // find signature that matches (datatype, datatype)\n eq = typed.find(equalScalar, [datatype, datatype]) || equalScalar; // convert 0 to the same datatype\n\n zero = typed.convert(0, datatype);\n } // check we have rows (empty array)\n\n\n if (rows > 0) {\n // column index\n var j = 0;\n\n do {\n // store pointer to values index\n matrix._ptr.push(matrix._index.length); // loop rows\n\n\n for (var i = 0; i < rows; i++) {\n // current row\n var row = data[i]; // check row is an array\n\n if ((0, _is.isArray)(row)) {\n // update columns if needed (only on first column)\n if (j === 0 && columns < row.length) {\n columns = row.length;\n } // check row has column\n\n\n if (j < row.length) {\n // value\n var v = row[j]; // check value != 0\n\n if (!eq(v, zero)) {\n // store value\n matrix._values.push(v); // index\n\n\n matrix._index.push(i);\n }\n }\n } else {\n // update columns if needed (only on first column)\n if (j === 0 && columns < 1) {\n columns = 1;\n } // check value != 0 (row is a scalar)\n\n\n if (!eq(row, zero)) {\n // store value\n matrix._values.push(row); // index\n\n\n matrix._index.push(i);\n }\n }\n } // increment index\n\n\n j++;\n } while (j < columns);\n } // store number of values in ptr\n\n\n matrix._ptr.push(matrix._index.length); // size\n\n\n matrix._size = [rows, columns];\n }\n\n SparseMatrix.prototype = new Matrix();\n /**\n * Create a new SparseMatrix\n */\n\n SparseMatrix.prototype.createSparseMatrix = function (data, datatype) {\n return new SparseMatrix(data, datatype);\n };\n /**\n * Attach type information\n */\n\n\n SparseMatrix.prototype.type = 'SparseMatrix';\n SparseMatrix.prototype.isSparseMatrix = true;\n /**\n * Get the matrix type\n *\n * Usage:\n * const matrixType = matrix.getDataType() // retrieves the matrix type\n *\n * @memberOf SparseMatrix\n * @return {string} type information; if multiple types are found from the Matrix, it will return \"mixed\"\n */\n\n SparseMatrix.prototype.getDataType = function () {\n return (0, _array.getArrayDataType)(this._values, _is.typeOf);\n };\n /**\n * Get the storage format used by the matrix.\n *\n * Usage:\n * const format = matrix.storage() // retrieve storage format\n *\n * @memberof SparseMatrix\n * @return {string} The storage format.\n */\n\n\n SparseMatrix.prototype.storage = function () {\n return 'sparse';\n };\n /**\n * Get the datatype of the data stored in the matrix.\n *\n * Usage:\n * const format = matrix.datatype() // retrieve matrix datatype\n *\n * @memberof SparseMatrix\n * @return {string} The datatype.\n */\n\n\n SparseMatrix.prototype.datatype = function () {\n return this._datatype;\n };\n /**\n * Create a new SparseMatrix\n * @memberof SparseMatrix\n * @param {Array} data\n * @param {string} [datatype]\n */\n\n\n SparseMatrix.prototype.create = function (data, datatype) {\n return new SparseMatrix(data, datatype);\n };\n /**\n * Get the matrix density.\n *\n * Usage:\n * const density = matrix.density() // retrieve matrix density\n *\n * @memberof SparseMatrix\n * @return {number} The matrix density.\n */\n\n\n SparseMatrix.prototype.density = function () {\n // rows & columns\n var rows = this._size[0];\n var columns = this._size[1]; // calculate density\n\n return rows !== 0 && columns !== 0 ? this._index.length / (rows * columns) : 0;\n };\n /**\n * Get a subset of the matrix, or replace a subset of the matrix.\n *\n * Usage:\n * const subset = matrix.subset(index) // retrieve subset\n * const value = matrix.subset(index, replacement) // replace subset\n *\n * @memberof SparseMatrix\n * @param {Index} index\n * @param {Array | Matrix | *} [replacement]\n * @param {*} [defaultValue=0] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be filled with zeros.\n */\n\n\n SparseMatrix.prototype.subset = function (index, replacement, defaultValue) {\n // check it is a pattern matrix\n if (!this._values) {\n throw new Error('Cannot invoke subset on a Pattern only matrix');\n } // check arguments\n\n\n switch (arguments.length) {\n case 1:\n return _getsubset(this, index);\n // intentional fall through\n\n case 2:\n case 3:\n return _setsubset(this, index, replacement, defaultValue);\n\n default:\n throw new SyntaxError('Wrong number of arguments');\n }\n };\n\n function _getsubset(matrix, idx) {\n // check idx\n if (!(0, _is.isIndex)(idx)) {\n throw new TypeError('Invalid index');\n }\n\n var isScalar = idx.isScalar();\n\n if (isScalar) {\n // return a scalar\n return matrix.get(idx.min());\n } // validate dimensions\n\n\n var size = idx.size();\n\n if (size.length !== matrix._size.length) {\n throw new _DimensionError.DimensionError(size.length, matrix._size.length);\n } // vars\n\n\n var i, ii, k, kk; // validate if any of the ranges in the index is out of range\n\n var min = idx.min();\n var max = idx.max();\n\n for (i = 0, ii = matrix._size.length; i < ii; i++) {\n (0, _array.validateIndex)(min[i], matrix._size[i]);\n (0, _array.validateIndex)(max[i], matrix._size[i]);\n } // matrix arrays\n\n\n var mvalues = matrix._values;\n var mindex = matrix._index;\n var mptr = matrix._ptr; // rows & columns dimensions for result matrix\n\n var rows = idx.dimension(0);\n var columns = idx.dimension(1); // workspace & permutation vector\n\n var w = [];\n var pv = []; // loop rows in resulting matrix\n\n rows.forEach(function (i, r) {\n // update permutation vector\n pv[i] = r[0]; // mark i in workspace\n\n w[i] = true;\n }); // result matrix arrays\n\n var values = mvalues ? [] : undefined;\n var index = [];\n var ptr = []; // loop columns in result matrix\n\n columns.forEach(function (j) {\n // update ptr\n ptr.push(index.length); // loop values in column j\n\n for (k = mptr[j], kk = mptr[j + 1]; k < kk; k++) {\n // row\n i = mindex[k]; // check row is in result matrix\n\n if (w[i] === true) {\n // push index\n index.push(pv[i]); // check we need to process values\n\n if (values) {\n values.push(mvalues[k]);\n }\n }\n }\n }); // update ptr\n\n ptr.push(index.length); // return matrix\n\n return new SparseMatrix({\n values: values,\n index: index,\n ptr: ptr,\n size: size,\n datatype: matrix._datatype\n });\n }\n\n function _setsubset(matrix, index, submatrix, defaultValue) {\n // check index\n if (!index || index.isIndex !== true) {\n throw new TypeError('Invalid index');\n } // get index size and check whether the index contains a single value\n\n\n var iSize = index.size();\n var isScalar = index.isScalar(); // calculate the size of the submatrix, and convert it into an Array if needed\n\n var sSize;\n\n if ((0, _is.isMatrix)(submatrix)) {\n // submatrix size\n sSize = submatrix.size(); // use array representation\n\n submatrix = submatrix.toArray();\n } else {\n // get submatrix size (array, scalar)\n sSize = (0, _array.arraySize)(submatrix);\n } // check index is a scalar\n\n\n if (isScalar) {\n // verify submatrix is a scalar\n if (sSize.length !== 0) {\n throw new TypeError('Scalar expected');\n } // set value\n\n\n matrix.set(index.min(), submatrix, defaultValue);\n } else {\n // validate dimensions, index size must be one or two dimensions\n if (iSize.length !== 1 && iSize.length !== 2) {\n throw new _DimensionError.DimensionError(iSize.length, matrix._size.length, '<');\n } // check submatrix and index have the same dimensions\n\n\n if (sSize.length < iSize.length) {\n // calculate number of missing outer dimensions\n var i = 0;\n var outer = 0;\n\n while (iSize[i] === 1 && sSize[i] === 1) {\n i++;\n }\n\n while (iSize[i] === 1) {\n outer++;\n i++;\n } // unsqueeze both outer and inner dimensions\n\n\n submatrix = (0, _array.unsqueeze)(submatrix, iSize.length, outer, sSize);\n } // check whether the size of the submatrix matches the index size\n\n\n if (!(0, _object.deepStrictEqual)(iSize, sSize)) {\n throw new _DimensionError.DimensionError(iSize, sSize, '>');\n } // insert the sub matrix\n\n\n if (iSize.length === 1) {\n // if the replacement index only has 1 dimension, go trough each one and set its value\n var range = index.dimension(0);\n range.forEach(function (dataIndex, subIndex) {\n (0, _array.validateIndex)(dataIndex);\n matrix.set([dataIndex, 0], submatrix[subIndex[0]], defaultValue);\n });\n } else {\n // if the replacement index has 2 dimensions, go through each one and set the value in the correct index\n var firstDimensionRange = index.dimension(0);\n var secondDimensionRange = index.dimension(1);\n firstDimensionRange.forEach(function (firstDataIndex, firstSubIndex) {\n (0, _array.validateIndex)(firstDataIndex);\n secondDimensionRange.forEach(function (secondDataIndex, secondSubIndex) {\n (0, _array.validateIndex)(secondDataIndex);\n matrix.set([firstDataIndex, secondDataIndex], submatrix[firstSubIndex[0]][secondSubIndex[0]], defaultValue);\n });\n });\n }\n }\n\n return matrix;\n }\n /**\n * Get a single element from the matrix.\n * @memberof SparseMatrix\n * @param {number[]} index Zero-based index\n * @return {*} value\n */\n\n\n SparseMatrix.prototype.get = function (index) {\n if (!(0, _is.isArray)(index)) {\n throw new TypeError('Array expected');\n }\n\n if (index.length !== this._size.length) {\n throw new _DimensionError.DimensionError(index.length, this._size.length);\n } // check it is a pattern matrix\n\n\n if (!this._values) {\n throw new Error('Cannot invoke get on a Pattern only matrix');\n } // row and column\n\n\n var i = index[0];\n var j = index[1]; // check i, j are valid\n\n (0, _array.validateIndex)(i, this._size[0]);\n (0, _array.validateIndex)(j, this._size[1]); // find value index\n\n var k = _getValueIndex(i, this._ptr[j], this._ptr[j + 1], this._index); // check k is prior to next column k and it is in the correct row\n\n\n if (k < this._ptr[j + 1] && this._index[k] === i) {\n return this._values[k];\n }\n\n return 0;\n };\n /**\n * Replace a single element in the matrix.\n * @memberof SparseMatrix\n * @param {number[]} index Zero-based index\n * @param {*} v\n * @param {*} [defaultValue] Default value, filled in on new entries when\n * the matrix is resized. If not provided,\n * new matrix elements will be set to zero.\n * @return {SparseMatrix} self\n */\n\n\n SparseMatrix.prototype.set = function (index, v, defaultValue) {\n if (!(0, _is.isArray)(index)) {\n throw new TypeError('Array expected');\n }\n\n if (index.length !== this._size.length) {\n throw new _DimensionError.DimensionError(index.length, this._size.length);\n } // check it is a pattern matrix\n\n\n if (!this._values) {\n throw new Error('Cannot invoke set on a Pattern only matrix');\n } // row and column\n\n\n var i = index[0];\n var j = index[1]; // rows & columns\n\n var rows = this._size[0];\n var columns = this._size[1]; // equal signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0;\n\n if ((0, _is.isString)(this._datatype)) {\n // find signature that matches (datatype, datatype)\n eq = typed.find(equalScalar, [this._datatype, this._datatype]) || equalScalar; // convert 0 to the same datatype\n\n zero = typed.convert(0, this._datatype);\n } // check we need to resize matrix\n\n\n if (i > rows - 1 || j > columns - 1) {\n // resize matrix\n _resize(this, Math.max(i + 1, rows), Math.max(j + 1, columns), defaultValue); // update rows & columns\n\n\n rows = this._size[0];\n columns = this._size[1];\n } // check i, j are valid\n\n\n (0, _array.validateIndex)(i, rows);\n (0, _array.validateIndex)(j, columns); // find value index\n\n var k = _getValueIndex(i, this._ptr[j], this._ptr[j + 1], this._index); // check k is prior to next column k and it is in the correct row\n\n\n if (k < this._ptr[j + 1] && this._index[k] === i) {\n // check value != 0\n if (!eq(v, zero)) {\n // update value\n this._values[k] = v;\n } else {\n // remove value from matrix\n _remove(k, j, this._values, this._index, this._ptr);\n }\n } else {\n // insert value @ (i, j)\n _insert(k, i, j, v, this._values, this._index, this._ptr);\n }\n\n return this;\n };\n\n function _getValueIndex(i, top, bottom, index) {\n // check row is on the bottom side\n if (bottom - top === 0) {\n return bottom;\n } // loop rows [top, bottom[\n\n\n for (var r = top; r < bottom; r++) {\n // check we found value index\n if (index[r] === i) {\n return r;\n }\n } // we did not find row\n\n\n return top;\n }\n\n function _remove(k, j, values, index, ptr) {\n // remove value @ k\n values.splice(k, 1);\n index.splice(k, 1); // update pointers\n\n for (var x = j + 1; x < ptr.length; x++) {\n ptr[x]--;\n }\n }\n\n function _insert(k, i, j, v, values, index, ptr) {\n // insert value\n values.splice(k, 0, v); // update row for k\n\n index.splice(k, 0, i); // update column pointers\n\n for (var x = j + 1; x < ptr.length; x++) {\n ptr[x]++;\n }\n }\n /**\n * Resize the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (resize in place).\n *\n * @memberof SparseMatrix\n * @param {number[] | Matrix} size The new size the matrix should have.\n * Since sparse matrices are always two-dimensional,\n * size must be two numbers in either an array or a matrix\n * @param {*} [defaultValue=0] Default value, filled in on new entries.\n * If not provided, the matrix elements will\n * be filled with zeros.\n * @param {boolean} [copy] Return a resized copy of the matrix\n *\n * @return {Matrix} The resized matrix\n */\n\n\n SparseMatrix.prototype.resize = function (size, defaultValue, copy) {\n // validate arguments\n if (!(0, _is.isCollection)(size)) {\n throw new TypeError('Array or Matrix expected');\n } // SparseMatrix input is always 2d, flatten this into 1d if it's indeed a vector\n\n\n var sizeArray = size.valueOf().map(function (value) {\n return Array.isArray(value) && value.length === 1 ? value[0] : value;\n });\n\n if (sizeArray.length !== 2) {\n throw new Error('Only two dimensions matrix are supported');\n } // check sizes\n\n\n sizeArray.forEach(function (value) {\n if (!(0, _is.isNumber)(value) || !(0, _number.isInteger)(value) || value < 0) {\n throw new TypeError('Invalid size, must contain positive integers ' + '(size: ' + (0, _string.format)(sizeArray) + ')');\n }\n }); // matrix to resize\n\n var m = copy ? this.clone() : this; // resize matrix\n\n return _resize(m, sizeArray[0], sizeArray[1], defaultValue);\n };\n\n function _resize(matrix, rows, columns, defaultValue) {\n // value to insert at the time of growing matrix\n var value = defaultValue || 0; // equal signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0;\n\n if ((0, _is.isString)(matrix._datatype)) {\n // find signature that matches (datatype, datatype)\n eq = typed.find(equalScalar, [matrix._datatype, matrix._datatype]) || equalScalar; // convert 0 to the same datatype\n\n zero = typed.convert(0, matrix._datatype); // convert value to the same datatype\n\n value = typed.convert(value, matrix._datatype);\n } // should we insert the value?\n\n\n var ins = !eq(value, zero); // old columns and rows\n\n var r = matrix._size[0];\n var c = matrix._size[1];\n var i, j, k; // check we need to increase columns\n\n if (columns > c) {\n // loop new columns\n for (j = c; j < columns; j++) {\n // update matrix._ptr for current column\n matrix._ptr[j] = matrix._values.length; // check we need to insert matrix._values\n\n if (ins) {\n // loop rows\n for (i = 0; i < r; i++) {\n // add new matrix._values\n matrix._values.push(value); // update matrix._index\n\n\n matrix._index.push(i);\n }\n }\n } // store number of matrix._values in matrix._ptr\n\n\n matrix._ptr[columns] = matrix._values.length;\n } else if (columns < c) {\n // truncate matrix._ptr\n matrix._ptr.splice(columns + 1, c - columns); // truncate matrix._values and matrix._index\n\n\n matrix._values.splice(matrix._ptr[columns], matrix._values.length);\n\n matrix._index.splice(matrix._ptr[columns], matrix._index.length);\n } // update columns\n\n\n c = columns; // check we need to increase rows\n\n if (rows > r) {\n // check we have to insert values\n if (ins) {\n // inserts\n var n = 0; // loop columns\n\n for (j = 0; j < c; j++) {\n // update matrix._ptr for current column\n matrix._ptr[j] = matrix._ptr[j] + n; // where to insert matrix._values\n\n k = matrix._ptr[j + 1] + n; // pointer\n\n var p = 0; // loop new rows, initialize pointer\n\n for (i = r; i < rows; i++, p++) {\n // add value\n matrix._values.splice(k + p, 0, value); // update matrix._index\n\n\n matrix._index.splice(k + p, 0, i); // increment inserts\n\n\n n++;\n }\n } // store number of matrix._values in matrix._ptr\n\n\n matrix._ptr[c] = matrix._values.length;\n }\n } else if (rows < r) {\n // deletes\n var d = 0; // loop columns\n\n for (j = 0; j < c; j++) {\n // update matrix._ptr for current column\n matrix._ptr[j] = matrix._ptr[j] - d; // where matrix._values start for next column\n\n var k0 = matrix._ptr[j];\n var k1 = matrix._ptr[j + 1] - d; // loop matrix._index\n\n for (k = k0; k < k1; k++) {\n // row\n i = matrix._index[k]; // check we need to delete value and matrix._index\n\n if (i > rows - 1) {\n // remove value\n matrix._values.splice(k, 1); // remove item from matrix._index\n\n\n matrix._index.splice(k, 1); // increase deletes\n\n\n d++;\n }\n }\n } // update matrix._ptr for current column\n\n\n matrix._ptr[j] = matrix._values.length;\n } // update matrix._size\n\n\n matrix._size[0] = rows;\n matrix._size[1] = columns; // return matrix\n\n return matrix;\n }\n /**\n * Reshape the matrix to the given size. Returns a copy of the matrix when\n * `copy=true`, otherwise return the matrix itself (reshape in place).\n *\n * NOTE: This might be better suited to copy by default, instead of modifying\n * in place. For now, it operates in place to remain consistent with\n * resize().\n *\n * @memberof SparseMatrix\n * @param {number[]} sizes The new size the matrix should have.\n * Since sparse matrices are always two-dimensional,\n * size must be two numbers in either an array or a matrix\n * @param {boolean} [copy] Return a reshaped copy of the matrix\n *\n * @return {Matrix} The reshaped matrix\n */\n\n\n SparseMatrix.prototype.reshape = function (sizes, copy) {\n // validate arguments\n if (!(0, _is.isArray)(sizes)) {\n throw new TypeError('Array expected');\n }\n\n if (sizes.length !== 2) {\n throw new Error('Sparse matrices can only be reshaped in two dimensions');\n } // check sizes\n\n\n sizes.forEach(function (value) {\n if (!(0, _is.isNumber)(value) || !(0, _number.isInteger)(value) || value <= -2 || value === 0) {\n throw new TypeError('Invalid size, must contain positive integers or -1 ' + '(size: ' + (0, _string.format)(sizes) + ')');\n }\n });\n var currentLength = this._size[0] * this._size[1];\n sizes = (0, _array.processSizesWildcard)(sizes, currentLength);\n var newLength = sizes[0] * sizes[1]; // m * n must not change\n\n if (currentLength !== newLength) {\n throw new Error('Reshaping sparse matrix will result in the wrong number of elements');\n } // matrix to reshape\n\n\n var m = copy ? this.clone() : this; // return unchanged if the same shape\n\n if (this._size[0] === sizes[0] && this._size[1] === sizes[1]) {\n return m;\n } // Convert to COO format (generate a column index)\n\n\n var colIndex = [];\n\n for (var i = 0; i < m._ptr.length; i++) {\n for (var j = 0; j < m._ptr[i + 1] - m._ptr[i]; j++) {\n colIndex.push(i);\n }\n } // Clone the values array\n\n\n var values = m._values.slice(); // Clone the row index array\n\n\n var rowIndex = m._index.slice(); // Transform the (row, column) indices\n\n\n for (var _i = 0; _i < m._index.length; _i++) {\n var r1 = rowIndex[_i];\n var c1 = colIndex[_i];\n var flat = r1 * m._size[1] + c1;\n colIndex[_i] = flat % sizes[1];\n rowIndex[_i] = Math.floor(flat / sizes[1]);\n } // Now reshaping is supposed to preserve the row-major order, BUT these sparse matrices are stored\n // in column-major order, so we have to reorder the value array now. One option is to use a multisort,\n // sorting several arrays based on some other array.\n // OR, we could easily just:\n // 1. Remove all values from the matrix\n\n\n m._values.length = 0;\n m._index.length = 0;\n m._ptr.length = sizes[1] + 1;\n m._size = sizes.slice();\n\n for (var _i2 = 0; _i2 < m._ptr.length; _i2++) {\n m._ptr[_i2] = 0;\n } // 2. Re-insert all elements in the proper order (simplified code from SparseMatrix.prototype.set)\n // This step is probably the most time-consuming\n\n\n for (var h = 0; h < values.length; h++) {\n var _i3 = rowIndex[h];\n var _j = colIndex[h];\n var v = values[h];\n\n var k = _getValueIndex(_i3, m._ptr[_j], m._ptr[_j + 1], m._index);\n\n _insert(k, _i3, _j, v, m._values, m._index, m._ptr);\n } // The value indices are inserted out of order, but apparently that's... still OK?\n\n\n return m;\n };\n /**\n * Create a clone of the matrix\n * @memberof SparseMatrix\n * @return {SparseMatrix} clone\n */\n\n\n SparseMatrix.prototype.clone = function () {\n var m = new SparseMatrix({\n values: this._values ? (0, _object.clone)(this._values) : undefined,\n index: (0, _object.clone)(this._index),\n ptr: (0, _object.clone)(this._ptr),\n size: (0, _object.clone)(this._size),\n datatype: this._datatype\n });\n return m;\n };\n /**\n * Retrieve the size of the matrix.\n * @memberof SparseMatrix\n * @returns {number[]} size\n */\n\n\n SparseMatrix.prototype.size = function () {\n return this._size.slice(0); // copy the Array\n };\n /**\n * Create a new matrix with the results of the callback function executed on\n * each entry of the matrix.\n * @memberof SparseMatrix\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n * @param {boolean} [skipZeros] Invoke callback function for non-zero values only.\n *\n * @return {SparseMatrix} matrix\n */\n\n\n SparseMatrix.prototype.map = function (callback, skipZeros) {\n // check it is a pattern matrix\n if (!this._values) {\n throw new Error('Cannot invoke map on a Pattern only matrix');\n } // matrix instance\n\n\n var me = this; // rows and columns\n\n var rows = this._size[0];\n var columns = this._size[1]; // invoke callback\n\n var invoke = function invoke(v, i, j) {\n // invoke callback\n return callback(v, [i, j], me);\n }; // invoke _map\n\n\n return _map(this, 0, rows - 1, 0, columns - 1, invoke, skipZeros);\n };\n /**\n * Create a new matrix with the results of the callback function executed on the interval\n * [minRow..maxRow, minColumn..maxColumn].\n */\n\n\n function _map(matrix, minRow, maxRow, minColumn, maxColumn, callback, skipZeros) {\n // result arrays\n var values = [];\n var index = [];\n var ptr = []; // equal signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0;\n\n if ((0, _is.isString)(matrix._datatype)) {\n // find signature that matches (datatype, datatype)\n eq = typed.find(equalScalar, [matrix._datatype, matrix._datatype]) || equalScalar; // convert 0 to the same datatype\n\n zero = typed.convert(0, matrix._datatype);\n } // invoke callback\n\n\n var invoke = function invoke(v, x, y) {\n // invoke callback\n v = callback(v, x, y); // check value != 0\n\n if (!eq(v, zero)) {\n // store value\n values.push(v); // index\n\n index.push(x);\n }\n }; // loop columns\n\n\n for (var j = minColumn; j <= maxColumn; j++) {\n // store pointer to values index\n ptr.push(values.length); // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n\n var k0 = matrix._ptr[j];\n var k1 = matrix._ptr[j + 1];\n\n if (skipZeros) {\n // loop k within [k0, k1[\n for (var k = k0; k < k1; k++) {\n // row index\n var i = matrix._index[k]; // check i is in range\n\n if (i >= minRow && i <= maxRow) {\n // value @ k\n invoke(matrix._values[k], i - minRow, j - minColumn);\n }\n }\n } else {\n // create a cache holding all defined values\n var _values = {};\n\n for (var _k = k0; _k < k1; _k++) {\n var _i4 = matrix._index[_k];\n _values[_i4] = matrix._values[_k];\n } // loop over all rows (indexes can be unordered so we can't use that),\n // and either read the value or zero\n\n\n for (var _i5 = minRow; _i5 <= maxRow; _i5++) {\n var value = _i5 in _values ? _values[_i5] : 0;\n invoke(value, _i5 - minRow, j - minColumn);\n }\n }\n } // store number of values in ptr\n\n\n ptr.push(values.length); // return sparse matrix\n\n return new SparseMatrix({\n values: values,\n index: index,\n ptr: ptr,\n size: [maxRow - minRow + 1, maxColumn - minColumn + 1]\n });\n }\n /**\n * Execute a callback function on each entry of the matrix.\n * @memberof SparseMatrix\n * @param {Function} callback The callback function is invoked with three\n * parameters: the value of the element, the index\n * of the element, and the Matrix being traversed.\n * @param {boolean} [skipZeros] Invoke callback function for non-zero values only.\n * If false, the indices are guaranteed to be in order,\n * if true, the indices can be unordered.\n */\n\n\n SparseMatrix.prototype.forEach = function (callback, skipZeros) {\n // check it is a pattern matrix\n if (!this._values) {\n throw new Error('Cannot invoke forEach on a Pattern only matrix');\n } // matrix instance\n\n\n var me = this; // rows and columns\n\n var rows = this._size[0];\n var columns = this._size[1]; // loop columns\n\n for (var j = 0; j < columns; j++) {\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n var k0 = this._ptr[j];\n var k1 = this._ptr[j + 1];\n\n if (skipZeros) {\n // loop k within [k0, k1[\n for (var k = k0; k < k1; k++) {\n // row index\n var i = this._index[k]; // value @ k\n\n callback(this._values[k], [i, j], me);\n }\n } else {\n // create a cache holding all defined values\n var values = {};\n\n for (var _k2 = k0; _k2 < k1; _k2++) {\n var _i6 = this._index[_k2];\n values[_i6] = this._values[_k2];\n } // loop over all rows (indexes can be unordered so we can't use that),\n // and either read the value or zero\n\n\n for (var _i7 = 0; _i7 < rows; _i7++) {\n var value = _i7 in values ? values[_i7] : 0;\n callback(value, [_i7, j], me);\n }\n }\n }\n };\n /**\n * Iterate over the matrix elements, skipping zeros\n * @return {Iterable<{ value, index: number[] }>}\n */\n\n\n SparseMatrix.prototype[Symbol.iterator] = /*#__PURE__*/_regenerator.default.mark(function _callee() {\n var columns, j, k0, k1, k, i;\n return _regenerator.default.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (this._values) {\n _context.next = 2;\n break;\n }\n\n throw new Error('Cannot iterate a Pattern only matrix');\n\n case 2:\n columns = this._size[1];\n j = 0;\n\n case 4:\n if (!(j < columns)) {\n _context.next = 18;\n break;\n }\n\n k0 = this._ptr[j];\n k1 = this._ptr[j + 1];\n k = k0;\n\n case 8:\n if (!(k < k1)) {\n _context.next = 15;\n break;\n }\n\n // row index\n i = this._index[k];\n _context.next = 12;\n return {\n value: this._values[k],\n index: [i, j]\n };\n\n case 12:\n k++;\n _context.next = 8;\n break;\n\n case 15:\n j++;\n _context.next = 4;\n break;\n\n case 18:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n });\n /**\n * Create an Array with a copy of the data of the SparseMatrix\n * @memberof SparseMatrix\n * @returns {Array} array\n */\n\n SparseMatrix.prototype.toArray = function () {\n return _toArray(this._values, this._index, this._ptr, this._size, true);\n };\n /**\n * Get the primitive value of the SparseMatrix: a two dimensions array\n * @memberof SparseMatrix\n * @returns {Array} array\n */\n\n\n SparseMatrix.prototype.valueOf = function () {\n return _toArray(this._values, this._index, this._ptr, this._size, false);\n };\n\n function _toArray(values, index, ptr, size, copy) {\n // rows and columns\n var rows = size[0];\n var columns = size[1]; // result\n\n var a = []; // vars\n\n var i, j; // initialize array\n\n for (i = 0; i < rows; i++) {\n a[i] = [];\n\n for (j = 0; j < columns; j++) {\n a[i][j] = 0;\n }\n } // loop columns\n\n\n for (j = 0; j < columns; j++) {\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n var k0 = ptr[j];\n var k1 = ptr[j + 1]; // loop k within [k0, k1[\n\n for (var k = k0; k < k1; k++) {\n // row index\n i = index[k]; // set value (use one for pattern matrix)\n\n a[i][j] = values ? copy ? (0, _object.clone)(values[k]) : values[k] : 1;\n }\n }\n\n return a;\n }\n /**\n * Get a string representation of the matrix, with optional formatting options.\n * @memberof SparseMatrix\n * @param {Object | number | Function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @returns {string} str\n */\n\n\n SparseMatrix.prototype.format = function (options) {\n // rows and columns\n var rows = this._size[0];\n var columns = this._size[1]; // density\n\n var density = this.density(); // rows & columns\n\n var str = 'Sparse Matrix [' + (0, _string.format)(rows, options) + ' x ' + (0, _string.format)(columns, options) + '] density: ' + (0, _string.format)(density, options) + '\\n'; // loop columns\n\n for (var j = 0; j < columns; j++) {\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n var k0 = this._ptr[j];\n var k1 = this._ptr[j + 1]; // loop k within [k0, k1[\n\n for (var k = k0; k < k1; k++) {\n // row index\n var i = this._index[k]; // append value\n\n str += '\\n (' + (0, _string.format)(i, options) + ', ' + (0, _string.format)(j, options) + ') ==> ' + (this._values ? (0, _string.format)(this._values[k], options) : 'X');\n }\n }\n\n return str;\n };\n /**\n * Get a string representation of the matrix\n * @memberof SparseMatrix\n * @returns {string} str\n */\n\n\n SparseMatrix.prototype.toString = function () {\n return (0, _string.format)(this.toArray());\n };\n /**\n * Get a JSON representation of the matrix\n * @memberof SparseMatrix\n * @returns {Object}\n */\n\n\n SparseMatrix.prototype.toJSON = function () {\n return {\n mathjs: 'SparseMatrix',\n values: this._values,\n index: this._index,\n ptr: this._ptr,\n size: this._size,\n datatype: this._datatype\n };\n };\n /**\n * Get the kth Matrix diagonal.\n *\n * @memberof SparseMatrix\n * @param {number | BigNumber} [k=0] The kth diagonal where the vector will retrieved.\n *\n * @returns {Matrix} The matrix vector with the diagonal values.\n */\n\n\n SparseMatrix.prototype.diagonal = function (k) {\n // validate k if any\n if (k) {\n // convert BigNumber to a number\n if ((0, _is.isBigNumber)(k)) {\n k = k.toNumber();\n } // is must be an integer\n\n\n if (!(0, _is.isNumber)(k) || !(0, _number.isInteger)(k)) {\n throw new TypeError('The parameter k must be an integer number');\n }\n } else {\n // default value\n k = 0;\n }\n\n var kSuper = k > 0 ? k : 0;\n var kSub = k < 0 ? -k : 0; // rows & columns\n\n var rows = this._size[0];\n var columns = this._size[1]; // number diagonal values\n\n var n = Math.min(rows - kSub, columns - kSuper); // diagonal arrays\n\n var values = [];\n var index = [];\n var ptr = []; // initial ptr value\n\n ptr[0] = 0; // loop columns\n\n for (var j = kSuper; j < columns && values.length < n; j++) {\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n var k0 = this._ptr[j];\n var k1 = this._ptr[j + 1]; // loop x within [k0, k1[\n\n for (var x = k0; x < k1; x++) {\n // row index\n var i = this._index[x]; // check row\n\n if (i === j - kSuper + kSub) {\n // value on this column\n values.push(this._values[x]); // store row\n\n index[values.length - 1] = i - kSub; // exit loop\n\n break;\n }\n }\n } // close ptr\n\n\n ptr.push(values.length); // return matrix\n\n return new SparseMatrix({\n values: values,\n index: index,\n ptr: ptr,\n size: [n, 1]\n });\n };\n /**\n * Generate a matrix from a JSON object\n * @memberof SparseMatrix\n * @param {Object} json An object structured like\n * `{\"mathjs\": \"SparseMatrix\", \"values\": [], \"index\": [], \"ptr\": [], \"size\": []}`,\n * where mathjs is optional\n * @returns {SparseMatrix}\n */\n\n\n SparseMatrix.fromJSON = function (json) {\n return new SparseMatrix(json);\n };\n /**\n * Create a diagonal matrix.\n *\n * @memberof SparseMatrix\n * @param {Array} size The matrix size.\n * @param {number | Array | Matrix } value The values for the diagonal.\n * @param {number | BigNumber} [k=0] The kth diagonal where the vector will be filled in.\n * @param {number} [defaultValue] The default value for non-diagonal\n * @param {string} [datatype] The Matrix datatype, values must be of this datatype.\n *\n * @returns {SparseMatrix}\n */\n\n\n SparseMatrix.diagonal = function (size, value, k, defaultValue, datatype) {\n if (!(0, _is.isArray)(size)) {\n throw new TypeError('Array expected, size parameter');\n }\n\n if (size.length !== 2) {\n throw new Error('Only two dimensions matrix are supported');\n } // map size & validate\n\n\n size = size.map(function (s) {\n // check it is a big number\n if ((0, _is.isBigNumber)(s)) {\n // convert it\n s = s.toNumber();\n } // validate arguments\n\n\n if (!(0, _is.isNumber)(s) || !(0, _number.isInteger)(s) || s < 1) {\n throw new Error('Size values must be positive integers');\n }\n\n return s;\n }); // validate k if any\n\n if (k) {\n // convert BigNumber to a number\n if ((0, _is.isBigNumber)(k)) {\n k = k.toNumber();\n } // is must be an integer\n\n\n if (!(0, _is.isNumber)(k) || !(0, _number.isInteger)(k)) {\n throw new TypeError('The parameter k must be an integer number');\n }\n } else {\n // default value\n k = 0;\n } // equal signature to use\n\n\n var eq = equalScalar; // zero value\n\n var zero = 0;\n\n if ((0, _is.isString)(datatype)) {\n // find signature that matches (datatype, datatype)\n eq = typed.find(equalScalar, [datatype, datatype]) || equalScalar; // convert 0 to the same datatype\n\n zero = typed.convert(0, datatype);\n }\n\n var kSuper = k > 0 ? k : 0;\n var kSub = k < 0 ? -k : 0; // rows and columns\n\n var rows = size[0];\n var columns = size[1]; // number of non-zero items\n\n var n = Math.min(rows - kSub, columns - kSuper); // value extraction function\n\n var _value; // check value\n\n\n if ((0, _is.isArray)(value)) {\n // validate array\n if (value.length !== n) {\n // number of values in array must be n\n throw new Error('Invalid value array length');\n } // define function\n\n\n _value = function _value(i) {\n // return value @ i\n return value[i];\n };\n } else if ((0, _is.isMatrix)(value)) {\n // matrix size\n var ms = value.size(); // validate matrix\n\n if (ms.length !== 1 || ms[0] !== n) {\n // number of values in array must be n\n throw new Error('Invalid matrix length');\n } // define function\n\n\n _value = function _value(i) {\n // return value @ i\n return value.get([i]);\n };\n } else {\n // define function\n _value = function _value() {\n // return value\n return value;\n };\n } // create arrays\n\n\n var values = [];\n var index = [];\n var ptr = []; // loop items\n\n for (var j = 0; j < columns; j++) {\n // number of rows with value\n ptr.push(values.length); // diagonal index\n\n var i = j - kSuper; // check we need to set diagonal value\n\n if (i >= 0 && i < n) {\n // get value @ i\n var v = _value(i); // check for zero\n\n\n if (!eq(v, zero)) {\n // column\n index.push(i + kSub); // add value\n\n values.push(v);\n }\n }\n } // last value should be number of values\n\n\n ptr.push(values.length); // create SparseMatrix\n\n return new SparseMatrix({\n values: values,\n index: index,\n ptr: ptr,\n size: [rows, columns]\n });\n };\n /**\n * Swap rows i and j in Matrix.\n *\n * @memberof SparseMatrix\n * @param {number} i Matrix row index 1\n * @param {number} j Matrix row index 2\n *\n * @return {Matrix} The matrix reference\n */\n\n\n SparseMatrix.prototype.swapRows = function (i, j) {\n // check index\n if (!(0, _is.isNumber)(i) || !(0, _number.isInteger)(i) || !(0, _is.isNumber)(j) || !(0, _number.isInteger)(j)) {\n throw new Error('Row index must be positive integers');\n } // check dimensions\n\n\n if (this._size.length !== 2) {\n throw new Error('Only two dimensional matrix is supported');\n } // validate index\n\n\n (0, _array.validateIndex)(i, this._size[0]);\n (0, _array.validateIndex)(j, this._size[0]); // swap rows\n\n SparseMatrix._swapRows(i, j, this._size[1], this._values, this._index, this._ptr); // return current instance\n\n\n return this;\n };\n /**\n * Loop rows with data in column j.\n *\n * @param {number} j Column\n * @param {Array} values Matrix values\n * @param {Array} index Matrix row indeces\n * @param {Array} ptr Matrix column pointers\n * @param {Function} callback Callback function invoked for every row in column j\n */\n\n\n SparseMatrix._forEachRow = function (j, values, index, ptr, callback) {\n // indeces for column j\n var k0 = ptr[j];\n var k1 = ptr[j + 1]; // loop\n\n for (var k = k0; k < k1; k++) {\n // invoke callback\n callback(index[k], values[k]);\n }\n };\n /**\n * Swap rows x and y in Sparse Matrix data structures.\n *\n * @param {number} x Matrix row index 1\n * @param {number} y Matrix row index 2\n * @param {number} columns Number of columns in matrix\n * @param {Array} values Matrix values\n * @param {Array} index Matrix row indeces\n * @param {Array} ptr Matrix column pointers\n */\n\n\n SparseMatrix._swapRows = function (x, y, columns, values, index, ptr) {\n // loop columns\n for (var j = 0; j < columns; j++) {\n // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n var k0 = ptr[j];\n var k1 = ptr[j + 1]; // find value index @ x\n\n var kx = _getValueIndex(x, k0, k1, index); // find value index @ x\n\n\n var ky = _getValueIndex(y, k0, k1, index); // check both rows exist in matrix\n\n\n if (kx < k1 && ky < k1 && index[kx] === x && index[ky] === y) {\n // swap values (check for pattern matrix)\n if (values) {\n var v = values[kx];\n values[kx] = values[ky];\n values[ky] = v;\n } // next column\n\n\n continue;\n } // check x row exist & no y row\n\n\n if (kx < k1 && index[kx] === x && (ky >= k1 || index[ky] !== y)) {\n // value @ x (check for pattern matrix)\n var vx = values ? values[kx] : undefined; // insert value @ y\n\n index.splice(ky, 0, y);\n\n if (values) {\n values.splice(ky, 0, vx);\n } // remove value @ x (adjust array index if needed)\n\n\n index.splice(ky <= kx ? kx + 1 : kx, 1);\n\n if (values) {\n values.splice(ky <= kx ? kx + 1 : kx, 1);\n } // next column\n\n\n continue;\n } // check y row exist & no x row\n\n\n if (ky < k1 && index[ky] === y && (kx >= k1 || index[kx] !== x)) {\n // value @ y (check for pattern matrix)\n var vy = values ? values[ky] : undefined; // insert value @ x\n\n index.splice(kx, 0, x);\n\n if (values) {\n values.splice(kx, 0, vy);\n } // remove value @ y (adjust array index if needed)\n\n\n index.splice(kx <= ky ? ky + 1 : ky, 1);\n\n if (values) {\n values.splice(kx <= ky ? ky + 1 : ky, 1);\n }\n }\n }\n };\n\n return SparseMatrix;\n}, {\n isClass: true\n});\nexports.createSparseMatrixClass = createSparseMatrixClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIndex = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _is = require(\"../../../utils/is.js\");\n\nvar name = 'index';\nvar dependencies = ['typed', 'Index'];\nvar createIndex = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Index = _ref.Index;\n\n /**\n * Create an index. An Index can store ranges having start, step, and end\n * for multiple dimensions.\n * Matrix.get, Matrix.set, and math.subset accept an Index as input.\n *\n * Syntax:\n *\n * math.index(range1, range2, ...)\n *\n * Where each range can be any of:\n *\n * - A number\n * - A string for getting/setting an object property\n * - An instance of `Range`\n * - A one-dimensional Array or a Matrix with numbers\n *\n * Indexes must be zero-based, integer numbers.\n *\n * Examples:\n *\n * const b = [1, 2, 3, 4, 5]\n * math.subset(b, math.index([1, 2, 3])) // returns [2, 3, 4]\n *\n * const a = math.matrix([[1, 2], [3, 4]])\n * a.subset(math.index(0, 1)) // returns 2\n *\n * See also:\n *\n * bignumber, boolean, complex, matrix, number, string, unit\n *\n * @param {...*} ranges Zero or more ranges or numbers.\n * @return {Index} Returns the created index\n */\n return typed(name, {\n '...number | string | BigNumber | Range | Array | Matrix': function numberStringBigNumberRangeArrayMatrix(args) {\n var ranges = args.map(function (arg) {\n if ((0, _is.isBigNumber)(arg)) {\n return arg.toNumber(); // convert BigNumber to Number\n } else if (Array.isArray(arg) || (0, _is.isMatrix)(arg)) {\n return arg.map(function (elem) {\n // convert BigNumber to Number\n return (0, _is.isBigNumber)(elem) ? elem.toNumber() : elem;\n });\n } else {\n return arg;\n }\n });\n var res = new Index();\n Index.apply(res, ranges);\n return res;\n }\n });\n});\nexports.createIndex = createIndex;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createMatrix = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar name = 'matrix';\nvar dependencies = ['typed', 'Matrix', 'DenseMatrix', 'SparseMatrix'];\nvar createMatrix = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Matrix = _ref.Matrix,\n DenseMatrix = _ref.DenseMatrix,\n SparseMatrix = _ref.SparseMatrix;\n\n /**\n * Create a Matrix. The function creates a new `math.Matrix` object from\n * an `Array`. A Matrix has utility functions to manipulate the data in the\n * matrix, like getting the size and getting or setting values in the matrix.\n * Supported storage formats are 'dense' and 'sparse'.\n *\n * Syntax:\n *\n * math.matrix() // creates an empty matrix using default storage format (dense).\n * math.matrix(data) // creates a matrix with initial data using default storage format (dense).\n * math.matrix('dense') // creates an empty matrix using the given storage format.\n * math.matrix(data, 'dense') // creates a matrix with initial data using the given storage format.\n * math.matrix(data, 'sparse') // creates a sparse matrix with initial data.\n * math.matrix(data, 'sparse', 'number') // creates a sparse matrix with initial data, number data type.\n *\n * Examples:\n *\n * let m = math.matrix([[1, 2], [3, 4]])\n * m.size() // Array [2, 2]\n * m.resize([3, 2], 5)\n * m.valueOf() // Array [[1, 2], [3, 4], [5, 5]]\n * m.get([1, 0]) // number 3\n *\n * See also:\n *\n * bignumber, boolean, complex, index, number, string, unit, sparse\n *\n * @param {Array | Matrix} [data] A multi dimensional array\n * @param {string} [format] The Matrix storage format, either `'dense'` or `'sparse'`\n * @param {string} [datatype] Type of the values\n *\n * @return {Matrix} The created matrix\n */\n return typed(name, {\n '': function _() {\n return _create([]);\n },\n string: function string(format) {\n return _create([], format);\n },\n 'string, string': function stringString(format, datatype) {\n return _create([], format, datatype);\n },\n Array: function Array(data) {\n return _create(data);\n },\n Matrix: function Matrix(data) {\n return _create(data, data.storage());\n },\n 'Array | Matrix, string': _create,\n 'Array | Matrix, string, string': _create\n });\n /**\n * Create a new Matrix with given storage format\n * @param {Array} data\n * @param {string} [format]\n * @param {string} [datatype]\n * @returns {Matrix} Returns a new Matrix\n * @private\n */\n\n function _create(data, format, datatype) {\n // get storage format constructor\n if (format === 'dense' || format === 'default' || format === undefined) {\n return new DenseMatrix(data, datatype);\n }\n\n if (format === 'sparse') {\n return new SparseMatrix(data, datatype);\n }\n\n throw new TypeError('Unknown matrix type ' + JSON.stringify(format) + '.');\n }\n});\nexports.createMatrix = createMatrix;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSparse = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar name = 'sparse';\nvar dependencies = ['typed', 'SparseMatrix'];\nvar createSparse = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n SparseMatrix = _ref.SparseMatrix;\n\n /**\n * Create a Sparse Matrix. The function creates a new `math.Matrix` object from\n * an `Array`. A Matrix has utility functions to manipulate the data in the\n * matrix, like getting the size and getting or setting values in the matrix.\n * Note that a Sparse Matrix is always 2-dimensional, so for example if\n * you create one from a plain array of _n_ numbers, you get an _n_ by 1\n * Sparse \"column vector\".\n *\n * Syntax:\n *\n * math.sparse() // creates an empty sparse matrix.\n * math.sparse(data) // creates a sparse matrix with initial data.\n * math.sparse(data, 'number') // creates a sparse matrix with initial data, number datatype.\n *\n * Examples:\n *\n * let m = math.sparse([[1, 2], [3, 4]])\n * m.size() // Array [2, 2]\n * m.resize([3, 2], 5)\n * m.valueOf() // Array [[1, 2], [3, 4], [5, 5]]\n * m.get([1, 0]) // number 3\n * let v = math.sparse([0, 0, 1])\n * v.size() // Array [3, 1]\n * v.get([2, 0]) // number 1\n *\n * See also:\n *\n * bignumber, boolean, complex, index, number, string, unit, matrix\n *\n * @param {Array | Matrix} [data] A two dimensional array\n *\n * @return {Matrix} The created matrix\n */\n return typed(name, {\n '': function _() {\n return new SparseMatrix([]);\n },\n string: function string(datatype) {\n return new SparseMatrix([], datatype);\n },\n 'Array | Matrix': function ArrayMatrix(data) {\n return new SparseMatrix(data);\n },\n 'Array | Matrix, string': function ArrayMatrixString(data, datatype) {\n return new SparseMatrix(data, datatype);\n }\n });\n});\nexports.createSparse = createSparse;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm01 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _DimensionError = require(\"../../../error/DimensionError.js\");\n\nvar name = 'algorithm01';\nvar dependencies = ['typed'];\nvar createAlgorithm01 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Iterates over SparseMatrix nonzero items and invokes the callback function f(Dij, Sij).\n * Callback function invoked NNZ times (number of nonzero items in SparseMatrix).\n *\n *\n * ┌ f(Dij, Sij) ; S(i,j) !== 0\n * C(i,j) = ┤\n * └ Dij ; otherwise\n *\n *\n * @param {Matrix} denseMatrix The DenseMatrix instance (D)\n * @param {Matrix} sparseMatrix The SparseMatrix instance (S)\n * @param {Function} callback The f(Dij,Sij) operation to invoke, where Dij = DenseMatrix(i,j) and Sij = SparseMatrix(i,j)\n * @param {boolean} inverse A true value indicates callback should be invoked f(Sij,Dij)\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97477571\n */\n return function algorithm1(denseMatrix, sparseMatrix, callback, inverse) {\n // dense matrix arrays\n var adata = denseMatrix._data;\n var asize = denseMatrix._size;\n var adt = denseMatrix._datatype; // sparse matrix arrays\n\n var bvalues = sparseMatrix._values;\n var bindex = sparseMatrix._index;\n var bptr = sparseMatrix._ptr;\n var bsize = sparseMatrix._size;\n var bdt = sparseMatrix._datatype; // validate dimensions\n\n if (asize.length !== bsize.length) {\n throw new _DimensionError.DimensionError(asize.length, bsize.length);\n } // check rows & columns\n\n\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) {\n throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')');\n } // sparse matrix cannot be a Pattern matrix\n\n\n if (!bvalues) {\n throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix');\n } // rows & columns\n\n\n var rows = asize[0];\n var columns = asize[1]; // process data types\n\n var dt = typeof adt === 'string' && adt === bdt ? adt : undefined; // callback function\n\n var cf = dt ? typed.find(callback, [dt, dt]) : callback; // vars\n\n var i, j; // result (DenseMatrix)\n\n var cdata = []; // initialize c\n\n for (i = 0; i < rows; i++) {\n cdata[i] = [];\n } // workspace\n\n\n var x = []; // marks indicating we have a value in x for a given column\n\n var w = []; // loop columns in b\n\n for (j = 0; j < columns; j++) {\n // column mark\n var mark = j + 1; // values in column j\n\n for (var k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = bindex[k]; // update workspace\n\n x[i] = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k]); // mark i as updated\n\n w[i] = mark;\n } // loop rows\n\n\n for (i = 0; i < rows; i++) {\n // check row is in workspace\n if (w[i] === mark) {\n // c[i][j] was already calculated\n cdata[i][j] = x[i];\n } else {\n // item does not exist in S\n cdata[i][j] = adata[i][j];\n }\n }\n } // return dense matrix\n\n\n return denseMatrix.createDenseMatrix({\n data: cdata,\n size: [rows, columns],\n datatype: dt\n });\n };\n});\nexports.createAlgorithm01 = createAlgorithm01;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm02 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _DimensionError = require(\"../../../error/DimensionError.js\");\n\nvar name = 'algorithm02';\nvar dependencies = ['typed', 'equalScalar'];\nvar createAlgorithm02 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n equalScalar = _ref.equalScalar;\n\n /**\n * Iterates over SparseMatrix nonzero items and invokes the callback function f(Dij, Sij).\n * Callback function invoked NNZ times (number of nonzero items in SparseMatrix).\n *\n *\n * ┌ f(Dij, Sij) ; S(i,j) !== 0\n * C(i,j) = ┤\n * └ 0 ; otherwise\n *\n *\n * @param {Matrix} denseMatrix The DenseMatrix instance (D)\n * @param {Matrix} sparseMatrix The SparseMatrix instance (S)\n * @param {Function} callback The f(Dij,Sij) operation to invoke, where Dij = DenseMatrix(i,j) and Sij = SparseMatrix(i,j)\n * @param {boolean} inverse A true value indicates callback should be invoked f(Sij,Dij)\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97477571\n */\n return function algorithm02(denseMatrix, sparseMatrix, callback, inverse) {\n // dense matrix arrays\n var adata = denseMatrix._data;\n var asize = denseMatrix._size;\n var adt = denseMatrix._datatype; // sparse matrix arrays\n\n var bvalues = sparseMatrix._values;\n var bindex = sparseMatrix._index;\n var bptr = sparseMatrix._ptr;\n var bsize = sparseMatrix._size;\n var bdt = sparseMatrix._datatype; // validate dimensions\n\n if (asize.length !== bsize.length) {\n throw new _DimensionError.DimensionError(asize.length, bsize.length);\n } // check rows & columns\n\n\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) {\n throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')');\n } // sparse matrix cannot be a Pattern matrix\n\n\n if (!bvalues) {\n throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix');\n } // rows & columns\n\n\n var rows = asize[0];\n var columns = asize[1]; // datatype\n\n var dt; // equal signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string' && adt === bdt) {\n // datatype\n dt = adt; // find signature that matches (dt, dt)\n\n eq = typed.find(equalScalar, [dt, dt]); // convert 0 to the same datatype\n\n zero = typed.convert(0, dt); // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // result (SparseMatrix)\n\n\n var cvalues = [];\n var cindex = [];\n var cptr = []; // loop columns in b\n\n for (var j = 0; j < columns; j++) {\n // update cptr\n cptr[j] = cindex.length; // values in column j\n\n for (var k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n // row\n var i = bindex[k]; // update C(i,j)\n\n var cij = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k]); // check for nonzero\n\n if (!eq(cij, zero)) {\n // push i & v\n cindex.push(i);\n cvalues.push(cij);\n }\n }\n } // update cptr\n\n\n cptr[columns] = cindex.length; // return sparse matrix\n\n return sparseMatrix.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: dt\n });\n };\n});\nexports.createAlgorithm02 = createAlgorithm02;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm03 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _DimensionError = require(\"../../../error/DimensionError.js\");\n\nvar name = 'algorithm03';\nvar dependencies = ['typed'];\nvar createAlgorithm03 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Iterates over SparseMatrix items and invokes the callback function f(Dij, Sij).\n * Callback function invoked M*N times.\n *\n *\n * ┌ f(Dij, Sij) ; S(i,j) !== 0\n * C(i,j) = ┤\n * └ f(Dij, 0) ; otherwise\n *\n *\n * @param {Matrix} denseMatrix The DenseMatrix instance (D)\n * @param {Matrix} sparseMatrix The SparseMatrix instance (C)\n * @param {Function} callback The f(Dij,Sij) operation to invoke, where Dij = DenseMatrix(i,j) and Sij = SparseMatrix(i,j)\n * @param {boolean} inverse A true value indicates callback should be invoked f(Sij,Dij)\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97477571\n */\n return function algorithm03(denseMatrix, sparseMatrix, callback, inverse) {\n // dense matrix arrays\n var adata = denseMatrix._data;\n var asize = denseMatrix._size;\n var adt = denseMatrix._datatype; // sparse matrix arrays\n\n var bvalues = sparseMatrix._values;\n var bindex = sparseMatrix._index;\n var bptr = sparseMatrix._ptr;\n var bsize = sparseMatrix._size;\n var bdt = sparseMatrix._datatype; // validate dimensions\n\n if (asize.length !== bsize.length) {\n throw new _DimensionError.DimensionError(asize.length, bsize.length);\n } // check rows & columns\n\n\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) {\n throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')');\n } // sparse matrix cannot be a Pattern matrix\n\n\n if (!bvalues) {\n throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix');\n } // rows & columns\n\n\n var rows = asize[0];\n var columns = asize[1]; // datatype\n\n var dt; // zero value\n\n var zero = 0; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string' && adt === bdt) {\n // datatype\n dt = adt; // convert 0 to the same datatype\n\n zero = typed.convert(0, dt); // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // result (DenseMatrix)\n\n\n var cdata = []; // initialize dense matrix\n\n for (var z = 0; z < rows; z++) {\n // initialize row\n cdata[z] = [];\n } // workspace\n\n\n var x = []; // marks indicating we have a value in x for a given column\n\n var w = []; // loop columns in b\n\n for (var j = 0; j < columns; j++) {\n // column mark\n var mark = j + 1; // values in column j\n\n for (var k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n // row\n var i = bindex[k]; // update workspace\n\n x[i] = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k]);\n w[i] = mark;\n } // process workspace\n\n\n for (var y = 0; y < rows; y++) {\n // check we have a calculated value for current row\n if (w[y] === mark) {\n // use calculated value\n cdata[y][j] = x[y];\n } else {\n // calculate value\n cdata[y][j] = inverse ? cf(zero, adata[y][j]) : cf(adata[y][j], zero);\n }\n }\n } // return dense matrix\n\n\n return denseMatrix.createDenseMatrix({\n data: cdata,\n size: [rows, columns],\n datatype: dt\n });\n };\n});\nexports.createAlgorithm03 = createAlgorithm03;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm04 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _DimensionError = require(\"../../../error/DimensionError.js\");\n\nvar name = 'algorithm04';\nvar dependencies = ['typed', 'equalScalar'];\nvar createAlgorithm04 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n equalScalar = _ref.equalScalar;\n\n /**\n * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij).\n * Callback function invoked MAX(NNZA, NNZB) times\n *\n *\n * ┌ f(Aij, Bij) ; A(i,j) !== 0 && B(i,j) !== 0\n * C(i,j) = ┤ A(i,j) ; A(i,j) !== 0\n * └ B(i,j) ; B(i,j) !== 0\n *\n *\n * @param {Matrix} a The SparseMatrix instance (A)\n * @param {Matrix} b The SparseMatrix instance (B)\n * @param {Function} callback The f(Aij,Bij) operation to invoke\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294\n */\n return function algorithm04(a, b, callback) {\n // sparse matrix arrays\n var avalues = a._values;\n var aindex = a._index;\n var aptr = a._ptr;\n var asize = a._size;\n var adt = a._datatype; // sparse matrix arrays\n\n var bvalues = b._values;\n var bindex = b._index;\n var bptr = b._ptr;\n var bsize = b._size;\n var bdt = b._datatype; // validate dimensions\n\n if (asize.length !== bsize.length) {\n throw new _DimensionError.DimensionError(asize.length, bsize.length);\n } // check rows & columns\n\n\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) {\n throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')');\n } // rows & columns\n\n\n var rows = asize[0];\n var columns = asize[1]; // datatype\n\n var dt; // equal signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string' && adt === bdt) {\n // datatype\n dt = adt; // find signature that matches (dt, dt)\n\n eq = typed.find(equalScalar, [dt, dt]); // convert 0 to the same datatype\n\n zero = typed.convert(0, dt); // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // result arrays\n\n\n var cvalues = avalues && bvalues ? [] : undefined;\n var cindex = [];\n var cptr = []; // workspace\n\n var xa = avalues && bvalues ? [] : undefined;\n var xb = avalues && bvalues ? [] : undefined; // marks indicating we have a value in x for a given column\n\n var wa = [];\n var wb = []; // vars\n\n var i, j, k, k0, k1; // loop columns\n\n for (j = 0; j < columns; j++) {\n // update cptr\n cptr[j] = cindex.length; // columns mark\n\n var mark = j + 1; // loop A(:,j)\n\n for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = aindex[k]; // update c\n\n cindex.push(i); // update workspace\n\n wa[i] = mark; // check we need to process values\n\n if (xa) {\n xa[i] = avalues[k];\n }\n } // loop B(:,j)\n\n\n for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = bindex[k]; // check row exists in A\n\n if (wa[i] === mark) {\n // update record in xa @ i\n if (xa) {\n // invoke callback\n var v = cf(xa[i], bvalues[k]); // check for zero\n\n if (!eq(v, zero)) {\n // update workspace\n xa[i] = v;\n } else {\n // remove mark (index will be removed later)\n wa[i] = null;\n }\n }\n } else {\n // update c\n cindex.push(i); // update workspace\n\n wb[i] = mark; // check we need to process values\n\n if (xb) {\n xb[i] = bvalues[k];\n }\n }\n } // check we need to process values (non pattern matrix)\n\n\n if (xa && xb) {\n // initialize first index in j\n k = cptr[j]; // loop index in j\n\n while (k < cindex.length) {\n // row\n i = cindex[k]; // check workspace has value @ i\n\n if (wa[i] === mark) {\n // push value (Aij != 0 || (Aij != 0 && Bij != 0))\n cvalues[k] = xa[i]; // increment pointer\n\n k++;\n } else if (wb[i] === mark) {\n // push value (bij != 0)\n cvalues[k] = xb[i]; // increment pointer\n\n k++;\n } else {\n // remove index @ k\n cindex.splice(k, 1);\n }\n }\n }\n } // update cptr\n\n\n cptr[columns] = cindex.length; // return sparse matrix\n\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: dt\n });\n };\n});\nexports.createAlgorithm04 = createAlgorithm04;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm05 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _DimensionError = require(\"../../../error/DimensionError.js\");\n\nvar name = 'algorithm05';\nvar dependencies = ['typed', 'equalScalar'];\nvar createAlgorithm05 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n equalScalar = _ref.equalScalar;\n\n /**\n * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij).\n * Callback function invoked MAX(NNZA, NNZB) times\n *\n *\n * ┌ f(Aij, Bij) ; A(i,j) !== 0 || B(i,j) !== 0\n * C(i,j) = ┤\n * └ 0 ; otherwise\n *\n *\n * @param {Matrix} a The SparseMatrix instance (A)\n * @param {Matrix} b The SparseMatrix instance (B)\n * @param {Function} callback The f(Aij,Bij) operation to invoke\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294\n */\n return function algorithm05(a, b, callback) {\n // sparse matrix arrays\n var avalues = a._values;\n var aindex = a._index;\n var aptr = a._ptr;\n var asize = a._size;\n var adt = a._datatype; // sparse matrix arrays\n\n var bvalues = b._values;\n var bindex = b._index;\n var bptr = b._ptr;\n var bsize = b._size;\n var bdt = b._datatype; // validate dimensions\n\n if (asize.length !== bsize.length) {\n throw new _DimensionError.DimensionError(asize.length, bsize.length);\n } // check rows & columns\n\n\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) {\n throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')');\n } // rows & columns\n\n\n var rows = asize[0];\n var columns = asize[1]; // datatype\n\n var dt; // equal signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string' && adt === bdt) {\n // datatype\n dt = adt; // find signature that matches (dt, dt)\n\n eq = typed.find(equalScalar, [dt, dt]); // convert 0 to the same datatype\n\n zero = typed.convert(0, dt); // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // result arrays\n\n\n var cvalues = avalues && bvalues ? [] : undefined;\n var cindex = [];\n var cptr = []; // workspaces\n\n var xa = cvalues ? [] : undefined;\n var xb = cvalues ? [] : undefined; // marks indicating we have a value in x for a given column\n\n var wa = [];\n var wb = []; // vars\n\n var i, j, k, k1; // loop columns\n\n for (j = 0; j < columns; j++) {\n // update cptr\n cptr[j] = cindex.length; // columns mark\n\n var mark = j + 1; // loop values A(:,j)\n\n for (k = aptr[j], k1 = aptr[j + 1]; k < k1; k++) {\n // row\n i = aindex[k]; // push index\n\n cindex.push(i); // update workspace\n\n wa[i] = mark; // check we need to process values\n\n if (xa) {\n xa[i] = avalues[k];\n }\n } // loop values B(:,j)\n\n\n for (k = bptr[j], k1 = bptr[j + 1]; k < k1; k++) {\n // row\n i = bindex[k]; // check row existed in A\n\n if (wa[i] !== mark) {\n // push index\n cindex.push(i);\n } // update workspace\n\n\n wb[i] = mark; // check we need to process values\n\n if (xb) {\n xb[i] = bvalues[k];\n }\n } // check we need to process values (non pattern matrix)\n\n\n if (cvalues) {\n // initialize first index in j\n k = cptr[j]; // loop index in j\n\n while (k < cindex.length) {\n // row\n i = cindex[k]; // marks\n\n var wai = wa[i];\n var wbi = wb[i]; // check Aij or Bij are nonzero\n\n if (wai === mark || wbi === mark) {\n // matrix values @ i,j\n var va = wai === mark ? xa[i] : zero;\n var vb = wbi === mark ? xb[i] : zero; // Cij\n\n var vc = cf(va, vb); // check for zero\n\n if (!eq(vc, zero)) {\n // push value\n cvalues.push(vc); // increment pointer\n\n k++;\n } else {\n // remove value @ i, do not increment pointer\n cindex.splice(k, 1);\n }\n }\n }\n }\n } // update cptr\n\n\n cptr[columns] = cindex.length; // return sparse matrix\n\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: dt\n });\n };\n});\nexports.createAlgorithm05 = createAlgorithm05;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm06 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _DimensionError = require(\"../../../error/DimensionError.js\");\n\nvar _collection = require(\"../../../utils/collection.js\");\n\nvar name = 'algorithm06';\nvar dependencies = ['typed', 'equalScalar'];\nvar createAlgorithm06 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n equalScalar = _ref.equalScalar;\n\n /**\n * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij).\n * Callback function invoked (Anz U Bnz) times, where Anz and Bnz are the nonzero elements in both matrices.\n *\n *\n * ┌ f(Aij, Bij) ; A(i,j) !== 0 && B(i,j) !== 0\n * C(i,j) = ┤\n * └ 0 ; otherwise\n *\n *\n * @param {Matrix} a The SparseMatrix instance (A)\n * @param {Matrix} b The SparseMatrix instance (B)\n * @param {Function} callback The f(Aij,Bij) operation to invoke\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294\n */\n return function algorithm06(a, b, callback) {\n // sparse matrix arrays\n var avalues = a._values;\n var asize = a._size;\n var adt = a._datatype; // sparse matrix arrays\n\n var bvalues = b._values;\n var bsize = b._size;\n var bdt = b._datatype; // validate dimensions\n\n if (asize.length !== bsize.length) {\n throw new _DimensionError.DimensionError(asize.length, bsize.length);\n } // check rows & columns\n\n\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) {\n throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')');\n } // rows & columns\n\n\n var rows = asize[0];\n var columns = asize[1]; // datatype\n\n var dt; // equal signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string' && adt === bdt) {\n // datatype\n dt = adt; // find signature that matches (dt, dt)\n\n eq = typed.find(equalScalar, [dt, dt]); // convert 0 to the same datatype\n\n zero = typed.convert(0, dt); // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // result arrays\n\n\n var cvalues = avalues && bvalues ? [] : undefined;\n var cindex = [];\n var cptr = []; // workspaces\n\n var x = cvalues ? [] : undefined; // marks indicating we have a value in x for a given column\n\n var w = []; // marks indicating value in a given row has been updated\n\n var u = []; // loop columns\n\n for (var j = 0; j < columns; j++) {\n // update cptr\n cptr[j] = cindex.length; // columns mark\n\n var mark = j + 1; // scatter the values of A(:,j) into workspace\n\n (0, _collection.scatter)(a, j, w, x, u, mark, cindex, cf); // scatter the values of B(:,j) into workspace\n\n (0, _collection.scatter)(b, j, w, x, u, mark, cindex, cf); // check we need to process values (non pattern matrix)\n\n if (x) {\n // initialize first index in j\n var k = cptr[j]; // loop index in j\n\n while (k < cindex.length) {\n // row\n var i = cindex[k]; // check function was invoked on current row (Aij !=0 && Bij != 0)\n\n if (u[i] === mark) {\n // value @ i\n var v = x[i]; // check for zero value\n\n if (!eq(v, zero)) {\n // push value\n cvalues.push(v); // increment pointer\n\n k++;\n } else {\n // remove value @ i, do not increment pointer\n cindex.splice(k, 1);\n }\n } else {\n // remove value @ i, do not increment pointer\n cindex.splice(k, 1);\n }\n }\n } else {\n // initialize first index in j\n var p = cptr[j]; // loop index in j\n\n while (p < cindex.length) {\n // row\n var r = cindex[p]; // check function was invoked on current row (Aij !=0 && Bij != 0)\n\n if (u[r] !== mark) {\n // remove value @ i, do not increment pointer\n cindex.splice(p, 1);\n } else {\n // increment pointer\n p++;\n }\n }\n }\n } // update cptr\n\n\n cptr[columns] = cindex.length; // return sparse matrix\n\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: dt\n });\n };\n});\nexports.createAlgorithm06 = createAlgorithm06;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm07 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _DimensionError = require(\"../../../error/DimensionError.js\");\n\nvar name = 'algorithm07';\nvar dependencies = ['typed', 'DenseMatrix'];\nvar createAlgorithm07 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n DenseMatrix = _ref.DenseMatrix;\n\n /**\n * Iterates over SparseMatrix A and SparseMatrix B items (zero and nonzero) and invokes the callback function f(Aij, Bij).\n * Callback function invoked MxN times.\n *\n * C(i,j) = f(Aij, Bij)\n *\n * @param {Matrix} a The SparseMatrix instance (A)\n * @param {Matrix} b The SparseMatrix instance (B)\n * @param {Function} callback The f(Aij,Bij) operation to invoke\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294\n */\n return function algorithm07(a, b, callback) {\n // sparse matrix arrays\n var asize = a._size;\n var adt = a._datatype; // sparse matrix arrays\n\n var bsize = b._size;\n var bdt = b._datatype; // validate dimensions\n\n if (asize.length !== bsize.length) {\n throw new _DimensionError.DimensionError(asize.length, bsize.length);\n } // check rows & columns\n\n\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) {\n throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')');\n } // rows & columns\n\n\n var rows = asize[0];\n var columns = asize[1]; // datatype\n\n var dt; // zero value\n\n var zero = 0; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string' && adt === bdt) {\n // datatype\n dt = adt; // convert 0 to the same datatype\n\n zero = typed.convert(0, dt); // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // vars\n\n\n var i, j; // result arrays\n\n var cdata = []; // initialize c\n\n for (i = 0; i < rows; i++) {\n cdata[i] = [];\n } // workspaces\n\n\n var xa = [];\n var xb = []; // marks indicating we have a value in x for a given column\n\n var wa = [];\n var wb = []; // loop columns\n\n for (j = 0; j < columns; j++) {\n // columns mark\n var mark = j + 1; // scatter the values of A(:,j) into workspace\n\n _scatter(a, j, wa, xa, mark); // scatter the values of B(:,j) into workspace\n\n\n _scatter(b, j, wb, xb, mark); // loop rows\n\n\n for (i = 0; i < rows; i++) {\n // matrix values @ i,j\n var va = wa[i] === mark ? xa[i] : zero;\n var vb = wb[i] === mark ? xb[i] : zero; // invoke callback\n\n cdata[i][j] = cf(va, vb);\n }\n } // return dense matrix\n\n\n return new DenseMatrix({\n data: cdata,\n size: [rows, columns],\n datatype: dt\n });\n };\n\n function _scatter(m, j, w, x, mark) {\n // a arrays\n var values = m._values;\n var index = m._index;\n var ptr = m._ptr; // loop values in column j\n\n for (var k = ptr[j], k1 = ptr[j + 1]; k < k1; k++) {\n // row\n var i = index[k]; // update workspace\n\n w[i] = mark;\n x[i] = values[k];\n }\n }\n});\nexports.createAlgorithm07 = createAlgorithm07;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm08 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _DimensionError = require(\"../../../error/DimensionError.js\");\n\nvar name = 'algorithm08';\nvar dependencies = ['typed', 'equalScalar'];\nvar createAlgorithm08 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n equalScalar = _ref.equalScalar;\n\n /**\n * Iterates over SparseMatrix A and SparseMatrix B nonzero items and invokes the callback function f(Aij, Bij).\n * Callback function invoked MAX(NNZA, NNZB) times\n *\n *\n * ┌ f(Aij, Bij) ; A(i,j) !== 0 && B(i,j) !== 0\n * C(i,j) = ┤ A(i,j) ; A(i,j) !== 0\n * └ 0 ; otherwise\n *\n *\n * @param {Matrix} a The SparseMatrix instance (A)\n * @param {Matrix} b The SparseMatrix instance (B)\n * @param {Function} callback The f(Aij,Bij) operation to invoke\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294\n */\n return function algorithm08(a, b, callback) {\n // sparse matrix arrays\n var avalues = a._values;\n var aindex = a._index;\n var aptr = a._ptr;\n var asize = a._size;\n var adt = a._datatype; // sparse matrix arrays\n\n var bvalues = b._values;\n var bindex = b._index;\n var bptr = b._ptr;\n var bsize = b._size;\n var bdt = b._datatype; // validate dimensions\n\n if (asize.length !== bsize.length) {\n throw new _DimensionError.DimensionError(asize.length, bsize.length);\n } // check rows & columns\n\n\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) {\n throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')');\n } // sparse matrix cannot be a Pattern matrix\n\n\n if (!avalues || !bvalues) {\n throw new Error('Cannot perform operation on Pattern Sparse Matrices');\n } // rows & columns\n\n\n var rows = asize[0];\n var columns = asize[1]; // datatype\n\n var dt; // equal signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string' && adt === bdt) {\n // datatype\n dt = adt; // find signature that matches (dt, dt)\n\n eq = typed.find(equalScalar, [dt, dt]); // convert 0 to the same datatype\n\n zero = typed.convert(0, dt); // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // result arrays\n\n\n var cvalues = [];\n var cindex = [];\n var cptr = []; // workspace\n\n var x = []; // marks indicating we have a value in x for a given column\n\n var w = []; // vars\n\n var k, k0, k1, i; // loop columns\n\n for (var j = 0; j < columns; j++) {\n // update cptr\n cptr[j] = cindex.length; // columns mark\n\n var mark = j + 1; // loop values in a\n\n for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = aindex[k]; // mark workspace\n\n w[i] = mark; // set value\n\n x[i] = avalues[k]; // add index\n\n cindex.push(i);\n } // loop values in b\n\n\n for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = bindex[k]; // check value exists in workspace\n\n if (w[i] === mark) {\n // evaluate callback\n x[i] = cf(x[i], bvalues[k]);\n }\n } // initialize first index in j\n\n\n k = cptr[j]; // loop index in j\n\n while (k < cindex.length) {\n // row\n i = cindex[k]; // value @ i\n\n var v = x[i]; // check for zero value\n\n if (!eq(v, zero)) {\n // push value\n cvalues.push(v); // increment pointer\n\n k++;\n } else {\n // remove value @ i, do not increment pointer\n cindex.splice(k, 1);\n }\n }\n } // update cptr\n\n\n cptr[columns] = cindex.length; // return sparse matrix\n\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: dt\n });\n };\n});\nexports.createAlgorithm08 = createAlgorithm08;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm09 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _DimensionError = require(\"../../../error/DimensionError.js\");\n\nvar name = 'algorithm09';\nvar dependencies = ['typed', 'equalScalar'];\nvar createAlgorithm09 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n equalScalar = _ref.equalScalar;\n\n /**\n * Iterates over SparseMatrix A and invokes the callback function f(Aij, Bij).\n * Callback function invoked NZA times, number of nonzero elements in A.\n *\n *\n * ┌ f(Aij, Bij) ; A(i,j) !== 0\n * C(i,j) = ┤\n * └ 0 ; otherwise\n *\n *\n * @param {Matrix} a The SparseMatrix instance (A)\n * @param {Matrix} b The SparseMatrix instance (B)\n * @param {Function} callback The f(Aij,Bij) operation to invoke\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * see https://github.com/josdejong/mathjs/pull/346#issuecomment-97620294\n */\n return function algorithm09(a, b, callback) {\n // sparse matrix arrays\n var avalues = a._values;\n var aindex = a._index;\n var aptr = a._ptr;\n var asize = a._size;\n var adt = a._datatype; // sparse matrix arrays\n\n var bvalues = b._values;\n var bindex = b._index;\n var bptr = b._ptr;\n var bsize = b._size;\n var bdt = b._datatype; // validate dimensions\n\n if (asize.length !== bsize.length) {\n throw new _DimensionError.DimensionError(asize.length, bsize.length);\n } // check rows & columns\n\n\n if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) {\n throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')');\n } // rows & columns\n\n\n var rows = asize[0];\n var columns = asize[1]; // datatype\n\n var dt; // equal signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string' && adt === bdt) {\n // datatype\n dt = adt; // find signature that matches (dt, dt)\n\n eq = typed.find(equalScalar, [dt, dt]); // convert 0 to the same datatype\n\n zero = typed.convert(0, dt); // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // result arrays\n\n\n var cvalues = avalues && bvalues ? [] : undefined;\n var cindex = [];\n var cptr = []; // workspaces\n\n var x = cvalues ? [] : undefined; // marks indicating we have a value in x for a given column\n\n var w = []; // vars\n\n var i, j, k, k0, k1; // loop columns\n\n for (j = 0; j < columns; j++) {\n // update cptr\n cptr[j] = cindex.length; // column mark\n\n var mark = j + 1; // check we need to process values\n\n if (x) {\n // loop B(:,j)\n for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = bindex[k]; // update workspace\n\n w[i] = mark;\n x[i] = bvalues[k];\n }\n } // loop A(:,j)\n\n\n for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = aindex[k]; // check we need to process values\n\n if (x) {\n // b value @ i,j\n var vb = w[i] === mark ? x[i] : zero; // invoke f\n\n var vc = cf(avalues[k], vb); // check zero value\n\n if (!eq(vc, zero)) {\n // push index\n cindex.push(i); // push value\n\n cvalues.push(vc);\n }\n } else {\n // push index\n cindex.push(i);\n }\n }\n } // update cptr\n\n\n cptr[columns] = cindex.length; // return sparse matrix\n\n return a.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: dt\n });\n };\n});\nexports.createAlgorithm09 = createAlgorithm09;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm10 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar name = 'algorithm10';\nvar dependencies = ['typed', 'DenseMatrix'];\nvar createAlgorithm10 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n DenseMatrix = _ref.DenseMatrix;\n\n /**\n * Iterates over SparseMatrix S nonzero items and invokes the callback function f(Sij, b).\n * Callback function invoked NZ times (number of nonzero items in S).\n *\n *\n * ┌ f(Sij, b) ; S(i,j) !== 0\n * C(i,j) = ┤\n * └ b ; otherwise\n *\n *\n * @param {Matrix} s The SparseMatrix instance (S)\n * @param {Scalar} b The Scalar value\n * @param {Function} callback The f(Aij,b) operation to invoke\n * @param {boolean} inverse A true value indicates callback should be invoked f(b,Sij)\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * https://github.com/josdejong/mathjs/pull/346#issuecomment-97626813\n */\n return function algorithm10(s, b, callback, inverse) {\n // sparse matrix arrays\n var avalues = s._values;\n var aindex = s._index;\n var aptr = s._ptr;\n var asize = s._size;\n var adt = s._datatype; // sparse matrix cannot be a Pattern matrix\n\n if (!avalues) {\n throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value');\n } // rows & columns\n\n\n var rows = asize[0];\n var columns = asize[1]; // datatype\n\n var dt; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string') {\n // datatype\n dt = adt; // convert b to the same datatype\n\n b = typed.convert(b, dt); // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // result arrays\n\n\n var cdata = []; // workspaces\n\n var x = []; // marks indicating we have a value in x for a given column\n\n var w = []; // loop columns\n\n for (var j = 0; j < columns; j++) {\n // columns mark\n var mark = j + 1; // values in j\n\n for (var k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n var r = aindex[k]; // update workspace\n\n x[r] = avalues[k];\n w[r] = mark;\n } // loop rows\n\n\n for (var i = 0; i < rows; i++) {\n // initialize C on first column\n if (j === 0) {\n // create row array\n cdata[i] = [];\n } // check sparse matrix has a value @ i,j\n\n\n if (w[i] === mark) {\n // invoke callback, update C\n cdata[i][j] = inverse ? cf(b, x[i]) : cf(x[i], b);\n } else {\n // dense matrix value @ i, j\n cdata[i][j] = b;\n }\n }\n } // return dense matrix\n\n\n return new DenseMatrix({\n data: cdata,\n size: [rows, columns],\n datatype: dt\n });\n };\n});\nexports.createAlgorithm10 = createAlgorithm10;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm11 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar name = 'algorithm11';\nvar dependencies = ['typed', 'equalScalar'];\nvar createAlgorithm11 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n equalScalar = _ref.equalScalar;\n\n /**\n * Iterates over SparseMatrix S nonzero items and invokes the callback function f(Sij, b).\n * Callback function invoked NZ times (number of nonzero items in S).\n *\n *\n * ┌ f(Sij, b) ; S(i,j) !== 0\n * C(i,j) = ┤\n * └ 0 ; otherwise\n *\n *\n * @param {Matrix} s The SparseMatrix instance (S)\n * @param {Scalar} b The Scalar value\n * @param {Function} callback The f(Aij,b) operation to invoke\n * @param {boolean} inverse A true value indicates callback should be invoked f(b,Sij)\n *\n * @return {Matrix} SparseMatrix (C)\n *\n * https://github.com/josdejong/mathjs/pull/346#issuecomment-97626813\n */\n return function algorithm11(s, b, callback, inverse) {\n // sparse matrix arrays\n var avalues = s._values;\n var aindex = s._index;\n var aptr = s._ptr;\n var asize = s._size;\n var adt = s._datatype; // sparse matrix cannot be a Pattern matrix\n\n if (!avalues) {\n throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value');\n } // rows & columns\n\n\n var rows = asize[0];\n var columns = asize[1]; // datatype\n\n var dt; // equal signature to use\n\n var eq = equalScalar; // zero value\n\n var zero = 0; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string') {\n // datatype\n dt = adt; // find signature that matches (dt, dt)\n\n eq = typed.find(equalScalar, [dt, dt]); // convert 0 to the same datatype\n\n zero = typed.convert(0, dt); // convert b to the same datatype\n\n b = typed.convert(b, dt); // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // result arrays\n\n\n var cvalues = [];\n var cindex = [];\n var cptr = []; // loop columns\n\n for (var j = 0; j < columns; j++) {\n // initialize ptr\n cptr[j] = cindex.length; // values in j\n\n for (var k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n var i = aindex[k]; // invoke callback\n\n var v = inverse ? cf(b, avalues[k]) : cf(avalues[k], b); // check value is zero\n\n if (!eq(v, zero)) {\n // push index & value\n cindex.push(i);\n cvalues.push(v);\n }\n }\n } // update ptr\n\n\n cptr[columns] = cindex.length; // return sparse matrix\n\n return s.createSparseMatrix({\n values: cvalues,\n index: cindex,\n ptr: cptr,\n size: [rows, columns],\n datatype: dt\n });\n };\n});\nexports.createAlgorithm11 = createAlgorithm11;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm12 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar name = 'algorithm12';\nvar dependencies = ['typed', 'DenseMatrix'];\nvar createAlgorithm12 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n DenseMatrix = _ref.DenseMatrix;\n\n /**\n * Iterates over SparseMatrix S nonzero items and invokes the callback function f(Sij, b).\n * Callback function invoked MxN times.\n *\n *\n * ┌ f(Sij, b) ; S(i,j) !== 0\n * C(i,j) = ┤\n * └ f(0, b) ; otherwise\n *\n *\n * @param {Matrix} s The SparseMatrix instance (S)\n * @param {Scalar} b The Scalar value\n * @param {Function} callback The f(Aij,b) operation to invoke\n * @param {boolean} inverse A true value indicates callback should be invoked f(b,Sij)\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * https://github.com/josdejong/mathjs/pull/346#issuecomment-97626813\n */\n return function algorithm12(s, b, callback, inverse) {\n // sparse matrix arrays\n var avalues = s._values;\n var aindex = s._index;\n var aptr = s._ptr;\n var asize = s._size;\n var adt = s._datatype; // sparse matrix cannot be a Pattern matrix\n\n if (!avalues) {\n throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value');\n } // rows & columns\n\n\n var rows = asize[0];\n var columns = asize[1]; // datatype\n\n var dt; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string') {\n // datatype\n dt = adt; // convert b to the same datatype\n\n b = typed.convert(b, dt); // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // result arrays\n\n\n var cdata = []; // workspaces\n\n var x = []; // marks indicating we have a value in x for a given column\n\n var w = []; // loop columns\n\n for (var j = 0; j < columns; j++) {\n // columns mark\n var mark = j + 1; // values in j\n\n for (var k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n var r = aindex[k]; // update workspace\n\n x[r] = avalues[k];\n w[r] = mark;\n } // loop rows\n\n\n for (var i = 0; i < rows; i++) {\n // initialize C on first column\n if (j === 0) {\n // create row array\n cdata[i] = [];\n } // check sparse matrix has a value @ i,j\n\n\n if (w[i] === mark) {\n // invoke callback, update C\n cdata[i][j] = inverse ? cf(b, x[i]) : cf(x[i], b);\n } else {\n // dense matrix value @ i, j\n cdata[i][j] = inverse ? cf(b, 0) : cf(0, b);\n }\n }\n } // return dense matrix\n\n\n return new DenseMatrix({\n data: cdata,\n size: [rows, columns],\n datatype: dt\n });\n };\n});\nexports.createAlgorithm12 = createAlgorithm12;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm13 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _DimensionError = require(\"../../../error/DimensionError.js\");\n\nvar name = 'algorithm13';\nvar dependencies = ['typed'];\nvar createAlgorithm13 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Iterates over DenseMatrix items and invokes the callback function f(Aij..z, Bij..z).\n * Callback function invoked MxN times.\n *\n * C(i,j,...z) = f(Aij..z, Bij..z)\n *\n * @param {Matrix} a The DenseMatrix instance (A)\n * @param {Matrix} b The DenseMatrix instance (B)\n * @param {Function} callback The f(Aij..z,Bij..z) operation to invoke\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * https://github.com/josdejong/mathjs/pull/346#issuecomment-97658658\n */\n return function algorithm13(a, b, callback) {\n // a arrays\n var adata = a._data;\n var asize = a._size;\n var adt = a._datatype; // b arrays\n\n var bdata = b._data;\n var bsize = b._size;\n var bdt = b._datatype; // c arrays\n\n var csize = []; // validate dimensions\n\n if (asize.length !== bsize.length) {\n throw new _DimensionError.DimensionError(asize.length, bsize.length);\n } // validate each one of the dimension sizes\n\n\n for (var s = 0; s < asize.length; s++) {\n // must match\n if (asize[s] !== bsize[s]) {\n throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')');\n } // update dimension in c\n\n\n csize[s] = asize[s];\n } // datatype\n\n\n var dt; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string' && adt === bdt) {\n // datatype\n dt = adt; // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // populate cdata, iterate through dimensions\n\n\n var cdata = csize.length > 0 ? _iterate(cf, 0, csize, csize[0], adata, bdata) : []; // c matrix\n\n return a.createDenseMatrix({\n data: cdata,\n size: csize,\n datatype: dt\n });\n }; // recursive function\n\n function _iterate(f, level, s, n, av, bv) {\n // initialize array for this level\n var cv = []; // check we reach the last level\n\n if (level === s.length - 1) {\n // loop arrays in last level\n for (var i = 0; i < n; i++) {\n // invoke callback and store value\n cv[i] = f(av[i], bv[i]);\n }\n } else {\n // iterate current level\n for (var j = 0; j < n; j++) {\n // iterate next level\n cv[j] = _iterate(f, level + 1, s, s[level + 1], av[j], bv[j]);\n }\n }\n\n return cv;\n }\n});\nexports.createAlgorithm13 = createAlgorithm13;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAlgorithm14 = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _object = require(\"../../../utils/object.js\");\n\nvar name = 'algorithm14';\nvar dependencies = ['typed'];\nvar createAlgorithm14 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Iterates over DenseMatrix items and invokes the callback function f(Aij..z, b).\n * Callback function invoked MxN times.\n *\n * C(i,j,...z) = f(Aij..z, b)\n *\n * @param {Matrix} a The DenseMatrix instance (A)\n * @param {Scalar} b The Scalar value\n * @param {Function} callback The f(Aij..z,b) operation to invoke\n * @param {boolean} inverse A true value indicates callback should be invoked f(b,Aij..z)\n *\n * @return {Matrix} DenseMatrix (C)\n *\n * https://github.com/josdejong/mathjs/pull/346#issuecomment-97659042\n */\n return function algorithm14(a, b, callback, inverse) {\n // a arrays\n var adata = a._data;\n var asize = a._size;\n var adt = a._datatype; // datatype\n\n var dt; // callback signature to use\n\n var cf = callback; // process data types\n\n if (typeof adt === 'string') {\n // datatype\n dt = adt; // convert b to the same datatype\n\n b = typed.convert(b, dt); // callback\n\n cf = typed.find(callback, [dt, dt]);\n } // populate cdata, iterate through dimensions\n\n\n var cdata = asize.length > 0 ? _iterate(cf, 0, asize, asize[0], adata, b, inverse) : []; // c matrix\n\n return a.createDenseMatrix({\n data: cdata,\n size: (0, _object.clone)(asize),\n datatype: dt\n });\n }; // recursive function\n\n function _iterate(f, level, s, n, av, bv, inverse) {\n // initialize array for this level\n var cv = []; // check we reach the last level\n\n if (level === s.length - 1) {\n // loop arrays in last level\n for (var i = 0; i < n; i++) {\n // invoke callback and store value\n cv[i] = inverse ? f(bv, av[i]) : f(av[i], bv);\n }\n } else {\n // iterate current level\n for (var j = 0; j < n; j++) {\n // iterate next level\n cv[j] = _iterate(f, level + 1, s, s[level + 1], av[j], bv, inverse);\n }\n }\n\n return cv;\n }\n});\nexports.createAlgorithm14 = createAlgorithm14;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createNumber = void 0;\n\nvar _factory = require(\"../utils/factory.js\");\n\nvar _collection = require(\"../utils/collection.js\");\n\nvar name = 'number';\nvar dependencies = ['typed'];\n/**\n * Separates the radix, integer part, and fractional part of a non decimal number string\n * @param {string} input string to parse\n * @returns {object} the parts of the string or null if not a valid input\n */\n\nfunction getNonDecimalNumberParts(input) {\n var nonDecimalWithRadixMatch = input.match(/(0[box])([0-9a-fA-F]*)\\.([0-9a-fA-F]*)/);\n\n if (nonDecimalWithRadixMatch) {\n var radix = {\n '0b': 2,\n '0o': 8,\n '0x': 16\n }[nonDecimalWithRadixMatch[1]];\n var integerPart = nonDecimalWithRadixMatch[2];\n var fractionalPart = nonDecimalWithRadixMatch[3];\n return {\n input: input,\n radix: radix,\n integerPart: integerPart,\n fractionalPart: fractionalPart\n };\n } else {\n return null;\n }\n}\n/**\n * Makes a number from a radix, and integer part, and a fractional part\n * @param {parts} [x] parts of the number string (from getNonDecimalNumberParts)\n * @returns {number} the number\n */\n\n\nfunction makeNumberFromNonDecimalParts(parts) {\n var n = parseInt(parts.integerPart, parts.radix);\n var f = 0;\n\n for (var i = 0; i < parts.fractionalPart.length; i++) {\n var digitValue = parseInt(parts.fractionalPart[i], parts.radix);\n f += digitValue / Math.pow(parts.radix, i + 1);\n }\n\n var result = n + f;\n\n if (isNaN(result)) {\n throw new SyntaxError('String \"' + parts.input + '\" is no valid number');\n }\n\n return result;\n}\n\nvar createNumber = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Create a number or convert a string, boolean, or unit to a number.\n * When value is a matrix, all elements will be converted to number.\n *\n * Syntax:\n *\n * math.number(value)\n * math.number(unit, valuelessUnit)\n *\n * Examples:\n *\n * math.number(2) // returns number 2\n * math.number('7.2') // returns number 7.2\n * math.number(true) // returns number 1\n * math.number([true, false, true, true]) // returns [1, 0, 1, 1]\n * math.number(math.unit('52cm'), 'm') // returns 0.52\n *\n * See also:\n *\n * bignumber, boolean, complex, index, matrix, string, unit\n *\n * @param {string | number | BigNumber | Fraction | boolean | Array | Matrix | Unit | null} [value] Value to be converted\n * @param {Unit | string} [valuelessUnit] A valueless unit, used to convert a unit to a number\n * @return {number | Array | Matrix} The created number\n */\n var number = typed('number', {\n '': function _() {\n return 0;\n },\n number: function number(x) {\n return x;\n },\n string: function string(x) {\n if (x === 'NaN') return NaN;\n var nonDecimalNumberParts = getNonDecimalNumberParts(x);\n\n if (nonDecimalNumberParts) {\n return makeNumberFromNonDecimalParts(nonDecimalNumberParts);\n }\n\n var size = 0;\n var wordSizeSuffixMatch = x.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/);\n\n if (wordSizeSuffixMatch) {\n // x includes a size suffix like 0xffffi32, so we extract\n // the suffix and remove it from x\n size = Number(wordSizeSuffixMatch[2]);\n x = wordSizeSuffixMatch[1];\n }\n\n var num = Number(x);\n\n if (isNaN(num)) {\n throw new SyntaxError('String \"' + x + '\" is no valid number');\n }\n\n if (wordSizeSuffixMatch) {\n // x is a signed bin, oct, or hex literal\n // num is the value of string x if x is interpreted as unsigned\n if (num > Math.pow(2, size) - 1) {\n // literal is too large for size suffix\n throw new SyntaxError(\"String \\\"\".concat(x, \"\\\" is out of range\"));\n } // check if the bit at index size - 1 is set and if so do the twos complement\n\n\n if (num >= Math.pow(2, size - 1)) {\n num = num - Math.pow(2, size);\n }\n }\n\n return num;\n },\n BigNumber: function BigNumber(x) {\n return x.toNumber();\n },\n Fraction: function Fraction(x) {\n return x.valueOf();\n },\n Unit: function Unit(x) {\n throw new Error('Second argument with valueless unit expected');\n },\n null: function _null(x) {\n return 0;\n },\n 'Unit, string | Unit': function UnitStringUnit(unit, valuelessUnit) {\n return unit.toNumber(valuelessUnit);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n }); // reviver function to parse a JSON object like:\n //\n // {\"mathjs\":\"number\",\"value\":\"2.3\"}\n //\n // into a number 2.3\n\n number.fromJSON = function (json) {\n return parseFloat(json.value);\n };\n\n return number;\n});\nexports.createNumber = createNumber;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createResultSet = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar name = 'ResultSet';\nvar dependencies = [];\nvar createResultSet = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function () {\n /**\n * A ResultSet contains a list or results\n * @class ResultSet\n * @param {Array} entries\n * @constructor ResultSet\n */\n function ResultSet(entries) {\n if (!(this instanceof ResultSet)) {\n throw new SyntaxError('Constructor must be called with the new operator');\n }\n\n this.entries = entries || [];\n }\n /**\n * Attach type information\n */\n\n\n ResultSet.prototype.type = 'ResultSet';\n ResultSet.prototype.isResultSet = true;\n /**\n * Returns the array with results hold by this ResultSet\n * @memberof ResultSet\n * @returns {Array} entries\n */\n\n ResultSet.prototype.valueOf = function () {\n return this.entries;\n };\n /**\n * Returns the stringified results of the ResultSet\n * @memberof ResultSet\n * @returns {string} string\n */\n\n\n ResultSet.prototype.toString = function () {\n return '[' + this.entries.join(', ') + ']';\n };\n /**\n * Get a JSON representation of the ResultSet\n * @memberof ResultSet\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"ResultSet\", \"entries\": [...]}`\n */\n\n\n ResultSet.prototype.toJSON = function () {\n return {\n mathjs: 'ResultSet',\n entries: this.entries\n };\n };\n /**\n * Instantiate a ResultSet from a JSON object\n * @memberof ResultSet\n * @param {Object} json A JSON object structured as:\n * `{\"mathjs\": \"ResultSet\", \"entries\": [...]}`\n * @return {ResultSet}\n */\n\n\n ResultSet.fromJSON = function (json) {\n return new ResultSet(json.entries);\n };\n\n return ResultSet;\n}, {\n isClass: true\n});\nexports.createResultSet = createResultSet;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createString = void 0;\n\nvar _factory = require(\"../utils/factory.js\");\n\nvar _collection = require(\"../utils/collection.js\");\n\nvar _number = require(\"../utils/number.js\");\n\nvar name = 'string';\nvar dependencies = ['typed'];\nvar createString = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Create a string or convert any object into a string.\n * Elements of Arrays and Matrices are processed element wise.\n *\n * Syntax:\n *\n * math.string(value)\n *\n * Examples:\n *\n * math.string(4.2) // returns string '4.2'\n * math.string(math.complex(3, 2) // returns string '3 + 2i'\n *\n * const u = math.unit(5, 'km')\n * math.string(u.to('m')) // returns string '5000 m'\n *\n * math.string([true, false]) // returns ['true', 'false']\n *\n * See also:\n *\n * bignumber, boolean, complex, index, matrix, number, unit\n *\n * @param {* | Array | Matrix | null} [value] A value to convert to a string\n * @return {string | Array | Matrix} The created string\n */\n return typed(name, {\n '': function _() {\n return '';\n },\n number: _number.format,\n null: function _null(x) {\n return 'null';\n },\n boolean: function boolean(x) {\n return x + '';\n },\n string: function string(x) {\n return x;\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n },\n any: function any(x) {\n return String(x);\n }\n });\n});\nexports.createString = createString;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createUnitClass = void 0;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _is = require(\"../../utils/is.js\");\n\nvar _factory = require(\"../../utils/factory.js\");\n\nvar _function = require(\"../../utils/function.js\");\n\nvar _string = require(\"../../utils/string.js\");\n\nvar _object = require(\"../../utils/object.js\");\n\nvar _constants = require(\"../../utils/bignumber/constants.js\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); 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 = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nvar name = 'Unit';\nvar dependencies = ['?on', 'config', 'addScalar', 'subtract', 'multiplyScalar', 'divideScalar', 'pow', 'abs', 'fix', 'round', 'equal', 'isNumeric', 'format', 'number', 'Complex', 'BigNumber', 'Fraction'];\nvar createUnitClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var on = _ref.on,\n config = _ref.config,\n addScalar = _ref.addScalar,\n subtract = _ref.subtract,\n multiplyScalar = _ref.multiplyScalar,\n divideScalar = _ref.divideScalar,\n pow = _ref.pow,\n abs = _ref.abs,\n fix = _ref.fix,\n round = _ref.round,\n equal = _ref.equal,\n isNumeric = _ref.isNumeric,\n format = _ref.format,\n number = _ref.number,\n Complex = _ref.Complex,\n _BigNumber = _ref.BigNumber,\n _Fraction = _ref.Fraction;\n var toNumber = number;\n /**\n * A unit can be constructed in the following ways:\n *\n * const a = new Unit(value, name)\n * const b = new Unit(null, name)\n * const c = Unit.parse(str)\n *\n * Example usage:\n *\n * const a = new Unit(5, 'cm') // 50 mm\n * const b = Unit.parse('23 kg') // 23 kg\n * const c = math.in(a, new Unit(null, 'm') // 0.05 m\n * const d = new Unit(9.81, \"m/s^2\") // 9.81 m/s^2\n *\n * @class Unit\n * @constructor Unit\n * @param {number | BigNumber | Fraction | Complex | boolean} [value] A value like 5.2\n * @param {string} [name] A unit name like \"cm\" or \"inch\", or a derived unit of the form: \"u1[^ex1] [u2[^ex2] ...] [/ u3[^ex3] [u4[^ex4]]]\", such as \"kg m^2/s^2\", where each unit appearing after the forward slash is taken to be in the denominator. \"kg m^2 s^-2\" is a synonym and is also acceptable. Any of the units can include a prefix.\n */\n\n function Unit(value, name) {\n if (!(this instanceof Unit)) {\n throw new Error('Constructor must be called with the new operator');\n }\n\n if (!(value === null || value === undefined || isNumeric(value) || (0, _is.isComplex)(value))) {\n throw new TypeError('First parameter in Unit constructor must be number, BigNumber, Fraction, Complex, or undefined');\n }\n\n if (name !== undefined && (typeof name !== 'string' || name === '')) {\n throw new TypeError('Second parameter in Unit constructor must be a string');\n }\n\n if (name !== undefined) {\n var u = Unit.parse(name);\n this.units = u.units;\n this.dimensions = u.dimensions;\n } else {\n this.units = [{\n unit: UNIT_NONE,\n prefix: PREFIXES.NONE,\n // link to a list with supported prefixes\n power: 0\n }];\n this.dimensions = [];\n\n for (var i = 0; i < BASE_DIMENSIONS.length; i++) {\n this.dimensions[i] = 0;\n }\n }\n\n this.value = value !== undefined && value !== null ? this._normalize(value) : null;\n this.fixPrefix = false; // if true, function format will not search for the\n // best prefix but leave it as initially provided.\n // fixPrefix is set true by the method Unit.to\n // The justification behind this is that if the constructor is explicitly called,\n // the caller wishes the units to be returned exactly as he supplied.\n\n this.skipAutomaticSimplification = true;\n }\n /**\n * Attach type information\n */\n\n\n Unit.prototype.type = 'Unit';\n Unit.prototype.isUnit = true; // private variables and functions for the Unit parser\n\n var text, index, c;\n\n function skipWhitespace() {\n while (c === ' ' || c === '\\t') {\n next();\n }\n }\n\n function isDigitDot(c) {\n return c >= '0' && c <= '9' || c === '.';\n }\n\n function isDigit(c) {\n return c >= '0' && c <= '9';\n }\n\n function next() {\n index++;\n c = text.charAt(index);\n }\n\n function revert(oldIndex) {\n index = oldIndex;\n c = text.charAt(index);\n }\n\n function parseNumber() {\n var number = '';\n var oldIndex = index;\n\n if (c === '+') {\n next();\n } else if (c === '-') {\n number += c;\n next();\n }\n\n if (!isDigitDot(c)) {\n // a + or - must be followed by a digit\n revert(oldIndex);\n return null;\n } // get number, can have a single dot\n\n\n if (c === '.') {\n number += c;\n next();\n\n if (!isDigit(c)) {\n // this is no legal number, it is just a dot\n revert(oldIndex);\n return null;\n }\n } else {\n while (isDigit(c)) {\n number += c;\n next();\n }\n\n if (c === '.') {\n number += c;\n next();\n }\n }\n\n while (isDigit(c)) {\n number += c;\n next();\n } // check for exponential notation like \"2.3e-4\" or \"1.23e50\"\n\n\n if (c === 'E' || c === 'e') {\n // The grammar branches here. This could either be part of an exponent or the start of a unit that begins with the letter e, such as \"4exabytes\"\n var tentativeNumber = '';\n var tentativeIndex = index;\n tentativeNumber += c;\n next();\n\n if (c === '+' || c === '-') {\n tentativeNumber += c;\n next();\n } // Scientific notation MUST be followed by an exponent (otherwise we assume it is not scientific notation)\n\n\n if (!isDigit(c)) {\n // The e or E must belong to something else, so return the number without the e or E.\n revert(tentativeIndex);\n return number;\n } // We can now safely say that this is scientific notation.\n\n\n number = number + tentativeNumber;\n\n while (isDigit(c)) {\n number += c;\n next();\n }\n }\n\n return number;\n }\n\n function parseUnit() {\n var unitName = ''; // Alphanumeric characters only; matches [a-zA-Z0-9]\n\n while (isDigit(c) || Unit.isValidAlpha(c)) {\n unitName += c;\n next();\n } // Must begin with [a-zA-Z]\n\n\n var firstC = unitName.charAt(0);\n\n if (Unit.isValidAlpha(firstC)) {\n return unitName;\n } else {\n return null;\n }\n }\n\n function parseCharacter(toFind) {\n if (c === toFind) {\n next();\n return toFind;\n } else {\n return null;\n }\n }\n /**\n * Parse a string into a unit. The value of the unit is parsed as number,\n * BigNumber, or Fraction depending on the math.js config setting `number`.\n *\n * Throws an exception if the provided string does not contain a valid unit or\n * cannot be parsed.\n * @memberof Unit\n * @param {string} str A string like \"5.2 inch\", \"4e2 cm/s^2\"\n * @return {Unit} unit\n */\n\n\n Unit.parse = function (str, options) {\n options = options || {};\n text = str;\n index = -1;\n c = '';\n\n if (typeof text !== 'string') {\n throw new TypeError('Invalid argument in Unit.parse, string expected');\n }\n\n var unit = new Unit();\n unit.units = [];\n var powerMultiplierCurrent = 1;\n var expectingUnit = false; // A unit should follow this pattern:\n // [number] ...[ [*/] unit[^number] ]\n // unit[^number] ... [ [*/] unit[^number] ]\n // Rules:\n // number is any floating point number.\n // unit is any alphanumeric string beginning with an alpha. Units with names like e3 should be avoided because they look like the exponent of a floating point number!\n // The string may optionally begin with a number.\n // Each unit may optionally be followed by ^number.\n // Whitespace or a forward slash is recommended between consecutive units, although the following technically is parseable:\n // 2m^2kg/s^2\n // it is not good form. If a unit starts with e, then it could be confused as a floating point number:\n // 4erg\n\n next();\n skipWhitespace(); // Optional number at the start of the string\n\n var valueStr = parseNumber();\n var value = null;\n\n if (valueStr) {\n if (config.number === 'BigNumber') {\n value = new _BigNumber(valueStr);\n } else if (config.number === 'Fraction') {\n try {\n // not all numbers can be turned in Fractions, for example very small numbers not\n value = new _Fraction(valueStr);\n } catch (err) {\n value = parseFloat(valueStr);\n }\n } else {\n // number\n value = parseFloat(valueStr);\n }\n\n skipWhitespace(); // Whitespace is not required here\n // handle multiplication or division right after the value, like '1/s'\n\n if (parseCharacter('*')) {\n powerMultiplierCurrent = 1;\n expectingUnit = true;\n } else if (parseCharacter('/')) {\n powerMultiplierCurrent = -1;\n expectingUnit = true;\n }\n } // Stack to keep track of powerMultipliers applied to each parentheses group\n\n\n var powerMultiplierStack = []; // Running product of all elements in powerMultiplierStack\n\n var powerMultiplierStackProduct = 1;\n\n while (true) {\n skipWhitespace(); // Check for and consume opening parentheses, pushing powerMultiplierCurrent to the stack\n // A '(' will always appear directly before a unit.\n\n while (c === '(') {\n powerMultiplierStack.push(powerMultiplierCurrent);\n powerMultiplierStackProduct *= powerMultiplierCurrent;\n powerMultiplierCurrent = 1;\n next();\n skipWhitespace();\n } // Is there something here?\n\n\n var uStr = void 0;\n\n if (c) {\n var oldC = c;\n uStr = parseUnit();\n\n if (uStr === null) {\n throw new SyntaxError('Unexpected \"' + oldC + '\" in \"' + text + '\" at index ' + index.toString());\n }\n } else {\n // End of input.\n break;\n } // Verify the unit exists and get the prefix (if any)\n\n\n var res = _findUnit(uStr);\n\n if (res === null) {\n // Unit not found.\n throw new SyntaxError('Unit \"' + uStr + '\" not found.');\n }\n\n var power = powerMultiplierCurrent * powerMultiplierStackProduct; // Is there a \"^ number\"?\n\n skipWhitespace();\n\n if (parseCharacter('^')) {\n skipWhitespace();\n var p = parseNumber();\n\n if (p === null) {\n // No valid number found for the power!\n throw new SyntaxError('In \"' + str + '\", \"^\" must be followed by a floating-point number');\n }\n\n power *= p;\n } // Add the unit to the list\n\n\n unit.units.push({\n unit: res.unit,\n prefix: res.prefix,\n power: power\n });\n\n for (var i = 0; i < BASE_DIMENSIONS.length; i++) {\n unit.dimensions[i] += (res.unit.dimensions[i] || 0) * power;\n } // Check for and consume closing parentheses, popping from the stack.\n // A ')' will always follow a unit.\n\n\n skipWhitespace();\n\n while (c === ')') {\n if (powerMultiplierStack.length === 0) {\n throw new SyntaxError('Unmatched \")\" in \"' + text + '\" at index ' + index.toString());\n }\n\n powerMultiplierStackProduct /= powerMultiplierStack.pop();\n next();\n skipWhitespace();\n } // \"*\" and \"/\" should mean we are expecting something to come next.\n // Is there a forward slash? If so, negate powerMultiplierCurrent. The next unit or paren group is in the denominator.\n\n\n expectingUnit = false;\n\n if (parseCharacter('*')) {\n // explicit multiplication\n powerMultiplierCurrent = 1;\n expectingUnit = true;\n } else if (parseCharacter('/')) {\n // division\n powerMultiplierCurrent = -1;\n expectingUnit = true;\n } else {\n // implicit multiplication\n powerMultiplierCurrent = 1;\n } // Replace the unit into the auto unit system\n\n\n if (res.unit.base) {\n var baseDim = res.unit.base.key;\n UNIT_SYSTEMS.auto[baseDim] = {\n unit: res.unit,\n prefix: res.prefix\n };\n }\n } // Has the string been entirely consumed?\n\n\n skipWhitespace();\n\n if (c) {\n throw new SyntaxError('Could not parse: \"' + str + '\"');\n } // Is there a trailing slash?\n\n\n if (expectingUnit) {\n throw new SyntaxError('Trailing characters: \"' + str + '\"');\n } // Is the parentheses stack empty?\n\n\n if (powerMultiplierStack.length !== 0) {\n throw new SyntaxError('Unmatched \"(\" in \"' + text + '\"');\n } // Are there any units at all?\n\n\n if (unit.units.length === 0 && !options.allowNoUnits) {\n throw new SyntaxError('\"' + str + '\" contains no units');\n }\n\n unit.value = value !== undefined ? unit._normalize(value) : null;\n return unit;\n };\n /**\n * create a copy of this unit\n * @memberof Unit\n * @return {Unit} Returns a cloned version of the unit\n */\n\n\n Unit.prototype.clone = function () {\n var unit = new Unit();\n unit.fixPrefix = this.fixPrefix;\n unit.skipAutomaticSimplification = this.skipAutomaticSimplification;\n unit.value = (0, _object.clone)(this.value);\n unit.dimensions = this.dimensions.slice(0);\n unit.units = [];\n\n for (var i = 0; i < this.units.length; i++) {\n unit.units[i] = {};\n\n for (var p in this.units[i]) {\n if ((0, _object.hasOwnProperty)(this.units[i], p)) {\n unit.units[i][p] = this.units[i][p];\n }\n }\n }\n\n return unit;\n };\n /**\n * Return whether the unit is derived (such as m/s, or cm^2, but not N)\n * @memberof Unit\n * @return {boolean} True if the unit is derived\n */\n\n\n Unit.prototype._isDerived = function () {\n if (this.units.length === 0) {\n return false;\n }\n\n return this.units.length > 1 || Math.abs(this.units[0].power - 1.0) > 1e-15;\n };\n /**\n * Normalize a value, based on its currently set unit(s)\n * @memberof Unit\n * @param {number | BigNumber | Fraction | boolean} value\n * @return {number | BigNumber | Fraction | boolean} normalized value\n * @private\n */\n\n\n Unit.prototype._normalize = function (value) {\n if (value === null || value === undefined || this.units.length === 0) {\n return value;\n }\n\n var res = value;\n\n var convert = Unit._getNumberConverter((0, _is.typeOf)(value)); // convert to Fraction or BigNumber if needed\n\n\n for (var i = 0; i < this.units.length; i++) {\n var unitValue = convert(this.units[i].unit.value);\n var unitPrefixValue = convert(this.units[i].prefix.value);\n var unitPower = convert(this.units[i].power);\n res = multiplyScalar(res, pow(multiplyScalar(unitValue, unitPrefixValue), unitPower));\n }\n\n return res;\n };\n /**\n * Denormalize a value, based on its currently set unit(s)\n * @memberof Unit\n * @param {number} value\n * @param {number} [prefixValue] Optional prefix value to be used (ignored if this is a derived unit)\n * @return {number} denormalized value\n * @private\n */\n\n\n Unit.prototype._denormalize = function (value, prefixValue) {\n if (value === null || value === undefined || this.units.length === 0) {\n return value;\n }\n\n var res = value;\n\n var convert = Unit._getNumberConverter((0, _is.typeOf)(value)); // convert to Fraction or BigNumber if needed\n\n\n for (var i = 0; i < this.units.length; i++) {\n var unitValue = convert(this.units[i].unit.value);\n var unitPrefixValue = convert(this.units[i].prefix.value);\n var unitPower = convert(this.units[i].power);\n res = divideScalar(res, pow(multiplyScalar(unitValue, unitPrefixValue), unitPower));\n }\n\n return res;\n };\n /**\n * Find a unit from a string\n * @memberof Unit\n * @param {string} str A string like 'cm' or 'inch'\n * @returns {Object | null} result When found, an object with fields unit and\n * prefix is returned. Else, null is returned.\n * @private\n */\n\n\n var _findUnit = (0, _function.memoize)(function (str) {\n // First, match units names exactly. For example, a user could define 'mm' as 10^-4 m, which is silly, but then we would want 'mm' to match the user-defined unit.\n if ((0, _object.hasOwnProperty)(UNITS, str)) {\n var unit = UNITS[str];\n var prefix = unit.prefixes[''];\n return {\n unit: unit,\n prefix: prefix\n };\n }\n\n for (var _name in UNITS) {\n if ((0, _object.hasOwnProperty)(UNITS, _name)) {\n if ((0, _string.endsWith)(str, _name)) {\n var _unit = UNITS[_name];\n var prefixLen = str.length - _name.length;\n var prefixName = str.substring(0, prefixLen);\n\n var _prefix = (0, _object.hasOwnProperty)(_unit.prefixes, prefixName) ? _unit.prefixes[prefixName] : undefined;\n\n if (_prefix !== undefined) {\n // store unit, prefix, and value\n return {\n unit: _unit,\n prefix: _prefix\n };\n }\n }\n }\n }\n\n return null;\n }, {\n hasher: function hasher(args) {\n return args[0];\n },\n limit: 100\n });\n /**\n * Test if the given expression is a unit.\n * The unit can have a prefix but cannot have a value.\n * @memberof Unit\n * @param {string} name A string to be tested whether it is a value less unit.\n * The unit can have prefix, like \"cm\"\n * @return {boolean} true if the given string is a unit\n */\n\n\n Unit.isValuelessUnit = function (name) {\n return _findUnit(name) !== null;\n };\n /**\n * check if this unit has given base unit\n * If this unit is a derived unit, this will ALWAYS return false, since by definition base units are not derived.\n * @memberof Unit\n * @param {BASE_UNITS | string | undefined} base\n */\n\n\n Unit.prototype.hasBase = function (base) {\n if (typeof base === 'string') {\n base = BASE_UNITS[base];\n }\n\n if (!base) {\n return false;\n } // All dimensions must be the same\n\n\n for (var i = 0; i < BASE_DIMENSIONS.length; i++) {\n if (Math.abs((this.dimensions[i] || 0) - (base.dimensions[i] || 0)) > 1e-12) {\n return false;\n }\n }\n\n return true;\n };\n /**\n * Check if this unit has a base or bases equal to another base or bases\n * For derived units, the exponent on each base also must match\n * @memberof Unit\n * @param {Unit} other\n * @return {boolean} true if equal base\n */\n\n\n Unit.prototype.equalBase = function (other) {\n // All dimensions must be the same\n for (var i = 0; i < BASE_DIMENSIONS.length; i++) {\n if (Math.abs((this.dimensions[i] || 0) - (other.dimensions[i] || 0)) > 1e-12) {\n return false;\n }\n }\n\n return true;\n };\n /**\n * Check if this unit equals another unit\n * @memberof Unit\n * @param {Unit} other\n * @return {boolean} true if both units are equal\n */\n\n\n Unit.prototype.equals = function (other) {\n return this.equalBase(other) && equal(this.value, other.value);\n };\n /**\n * Multiply this unit with another one\n * @memberof Unit\n * @param {Unit} other\n * @return {Unit} product of this unit and the other unit\n */\n\n\n Unit.prototype.multiply = function (other) {\n var res = this.clone();\n\n for (var i = 0; i < BASE_DIMENSIONS.length; i++) {\n // Dimensions arrays may be of different lengths. Default to 0.\n res.dimensions[i] = (this.dimensions[i] || 0) + (other.dimensions[i] || 0);\n } // Append other's units list onto res\n\n\n for (var _i = 0; _i < other.units.length; _i++) {\n // Make a shallow copy of every unit\n var inverted = _objectSpread({}, other.units[_i]);\n\n res.units.push(inverted);\n } // If at least one operand has a value, then the result should also have a value\n\n\n if (this.value !== null || other.value !== null) {\n var valThis = this.value === null ? this._normalize(1) : this.value;\n var valOther = other.value === null ? other._normalize(1) : other.value;\n res.value = multiplyScalar(valThis, valOther);\n } else {\n res.value = null;\n }\n\n res.skipAutomaticSimplification = false;\n return getNumericIfUnitless(res);\n };\n /**\n * Divide this unit by another one\n * @memberof Unit\n * @param {Unit} other\n * @return {Unit} result of dividing this unit by the other unit\n */\n\n\n Unit.prototype.divide = function (other) {\n var res = this.clone();\n\n for (var i = 0; i < BASE_DIMENSIONS.length; i++) {\n // Dimensions arrays may be of different lengths. Default to 0.\n res.dimensions[i] = (this.dimensions[i] || 0) - (other.dimensions[i] || 0);\n } // Invert and append other's units list onto res\n\n\n for (var _i2 = 0; _i2 < other.units.length; _i2++) {\n // Make a shallow copy of every unit\n var inverted = _objectSpread(_objectSpread({}, other.units[_i2]), {}, {\n power: -other.units[_i2].power\n });\n\n res.units.push(inverted);\n } // If at least one operand has a value, the result should have a value\n\n\n if (this.value !== null || other.value !== null) {\n var valThis = this.value === null ? this._normalize(1) : this.value;\n var valOther = other.value === null ? other._normalize(1) : other.value;\n res.value = divideScalar(valThis, valOther);\n } else {\n res.value = null;\n }\n\n res.skipAutomaticSimplification = false;\n return getNumericIfUnitless(res);\n };\n /**\n * Calculate the power of a unit\n * @memberof Unit\n * @param {number | Fraction | BigNumber} p\n * @returns {Unit} The result: this^p\n */\n\n\n Unit.prototype.pow = function (p) {\n var res = this.clone();\n\n for (var i = 0; i < BASE_DIMENSIONS.length; i++) {\n // Dimensions arrays may be of different lengths. Default to 0.\n res.dimensions[i] = (this.dimensions[i] || 0) * p;\n } // Adjust the power of each unit in the list\n\n\n for (var _i3 = 0; _i3 < res.units.length; _i3++) {\n res.units[_i3].power *= p;\n }\n\n if (res.value !== null) {\n res.value = pow(res.value, p); // only allow numeric output, we don't want to return a Complex number\n // if (!isNumeric(res.value)) {\n // res.value = NaN\n // }\n // Update: Complex supported now\n } else {\n res.value = null;\n }\n\n res.skipAutomaticSimplification = false;\n return getNumericIfUnitless(res);\n };\n /**\n * Return the numeric value of this unit if it is dimensionless, has a value, and config.predictable == false; or the original unit otherwise\n * @param {Unit} unit\n * @returns {number | Fraction | BigNumber | Unit} The numeric value of the unit if conditions are met, or the original unit otherwise\n */\n\n\n function getNumericIfUnitless(unit) {\n if (unit.equalBase(BASE_UNITS.NONE) && unit.value !== null && !config.predictable) {\n return unit.value;\n } else {\n return unit;\n }\n }\n /**\n * Calculate the absolute value of a unit\n * @memberof Unit\n * @param {number | Fraction | BigNumber} x\n * @returns {Unit} The result: |x|, absolute value of x\n */\n\n\n Unit.prototype.abs = function () {\n var ret = this.clone();\n\n if (ret.value !== null) {\n if (ret._isDerived() || ret.units[0].unit.offset === 0) {\n ret.value = abs(ret.value);\n } else {\n // To give the correct, but unexpected, results for units with an offset.\n // For example, abs(-283.15 degC) = -263.15 degC !!!\n // We must take the offset into consideration here\n var convert = Unit._getNumberConverter((0, _is.typeOf)(ret.value)); // convert to Fraction or BigNumber if needed\n\n\n var unitValue = convert(ret.units[0].unit.value);\n var nominalOffset = convert(ret.units[0].unit.offset);\n var unitOffset = multiplyScalar(unitValue, nominalOffset);\n ret.value = subtract(abs(addScalar(ret.value, unitOffset)), unitOffset);\n }\n }\n\n for (var i in ret.units) {\n if (ret.units[i].unit.name === 'VA' || ret.units[i].unit.name === 'VAR') {\n ret.units[i].unit = UNITS.W;\n }\n }\n\n return ret;\n };\n /**\n * Convert the unit to a specific unit name.\n * @memberof Unit\n * @param {string | Unit} valuelessUnit A unit without value. Can have prefix, like \"cm\"\n * @returns {Unit} Returns a clone of the unit with a fixed prefix and unit.\n */\n\n\n Unit.prototype.to = function (valuelessUnit) {\n var value = this.value === null ? this._normalize(1) : this.value;\n var other;\n\n if (typeof valuelessUnit === 'string') {\n other = Unit.parse(valuelessUnit);\n } else if ((0, _is.isUnit)(valuelessUnit)) {\n other = valuelessUnit.clone();\n } else {\n throw new Error('String or Unit expected as parameter');\n }\n\n if (!this.equalBase(other)) {\n throw new Error(\"Units do not match ('\".concat(other.toString(), \"' != '\").concat(this.toString(), \"')\"));\n }\n\n if (other.value !== null) {\n throw new Error('Cannot convert to a unit with a value');\n }\n\n if (this.value === null || this._isDerived() || this.units[0].unit.offset === other.units[0].unit.offset) {\n other.value = (0, _object.clone)(value);\n } else {\n /* Need to adjust value by difference in offset to convert */\n var convert = Unit._getNumberConverter((0, _is.typeOf)(value)); // convert to Fraction or BigNumber if needed\n\n\n var thisUnitValue = convert(this.units[0].unit.value);\n var thisNominalOffset = convert(this.units[0].unit.offset);\n var thisUnitOffset = multiplyScalar(thisUnitValue, thisNominalOffset);\n var otherUnitValue = convert(other.units[0].unit.value);\n var otherNominalOffset = convert(other.units[0].unit.offset);\n var otherUnitOffset = multiplyScalar(otherUnitValue, otherNominalOffset);\n other.value = subtract(addScalar(value, thisUnitOffset), otherUnitOffset);\n }\n\n other.fixPrefix = true;\n other.skipAutomaticSimplification = true;\n return other;\n };\n /**\n * Return the value of the unit when represented with given valueless unit\n * @memberof Unit\n * @param {string | Unit} valuelessUnit For example 'cm' or 'inch'\n * @return {number} Returns the unit value as number.\n */\n // TODO: deprecate Unit.toNumber? It's always better to use toNumeric\n\n\n Unit.prototype.toNumber = function (valuelessUnit) {\n return toNumber(this.toNumeric(valuelessUnit));\n };\n /**\n * Return the value of the unit in the original numeric type\n * @memberof Unit\n * @param {string | Unit} valuelessUnit For example 'cm' or 'inch'\n * @return {number | BigNumber | Fraction} Returns the unit value\n */\n\n\n Unit.prototype.toNumeric = function (valuelessUnit) {\n var other;\n\n if (valuelessUnit) {\n // Allow getting the numeric value without converting to a different unit\n other = this.to(valuelessUnit);\n } else {\n other = this.clone();\n }\n\n if (other._isDerived() || other.units.length === 0) {\n return other._denormalize(other.value);\n } else {\n return other._denormalize(other.value, other.units[0].prefix.value);\n }\n };\n /**\n * Get a string representation of the unit.\n * @memberof Unit\n * @return {string}\n */\n\n\n Unit.prototype.toString = function () {\n return this.format();\n };\n /**\n * Get a JSON representation of the unit\n * @memberof Unit\n * @returns {Object} Returns a JSON object structured as:\n * `{\"mathjs\": \"Unit\", \"value\": 2, \"unit\": \"cm\", \"fixPrefix\": false}`\n */\n\n\n Unit.prototype.toJSON = function () {\n return {\n mathjs: 'Unit',\n value: this._denormalize(this.value),\n unit: this.formatUnits(),\n fixPrefix: this.fixPrefix\n };\n };\n /**\n * Instantiate a Unit from a JSON object\n * @memberof Unit\n * @param {Object} json A JSON object structured as:\n * `{\"mathjs\": \"Unit\", \"value\": 2, \"unit\": \"cm\", \"fixPrefix\": false}`\n * @return {Unit}\n */\n\n\n Unit.fromJSON = function (json) {\n var unit = new Unit(json.value, json.unit);\n unit.fixPrefix = json.fixPrefix || false;\n return unit;\n };\n /**\n * Returns the string representation of the unit.\n * @memberof Unit\n * @return {string}\n */\n\n\n Unit.prototype.valueOf = Unit.prototype.toString;\n /**\n * Simplify this Unit's unit list and return a new Unit with the simplified list.\n * The returned Unit will contain a list of the \"best\" units for formatting.\n */\n\n Unit.prototype.simplify = function () {\n var ret = this.clone();\n var proposedUnitList = []; // Search for a matching base\n\n var matchingBase;\n\n for (var key in currentUnitSystem) {\n if ((0, _object.hasOwnProperty)(currentUnitSystem, key)) {\n if (ret.hasBase(BASE_UNITS[key])) {\n matchingBase = key;\n break;\n }\n }\n }\n\n if (matchingBase === 'NONE') {\n ret.units = [];\n } else {\n var matchingUnit;\n\n if (matchingBase) {\n // Does the unit system have a matching unit?\n if ((0, _object.hasOwnProperty)(currentUnitSystem, matchingBase)) {\n matchingUnit = currentUnitSystem[matchingBase];\n }\n }\n\n if (matchingUnit) {\n ret.units = [{\n unit: matchingUnit.unit,\n prefix: matchingUnit.prefix,\n power: 1.0\n }];\n } else {\n // Multiple units or units with powers are formatted like this:\n // 5 (kg m^2) / (s^3 mol)\n // Build an representation from the base units of the current unit system\n var missingBaseDim = false;\n\n for (var i = 0; i < BASE_DIMENSIONS.length; i++) {\n var baseDim = BASE_DIMENSIONS[i];\n\n if (Math.abs(ret.dimensions[i] || 0) > 1e-12) {\n if ((0, _object.hasOwnProperty)(currentUnitSystem, baseDim)) {\n proposedUnitList.push({\n unit: currentUnitSystem[baseDim].unit,\n prefix: currentUnitSystem[baseDim].prefix,\n power: ret.dimensions[i] || 0\n });\n } else {\n missingBaseDim = true;\n }\n }\n } // Is the proposed unit list \"simpler\" than the existing one?\n\n\n if (proposedUnitList.length < ret.units.length && !missingBaseDim) {\n // Replace this unit list with the proposed list\n ret.units = proposedUnitList;\n }\n }\n }\n\n return ret;\n };\n /**\n * Returns a new Unit in the SI system with the same value as this one\n */\n\n\n Unit.prototype.toSI = function () {\n var ret = this.clone();\n var proposedUnitList = []; // Multiple units or units with powers are formatted like this:\n // 5 (kg m^2) / (s^3 mol)\n // Build an representation from the base units of the SI unit system\n\n for (var i = 0; i < BASE_DIMENSIONS.length; i++) {\n var baseDim = BASE_DIMENSIONS[i];\n\n if (Math.abs(ret.dimensions[i] || 0) > 1e-12) {\n if ((0, _object.hasOwnProperty)(UNIT_SYSTEMS.si, baseDim)) {\n proposedUnitList.push({\n unit: UNIT_SYSTEMS.si[baseDim].unit,\n prefix: UNIT_SYSTEMS.si[baseDim].prefix,\n power: ret.dimensions[i] || 0\n });\n } else {\n throw new Error('Cannot express custom unit ' + baseDim + ' in SI units');\n }\n }\n } // Replace this unit list with the proposed list\n\n\n ret.units = proposedUnitList;\n ret.fixPrefix = true;\n ret.skipAutomaticSimplification = true;\n return ret;\n };\n /**\n * Get a string representation of the units of this Unit, without the value. The unit list is formatted as-is without first being simplified.\n * @memberof Unit\n * @return {string}\n */\n\n\n Unit.prototype.formatUnits = function () {\n var strNum = '';\n var strDen = '';\n var nNum = 0;\n var nDen = 0;\n\n for (var i = 0; i < this.units.length; i++) {\n if (this.units[i].power > 0) {\n nNum++;\n strNum += ' ' + this.units[i].prefix.name + this.units[i].unit.name;\n\n if (Math.abs(this.units[i].power - 1.0) > 1e-15) {\n strNum += '^' + this.units[i].power;\n }\n } else if (this.units[i].power < 0) {\n nDen++;\n }\n }\n\n if (nDen > 0) {\n for (var _i4 = 0; _i4 < this.units.length; _i4++) {\n if (this.units[_i4].power < 0) {\n if (nNum > 0) {\n strDen += ' ' + this.units[_i4].prefix.name + this.units[_i4].unit.name;\n\n if (Math.abs(this.units[_i4].power + 1.0) > 1e-15) {\n strDen += '^' + -this.units[_i4].power;\n }\n } else {\n strDen += ' ' + this.units[_i4].prefix.name + this.units[_i4].unit.name;\n strDen += '^' + this.units[_i4].power;\n }\n }\n }\n } // Remove leading \" \"\n\n\n strNum = strNum.substr(1);\n strDen = strDen.substr(1); // Add parans for better copy/paste back into evaluate, for example, or for better pretty print formatting\n\n if (nNum > 1 && nDen > 0) {\n strNum = '(' + strNum + ')';\n }\n\n if (nDen > 1 && nNum > 0) {\n strDen = '(' + strDen + ')';\n }\n\n var str = strNum;\n\n if (nNum > 0 && nDen > 0) {\n str += ' / ';\n }\n\n str += strDen;\n return str;\n };\n /**\n * Get a string representation of the Unit, with optional formatting options.\n * @memberof Unit\n * @param {Object | number | Function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @return {string}\n */\n\n\n Unit.prototype.format = function (options) {\n // Simplfy the unit list, unless it is valueless or was created directly in the\n // constructor or as the result of to or toSI\n var simp = this.skipAutomaticSimplification || this.value === null ? this.clone() : this.simplify(); // Apply some custom logic for handling VA and VAR. The goal is to express the value of the unit as a real value, if possible. Otherwise, use a real-valued unit instead of a complex-valued one.\n\n var isImaginary = false;\n\n if (typeof simp.value !== 'undefined' && simp.value !== null && (0, _is.isComplex)(simp.value)) {\n // TODO: Make this better, for example, use relative magnitude of re and im rather than absolute\n isImaginary = Math.abs(simp.value.re) < 1e-14;\n }\n\n for (var i in simp.units) {\n if ((0, _object.hasOwnProperty)(simp.units, i)) {\n if (simp.units[i].unit) {\n if (simp.units[i].unit.name === 'VA' && isImaginary) {\n simp.units[i].unit = UNITS.VAR;\n } else if (simp.units[i].unit.name === 'VAR' && !isImaginary) {\n simp.units[i].unit = UNITS.VA;\n }\n }\n }\n } // Now apply the best prefix\n // Units must have only one unit and not have the fixPrefix flag set\n\n\n if (simp.units.length === 1 && !simp.fixPrefix) {\n // Units must have integer powers, otherwise the prefix will change the\n // outputted value by not-an-integer-power-of-ten\n if (Math.abs(simp.units[0].power - Math.round(simp.units[0].power)) < 1e-14) {\n // Apply the best prefix\n simp.units[0].prefix = simp._bestPrefix();\n }\n }\n\n var value = simp._denormalize(simp.value);\n\n var str = simp.value !== null ? format(value, options || {}) : '';\n var unitStr = simp.formatUnits();\n\n if (simp.value && (0, _is.isComplex)(simp.value)) {\n str = '(' + str + ')'; // Surround complex values with ( ) to enable better parsing\n }\n\n if (unitStr.length > 0 && str.length > 0) {\n str += ' ';\n }\n\n str += unitStr;\n return str;\n };\n /**\n * Calculate the best prefix using current value.\n * @memberof Unit\n * @returns {Object} prefix\n * @private\n */\n\n\n Unit.prototype._bestPrefix = function () {\n if (this.units.length !== 1) {\n throw new Error('Can only compute the best prefix for single units with integer powers, like kg, s^2, N^-1, and so forth!');\n }\n\n if (Math.abs(this.units[0].power - Math.round(this.units[0].power)) >= 1e-14) {\n throw new Error('Can only compute the best prefix for single units with integer powers, like kg, s^2, N^-1, and so forth!');\n } // find the best prefix value (resulting in the value of which\n // the absolute value of the log10 is closest to zero,\n // though with a little offset of 1.2 for nicer values: you get a\n // sequence 1mm 100mm 500mm 0.6m 1m 10m 100m 500m 0.6km 1km ...\n // Note: the units value can be any numeric type, but to find the best\n // prefix it's enough to work with limited precision of a regular number\n // Update: using mathjs abs since we also allow complex numbers\n\n\n var absValue = this.value !== null ? abs(this.value) : 0;\n var absUnitValue = abs(this.units[0].unit.value);\n var bestPrefix = this.units[0].prefix;\n\n if (absValue === 0) {\n return bestPrefix;\n }\n\n var power = this.units[0].power;\n var bestDiff = Math.log(absValue / Math.pow(bestPrefix.value * absUnitValue, power)) / Math.LN10 - 1.2;\n if (bestDiff > -2.200001 && bestDiff < 1.800001) return bestPrefix; // Allow the original prefix\n\n bestDiff = Math.abs(bestDiff);\n var prefixes = this.units[0].unit.prefixes;\n\n for (var p in prefixes) {\n if ((0, _object.hasOwnProperty)(prefixes, p)) {\n var prefix = prefixes[p];\n\n if (prefix.scientific) {\n var diff = Math.abs(Math.log(absValue / Math.pow(prefix.value * absUnitValue, power)) / Math.LN10 - 1.2);\n\n if (diff < bestDiff || diff === bestDiff && prefix.name.length < bestPrefix.name.length) {\n // choose the prefix with the smallest diff, or if equal, choose the one\n // with the shortest name (can happen with SHORTLONG for example)\n bestPrefix = prefix;\n bestDiff = diff;\n }\n }\n }\n }\n\n return bestPrefix;\n };\n /**\n * Returns an array of units whose sum is equal to this unit\n * @memberof Unit\n * @param {Array} [parts] An array of strings or valueless units.\n *\n * Example:\n *\n * const u = new Unit(1, 'm')\n * u.splitUnit(['feet', 'inch'])\n * [ 3 feet, 3.3700787401575 inch ]\n *\n * @return {Array} An array of units.\n */\n\n\n Unit.prototype.splitUnit = function (parts) {\n var x = this.clone();\n var ret = [];\n\n for (var i = 0; i < parts.length; i++) {\n // Convert x to the requested unit\n x = x.to(parts[i]);\n if (i === parts.length - 1) break; // Get the numeric value of this unit\n\n var xNumeric = x.toNumeric(); // Check to see if xNumeric is nearly equal to an integer,\n // since fix can incorrectly round down if there is round-off error\n\n var xRounded = round(xNumeric);\n var xFixed = void 0;\n var isNearlyEqual = equal(xRounded, xNumeric);\n\n if (isNearlyEqual) {\n xFixed = xRounded;\n } else {\n xFixed = fix(x.toNumeric());\n }\n\n var y = new Unit(xFixed, parts[i].toString());\n ret.push(y);\n x = subtract(x, y);\n } // This little bit fixes a bug where the remainder should be 0 but is a little bit off.\n // But instead of comparing x, the remainder, with zero--we will compare the sum of\n // all the parts so far with the original value. If they are nearly equal,\n // we set the remainder to 0.\n\n\n var testSum = 0;\n\n for (var _i5 = 0; _i5 < ret.length; _i5++) {\n testSum = addScalar(testSum, ret[_i5].value);\n }\n\n if (equal(testSum, this.value)) {\n x.value = 0;\n }\n\n ret.push(x);\n return ret;\n };\n\n var PREFIXES = {\n NONE: {\n '': {\n name: '',\n value: 1,\n scientific: true\n }\n },\n SHORT: {\n '': {\n name: '',\n value: 1,\n scientific: true\n },\n da: {\n name: 'da',\n value: 1e1,\n scientific: false\n },\n h: {\n name: 'h',\n value: 1e2,\n scientific: false\n },\n k: {\n name: 'k',\n value: 1e3,\n scientific: true\n },\n M: {\n name: 'M',\n value: 1e6,\n scientific: true\n },\n G: {\n name: 'G',\n value: 1e9,\n scientific: true\n },\n T: {\n name: 'T',\n value: 1e12,\n scientific: true\n },\n P: {\n name: 'P',\n value: 1e15,\n scientific: true\n },\n E: {\n name: 'E',\n value: 1e18,\n scientific: true\n },\n Z: {\n name: 'Z',\n value: 1e21,\n scientific: true\n },\n Y: {\n name: 'Y',\n value: 1e24,\n scientific: true\n },\n d: {\n name: 'd',\n value: 1e-1,\n scientific: false\n },\n c: {\n name: 'c',\n value: 1e-2,\n scientific: false\n },\n m: {\n name: 'm',\n value: 1e-3,\n scientific: true\n },\n u: {\n name: 'u',\n value: 1e-6,\n scientific: true\n },\n n: {\n name: 'n',\n value: 1e-9,\n scientific: true\n },\n p: {\n name: 'p',\n value: 1e-12,\n scientific: true\n },\n f: {\n name: 'f',\n value: 1e-15,\n scientific: true\n },\n a: {\n name: 'a',\n value: 1e-18,\n scientific: true\n },\n z: {\n name: 'z',\n value: 1e-21,\n scientific: true\n },\n y: {\n name: 'y',\n value: 1e-24,\n scientific: true\n }\n },\n LONG: {\n '': {\n name: '',\n value: 1,\n scientific: true\n },\n deca: {\n name: 'deca',\n value: 1e1,\n scientific: false\n },\n hecto: {\n name: 'hecto',\n value: 1e2,\n scientific: false\n },\n kilo: {\n name: 'kilo',\n value: 1e3,\n scientific: true\n },\n mega: {\n name: 'mega',\n value: 1e6,\n scientific: true\n },\n giga: {\n name: 'giga',\n value: 1e9,\n scientific: true\n },\n tera: {\n name: 'tera',\n value: 1e12,\n scientific: true\n },\n peta: {\n name: 'peta',\n value: 1e15,\n scientific: true\n },\n exa: {\n name: 'exa',\n value: 1e18,\n scientific: true\n },\n zetta: {\n name: 'zetta',\n value: 1e21,\n scientific: true\n },\n yotta: {\n name: 'yotta',\n value: 1e24,\n scientific: true\n },\n deci: {\n name: 'deci',\n value: 1e-1,\n scientific: false\n },\n centi: {\n name: 'centi',\n value: 1e-2,\n scientific: false\n },\n milli: {\n name: 'milli',\n value: 1e-3,\n scientific: true\n },\n micro: {\n name: 'micro',\n value: 1e-6,\n scientific: true\n },\n nano: {\n name: 'nano',\n value: 1e-9,\n scientific: true\n },\n pico: {\n name: 'pico',\n value: 1e-12,\n scientific: true\n },\n femto: {\n name: 'femto',\n value: 1e-15,\n scientific: true\n },\n atto: {\n name: 'atto',\n value: 1e-18,\n scientific: true\n },\n zepto: {\n name: 'zepto',\n value: 1e-21,\n scientific: true\n },\n yocto: {\n name: 'yocto',\n value: 1e-24,\n scientific: true\n }\n },\n SQUARED: {\n '': {\n name: '',\n value: 1,\n scientific: true\n },\n da: {\n name: 'da',\n value: 1e2,\n scientific: false\n },\n h: {\n name: 'h',\n value: 1e4,\n scientific: false\n },\n k: {\n name: 'k',\n value: 1e6,\n scientific: true\n },\n M: {\n name: 'M',\n value: 1e12,\n scientific: true\n },\n G: {\n name: 'G',\n value: 1e18,\n scientific: true\n },\n T: {\n name: 'T',\n value: 1e24,\n scientific: true\n },\n P: {\n name: 'P',\n value: 1e30,\n scientific: true\n },\n E: {\n name: 'E',\n value: 1e36,\n scientific: true\n },\n Z: {\n name: 'Z',\n value: 1e42,\n scientific: true\n },\n Y: {\n name: 'Y',\n value: 1e48,\n scientific: true\n },\n d: {\n name: 'd',\n value: 1e-2,\n scientific: false\n },\n c: {\n name: 'c',\n value: 1e-4,\n scientific: false\n },\n m: {\n name: 'm',\n value: 1e-6,\n scientific: true\n },\n u: {\n name: 'u',\n value: 1e-12,\n scientific: true\n },\n n: {\n name: 'n',\n value: 1e-18,\n scientific: true\n },\n p: {\n name: 'p',\n value: 1e-24,\n scientific: true\n },\n f: {\n name: 'f',\n value: 1e-30,\n scientific: true\n },\n a: {\n name: 'a',\n value: 1e-36,\n scientific: true\n },\n z: {\n name: 'z',\n value: 1e-42,\n scientific: true\n },\n y: {\n name: 'y',\n value: 1e-48,\n scientific: true\n }\n },\n CUBIC: {\n '': {\n name: '',\n value: 1,\n scientific: true\n },\n da: {\n name: 'da',\n value: 1e3,\n scientific: false\n },\n h: {\n name: 'h',\n value: 1e6,\n scientific: false\n },\n k: {\n name: 'k',\n value: 1e9,\n scientific: true\n },\n M: {\n name: 'M',\n value: 1e18,\n scientific: true\n },\n G: {\n name: 'G',\n value: 1e27,\n scientific: true\n },\n T: {\n name: 'T',\n value: 1e36,\n scientific: true\n },\n P: {\n name: 'P',\n value: 1e45,\n scientific: true\n },\n E: {\n name: 'E',\n value: 1e54,\n scientific: true\n },\n Z: {\n name: 'Z',\n value: 1e63,\n scientific: true\n },\n Y: {\n name: 'Y',\n value: 1e72,\n scientific: true\n },\n d: {\n name: 'd',\n value: 1e-3,\n scientific: false\n },\n c: {\n name: 'c',\n value: 1e-6,\n scientific: false\n },\n m: {\n name: 'm',\n value: 1e-9,\n scientific: true\n },\n u: {\n name: 'u',\n value: 1e-18,\n scientific: true\n },\n n: {\n name: 'n',\n value: 1e-27,\n scientific: true\n },\n p: {\n name: 'p',\n value: 1e-36,\n scientific: true\n },\n f: {\n name: 'f',\n value: 1e-45,\n scientific: true\n },\n a: {\n name: 'a',\n value: 1e-54,\n scientific: true\n },\n z: {\n name: 'z',\n value: 1e-63,\n scientific: true\n },\n y: {\n name: 'y',\n value: 1e-72,\n scientific: true\n }\n },\n BINARY_SHORT_SI: {\n '': {\n name: '',\n value: 1,\n scientific: true\n },\n k: {\n name: 'k',\n value: 1e3,\n scientific: true\n },\n M: {\n name: 'M',\n value: 1e6,\n scientific: true\n },\n G: {\n name: 'G',\n value: 1e9,\n scientific: true\n },\n T: {\n name: 'T',\n value: 1e12,\n scientific: true\n },\n P: {\n name: 'P',\n value: 1e15,\n scientific: true\n },\n E: {\n name: 'E',\n value: 1e18,\n scientific: true\n },\n Z: {\n name: 'Z',\n value: 1e21,\n scientific: true\n },\n Y: {\n name: 'Y',\n value: 1e24,\n scientific: true\n }\n },\n BINARY_SHORT_IEC: {\n '': {\n name: '',\n value: 1,\n scientific: true\n },\n Ki: {\n name: 'Ki',\n value: 1024,\n scientific: true\n },\n Mi: {\n name: 'Mi',\n value: Math.pow(1024, 2),\n scientific: true\n },\n Gi: {\n name: 'Gi',\n value: Math.pow(1024, 3),\n scientific: true\n },\n Ti: {\n name: 'Ti',\n value: Math.pow(1024, 4),\n scientific: true\n },\n Pi: {\n name: 'Pi',\n value: Math.pow(1024, 5),\n scientific: true\n },\n Ei: {\n name: 'Ei',\n value: Math.pow(1024, 6),\n scientific: true\n },\n Zi: {\n name: 'Zi',\n value: Math.pow(1024, 7),\n scientific: true\n },\n Yi: {\n name: 'Yi',\n value: Math.pow(1024, 8),\n scientific: true\n }\n },\n BINARY_LONG_SI: {\n '': {\n name: '',\n value: 1,\n scientific: true\n },\n kilo: {\n name: 'kilo',\n value: 1e3,\n scientific: true\n },\n mega: {\n name: 'mega',\n value: 1e6,\n scientific: true\n },\n giga: {\n name: 'giga',\n value: 1e9,\n scientific: true\n },\n tera: {\n name: 'tera',\n value: 1e12,\n scientific: true\n },\n peta: {\n name: 'peta',\n value: 1e15,\n scientific: true\n },\n exa: {\n name: 'exa',\n value: 1e18,\n scientific: true\n },\n zetta: {\n name: 'zetta',\n value: 1e21,\n scientific: true\n },\n yotta: {\n name: 'yotta',\n value: 1e24,\n scientific: true\n }\n },\n BINARY_LONG_IEC: {\n '': {\n name: '',\n value: 1,\n scientific: true\n },\n kibi: {\n name: 'kibi',\n value: 1024,\n scientific: true\n },\n mebi: {\n name: 'mebi',\n value: Math.pow(1024, 2),\n scientific: true\n },\n gibi: {\n name: 'gibi',\n value: Math.pow(1024, 3),\n scientific: true\n },\n tebi: {\n name: 'tebi',\n value: Math.pow(1024, 4),\n scientific: true\n },\n pebi: {\n name: 'pebi',\n value: Math.pow(1024, 5),\n scientific: true\n },\n exi: {\n name: 'exi',\n value: Math.pow(1024, 6),\n scientific: true\n },\n zebi: {\n name: 'zebi',\n value: Math.pow(1024, 7),\n scientific: true\n },\n yobi: {\n name: 'yobi',\n value: Math.pow(1024, 8),\n scientific: true\n }\n },\n BTU: {\n '': {\n name: '',\n value: 1,\n scientific: true\n },\n MM: {\n name: 'MM',\n value: 1e6,\n scientific: true\n }\n }\n };\n PREFIXES.SHORTLONG = (0, _extends2.default)({}, PREFIXES.SHORT, PREFIXES.LONG);\n PREFIXES.BINARY_SHORT = (0, _extends2.default)({}, PREFIXES.BINARY_SHORT_SI, PREFIXES.BINARY_SHORT_IEC);\n PREFIXES.BINARY_LONG = (0, _extends2.default)({}, PREFIXES.BINARY_LONG_SI, PREFIXES.BINARY_LONG_IEC);\n /* Internally, each unit is represented by a value and a dimension array. The elements of the dimensions array have the following meaning:\n * Index Dimension\n * ----- ---------\n * 0 Length\n * 1 Mass\n * 2 Time\n * 3 Current\n * 4 Temperature\n * 5 Luminous intensity\n * 6 Amount of substance\n * 7 Angle\n * 8 Bit (digital)\n * For example, the unit \"298.15 K\" is a pure temperature and would have a value of 298.15 and a dimension array of [0, 0, 0, 0, 1, 0, 0, 0, 0]. The unit \"1 cal / (gm °C)\" can be written in terms of the 9 fundamental dimensions as [length^2] / ([time^2] * [temperature]), and would a value of (after conversion to SI) 4184.0 and a dimensions array of [2, 0, -2, 0, -1, 0, 0, 0, 0].\n *\n */\n\n var BASE_DIMENSIONS = ['MASS', 'LENGTH', 'TIME', 'CURRENT', 'TEMPERATURE', 'LUMINOUS_INTENSITY', 'AMOUNT_OF_SUBSTANCE', 'ANGLE', 'BIT'];\n var BASE_UNITS = {\n NONE: {\n dimensions: [0, 0, 0, 0, 0, 0, 0, 0, 0]\n },\n MASS: {\n dimensions: [1, 0, 0, 0, 0, 0, 0, 0, 0]\n },\n LENGTH: {\n dimensions: [0, 1, 0, 0, 0, 0, 0, 0, 0]\n },\n TIME: {\n dimensions: [0, 0, 1, 0, 0, 0, 0, 0, 0]\n },\n CURRENT: {\n dimensions: [0, 0, 0, 1, 0, 0, 0, 0, 0]\n },\n TEMPERATURE: {\n dimensions: [0, 0, 0, 0, 1, 0, 0, 0, 0]\n },\n LUMINOUS_INTENSITY: {\n dimensions: [0, 0, 0, 0, 0, 1, 0, 0, 0]\n },\n AMOUNT_OF_SUBSTANCE: {\n dimensions: [0, 0, 0, 0, 0, 0, 1, 0, 0]\n },\n FORCE: {\n dimensions: [1, 1, -2, 0, 0, 0, 0, 0, 0]\n },\n SURFACE: {\n dimensions: [0, 2, 0, 0, 0, 0, 0, 0, 0]\n },\n VOLUME: {\n dimensions: [0, 3, 0, 0, 0, 0, 0, 0, 0]\n },\n ENERGY: {\n dimensions: [1, 2, -2, 0, 0, 0, 0, 0, 0]\n },\n POWER: {\n dimensions: [1, 2, -3, 0, 0, 0, 0, 0, 0]\n },\n PRESSURE: {\n dimensions: [1, -1, -2, 0, 0, 0, 0, 0, 0]\n },\n ELECTRIC_CHARGE: {\n dimensions: [0, 0, 1, 1, 0, 0, 0, 0, 0]\n },\n ELECTRIC_CAPACITANCE: {\n dimensions: [-1, -2, 4, 2, 0, 0, 0, 0, 0]\n },\n ELECTRIC_POTENTIAL: {\n dimensions: [1, 2, -3, -1, 0, 0, 0, 0, 0]\n },\n ELECTRIC_RESISTANCE: {\n dimensions: [1, 2, -3, -2, 0, 0, 0, 0, 0]\n },\n ELECTRIC_INDUCTANCE: {\n dimensions: [1, 2, -2, -2, 0, 0, 0, 0, 0]\n },\n ELECTRIC_CONDUCTANCE: {\n dimensions: [-1, -2, 3, 2, 0, 0, 0, 0, 0]\n },\n MAGNETIC_FLUX: {\n dimensions: [1, 2, -2, -1, 0, 0, 0, 0, 0]\n },\n MAGNETIC_FLUX_DENSITY: {\n dimensions: [1, 0, -2, -1, 0, 0, 0, 0, 0]\n },\n FREQUENCY: {\n dimensions: [0, 0, -1, 0, 0, 0, 0, 0, 0]\n },\n ANGLE: {\n dimensions: [0, 0, 0, 0, 0, 0, 0, 1, 0]\n },\n BIT: {\n dimensions: [0, 0, 0, 0, 0, 0, 0, 0, 1]\n }\n };\n\n for (var key in BASE_UNITS) {\n if ((0, _object.hasOwnProperty)(BASE_UNITS, key)) {\n BASE_UNITS[key].key = key;\n }\n }\n\n var BASE_UNIT_NONE = {};\n var UNIT_NONE = {\n name: '',\n base: BASE_UNIT_NONE,\n value: 1,\n offset: 0,\n dimensions: BASE_DIMENSIONS.map(function (x) {\n return 0;\n })\n };\n var UNITS = {\n // length\n meter: {\n name: 'meter',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n inch: {\n name: 'inch',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.0254,\n offset: 0\n },\n foot: {\n name: 'foot',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.3048,\n offset: 0\n },\n yard: {\n name: 'yard',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.9144,\n offset: 0\n },\n mile: {\n name: 'mile',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 1609.344,\n offset: 0\n },\n link: {\n name: 'link',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.201168,\n offset: 0\n },\n rod: {\n name: 'rod',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 5.0292,\n offset: 0\n },\n chain: {\n name: 'chain',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 20.1168,\n offset: 0\n },\n angstrom: {\n name: 'angstrom',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 1e-10,\n offset: 0\n },\n m: {\n name: 'm',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n in: {\n name: 'in',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.0254,\n offset: 0\n },\n ft: {\n name: 'ft',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.3048,\n offset: 0\n },\n yd: {\n name: 'yd',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.9144,\n offset: 0\n },\n mi: {\n name: 'mi',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 1609.344,\n offset: 0\n },\n li: {\n name: 'li',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.201168,\n offset: 0\n },\n rd: {\n name: 'rd',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 5.029210,\n offset: 0\n },\n ch: {\n name: 'ch',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 20.1168,\n offset: 0\n },\n mil: {\n name: 'mil',\n base: BASE_UNITS.LENGTH,\n prefixes: PREFIXES.NONE,\n value: 0.0000254,\n offset: 0\n },\n // 1/1000 inch\n // Surface\n m2: {\n name: 'm2',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.SQUARED,\n value: 1,\n offset: 0\n },\n sqin: {\n name: 'sqin',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 0.00064516,\n offset: 0\n },\n // 645.16 mm2\n sqft: {\n name: 'sqft',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 0.09290304,\n offset: 0\n },\n // 0.09290304 m2\n sqyd: {\n name: 'sqyd',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 0.83612736,\n offset: 0\n },\n // 0.83612736 m2\n sqmi: {\n name: 'sqmi',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 2589988.110336,\n offset: 0\n },\n // 2.589988110336 km2\n sqrd: {\n name: 'sqrd',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 25.29295,\n offset: 0\n },\n // 25.29295 m2\n sqch: {\n name: 'sqch',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 404.6873,\n offset: 0\n },\n // 404.6873 m2\n sqmil: {\n name: 'sqmil',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 6.4516e-10,\n offset: 0\n },\n // 6.4516 * 10^-10 m2\n acre: {\n name: 'acre',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 4046.86,\n offset: 0\n },\n // 4046.86 m2\n hectare: {\n name: 'hectare',\n base: BASE_UNITS.SURFACE,\n prefixes: PREFIXES.NONE,\n value: 10000,\n offset: 0\n },\n // 10000 m2\n // Volume\n m3: {\n name: 'm3',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.CUBIC,\n value: 1,\n offset: 0\n },\n L: {\n name: 'L',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.SHORT,\n value: 0.001,\n offset: 0\n },\n // litre\n l: {\n name: 'l',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.SHORT,\n value: 0.001,\n offset: 0\n },\n // litre\n litre: {\n name: 'litre',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.LONG,\n value: 0.001,\n offset: 0\n },\n cuin: {\n name: 'cuin',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 1.6387064e-5,\n offset: 0\n },\n // 1.6387064e-5 m3\n cuft: {\n name: 'cuft',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.028316846592,\n offset: 0\n },\n // 28.316 846 592 L\n cuyd: {\n name: 'cuyd',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.764554857984,\n offset: 0\n },\n // 764.554 857 984 L\n teaspoon: {\n name: 'teaspoon',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.000005,\n offset: 0\n },\n // 5 mL\n tablespoon: {\n name: 'tablespoon',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.000015,\n offset: 0\n },\n // 15 mL\n // {name: 'cup', base: BASE_UNITS.VOLUME, prefixes: PREFIXES.NONE, value: 0.000240, offset: 0}, // 240 mL // not possible, we have already another cup\n drop: {\n name: 'drop',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 5e-8,\n offset: 0\n },\n // 0.05 mL = 5e-8 m3\n gtt: {\n name: 'gtt',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 5e-8,\n offset: 0\n },\n // 0.05 mL = 5e-8 m3\n // Liquid volume\n minim: {\n name: 'minim',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.00000006161152,\n offset: 0\n },\n // 0.06161152 mL\n fluiddram: {\n name: 'fluiddram',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0000036966911,\n offset: 0\n },\n // 3.696691 mL\n fluidounce: {\n name: 'fluidounce',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.00002957353,\n offset: 0\n },\n // 29.57353 mL\n gill: {\n name: 'gill',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0001182941,\n offset: 0\n },\n // 118.2941 mL\n cc: {\n name: 'cc',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 1e-6,\n offset: 0\n },\n // 1e-6 L\n cup: {\n name: 'cup',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0002365882,\n offset: 0\n },\n // 236.5882 mL\n pint: {\n name: 'pint',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0004731765,\n offset: 0\n },\n // 473.1765 mL\n quart: {\n name: 'quart',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0009463529,\n offset: 0\n },\n // 946.3529 mL\n gallon: {\n name: 'gallon',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.003785412,\n offset: 0\n },\n // 3.785412 L\n beerbarrel: {\n name: 'beerbarrel',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.1173478,\n offset: 0\n },\n // 117.3478 L\n oilbarrel: {\n name: 'oilbarrel',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.1589873,\n offset: 0\n },\n // 158.9873 L\n hogshead: {\n name: 'hogshead',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.2384810,\n offset: 0\n },\n // 238.4810 L\n // {name: 'min', base: BASE_UNITS.VOLUME, prefixes: PREFIXES.NONE, value: 0.00000006161152, offset: 0}, // 0.06161152 mL // min is already in use as minute\n fldr: {\n name: 'fldr',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0000036966911,\n offset: 0\n },\n // 3.696691 mL\n floz: {\n name: 'floz',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.00002957353,\n offset: 0\n },\n // 29.57353 mL\n gi: {\n name: 'gi',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0001182941,\n offset: 0\n },\n // 118.2941 mL\n cp: {\n name: 'cp',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0002365882,\n offset: 0\n },\n // 236.5882 mL\n pt: {\n name: 'pt',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0004731765,\n offset: 0\n },\n // 473.1765 mL\n qt: {\n name: 'qt',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.0009463529,\n offset: 0\n },\n // 946.3529 mL\n gal: {\n name: 'gal',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.003785412,\n offset: 0\n },\n // 3.785412 L\n bbl: {\n name: 'bbl',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.1173478,\n offset: 0\n },\n // 117.3478 L\n obl: {\n name: 'obl',\n base: BASE_UNITS.VOLUME,\n prefixes: PREFIXES.NONE,\n value: 0.1589873,\n offset: 0\n },\n // 158.9873 L\n // {name: 'hogshead', base: BASE_UNITS.VOLUME, prefixes: PREFIXES.NONE, value: 0.2384810, offset: 0}, // 238.4810 L // TODO: hh?\n // Mass\n g: {\n name: 'g',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.SHORT,\n value: 0.001,\n offset: 0\n },\n gram: {\n name: 'gram',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.LONG,\n value: 0.001,\n offset: 0\n },\n ton: {\n name: 'ton',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.SHORT,\n value: 907.18474,\n offset: 0\n },\n t: {\n name: 't',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.SHORT,\n value: 1000,\n offset: 0\n },\n tonne: {\n name: 'tonne',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.LONG,\n value: 1000,\n offset: 0\n },\n grain: {\n name: 'grain',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 64.79891e-6,\n offset: 0\n },\n dram: {\n name: 'dram',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 1.7718451953125e-3,\n offset: 0\n },\n ounce: {\n name: 'ounce',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 28.349523125e-3,\n offset: 0\n },\n poundmass: {\n name: 'poundmass',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 453.59237e-3,\n offset: 0\n },\n hundredweight: {\n name: 'hundredweight',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 45.359237,\n offset: 0\n },\n stick: {\n name: 'stick',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 115e-3,\n offset: 0\n },\n stone: {\n name: 'stone',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 6.35029318,\n offset: 0\n },\n gr: {\n name: 'gr',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 64.79891e-6,\n offset: 0\n },\n dr: {\n name: 'dr',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 1.7718451953125e-3,\n offset: 0\n },\n oz: {\n name: 'oz',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 28.349523125e-3,\n offset: 0\n },\n lbm: {\n name: 'lbm',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 453.59237e-3,\n offset: 0\n },\n cwt: {\n name: 'cwt',\n base: BASE_UNITS.MASS,\n prefixes: PREFIXES.NONE,\n value: 45.359237,\n offset: 0\n },\n // Time\n s: {\n name: 's',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n min: {\n name: 'min',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 60,\n offset: 0\n },\n h: {\n name: 'h',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 3600,\n offset: 0\n },\n second: {\n name: 'second',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n sec: {\n name: 'sec',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n minute: {\n name: 'minute',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 60,\n offset: 0\n },\n hour: {\n name: 'hour',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 3600,\n offset: 0\n },\n day: {\n name: 'day',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 86400,\n offset: 0\n },\n week: {\n name: 'week',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 7 * 86400,\n offset: 0\n },\n month: {\n name: 'month',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 2629800,\n // 1/12th of Julian year\n offset: 0\n },\n year: {\n name: 'year',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 31557600,\n // Julian year\n offset: 0\n },\n decade: {\n name: 'decade',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 315576000,\n // Julian decade\n offset: 0\n },\n century: {\n name: 'century',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 3155760000,\n // Julian century\n offset: 0\n },\n millennium: {\n name: 'millennium',\n base: BASE_UNITS.TIME,\n prefixes: PREFIXES.NONE,\n value: 31557600000,\n // Julian millennium\n offset: 0\n },\n // Frequency\n hertz: {\n name: 'Hertz',\n base: BASE_UNITS.FREQUENCY,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0,\n reciprocal: true\n },\n Hz: {\n name: 'Hz',\n base: BASE_UNITS.FREQUENCY,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0,\n reciprocal: true\n },\n // Angle\n rad: {\n name: 'rad',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n radian: {\n name: 'radian',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n // deg = rad / (2*pi) * 360 = rad / 0.017453292519943295769236907684888\n deg: {\n name: 'deg',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.SHORT,\n value: null,\n // will be filled in by calculateAngleValues()\n offset: 0\n },\n degree: {\n name: 'degree',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.LONG,\n value: null,\n // will be filled in by calculateAngleValues()\n offset: 0\n },\n // grad = rad / (2*pi) * 400 = rad / 0.015707963267948966192313216916399\n grad: {\n name: 'grad',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.SHORT,\n value: null,\n // will be filled in by calculateAngleValues()\n offset: 0\n },\n gradian: {\n name: 'gradian',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.LONG,\n value: null,\n // will be filled in by calculateAngleValues()\n offset: 0\n },\n // cycle = rad / (2*pi) = rad / 6.2831853071795864769252867665793\n cycle: {\n name: 'cycle',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.NONE,\n value: null,\n // will be filled in by calculateAngleValues()\n offset: 0\n },\n // arcsec = rad / (3600 * (360 / 2 * pi)) = rad / 0.0000048481368110953599358991410235795\n arcsec: {\n name: 'arcsec',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.NONE,\n value: null,\n // will be filled in by calculateAngleValues()\n offset: 0\n },\n // arcmin = rad / (60 * (360 / 2 * pi)) = rad / 0.00029088820866572159615394846141477\n arcmin: {\n name: 'arcmin',\n base: BASE_UNITS.ANGLE,\n prefixes: PREFIXES.NONE,\n value: null,\n // will be filled in by calculateAngleValues()\n offset: 0\n },\n // Electric current\n A: {\n name: 'A',\n base: BASE_UNITS.CURRENT,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n ampere: {\n name: 'ampere',\n base: BASE_UNITS.CURRENT,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n // Temperature\n // K(C) = °C + 273.15\n // K(F) = (°F + 459.67) / 1.8\n // K(R) = °R / 1.8\n K: {\n name: 'K',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.NONE,\n value: 1,\n offset: 0\n },\n degC: {\n name: 'degC',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.NONE,\n value: 1,\n offset: 273.15\n },\n degF: {\n name: 'degF',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.NONE,\n value: 1 / 1.8,\n offset: 459.67\n },\n degR: {\n name: 'degR',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.NONE,\n value: 1 / 1.8,\n offset: 0\n },\n kelvin: {\n name: 'kelvin',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.NONE,\n value: 1,\n offset: 0\n },\n celsius: {\n name: 'celsius',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.NONE,\n value: 1,\n offset: 273.15\n },\n fahrenheit: {\n name: 'fahrenheit',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.NONE,\n value: 1 / 1.8,\n offset: 459.67\n },\n rankine: {\n name: 'rankine',\n base: BASE_UNITS.TEMPERATURE,\n prefixes: PREFIXES.NONE,\n value: 1 / 1.8,\n offset: 0\n },\n // amount of substance\n mol: {\n name: 'mol',\n base: BASE_UNITS.AMOUNT_OF_SUBSTANCE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n mole: {\n name: 'mole',\n base: BASE_UNITS.AMOUNT_OF_SUBSTANCE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n // luminous intensity\n cd: {\n name: 'cd',\n base: BASE_UNITS.LUMINOUS_INTENSITY,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n candela: {\n name: 'candela',\n base: BASE_UNITS.LUMINOUS_INTENSITY,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n // TODO: units STERADIAN\n // {name: 'sr', base: BASE_UNITS.STERADIAN, prefixes: PREFIXES.NONE, value: 1, offset: 0},\n // {name: 'steradian', base: BASE_UNITS.STERADIAN, prefixes: PREFIXES.NONE, value: 1, offset: 0},\n // Force\n N: {\n name: 'N',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n newton: {\n name: 'newton',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n dyn: {\n name: 'dyn',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.SHORT,\n value: 0.00001,\n offset: 0\n },\n dyne: {\n name: 'dyne',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.LONG,\n value: 0.00001,\n offset: 0\n },\n lbf: {\n name: 'lbf',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.NONE,\n value: 4.4482216152605,\n offset: 0\n },\n poundforce: {\n name: 'poundforce',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.NONE,\n value: 4.4482216152605,\n offset: 0\n },\n kip: {\n name: 'kip',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.LONG,\n value: 4448.2216,\n offset: 0\n },\n kilogramforce: {\n name: 'kilogramforce',\n base: BASE_UNITS.FORCE,\n prefixes: PREFIXES.NONE,\n value: 9.80665,\n offset: 0\n },\n // Energy\n J: {\n name: 'J',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n joule: {\n name: 'joule',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n erg: {\n name: 'erg',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.NONE,\n value: 1e-7,\n offset: 0\n },\n Wh: {\n name: 'Wh',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.SHORT,\n value: 3600,\n offset: 0\n },\n BTU: {\n name: 'BTU',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.BTU,\n value: 1055.05585262,\n offset: 0\n },\n eV: {\n name: 'eV',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.SHORT,\n value: 1.602176565e-19,\n offset: 0\n },\n electronvolt: {\n name: 'electronvolt',\n base: BASE_UNITS.ENERGY,\n prefixes: PREFIXES.LONG,\n value: 1.602176565e-19,\n offset: 0\n },\n // Power\n W: {\n name: 'W',\n base: BASE_UNITS.POWER,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n watt: {\n name: 'watt',\n base: BASE_UNITS.POWER,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n hp: {\n name: 'hp',\n base: BASE_UNITS.POWER,\n prefixes: PREFIXES.NONE,\n value: 745.6998715386,\n offset: 0\n },\n // Electrical power units\n VAR: {\n name: 'VAR',\n base: BASE_UNITS.POWER,\n prefixes: PREFIXES.SHORT,\n value: Complex.I,\n offset: 0\n },\n VA: {\n name: 'VA',\n base: BASE_UNITS.POWER,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Pressure\n Pa: {\n name: 'Pa',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n psi: {\n name: 'psi',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.NONE,\n value: 6894.75729276459,\n offset: 0\n },\n atm: {\n name: 'atm',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.NONE,\n value: 101325,\n offset: 0\n },\n bar: {\n name: 'bar',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.SHORTLONG,\n value: 100000,\n offset: 0\n },\n torr: {\n name: 'torr',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.NONE,\n value: 133.322,\n offset: 0\n },\n mmHg: {\n name: 'mmHg',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.NONE,\n value: 133.322,\n offset: 0\n },\n mmH2O: {\n name: 'mmH2O',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.NONE,\n value: 9.80665,\n offset: 0\n },\n cmH2O: {\n name: 'cmH2O',\n base: BASE_UNITS.PRESSURE,\n prefixes: PREFIXES.NONE,\n value: 98.0665,\n offset: 0\n },\n // Electric charge\n coulomb: {\n name: 'coulomb',\n base: BASE_UNITS.ELECTRIC_CHARGE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n C: {\n name: 'C',\n base: BASE_UNITS.ELECTRIC_CHARGE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Electric capacitance\n farad: {\n name: 'farad',\n base: BASE_UNITS.ELECTRIC_CAPACITANCE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n F: {\n name: 'F',\n base: BASE_UNITS.ELECTRIC_CAPACITANCE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Electric potential\n volt: {\n name: 'volt',\n base: BASE_UNITS.ELECTRIC_POTENTIAL,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n V: {\n name: 'V',\n base: BASE_UNITS.ELECTRIC_POTENTIAL,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Electric resistance\n ohm: {\n name: 'ohm',\n base: BASE_UNITS.ELECTRIC_RESISTANCE,\n prefixes: PREFIXES.SHORTLONG,\n // Both Mohm and megaohm are acceptable\n value: 1,\n offset: 0\n },\n\n /*\n * Unicode breaks in browsers if charset is not specified\n Ω: {\n name: 'Ω',\n base: BASE_UNITS.ELECTRIC_RESISTANCE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n */\n // Electric inductance\n henry: {\n name: 'henry',\n base: BASE_UNITS.ELECTRIC_INDUCTANCE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n H: {\n name: 'H',\n base: BASE_UNITS.ELECTRIC_INDUCTANCE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Electric conductance\n siemens: {\n name: 'siemens',\n base: BASE_UNITS.ELECTRIC_CONDUCTANCE,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n S: {\n name: 'S',\n base: BASE_UNITS.ELECTRIC_CONDUCTANCE,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Magnetic flux\n weber: {\n name: 'weber',\n base: BASE_UNITS.MAGNETIC_FLUX,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n Wb: {\n name: 'Wb',\n base: BASE_UNITS.MAGNETIC_FLUX,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Magnetic flux density\n tesla: {\n name: 'tesla',\n base: BASE_UNITS.MAGNETIC_FLUX_DENSITY,\n prefixes: PREFIXES.LONG,\n value: 1,\n offset: 0\n },\n T: {\n name: 'T',\n base: BASE_UNITS.MAGNETIC_FLUX_DENSITY,\n prefixes: PREFIXES.SHORT,\n value: 1,\n offset: 0\n },\n // Binary\n b: {\n name: 'b',\n base: BASE_UNITS.BIT,\n prefixes: PREFIXES.BINARY_SHORT,\n value: 1,\n offset: 0\n },\n bits: {\n name: 'bits',\n base: BASE_UNITS.BIT,\n prefixes: PREFIXES.BINARY_LONG,\n value: 1,\n offset: 0\n },\n B: {\n name: 'B',\n base: BASE_UNITS.BIT,\n prefixes: PREFIXES.BINARY_SHORT,\n value: 8,\n offset: 0\n },\n bytes: {\n name: 'bytes',\n base: BASE_UNITS.BIT,\n prefixes: PREFIXES.BINARY_LONG,\n value: 8,\n offset: 0\n }\n }; // aliases (formerly plurals)\n\n var ALIASES = {\n meters: 'meter',\n inches: 'inch',\n feet: 'foot',\n yards: 'yard',\n miles: 'mile',\n links: 'link',\n rods: 'rod',\n chains: 'chain',\n angstroms: 'angstrom',\n lt: 'l',\n litres: 'litre',\n liter: 'litre',\n liters: 'litre',\n teaspoons: 'teaspoon',\n tablespoons: 'tablespoon',\n minims: 'minim',\n fluiddrams: 'fluiddram',\n fluidounces: 'fluidounce',\n gills: 'gill',\n cups: 'cup',\n pints: 'pint',\n quarts: 'quart',\n gallons: 'gallon',\n beerbarrels: 'beerbarrel',\n oilbarrels: 'oilbarrel',\n hogsheads: 'hogshead',\n gtts: 'gtt',\n grams: 'gram',\n tons: 'ton',\n tonnes: 'tonne',\n grains: 'grain',\n drams: 'dram',\n ounces: 'ounce',\n poundmasses: 'poundmass',\n hundredweights: 'hundredweight',\n sticks: 'stick',\n lb: 'lbm',\n lbs: 'lbm',\n kips: 'kip',\n kgf: 'kilogramforce',\n acres: 'acre',\n hectares: 'hectare',\n sqfeet: 'sqft',\n sqyard: 'sqyd',\n sqmile: 'sqmi',\n sqmiles: 'sqmi',\n mmhg: 'mmHg',\n mmh2o: 'mmH2O',\n cmh2o: 'cmH2O',\n seconds: 'second',\n secs: 'second',\n minutes: 'minute',\n mins: 'minute',\n hours: 'hour',\n hr: 'hour',\n hrs: 'hour',\n days: 'day',\n weeks: 'week',\n months: 'month',\n years: 'year',\n decades: 'decade',\n centuries: 'century',\n millennia: 'millennium',\n hertz: 'hertz',\n radians: 'radian',\n degrees: 'degree',\n gradians: 'gradian',\n cycles: 'cycle',\n arcsecond: 'arcsec',\n arcseconds: 'arcsec',\n arcminute: 'arcmin',\n arcminutes: 'arcmin',\n BTUs: 'BTU',\n watts: 'watt',\n joules: 'joule',\n amperes: 'ampere',\n coulombs: 'coulomb',\n volts: 'volt',\n ohms: 'ohm',\n farads: 'farad',\n webers: 'weber',\n teslas: 'tesla',\n electronvolts: 'electronvolt',\n moles: 'mole',\n bit: 'bits',\n byte: 'bytes'\n };\n /**\n * Calculate the values for the angle units.\n * Value is calculated as number or BigNumber depending on the configuration\n * @param {{number: 'number' | 'BigNumber'}} config\n */\n\n function calculateAngleValues(config) {\n if (config.number === 'BigNumber') {\n var pi = (0, _constants.createBigNumberPi)(_BigNumber);\n UNITS.rad.value = new _BigNumber(1);\n UNITS.deg.value = pi.div(180); // 2 * pi / 360\n\n UNITS.grad.value = pi.div(200); // 2 * pi / 400\n\n UNITS.cycle.value = pi.times(2); // 2 * pi\n\n UNITS.arcsec.value = pi.div(648000); // 2 * pi / 360 / 3600\n\n UNITS.arcmin.value = pi.div(10800); // 2 * pi / 360 / 60\n } else {\n // number\n UNITS.rad.value = 1;\n UNITS.deg.value = Math.PI / 180; // 2 * pi / 360\n\n UNITS.grad.value = Math.PI / 200; // 2 * pi / 400\n\n UNITS.cycle.value = Math.PI * 2; // 2 * pi\n\n UNITS.arcsec.value = Math.PI / 648000; // 2 * pi / 360 / 3600\n\n UNITS.arcmin.value = Math.PI / 10800; // 2 * pi / 360 / 60\n } // copy to the full names of the angles\n\n\n UNITS.radian.value = UNITS.rad.value;\n UNITS.degree.value = UNITS.deg.value;\n UNITS.gradian.value = UNITS.grad.value;\n } // apply the angle values now\n\n\n calculateAngleValues(config);\n\n if (on) {\n // recalculate the values on change of configuration\n on('config', function (curr, prev) {\n if (curr.number !== prev.number) {\n calculateAngleValues(curr);\n }\n });\n }\n /**\n * A unit system is a set of dimensionally independent base units plus a set of derived units, formed by multiplication and division of the base units, that are by convention used with the unit system.\n * A user perhaps could issue a command to select a preferred unit system, or use the default (see below).\n * Auto unit system: The default unit system is updated on the fly anytime a unit is parsed. The corresponding unit in the default unit system is updated, so that answers are given in the same units the user supplies.\n */\n\n\n var UNIT_SYSTEMS = {\n si: {\n // Base units\n NONE: {\n unit: UNIT_NONE,\n prefix: PREFIXES.NONE['']\n },\n LENGTH: {\n unit: UNITS.m,\n prefix: PREFIXES.SHORT['']\n },\n MASS: {\n unit: UNITS.g,\n prefix: PREFIXES.SHORT.k\n },\n TIME: {\n unit: UNITS.s,\n prefix: PREFIXES.SHORT['']\n },\n CURRENT: {\n unit: UNITS.A,\n prefix: PREFIXES.SHORT['']\n },\n TEMPERATURE: {\n unit: UNITS.K,\n prefix: PREFIXES.SHORT['']\n },\n LUMINOUS_INTENSITY: {\n unit: UNITS.cd,\n prefix: PREFIXES.SHORT['']\n },\n AMOUNT_OF_SUBSTANCE: {\n unit: UNITS.mol,\n prefix: PREFIXES.SHORT['']\n },\n ANGLE: {\n unit: UNITS.rad,\n prefix: PREFIXES.SHORT['']\n },\n BIT: {\n unit: UNITS.bits,\n prefix: PREFIXES.SHORT['']\n },\n // Derived units\n FORCE: {\n unit: UNITS.N,\n prefix: PREFIXES.SHORT['']\n },\n ENERGY: {\n unit: UNITS.J,\n prefix: PREFIXES.SHORT['']\n },\n POWER: {\n unit: UNITS.W,\n prefix: PREFIXES.SHORT['']\n },\n PRESSURE: {\n unit: UNITS.Pa,\n prefix: PREFIXES.SHORT['']\n },\n ELECTRIC_CHARGE: {\n unit: UNITS.C,\n prefix: PREFIXES.SHORT['']\n },\n ELECTRIC_CAPACITANCE: {\n unit: UNITS.F,\n prefix: PREFIXES.SHORT['']\n },\n ELECTRIC_POTENTIAL: {\n unit: UNITS.V,\n prefix: PREFIXES.SHORT['']\n },\n ELECTRIC_RESISTANCE: {\n unit: UNITS.ohm,\n prefix: PREFIXES.SHORT['']\n },\n ELECTRIC_INDUCTANCE: {\n unit: UNITS.H,\n prefix: PREFIXES.SHORT['']\n },\n ELECTRIC_CONDUCTANCE: {\n unit: UNITS.S,\n prefix: PREFIXES.SHORT['']\n },\n MAGNETIC_FLUX: {\n unit: UNITS.Wb,\n prefix: PREFIXES.SHORT['']\n },\n MAGNETIC_FLUX_DENSITY: {\n unit: UNITS.T,\n prefix: PREFIXES.SHORT['']\n },\n FREQUENCY: {\n unit: UNITS.Hz,\n prefix: PREFIXES.SHORT['']\n }\n }\n }; // Clone to create the other unit systems\n\n UNIT_SYSTEMS.cgs = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si));\n UNIT_SYSTEMS.cgs.LENGTH = {\n unit: UNITS.m,\n prefix: PREFIXES.SHORT.c\n };\n UNIT_SYSTEMS.cgs.MASS = {\n unit: UNITS.g,\n prefix: PREFIXES.SHORT['']\n };\n UNIT_SYSTEMS.cgs.FORCE = {\n unit: UNITS.dyn,\n prefix: PREFIXES.SHORT['']\n };\n UNIT_SYSTEMS.cgs.ENERGY = {\n unit: UNITS.erg,\n prefix: PREFIXES.NONE['']\n }; // there are wholly 4 unique cgs systems for electricity and magnetism,\n // so let's not worry about it unless somebody complains\n\n UNIT_SYSTEMS.us = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si));\n UNIT_SYSTEMS.us.LENGTH = {\n unit: UNITS.ft,\n prefix: PREFIXES.NONE['']\n };\n UNIT_SYSTEMS.us.MASS = {\n unit: UNITS.lbm,\n prefix: PREFIXES.NONE['']\n };\n UNIT_SYSTEMS.us.TEMPERATURE = {\n unit: UNITS.degF,\n prefix: PREFIXES.NONE['']\n };\n UNIT_SYSTEMS.us.FORCE = {\n unit: UNITS.lbf,\n prefix: PREFIXES.NONE['']\n };\n UNIT_SYSTEMS.us.ENERGY = {\n unit: UNITS.BTU,\n prefix: PREFIXES.BTU['']\n };\n UNIT_SYSTEMS.us.POWER = {\n unit: UNITS.hp,\n prefix: PREFIXES.NONE['']\n };\n UNIT_SYSTEMS.us.PRESSURE = {\n unit: UNITS.psi,\n prefix: PREFIXES.NONE['']\n }; // Add additional unit systems here.\n // Choose a unit system to seed the auto unit system.\n\n UNIT_SYSTEMS.auto = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si)); // Set the current unit system\n\n var currentUnitSystem = UNIT_SYSTEMS.auto;\n /**\n * Set a unit system for formatting derived units.\n * @param {string} [name] The name of the unit system.\n */\n\n Unit.setUnitSystem = function (name) {\n if ((0, _object.hasOwnProperty)(UNIT_SYSTEMS, name)) {\n currentUnitSystem = UNIT_SYSTEMS[name];\n } else {\n throw new Error('Unit system ' + name + ' does not exist. Choices are: ' + Object.keys(UNIT_SYSTEMS).join(', '));\n }\n };\n /**\n * Return the current unit system.\n * @return {string} The current unit system.\n */\n\n\n Unit.getUnitSystem = function () {\n for (var _key in UNIT_SYSTEMS) {\n if ((0, _object.hasOwnProperty)(UNIT_SYSTEMS, _key)) {\n if (UNIT_SYSTEMS[_key] === currentUnitSystem) {\n return _key;\n }\n }\n }\n };\n /**\n * Converters to convert from number to an other numeric type like BigNumber\n * or Fraction\n */\n\n\n Unit.typeConverters = {\n BigNumber: function BigNumber(x) {\n return new _BigNumber(x + ''); // stringify to prevent constructor error\n },\n Fraction: function Fraction(x) {\n return new _Fraction(x);\n },\n Complex: function Complex(x) {\n return x;\n },\n number: function number(x) {\n return x;\n }\n };\n /**\n * Retrieve the right convertor function corresponding with the type\n * of provided exampleValue.\n *\n * @param {string} type A string 'number', 'BigNumber', or 'Fraction'\n * In case of an unknown type,\n * @return {Function}\n */\n\n Unit._getNumberConverter = function (type) {\n if (!Unit.typeConverters[type]) {\n throw new TypeError('Unsupported type \"' + type + '\"');\n }\n\n return Unit.typeConverters[type];\n }; // Add dimensions to each built-in unit\n\n\n for (var _key2 in UNITS) {\n if ((0, _object.hasOwnProperty)(UNITS, _key2)) {\n var unit = UNITS[_key2];\n unit.dimensions = unit.base.dimensions;\n }\n } // Create aliases\n\n\n for (var _name2 in ALIASES) {\n if ((0, _object.hasOwnProperty)(ALIASES, _name2)) {\n var _unit2 = UNITS[ALIASES[_name2]];\n var alias = {};\n\n for (var _key3 in _unit2) {\n if ((0, _object.hasOwnProperty)(_unit2, _key3)) {\n alias[_key3] = _unit2[_key3];\n }\n }\n\n alias.name = _name2;\n UNITS[_name2] = alias;\n }\n }\n /**\n * Checks if a character is a valid latin letter (upper or lower case).\n * Note that this function can be overridden, for example to allow support of other alphabets.\n * @param {string} c Tested character\n */\n\n\n Unit.isValidAlpha = function isValidAlpha(c) {\n return /^[a-zA-Z]$/.test(c);\n };\n\n function assertUnitNameIsValid(name) {\n for (var i = 0; i < name.length; i++) {\n c = name.charAt(i);\n\n if (i === 0 && !Unit.isValidAlpha(c)) {\n throw new Error('Invalid unit name (must begin with alpha character): \"' + name + '\"');\n }\n\n if (i > 0 && !(Unit.isValidAlpha(c) || isDigit(c))) {\n throw new Error('Invalid unit name (only alphanumeric characters are allowed): \"' + name + '\"');\n }\n }\n }\n /**\n * Wrapper around createUnitSingle.\n * Example:\n * createUnit({\n * foo: { },\n * bar: {\n * definition: 'kg/foo',\n * aliases: ['ba', 'barr', 'bars'],\n * offset: 200\n * },\n * baz: '4 bar'\n * },\n * {\n * override: true\n * })\n * @param {object} obj Object map. Each key becomes a unit which is defined by its value.\n * @param {object} options\n */\n\n\n Unit.createUnit = function (obj, options) {\n if ((0, _typeof2.default)(obj) !== 'object') {\n throw new TypeError(\"createUnit expects first parameter to be of type 'Object'\");\n } // Remove all units and aliases we are overriding\n\n\n if (options && options.override) {\n for (var _key4 in obj) {\n if ((0, _object.hasOwnProperty)(obj, _key4)) {\n Unit.deleteUnit(_key4);\n }\n\n if (obj[_key4].aliases) {\n for (var i = 0; i < obj[_key4].aliases.length; i++) {\n Unit.deleteUnit(obj[_key4].aliases[i]);\n }\n }\n }\n } // TODO: traverse multiple times until all units have been added\n\n\n var lastUnit;\n\n for (var _key5 in obj) {\n if ((0, _object.hasOwnProperty)(obj, _key5)) {\n lastUnit = Unit.createUnitSingle(_key5, obj[_key5]);\n }\n }\n\n return lastUnit;\n };\n /**\n * Create a user-defined unit and register it with the Unit type.\n * Example:\n * createUnitSingle('knot', '0.514444444 m/s')\n * createUnitSingle('acre', new Unit(43560, 'ft^2'))\n *\n * @param {string} name The name of the new unit. Must be unique. Example: 'knot'\n * @param {string, Unit, Object} definition Definition of the unit in terms\n * of existing units. For example, '0.514444444 m / s'. Can be a Unit, a string,\n * or an Object. If an Object, may have the following properties:\n * - definition {string|Unit} The definition of this unit.\n * - prefixes {string} \"none\", \"short\", \"long\", \"binary_short\", or \"binary_long\".\n * The default is \"none\".\n * - aliases {Array} Array of strings. Example: ['knots', 'kt', 'kts']\n * - offset {Numeric} An offset to apply when converting from the unit. For\n * example, the offset for celsius is 273.15 and the offset for farhenheit\n * is 459.67. Default is 0.\n * - baseName {string} If the unit's dimension does not match that of any other\n * base unit, the name of the newly create base unit. Otherwise, this property\n * has no effect.\n *\n * @param {Object} options (optional) An object containing any of the following\n * properties:\n * - override {boolean} Whether this unit should be allowed to override existing\n * units.\n *\n * @return {Unit}\n */\n\n\n Unit.createUnitSingle = function (name, obj, options) {\n if (typeof obj === 'undefined' || obj === null) {\n obj = {};\n }\n\n if (typeof name !== 'string') {\n throw new TypeError(\"createUnitSingle expects first parameter to be of type 'string'\");\n } // Check collisions with existing units\n\n\n if ((0, _object.hasOwnProperty)(UNITS, name)) {\n throw new Error('Cannot create unit \"' + name + '\": a unit with that name already exists');\n } // TODO: Validate name for collisions with other built-in functions (like abs or cos, for example), and for acceptable variable names. For example, '42' is probably not a valid unit. Nor is '%', since it is also an operator.\n\n\n assertUnitNameIsValid(name);\n var defUnit = null; // The Unit from which the new unit will be created.\n\n var aliases = [];\n var offset = 0;\n var definition;\n var prefixes;\n var baseName;\n\n if (obj && obj.type === 'Unit') {\n defUnit = obj.clone();\n } else if (typeof obj === 'string') {\n if (obj !== '') {\n definition = obj;\n }\n } else if ((0, _typeof2.default)(obj) === 'object') {\n definition = obj.definition;\n prefixes = obj.prefixes;\n offset = obj.offset;\n baseName = obj.baseName;\n\n if (obj.aliases) {\n aliases = obj.aliases.valueOf(); // aliases could be a Matrix, so convert to Array\n }\n } else {\n throw new TypeError('Cannot create unit \"' + name + '\" from \"' + obj.toString() + '\": expecting \"string\" or \"Unit\" or \"Object\"');\n }\n\n if (aliases) {\n for (var i = 0; i < aliases.length; i++) {\n if ((0, _object.hasOwnProperty)(UNITS, aliases[i])) {\n throw new Error('Cannot create alias \"' + aliases[i] + '\": a unit with that name already exists');\n }\n }\n }\n\n if (definition && typeof definition === 'string' && !defUnit) {\n try {\n defUnit = Unit.parse(definition, {\n allowNoUnits: true\n });\n } catch (ex) {\n ex.message = 'Could not create unit \"' + name + '\" from \"' + definition + '\": ' + ex.message;\n throw ex;\n }\n } else if (definition && definition.type === 'Unit') {\n defUnit = definition.clone();\n }\n\n aliases = aliases || [];\n offset = offset || 0;\n\n if (prefixes && prefixes.toUpperCase) {\n prefixes = PREFIXES[prefixes.toUpperCase()] || PREFIXES.NONE;\n } else {\n prefixes = PREFIXES.NONE;\n } // If defUnit is null, it is because the user did not\n // specify a defintion. So create a new base dimension.\n\n\n var newUnit = {};\n\n if (!defUnit) {\n // Add a new base dimension\n baseName = baseName || name + '_STUFF'; // foo --> foo_STUFF, or the essence of foo\n\n if (BASE_DIMENSIONS.indexOf(baseName) >= 0) {\n throw new Error('Cannot create new base unit \"' + name + '\": a base unit with that name already exists (and cannot be overridden)');\n }\n\n BASE_DIMENSIONS.push(baseName); // Push 0 onto existing base units\n\n for (var b in BASE_UNITS) {\n if ((0, _object.hasOwnProperty)(BASE_UNITS, b)) {\n BASE_UNITS[b].dimensions[BASE_DIMENSIONS.length - 1] = 0;\n }\n } // Add the new base unit\n\n\n var newBaseUnit = {\n dimensions: []\n };\n\n for (var _i6 = 0; _i6 < BASE_DIMENSIONS.length; _i6++) {\n newBaseUnit.dimensions[_i6] = 0;\n }\n\n newBaseUnit.dimensions[BASE_DIMENSIONS.length - 1] = 1;\n newBaseUnit.key = baseName;\n BASE_UNITS[baseName] = newBaseUnit;\n newUnit = {\n name: name,\n value: 1,\n dimensions: BASE_UNITS[baseName].dimensions.slice(0),\n prefixes: prefixes,\n offset: offset,\n base: BASE_UNITS[baseName]\n };\n currentUnitSystem[baseName] = {\n unit: newUnit,\n prefix: PREFIXES.NONE['']\n };\n } else {\n newUnit = {\n name: name,\n value: defUnit.value,\n dimensions: defUnit.dimensions.slice(0),\n prefixes: prefixes,\n offset: offset\n }; // Create a new base if no matching base exists\n\n var anyMatch = false;\n\n for (var _i7 in BASE_UNITS) {\n if ((0, _object.hasOwnProperty)(BASE_UNITS, _i7)) {\n var match = true;\n\n for (var j = 0; j < BASE_DIMENSIONS.length; j++) {\n if (Math.abs((newUnit.dimensions[j] || 0) - (BASE_UNITS[_i7].dimensions[j] || 0)) > 1e-12) {\n match = false;\n break;\n }\n }\n\n if (match) {\n anyMatch = true;\n newUnit.base = BASE_UNITS[_i7];\n break;\n }\n }\n }\n\n if (!anyMatch) {\n baseName = baseName || name + '_STUFF'; // foo --> foo_STUFF, or the essence of foo\n // Add the new base unit\n\n var _newBaseUnit = {\n dimensions: defUnit.dimensions.slice(0)\n };\n _newBaseUnit.key = baseName;\n BASE_UNITS[baseName] = _newBaseUnit;\n currentUnitSystem[baseName] = {\n unit: newUnit,\n prefix: PREFIXES.NONE['']\n };\n newUnit.base = BASE_UNITS[baseName];\n }\n }\n\n Unit.UNITS[name] = newUnit;\n\n for (var _i8 = 0; _i8 < aliases.length; _i8++) {\n var aliasName = aliases[_i8];\n var _alias = {};\n\n for (var _key6 in newUnit) {\n if ((0, _object.hasOwnProperty)(newUnit, _key6)) {\n _alias[_key6] = newUnit[_key6];\n }\n }\n\n _alias.name = aliasName;\n Unit.UNITS[aliasName] = _alias;\n } // delete the memoization cache, since adding a new unit to the array\n // invalidates all old results\n\n\n delete _findUnit.cache;\n return new Unit(null, name);\n };\n\n Unit.deleteUnit = function (name) {\n delete Unit.UNITS[name];\n }; // expose arrays with prefixes, dimensions, units, systems\n\n\n Unit.PREFIXES = PREFIXES;\n Unit.BASE_DIMENSIONS = BASE_DIMENSIONS;\n Unit.BASE_UNITS = BASE_UNITS;\n Unit.UNIT_SYSTEMS = UNIT_SYSTEMS;\n Unit.UNITS = UNITS;\n return Unit;\n}, {\n isClass: true\n});\nexports.createUnitClass = createUnitClass;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createCreateUnit = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar name = 'createUnit';\nvar dependencies = ['typed', 'Unit'];\nvar createCreateUnit = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Unit = _ref.Unit;\n\n /**\n * Create a user-defined unit and register it with the Unit type.\n *\n * Syntax:\n *\n * math.createUnit({\n * baseUnit1: {\n * aliases: [string, ...]\n * prefixes: object\n * },\n * unit2: {\n * definition: string,\n * aliases: [string, ...]\n * prefixes: object,\n * offset: number\n * },\n * unit3: string // Shortcut\n * })\n *\n * // Another shortcut:\n * math.createUnit(string, unit : string, [object])\n *\n * Examples:\n *\n * math.createUnit('foo')\n * math.createUnit('knot', {definition: '0.514444444 m/s', aliases: ['knots', 'kt', 'kts']})\n * math.createUnit('mph', '1 mile/hour')\n *\n * @param {string} name The name of the new unit. Must be unique. Example: 'knot'\n * @param {string, Unit} definition Definition of the unit in terms of existing units. For example, '0.514444444 m / s'.\n * @param {Object} options (optional) An object containing any of the following properties:\n * - `prefixes {string}` \"none\", \"short\", \"long\", \"binary_short\", or \"binary_long\". The default is \"none\".\n * - `aliases {Array}` Array of strings. Example: ['knots', 'kt', 'kts']\n * - `offset {Numeric}` An offset to apply when converting from the unit. For example, the offset for celsius is 273.15. Default is 0.\n *\n * See also:\n *\n * unit\n *\n * @return {Unit} The new unit\n */\n return typed(name, {\n // General function signature. First parameter is an object where each property is the definition of a new unit. The object keys are the unit names and the values are the definitions. The values can be objects, strings, or Units. If a property is an empty object or an empty string, a new base unit is created. The second parameter is the options.\n 'Object, Object': function ObjectObject(obj, options) {\n return Unit.createUnit(obj, options);\n },\n // Same as above but without the options.\n Object: function Object(obj) {\n return Unit.createUnit(obj, {});\n },\n // Shortcut method for creating one unit.\n 'string, Unit | string | Object, Object': function stringUnitStringObjectObject(name, def, options) {\n var obj = {};\n obj[name] = def;\n return Unit.createUnit(obj, options);\n },\n // Same as above but without the options.\n 'string, Unit | string | Object': function stringUnitStringObject(name, def) {\n var obj = {};\n obj[name] = def;\n return Unit.createUnit(obj, {});\n },\n // Without a definition, creates a base unit.\n string: function string(name) {\n var obj = {};\n obj[name] = {};\n return Unit.createUnit(obj, {});\n }\n });\n});\nexports.createCreateUnit = createCreateUnit;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSplitUnit = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar name = 'splitUnit';\nvar dependencies = ['typed'];\nvar createSplitUnit = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed;\n\n /**\n * Split a unit in an array of units whose sum is equal to the original unit.\n *\n * Syntax:\n *\n * splitUnit(unit: Unit, parts: Array.)\n *\n * Example:\n *\n * math.splitUnit(new Unit(1, 'm'), ['feet', 'inch'])\n * // [ 3 feet, 3.3700787401575 inch ]\n *\n * See also:\n *\n * unit\n *\n * @param {Array} [parts] An array of strings or valueless units.\n * @return {Array} An array of units.\n */\n return typed(name, {\n 'Unit, Array': function UnitArray(unit, parts) {\n return unit.splitUnit(parts);\n }\n });\n});\nexports.createSplitUnit = createSplitUnit;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createUnitFunction = void 0;\n\nvar _factory = require(\"../../../utils/factory.js\");\n\nvar _collection = require(\"../../../utils/collection.js\");\n\nvar name = 'unit';\nvar dependencies = ['typed', 'Unit']; // This function is named createUnitFunction to prevent a naming conflict with createUnit\n\nvar createUnitFunction = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {\n var typed = _ref.typed,\n Unit = _ref.Unit;\n\n /**\n * Create a unit. Depending on the passed arguments, the function\n * will create and return a new math.Unit object.\n * When a matrix is provided, all elements will be converted to units.\n *\n * Syntax:\n *\n * math.unit(unit : string)\n * math.unit(value : number, unit : string)\n *\n * Examples:\n *\n * const a = math.unit(5, 'cm') // returns Unit 50 mm\n * const b = math.unit('23 kg') // returns Unit 23 kg\n * a.to('m') // returns Unit 0.05 m\n *\n * See also:\n *\n * bignumber, boolean, complex, index, matrix, number, string, createUnit\n *\n * @param {* | Array | Matrix} args A number and unit.\n * @return {Unit | Array | Matrix} The created unit\n */\n return typed(name, {\n Unit: function Unit(x) {\n return x.clone();\n },\n string: function string(x) {\n if (Unit.isValuelessUnit(x)) {\n return new Unit(null, x); // a pure unit\n }\n\n return Unit.parse(x, {\n allowNoUnits: true\n }); // a unit with value, like '5cm'\n },\n 'number | BigNumber | Fraction | Complex, string': function numberBigNumberFractionComplexString(value, unit) {\n return new Unit(value, unit);\n },\n 'Array | Matrix': function ArrayMatrix(x) {\n return (0, _collection.deepMap)(x, this);\n }\n });\n});\nexports.createUnitFunction = createUnitFunction;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createWienDisplacement = exports.createWeakMixingAngle = exports.createVacuumImpedance = exports.createThomsonCrossSection = exports.createStefanBoltzmann = exports.createSpeedOfLight = exports.createSecondRadiation = exports.createSackurTetrode = exports.createRydberg = exports.createReducedPlanckConstant = exports.createQuantumOfCirculation = exports.createProtonMass = exports.createPlanckTime = exports.createPlanckTemperature = exports.createPlanckMass = exports.createPlanckLength = exports.createPlanckConstant = exports.createPlanckCharge = exports.createNuclearMagneton = exports.createNeutronMass = exports.createMolarVolume = exports.createMolarPlanckConstant = exports.createMolarMassC12 = exports.createMolarMass = exports.createMagneticFluxQuantum = exports.createMagneticConstant = exports.createLoschmidt = exports.createKlitzing = exports.createJosephson = exports.createInverseConductanceQuantum = exports.createHartreeEnergy = exports.createGravity = exports.createGravitationConstant = exports.createGasConstant = exports.createFirstRadiation = exports.createFineStructure = exports.createFermiCoupling = exports.createFaraday = exports.createElementaryCharge = exports.createElectronMass = exports.createElectricConstant = exports.createEfimovFactor = exports.createDeuteronMass = exports.createCoulomb = exports.createConductanceQuantum = exports.createClassicalElectronRadius = exports.createBoltzmann = exports.createBohrRadius = exports.createBohrMagneton = exports.createAvogadro = exports.createAtomicMass = void 0;\n\nvar _factory = require(\"../../utils/factory.js\");\n\n// Source: https://en.wikipedia.org/wiki/Physical_constant\n// Universal constants\nvar createSpeedOfLight = /* #__PURE__ */unitFactory('speedOfLight', '299792458', 'm s^-1');\nexports.createSpeedOfLight = createSpeedOfLight;\nvar createGravitationConstant = /* #__PURE__ */unitFactory('gravitationConstant', '6.67430e-11', 'm^3 kg^-1 s^-2');\nexports.createGravitationConstant = createGravitationConstant;\nvar createPlanckConstant = /* #__PURE__ */unitFactory('planckConstant', '6.62607015e-34', 'J s');\nexports.createPlanckConstant = createPlanckConstant;\nvar createReducedPlanckConstant = /* #__PURE__ */unitFactory('reducedPlanckConstant', '1.0545718176461565e-34', 'J s'); // Electromagnetic constants\n\nexports.createReducedPlanckConstant = createReducedPlanckConstant;\nvar createMagneticConstant = /* #__PURE__ */unitFactory('magneticConstant', '1.25663706212e-6', 'N A^-2');\nexports.createMagneticConstant = createMagneticConstant;\nvar createElectricConstant = /* #__PURE__ */unitFactory('electricConstant', '8.8541878128e-12', 'F m^-1');\nexports.createElectricConstant = createElectricConstant;\nvar createVacuumImpedance = /* #__PURE__ */unitFactory('vacuumImpedance', '376.730313667', 'ohm');\nexports.createVacuumImpedance = createVacuumImpedance;\nvar createCoulomb = /* #__PURE__ */unitFactory('coulomb', '8.987551792261171e9', 'N m^2 C^-2');\nexports.createCoulomb = createCoulomb;\nvar createElementaryCharge = /* #__PURE__ */unitFactory('elementaryCharge', '1.602176634e-19', 'C');\nexports.createElementaryCharge = createElementaryCharge;\nvar createBohrMagneton = /* #__PURE__ */unitFactory('bohrMagneton', '9.2740100783e-24', 'J T^-1');\nexports.createBohrMagneton = createBohrMagneton;\nvar createConductanceQuantum = /* #__PURE__ */unitFactory('conductanceQuantum', '7.748091729863649e-5', 'S');\nexports.createConductanceQuantum = createConductanceQuantum;\nvar createInverseConductanceQuantum = /* #__PURE__ */unitFactory('inverseConductanceQuantum', '12906.403729652257', 'ohm');\nexports.createInverseConductanceQuantum = createInverseConductanceQuantum;\nvar createMagneticFluxQuantum = /* #__PURE__ */unitFactory('magneticFluxQuantum', '2.0678338484619295e-15', 'Wb');\nexports.createMagneticFluxQuantum = createMagneticFluxQuantum;\nvar createNuclearMagneton = /* #__PURE__ */unitFactory('nuclearMagneton', '5.0507837461e-27', 'J T^-1');\nexports.createNuclearMagneton = createNuclearMagneton;\nvar createKlitzing = /* #__PURE__ */unitFactory('klitzing', '25812.807459304513', 'ohm');\nexports.createKlitzing = createKlitzing;\nvar createJosephson = /* #__PURE__ */unitFactory('josephson', '4.835978484169836e14 Hz V', 'Hz V^-1'); // TODO: support for Hz needed\n// Atomic and nuclear constants\n\nexports.createJosephson = createJosephson;\nvar createBohrRadius = /* #__PURE__ */unitFactory('bohrRadius', '5.29177210903e-11', 'm');\nexports.createBohrRadius = createBohrRadius;\nvar createClassicalElectronRadius = /* #__PURE__ */unitFactory('classicalElectronRadius', '2.8179403262e-15', 'm');\nexports.createClassicalElectronRadius = createClassicalElectronRadius;\nvar createElectronMass = /* #__PURE__ */unitFactory('electronMass', '9.1093837015e-31', 'kg');\nexports.createElectronMass = createElectronMass;\nvar createFermiCoupling = /* #__PURE__ */unitFactory('fermiCoupling', '1.1663787e-5', 'GeV^-2');\nexports.createFermiCoupling = createFermiCoupling;\nvar createFineStructure = numberFactory('fineStructure', 7.2973525693e-3);\nexports.createFineStructure = createFineStructure;\nvar createHartreeEnergy = /* #__PURE__ */unitFactory('hartreeEnergy', '4.3597447222071e-18', 'J');\nexports.createHartreeEnergy = createHartreeEnergy;\nvar createProtonMass = /* #__PURE__ */unitFactory('protonMass', '1.67262192369e-27', 'kg');\nexports.createProtonMass = createProtonMass;\nvar createDeuteronMass = /* #__PURE__ */unitFactory('deuteronMass', '3.3435830926e-27', 'kg');\nexports.createDeuteronMass = createDeuteronMass;\nvar createNeutronMass = /* #__PURE__ */unitFactory('neutronMass', '1.6749271613e-27', 'kg');\nexports.createNeutronMass = createNeutronMass;\nvar createQuantumOfCirculation = /* #__PURE__ */unitFactory('quantumOfCirculation', '3.6369475516e-4', 'm^2 s^-1');\nexports.createQuantumOfCirculation = createQuantumOfCirculation;\nvar createRydberg = /* #__PURE__ */unitFactory('rydberg', '10973731.568160', 'm^-1');\nexports.createRydberg = createRydberg;\nvar createThomsonCrossSection = /* #__PURE__ */unitFactory('thomsonCrossSection', '6.6524587321e-29', 'm^2');\nexports.createThomsonCrossSection = createThomsonCrossSection;\nvar createWeakMixingAngle = numberFactory('weakMixingAngle', 0.22290);\nexports.createWeakMixingAngle = createWeakMixingAngle;\nvar createEfimovFactor = numberFactory('efimovFactor', 22.7); // Physico-chemical constants\n\nexports.createEfimovFactor = createEfimovFactor;\nvar createAtomicMass = /* #__PURE__ */unitFactory('atomicMass', '1.66053906660e-27', 'kg');\nexports.createAtomicMass = createAtomicMass;\nvar createAvogadro = /* #__PURE__ */unitFactory('avogadro', '6.02214076e23', 'mol^-1');\nexports.createAvogadro = createAvogadro;\nvar createBoltzmann = /* #__PURE__ */unitFactory('boltzmann', '1.380649e-23', 'J K^-1');\nexports.createBoltzmann = createBoltzmann;\nvar createFaraday = /* #__PURE__ */unitFactory('faraday', '96485.33212331001', 'C mol^-1');\nexports.createFaraday = createFaraday;\nvar createFirstRadiation = /* #__PURE__ */unitFactory('firstRadiation', '3.7417718521927573e-16', 'W m^2'); // export const createSpectralRadiance = /* #__PURE__ */ unitFactory('spectralRadiance', '1.1910429723971881e-16', 'W m^2 sr^-1') // TODO spectralRadiance\n\nexports.createFirstRadiation = createFirstRadiation;\nvar createLoschmidt = /* #__PURE__ */unitFactory('loschmidt', '2.686780111798444e25', 'm^-3');\nexports.createLoschmidt = createLoschmidt;\nvar createGasConstant = /* #__PURE__ */unitFactory('gasConstant', '8.31446261815324', 'J K^-1 mol^-1');\nexports.createGasConstant = createGasConstant;\nvar createMolarPlanckConstant = /* #__PURE__ */unitFactory('molarPlanckConstant', '3.990312712893431e-10', 'J s mol^-1');\nexports.createMolarPlanckConstant = createMolarPlanckConstant;\nvar createMolarVolume = /* #__PURE__ */unitFactory('molarVolume', '0.022413969545014137', 'm^3 mol^-1');\nexports.createMolarVolume = createMolarVolume;\nvar createSackurTetrode = numberFactory('sackurTetrode', -1.16487052358);\nexports.createSackurTetrode = createSackurTetrode;\nvar createSecondRadiation = /* #__PURE__ */unitFactory('secondRadiation', '0.014387768775039337', 'm K');\nexports.createSecondRadiation = createSecondRadiation;\nvar createStefanBoltzmann = /* #__PURE__ */unitFactory('stefanBoltzmann', '5.67037441918443e-8', 'W m^-2 K^-4');\nexports.createStefanBoltzmann = createStefanBoltzmann;\nvar createWienDisplacement = /* #__PURE__ */unitFactory('wienDisplacement', '2.897771955e-3', 'm K'); // Adopted values\n\nexports.createWienDisplacement = createWienDisplacement;\nvar createMolarMass = /* #__PURE__ */unitFactory('molarMass', '0.99999999965e-3', 'kg mol^-1');\nexports.createMolarMass = createMolarMass;\nvar createMolarMassC12 = /* #__PURE__ */unitFactory('molarMassC12', '11.9999999958e-3', 'kg mol^-1');\nexports.createMolarMassC12 = createMolarMassC12;\nvar createGravity = /* #__PURE__ */unitFactory('gravity', '9.80665', 'm s^-2'); // atm is defined in Unit.js\n// Natural units\n\nexports.createGravity = createGravity;\nvar createPlanckLength = /* #__PURE__ */unitFactory('planckLength', '1.616255e-35', 'm');\nexports.createPlanckLength = createPlanckLength;\nvar createPlanckMass = /* #__PURE__ */unitFactory('planckMass', '2.176435e-8', 'kg');\nexports.createPlanckMass = createPlanckMass;\nvar createPlanckTime = /* #__PURE__ */unitFactory('planckTime', '5.391245e-44', 's');\nexports.createPlanckTime = createPlanckTime;\nvar createPlanckCharge = /* #__PURE__ */unitFactory('planckCharge', '1.87554603778e-18', 'C');\nexports.createPlanckCharge = createPlanckCharge;\nvar createPlanckTemperature = /* #__PURE__ */unitFactory('planckTemperature', '1.416785e+32', 'K'); // helper function to create a factory function which creates a physical constant,\n// a Unit with either a number value or a BigNumber value depending on the configuration\n\nexports.createPlanckTemperature = createPlanckTemperature;\n\nfunction unitFactory(name, valueStr, unitStr) {\n var dependencies = ['config', 'Unit', 'BigNumber'];\n return (0, _factory.factory)(name, dependencies, function (_ref) {\n var config = _ref.config,\n Unit = _ref.Unit,\n BigNumber = _ref.BigNumber;\n // Note that we can parse into number or BigNumber.\n // We do not parse into Fractions as that doesn't make sense: we would lose precision of the values\n // Therefore we dont use Unit.parse()\n var value = config.number === 'BigNumber' ? new BigNumber(valueStr) : parseFloat(valueStr);\n var unit = new Unit(value, unitStr);\n unit.fixPrefix = true;\n return unit;\n });\n} // helper function to create a factory function which creates a numeric constant,\n// either a number or BigNumber depending on the configuration\n\n\nfunction numberFactory(name, value) {\n var dependencies = ['config', 'BigNumber'];\n return (0, _factory.factory)(name, dependencies, function (_ref2) {\n var config = _ref2.config,\n BigNumber = _ref2.BigNumber;\n return config.number === 'BigNumber' ? new BigNumber(value) : value;\n });\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.arraySize = arraySize;\nexports.contains = contains;\nexports.filter = filter;\nexports.filterRegExp = filterRegExp;\nexports.flatten = flatten;\nexports.forEach = forEach;\nexports.generalize = generalize;\nexports.getArrayDataType = getArrayDataType;\nexports.identify = identify;\nexports.initial = initial;\nexports.join = join;\nexports.last = last;\nexports.map = map;\nexports.processSizesWildcard = processSizesWildcard;\nexports.reshape = reshape;\nexports.resize = resize;\nexports.squeeze = squeeze;\nexports.unsqueeze = unsqueeze;\nexports.validate = validate;\nexports.validateIndex = validateIndex;\n\nvar _number = require(\"./number.js\");\n\nvar _is = require(\"./is.js\");\n\nvar _string = require(\"./string.js\");\n\nvar _DimensionError = require(\"../error/DimensionError.js\");\n\nvar _IndexError = require(\"../error/IndexError.js\");\n\n/**\n * Calculate the size of a multi dimensional array.\n * This function checks the size of the first entry, it does not validate\n * whether all dimensions match. (use function `validate` for that)\n * @param {Array} x\n * @Return {Number[]} size\n */\nfunction arraySize(x) {\n var s = [];\n\n while (Array.isArray(x)) {\n s.push(x.length);\n x = x[0];\n }\n\n return s;\n}\n/**\n * Recursively validate whether each element in a multi dimensional array\n * has a size corresponding to the provided size array.\n * @param {Array} array Array to be validated\n * @param {number[]} size Array with the size of each dimension\n * @param {number} dim Current dimension\n * @throws DimensionError\n * @private\n */\n\n\nfunction _validate(array, size, dim) {\n var i;\n var len = array.length;\n\n if (len !== size[dim]) {\n throw new _DimensionError.DimensionError(len, size[dim]);\n }\n\n if (dim < size.length - 1) {\n // recursively validate each child array\n var dimNext = dim + 1;\n\n for (i = 0; i < len; i++) {\n var child = array[i];\n\n if (!Array.isArray(child)) {\n throw new _DimensionError.DimensionError(size.length - 1, size.length, '<');\n }\n\n _validate(array[i], size, dimNext);\n }\n } else {\n // last dimension. none of the childs may be an array\n for (i = 0; i < len; i++) {\n if (Array.isArray(array[i])) {\n throw new _DimensionError.DimensionError(size.length + 1, size.length, '>');\n }\n }\n }\n}\n/**\n * Validate whether each element in a multi dimensional array has\n * a size corresponding to the provided size array.\n * @param {Array} array Array to be validated\n * @param {number[]} size Array with the size of each dimension\n * @throws DimensionError\n */\n\n\nfunction validate(array, size) {\n var isScalar = size.length === 0;\n\n if (isScalar) {\n // scalar\n if (Array.isArray(array)) {\n throw new _DimensionError.DimensionError(array.length, 0);\n }\n } else {\n // array\n _validate(array, size, 0);\n }\n}\n/**\n * Test whether index is an integer number with index >= 0 and index < length\n * when length is provided\n * @param {number} index Zero-based index\n * @param {number} [length] Length of the array\n */\n\n\nfunction validateIndex(index, length) {\n if (!(0, _is.isNumber)(index) || !(0, _number.isInteger)(index)) {\n throw new TypeError('Index must be an integer (value: ' + index + ')');\n }\n\n if (index < 0 || typeof length === 'number' && index >= length) {\n throw new _IndexError.IndexError(index, length);\n }\n}\n/**\n * Resize a multi dimensional array. The resized array is returned.\n * @param {Array} array Array to be resized\n * @param {Array.} size Array with the size of each dimension\n * @param {*} [defaultValue=0] Value to be filled in in new entries,\n * zero by default. Specify for example `null`,\n * to clearly see entries that are not explicitly\n * set.\n * @return {Array} array The resized array\n */\n\n\nfunction resize(array, size, defaultValue) {\n // TODO: add support for scalars, having size=[] ?\n // check the type of the arguments\n if (!Array.isArray(array) || !Array.isArray(size)) {\n throw new TypeError('Array expected');\n }\n\n if (size.length === 0) {\n throw new Error('Resizing to scalar is not supported');\n } // check whether size contains positive integers\n\n\n size.forEach(function (value) {\n if (!(0, _is.isNumber)(value) || !(0, _number.isInteger)(value) || value < 0) {\n throw new TypeError('Invalid size, must contain positive integers ' + '(size: ' + (0, _string.format)(size) + ')');\n }\n }); // recursively resize the array\n\n var _defaultValue = defaultValue !== undefined ? defaultValue : 0;\n\n _resize(array, size, 0, _defaultValue);\n\n return array;\n}\n/**\n * Recursively resize a multi dimensional array\n * @param {Array} array Array to be resized\n * @param {number[]} size Array with the size of each dimension\n * @param {number} dim Current dimension\n * @param {*} [defaultValue] Value to be filled in in new entries,\n * undefined by default.\n * @private\n */\n\n\nfunction _resize(array, size, dim, defaultValue) {\n var i;\n var elem;\n var oldLen = array.length;\n var newLen = size[dim];\n var minLen = Math.min(oldLen, newLen); // apply new length\n\n array.length = newLen;\n\n if (dim < size.length - 1) {\n // non-last dimension\n var dimNext = dim + 1; // resize existing child arrays\n\n for (i = 0; i < minLen; i++) {\n // resize child array\n elem = array[i];\n\n if (!Array.isArray(elem)) {\n elem = [elem]; // add a dimension\n\n array[i] = elem;\n }\n\n _resize(elem, size, dimNext, defaultValue);\n } // create new child arrays\n\n\n for (i = minLen; i < newLen; i++) {\n // get child array\n elem = [];\n array[i] = elem; // resize new child array\n\n _resize(elem, size, dimNext, defaultValue);\n }\n } else {\n // last dimension\n // remove dimensions of existing values\n for (i = 0; i < minLen; i++) {\n while (Array.isArray(array[i])) {\n array[i] = array[i][0];\n }\n } // fill new elements with the default value\n\n\n for (i = minLen; i < newLen; i++) {\n array[i] = defaultValue;\n }\n }\n}\n/**\n * Re-shape a multi dimensional array to fit the specified dimensions\n * @param {Array} array Array to be reshaped\n * @param {Array.} sizes List of sizes for each dimension\n * @returns {Array} Array whose data has been formatted to fit the\n * specified dimensions\n *\n * @throws {DimensionError} If the product of the new dimension sizes does\n * not equal that of the old ones\n */\n\n\nfunction reshape(array, sizes) {\n var flatArray = flatten(array);\n var currentLength = flatArray.length;\n\n if (!Array.isArray(array) || !Array.isArray(sizes)) {\n throw new TypeError('Array expected');\n }\n\n if (sizes.length === 0) {\n throw new _DimensionError.DimensionError(0, currentLength, '!=');\n }\n\n sizes = processSizesWildcard(sizes, currentLength);\n var newLength = product(sizes);\n\n if (currentLength !== newLength) {\n throw new _DimensionError.DimensionError(newLength, currentLength, '!=');\n }\n\n try {\n return _reshape(flatArray, sizes);\n } catch (e) {\n if (e instanceof _DimensionError.DimensionError) {\n throw new _DimensionError.DimensionError(newLength, currentLength, '!=');\n }\n\n throw e;\n }\n}\n/**\n * Replaces the wildcard -1 in the sizes array.\n * @param {Array.} sizes List of sizes for each dimension. At most on wildcard.\n * @param {number} currentLength Number of elements in the array.\n * @throws {Error} If more than one wildcard or unable to replace it.\n * @returns {Array.} The sizes array with wildcard replaced.\n */\n\n\nfunction processSizesWildcard(sizes, currentLength) {\n var newLength = product(sizes);\n var processedSizes = sizes.slice();\n var WILDCARD = -1;\n var wildCardIndex = sizes.indexOf(WILDCARD);\n var isMoreThanOneWildcard = sizes.indexOf(WILDCARD, wildCardIndex + 1) >= 0;\n\n if (isMoreThanOneWildcard) {\n throw new Error('More than one wildcard in sizes');\n }\n\n var hasWildcard = wildCardIndex >= 0;\n var canReplaceWildcard = currentLength % newLength === 0;\n\n if (hasWildcard) {\n if (canReplaceWildcard) {\n processedSizes[wildCardIndex] = -currentLength / newLength;\n } else {\n throw new Error('Could not replace wildcard, since ' + currentLength + ' is no multiple of ' + -newLength);\n }\n }\n\n return processedSizes;\n}\n/**\n * Computes the product of all array elements.\n * @param {Array} array Array of factors\n * @returns {number} Product of all elements\n */\n\n\nfunction product(array) {\n return array.reduce(function (prev, curr) {\n return prev * curr;\n }, 1);\n}\n/**\n * Iteratively re-shape a multi dimensional array to fit the specified dimensions\n * @param {Array} array Array to be reshaped\n * @param {Array.} sizes List of sizes for each dimension\n * @returns {Array} Array whose data has been formatted to fit the\n * specified dimensions\n */\n\n\nfunction _reshape(array, sizes) {\n // testing if there are enough elements for the requested shape\n var tmpArray = array;\n var tmpArray2; // for each dimensions starting by the last one and ignoring the first one\n\n for (var sizeIndex = sizes.length - 1; sizeIndex > 0; sizeIndex--) {\n var size = sizes[sizeIndex];\n tmpArray2 = []; // aggregate the elements of the current tmpArray in elements of the requested size\n\n var length = tmpArray.length / size;\n\n for (var i = 0; i < length; i++) {\n tmpArray2.push(tmpArray.slice(i * size, (i + 1) * size));\n } // set it as the new tmpArray for the next loop turn or for return\n\n\n tmpArray = tmpArray2;\n }\n\n return tmpArray;\n}\n/**\n * Squeeze a multi dimensional array\n * @param {Array} array\n * @param {Array} [size]\n * @returns {Array} returns the array itself\n */\n\n\nfunction squeeze(array, size) {\n var s = size || arraySize(array); // squeeze outer dimensions\n\n while (Array.isArray(array) && array.length === 1) {\n array = array[0];\n s.shift();\n } // find the first dimension to be squeezed\n\n\n var dims = s.length;\n\n while (s[dims - 1] === 1) {\n dims--;\n } // squeeze inner dimensions\n\n\n if (dims < s.length) {\n array = _squeeze(array, dims, 0);\n s.length = dims;\n }\n\n return array;\n}\n/**\n * Recursively squeeze a multi dimensional array\n * @param {Array} array\n * @param {number} dims Required number of dimensions\n * @param {number} dim Current dimension\n * @returns {Array | *} Returns the squeezed array\n * @private\n */\n\n\nfunction _squeeze(array, dims, dim) {\n var i, ii;\n\n if (dim < dims) {\n var next = dim + 1;\n\n for (i = 0, ii = array.length; i < ii; i++) {\n array[i] = _squeeze(array[i], dims, next);\n }\n } else {\n while (Array.isArray(array)) {\n array = array[0];\n }\n }\n\n return array;\n}\n/**\n * Unsqueeze a multi dimensional array: add dimensions when missing\n *\n * Paramter `size` will be mutated to match the new, unqueezed matrix size.\n *\n * @param {Array} array\n * @param {number} dims Desired number of dimensions of the array\n * @param {number} [outer] Number of outer dimensions to be added\n * @param {Array} [size] Current size of array.\n * @returns {Array} returns the array itself\n * @private\n */\n\n\nfunction unsqueeze(array, dims, outer, size) {\n var s = size || arraySize(array); // unsqueeze outer dimensions\n\n if (outer) {\n for (var i = 0; i < outer; i++) {\n array = [array];\n s.unshift(1);\n }\n } // unsqueeze inner dimensions\n\n\n array = _unsqueeze(array, dims, 0);\n\n while (s.length < dims) {\n s.push(1);\n }\n\n return array;\n}\n/**\n * Recursively unsqueeze a multi dimensional array\n * @param {Array} array\n * @param {number} dims Required number of dimensions\n * @param {number} dim Current dimension\n * @returns {Array | *} Returns the squeezed array\n * @private\n */\n\n\nfunction _unsqueeze(array, dims, dim) {\n var i, ii;\n\n if (Array.isArray(array)) {\n var next = dim + 1;\n\n for (i = 0, ii = array.length; i < ii; i++) {\n array[i] = _unsqueeze(array[i], dims, next);\n }\n } else {\n for (var d = dim; d < dims; d++) {\n array = [array];\n }\n }\n\n return array;\n}\n/**\n * Flatten a multi dimensional array, put all elements in a one dimensional\n * array\n * @param {Array} array A multi dimensional array\n * @return {Array} The flattened array (1 dimensional)\n */\n\n\nfunction flatten(array) {\n if (!Array.isArray(array)) {\n // if not an array, return as is\n return array;\n }\n\n var flat = [];\n array.forEach(function callback(value) {\n if (Array.isArray(value)) {\n value.forEach(callback); // traverse through sub-arrays recursively\n } else {\n flat.push(value);\n }\n });\n return flat;\n}\n/**\n * A safe map\n * @param {Array} array\n * @param {function} callback\n */\n\n\nfunction map(array, callback) {\n return Array.prototype.map.call(array, callback);\n}\n/**\n * A safe forEach\n * @param {Array} array\n * @param {function} callback\n */\n\n\nfunction forEach(array, callback) {\n Array.prototype.forEach.call(array, callback);\n}\n/**\n * A safe filter\n * @param {Array} array\n * @param {function} callback\n */\n\n\nfunction filter(array, callback) {\n if (arraySize(array).length !== 1) {\n throw new Error('Only one dimensional matrices supported');\n }\n\n return Array.prototype.filter.call(array, callback);\n}\n/**\n * Filter values in a callback given a regular expression\n * @param {Array} array\n * @param {RegExp} regexp\n * @return {Array} Returns the filtered array\n * @private\n */\n\n\nfunction filterRegExp(array, regexp) {\n if (arraySize(array).length !== 1) {\n throw new Error('Only one dimensional matrices supported');\n }\n\n return Array.prototype.filter.call(array, function (entry) {\n return regexp.test(entry);\n });\n}\n/**\n * A safe join\n * @param {Array} array\n * @param {string} separator\n */\n\n\nfunction join(array, separator) {\n return Array.prototype.join.call(array, separator);\n}\n/**\n * Assign a numeric identifier to every element of a sorted array\n * @param {Array} a An array\n * @return {Array} An array of objects containing the original value and its identifier\n */\n\n\nfunction identify(a) {\n if (!Array.isArray(a)) {\n throw new TypeError('Array input expected');\n }\n\n if (a.length === 0) {\n return a;\n }\n\n var b = [];\n var count = 0;\n b[0] = {\n value: a[0],\n identifier: 0\n };\n\n for (var i = 1; i < a.length; i++) {\n if (a[i] === a[i - 1]) {\n count++;\n } else {\n count = 0;\n }\n\n b.push({\n value: a[i],\n identifier: count\n });\n }\n\n return b;\n}\n/**\n * Remove the numeric identifier from the elements\n * @param {array} a An array\n * @return {array} An array of values without identifiers\n */\n\n\nfunction generalize(a) {\n if (!Array.isArray(a)) {\n throw new TypeError('Array input expected');\n }\n\n if (a.length === 0) {\n return a;\n }\n\n var b = [];\n\n for (var i = 0; i < a.length; i++) {\n b.push(a[i].value);\n }\n\n return b;\n}\n/**\n * Check the datatype of a given object\n * This is a low level implementation that should only be used by\n * parent Matrix classes such as SparseMatrix or DenseMatrix\n * This method does not validate Array Matrix shape\n * @param {Array} array\n * @param {function} typeOf Callback function to use to determine the type of a value\n * @return {string}\n */\n\n\nfunction getArrayDataType(array, typeOf) {\n var type; // to hold type info\n\n var length = 0; // to hold length value to ensure it has consistent sizes\n\n for (var i = 0; i < array.length; i++) {\n var item = array[i];\n var isArray = Array.isArray(item); // Saving the target matrix row size\n\n if (i === 0 && isArray) {\n length = item.length;\n } // If the current item is an array but the length does not equal the targetVectorSize\n\n\n if (isArray && item.length !== length) {\n return undefined;\n }\n\n var itemType = isArray ? getArrayDataType(item, typeOf) // recurse into a nested array\n : typeOf(item);\n\n if (type === undefined) {\n type = itemType; // first item\n } else if (type !== itemType) {\n return 'mixed';\n } else {// we're good, everything has the same type so far\n }\n }\n\n return type;\n}\n/**\n * Return the last item from an array\n * @param array\n * @returns {*}\n */\n\n\nfunction last(array) {\n return array[array.length - 1];\n}\n/**\n * Get all but the last element of array.\n */\n\n\nfunction initial(array) {\n return array.slice(0, array.length - 1);\n}\n/**\n * Test whether an array or string contains an item\n * @param {Array | string} array\n * @param {*} item\n * @return {boolean}\n */\n\n\nfunction contains(array, item) {\n return array.indexOf(item) !== -1;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bitAndBigNumber = bitAndBigNumber;\nexports.bitNotBigNumber = bitNotBigNumber;\nexports.bitOrBigNumber = bitOrBigNumber;\nexports.bitXor = bitXor;\nexports.bitwise = bitwise;\nexports.leftShiftBigNumber = leftShiftBigNumber;\nexports.rightArithShiftBigNumber = rightArithShiftBigNumber;\n\n/**\n * Bitwise and for Bignumbers\n *\n * Special Cases:\n * N & n = N\n * n & 0 = 0\n * n & -1 = n\n * n & n = n\n * I & I = I\n * -I & -I = -I\n * I & -I = 0\n * I & n = n\n * I & -n = I\n * -I & n = 0\n * -I & -n = -I\n *\n * @param {BigNumber} x\n * @param {BigNumber} y\n * @return {BigNumber} Result of `x` & `y`, is fully precise\n * @private\n */\nfunction bitAndBigNumber(x, y) {\n if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) {\n throw new Error('Integers expected in function bitAnd');\n }\n\n var BigNumber = x.constructor;\n\n if (x.isNaN() || y.isNaN()) {\n return new BigNumber(NaN);\n }\n\n if (x.isZero() || y.eq(-1) || x.eq(y)) {\n return x;\n }\n\n if (y.isZero() || x.eq(-1)) {\n return y;\n }\n\n if (!x.isFinite() || !y.isFinite()) {\n if (!x.isFinite() && !y.isFinite()) {\n if (x.isNegative() === y.isNegative()) {\n return x;\n }\n\n return new BigNumber(0);\n }\n\n if (!x.isFinite()) {\n if (y.isNegative()) {\n return x;\n }\n\n if (x.isNegative()) {\n return new BigNumber(0);\n }\n\n return y;\n }\n\n if (!y.isFinite()) {\n if (x.isNegative()) {\n return y;\n }\n\n if (y.isNegative()) {\n return new BigNumber(0);\n }\n\n return x;\n }\n }\n\n return bitwise(x, y, function (a, b) {\n return a & b;\n });\n}\n/**\n * Bitwise not\n * @param {BigNumber} x\n * @return {BigNumber} Result of ~`x`, fully precise\n *\n */\n\n\nfunction bitNotBigNumber(x) {\n if (x.isFinite() && !x.isInteger()) {\n throw new Error('Integer expected in function bitNot');\n }\n\n var BigNumber = x.constructor;\n var prevPrec = BigNumber.precision;\n BigNumber.config({\n precision: 1E9\n });\n var result = x.plus(new BigNumber(1));\n result.s = -result.s || null;\n BigNumber.config({\n precision: prevPrec\n });\n return result;\n}\n/**\n * Bitwise OR for BigNumbers\n *\n * Special Cases:\n * N | n = N\n * n | 0 = n\n * n | -1 = -1\n * n | n = n\n * I | I = I\n * -I | -I = -I\n * I | -n = -1\n * I | -I = -1\n * I | n = I\n * -I | n = -I\n * -I | -n = -n\n *\n * @param {BigNumber} x\n * @param {BigNumber} y\n * @return {BigNumber} Result of `x` | `y`, fully precise\n */\n\n\nfunction bitOrBigNumber(x, y) {\n if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) {\n throw new Error('Integers expected in function bitOr');\n }\n\n var BigNumber = x.constructor;\n\n if (x.isNaN() || y.isNaN()) {\n return new BigNumber(NaN);\n }\n\n var negOne = new BigNumber(-1);\n\n if (x.isZero() || y.eq(negOne) || x.eq(y)) {\n return y;\n }\n\n if (y.isZero() || x.eq(negOne)) {\n return x;\n }\n\n if (!x.isFinite() || !y.isFinite()) {\n if (!x.isFinite() && !x.isNegative() && y.isNegative() || x.isNegative() && !y.isNegative() && !y.isFinite()) {\n return negOne;\n }\n\n if (x.isNegative() && y.isNegative()) {\n return x.isFinite() ? x : y;\n }\n\n return x.isFinite() ? y : x;\n }\n\n return bitwise(x, y, function (a, b) {\n return a | b;\n });\n}\n/**\n * Applies bitwise function to numbers\n * @param {BigNumber} x\n * @param {BigNumber} y\n * @param {function (a, b)} func\n * @return {BigNumber}\n */\n\n\nfunction bitwise(x, y, func) {\n var BigNumber = x.constructor;\n var xBits, yBits;\n var xSign = +(x.s < 0);\n var ySign = +(y.s < 0);\n\n if (xSign) {\n xBits = decCoefficientToBinaryString(bitNotBigNumber(x));\n\n for (var i = 0; i < xBits.length; ++i) {\n xBits[i] ^= 1;\n }\n } else {\n xBits = decCoefficientToBinaryString(x);\n }\n\n if (ySign) {\n yBits = decCoefficientToBinaryString(bitNotBigNumber(y));\n\n for (var _i = 0; _i < yBits.length; ++_i) {\n yBits[_i] ^= 1;\n }\n } else {\n yBits = decCoefficientToBinaryString(y);\n }\n\n var minBits, maxBits, minSign;\n\n if (xBits.length <= yBits.length) {\n minBits = xBits;\n maxBits = yBits;\n minSign = xSign;\n } else {\n minBits = yBits;\n maxBits = xBits;\n minSign = ySign;\n }\n\n var shortLen = minBits.length;\n var longLen = maxBits.length;\n var expFuncVal = func(xSign, ySign) ^ 1;\n var outVal = new BigNumber(expFuncVal ^ 1);\n var twoPower = new BigNumber(1);\n var two = new BigNumber(2);\n var prevPrec = BigNumber.precision;\n BigNumber.config({\n precision: 1E9\n });\n\n while (shortLen > 0) {\n if (func(minBits[--shortLen], maxBits[--longLen]) === expFuncVal) {\n outVal = outVal.plus(twoPower);\n }\n\n twoPower = twoPower.times(two);\n }\n\n while (longLen > 0) {\n if (func(minSign, maxBits[--longLen]) === expFuncVal) {\n outVal = outVal.plus(twoPower);\n }\n\n twoPower = twoPower.times(two);\n }\n\n BigNumber.config({\n precision: prevPrec\n });\n\n if (expFuncVal === 0) {\n outVal.s = -outVal.s;\n }\n\n return outVal;\n}\n/* Extracted from decimal.js, and edited to specialize. */\n\n\nfunction decCoefficientToBinaryString(x) {\n // Convert to string\n var a = x.d; // array with digits\n\n var r = a[0] + '';\n\n for (var i = 1; i < a.length; ++i) {\n var s = a[i] + '';\n\n for (var z = 7 - s.length; z--;) {\n s = '0' + s;\n }\n\n r += s;\n }\n\n var j = r.length;\n\n while (r.charAt(j) === '0') {\n j--;\n }\n\n var xe = x.e;\n var str = r.slice(0, j + 1 || 1);\n var strL = str.length;\n\n if (xe > 0) {\n if (++xe > strL) {\n // Append zeros.\n xe -= strL;\n\n while (xe--) {\n str += '0';\n }\n } else if (xe < strL) {\n str = str.slice(0, xe) + '.' + str.slice(xe);\n }\n } // Convert from base 10 (decimal) to base 2\n\n\n var arr = [0];\n\n for (var _i2 = 0; _i2 < str.length;) {\n var arrL = arr.length;\n\n while (arrL--) {\n arr[arrL] *= 10;\n }\n\n arr[0] += parseInt(str.charAt(_i2++)); // convert to int\n\n for (var _j = 0; _j < arr.length; ++_j) {\n if (arr[_j] > 1) {\n if (arr[_j + 1] === null || arr[_j + 1] === undefined) {\n arr[_j + 1] = 0;\n }\n\n arr[_j + 1] += arr[_j] >> 1;\n arr[_j] &= 1;\n }\n }\n }\n\n return arr.reverse();\n}\n/**\n * Bitwise XOR for BigNumbers\n *\n * Special Cases:\n * N ^ n = N\n * n ^ 0 = n\n * n ^ n = 0\n * n ^ -1 = ~n\n * I ^ n = I\n * I ^ -n = -I\n * I ^ -I = -1\n * -I ^ n = -I\n * -I ^ -n = I\n *\n * @param {BigNumber} x\n * @param {BigNumber} y\n * @return {BigNumber} Result of `x` ^ `y`, fully precise\n *\n */\n\n\nfunction bitXor(x, y) {\n if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) {\n throw new Error('Integers expected in function bitXor');\n }\n\n var BigNumber = x.constructor;\n\n if (x.isNaN() || y.isNaN()) {\n return new BigNumber(NaN);\n }\n\n if (x.isZero()) {\n return y;\n }\n\n if (y.isZero()) {\n return x;\n }\n\n if (x.eq(y)) {\n return new BigNumber(0);\n }\n\n var negOne = new BigNumber(-1);\n\n if (x.eq(negOne)) {\n return bitNotBigNumber(y);\n }\n\n if (y.eq(negOne)) {\n return bitNotBigNumber(x);\n }\n\n if (!x.isFinite() || !y.isFinite()) {\n if (!x.isFinite() && !y.isFinite()) {\n return negOne;\n }\n\n return new BigNumber(x.isNegative() === y.isNegative() ? Infinity : -Infinity);\n }\n\n return bitwise(x, y, function (a, b) {\n return a ^ b;\n });\n}\n/**\n * Bitwise left shift\n *\n * Special Cases:\n * n << -n = N\n * n << N = N\n * N << n = N\n * n << 0 = n\n * 0 << n = 0\n * I << I = N\n * I << n = I\n * n << I = I\n *\n * @param {BigNumber} x\n * @param {BigNumber} y\n * @return {BigNumber} Result of `x` << `y`\n *\n */\n\n\nfunction leftShiftBigNumber(x, y) {\n if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) {\n throw new Error('Integers expected in function leftShift');\n }\n\n var BigNumber = x.constructor;\n\n if (x.isNaN() || y.isNaN() || y.isNegative() && !y.isZero()) {\n return new BigNumber(NaN);\n }\n\n if (x.isZero() || y.isZero()) {\n return x;\n }\n\n if (!x.isFinite() && !y.isFinite()) {\n return new BigNumber(NaN);\n } // Math.pow(2, y) is fully precise for y < 55, and fast\n\n\n if (y.lt(55)) {\n return x.times(Math.pow(2, y.toNumber()) + '');\n }\n\n return x.times(new BigNumber(2).pow(y));\n}\n/*\n * Special Cases:\n * n >> -n = N\n * n >> N = N\n * N >> n = N\n * I >> I = N\n * n >> 0 = n\n * I >> n = I\n * -I >> n = -I\n * -I >> I = -I\n * n >> I = I\n * -n >> I = -1\n * 0 >> n = 0\n *\n * @param {BigNumber} value\n * @param {BigNumber} value\n * @return {BigNumber} Result of `x` >> `y`\n *\n */\n\n\nfunction rightArithShiftBigNumber(x, y) {\n if (x.isFinite() && !x.isInteger() || y.isFinite() && !y.isInteger()) {\n throw new Error('Integers expected in function rightArithShift');\n }\n\n var BigNumber = x.constructor;\n\n if (x.isNaN() || y.isNaN() || y.isNegative() && !y.isZero()) {\n return new BigNumber(NaN);\n }\n\n if (x.isZero() || y.isZero()) {\n return x;\n }\n\n if (!y.isFinite()) {\n if (x.isNegative()) {\n return new BigNumber(-1);\n }\n\n if (!x.isFinite()) {\n return new BigNumber(NaN);\n }\n\n return new BigNumber(0);\n } // Math.pow(2, y) is fully precise for y < 55, and fast\n\n\n if (y.lt(55)) {\n return x.div(Math.pow(2, y.toNumber()) + '').floor();\n }\n\n return x.div(new BigNumber(2).pow(y)).floor();\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createBigNumberTau = exports.createBigNumberPi = exports.createBigNumberPhi = exports.createBigNumberE = void 0;\n\nvar _function = require(\"../function.js\");\n\n/**\n * Calculate BigNumber e\n * @param {function} BigNumber BigNumber constructor\n * @returns {BigNumber} Returns e\n */\nvar createBigNumberE = (0, _function.memoize)(function (BigNumber) {\n return new BigNumber(1).exp();\n}, {\n hasher: hasher\n});\n/**\n * Calculate BigNumber golden ratio, phi = (1+sqrt(5))/2\n * @param {function} BigNumber BigNumber constructor\n * @returns {BigNumber} Returns phi\n */\n\nexports.createBigNumberE = createBigNumberE;\nvar createBigNumberPhi = (0, _function.memoize)(function (BigNumber) {\n return new BigNumber(1).plus(new BigNumber(5).sqrt()).div(2);\n}, {\n hasher: hasher\n});\n/**\n * Calculate BigNumber pi.\n * @param {function} BigNumber BigNumber constructor\n * @returns {BigNumber} Returns pi\n */\n\nexports.createBigNumberPhi = createBigNumberPhi;\nvar createBigNumberPi = (0, _function.memoize)(function (BigNumber) {\n return BigNumber.acos(-1);\n}, {\n hasher: hasher\n});\n/**\n * Calculate BigNumber tau, tau = 2 * pi\n * @param {function} BigNumber BigNumber constructor\n * @returns {BigNumber} Returns tau\n */\n\nexports.createBigNumberPi = createBigNumberPi;\nvar createBigNumberTau = (0, _function.memoize)(function (BigNumber) {\n return createBigNumberPi(BigNumber).times(2);\n}, {\n hasher: hasher\n});\n/**\n * Create a hash for a BigNumber constructor function. The created has is\n * the configured precision\n * @param {Array} args Supposed to contain a single entry with\n * a BigNumber constructor\n * @return {number} precision\n * @private\n */\n\nexports.createBigNumberTau = createBigNumberTau;\n\nfunction hasher(args) {\n return args[0].precision;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.format = format;\nexports.toEngineering = toEngineering;\nexports.toExponential = toExponential;\nexports.toFixed = toFixed;\n\nvar _number = require(\"../number.js\");\n\n/**\n * Formats a BigNumber in a given base\n * @param {BigNumber} n\n * @param {number} base\n * @param {number} size\n * @returns {string}\n */\nfunction formatBigNumberToBase(n, base, size) {\n var BigNumberCtor = n.constructor;\n var big2 = new BigNumberCtor(2);\n var suffix = '';\n\n if (size) {\n if (size < 1) {\n throw new Error('size must be in greater than 0');\n }\n\n if (!(0, _number.isInteger)(size)) {\n throw new Error('size must be an integer');\n }\n\n if (n.greaterThan(big2.pow(size - 1).sub(1)) || n.lessThan(big2.pow(size - 1).mul(-1))) {\n throw new Error(\"Value must be in range [-2^\".concat(size - 1, \", 2^\").concat(size - 1, \"-1]\"));\n }\n\n if (!n.isInteger()) {\n throw new Error('Value must be an integer');\n }\n\n if (n.lessThan(0)) {\n n = n.add(big2.pow(size));\n }\n\n suffix = \"i\".concat(size);\n }\n\n switch (base) {\n case 2:\n return \"\".concat(n.toBinary()).concat(suffix);\n\n case 8:\n return \"\".concat(n.toOctal()).concat(suffix);\n\n case 16:\n return \"\".concat(n.toHexadecimal()).concat(suffix);\n\n default:\n throw new Error(\"Base \".concat(base, \" not supported \"));\n }\n}\n/**\n * Convert a BigNumber to a formatted string representation.\n *\n * Syntax:\n *\n * format(value)\n * format(value, options)\n * format(value, precision)\n * format(value, fn)\n *\n * Where:\n *\n * {number} value The value to be formatted\n * {Object} options An object with formatting options. Available options:\n * {string} notation\n * Number notation. Choose from:\n * 'fixed' Always use regular number notation.\n * For example '123.40' and '14000000'\n * 'exponential' Always use exponential notation.\n * For example '1.234e+2' and '1.4e+7'\n * 'auto' (default) Regular number notation for numbers\n * having an absolute value between\n * `lower` and `upper` bounds, and uses\n * exponential notation elsewhere.\n * Lower bound is included, upper bound\n * is excluded.\n * For example '123.4' and '1.4e7'.\n * 'bin', 'oct, or\n * 'hex' Format the number using binary, octal,\n * or hexadecimal notation.\n * For example '0b1101' and '0x10fe'.\n * {number} wordSize The word size in bits to use for formatting\n * in binary, octal, or hexadecimal notation.\n * To be used only with 'bin', 'oct', or 'hex'\n * values for 'notation' option. When this option\n * is defined the value is formatted as a signed\n * twos complement integer of the given word size\n * and the size suffix is appended to the output.\n * For example\n * format(-1, {notation: 'hex', wordSize: 8}) === '0xffi8'.\n * Default value is undefined.\n * {number} precision A number between 0 and 16 to round\n * the digits of the number.\n * In case of notations 'exponential',\n * 'engineering', and 'auto',\n * `precision` defines the total\n * number of significant digits returned.\n * In case of notation 'fixed',\n * `precision` defines the number of\n * significant digits after the decimal\n * point.\n * `precision` is undefined by default.\n * {number} lowerExp Exponent determining the lower boundary\n * for formatting a value with an exponent\n * when `notation='auto`.\n * Default value is `-3`.\n * {number} upperExp Exponent determining the upper boundary\n * for formatting a value with an exponent\n * when `notation='auto`.\n * Default value is `5`.\n * {Function} fn A custom formatting function. Can be used to override the\n * built-in notations. Function `fn` is called with `value` as\n * parameter and must return a string. Is useful for example to\n * format all values inside a matrix in a particular way.\n *\n * Examples:\n *\n * format(6.4) // '6.4'\n * format(1240000) // '1.24e6'\n * format(1/3) // '0.3333333333333333'\n * format(1/3, 3) // '0.333'\n * format(21385, 2) // '21000'\n * format(12e8, {notation: 'fixed'}) // returns '1200000000'\n * format(2.3, {notation: 'fixed', precision: 4}) // returns '2.3000'\n * format(52.8, {notation: 'exponential'}) // returns '5.28e+1'\n * format(12400, {notation: 'engineering'}) // returns '12.400e+3'\n *\n * @param {BigNumber} value\n * @param {Object | Function | number} [options]\n * @return {string} str The formatted value\n */\n\n\nfunction format(value, options) {\n if (typeof options === 'function') {\n // handle format(value, fn)\n return options(value);\n } // handle special cases\n\n\n if (!value.isFinite()) {\n return value.isNaN() ? 'NaN' : value.gt(0) ? 'Infinity' : '-Infinity';\n } // default values for options\n\n\n var notation = 'auto';\n var precision;\n var wordSize;\n\n if (options !== undefined) {\n // determine notation from options\n if (options.notation) {\n notation = options.notation;\n } // determine precision from options\n\n\n if (typeof options === 'number') {\n precision = options;\n } else if (options.precision) {\n precision = options.precision;\n }\n\n if (options.wordSize) {\n wordSize = options.wordSize;\n\n if (typeof wordSize !== 'number') {\n throw new Error('Option \"wordSize\" must be a number');\n }\n }\n } // handle the various notations\n\n\n switch (notation) {\n case 'fixed':\n return toFixed(value, precision);\n\n case 'exponential':\n return toExponential(value, precision);\n\n case 'engineering':\n return toEngineering(value, precision);\n\n case 'bin':\n return formatBigNumberToBase(value, 2, wordSize);\n\n case 'oct':\n return formatBigNumberToBase(value, 8, wordSize);\n\n case 'hex':\n return formatBigNumberToBase(value, 16, wordSize);\n\n case 'auto':\n {\n // determine lower and upper bound for exponential notation.\n // TODO: implement support for upper and lower to be BigNumbers themselves\n var lowerExp = options && options.lowerExp !== undefined ? options.lowerExp : -3;\n var upperExp = options && options.upperExp !== undefined ? options.upperExp : 5; // handle special case zero\n\n if (value.isZero()) return '0'; // determine whether or not to output exponential notation\n\n var str;\n var rounded = value.toSignificantDigits(precision);\n var exp = rounded.e;\n\n if (exp >= lowerExp && exp < upperExp) {\n // normal number notation\n str = rounded.toFixed();\n } else {\n // exponential notation\n str = toExponential(value, precision);\n } // remove trailing zeros after the decimal point\n\n\n return str.replace(/((\\.\\d*?)(0+))($|e)/, function () {\n var digits = arguments[2];\n var e = arguments[4];\n return digits !== '.' ? digits + e : e;\n });\n }\n\n default:\n throw new Error('Unknown notation \"' + notation + '\". ' + 'Choose \"auto\", \"exponential\", \"fixed\", \"bin\", \"oct\", or \"hex.');\n }\n}\n/**\n * Format a BigNumber in engineering notation. Like '1.23e+6', '2.3e+0', '3.500e-3'\n * @param {BigNumber | string} value\n * @param {number} [precision] Optional number of significant figures to return.\n */\n\n\nfunction toEngineering(value, precision) {\n // find nearest lower multiple of 3 for exponent\n var e = value.e;\n var newExp = e % 3 === 0 ? e : e < 0 ? e - 3 - e % 3 : e - e % 3; // find difference in exponents, and calculate the value without exponent\n\n var valueWithoutExp = value.mul(Math.pow(10, -newExp));\n var valueStr = valueWithoutExp.toPrecision(precision);\n\n if (valueStr.indexOf('e') !== -1) {\n valueStr = valueWithoutExp.toString();\n }\n\n return valueStr + 'e' + (e >= 0 ? '+' : '') + newExp.toString();\n}\n/**\n * Format a number in exponential notation. Like '1.23e+5', '2.3e+0', '3.500e-3'\n * @param {BigNumber} value\n * @param {number} [precision] Number of digits in formatted output.\n * If not provided, the maximum available digits\n * is used.\n * @returns {string} str\n */\n\n\nfunction toExponential(value, precision) {\n if (precision !== undefined) {\n return value.toExponential(precision - 1); // Note the offset of one\n } else {\n return value.toExponential();\n }\n}\n/**\n * Format a number with fixed notation.\n * @param {BigNumber} value\n * @param {number} [precision=undefined] Optional number of decimals after the\n * decimal point. Undefined by default.\n */\n\n\nfunction toFixed(value, precision) {\n return value.toFixed(precision);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.nearlyEqual = nearlyEqual;\n\n/**\n * Compares two BigNumbers.\n * @param {BigNumber} x First value to compare\n * @param {BigNumber} y Second value to compare\n * @param {number} [epsilon] The maximum relative difference between x and y\n * If epsilon is undefined or null, the function will\n * test whether x and y are exactly equal.\n * @return {boolean} whether the two numbers are nearly equal\n */\nfunction nearlyEqual(x, y, epsilon) {\n // if epsilon is null or undefined, test whether x and y are exactly equal\n if (epsilon === null || epsilon === undefined) {\n return x.eq(y);\n } // use \"==\" operator, handles infinities\n\n\n if (x.eq(y)) {\n return true;\n } // NaN\n\n\n if (x.isNaN() || y.isNaN()) {\n return false;\n } // at this point x and y should be finite\n\n\n if (x.isFinite() && y.isFinite()) {\n // check numbers are very close, needed when comparing numbers near zero\n var diff = x.minus(y).abs();\n\n if (diff.isZero()) {\n return true;\n } else {\n // use relative error\n var max = x.constructor.max(x.abs(), y.abs());\n return diff.lte(max.times(epsilon));\n }\n } // Infinite and Number or negative Infinite and positive Infinite cases\n\n\n return false;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.containsCollections = containsCollections;\nexports.deepForEach = deepForEach;\nexports.deepMap = deepMap;\nexports.reduce = reduce;\nexports.scatter = scatter;\n\nvar _is = require(\"./is.js\");\n\nvar _IndexError = require(\"../error/IndexError.js\");\n\nvar _array = require(\"./array.js\");\n\nvar _switch2 = require(\"./switch.js\");\n\n/**\n * Test whether an array contains collections\n * @param {Array} array\n * @returns {boolean} Returns true when the array contains one or multiple\n * collections (Arrays or Matrices). Returns false otherwise.\n */\nfunction containsCollections(array) {\n for (var i = 0; i < array.length; i++) {\n if ((0, _is.isCollection)(array[i])) {\n return true;\n }\n }\n\n return false;\n}\n/**\n * Recursively loop over all elements in a given multi dimensional array\n * and invoke the callback on each of the elements.\n * @param {Array | Matrix} array\n * @param {Function} callback The callback method is invoked with one\n * parameter: the current element in the array\n */\n\n\nfunction deepForEach(array, callback) {\n if ((0, _is.isMatrix)(array)) {\n array = array.valueOf();\n }\n\n for (var i = 0, ii = array.length; i < ii; i++) {\n var value = array[i];\n\n if (Array.isArray(value)) {\n deepForEach(value, callback);\n } else {\n callback(value);\n }\n }\n}\n/**\n * Execute the callback function element wise for each element in array and any\n * nested array\n * Returns an array with the results\n * @param {Array | Matrix} array\n * @param {Function} callback The callback is called with two parameters:\n * value1 and value2, which contain the current\n * element of both arrays.\n * @param {boolean} [skipZeros] Invoke callback function for non-zero values only.\n *\n * @return {Array | Matrix} res\n */\n\n\nfunction deepMap(array, callback, skipZeros) {\n if (array && typeof array.map === 'function') {\n // TODO: replace array.map with a for loop to improve performance\n return array.map(function (x) {\n return deepMap(x, callback, skipZeros);\n });\n } else {\n return callback(array);\n }\n}\n/**\n * Reduce a given matrix or array to a new matrix or\n * array with one less dimension, applying the given\n * callback in the selected dimension.\n * @param {Array | Matrix} mat\n * @param {number} dim\n * @param {Function} callback\n * @return {Array | Matrix} res\n */\n\n\nfunction reduce(mat, dim, callback) {\n var size = Array.isArray(mat) ? (0, _array.arraySize)(mat) : mat.size();\n\n if (dim < 0 || dim >= size.length) {\n // TODO: would be more clear when throwing a DimensionError here\n throw new _IndexError.IndexError(dim, size.length);\n }\n\n if ((0, _is.isMatrix)(mat)) {\n return mat.create(_reduce(mat.valueOf(), dim, callback));\n } else {\n return _reduce(mat, dim, callback);\n }\n}\n/**\n * Recursively reduce a matrix\n * @param {Array} mat\n * @param {number} dim\n * @param {Function} callback\n * @returns {Array} ret\n * @private\n */\n\n\nfunction _reduce(mat, dim, callback) {\n var i, ret, val, tran;\n\n if (dim <= 0) {\n if (!Array.isArray(mat[0])) {\n val = mat[0];\n\n for (i = 1; i < mat.length; i++) {\n val = callback(val, mat[i]);\n }\n\n return val;\n } else {\n tran = (0, _switch2._switch)(mat);\n ret = [];\n\n for (i = 0; i < tran.length; i++) {\n ret[i] = _reduce(tran[i], dim - 1, callback);\n }\n\n return ret;\n }\n } else {\n ret = [];\n\n for (i = 0; i < mat.length; i++) {\n ret[i] = _reduce(mat[i], dim - 1, callback);\n }\n\n return ret;\n }\n} // TODO: document function scatter\n\n\nfunction scatter(a, j, w, x, u, mark, cindex, f, inverse, update, value) {\n // a arrays\n var avalues = a._values;\n var aindex = a._index;\n var aptr = a._ptr; // vars\n\n var k, k0, k1, i; // check we need to process values (pattern matrix)\n\n if (x) {\n // values in j\n for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = aindex[k]; // check value exists in current j\n\n if (w[i] !== mark) {\n // i is new entry in j\n w[i] = mark; // add i to pattern of C\n\n cindex.push(i); // x(i) = A, check we need to call function this time\n\n if (update) {\n // copy value to workspace calling callback function\n x[i] = inverse ? f(avalues[k], value) : f(value, avalues[k]); // function was called on current row\n\n u[i] = mark;\n } else {\n // copy value to workspace\n x[i] = avalues[k];\n }\n } else {\n // i exists in C already\n x[i] = inverse ? f(avalues[k], x[i]) : f(x[i], avalues[k]); // function was called on current row\n\n u[i] = mark;\n }\n }\n } else {\n // values in j\n for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n // row\n i = aindex[k]; // check value exists in current j\n\n if (w[i] !== mark) {\n // i is new entry in j\n w[i] = mark; // add i to pattern of C\n\n cindex.push(i);\n } else {\n // indicate function was called on current row\n u[i] = mark;\n }\n }\n }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.complexEquals = complexEquals;\n\nvar _number = require(\"./number.js\");\n\n/**\n * Test whether two complex values are equal provided a given epsilon.\n * Does not use or change the global Complex.EPSILON setting\n * @param {Complex} x\n * @param {Complex} y\n * @param {number} epsilon\n * @returns {boolean}\n */\nfunction complexEquals(x, y, epsilon) {\n return (0, _number.nearlyEqual)(x.re, y.re, epsilon) && (0, _number.nearlyEqual)(x.im, y.im, epsilon);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getSafeProperties = getSafeProperties;\nexports.getSafeProperty = getSafeProperty;\nexports.hasSafeProperty = hasSafeProperty;\nexports.isPlainObject = isPlainObject;\nexports.isSafeMethod = isSafeMethod;\nexports.isSafeProperty = isSafeProperty;\nexports.setSafeProperty = setSafeProperty;\nexports.validateSafeMethod = validateSafeMethod;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _object = require(\"./object.js\");\n\n/**\n * Get a property of a plain object\n * Throws an error in case the object is not a plain object or the\n * property is not defined on the object itself\n * @param {Object} object\n * @param {string} prop\n * @return {*} Returns the property value when safe\n */\nfunction getSafeProperty(object, prop) {\n // only allow getting safe properties of a plain object\n if (isPlainObject(object) && isSafeProperty(object, prop)) {\n return object[prop];\n }\n\n if (typeof object[prop] === 'function' && isSafeMethod(object, prop)) {\n throw new Error('Cannot access method \"' + prop + '\" as a property');\n }\n\n throw new Error('No access to property \"' + prop + '\"');\n}\n/**\n * Set a property on a plain object.\n * Throws an error in case the object is not a plain object or the\n * property would override an inherited property like .constructor or .toString\n * @param {Object} object\n * @param {string} prop\n * @param {*} value\n * @return {*} Returns the value\n */\n// TODO: merge this function into access.js?\n\n\nfunction setSafeProperty(object, prop, value) {\n // only allow setting safe properties of a plain object\n if (isPlainObject(object) && isSafeProperty(object, prop)) {\n object[prop] = value;\n return value;\n }\n\n throw new Error('No access to property \"' + prop + '\"');\n}\n\nfunction getSafeProperties(object) {\n return Object.keys(object).filter(function (prop) {\n return (0, _object.hasOwnProperty)(object, prop);\n });\n}\n\nfunction hasSafeProperty(object, prop) {\n return prop in object;\n}\n/**\n * Test whether a property is safe to use for an object.\n * For example .toString and .constructor are not safe\n * @param {string} prop\n * @return {boolean} Returns true when safe\n */\n\n\nfunction isSafeProperty(object, prop) {\n if (!object || (0, _typeof2.default)(object) !== 'object') {\n return false;\n } // SAFE: whitelisted\n // e.g length\n\n\n if ((0, _object.hasOwnProperty)(safeNativeProperties, prop)) {\n return true;\n } // UNSAFE: inherited from Object prototype\n // e.g constructor\n\n\n if (prop in Object.prototype) {\n // 'in' is used instead of hasOwnProperty for nodejs v0.10\n // which is inconsistent on root prototypes. It is safe\n // here because Object.prototype is a root object\n return false;\n } // UNSAFE: inherited from Function prototype\n // e.g call, apply\n\n\n if (prop in Function.prototype) {\n // 'in' is used instead of hasOwnProperty for nodejs v0.10\n // which is inconsistent on root prototypes. It is safe\n // here because Function.prototype is a root object\n return false;\n }\n\n return true;\n}\n/**\n * Validate whether a method is safe.\n * Throws an error when that's not the case.\n * @param {Object} object\n * @param {string} method\n */\n// TODO: merge this function into assign.js?\n\n\nfunction validateSafeMethod(object, method) {\n if (!isSafeMethod(object, method)) {\n throw new Error('No access to method \"' + method + '\"');\n }\n}\n/**\n * Check whether a method is safe.\n * Throws an error when that's not the case (for example for `constructor`).\n * @param {Object} object\n * @param {string} method\n * @return {boolean} Returns true when safe, false otherwise\n */\n\n\nfunction isSafeMethod(object, method) {\n if (object === null || object === undefined || typeof object[method] !== 'function') {\n return false;\n } // UNSAFE: ghosted\n // e.g overridden toString\n // Note that IE10 doesn't support __proto__ and we can't do this check there.\n\n\n if ((0, _object.hasOwnProperty)(object, method) && Object.getPrototypeOf && method in Object.getPrototypeOf(object)) {\n return false;\n } // SAFE: whitelisted\n // e.g toString\n\n\n if ((0, _object.hasOwnProperty)(safeNativeMethods, method)) {\n return true;\n } // UNSAFE: inherited from Object prototype\n // e.g constructor\n\n\n if (method in Object.prototype) {\n // 'in' is used instead of hasOwnProperty for nodejs v0.10\n // which is inconsistent on root prototypes. It is safe\n // here because Object.prototype is a root object\n return false;\n } // UNSAFE: inherited from Function prototype\n // e.g call, apply\n\n\n if (method in Function.prototype) {\n // 'in' is used instead of hasOwnProperty for nodejs v0.10\n // which is inconsistent on root prototypes. It is safe\n // here because Function.prototype is a root object\n return false;\n }\n\n return true;\n}\n\nfunction isPlainObject(object) {\n return (0, _typeof2.default)(object) === 'object' && object && object.constructor === Object;\n}\n\nvar safeNativeProperties = {\n length: true,\n name: true\n};\nvar safeNativeMethods = {\n toString: true,\n valueOf: true,\n toLocaleString: true\n};","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.mixin = mixin;\n\nvar _tinyEmitter = _interopRequireDefault(require(\"tiny-emitter\"));\n\n/**\n * Extend given object with emitter functions `on`, `off`, `once`, `emit`\n * @param {Object} obj\n * @return {Object} obj\n */\nfunction mixin(obj) {\n // create event emitter\n var emitter = new _tinyEmitter.default(); // bind methods to obj (we don't want to expose the emitter.e Array...)\n\n obj.on = emitter.on.bind(emitter);\n obj.off = emitter.off.bind(emitter);\n obj.once = emitter.once.bind(emitter);\n obj.emit = emitter.emit.bind(emitter);\n return obj;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.assertDependencies = assertDependencies;\nexports.create = create;\nexports.factory = factory;\nexports.isFactory = isFactory;\nexports.isOptionalDependency = isOptionalDependency;\nexports.sortFactories = sortFactories;\nexports.stripOptionalNotation = stripOptionalNotation;\n\nvar _array = require(\"./array.js\");\n\nvar _object = require(\"./object.js\");\n\n/**\n * Create a factory function, which can be used to inject dependencies.\n *\n * The created functions are memoized, a consecutive call of the factory\n * with the exact same inputs will return the same function instance.\n * The memoized cache is exposed on `factory.cache` and can be cleared\n * if needed.\n *\n * Example:\n *\n * const name = 'log'\n * const dependencies = ['config', 'typed', 'divideScalar', 'Complex']\n *\n * export const createLog = factory(name, dependencies, ({ typed, config, divideScalar, Complex }) => {\n * // ... create the function log here and return it\n * }\n *\n * @param {string} name Name of the function to be created\n * @param {string[]} dependencies The names of all required dependencies\n * @param {function} create Callback function called with an object with all dependencies\n * @param {Object} [meta] Optional object with meta information that will be attached\n * to the created factory function as property `meta`.\n * @returns {function}\n */\nfunction factory(name, dependencies, create, meta) {\n function assertAndCreate(scope) {\n // we only pass the requested dependencies to the factory function\n // to prevent functions to rely on dependencies that are not explicitly\n // requested.\n var deps = (0, _object.pickShallow)(scope, dependencies.map(stripOptionalNotation));\n assertDependencies(name, dependencies, scope);\n return create(deps);\n }\n\n assertAndCreate.isFactory = true;\n assertAndCreate.fn = name;\n assertAndCreate.dependencies = dependencies.slice().sort();\n\n if (meta) {\n assertAndCreate.meta = meta;\n }\n\n return assertAndCreate;\n}\n/**\n * Sort all factories such that when loading in order, the dependencies are resolved.\n *\n * @param {Array} factories\n * @returns {Array} Returns a new array with the sorted factories.\n */\n\n\nfunction sortFactories(factories) {\n var factoriesByName = {};\n factories.forEach(function (factory) {\n factoriesByName[factory.fn] = factory;\n });\n\n function containsDependency(factory, dependency) {\n // TODO: detect circular references\n if (isFactory(factory)) {\n if ((0, _array.contains)(factory.dependencies, dependency.fn || dependency.name)) {\n return true;\n }\n\n if (factory.dependencies.some(function (d) {\n return containsDependency(factoriesByName[d], dependency);\n })) {\n return true;\n }\n }\n\n return false;\n }\n\n var sorted = [];\n\n function addFactory(factory) {\n var index = 0;\n\n while (index < sorted.length && !containsDependency(sorted[index], factory)) {\n index++;\n }\n\n sorted.splice(index, 0, factory);\n } // sort regular factory functions\n\n\n factories.filter(isFactory).forEach(addFactory); // sort legacy factory functions AFTER the regular factory functions\n\n factories.filter(function (factory) {\n return !isFactory(factory);\n }).forEach(addFactory);\n return sorted;\n} // TODO: comment or cleanup if unused in the end\n\n\nfunction create(factories) {\n var scope = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n sortFactories(factories).forEach(function (factory) {\n return factory(scope);\n });\n return scope;\n}\n/**\n * Test whether an object is a factory. This is the case when it has\n * properties name, dependencies, and a function create.\n * @param {*} obj\n * @returns {boolean}\n */\n\n\nfunction isFactory(obj) {\n return typeof obj === 'function' && typeof obj.fn === 'string' && Array.isArray(obj.dependencies);\n}\n/**\n * Assert that all dependencies of a list with dependencies are available in the provided scope.\n *\n * Will throw an exception when there are dependencies missing.\n *\n * @param {string} name Name for the function to be created. Used to generate a useful error message\n * @param {string[]} dependencies\n * @param {Object} scope\n */\n\n\nfunction assertDependencies(name, dependencies, scope) {\n var allDefined = dependencies.filter(function (dependency) {\n return !isOptionalDependency(dependency);\n }) // filter optionals\n .every(function (dependency) {\n return scope[dependency] !== undefined;\n });\n\n if (!allDefined) {\n var missingDependencies = dependencies.filter(function (dependency) {\n return scope[dependency] === undefined;\n }); // TODO: create a custom error class for this, a MathjsError or something like that\n\n throw new Error(\"Cannot create function \\\"\".concat(name, \"\\\", \") + \"some dependencies are missing: \".concat(missingDependencies.map(function (d) {\n return \"\\\"\".concat(d, \"\\\"\");\n }).join(', '), \".\"));\n }\n}\n\nfunction isOptionalDependency(dependency) {\n return dependency && dependency[0] === '?';\n}\n\nfunction stripOptionalNotation(dependency) {\n return dependency && dependency[0] === '?' ? dependency.slice(1) : dependency;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.maxArgumentCount = maxArgumentCount;\nexports.memoize = memoize;\nexports.memoizeCompare = memoizeCompare;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _lruQueue = require(\"./lruQueue.js\");\n\n// function utils\n\n/**\n * Memoize a given function by caching the computed result.\n * The cache of a memoized function can be cleared by deleting the `cache`\n * property of the function.\n *\n * @param {function} fn The function to be memoized.\n * Must be a pure function.\n * @param {Object} [options]\n * @param {function(args: Array): string} [options.hasher]\n * A custom hash builder. Is JSON.stringify by default.\n * @param {number | undefined} [options.limit]\n * Maximum number of values that may be cached. Undefined indicates\n * unlimited (default)\n * @return {function} Returns the memoized function\n */\nfunction memoize(fn) {\n var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n hasher = _ref.hasher,\n limit = _ref.limit;\n\n limit = limit == null ? Number.POSITIVE_INFINITY : limit;\n hasher = hasher == null ? JSON.stringify : hasher;\n return function memoize() {\n if ((0, _typeof2.default)(memoize.cache) !== 'object') {\n memoize.cache = {\n values: new Map(),\n lru: (0, _lruQueue.lruQueue)(limit || Number.POSITIVE_INFINITY)\n };\n }\n\n var args = [];\n\n for (var i = 0; i < arguments.length; i++) {\n args[i] = arguments[i];\n }\n\n var hash = hasher(args);\n\n if (memoize.cache.values.has(hash)) {\n memoize.cache.lru.hit(hash);\n return memoize.cache.values.get(hash);\n }\n\n var newVal = fn.apply(fn, args);\n memoize.cache.values.set(hash, newVal);\n memoize.cache.values.delete(memoize.cache.lru.hit(hash));\n return newVal;\n };\n}\n/**\n * Memoize a given function by caching all results and the arguments,\n * and comparing against the arguments of previous results before\n * executing again.\n * This is less performant than `memoize` which calculates a hash,\n * which is very fast to compare. Use `memoizeCompare` only when it is\n * not possible to create a unique serializable hash from the function\n * arguments.\n * The isEqual function must compare two sets of arguments\n * and return true when equal (can be a deep equality check for example).\n * @param {function} fn\n * @param {function(a: *, b: *) : boolean} isEqual\n * @returns {function}\n */\n\n\nfunction memoizeCompare(fn, isEqual) {\n var memoize = function memoize() {\n var args = [];\n\n for (var i = 0; i < arguments.length; i++) {\n args[i] = arguments[i];\n }\n\n for (var c = 0; c < memoize.cache.length; c++) {\n var cached = memoize.cache[c];\n\n if (isEqual(args, cached.args)) {\n // TODO: move this cache entry to the top so recently used entries move up?\n return cached.res;\n }\n }\n\n var res = fn.apply(fn, args);\n memoize.cache.unshift({\n args: args,\n res: res\n });\n return res;\n };\n\n memoize.cache = [];\n return memoize;\n}\n/**\n * Find the maximum number of arguments expected by a typed function.\n * @param {function} fn A typed function\n * @return {number} Returns the maximum number of expected arguments.\n * Returns -1 when no signatures where found on the function.\n */\n\n\nfunction maxArgumentCount(fn) {\n return Object.keys(fn.signatures || {}).reduce(function (args, signature) {\n var count = (signature.match(/,/g) || []).length + 1;\n return Math.max(args, count);\n }, -1);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isAccessorNode = isAccessorNode;\nexports.isArray = void 0;\nexports.isArrayNode = isArrayNode;\nexports.isAssignmentNode = isAssignmentNode;\nexports.isBigNumber = isBigNumber;\nexports.isBlockNode = isBlockNode;\nexports.isBoolean = isBoolean;\nexports.isChain = isChain;\nexports.isCollection = isCollection;\nexports.isComplex = isComplex;\nexports.isConditionalNode = isConditionalNode;\nexports.isConstantNode = isConstantNode;\nexports.isDate = isDate;\nexports.isDenseMatrix = isDenseMatrix;\nexports.isFraction = isFraction;\nexports.isFunction = isFunction;\nexports.isFunctionAssignmentNode = isFunctionAssignmentNode;\nexports.isFunctionNode = isFunctionNode;\nexports.isHelp = isHelp;\nexports.isIndex = isIndex;\nexports.isIndexNode = isIndexNode;\nexports.isMatrix = isMatrix;\nexports.isNode = isNode;\nexports.isNull = isNull;\nexports.isNumber = isNumber;\nexports.isObject = isObject;\nexports.isObjectNode = isObjectNode;\nexports.isOperatorNode = isOperatorNode;\nexports.isParenthesisNode = isParenthesisNode;\nexports.isRange = isRange;\nexports.isRangeNode = isRangeNode;\nexports.isRegExp = isRegExp;\nexports.isResultSet = isResultSet;\nexports.isSparseMatrix = isSparseMatrix;\nexports.isString = isString;\nexports.isSymbolNode = isSymbolNode;\nexports.isUndefined = isUndefined;\nexports.isUnit = isUnit;\nexports.typeOf = typeOf;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\n// type checks for all known types\n//\n// note that:\n//\n// - check by duck-typing on a property like `isUnit`, instead of checking instanceof.\n// instanceof cannot be used because that would not allow to pass data from\n// one instance of math.js to another since each has it's own instance of Unit.\n// - check the `isUnit` property via the constructor, so there will be no\n// matches for \"fake\" instances like plain objects with a property `isUnit`.\n// That is important for security reasons.\n// - It must not be possible to override the type checks used internally,\n// for security reasons, so these functions are not exposed in the expression\n// parser.\nfunction isNumber(x) {\n return typeof x === 'number';\n}\n\nfunction isBigNumber(x) {\n if (!x || (0, _typeof2.default)(x) !== 'object' || typeof x.constructor !== 'function') {\n return false;\n }\n\n if (x.isBigNumber === true && (0, _typeof2.default)(x.constructor.prototype) === 'object' && x.constructor.prototype.isBigNumber === true) {\n return true;\n }\n\n if (typeof x.constructor.isDecimal === 'function' && x.constructor.isDecimal(x) === true) {\n return true;\n }\n\n return false;\n}\n\nfunction isComplex(x) {\n return x && (0, _typeof2.default)(x) === 'object' && Object.getPrototypeOf(x).isComplex === true || false;\n}\n\nfunction isFraction(x) {\n return x && (0, _typeof2.default)(x) === 'object' && Object.getPrototypeOf(x).isFraction === true || false;\n}\n\nfunction isUnit(x) {\n return x && x.constructor.prototype.isUnit === true || false;\n}\n\nfunction isString(x) {\n return typeof x === 'string';\n}\n\nvar isArray = Array.isArray;\nexports.isArray = isArray;\n\nfunction isMatrix(x) {\n return x && x.constructor.prototype.isMatrix === true || false;\n}\n/**\n * Test whether a value is a collection: an Array or Matrix\n * @param {*} x\n * @returns {boolean} isCollection\n */\n\n\nfunction isCollection(x) {\n return Array.isArray(x) || isMatrix(x);\n}\n\nfunction isDenseMatrix(x) {\n return x && x.isDenseMatrix && x.constructor.prototype.isMatrix === true || false;\n}\n\nfunction isSparseMatrix(x) {\n return x && x.isSparseMatrix && x.constructor.prototype.isMatrix === true || false;\n}\n\nfunction isRange(x) {\n return x && x.constructor.prototype.isRange === true || false;\n}\n\nfunction isIndex(x) {\n return x && x.constructor.prototype.isIndex === true || false;\n}\n\nfunction isBoolean(x) {\n return typeof x === 'boolean';\n}\n\nfunction isResultSet(x) {\n return x && x.constructor.prototype.isResultSet === true || false;\n}\n\nfunction isHelp(x) {\n return x && x.constructor.prototype.isHelp === true || false;\n}\n\nfunction isFunction(x) {\n return typeof x === 'function';\n}\n\nfunction isDate(x) {\n return x instanceof Date;\n}\n\nfunction isRegExp(x) {\n return x instanceof RegExp;\n}\n\nfunction isObject(x) {\n return !!(x && (0, _typeof2.default)(x) === 'object' && x.constructor === Object && !isComplex(x) && !isFraction(x));\n}\n\nfunction isNull(x) {\n return x === null;\n}\n\nfunction isUndefined(x) {\n return x === undefined;\n}\n\nfunction isAccessorNode(x) {\n return x && x.isAccessorNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isArrayNode(x) {\n return x && x.isArrayNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isAssignmentNode(x) {\n return x && x.isAssignmentNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isBlockNode(x) {\n return x && x.isBlockNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isConditionalNode(x) {\n return x && x.isConditionalNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isConstantNode(x) {\n return x && x.isConstantNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isFunctionAssignmentNode(x) {\n return x && x.isFunctionAssignmentNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isFunctionNode(x) {\n return x && x.isFunctionNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isIndexNode(x) {\n return x && x.isIndexNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isNode(x) {\n return x && x.isNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isObjectNode(x) {\n return x && x.isObjectNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isOperatorNode(x) {\n return x && x.isOperatorNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isParenthesisNode(x) {\n return x && x.isParenthesisNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isRangeNode(x) {\n return x && x.isRangeNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isSymbolNode(x) {\n return x && x.isSymbolNode === true && x.constructor.prototype.isNode === true || false;\n}\n\nfunction isChain(x) {\n return x && x.constructor.prototype.isChain === true || false;\n}\n\nfunction typeOf(x) {\n var t = (0, _typeof2.default)(x);\n\n if (t === 'object') {\n // JavaScript types\n if (x === null) return 'null';\n if (Array.isArray(x)) return 'Array';\n if (x instanceof Date) return 'Date';\n if (x instanceof RegExp) return 'RegExp'; // math.js types\n\n if (isBigNumber(x)) return 'BigNumber';\n if (isComplex(x)) return 'Complex';\n if (isFraction(x)) return 'Fraction';\n if (isMatrix(x)) return 'Matrix';\n if (isUnit(x)) return 'Unit';\n if (isIndex(x)) return 'Index';\n if (isRange(x)) return 'Range';\n if (isResultSet(x)) return 'ResultSet';\n if (isNode(x)) return x.type;\n if (isChain(x)) return 'Chain';\n if (isHelp(x)) return 'Help';\n return 'Object';\n }\n\n if (t === 'function') return 'Function';\n return t; // can be 'string', 'number', 'boolean', ...\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.defaultTemplate = void 0;\nexports.escapeLatex = escapeLatex;\nexports.latexSymbols = exports.latexOperators = exports.latexFunctions = void 0;\nexports.toSymbol = toSymbol;\n\nvar _escapeLatex = _interopRequireDefault(require(\"escape-latex\"));\n\nvar _object = require(\"./object.js\");\n\n/* eslint no-template-curly-in-string: \"off\" */\nvar latexSymbols = {\n // GREEK LETTERS\n Alpha: 'A',\n alpha: '\\\\alpha',\n Beta: 'B',\n beta: '\\\\beta',\n Gamma: '\\\\Gamma',\n gamma: '\\\\gamma',\n Delta: '\\\\Delta',\n delta: '\\\\delta',\n Epsilon: 'E',\n epsilon: '\\\\epsilon',\n varepsilon: '\\\\varepsilon',\n Zeta: 'Z',\n zeta: '\\\\zeta',\n Eta: 'H',\n eta: '\\\\eta',\n Theta: '\\\\Theta',\n theta: '\\\\theta',\n vartheta: '\\\\vartheta',\n Iota: 'I',\n iota: '\\\\iota',\n Kappa: 'K',\n kappa: '\\\\kappa',\n varkappa: '\\\\varkappa',\n Lambda: '\\\\Lambda',\n lambda: '\\\\lambda',\n Mu: 'M',\n mu: '\\\\mu',\n Nu: 'N',\n nu: '\\\\nu',\n Xi: '\\\\Xi',\n xi: '\\\\xi',\n Omicron: 'O',\n omicron: 'o',\n Pi: '\\\\Pi',\n pi: '\\\\pi',\n varpi: '\\\\varpi',\n Rho: 'P',\n rho: '\\\\rho',\n varrho: '\\\\varrho',\n Sigma: '\\\\Sigma',\n sigma: '\\\\sigma',\n varsigma: '\\\\varsigma',\n Tau: 'T',\n tau: '\\\\tau',\n Upsilon: \"\\\\Upsilon\",\n upsilon: \"\\\\upsilon\",\n Phi: '\\\\Phi',\n phi: '\\\\phi',\n varphi: '\\\\varphi',\n Chi: 'X',\n chi: '\\\\chi',\n Psi: '\\\\Psi',\n psi: '\\\\psi',\n Omega: '\\\\Omega',\n omega: '\\\\omega',\n // logic\n true: '\\\\mathrm{True}',\n false: '\\\\mathrm{False}',\n // other\n i: 'i',\n // TODO use \\i ??\n inf: '\\\\infty',\n Inf: '\\\\infty',\n infinity: '\\\\infty',\n Infinity: '\\\\infty',\n oo: '\\\\infty',\n lim: '\\\\lim',\n undefined: '\\\\mathbf{?}'\n};\nexports.latexSymbols = latexSymbols;\nvar latexOperators = {\n transpose: '^\\\\top',\n ctranspose: '^H',\n factorial: '!',\n pow: '^',\n dotPow: '.^\\\\wedge',\n // TODO find ideal solution\n unaryPlus: '+',\n unaryMinus: '-',\n bitNot: '\\\\~',\n // TODO find ideal solution\n not: '\\\\neg',\n multiply: '\\\\cdot',\n divide: '\\\\frac',\n // TODO how to handle that properly?\n dotMultiply: '.\\\\cdot',\n // TODO find ideal solution\n dotDivide: '.:',\n // TODO find ideal solution\n mod: '\\\\mod',\n add: '+',\n subtract: '-',\n to: '\\\\rightarrow',\n leftShift: '<<',\n rightArithShift: '>>',\n rightLogShift: '>>>',\n equal: '=',\n unequal: '\\\\neq',\n smaller: '<',\n larger: '>',\n smallerEq: '\\\\leq',\n largerEq: '\\\\geq',\n bitAnd: '\\\\&',\n bitXor: \"\\\\underline{|}\",\n bitOr: '|',\n and: '\\\\wedge',\n xor: '\\\\veebar',\n or: '\\\\vee'\n};\nexports.latexOperators = latexOperators;\nvar latexFunctions = {\n // arithmetic\n abs: {\n 1: '\\\\left|${args[0]}\\\\right|'\n },\n add: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.add, \"${args[1]}\\\\right)\")\n },\n cbrt: {\n 1: '\\\\sqrt[3]{${args[0]}}'\n },\n ceil: {\n 1: '\\\\left\\\\lceil${args[0]}\\\\right\\\\rceil'\n },\n cube: {\n 1: '\\\\left(${args[0]}\\\\right)^3'\n },\n divide: {\n 2: '\\\\frac{${args[0]}}{${args[1]}}'\n },\n dotDivide: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.dotDivide, \"${args[1]}\\\\right)\")\n },\n dotMultiply: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.dotMultiply, \"${args[1]}\\\\right)\")\n },\n dotPow: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.dotPow, \"${args[1]}\\\\right)\")\n },\n exp: {\n 1: '\\\\exp\\\\left(${args[0]}\\\\right)'\n },\n expm1: \"\\\\left(e\".concat(latexOperators.pow, \"{${args[0]}}-1\\\\right)\"),\n fix: {\n 1: '\\\\mathrm{${name}}\\\\left(${args[0]}\\\\right)'\n },\n floor: {\n 1: '\\\\left\\\\lfloor${args[0]}\\\\right\\\\rfloor'\n },\n gcd: '\\\\gcd\\\\left(${args}\\\\right)',\n hypot: '\\\\hypot\\\\left(${args}\\\\right)',\n log: {\n 1: '\\\\ln\\\\left(${args[0]}\\\\right)',\n 2: '\\\\log_{${args[1]}}\\\\left(${args[0]}\\\\right)'\n },\n log10: {\n 1: '\\\\log_{10}\\\\left(${args[0]}\\\\right)'\n },\n log1p: {\n 1: '\\\\ln\\\\left(${args[0]}+1\\\\right)',\n 2: '\\\\log_{${args[1]}}\\\\left(${args[0]}+1\\\\right)'\n },\n log2: '\\\\log_{2}\\\\left(${args[0]}\\\\right)',\n mod: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.mod, \"${args[1]}\\\\right)\")\n },\n multiply: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.multiply, \"${args[1]}\\\\right)\")\n },\n norm: {\n 1: '\\\\left\\\\|${args[0]}\\\\right\\\\|',\n 2: undefined // use default template\n\n },\n nthRoot: {\n 2: '\\\\sqrt[${args[1]}]{${args[0]}}'\n },\n nthRoots: {\n 2: '\\\\{y : $y^{args[1]} = {${args[0]}}\\\\}'\n },\n pow: {\n 2: \"\\\\left(${args[0]}\\\\right)\".concat(latexOperators.pow, \"{${args[1]}}\")\n },\n round: {\n 1: '\\\\left\\\\lfloor${args[0]}\\\\right\\\\rceil',\n 2: undefined // use default template\n\n },\n sign: {\n 1: '\\\\mathrm{${name}}\\\\left(${args[0]}\\\\right)'\n },\n sqrt: {\n 1: '\\\\sqrt{${args[0]}}'\n },\n square: {\n 1: '\\\\left(${args[0]}\\\\right)^2'\n },\n subtract: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.subtract, \"${args[1]}\\\\right)\")\n },\n unaryMinus: {\n 1: \"\".concat(latexOperators.unaryMinus, \"\\\\left(${args[0]}\\\\right)\")\n },\n unaryPlus: {\n 1: \"\".concat(latexOperators.unaryPlus, \"\\\\left(${args[0]}\\\\right)\")\n },\n // bitwise\n bitAnd: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.bitAnd, \"${args[1]}\\\\right)\")\n },\n bitNot: {\n 1: latexOperators.bitNot + '\\\\left(${args[0]}\\\\right)'\n },\n bitOr: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.bitOr, \"${args[1]}\\\\right)\")\n },\n bitXor: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.bitXor, \"${args[1]}\\\\right)\")\n },\n leftShift: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.leftShift, \"${args[1]}\\\\right)\")\n },\n rightArithShift: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.rightArithShift, \"${args[1]}\\\\right)\")\n },\n rightLogShift: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.rightLogShift, \"${args[1]}\\\\right)\")\n },\n // combinatorics\n bellNumbers: {\n 1: '\\\\mathrm{B}_{${args[0]}}'\n },\n catalan: {\n 1: '\\\\mathrm{C}_{${args[0]}}'\n },\n stirlingS2: {\n 2: '\\\\mathrm{S}\\\\left(${args}\\\\right)'\n },\n // complex\n arg: {\n 1: '\\\\arg\\\\left(${args[0]}\\\\right)'\n },\n conj: {\n 1: '\\\\left(${args[0]}\\\\right)^*'\n },\n im: {\n 1: '\\\\Im\\\\left\\\\lbrace${args[0]}\\\\right\\\\rbrace'\n },\n re: {\n 1: '\\\\Re\\\\left\\\\lbrace${args[0]}\\\\right\\\\rbrace'\n },\n // logical\n and: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.and, \"${args[1]}\\\\right)\")\n },\n not: {\n 1: latexOperators.not + '\\\\left(${args[0]}\\\\right)'\n },\n or: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.or, \"${args[1]}\\\\right)\")\n },\n xor: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.xor, \"${args[1]}\\\\right)\")\n },\n // matrix\n cross: {\n 2: '\\\\left(${args[0]}\\\\right)\\\\times\\\\left(${args[1]}\\\\right)'\n },\n ctranspose: {\n 1: \"\\\\left(${args[0]}\\\\right)\".concat(latexOperators.ctranspose)\n },\n det: {\n 1: '\\\\det\\\\left(${args[0]}\\\\right)'\n },\n dot: {\n 2: '\\\\left(${args[0]}\\\\cdot${args[1]}\\\\right)'\n },\n expm: {\n 1: '\\\\exp\\\\left(${args[0]}\\\\right)'\n },\n inv: {\n 1: '\\\\left(${args[0]}\\\\right)^{-1}'\n },\n pinv: {\n 1: '\\\\left(${args[0]}\\\\right)^{+}'\n },\n sqrtm: {\n 1: \"{${args[0]}}\".concat(latexOperators.pow, \"{\\\\frac{1}{2}}\")\n },\n trace: {\n 1: '\\\\mathrm{tr}\\\\left(${args[0]}\\\\right)'\n },\n transpose: {\n 1: \"\\\\left(${args[0]}\\\\right)\".concat(latexOperators.transpose)\n },\n // probability\n combinations: {\n 2: '\\\\binom{${args[0]}}{${args[1]}}'\n },\n combinationsWithRep: {\n 2: '\\\\left(\\\\!\\\\!{\\\\binom{${args[0]}}{${args[1]}}}\\\\!\\\\!\\\\right)'\n },\n factorial: {\n 1: \"\\\\left(${args[0]}\\\\right)\".concat(latexOperators.factorial)\n },\n gamma: {\n 1: '\\\\Gamma\\\\left(${args[0]}\\\\right)'\n },\n lgamma: {\n 1: '\\\\ln\\\\Gamma\\\\left(${args[0]}\\\\right)'\n },\n // relational\n equal: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.equal, \"${args[1]}\\\\right)\")\n },\n larger: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.larger, \"${args[1]}\\\\right)\")\n },\n largerEq: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.largerEq, \"${args[1]}\\\\right)\")\n },\n smaller: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.smaller, \"${args[1]}\\\\right)\")\n },\n smallerEq: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.smallerEq, \"${args[1]}\\\\right)\")\n },\n unequal: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.unequal, \"${args[1]}\\\\right)\")\n },\n // special\n erf: {\n 1: 'erf\\\\left(${args[0]}\\\\right)'\n },\n // statistics\n max: '\\\\max\\\\left(${args}\\\\right)',\n min: '\\\\min\\\\left(${args}\\\\right)',\n variance: '\\\\mathrm{Var}\\\\left(${args}\\\\right)',\n // trigonometry\n acos: {\n 1: '\\\\cos^{-1}\\\\left(${args[0]}\\\\right)'\n },\n acosh: {\n 1: '\\\\cosh^{-1}\\\\left(${args[0]}\\\\right)'\n },\n acot: {\n 1: '\\\\cot^{-1}\\\\left(${args[0]}\\\\right)'\n },\n acoth: {\n 1: '\\\\coth^{-1}\\\\left(${args[0]}\\\\right)'\n },\n acsc: {\n 1: '\\\\csc^{-1}\\\\left(${args[0]}\\\\right)'\n },\n acsch: {\n 1: '\\\\mathrm{csch}^{-1}\\\\left(${args[0]}\\\\right)'\n },\n asec: {\n 1: '\\\\sec^{-1}\\\\left(${args[0]}\\\\right)'\n },\n asech: {\n 1: '\\\\mathrm{sech}^{-1}\\\\left(${args[0]}\\\\right)'\n },\n asin: {\n 1: '\\\\sin^{-1}\\\\left(${args[0]}\\\\right)'\n },\n asinh: {\n 1: '\\\\sinh^{-1}\\\\left(${args[0]}\\\\right)'\n },\n atan: {\n 1: '\\\\tan^{-1}\\\\left(${args[0]}\\\\right)'\n },\n atan2: {\n 2: '\\\\mathrm{atan2}\\\\left(${args}\\\\right)'\n },\n atanh: {\n 1: '\\\\tanh^{-1}\\\\left(${args[0]}\\\\right)'\n },\n cos: {\n 1: '\\\\cos\\\\left(${args[0]}\\\\right)'\n },\n cosh: {\n 1: '\\\\cosh\\\\left(${args[0]}\\\\right)'\n },\n cot: {\n 1: '\\\\cot\\\\left(${args[0]}\\\\right)'\n },\n coth: {\n 1: '\\\\coth\\\\left(${args[0]}\\\\right)'\n },\n csc: {\n 1: '\\\\csc\\\\left(${args[0]}\\\\right)'\n },\n csch: {\n 1: '\\\\mathrm{csch}\\\\left(${args[0]}\\\\right)'\n },\n sec: {\n 1: '\\\\sec\\\\left(${args[0]}\\\\right)'\n },\n sech: {\n 1: '\\\\mathrm{sech}\\\\left(${args[0]}\\\\right)'\n },\n sin: {\n 1: '\\\\sin\\\\left(${args[0]}\\\\right)'\n },\n sinh: {\n 1: '\\\\sinh\\\\left(${args[0]}\\\\right)'\n },\n tan: {\n 1: '\\\\tan\\\\left(${args[0]}\\\\right)'\n },\n tanh: {\n 1: '\\\\tanh\\\\left(${args[0]}\\\\right)'\n },\n // unit\n to: {\n 2: \"\\\\left(${args[0]}\".concat(latexOperators.to, \"${args[1]}\\\\right)\")\n },\n // utils\n numeric: function numeric(node, options) {\n // Not sure if this is strictly right but should work correctly for the vast majority of use cases.\n return node.args[0].toTex();\n },\n // type\n number: {\n 0: '0',\n 1: '\\\\left(${args[0]}\\\\right)',\n 2: '\\\\left(\\\\left(${args[0]}\\\\right)${args[1]}\\\\right)'\n },\n string: {\n 0: '\\\\mathtt{\"\"}',\n 1: '\\\\mathrm{string}\\\\left(${args[0]}\\\\right)'\n },\n bignumber: {\n 0: '0',\n 1: '\\\\left(${args[0]}\\\\right)'\n },\n complex: {\n 0: '0',\n 1: '\\\\left(${args[0]}\\\\right)',\n 2: \"\\\\left(\\\\left(${args[0]}\\\\right)+\".concat(latexSymbols.i, \"\\\\cdot\\\\left(${args[1]}\\\\right)\\\\right)\")\n },\n matrix: {\n 0: '\\\\begin{bmatrix}\\\\end{bmatrix}',\n 1: '\\\\left(${args[0]}\\\\right)',\n 2: '\\\\left(${args[0]}\\\\right)'\n },\n sparse: {\n 0: '\\\\begin{bsparse}\\\\end{bsparse}',\n 1: '\\\\left(${args[0]}\\\\right)'\n },\n unit: {\n 1: '\\\\left(${args[0]}\\\\right)',\n 2: '\\\\left(\\\\left(${args[0]}\\\\right)${args[1]}\\\\right)'\n }\n};\nexports.latexFunctions = latexFunctions;\nvar defaultTemplate = '\\\\mathrm{${name}}\\\\left(${args}\\\\right)';\nexports.defaultTemplate = defaultTemplate;\nvar latexUnits = {\n deg: '^\\\\circ'\n};\n\nfunction escapeLatex(string) {\n return (0, _escapeLatex.default)(string, {\n preserveFormatting: true\n });\n} // @param {string} name\n// @param {boolean} isUnit\n\n\nfunction toSymbol(name, isUnit) {\n isUnit = typeof isUnit === 'undefined' ? false : isUnit;\n\n if (isUnit) {\n if ((0, _object.hasOwnProperty)(latexUnits, name)) {\n return latexUnits[name];\n }\n\n return '\\\\mathrm{' + escapeLatex(name) + '}';\n }\n\n if ((0, _object.hasOwnProperty)(latexSymbols, name)) {\n return latexSymbols[name];\n }\n\n return escapeLatex(name);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.lruQueue = lruQueue;\n\n// (c) 2018, Mariusz Nowak\n// SPDX-License-Identifier: ISC\n// Derived from https://github.com/medikoo/lru-queue\nfunction lruQueue(limit) {\n var size = 0;\n var base = 1;\n var queue = Object.create(null);\n var map = Object.create(null);\n var index = 0;\n\n var del = function del(id) {\n var oldIndex = map[id];\n if (!oldIndex) return;\n delete queue[oldIndex];\n delete map[id];\n --size;\n if (base !== oldIndex) return;\n\n if (!size) {\n index = 0;\n base = 1;\n return;\n }\n\n while (!hasOwnProperty.call(queue, ++base)) {\n continue;\n }\n };\n\n limit = Math.abs(limit);\n return {\n hit: function hit(id) {\n var oldIndex = map[id];\n var nuIndex = ++index;\n queue[nuIndex] = id;\n map[id] = nuIndex;\n\n if (!oldIndex) {\n ++size;\n if (size <= limit) return undefined;\n id = queue[base];\n del(id);\n return id;\n }\n\n delete queue[oldIndex];\n if (base !== oldIndex) return undefined;\n\n while (!hasOwnProperty.call(queue, ++base)) {\n continue;\n }\n\n return undefined;\n },\n delete: del,\n clear: function clear() {\n size = index = 0;\n base = 1;\n queue = Object.create(null);\n map = Object.create(null);\n }\n };\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ObjectWrappingMap = void 0;\nexports.assign = assign;\nexports.createEmptyMap = createEmptyMap;\nexports.createMap = createMap;\nexports.isMap = isMap;\nexports.toObject = toObject;\n\nvar _classCallCheck2 = _interopRequireDefault(require(\"@babel/runtime/helpers/classCallCheck\"));\n\nvar _createClass2 = _interopRequireDefault(require(\"@babel/runtime/helpers/createClass\"));\n\nvar _customs = require(\"./customs.js\");\n\nvar _is = require(\"./is.js\");\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { 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 = it.call(o); }, 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\n/**\n * A map facade on a bare object.\n *\n * The small number of methods needed to implement a scope,\n * forwarding on to the SafeProperty functions. Over time, the codebase\n * will stop using this method, as all objects will be Maps, rather than\n * more security prone objects.\n */\nvar ObjectWrappingMap = /*#__PURE__*/function () {\n function ObjectWrappingMap(object) {\n (0, _classCallCheck2.default)(this, ObjectWrappingMap);\n this.wrappedObject = object;\n }\n\n (0, _createClass2.default)(ObjectWrappingMap, [{\n key: \"keys\",\n value: function keys() {\n return Object.keys(this.wrappedObject);\n }\n }, {\n key: \"get\",\n value: function get(key) {\n return (0, _customs.getSafeProperty)(this.wrappedObject, key);\n }\n }, {\n key: \"set\",\n value: function set(key, value) {\n (0, _customs.setSafeProperty)(this.wrappedObject, key, value);\n return this;\n }\n }, {\n key: \"has\",\n value: function has(key) {\n return (0, _customs.hasSafeProperty)(this.wrappedObject, key);\n }\n }]);\n return ObjectWrappingMap;\n}();\n/**\n * Creates an empty map, or whatever your platform's polyfill is.\n *\n * @returns an empty Map or Map like object.\n */\n\n\nexports.ObjectWrappingMap = ObjectWrappingMap;\n\nfunction createEmptyMap() {\n return new Map();\n}\n/**\n * Creates a Map from the given object.\n *\n * @param { Map | { [key: string]: unknown } | undefined } mapOrObject\n * @returns\n */\n\n\nfunction createMap(mapOrObject) {\n if (!mapOrObject) {\n return createEmptyMap();\n }\n\n if (isMap(mapOrObject)) {\n return mapOrObject;\n }\n\n if ((0, _is.isObject)(mapOrObject)) {\n return new ObjectWrappingMap(mapOrObject);\n }\n\n throw new Error('createMap can create maps from objects or Maps');\n}\n/**\n * Unwraps a map into an object.\n *\n * @param {Map} map\n * @returns { [key: string]: unknown }\n */\n\n\nfunction toObject(map) {\n if (map instanceof ObjectWrappingMap) {\n return map.wrappedObject;\n }\n\n var object = {};\n\n var _iterator = _createForOfIteratorHelper(map.keys()),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var key = _step.value;\n var value = map.get(key);\n (0, _customs.setSafeProperty)(object, key, value);\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n return object;\n}\n/**\n * Returns `true` if the passed object appears to be a Map (i.e. duck typing).\n *\n * Methods looked for are `get`, `set`, `keys` and `has`.\n *\n * @param {Map | object} object\n * @returns\n */\n\n\nfunction isMap(object) {\n // We can use the fast instanceof, or a slower duck typing check.\n // The duck typing method needs to cover enough methods to not be confused with DenseMatrix.\n if (!object) {\n return false;\n }\n\n return object instanceof Map || object instanceof ObjectWrappingMap || typeof object.set === 'function' && typeof object.get === 'function' && typeof object.keys === 'function' && typeof object.has === 'function';\n}\n/**\n * Copies the contents of key-value pairs from each `objects` in to `map`.\n *\n * Object is `objects` can be a `Map` or object.\n *\n * This is the `Map` analog to `Object.assign`.\n */\n\n\nfunction assign(map) {\n for (var _len = arguments.length, objects = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n objects[_key - 1] = arguments[_key];\n }\n\n for (var _i = 0, _objects = objects; _i < _objects.length; _i++) {\n var args = _objects[_i];\n\n if (!args) {\n continue;\n }\n\n if (isMap(args)) {\n var _iterator2 = _createForOfIteratorHelper(args.keys()),\n _step2;\n\n try {\n for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n var key = _step2.value;\n map.set(key, args.get(key));\n }\n } catch (err) {\n _iterator2.e(err);\n } finally {\n _iterator2.f();\n }\n } else if ((0, _is.isObject)(args)) {\n for (var _i2 = 0, _Object$keys = Object.keys(args); _i2 < _Object$keys.length; _i2++) {\n var _key2 = _Object$keys[_i2];\n map.set(_key2, args[_key2]);\n }\n }\n }\n\n return map;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.noBignumber = noBignumber;\nexports.noFraction = noFraction;\nexports.noIndex = noIndex;\nexports.noMatrix = noMatrix;\nexports.noSubset = noSubset;\n\nfunction noBignumber() {\n throw new Error('No \"bignumber\" implementation available');\n}\n\nfunction noFraction() {\n throw new Error('No \"fraction\" implementation available');\n}\n\nfunction noMatrix() {\n throw new Error('No \"matrix\" implementation available');\n}\n\nfunction noIndex() {\n throw new Error('No \"index\" implementation available');\n}\n\nfunction noSubset() {\n throw new Error('No \"matrix\" implementation available');\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cbrt = exports.atanh = exports.asinh = exports.acosh = exports.DBL_EPSILON = void 0;\nexports.copysign = copysign;\nexports.cosh = void 0;\nexports.digits = digits;\nexports.expm1 = void 0;\nexports.format = format;\nexports.isInteger = isInteger;\nexports.log2 = exports.log1p = exports.log10 = void 0;\nexports.nearlyEqual = nearlyEqual;\nexports.roundDigits = roundDigits;\nexports.sinh = exports.sign = void 0;\nexports.splitNumber = splitNumber;\nexports.tanh = void 0;\nexports.toEngineering = toEngineering;\nexports.toExponential = toExponential;\nexports.toFixed = toFixed;\nexports.toPrecision = toPrecision;\n\nvar _is = require(\"./is.js\");\n\n/**\n * @typedef {{sign: '+' | '-' | '', coefficients: number[], exponent: number}} SplitValue\n */\n\n/**\n * Check if a number is integer\n * @param {number | boolean} value\n * @return {boolean} isInteger\n */\nfunction isInteger(value) {\n if (typeof value === 'boolean') {\n return true;\n }\n\n return isFinite(value) ? value === Math.round(value) : false;\n}\n/**\n * Calculate the sign of a number\n * @param {number} x\n * @returns {number}\n */\n\n\nvar sign = /* #__PURE__ */Math.sign || function (x) {\n if (x > 0) {\n return 1;\n } else if (x < 0) {\n return -1;\n } else {\n return 0;\n }\n};\n/**\n * Calculate the base-2 logarithm of a number\n * @param {number} x\n * @returns {number}\n */\n\n\nexports.sign = sign;\n\nvar log2 = /* #__PURE__ */Math.log2 || function log2(x) {\n return Math.log(x) / Math.LN2;\n};\n/**\n * Calculate the base-10 logarithm of a number\n * @param {number} x\n * @returns {number}\n */\n\n\nexports.log2 = log2;\n\nvar log10 = /* #__PURE__ */Math.log10 || function log10(x) {\n return Math.log(x) / Math.LN10;\n};\n/**\n * Calculate the natural logarithm of a number + 1\n * @param {number} x\n * @returns {number}\n */\n\n\nexports.log10 = log10;\n\nvar log1p = /* #__PURE__ */Math.log1p || function (x) {\n return Math.log(x + 1);\n};\n/**\n * Calculate cubic root for a number\n *\n * Code from es6-shim.js:\n * https://github.com/paulmillr/es6-shim/blob/master/es6-shim.js#L1564-L1577\n *\n * @param {number} x\n * @returns {number} Returns the cubic root of x\n */\n\n\nexports.log1p = log1p;\n\nvar cbrt = /* #__PURE__ */Math.cbrt || function cbrt(x) {\n if (x === 0) {\n return x;\n }\n\n var negate = x < 0;\n var result;\n\n if (negate) {\n x = -x;\n }\n\n if (isFinite(x)) {\n result = Math.exp(Math.log(x) / 3); // from https://en.wikipedia.org/wiki/Cube_root#Numerical_methods\n\n result = (x / (result * result) + 2 * result) / 3;\n } else {\n result = x;\n }\n\n return negate ? -result : result;\n};\n/**\n * Calculates exponentiation minus 1\n * @param {number} x\n * @return {number} res\n */\n\n\nexports.cbrt = cbrt;\n\nvar expm1 = /* #__PURE__ */Math.expm1 || function expm1(x) {\n return x >= 2e-4 || x <= -2e-4 ? Math.exp(x) - 1 : x + x * x / 2 + x * x * x / 6;\n};\n/**\n * Formats a number in a given base\n * @param {number} n\n * @param {number} base\n * @param {number} size\n * @returns {string}\n */\n\n\nexports.expm1 = expm1;\n\nfunction formatNumberToBase(n, base, size) {\n var prefixes = {\n 2: '0b',\n 8: '0o',\n 16: '0x'\n };\n var prefix = prefixes[base];\n var suffix = '';\n\n if (size) {\n if (size < 1) {\n throw new Error('size must be in greater than 0');\n }\n\n if (!isInteger(size)) {\n throw new Error('size must be an integer');\n }\n\n if (n > Math.pow(2, size - 1) - 1 || n < -Math.pow(2, size - 1)) {\n throw new Error(\"Value must be in range [-2^\".concat(size - 1, \", 2^\").concat(size - 1, \"-1]\"));\n }\n\n if (!isInteger(n)) {\n throw new Error('Value must be an integer');\n }\n\n if (n < 0) {\n n = n + Math.pow(2, size);\n }\n\n suffix = \"i\".concat(size);\n }\n\n var sign = '';\n\n if (n < 0) {\n n = -n;\n sign = '-';\n }\n\n return \"\".concat(sign).concat(prefix).concat(n.toString(base)).concat(suffix);\n}\n/**\n * Convert a number to a formatted string representation.\n *\n * Syntax:\n *\n * format(value)\n * format(value, options)\n * format(value, precision)\n * format(value, fn)\n *\n * Where:\n *\n * {number} value The value to be formatted\n * {Object} options An object with formatting options. Available options:\n * {string} notation\n * Number notation. Choose from:\n * 'fixed' Always use regular number notation.\n * For example '123.40' and '14000000'\n * 'exponential' Always use exponential notation.\n * For example '1.234e+2' and '1.4e+7'\n * 'engineering' Always use engineering notation.\n * For example '123.4e+0' and '14.0e+6'\n * 'auto' (default) Regular number notation for numbers\n * having an absolute value between\n * `lowerExp` and `upperExp` bounds, and\n * uses exponential notation elsewhere.\n * Lower bound is included, upper bound\n * is excluded.\n * For example '123.4' and '1.4e7'.\n * 'bin', 'oct, or\n * 'hex' Format the number using binary, octal,\n * or hexadecimal notation.\n * For example '0b1101' and '0x10fe'.\n * {number} wordSize The word size in bits to use for formatting\n * in binary, octal, or hexadecimal notation.\n * To be used only with 'bin', 'oct', or 'hex'\n * values for 'notation' option. When this option\n * is defined the value is formatted as a signed\n * twos complement integer of the given word size\n * and the size suffix is appended to the output.\n * For example\n * format(-1, {notation: 'hex', wordSize: 8}) === '0xffi8'.\n * Default value is undefined.\n * {number} precision A number between 0 and 16 to round\n * the digits of the number.\n * In case of notations 'exponential',\n * 'engineering', and 'auto',\n * `precision` defines the total\n * number of significant digits returned.\n * In case of notation 'fixed',\n * `precision` defines the number of\n * significant digits after the decimal\n * point.\n * `precision` is undefined by default,\n * not rounding any digits.\n * {number} lowerExp Exponent determining the lower boundary\n * for formatting a value with an exponent\n * when `notation='auto`.\n * Default value is `-3`.\n * {number} upperExp Exponent determining the upper boundary\n * for formatting a value with an exponent\n * when `notation='auto`.\n * Default value is `5`.\n * {Function} fn A custom formatting function. Can be used to override the\n * built-in notations. Function `fn` is called with `value` as\n * parameter and must return a string. Is useful for example to\n * format all values inside a matrix in a particular way.\n *\n * Examples:\n *\n * format(6.4) // '6.4'\n * format(1240000) // '1.24e6'\n * format(1/3) // '0.3333333333333333'\n * format(1/3, 3) // '0.333'\n * format(21385, 2) // '21000'\n * format(12.071, {notation: 'fixed'}) // '12'\n * format(2.3, {notation: 'fixed', precision: 2}) // '2.30'\n * format(52.8, {notation: 'exponential'}) // '5.28e+1'\n * format(12345678, {notation: 'engineering'}) // '12.345678e+6'\n *\n * @param {number} value\n * @param {Object | Function | number} [options]\n * @return {string} str The formatted value\n */\n\n\nfunction format(value, options) {\n if (typeof options === 'function') {\n // handle format(value, fn)\n return options(value);\n } // handle special cases\n\n\n if (value === Infinity) {\n return 'Infinity';\n } else if (value === -Infinity) {\n return '-Infinity';\n } else if (isNaN(value)) {\n return 'NaN';\n } // default values for options\n\n\n var notation = 'auto';\n var precision;\n var wordSize;\n\n if (options) {\n // determine notation from options\n if (options.notation) {\n notation = options.notation;\n } // determine precision from options\n\n\n if ((0, _is.isNumber)(options)) {\n precision = options;\n } else if ((0, _is.isNumber)(options.precision)) {\n precision = options.precision;\n }\n\n if (options.wordSize) {\n wordSize = options.wordSize;\n\n if (typeof wordSize !== 'number') {\n throw new Error('Option \"wordSize\" must be a number');\n }\n }\n } // handle the various notations\n\n\n switch (notation) {\n case 'fixed':\n return toFixed(value, precision);\n\n case 'exponential':\n return toExponential(value, precision);\n\n case 'engineering':\n return toEngineering(value, precision);\n\n case 'bin':\n return formatNumberToBase(value, 2, wordSize);\n\n case 'oct':\n return formatNumberToBase(value, 8, wordSize);\n\n case 'hex':\n return formatNumberToBase(value, 16, wordSize);\n\n case 'auto':\n // remove trailing zeros after the decimal point\n return toPrecision(value, precision, options && options).replace(/((\\.\\d*?)(0+))($|e)/, function () {\n var digits = arguments[2];\n var e = arguments[4];\n return digits !== '.' ? digits + e : e;\n });\n\n default:\n throw new Error('Unknown notation \"' + notation + '\". ' + 'Choose \"auto\", \"exponential\", \"fixed\", \"bin\", \"oct\", or \"hex.');\n }\n}\n/**\n * Split a number into sign, coefficients, and exponent\n * @param {number | string} value\n * @return {SplitValue}\n * Returns an object containing sign, coefficients, and exponent\n */\n\n\nfunction splitNumber(value) {\n // parse the input value\n var match = String(value).toLowerCase().match(/^(-?)(\\d+\\.?\\d*)(e([+-]?\\d+))?$/);\n\n if (!match) {\n throw new SyntaxError('Invalid number ' + value);\n }\n\n var sign = match[1];\n var digits = match[2];\n var exponent = parseFloat(match[4] || '0');\n var dot = digits.indexOf('.');\n exponent += dot !== -1 ? dot - 1 : digits.length - 1;\n var coefficients = digits.replace('.', '') // remove the dot (must be removed before removing leading zeros)\n .replace(/^0*/, function (zeros) {\n // remove leading zeros, add their count to the exponent\n exponent -= zeros.length;\n return '';\n }).replace(/0*$/, '') // remove trailing zeros\n .split('').map(function (d) {\n return parseInt(d);\n });\n\n if (coefficients.length === 0) {\n coefficients.push(0);\n exponent++;\n }\n\n return {\n sign: sign,\n coefficients: coefficients,\n exponent: exponent\n };\n}\n/**\n * Format a number in engineering notation. Like '1.23e+6', '2.3e+0', '3.500e-3'\n * @param {number | string} value\n * @param {number} [precision] Optional number of significant figures to return.\n */\n\n\nfunction toEngineering(value, precision) {\n if (isNaN(value) || !isFinite(value)) {\n return String(value);\n }\n\n var split = splitNumber(value);\n var rounded = roundDigits(split, precision);\n var e = rounded.exponent;\n var c = rounded.coefficients; // find nearest lower multiple of 3 for exponent\n\n var newExp = e % 3 === 0 ? e : e < 0 ? e - 3 - e % 3 : e - e % 3;\n\n if ((0, _is.isNumber)(precision)) {\n // add zeroes to give correct sig figs\n while (precision > c.length || e - newExp + 1 > c.length) {\n c.push(0);\n }\n } else {\n // concatenate coefficients with necessary zeros\n // add zeros if necessary (for example: 1e+8 -> 100e+6)\n var missingZeros = Math.abs(e - newExp) - (c.length - 1);\n\n for (var i = 0; i < missingZeros; i++) {\n c.push(0);\n }\n } // find difference in exponents\n\n\n var expDiff = Math.abs(e - newExp);\n var decimalIdx = 1; // push decimal index over by expDiff times\n\n while (expDiff > 0) {\n decimalIdx++;\n expDiff--;\n } // if all coefficient values are zero after the decimal point and precision is unset, don't add a decimal value.\n // otherwise concat with the rest of the coefficients\n\n\n var decimals = c.slice(decimalIdx).join('');\n var decimalVal = (0, _is.isNumber)(precision) && decimals.length || decimals.match(/[1-9]/) ? '.' + decimals : '';\n var str = c.slice(0, decimalIdx).join('') + decimalVal + 'e' + (e >= 0 ? '+' : '') + newExp.toString();\n return rounded.sign + str;\n}\n/**\n * Format a number with fixed notation.\n * @param {number | string} value\n * @param {number} [precision=undefined] Optional number of decimals after the\n * decimal point. null by default.\n */\n\n\nfunction toFixed(value, precision) {\n if (isNaN(value) || !isFinite(value)) {\n return String(value);\n }\n\n var splitValue = splitNumber(value);\n var rounded = typeof precision === 'number' ? roundDigits(splitValue, splitValue.exponent + 1 + precision) : splitValue;\n var c = rounded.coefficients;\n var p = rounded.exponent + 1; // exponent may have changed\n // append zeros if needed\n\n var pp = p + (precision || 0);\n\n if (c.length < pp) {\n c = c.concat(zeros(pp - c.length));\n } // prepend zeros if needed\n\n\n if (p < 0) {\n c = zeros(-p + 1).concat(c);\n p = 1;\n } // insert a dot if needed\n\n\n if (p < c.length) {\n c.splice(p, 0, p === 0 ? '0.' : '.');\n }\n\n return rounded.sign + c.join('');\n}\n/**\n * Format a number in exponential notation. Like '1.23e+5', '2.3e+0', '3.500e-3'\n * @param {number | string} value\n * @param {number} [precision] Number of digits in formatted output.\n * If not provided, the maximum available digits\n * is used.\n */\n\n\nfunction toExponential(value, precision) {\n if (isNaN(value) || !isFinite(value)) {\n return String(value);\n } // round if needed, else create a clone\n\n\n var split = splitNumber(value);\n var rounded = precision ? roundDigits(split, precision) : split;\n var c = rounded.coefficients;\n var e = rounded.exponent; // append zeros if needed\n\n if (c.length < precision) {\n c = c.concat(zeros(precision - c.length));\n } // format as `C.CCCe+EEE` or `C.CCCe-EEE`\n\n\n var first = c.shift();\n return rounded.sign + first + (c.length > 0 ? '.' + c.join('') : '') + 'e' + (e >= 0 ? '+' : '') + e;\n}\n/**\n * Format a number with a certain precision\n * @param {number | string} value\n * @param {number} [precision=undefined] Optional number of digits.\n * @param {{lowerExp: number | undefined, upperExp: number | undefined}} [options]\n * By default:\n * lowerExp = -3 (incl)\n * upper = +5 (excl)\n * @return {string}\n */\n\n\nfunction toPrecision(value, precision, options) {\n if (isNaN(value) || !isFinite(value)) {\n return String(value);\n } // determine lower and upper bound for exponential notation.\n\n\n var lowerExp = options && options.lowerExp !== undefined ? options.lowerExp : -3;\n var upperExp = options && options.upperExp !== undefined ? options.upperExp : 5;\n var split = splitNumber(value);\n var rounded = precision ? roundDigits(split, precision) : split;\n\n if (rounded.exponent < lowerExp || rounded.exponent >= upperExp) {\n // exponential notation\n return toExponential(value, precision);\n } else {\n var c = rounded.coefficients;\n var e = rounded.exponent; // append trailing zeros\n\n if (c.length < precision) {\n c = c.concat(zeros(precision - c.length));\n } // append trailing zeros\n // TODO: simplify the next statement\n\n\n c = c.concat(zeros(e - c.length + 1 + (c.length < precision ? precision - c.length : 0))); // prepend zeros\n\n c = zeros(-e).concat(c);\n var dot = e > 0 ? e : 0;\n\n if (dot < c.length - 1) {\n c.splice(dot + 1, 0, '.');\n }\n\n return rounded.sign + c.join('');\n }\n}\n/**\n * Round the number of digits of a number *\n * @param {SplitValue} split A value split with .splitNumber(value)\n * @param {number} precision A positive integer\n * @return {SplitValue}\n * Returns an object containing sign, coefficients, and exponent\n * with rounded digits\n */\n\n\nfunction roundDigits(split, precision) {\n // create a clone\n var rounded = {\n sign: split.sign,\n coefficients: split.coefficients,\n exponent: split.exponent\n };\n var c = rounded.coefficients; // prepend zeros if needed\n\n while (precision <= 0) {\n c.unshift(0);\n rounded.exponent++;\n precision++;\n }\n\n if (c.length > precision) {\n var removed = c.splice(precision, c.length - precision);\n\n if (removed[0] >= 5) {\n var i = precision - 1;\n c[i]++;\n\n while (c[i] === 10) {\n c.pop();\n\n if (i === 0) {\n c.unshift(0);\n rounded.exponent++;\n i++;\n }\n\n i--;\n c[i]++;\n }\n }\n }\n\n return rounded;\n}\n/**\n * Create an array filled with zeros.\n * @param {number} length\n * @return {Array}\n */\n\n\nfunction zeros(length) {\n var arr = [];\n\n for (var i = 0; i < length; i++) {\n arr.push(0);\n }\n\n return arr;\n}\n/**\n * Count the number of significant digits of a number.\n *\n * For example:\n * 2.34 returns 3\n * 0.0034 returns 2\n * 120.5e+30 returns 4\n *\n * @param {number} value\n * @return {number} digits Number of significant digits\n */\n\n\nfunction digits(value) {\n return value.toExponential().replace(/e.*$/, '') // remove exponential notation\n .replace(/^0\\.?0*|\\./, '') // remove decimal point and leading zeros\n .length;\n}\n/**\n * Minimum number added to one that makes the result different than one\n */\n\n\nvar DBL_EPSILON = Number.EPSILON || 2.2204460492503130808472633361816E-16;\n/**\n * Compares two floating point numbers.\n * @param {number} x First value to compare\n * @param {number} y Second value to compare\n * @param {number} [epsilon] The maximum relative difference between x and y\n * If epsilon is undefined or null, the function will\n * test whether x and y are exactly equal.\n * @return {boolean} whether the two numbers are nearly equal\n*/\n\nexports.DBL_EPSILON = DBL_EPSILON;\n\nfunction nearlyEqual(x, y, epsilon) {\n // if epsilon is null or undefined, test whether x and y are exactly equal\n if (epsilon === null || epsilon === undefined) {\n return x === y;\n }\n\n if (x === y) {\n return true;\n } // NaN\n\n\n if (isNaN(x) || isNaN(y)) {\n return false;\n } // at this point x and y should be finite\n\n\n if (isFinite(x) && isFinite(y)) {\n // check numbers are very close, needed when comparing numbers near zero\n var diff = Math.abs(x - y);\n\n if (diff < DBL_EPSILON) {\n return true;\n } else {\n // use relative error\n return diff <= Math.max(Math.abs(x), Math.abs(y)) * epsilon;\n }\n } // Infinite and Number or negative Infinite and positive Infinite cases\n\n\n return false;\n}\n/**\n * Calculate the hyperbolic arccos of a number\n * @param {number} x\n * @return {number}\n */\n\n\nvar acosh = Math.acosh || function (x) {\n return Math.log(Math.sqrt(x * x - 1) + x);\n};\n\nexports.acosh = acosh;\n\nvar asinh = Math.asinh || function (x) {\n return Math.log(Math.sqrt(x * x + 1) + x);\n};\n/**\n * Calculate the hyperbolic arctangent of a number\n * @param {number} x\n * @return {number}\n */\n\n\nexports.asinh = asinh;\n\nvar atanh = Math.atanh || function (x) {\n return Math.log((1 + x) / (1 - x)) / 2;\n};\n/**\n * Calculate the hyperbolic cosine of a number\n * @param {number} x\n * @returns {number}\n */\n\n\nexports.atanh = atanh;\n\nvar cosh = Math.cosh || function (x) {\n return (Math.exp(x) + Math.exp(-x)) / 2;\n};\n/**\n * Calculate the hyperbolic sine of a number\n * @param {number} x\n * @returns {number}\n */\n\n\nexports.cosh = cosh;\n\nvar sinh = Math.sinh || function (x) {\n return (Math.exp(x) - Math.exp(-x)) / 2;\n};\n/**\n * Calculate the hyperbolic tangent of a number\n * @param {number} x\n * @returns {number}\n */\n\n\nexports.sinh = sinh;\n\nvar tanh = Math.tanh || function (x) {\n var e = Math.exp(2 * x);\n return (e - 1) / (e + 1);\n};\n/**\n * Returns a value with the magnitude of x and the sign of y.\n * @param {number} x\n * @param {number} y\n * @returns {number}\n */\n\n\nexports.tanh = tanh;\n\nfunction copysign(x, y) {\n var signx = x > 0 ? true : x < 0 ? false : 1 / x === Infinity;\n var signy = y > 0 ? true : y < 0 ? false : 1 / y === Infinity;\n return signx ^ signy ? -x : x;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.canDefineProperty = canDefineProperty;\nexports.clone = clone;\nexports.deepExtend = deepExtend;\nexports.deepFlatten = deepFlatten;\nexports.deepStrictEqual = deepStrictEqual;\nexports.extend = extend;\nexports.get = get;\nexports.hasOwnProperty = hasOwnProperty;\nexports.isLegacyFactory = isLegacyFactory;\nexports.lazy = lazy;\nexports.mapObject = mapObject;\nexports.pick = pick;\nexports.pickShallow = pickShallow;\nexports.set = set;\nexports.traverse = traverse;\nexports.values = values;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _is = require(\"./is.js\");\n\n/**\n * Clone an object\n *\n * clone(x)\n *\n * Can clone any primitive type, array, and object.\n * If x has a function clone, this function will be invoked to clone the object.\n *\n * @param {*} x\n * @return {*} clone\n */\nfunction clone(x) {\n var type = (0, _typeof2.default)(x); // immutable primitive types\n\n if (type === 'number' || type === 'string' || type === 'boolean' || x === null || x === undefined) {\n return x;\n } // use clone function of the object when available\n\n\n if (typeof x.clone === 'function') {\n return x.clone();\n } // array\n\n\n if (Array.isArray(x)) {\n return x.map(function (value) {\n return clone(value);\n });\n }\n\n if (x instanceof Date) return new Date(x.valueOf());\n if ((0, _is.isBigNumber)(x)) return x; // bignumbers are immutable\n\n if (x instanceof RegExp) throw new TypeError('Cannot clone ' + x); // TODO: clone a RegExp\n // object\n\n return mapObject(x, clone);\n}\n/**\n * Apply map to all properties of an object\n * @param {Object} object\n * @param {function} callback\n * @return {Object} Returns a copy of the object with mapped properties\n */\n\n\nfunction mapObject(object, callback) {\n var clone = {};\n\n for (var key in object) {\n if (hasOwnProperty(object, key)) {\n clone[key] = callback(object[key]);\n }\n }\n\n return clone;\n}\n/**\n * Extend object a with the properties of object b\n * @param {Object} a\n * @param {Object} b\n * @return {Object} a\n */\n\n\nfunction extend(a, b) {\n for (var prop in b) {\n if (hasOwnProperty(b, prop)) {\n a[prop] = b[prop];\n }\n }\n\n return a;\n}\n/**\n * Deep extend an object a with the properties of object b\n * @param {Object} a\n * @param {Object} b\n * @returns {Object}\n */\n\n\nfunction deepExtend(a, b) {\n // TODO: add support for Arrays to deepExtend\n if (Array.isArray(b)) {\n throw new TypeError('Arrays are not supported by deepExtend');\n }\n\n for (var prop in b) {\n // We check against prop not being in Object.prototype or Function.prototype\n // to prevent polluting for example Object.__proto__.\n if (hasOwnProperty(b, prop) && !(prop in Object.prototype) && !(prop in Function.prototype)) {\n if (b[prop] && b[prop].constructor === Object) {\n if (a[prop] === undefined) {\n a[prop] = {};\n }\n\n if (a[prop] && a[prop].constructor === Object) {\n deepExtend(a[prop], b[prop]);\n } else {\n a[prop] = b[prop];\n }\n } else if (Array.isArray(b[prop])) {\n throw new TypeError('Arrays are not supported by deepExtend');\n } else {\n a[prop] = b[prop];\n }\n }\n }\n\n return a;\n}\n/**\n * Deep test equality of all fields in two pairs of arrays or objects.\n * Compares values and functions strictly (ie. 2 is not the same as '2').\n * @param {Array | Object} a\n * @param {Array | Object} b\n * @returns {boolean}\n */\n\n\nfunction deepStrictEqual(a, b) {\n var prop, i, len;\n\n if (Array.isArray(a)) {\n if (!Array.isArray(b)) {\n return false;\n }\n\n if (a.length !== b.length) {\n return false;\n }\n\n for (i = 0, len = a.length; i < len; i++) {\n if (!deepStrictEqual(a[i], b[i])) {\n return false;\n }\n }\n\n return true;\n } else if (typeof a === 'function') {\n return a === b;\n } else if (a instanceof Object) {\n if (Array.isArray(b) || !(b instanceof Object)) {\n return false;\n }\n\n for (prop in a) {\n // noinspection JSUnfilteredForInLoop\n if (!(prop in b) || !deepStrictEqual(a[prop], b[prop])) {\n return false;\n }\n }\n\n for (prop in b) {\n // noinspection JSUnfilteredForInLoop\n if (!(prop in a)) {\n return false;\n }\n }\n\n return true;\n } else {\n return a === b;\n }\n}\n/**\n * Recursively flatten a nested object.\n * @param {Object} nestedObject\n * @return {Object} Returns the flattened object\n */\n\n\nfunction deepFlatten(nestedObject) {\n var flattenedObject = {};\n\n _deepFlatten(nestedObject, flattenedObject);\n\n return flattenedObject;\n} // helper function used by deepFlatten\n\n\nfunction _deepFlatten(nestedObject, flattenedObject) {\n for (var prop in nestedObject) {\n if (hasOwnProperty(nestedObject, prop)) {\n var value = nestedObject[prop];\n\n if ((0, _typeof2.default)(value) === 'object' && value !== null) {\n _deepFlatten(value, flattenedObject);\n } else {\n flattenedObject[prop] = value;\n }\n }\n }\n}\n/**\n * Test whether the current JavaScript engine supports Object.defineProperty\n * @returns {boolean} returns true if supported\n */\n\n\nfunction canDefineProperty() {\n // test needed for broken IE8 implementation\n try {\n if (Object.defineProperty) {\n Object.defineProperty({}, 'x', {\n get: function get() {\n return null;\n }\n });\n return true;\n }\n } catch (e) {}\n\n return false;\n}\n/**\n * Attach a lazy loading property to a constant.\n * The given function `fn` is called once when the property is first requested.\n *\n * @param {Object} object Object where to add the property\n * @param {string} prop Property name\n * @param {Function} valueResolver Function returning the property value. Called\n * without arguments.\n */\n\n\nfunction lazy(object, prop, valueResolver) {\n var _uninitialized = true;\n\n var _value;\n\n Object.defineProperty(object, prop, {\n get: function get() {\n if (_uninitialized) {\n _value = valueResolver();\n _uninitialized = false;\n }\n\n return _value;\n },\n set: function set(value) {\n _value = value;\n _uninitialized = false;\n },\n configurable: true,\n enumerable: true\n });\n}\n/**\n * Traverse a path into an object.\n * When a namespace is missing, it will be created\n * @param {Object} object\n * @param {string | string[]} path A dot separated string like 'name.space'\n * @return {Object} Returns the object at the end of the path\n */\n\n\nfunction traverse(object, path) {\n if (path && typeof path === 'string') {\n return traverse(object, path.split('.'));\n }\n\n var obj = object;\n\n if (path) {\n for (var i = 0; i < path.length; i++) {\n var key = path[i];\n\n if (!(key in obj)) {\n obj[key] = {};\n }\n\n obj = obj[key];\n }\n }\n\n return obj;\n}\n/**\n * A safe hasOwnProperty\n * @param {Object} object\n * @param {string} property\n */\n\n\nfunction hasOwnProperty(object, property) {\n return object && Object.hasOwnProperty.call(object, property);\n}\n/**\n * Test whether an object is a factory. a factory has fields:\n *\n * - factory: function (type: Object, config: Object, load: function, typed: function [, math: Object]) (required)\n * - name: string (optional)\n * - path: string A dot separated path (optional)\n * - math: boolean If true (false by default), the math namespace is passed\n * as fifth argument of the factory function\n *\n * @param {*} object\n * @returns {boolean}\n */\n\n\nfunction isLegacyFactory(object) {\n return object && typeof object.factory === 'function';\n}\n/**\n * Get a nested property from an object\n * @param {Object} object\n * @param {string | string[]} path\n * @returns {Object}\n */\n\n\nfunction get(object, path) {\n if (typeof path === 'string') {\n if (isPath(path)) {\n return get(object, path.split('.'));\n } else {\n return object[path];\n }\n }\n\n var child = object;\n\n for (var i = 0; i < path.length; i++) {\n var key = path[i];\n child = child ? child[key] : undefined;\n }\n\n return child;\n}\n/**\n * Set a nested property in an object\n * Mutates the object itself\n * If the path doesn't exist, it will be created\n * @param {Object} object\n * @param {string | string[]} path\n * @param {*} value\n * @returns {Object}\n */\n\n\nfunction set(object, path, value) {\n if (typeof path === 'string') {\n if (isPath(path)) {\n return set(object, path.split('.'), value);\n } else {\n object[path] = value;\n return object;\n }\n }\n\n var child = object;\n\n for (var i = 0; i < path.length - 1; i++) {\n var key = path[i];\n\n if (child[key] === undefined) {\n child[key] = {};\n }\n\n child = child[key];\n }\n\n if (path.length > 0) {\n var lastKey = path[path.length - 1];\n child[lastKey] = value;\n }\n\n return object;\n}\n/**\n * Create an object composed of the picked object properties\n * @param {Object} object\n * @param {string[]} properties\n * @param {function} [transform] Optional value to transform a value when picking it\n * @return {Object}\n */\n\n\nfunction pick(object, properties, transform) {\n var copy = {};\n\n for (var i = 0; i < properties.length; i++) {\n var key = properties[i];\n var value = get(object, key);\n\n if (value !== undefined) {\n set(copy, key, transform ? transform(value, key) : value);\n }\n }\n\n return copy;\n}\n/**\n * Shallow version of pick, creating an object composed of the picked object properties\n * but not for nested properties\n * @param {Object} object\n * @param {string[]} properties\n * @return {Object}\n */\n\n\nfunction pickShallow(object, properties) {\n var copy = {};\n\n for (var i = 0; i < properties.length; i++) {\n var key = properties[i];\n var value = object[key];\n\n if (value !== undefined) {\n copy[key] = value;\n }\n }\n\n return copy;\n}\n\nfunction values(object) {\n return Object.keys(object).map(function (key) {\n return object[key];\n });\n} // helper function to test whether a string contains a path like 'user.name'\n\n\nfunction isPath(str) {\n return str.indexOf('.') !== -1;\n}","\"use strict\";\n\n// TODO: remove these polyfills as soon as we have a build process that transpiles the code to ES5\n// Polyfill for IE 11 (Number.isFinite is used in `complex.js`)\n// source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/isFinite\nNumber.isFinite = Number.isFinite || function (value) {\n return typeof value === 'number' && isFinite(value);\n}; // Polyfill for IE 11\n// source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/isNaN\n\n\nNumber.isNaN = Number.isNaN || function (value) {\n return value !== value; // eslint-disable-line no-self-compare\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.product = product;\n\n/** @param {number} i\n * @param {number} n\n * @returns {number} product of i to n\n */\nfunction product(i, n) {\n if (n < i) {\n return 1;\n }\n\n if (n === i) {\n return n;\n }\n\n var half = n + i >> 1; // divide (n + i) by 2 and truncate to integer\n\n return product(i, half) * product(half + 1, n);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createSubScope = createSubScope;\n\nvar _map = require(\"./map.js\");\n\n/**\n * Create a new scope which can access the parent scope,\n * but does not affect it when written. This is suitable for variable definitions\n * within a block node, or function definition.\n *\n * If parent scope has a createSubScope method, it delegates to that. Otherwise,\n * creates an empty map, and copies the parent scope to it, adding in\n * the remaining `args`.\n *\n * @param {Map} parentScope\n * @param {...any} args\n * @returns {Map}\n */\nfunction createSubScope(parentScope) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n if (typeof parentScope.createSubScope === 'function') {\n return _map.assign.apply(void 0, [parentScope.createSubScope()].concat(args));\n }\n\n return _map.assign.apply(void 0, [(0, _map.createEmptyMap)(), parentScope].concat(args));\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.compareText = compareText;\nexports.endsWith = endsWith;\nexports.escape = escape;\nexports.format = format;\nexports.stringify = stringify;\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _is = require(\"./is.js\");\n\nvar _number = require(\"./number.js\");\n\nvar _formatter = require(\"./bignumber/formatter.js\");\n\n/**\n * Check if a text ends with a certain string.\n * @param {string} text\n * @param {string} search\n */\nfunction endsWith(text, search) {\n var start = text.length - search.length;\n var end = text.length;\n return text.substring(start, end) === search;\n}\n/**\n * Format a value of any type into a string.\n *\n * Usage:\n * math.format(value)\n * math.format(value, precision)\n * math.format(value, options)\n *\n * When value is a function:\n *\n * - When the function has a property `syntax`, it returns this\n * syntax description.\n * - In other cases, a string `'function'` is returned.\n *\n * When `value` is an Object:\n *\n * - When the object contains a property `format` being a function, this\n * function is invoked as `value.format(options)` and the result is returned.\n * - When the object has its own `toString` method, this method is invoked\n * and the result is returned.\n * - In other cases the function will loop over all object properties and\n * return JSON object notation like '{\"a\": 2, \"b\": 3}'.\n *\n * Example usage:\n * math.format(2/7) // '0.2857142857142857'\n * math.format(math.pi, 3) // '3.14'\n * math.format(new Complex(2, 3)) // '2 + 3i'\n * math.format('hello') // '\"hello\"'\n *\n * @param {*} value Value to be stringified\n * @param {Object | number | Function} [options]\n * Formatting options. See src/utils/number.js:format for a\n * description of the available options controlling number output.\n * This generic \"format\" also supports the option property `truncate: NN`\n * giving the maximum number NN of characters to return (if there would\n * have been more, they are deleted and replaced by an ellipsis).\n * @return {string} str\n */\n\n\nfunction format(value, options) {\n var result = _format(value, options);\n\n if (options && (0, _typeof2.default)(options) === 'object' && 'truncate' in options && result.length > options.truncate) {\n return result.substring(0, options.truncate - 3) + '...';\n }\n\n return result;\n}\n\nfunction _format(value, options) {\n if (typeof value === 'number') {\n return (0, _number.format)(value, options);\n }\n\n if ((0, _is.isBigNumber)(value)) {\n return (0, _formatter.format)(value, options);\n } // note: we use unsafe duck-typing here to check for Fractions, this is\n // ok here since we're only invoking toString or concatenating its values\n\n\n if (looksLikeFraction(value)) {\n if (!options || options.fraction !== 'decimal') {\n // output as ratio, like '1/3'\n return value.s * value.n + '/' + value.d;\n } else {\n // output as decimal, like '0.(3)'\n return value.toString();\n }\n }\n\n if (Array.isArray(value)) {\n return formatArray(value, options);\n }\n\n if ((0, _is.isString)(value)) {\n return '\"' + value + '\"';\n }\n\n if (typeof value === 'function') {\n return value.syntax ? String(value.syntax) : 'function';\n }\n\n if (value && (0, _typeof2.default)(value) === 'object') {\n if (typeof value.format === 'function') {\n return value.format(options);\n } else if (value && value.toString(options) !== {}.toString()) {\n // this object has a non-native toString method, use that one\n return value.toString(options);\n } else {\n var entries = Object.keys(value).map(function (key) {\n return '\"' + key + '\": ' + format(value[key], options);\n });\n return '{' + entries.join(', ') + '}';\n }\n }\n\n return String(value);\n}\n/**\n * Stringify a value into a string enclosed in double quotes.\n * Unescaped double quotes and backslashes inside the value are escaped.\n * @param {*} value\n * @return {string}\n */\n\n\nfunction stringify(value) {\n var text = String(value);\n var escaped = '';\n var i = 0;\n\n while (i < text.length) {\n var c = text.charAt(i);\n\n if (c === '\\\\') {\n escaped += c;\n i++;\n c = text.charAt(i);\n\n if (c === '' || '\"\\\\/bfnrtu'.indexOf(c) === -1) {\n escaped += '\\\\'; // no valid escape character -> escape it\n }\n\n escaped += c;\n } else if (c === '\"') {\n escaped += '\\\\\"';\n } else {\n escaped += c;\n }\n\n i++;\n }\n\n return '\"' + escaped + '\"';\n}\n/**\n * Escape special HTML characters\n * @param {*} value\n * @return {string}\n */\n\n\nfunction escape(value) {\n var text = String(value);\n text = text.replace(/&/g, '&').replace(/\"/g, '"').replace(/'/g, ''').replace(//g, '>');\n return text;\n}\n/**\n * Recursively format an n-dimensional matrix\n * Example output: \"[[1, 2], [3, 4]]\"\n * @param {Array} array\n * @param {Object | number | Function} [options] Formatting options. See\n * lib/utils/number:format for a\n * description of the available\n * options.\n * @returns {string} str\n */\n\n\nfunction formatArray(array, options) {\n if (Array.isArray(array)) {\n var str = '[';\n var len = array.length;\n\n for (var i = 0; i < len; i++) {\n if (i !== 0) {\n str += ', ';\n }\n\n str += formatArray(array[i], options);\n }\n\n str += ']';\n return str;\n } else {\n return format(array, options);\n }\n}\n/**\n * Check whether a value looks like a Fraction (unsafe duck-type check)\n * @param {*} value\n * @return {boolean}\n */\n\n\nfunction looksLikeFraction(value) {\n return value && (0, _typeof2.default)(value) === 'object' && typeof value.s === 'number' && typeof value.n === 'number' && typeof value.d === 'number' || false;\n}\n/**\n * Compare two strings\n * @param {string} x\n * @param {string} y\n * @returns {number}\n */\n\n\nfunction compareText(x, y) {\n // we don't want to convert numbers to string, only accept string input\n if (!(0, _is.isString)(x)) {\n throw new TypeError('Unexpected type of argument in function compareText ' + '(expected: string or Array or Matrix, actual: ' + (0, _is.typeOf)(x) + ', index: 0)');\n }\n\n if (!(0, _is.isString)(y)) {\n throw new TypeError('Unexpected type of argument in function compareText ' + '(expected: string or Array or Matrix, actual: ' + (0, _is.typeOf)(y) + ', index: 1)');\n }\n\n return x === y ? 0 : x > y ? 1 : -1;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports._switch = _switch;\n\n/**\n * Transpose a matrix\n * @param {Array} mat\n * @returns {Array} ret\n * @private\n */\nfunction _switch(mat) {\n var I = mat.length;\n var J = mat[0].length;\n var i, j;\n var ret = [];\n\n for (j = 0; j < J; j++) {\n var tmp = [];\n\n for (i = 0; i < I; i++) {\n tmp.push(mat[i][j]);\n }\n\n ret.push(tmp);\n }\n\n return ret;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.version = void 0;\nvar version = '10.6.4'; // Note: This file is automatically generated when building math.js.\n// Changes made in this file will be overwritten.\n\nexports.version = version;","/**\n * @license\n * Copyright 2010-2022 Three.js Authors\n * SPDX-License-Identifier: MIT\n */\n'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nconst REVISION = '141';\nconst MOUSE = {\n\tLEFT: 0,\n\tMIDDLE: 1,\n\tRIGHT: 2,\n\tROTATE: 0,\n\tDOLLY: 1,\n\tPAN: 2\n};\nconst TOUCH = {\n\tROTATE: 0,\n\tPAN: 1,\n\tDOLLY_PAN: 2,\n\tDOLLY_ROTATE: 3\n};\nconst CullFaceNone = 0;\nconst CullFaceBack = 1;\nconst CullFaceFront = 2;\nconst CullFaceFrontBack = 3;\nconst BasicShadowMap = 0;\nconst PCFShadowMap = 1;\nconst PCFSoftShadowMap = 2;\nconst VSMShadowMap = 3;\nconst FrontSide = 0;\nconst BackSide = 1;\nconst DoubleSide = 2;\nconst FlatShading = 1;\nconst SmoothShading = 2;\nconst NoBlending = 0;\nconst NormalBlending = 1;\nconst AdditiveBlending = 2;\nconst SubtractiveBlending = 3;\nconst MultiplyBlending = 4;\nconst CustomBlending = 5;\nconst AddEquation = 100;\nconst SubtractEquation = 101;\nconst ReverseSubtractEquation = 102;\nconst MinEquation = 103;\nconst MaxEquation = 104;\nconst ZeroFactor = 200;\nconst OneFactor = 201;\nconst SrcColorFactor = 202;\nconst OneMinusSrcColorFactor = 203;\nconst SrcAlphaFactor = 204;\nconst OneMinusSrcAlphaFactor = 205;\nconst DstAlphaFactor = 206;\nconst OneMinusDstAlphaFactor = 207;\nconst DstColorFactor = 208;\nconst OneMinusDstColorFactor = 209;\nconst SrcAlphaSaturateFactor = 210;\nconst NeverDepth = 0;\nconst AlwaysDepth = 1;\nconst LessDepth = 2;\nconst LessEqualDepth = 3;\nconst EqualDepth = 4;\nconst GreaterEqualDepth = 5;\nconst GreaterDepth = 6;\nconst NotEqualDepth = 7;\nconst MultiplyOperation = 0;\nconst MixOperation = 1;\nconst AddOperation = 2;\nconst NoToneMapping = 0;\nconst LinearToneMapping = 1;\nconst ReinhardToneMapping = 2;\nconst CineonToneMapping = 3;\nconst ACESFilmicToneMapping = 4;\nconst CustomToneMapping = 5;\nconst UVMapping = 300;\nconst CubeReflectionMapping = 301;\nconst CubeRefractionMapping = 302;\nconst EquirectangularReflectionMapping = 303;\nconst EquirectangularRefractionMapping = 304;\nconst CubeUVReflectionMapping = 306;\nconst RepeatWrapping = 1000;\nconst ClampToEdgeWrapping = 1001;\nconst MirroredRepeatWrapping = 1002;\nconst NearestFilter = 1003;\nconst NearestMipmapNearestFilter = 1004;\nconst NearestMipMapNearestFilter = 1004;\nconst NearestMipmapLinearFilter = 1005;\nconst NearestMipMapLinearFilter = 1005;\nconst LinearFilter = 1006;\nconst LinearMipmapNearestFilter = 1007;\nconst LinearMipMapNearestFilter = 1007;\nconst LinearMipmapLinearFilter = 1008;\nconst LinearMipMapLinearFilter = 1008;\nconst UnsignedByteType = 1009;\nconst ByteType = 1010;\nconst ShortType = 1011;\nconst UnsignedShortType = 1012;\nconst IntType = 1013;\nconst UnsignedIntType = 1014;\nconst FloatType = 1015;\nconst HalfFloatType = 1016;\nconst UnsignedShort4444Type = 1017;\nconst UnsignedShort5551Type = 1018;\nconst UnsignedInt248Type = 1020;\nconst AlphaFormat = 1021;\nconst RGBFormat = 1022;\nconst RGBAFormat = 1023;\nconst LuminanceFormat = 1024;\nconst LuminanceAlphaFormat = 1025;\nconst DepthFormat = 1026;\nconst DepthStencilFormat = 1027;\nconst RedFormat = 1028;\nconst RedIntegerFormat = 1029;\nconst RGFormat = 1030;\nconst RGIntegerFormat = 1031;\nconst RGBAIntegerFormat = 1033;\nconst RGB_S3TC_DXT1_Format = 33776;\nconst RGBA_S3TC_DXT1_Format = 33777;\nconst RGBA_S3TC_DXT3_Format = 33778;\nconst RGBA_S3TC_DXT5_Format = 33779;\nconst RGB_PVRTC_4BPPV1_Format = 35840;\nconst RGB_PVRTC_2BPPV1_Format = 35841;\nconst RGBA_PVRTC_4BPPV1_Format = 35842;\nconst RGBA_PVRTC_2BPPV1_Format = 35843;\nconst RGB_ETC1_Format = 36196;\nconst RGB_ETC2_Format = 37492;\nconst RGBA_ETC2_EAC_Format = 37496;\nconst RGBA_ASTC_4x4_Format = 37808;\nconst RGBA_ASTC_5x4_Format = 37809;\nconst RGBA_ASTC_5x5_Format = 37810;\nconst RGBA_ASTC_6x5_Format = 37811;\nconst RGBA_ASTC_6x6_Format = 37812;\nconst RGBA_ASTC_8x5_Format = 37813;\nconst RGBA_ASTC_8x6_Format = 37814;\nconst RGBA_ASTC_8x8_Format = 37815;\nconst RGBA_ASTC_10x5_Format = 37816;\nconst RGBA_ASTC_10x6_Format = 37817;\nconst RGBA_ASTC_10x8_Format = 37818;\nconst RGBA_ASTC_10x10_Format = 37819;\nconst RGBA_ASTC_12x10_Format = 37820;\nconst RGBA_ASTC_12x12_Format = 37821;\nconst RGBA_BPTC_Format = 36492;\nconst LoopOnce = 2200;\nconst LoopRepeat = 2201;\nconst LoopPingPong = 2202;\nconst InterpolateDiscrete = 2300;\nconst InterpolateLinear = 2301;\nconst InterpolateSmooth = 2302;\nconst ZeroCurvatureEnding = 2400;\nconst ZeroSlopeEnding = 2401;\nconst WrapAroundEnding = 2402;\nconst NormalAnimationBlendMode = 2500;\nconst AdditiveAnimationBlendMode = 2501;\nconst TrianglesDrawMode = 0;\nconst TriangleStripDrawMode = 1;\nconst TriangleFanDrawMode = 2;\nconst LinearEncoding = 3000;\nconst sRGBEncoding = 3001;\nconst BasicDepthPacking = 3200;\nconst RGBADepthPacking = 3201;\nconst TangentSpaceNormalMap = 0;\nconst ObjectSpaceNormalMap = 1; // Color space string identifiers, matching CSS Color Module Level 4 and WebGPU names where available.\n\nconst NoColorSpace = '';\nconst SRGBColorSpace = 'srgb';\nconst LinearSRGBColorSpace = 'srgb-linear';\nconst ZeroStencilOp = 0;\nconst KeepStencilOp = 7680;\nconst ReplaceStencilOp = 7681;\nconst IncrementStencilOp = 7682;\nconst DecrementStencilOp = 7683;\nconst IncrementWrapStencilOp = 34055;\nconst DecrementWrapStencilOp = 34056;\nconst InvertStencilOp = 5386;\nconst NeverStencilFunc = 512;\nconst LessStencilFunc = 513;\nconst EqualStencilFunc = 514;\nconst LessEqualStencilFunc = 515;\nconst GreaterStencilFunc = 516;\nconst NotEqualStencilFunc = 517;\nconst GreaterEqualStencilFunc = 518;\nconst AlwaysStencilFunc = 519;\nconst StaticDrawUsage = 35044;\nconst DynamicDrawUsage = 35048;\nconst StreamDrawUsage = 35040;\nconst StaticReadUsage = 35045;\nconst DynamicReadUsage = 35049;\nconst StreamReadUsage = 35041;\nconst StaticCopyUsage = 35046;\nconst DynamicCopyUsage = 35050;\nconst StreamCopyUsage = 35042;\nconst GLSL1 = '100';\nconst GLSL3 = '300 es';\nconst _SRGBAFormat = 1035; // fallback for WebGL 1\n\n/**\n * https://github.com/mrdoob/eventdispatcher.js/\n */\nclass EventDispatcher {\n\taddEventListener(type, listener) {\n\t\tif (this._listeners === undefined) this._listeners = {};\n\t\tconst listeners = this._listeners;\n\n\t\tif (listeners[type] === undefined) {\n\t\t\tlisteners[type] = [];\n\t\t}\n\n\t\tif (listeners[type].indexOf(listener) === -1) {\n\t\t\tlisteners[type].push(listener);\n\t\t}\n\t}\n\n\thasEventListener(type, listener) {\n\t\tif (this._listeners === undefined) return false;\n\t\tconst listeners = this._listeners;\n\t\treturn listeners[type] !== undefined && listeners[type].indexOf(listener) !== -1;\n\t}\n\n\tremoveEventListener(type, listener) {\n\t\tif (this._listeners === undefined) return;\n\t\tconst listeners = this._listeners;\n\t\tconst listenerArray = listeners[type];\n\n\t\tif (listenerArray !== undefined) {\n\t\t\tconst index = listenerArray.indexOf(listener);\n\n\t\t\tif (index !== -1) {\n\t\t\t\tlistenerArray.splice(index, 1);\n\t\t\t}\n\t\t}\n\t}\n\n\tdispatchEvent(event) {\n\t\tif (this._listeners === undefined) return;\n\t\tconst listeners = this._listeners;\n\t\tconst listenerArray = listeners[event.type];\n\n\t\tif (listenerArray !== undefined) {\n\t\t\tevent.target = this; // Make a copy, in case listeners are removed while iterating.\n\n\t\t\tconst array = listenerArray.slice(0);\n\n\t\t\tfor (let i = 0, l = array.length; i < l; i++) {\n\t\t\t\tarray[i].call(this, event);\n\t\t\t}\n\n\t\t\tevent.target = null;\n\t\t}\n\t}\n\n}\n\nconst _lut = [];\n\nfor (let i = 0; i < 256; i++) {\n\t_lut[i] = (i < 16 ? '0' : '') + i.toString(16);\n}\n\nlet _seed = 1234567;\nconst DEG2RAD = Math.PI / 180;\nconst RAD2DEG = 180 / Math.PI; // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/21963136#21963136\n\nfunction generateUUID() {\n\tconst d0 = Math.random() * 0xffffffff | 0;\n\tconst d1 = Math.random() * 0xffffffff | 0;\n\tconst d2 = Math.random() * 0xffffffff | 0;\n\tconst d3 = Math.random() * 0xffffffff | 0;\n\tconst uuid = _lut[d0 & 0xff] + _lut[d0 >> 8 & 0xff] + _lut[d0 >> 16 & 0xff] + _lut[d0 >> 24 & 0xff] + '-' + _lut[d1 & 0xff] + _lut[d1 >> 8 & 0xff] + '-' + _lut[d1 >> 16 & 0x0f | 0x40] + _lut[d1 >> 24 & 0xff] + '-' + _lut[d2 & 0x3f | 0x80] + _lut[d2 >> 8 & 0xff] + '-' + _lut[d2 >> 16 & 0xff] + _lut[d2 >> 24 & 0xff] + _lut[d3 & 0xff] + _lut[d3 >> 8 & 0xff] + _lut[d3 >> 16 & 0xff] + _lut[d3 >> 24 & 0xff]; // .toLowerCase() here flattens concatenated strings to save heap memory space.\n\n\treturn uuid.toLowerCase();\n}\n\nfunction clamp(value, min, max) {\n\treturn Math.max(min, Math.min(max, value));\n} // compute euclidean modulo of m % n\n// https://en.wikipedia.org/wiki/Modulo_operation\n\n\nfunction euclideanModulo(n, m) {\n\treturn (n % m + m) % m;\n} // Linear mapping from range to range \n\n\nfunction mapLinear(x, a1, a2, b1, b2) {\n\treturn b1 + (x - a1) * (b2 - b1) / (a2 - a1);\n} // https://www.gamedev.net/tutorials/programming/general-and-gameplay-programming/inverse-lerp-a-super-useful-yet-often-overlooked-function-r5230/\n\n\nfunction inverseLerp(x, y, value) {\n\tif (x !== y) {\n\t\treturn (value - x) / (y - x);\n\t} else {\n\t\treturn 0;\n\t}\n} // https://en.wikipedia.org/wiki/Linear_interpolation\n\n\nfunction lerp(x, y, t) {\n\treturn (1 - t) * x + t * y;\n} // http://www.rorydriscoll.com/2016/03/07/frame-rate-independent-damping-using-lerp/\n\n\nfunction damp(x, y, lambda, dt) {\n\treturn lerp(x, y, 1 - Math.exp(-lambda * dt));\n} // https://www.desmos.com/calculator/vcsjnyz7x4\n\n\nfunction pingpong(x, length = 1) {\n\treturn length - Math.abs(euclideanModulo(x, length * 2) - length);\n} // http://en.wikipedia.org/wiki/Smoothstep\n\n\nfunction smoothstep(x, min, max) {\n\tif (x <= min) return 0;\n\tif (x >= max) return 1;\n\tx = (x - min) / (max - min);\n\treturn x * x * (3 - 2 * x);\n}\n\nfunction smootherstep(x, min, max) {\n\tif (x <= min) return 0;\n\tif (x >= max) return 1;\n\tx = (x - min) / (max - min);\n\treturn x * x * x * (x * (x * 6 - 15) + 10);\n} // Random integer from interval\n\n\nfunction randInt(low, high) {\n\treturn low + Math.floor(Math.random() * (high - low + 1));\n} // Random float from interval\n\n\nfunction randFloat(low, high) {\n\treturn low + Math.random() * (high - low);\n} // Random float from <-range/2, range/2> interval\n\n\nfunction randFloatSpread(range) {\n\treturn range * (0.5 - Math.random());\n} // Deterministic pseudo-random float in the interval [ 0, 1 ]\n\n\nfunction seededRandom(s) {\n\tif (s !== undefined) _seed = s; // Mulberry32 generator\n\n\tlet t = _seed += 0x6D2B79F5;\n\tt = Math.imul(t ^ t >>> 15, t | 1);\n\tt ^= t + Math.imul(t ^ t >>> 7, t | 61);\n\treturn ((t ^ t >>> 14) >>> 0) / 4294967296;\n}\n\nfunction degToRad(degrees) {\n\treturn degrees * DEG2RAD;\n}\n\nfunction radToDeg(radians) {\n\treturn radians * RAD2DEG;\n}\n\nfunction isPowerOfTwo(value) {\n\treturn (value & value - 1) === 0 && value !== 0;\n}\n\nfunction ceilPowerOfTwo(value) {\n\treturn Math.pow(2, Math.ceil(Math.log(value) / Math.LN2));\n}\n\nfunction floorPowerOfTwo(value) {\n\treturn Math.pow(2, Math.floor(Math.log(value) / Math.LN2));\n}\n\nfunction setQuaternionFromProperEuler(q, a, b, c, order) {\n\t// Intrinsic Proper Euler Angles - see https://en.wikipedia.org/wiki/Euler_angles\n\t// rotations are applied to the axes in the order specified by 'order'\n\t// rotation by angle 'a' is applied first, then by angle 'b', then by angle 'c'\n\t// angles are in radians\n\tconst cos = Math.cos;\n\tconst sin = Math.sin;\n\tconst c2 = cos(b / 2);\n\tconst s2 = sin(b / 2);\n\tconst c13 = cos((a + c) / 2);\n\tconst s13 = sin((a + c) / 2);\n\tconst c1_3 = cos((a - c) / 2);\n\tconst s1_3 = sin((a - c) / 2);\n\tconst c3_1 = cos((c - a) / 2);\n\tconst s3_1 = sin((c - a) / 2);\n\n\tswitch (order) {\n\t\tcase 'XYX':\n\t\t\tq.set(c2 * s13, s2 * c1_3, s2 * s1_3, c2 * c13);\n\t\t\tbreak;\n\n\t\tcase 'YZY':\n\t\t\tq.set(s2 * s1_3, c2 * s13, s2 * c1_3, c2 * c13);\n\t\t\tbreak;\n\n\t\tcase 'ZXZ':\n\t\t\tq.set(s2 * c1_3, s2 * s1_3, c2 * s13, c2 * c13);\n\t\t\tbreak;\n\n\t\tcase 'XZX':\n\t\t\tq.set(c2 * s13, s2 * s3_1, s2 * c3_1, c2 * c13);\n\t\t\tbreak;\n\n\t\tcase 'YXY':\n\t\t\tq.set(s2 * c3_1, c2 * s13, s2 * s3_1, c2 * c13);\n\t\t\tbreak;\n\n\t\tcase 'ZYZ':\n\t\t\tq.set(s2 * s3_1, s2 * c3_1, c2 * s13, c2 * c13);\n\t\t\tbreak;\n\n\t\tdefault:\n\t\t\tconsole.warn('THREE.MathUtils: .setQuaternionFromProperEuler() encountered an unknown order: ' + order);\n\t}\n}\n\nfunction denormalize$1(value, array) {\n\tswitch (array.constructor) {\n\t\tcase Float32Array:\n\t\t\treturn value;\n\n\t\tcase Uint16Array:\n\t\t\treturn value / 65535.0;\n\n\t\tcase Uint8Array:\n\t\t\treturn value / 255.0;\n\n\t\tcase Int16Array:\n\t\t\treturn Math.max(value / 32767.0, -1.0);\n\n\t\tcase Int8Array:\n\t\t\treturn Math.max(value / 127.0, -1.0);\n\n\t\tdefault:\n\t\t\tthrow new Error('Invalid component type.');\n\t}\n}\n\nfunction normalize(value, array) {\n\tswitch (array.constructor) {\n\t\tcase Float32Array:\n\t\t\treturn value;\n\n\t\tcase Uint16Array:\n\t\t\treturn Math.round(value * 65535.0);\n\n\t\tcase Uint8Array:\n\t\t\treturn Math.round(value * 255.0);\n\n\t\tcase Int16Array:\n\t\t\treturn Math.round(value * 32767.0);\n\n\t\tcase Int8Array:\n\t\t\treturn Math.round(value * 127.0);\n\n\t\tdefault:\n\t\t\tthrow new Error('Invalid component type.');\n\t}\n}\n\nvar MathUtils = /*#__PURE__*/Object.freeze({\n\t__proto__: null,\n\tDEG2RAD: DEG2RAD,\n\tRAD2DEG: RAD2DEG,\n\tgenerateUUID: generateUUID,\n\tclamp: clamp,\n\teuclideanModulo: euclideanModulo,\n\tmapLinear: mapLinear,\n\tinverseLerp: inverseLerp,\n\tlerp: lerp,\n\tdamp: damp,\n\tpingpong: pingpong,\n\tsmoothstep: smoothstep,\n\tsmootherstep: smootherstep,\n\trandInt: randInt,\n\trandFloat: randFloat,\n\trandFloatSpread: randFloatSpread,\n\tseededRandom: seededRandom,\n\tdegToRad: degToRad,\n\tradToDeg: radToDeg,\n\tisPowerOfTwo: isPowerOfTwo,\n\tceilPowerOfTwo: ceilPowerOfTwo,\n\tfloorPowerOfTwo: floorPowerOfTwo,\n\tsetQuaternionFromProperEuler: setQuaternionFromProperEuler,\n\tnormalize: normalize,\n\tdenormalize: denormalize$1\n});\n\nclass Vector2 {\n\tconstructor(x = 0, y = 0) {\n\t\tthis.isVector2 = true;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t}\n\n\tget width() {\n\t\treturn this.x;\n\t}\n\n\tset width(value) {\n\t\tthis.x = value;\n\t}\n\n\tget height() {\n\t\treturn this.y;\n\t}\n\n\tset height(value) {\n\t\tthis.y = value;\n\t}\n\n\tset(x, y) {\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\treturn this;\n\t}\n\n\tsetScalar(scalar) {\n\t\tthis.x = scalar;\n\t\tthis.y = scalar;\n\t\treturn this;\n\t}\n\n\tsetX(x) {\n\t\tthis.x = x;\n\t\treturn this;\n\t}\n\n\tsetY(y) {\n\t\tthis.y = y;\n\t\treturn this;\n\t}\n\n\tsetComponent(index, value) {\n\t\tswitch (index) {\n\t\t\tcase 0:\n\t\t\t\tthis.x = value;\n\t\t\t\tbreak;\n\n\t\t\tcase 1:\n\t\t\t\tthis.y = value;\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tthrow new Error('index is out of range: ' + index);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tgetComponent(index) {\n\t\tswitch (index) {\n\t\t\tcase 0:\n\t\t\t\treturn this.x;\n\n\t\t\tcase 1:\n\t\t\t\treturn this.y;\n\n\t\t\tdefault:\n\t\t\t\tthrow new Error('index is out of range: ' + index);\n\t\t}\n\t}\n\n\tclone() {\n\t\treturn new this.constructor(this.x, this.y);\n\t}\n\n\tcopy(v) {\n\t\tthis.x = v.x;\n\t\tthis.y = v.y;\n\t\treturn this;\n\t}\n\n\tadd(v, w) {\n\t\tif (w !== undefined) {\n\t\t\tconsole.warn('THREE.Vector2: .add() now only accepts one argument. Use .addVectors( a, b ) instead.');\n\t\t\treturn this.addVectors(v, w);\n\t\t}\n\n\t\tthis.x += v.x;\n\t\tthis.y += v.y;\n\t\treturn this;\n\t}\n\n\taddScalar(s) {\n\t\tthis.x += s;\n\t\tthis.y += s;\n\t\treturn this;\n\t}\n\n\taddVectors(a, b) {\n\t\tthis.x = a.x + b.x;\n\t\tthis.y = a.y + b.y;\n\t\treturn this;\n\t}\n\n\taddScaledVector(v, s) {\n\t\tthis.x += v.x * s;\n\t\tthis.y += v.y * s;\n\t\treturn this;\n\t}\n\n\tsub(v, w) {\n\t\tif (w !== undefined) {\n\t\t\tconsole.warn('THREE.Vector2: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.');\n\t\t\treturn this.subVectors(v, w);\n\t\t}\n\n\t\tthis.x -= v.x;\n\t\tthis.y -= v.y;\n\t\treturn this;\n\t}\n\n\tsubScalar(s) {\n\t\tthis.x -= s;\n\t\tthis.y -= s;\n\t\treturn this;\n\t}\n\n\tsubVectors(a, b) {\n\t\tthis.x = a.x - b.x;\n\t\tthis.y = a.y - b.y;\n\t\treturn this;\n\t}\n\n\tmultiply(v) {\n\t\tthis.x *= v.x;\n\t\tthis.y *= v.y;\n\t\treturn this;\n\t}\n\n\tmultiplyScalar(scalar) {\n\t\tthis.x *= scalar;\n\t\tthis.y *= scalar;\n\t\treturn this;\n\t}\n\n\tdivide(v) {\n\t\tthis.x /= v.x;\n\t\tthis.y /= v.y;\n\t\treturn this;\n\t}\n\n\tdivideScalar(scalar) {\n\t\treturn this.multiplyScalar(1 / scalar);\n\t}\n\n\tapplyMatrix3(m) {\n\t\tconst x = this.x,\n\t\t\t\t\ty = this.y;\n\t\tconst e = m.elements;\n\t\tthis.x = e[0] * x + e[3] * y + e[6];\n\t\tthis.y = e[1] * x + e[4] * y + e[7];\n\t\treturn this;\n\t}\n\n\tmin(v) {\n\t\tthis.x = Math.min(this.x, v.x);\n\t\tthis.y = Math.min(this.y, v.y);\n\t\treturn this;\n\t}\n\n\tmax(v) {\n\t\tthis.x = Math.max(this.x, v.x);\n\t\tthis.y = Math.max(this.y, v.y);\n\t\treturn this;\n\t}\n\n\tclamp(min, max) {\n\t\t// assumes min < max, componentwise\n\t\tthis.x = Math.max(min.x, Math.min(max.x, this.x));\n\t\tthis.y = Math.max(min.y, Math.min(max.y, this.y));\n\t\treturn this;\n\t}\n\n\tclampScalar(minVal, maxVal) {\n\t\tthis.x = Math.max(minVal, Math.min(maxVal, this.x));\n\t\tthis.y = Math.max(minVal, Math.min(maxVal, this.y));\n\t\treturn this;\n\t}\n\n\tclampLength(min, max) {\n\t\tconst length = this.length();\n\t\treturn this.divideScalar(length || 1).multiplyScalar(Math.max(min, Math.min(max, length)));\n\t}\n\n\tfloor() {\n\t\tthis.x = Math.floor(this.x);\n\t\tthis.y = Math.floor(this.y);\n\t\treturn this;\n\t}\n\n\tceil() {\n\t\tthis.x = Math.ceil(this.x);\n\t\tthis.y = Math.ceil(this.y);\n\t\treturn this;\n\t}\n\n\tround() {\n\t\tthis.x = Math.round(this.x);\n\t\tthis.y = Math.round(this.y);\n\t\treturn this;\n\t}\n\n\troundToZero() {\n\t\tthis.x = this.x < 0 ? Math.ceil(this.x) : Math.floor(this.x);\n\t\tthis.y = this.y < 0 ? Math.ceil(this.y) : Math.floor(this.y);\n\t\treturn this;\n\t}\n\n\tnegate() {\n\t\tthis.x = -this.x;\n\t\tthis.y = -this.y;\n\t\treturn this;\n\t}\n\n\tdot(v) {\n\t\treturn this.x * v.x + this.y * v.y;\n\t}\n\n\tcross(v) {\n\t\treturn this.x * v.y - this.y * v.x;\n\t}\n\n\tlengthSq() {\n\t\treturn this.x * this.x + this.y * this.y;\n\t}\n\n\tlength() {\n\t\treturn Math.sqrt(this.x * this.x + this.y * this.y);\n\t}\n\n\tmanhattanLength() {\n\t\treturn Math.abs(this.x) + Math.abs(this.y);\n\t}\n\n\tnormalize() {\n\t\treturn this.divideScalar(this.length() || 1);\n\t}\n\n\tangle() {\n\t\t// computes the angle in radians with respect to the positive x-axis\n\t\tconst angle = Math.atan2(-this.y, -this.x) + Math.PI;\n\t\treturn angle;\n\t}\n\n\tdistanceTo(v) {\n\t\treturn Math.sqrt(this.distanceToSquared(v));\n\t}\n\n\tdistanceToSquared(v) {\n\t\tconst dx = this.x - v.x,\n\t\t\t\t\tdy = this.y - v.y;\n\t\treturn dx * dx + dy * dy;\n\t}\n\n\tmanhattanDistanceTo(v) {\n\t\treturn Math.abs(this.x - v.x) + Math.abs(this.y - v.y);\n\t}\n\n\tsetLength(length) {\n\t\treturn this.normalize().multiplyScalar(length);\n\t}\n\n\tlerp(v, alpha) {\n\t\tthis.x += (v.x - this.x) * alpha;\n\t\tthis.y += (v.y - this.y) * alpha;\n\t\treturn this;\n\t}\n\n\tlerpVectors(v1, v2, alpha) {\n\t\tthis.x = v1.x + (v2.x - v1.x) * alpha;\n\t\tthis.y = v1.y + (v2.y - v1.y) * alpha;\n\t\treturn this;\n\t}\n\n\tequals(v) {\n\t\treturn v.x === this.x && v.y === this.y;\n\t}\n\n\tfromArray(array, offset = 0) {\n\t\tthis.x = array[offset];\n\t\tthis.y = array[offset + 1];\n\t\treturn this;\n\t}\n\n\ttoArray(array = [], offset = 0) {\n\t\tarray[offset] = this.x;\n\t\tarray[offset + 1] = this.y;\n\t\treturn array;\n\t}\n\n\tfromBufferAttribute(attribute, index, offset) {\n\t\tif (offset !== undefined) {\n\t\t\tconsole.warn('THREE.Vector2: offset has been removed from .fromBufferAttribute().');\n\t\t}\n\n\t\tthis.x = attribute.getX(index);\n\t\tthis.y = attribute.getY(index);\n\t\treturn this;\n\t}\n\n\trotateAround(center, angle) {\n\t\tconst c = Math.cos(angle),\n\t\t\t\t\ts = Math.sin(angle);\n\t\tconst x = this.x - center.x;\n\t\tconst y = this.y - center.y;\n\t\tthis.x = x * c - y * s + center.x;\n\t\tthis.y = x * s + y * c + center.y;\n\t\treturn this;\n\t}\n\n\trandom() {\n\t\tthis.x = Math.random();\n\t\tthis.y = Math.random();\n\t\treturn this;\n\t}\n\n\t*[Symbol.iterator]() {\n\t\tyield this.x;\n\t\tyield this.y;\n\t}\n\n}\n\nclass Matrix3 {\n\tconstructor() {\n\t\tthis.isMatrix3 = true;\n\t\tthis.elements = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n\n\t\tif (arguments.length > 0) {\n\t\t\tconsole.error('THREE.Matrix3: the constructor no longer reads arguments. use .set() instead.');\n\t\t}\n\t}\n\n\tset(n11, n12, n13, n21, n22, n23, n31, n32, n33) {\n\t\tconst te = this.elements;\n\t\tte[0] = n11;\n\t\tte[1] = n21;\n\t\tte[2] = n31;\n\t\tte[3] = n12;\n\t\tte[4] = n22;\n\t\tte[5] = n32;\n\t\tte[6] = n13;\n\t\tte[7] = n23;\n\t\tte[8] = n33;\n\t\treturn this;\n\t}\n\n\tidentity() {\n\t\tthis.set(1, 0, 0, 0, 1, 0, 0, 0, 1);\n\t\treturn this;\n\t}\n\n\tcopy(m) {\n\t\tconst te = this.elements;\n\t\tconst me = m.elements;\n\t\tte[0] = me[0];\n\t\tte[1] = me[1];\n\t\tte[2] = me[2];\n\t\tte[3] = me[3];\n\t\tte[4] = me[4];\n\t\tte[5] = me[5];\n\t\tte[6] = me[6];\n\t\tte[7] = me[7];\n\t\tte[8] = me[8];\n\t\treturn this;\n\t}\n\n\textractBasis(xAxis, yAxis, zAxis) {\n\t\txAxis.setFromMatrix3Column(this, 0);\n\t\tyAxis.setFromMatrix3Column(this, 1);\n\t\tzAxis.setFromMatrix3Column(this, 2);\n\t\treturn this;\n\t}\n\n\tsetFromMatrix4(m) {\n\t\tconst me = m.elements;\n\t\tthis.set(me[0], me[4], me[8], me[1], me[5], me[9], me[2], me[6], me[10]);\n\t\treturn this;\n\t}\n\n\tmultiply(m) {\n\t\treturn this.multiplyMatrices(this, m);\n\t}\n\n\tpremultiply(m) {\n\t\treturn this.multiplyMatrices(m, this);\n\t}\n\n\tmultiplyMatrices(a, b) {\n\t\tconst ae = a.elements;\n\t\tconst be = b.elements;\n\t\tconst te = this.elements;\n\t\tconst a11 = ae[0],\n\t\t\t\t\ta12 = ae[3],\n\t\t\t\t\ta13 = ae[6];\n\t\tconst a21 = ae[1],\n\t\t\t\t\ta22 = ae[4],\n\t\t\t\t\ta23 = ae[7];\n\t\tconst a31 = ae[2],\n\t\t\t\t\ta32 = ae[5],\n\t\t\t\t\ta33 = ae[8];\n\t\tconst b11 = be[0],\n\t\t\t\t\tb12 = be[3],\n\t\t\t\t\tb13 = be[6];\n\t\tconst b21 = be[1],\n\t\t\t\t\tb22 = be[4],\n\t\t\t\t\tb23 = be[7];\n\t\tconst b31 = be[2],\n\t\t\t\t\tb32 = be[5],\n\t\t\t\t\tb33 = be[8];\n\t\tte[0] = a11 * b11 + a12 * b21 + a13 * b31;\n\t\tte[3] = a11 * b12 + a12 * b22 + a13 * b32;\n\t\tte[6] = a11 * b13 + a12 * b23 + a13 * b33;\n\t\tte[1] = a21 * b11 + a22 * b21 + a23 * b31;\n\t\tte[4] = a21 * b12 + a22 * b22 + a23 * b32;\n\t\tte[7] = a21 * b13 + a22 * b23 + a23 * b33;\n\t\tte[2] = a31 * b11 + a32 * b21 + a33 * b31;\n\t\tte[5] = a31 * b12 + a32 * b22 + a33 * b32;\n\t\tte[8] = a31 * b13 + a32 * b23 + a33 * b33;\n\t\treturn this;\n\t}\n\n\tmultiplyScalar(s) {\n\t\tconst te = this.elements;\n\t\tte[0] *= s;\n\t\tte[3] *= s;\n\t\tte[6] *= s;\n\t\tte[1] *= s;\n\t\tte[4] *= s;\n\t\tte[7] *= s;\n\t\tte[2] *= s;\n\t\tte[5] *= s;\n\t\tte[8] *= s;\n\t\treturn this;\n\t}\n\n\tdeterminant() {\n\t\tconst te = this.elements;\n\t\tconst a = te[0],\n\t\t\t\t\tb = te[1],\n\t\t\t\t\tc = te[2],\n\t\t\t\t\td = te[3],\n\t\t\t\t\te = te[4],\n\t\t\t\t\tf = te[5],\n\t\t\t\t\tg = te[6],\n\t\t\t\t\th = te[7],\n\t\t\t\t\ti = te[8];\n\t\treturn a * e * i - a * f * h - b * d * i + b * f * g + c * d * h - c * e * g;\n\t}\n\n\tinvert() {\n\t\tconst te = this.elements,\n\t\t\t\t\tn11 = te[0],\n\t\t\t\t\tn21 = te[1],\n\t\t\t\t\tn31 = te[2],\n\t\t\t\t\tn12 = te[3],\n\t\t\t\t\tn22 = te[4],\n\t\t\t\t\tn32 = te[5],\n\t\t\t\t\tn13 = te[6],\n\t\t\t\t\tn23 = te[7],\n\t\t\t\t\tn33 = te[8],\n\t\t\t\t\tt11 = n33 * n22 - n32 * n23,\n\t\t\t\t\tt12 = n32 * n13 - n33 * n12,\n\t\t\t\t\tt13 = n23 * n12 - n22 * n13,\n\t\t\t\t\tdet = n11 * t11 + n21 * t12 + n31 * t13;\n\t\tif (det === 0) return this.set(0, 0, 0, 0, 0, 0, 0, 0, 0);\n\t\tconst detInv = 1 / det;\n\t\tte[0] = t11 * detInv;\n\t\tte[1] = (n31 * n23 - n33 * n21) * detInv;\n\t\tte[2] = (n32 * n21 - n31 * n22) * detInv;\n\t\tte[3] = t12 * detInv;\n\t\tte[4] = (n33 * n11 - n31 * n13) * detInv;\n\t\tte[5] = (n31 * n12 - n32 * n11) * detInv;\n\t\tte[6] = t13 * detInv;\n\t\tte[7] = (n21 * n13 - n23 * n11) * detInv;\n\t\tte[8] = (n22 * n11 - n21 * n12) * detInv;\n\t\treturn this;\n\t}\n\n\ttranspose() {\n\t\tlet tmp;\n\t\tconst m = this.elements;\n\t\ttmp = m[1];\n\t\tm[1] = m[3];\n\t\tm[3] = tmp;\n\t\ttmp = m[2];\n\t\tm[2] = m[6];\n\t\tm[6] = tmp;\n\t\ttmp = m[5];\n\t\tm[5] = m[7];\n\t\tm[7] = tmp;\n\t\treturn this;\n\t}\n\n\tgetNormalMatrix(matrix4) {\n\t\treturn this.setFromMatrix4(matrix4).invert().transpose();\n\t}\n\n\ttransposeIntoArray(r) {\n\t\tconst m = this.elements;\n\t\tr[0] = m[0];\n\t\tr[1] = m[3];\n\t\tr[2] = m[6];\n\t\tr[3] = m[1];\n\t\tr[4] = m[4];\n\t\tr[5] = m[7];\n\t\tr[6] = m[2];\n\t\tr[7] = m[5];\n\t\tr[8] = m[8];\n\t\treturn this;\n\t}\n\n\tsetUvTransform(tx, ty, sx, sy, rotation, cx, cy) {\n\t\tconst c = Math.cos(rotation);\n\t\tconst s = Math.sin(rotation);\n\t\tthis.set(sx * c, sx * s, -sx * (c * cx + s * cy) + cx + tx, -sy * s, sy * c, -sy * (-s * cx + c * cy) + cy + ty, 0, 0, 1);\n\t\treturn this;\n\t}\n\n\tscale(sx, sy) {\n\t\tconst te = this.elements;\n\t\tte[0] *= sx;\n\t\tte[3] *= sx;\n\t\tte[6] *= sx;\n\t\tte[1] *= sy;\n\t\tte[4] *= sy;\n\t\tte[7] *= sy;\n\t\treturn this;\n\t}\n\n\trotate(theta) {\n\t\tconst c = Math.cos(theta);\n\t\tconst s = Math.sin(theta);\n\t\tconst te = this.elements;\n\t\tconst a11 = te[0],\n\t\t\t\t\ta12 = te[3],\n\t\t\t\t\ta13 = te[6];\n\t\tconst a21 = te[1],\n\t\t\t\t\ta22 = te[4],\n\t\t\t\t\ta23 = te[7];\n\t\tte[0] = c * a11 + s * a21;\n\t\tte[3] = c * a12 + s * a22;\n\t\tte[6] = c * a13 + s * a23;\n\t\tte[1] = -s * a11 + c * a21;\n\t\tte[4] = -s * a12 + c * a22;\n\t\tte[7] = -s * a13 + c * a23;\n\t\treturn this;\n\t}\n\n\ttranslate(tx, ty) {\n\t\tconst te = this.elements;\n\t\tte[0] += tx * te[2];\n\t\tte[3] += tx * te[5];\n\t\tte[6] += tx * te[8];\n\t\tte[1] += ty * te[2];\n\t\tte[4] += ty * te[5];\n\t\tte[7] += ty * te[8];\n\t\treturn this;\n\t}\n\n\tequals(matrix) {\n\t\tconst te = this.elements;\n\t\tconst me = matrix.elements;\n\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tif (te[i] !== me[i]) return false;\n\t\t}\n\n\t\treturn true;\n\t}\n\n\tfromArray(array, offset = 0) {\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tthis.elements[i] = array[i + offset];\n\t\t}\n\n\t\treturn this;\n\t}\n\n\ttoArray(array = [], offset = 0) {\n\t\tconst te = this.elements;\n\t\tarray[offset] = te[0];\n\t\tarray[offset + 1] = te[1];\n\t\tarray[offset + 2] = te[2];\n\t\tarray[offset + 3] = te[3];\n\t\tarray[offset + 4] = te[4];\n\t\tarray[offset + 5] = te[5];\n\t\tarray[offset + 6] = te[6];\n\t\tarray[offset + 7] = te[7];\n\t\tarray[offset + 8] = te[8];\n\t\treturn array;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().fromArray(this.elements);\n\t}\n\n}\n\nfunction arrayNeedsUint32(array) {\n\t// assumes larger values usually on last\n\tfor (let i = array.length - 1; i >= 0; --i) {\n\t\tif (array[i] > 65535) return true;\n\t}\n\n\treturn false;\n}\n\nconst TYPED_ARRAYS = {\n\tInt8Array: Int8Array,\n\tUint8Array: Uint8Array,\n\tUint8ClampedArray: Uint8ClampedArray,\n\tInt16Array: Int16Array,\n\tUint16Array: Uint16Array,\n\tInt32Array: Int32Array,\n\tUint32Array: Uint32Array,\n\tFloat32Array: Float32Array,\n\tFloat64Array: Float64Array\n};\n\nfunction getTypedArray(type, buffer) {\n\treturn new TYPED_ARRAYS[type](buffer);\n}\n\nfunction createElementNS(name) {\n\treturn document.createElementNS('http://www.w3.org/1999/xhtml', name);\n}\n\nfunction SRGBToLinear(c) {\n\treturn c < 0.04045 ? c * 0.0773993808 : Math.pow(c * 0.9478672986 + 0.0521327014, 2.4);\n}\nfunction LinearToSRGB(c) {\n\treturn c < 0.0031308 ? c * 12.92 : 1.055 * Math.pow(c, 0.41666) - 0.055;\n} // JavaScript RGB-to-RGB transforms, defined as\n// FN[InputColorSpace][OutputColorSpace] callback functions.\n\nconst FN = {\n\t[SRGBColorSpace]: {\n\t\t[LinearSRGBColorSpace]: SRGBToLinear\n\t},\n\t[LinearSRGBColorSpace]: {\n\t\t[SRGBColorSpace]: LinearToSRGB\n\t}\n};\nconst ColorManagement = {\n\tlegacyMode: true,\n\n\tget workingColorSpace() {\n\t\treturn LinearSRGBColorSpace;\n\t},\n\n\tset workingColorSpace(colorSpace) {\n\t\tconsole.warn('THREE.ColorManagement: .workingColorSpace is readonly.');\n\t},\n\n\tconvert: function (color, sourceColorSpace, targetColorSpace) {\n\t\tif (this.legacyMode || sourceColorSpace === targetColorSpace || !sourceColorSpace || !targetColorSpace) {\n\t\t\treturn color;\n\t\t}\n\n\t\tif (FN[sourceColorSpace] && FN[sourceColorSpace][targetColorSpace] !== undefined) {\n\t\t\tconst fn = FN[sourceColorSpace][targetColorSpace];\n\t\t\tcolor.r = fn(color.r);\n\t\t\tcolor.g = fn(color.g);\n\t\t\tcolor.b = fn(color.b);\n\t\t\treturn color;\n\t\t}\n\n\t\tthrow new Error('Unsupported color space conversion.');\n\t},\n\tfromWorkingColorSpace: function (color, targetColorSpace) {\n\t\treturn this.convert(color, this.workingColorSpace, targetColorSpace);\n\t},\n\ttoWorkingColorSpace: function (color, sourceColorSpace) {\n\t\treturn this.convert(color, sourceColorSpace, this.workingColorSpace);\n\t}\n};\n\nconst _colorKeywords = {\n\t'aliceblue': 0xF0F8FF,\n\t'antiquewhite': 0xFAEBD7,\n\t'aqua': 0x00FFFF,\n\t'aquamarine': 0x7FFFD4,\n\t'azure': 0xF0FFFF,\n\t'beige': 0xF5F5DC,\n\t'bisque': 0xFFE4C4,\n\t'black': 0x000000,\n\t'blanchedalmond': 0xFFEBCD,\n\t'blue': 0x0000FF,\n\t'blueviolet': 0x8A2BE2,\n\t'brown': 0xA52A2A,\n\t'burlywood': 0xDEB887,\n\t'cadetblue': 0x5F9EA0,\n\t'chartreuse': 0x7FFF00,\n\t'chocolate': 0xD2691E,\n\t'coral': 0xFF7F50,\n\t'cornflowerblue': 0x6495ED,\n\t'cornsilk': 0xFFF8DC,\n\t'crimson': 0xDC143C,\n\t'cyan': 0x00FFFF,\n\t'darkblue': 0x00008B,\n\t'darkcyan': 0x008B8B,\n\t'darkgoldenrod': 0xB8860B,\n\t'darkgray': 0xA9A9A9,\n\t'darkgreen': 0x006400,\n\t'darkgrey': 0xA9A9A9,\n\t'darkkhaki': 0xBDB76B,\n\t'darkmagenta': 0x8B008B,\n\t'darkolivegreen': 0x556B2F,\n\t'darkorange': 0xFF8C00,\n\t'darkorchid': 0x9932CC,\n\t'darkred': 0x8B0000,\n\t'darksalmon': 0xE9967A,\n\t'darkseagreen': 0x8FBC8F,\n\t'darkslateblue': 0x483D8B,\n\t'darkslategray': 0x2F4F4F,\n\t'darkslategrey': 0x2F4F4F,\n\t'darkturquoise': 0x00CED1,\n\t'darkviolet': 0x9400D3,\n\t'deeppink': 0xFF1493,\n\t'deepskyblue': 0x00BFFF,\n\t'dimgray': 0x696969,\n\t'dimgrey': 0x696969,\n\t'dodgerblue': 0x1E90FF,\n\t'firebrick': 0xB22222,\n\t'floralwhite': 0xFFFAF0,\n\t'forestgreen': 0x228B22,\n\t'fuchsia': 0xFF00FF,\n\t'gainsboro': 0xDCDCDC,\n\t'ghostwhite': 0xF8F8FF,\n\t'gold': 0xFFD700,\n\t'goldenrod': 0xDAA520,\n\t'gray': 0x808080,\n\t'green': 0x008000,\n\t'greenyellow': 0xADFF2F,\n\t'grey': 0x808080,\n\t'honeydew': 0xF0FFF0,\n\t'hotpink': 0xFF69B4,\n\t'indianred': 0xCD5C5C,\n\t'indigo': 0x4B0082,\n\t'ivory': 0xFFFFF0,\n\t'khaki': 0xF0E68C,\n\t'lavender': 0xE6E6FA,\n\t'lavenderblush': 0xFFF0F5,\n\t'lawngreen': 0x7CFC00,\n\t'lemonchiffon': 0xFFFACD,\n\t'lightblue': 0xADD8E6,\n\t'lightcoral': 0xF08080,\n\t'lightcyan': 0xE0FFFF,\n\t'lightgoldenrodyellow': 0xFAFAD2,\n\t'lightgray': 0xD3D3D3,\n\t'lightgreen': 0x90EE90,\n\t'lightgrey': 0xD3D3D3,\n\t'lightpink': 0xFFB6C1,\n\t'lightsalmon': 0xFFA07A,\n\t'lightseagreen': 0x20B2AA,\n\t'lightskyblue': 0x87CEFA,\n\t'lightslategray': 0x778899,\n\t'lightslategrey': 0x778899,\n\t'lightsteelblue': 0xB0C4DE,\n\t'lightyellow': 0xFFFFE0,\n\t'lime': 0x00FF00,\n\t'limegreen': 0x32CD32,\n\t'linen': 0xFAF0E6,\n\t'magenta': 0xFF00FF,\n\t'maroon': 0x800000,\n\t'mediumaquamarine': 0x66CDAA,\n\t'mediumblue': 0x0000CD,\n\t'mediumorchid': 0xBA55D3,\n\t'mediumpurple': 0x9370DB,\n\t'mediumseagreen': 0x3CB371,\n\t'mediumslateblue': 0x7B68EE,\n\t'mediumspringgreen': 0x00FA9A,\n\t'mediumturquoise': 0x48D1CC,\n\t'mediumvioletred': 0xC71585,\n\t'midnightblue': 0x191970,\n\t'mintcream': 0xF5FFFA,\n\t'mistyrose': 0xFFE4E1,\n\t'moccasin': 0xFFE4B5,\n\t'navajowhite': 0xFFDEAD,\n\t'navy': 0x000080,\n\t'oldlace': 0xFDF5E6,\n\t'olive': 0x808000,\n\t'olivedrab': 0x6B8E23,\n\t'orange': 0xFFA500,\n\t'orangered': 0xFF4500,\n\t'orchid': 0xDA70D6,\n\t'palegoldenrod': 0xEEE8AA,\n\t'palegreen': 0x98FB98,\n\t'paleturquoise': 0xAFEEEE,\n\t'palevioletred': 0xDB7093,\n\t'papayawhip': 0xFFEFD5,\n\t'peachpuff': 0xFFDAB9,\n\t'peru': 0xCD853F,\n\t'pink': 0xFFC0CB,\n\t'plum': 0xDDA0DD,\n\t'powderblue': 0xB0E0E6,\n\t'purple': 0x800080,\n\t'rebeccapurple': 0x663399,\n\t'red': 0xFF0000,\n\t'rosybrown': 0xBC8F8F,\n\t'royalblue': 0x4169E1,\n\t'saddlebrown': 0x8B4513,\n\t'salmon': 0xFA8072,\n\t'sandybrown': 0xF4A460,\n\t'seagreen': 0x2E8B57,\n\t'seashell': 0xFFF5EE,\n\t'sienna': 0xA0522D,\n\t'silver': 0xC0C0C0,\n\t'skyblue': 0x87CEEB,\n\t'slateblue': 0x6A5ACD,\n\t'slategray': 0x708090,\n\t'slategrey': 0x708090,\n\t'snow': 0xFFFAFA,\n\t'springgreen': 0x00FF7F,\n\t'steelblue': 0x4682B4,\n\t'tan': 0xD2B48C,\n\t'teal': 0x008080,\n\t'thistle': 0xD8BFD8,\n\t'tomato': 0xFF6347,\n\t'turquoise': 0x40E0D0,\n\t'violet': 0xEE82EE,\n\t'wheat': 0xF5DEB3,\n\t'white': 0xFFFFFF,\n\t'whitesmoke': 0xF5F5F5,\n\t'yellow': 0xFFFF00,\n\t'yellowgreen': 0x9ACD32\n};\nconst _rgb = {\n\tr: 0,\n\tg: 0,\n\tb: 0\n};\nconst _hslA = {\n\th: 0,\n\ts: 0,\n\tl: 0\n};\nconst _hslB = {\n\th: 0,\n\ts: 0,\n\tl: 0\n};\n\nfunction hue2rgb(p, q, t) {\n\tif (t < 0) t += 1;\n\tif (t > 1) t -= 1;\n\tif (t < 1 / 6) return p + (q - p) * 6 * t;\n\tif (t < 1 / 2) return q;\n\tif (t < 2 / 3) return p + (q - p) * 6 * (2 / 3 - t);\n\treturn p;\n}\n\nfunction toComponents(source, target) {\n\ttarget.r = source.r;\n\ttarget.g = source.g;\n\ttarget.b = source.b;\n\treturn target;\n}\n\nclass Color {\n\tconstructor(r, g, b) {\n\t\tthis.isColor = true;\n\t\tthis.r = 1;\n\t\tthis.g = 1;\n\t\tthis.b = 1;\n\n\t\tif (g === undefined && b === undefined) {\n\t\t\t// r is THREE.Color, hex or string\n\t\t\treturn this.set(r);\n\t\t}\n\n\t\treturn this.setRGB(r, g, b);\n\t}\n\n\tset(value) {\n\t\tif (value && value.isColor) {\n\t\t\tthis.copy(value);\n\t\t} else if (typeof value === 'number') {\n\t\t\tthis.setHex(value);\n\t\t} else if (typeof value === 'string') {\n\t\t\tthis.setStyle(value);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tsetScalar(scalar) {\n\t\tthis.r = scalar;\n\t\tthis.g = scalar;\n\t\tthis.b = scalar;\n\t\treturn this;\n\t}\n\n\tsetHex(hex, colorSpace = SRGBColorSpace) {\n\t\thex = Math.floor(hex);\n\t\tthis.r = (hex >> 16 & 255) / 255;\n\t\tthis.g = (hex >> 8 & 255) / 255;\n\t\tthis.b = (hex & 255) / 255;\n\t\tColorManagement.toWorkingColorSpace(this, colorSpace);\n\t\treturn this;\n\t}\n\n\tsetRGB(r, g, b, colorSpace = LinearSRGBColorSpace) {\n\t\tthis.r = r;\n\t\tthis.g = g;\n\t\tthis.b = b;\n\t\tColorManagement.toWorkingColorSpace(this, colorSpace);\n\t\treturn this;\n\t}\n\n\tsetHSL(h, s, l, colorSpace = LinearSRGBColorSpace) {\n\t\t// h,s,l ranges are in 0.0 - 1.0\n\t\th = euclideanModulo(h, 1);\n\t\ts = clamp(s, 0, 1);\n\t\tl = clamp(l, 0, 1);\n\n\t\tif (s === 0) {\n\t\t\tthis.r = this.g = this.b = l;\n\t\t} else {\n\t\t\tconst p = l <= 0.5 ? l * (1 + s) : l + s - l * s;\n\t\t\tconst q = 2 * l - p;\n\t\t\tthis.r = hue2rgb(q, p, h + 1 / 3);\n\t\t\tthis.g = hue2rgb(q, p, h);\n\t\t\tthis.b = hue2rgb(q, p, h - 1 / 3);\n\t\t}\n\n\t\tColorManagement.toWorkingColorSpace(this, colorSpace);\n\t\treturn this;\n\t}\n\n\tsetStyle(style, colorSpace = SRGBColorSpace) {\n\t\tfunction handleAlpha(string) {\n\t\t\tif (string === undefined) return;\n\n\t\t\tif (parseFloat(string) < 1) {\n\t\t\t\tconsole.warn('THREE.Color: Alpha component of ' + style + ' will be ignored.');\n\t\t\t}\n\t\t}\n\n\t\tlet m;\n\n\t\tif (m = /^((?:rgb|hsl)a?)\\(([^\\)]*)\\)/.exec(style)) {\n\t\t\t// rgb / hsl\n\t\t\tlet color;\n\t\t\tconst name = m[1];\n\t\t\tconst components = m[2];\n\n\t\t\tswitch (name) {\n\t\t\t\tcase 'rgb':\n\t\t\t\tcase 'rgba':\n\t\t\t\t\tif (color = /^\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d+)\\s*(?:,\\s*(\\d*\\.?\\d+)\\s*)?$/.exec(components)) {\n\t\t\t\t\t\t// rgb(255,0,0) rgba(255,0,0,0.5)\n\t\t\t\t\t\tthis.r = Math.min(255, parseInt(color[1], 10)) / 255;\n\t\t\t\t\t\tthis.g = Math.min(255, parseInt(color[2], 10)) / 255;\n\t\t\t\t\t\tthis.b = Math.min(255, parseInt(color[3], 10)) / 255;\n\t\t\t\t\t\tColorManagement.toWorkingColorSpace(this, colorSpace);\n\t\t\t\t\t\thandleAlpha(color[4]);\n\t\t\t\t\t\treturn this;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (color = /^\\s*(\\d+)\\%\\s*,\\s*(\\d+)\\%\\s*,\\s*(\\d+)\\%\\s*(?:,\\s*(\\d*\\.?\\d+)\\s*)?$/.exec(components)) {\n\t\t\t\t\t\t// rgb(100%,0%,0%) rgba(100%,0%,0%,0.5)\n\t\t\t\t\t\tthis.r = Math.min(100, parseInt(color[1], 10)) / 100;\n\t\t\t\t\t\tthis.g = Math.min(100, parseInt(color[2], 10)) / 100;\n\t\t\t\t\t\tthis.b = Math.min(100, parseInt(color[3], 10)) / 100;\n\t\t\t\t\t\tColorManagement.toWorkingColorSpace(this, colorSpace);\n\t\t\t\t\t\thandleAlpha(color[4]);\n\t\t\t\t\t\treturn this;\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'hsl':\n\t\t\t\tcase 'hsla':\n\t\t\t\t\tif (color = /^\\s*(\\d*\\.?\\d+)\\s*,\\s*(\\d+)\\%\\s*,\\s*(\\d+)\\%\\s*(?:,\\s*(\\d*\\.?\\d+)\\s*)?$/.exec(components)) {\n\t\t\t\t\t\t// hsl(120,50%,50%) hsla(120,50%,50%,0.5)\n\t\t\t\t\t\tconst h = parseFloat(color[1]) / 360;\n\t\t\t\t\t\tconst s = parseInt(color[2], 10) / 100;\n\t\t\t\t\t\tconst l = parseInt(color[3], 10) / 100;\n\t\t\t\t\t\thandleAlpha(color[4]);\n\t\t\t\t\t\treturn this.setHSL(h, s, l, colorSpace);\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t} else if (m = /^\\#([A-Fa-f\\d]+)$/.exec(style)) {\n\t\t\t// hex color\n\t\t\tconst hex = m[1];\n\t\t\tconst size = hex.length;\n\n\t\t\tif (size === 3) {\n\t\t\t\t// #ff0\n\t\t\t\tthis.r = parseInt(hex.charAt(0) + hex.charAt(0), 16) / 255;\n\t\t\t\tthis.g = parseInt(hex.charAt(1) + hex.charAt(1), 16) / 255;\n\t\t\t\tthis.b = parseInt(hex.charAt(2) + hex.charAt(2), 16) / 255;\n\t\t\t\tColorManagement.toWorkingColorSpace(this, colorSpace);\n\t\t\t\treturn this;\n\t\t\t} else if (size === 6) {\n\t\t\t\t// #ff0000\n\t\t\t\tthis.r = parseInt(hex.charAt(0) + hex.charAt(1), 16) / 255;\n\t\t\t\tthis.g = parseInt(hex.charAt(2) + hex.charAt(3), 16) / 255;\n\t\t\t\tthis.b = parseInt(hex.charAt(4) + hex.charAt(5), 16) / 255;\n\t\t\t\tColorManagement.toWorkingColorSpace(this, colorSpace);\n\t\t\t\treturn this;\n\t\t\t}\n\t\t}\n\n\t\tif (style && style.length > 0) {\n\t\t\treturn this.setColorName(style, colorSpace);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tsetColorName(style, colorSpace = SRGBColorSpace) {\n\t\t// color keywords\n\t\tconst hex = _colorKeywords[style.toLowerCase()];\n\n\t\tif (hex !== undefined) {\n\t\t\t// red\n\t\t\tthis.setHex(hex, colorSpace);\n\t\t} else {\n\t\t\t// unknown color\n\t\t\tconsole.warn('THREE.Color: Unknown color ' + style);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor(this.r, this.g, this.b);\n\t}\n\n\tcopy(color) {\n\t\tthis.r = color.r;\n\t\tthis.g = color.g;\n\t\tthis.b = color.b;\n\t\treturn this;\n\t}\n\n\tcopySRGBToLinear(color) {\n\t\tthis.r = SRGBToLinear(color.r);\n\t\tthis.g = SRGBToLinear(color.g);\n\t\tthis.b = SRGBToLinear(color.b);\n\t\treturn this;\n\t}\n\n\tcopyLinearToSRGB(color) {\n\t\tthis.r = LinearToSRGB(color.r);\n\t\tthis.g = LinearToSRGB(color.g);\n\t\tthis.b = LinearToSRGB(color.b);\n\t\treturn this;\n\t}\n\n\tconvertSRGBToLinear() {\n\t\tthis.copySRGBToLinear(this);\n\t\treturn this;\n\t}\n\n\tconvertLinearToSRGB() {\n\t\tthis.copyLinearToSRGB(this);\n\t\treturn this;\n\t}\n\n\tgetHex(colorSpace = SRGBColorSpace) {\n\t\tColorManagement.fromWorkingColorSpace(toComponents(this, _rgb), colorSpace);\n\t\treturn clamp(_rgb.r * 255, 0, 255) << 16 ^ clamp(_rgb.g * 255, 0, 255) << 8 ^ clamp(_rgb.b * 255, 0, 255) << 0;\n\t}\n\n\tgetHexString(colorSpace = SRGBColorSpace) {\n\t\treturn ('000000' + this.getHex(colorSpace).toString(16)).slice(-6);\n\t}\n\n\tgetHSL(target, colorSpace = LinearSRGBColorSpace) {\n\t\t// h,s,l ranges are in 0.0 - 1.0\n\t\tColorManagement.fromWorkingColorSpace(toComponents(this, _rgb), colorSpace);\n\t\tconst r = _rgb.r,\n\t\t\t\t\tg = _rgb.g,\n\t\t\t\t\tb = _rgb.b;\n\t\tconst max = Math.max(r, g, b);\n\t\tconst min = Math.min(r, g, b);\n\t\tlet hue, saturation;\n\t\tconst lightness = (min + max) / 2.0;\n\n\t\tif (min === max) {\n\t\t\thue = 0;\n\t\t\tsaturation = 0;\n\t\t} else {\n\t\t\tconst delta = max - min;\n\t\t\tsaturation = lightness <= 0.5 ? delta / (max + min) : delta / (2 - max - min);\n\n\t\t\tswitch (max) {\n\t\t\t\tcase r:\n\t\t\t\t\thue = (g - b) / delta + (g < b ? 6 : 0);\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase g:\n\t\t\t\t\thue = (b - r) / delta + 2;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase b:\n\t\t\t\t\thue = (r - g) / delta + 4;\n\t\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\thue /= 6;\n\t\t}\n\n\t\ttarget.h = hue;\n\t\ttarget.s = saturation;\n\t\ttarget.l = lightness;\n\t\treturn target;\n\t}\n\n\tgetRGB(target, colorSpace = LinearSRGBColorSpace) {\n\t\tColorManagement.fromWorkingColorSpace(toComponents(this, _rgb), colorSpace);\n\t\ttarget.r = _rgb.r;\n\t\ttarget.g = _rgb.g;\n\t\ttarget.b = _rgb.b;\n\t\treturn target;\n\t}\n\n\tgetStyle(colorSpace = SRGBColorSpace) {\n\t\tColorManagement.fromWorkingColorSpace(toComponents(this, _rgb), colorSpace);\n\n\t\tif (colorSpace !== SRGBColorSpace) {\n\t\t\t// Requires CSS Color Module Level 4 (https://www.w3.org/TR/css-color-4/).\n\t\t\treturn `color(${colorSpace} ${_rgb.r} ${_rgb.g} ${_rgb.b})`;\n\t\t}\n\n\t\treturn `rgb(${_rgb.r * 255 | 0},${_rgb.g * 255 | 0},${_rgb.b * 255 | 0})`;\n\t}\n\n\toffsetHSL(h, s, l) {\n\t\tthis.getHSL(_hslA);\n\t\t_hslA.h += h;\n\t\t_hslA.s += s;\n\t\t_hslA.l += l;\n\t\tthis.setHSL(_hslA.h, _hslA.s, _hslA.l);\n\t\treturn this;\n\t}\n\n\tadd(color) {\n\t\tthis.r += color.r;\n\t\tthis.g += color.g;\n\t\tthis.b += color.b;\n\t\treturn this;\n\t}\n\n\taddColors(color1, color2) {\n\t\tthis.r = color1.r + color2.r;\n\t\tthis.g = color1.g + color2.g;\n\t\tthis.b = color1.b + color2.b;\n\t\treturn this;\n\t}\n\n\taddScalar(s) {\n\t\tthis.r += s;\n\t\tthis.g += s;\n\t\tthis.b += s;\n\t\treturn this;\n\t}\n\n\tsub(color) {\n\t\tthis.r = Math.max(0, this.r - color.r);\n\t\tthis.g = Math.max(0, this.g - color.g);\n\t\tthis.b = Math.max(0, this.b - color.b);\n\t\treturn this;\n\t}\n\n\tmultiply(color) {\n\t\tthis.r *= color.r;\n\t\tthis.g *= color.g;\n\t\tthis.b *= color.b;\n\t\treturn this;\n\t}\n\n\tmultiplyScalar(s) {\n\t\tthis.r *= s;\n\t\tthis.g *= s;\n\t\tthis.b *= s;\n\t\treturn this;\n\t}\n\n\tlerp(color, alpha) {\n\t\tthis.r += (color.r - this.r) * alpha;\n\t\tthis.g += (color.g - this.g) * alpha;\n\t\tthis.b += (color.b - this.b) * alpha;\n\t\treturn this;\n\t}\n\n\tlerpColors(color1, color2, alpha) {\n\t\tthis.r = color1.r + (color2.r - color1.r) * alpha;\n\t\tthis.g = color1.g + (color2.g - color1.g) * alpha;\n\t\tthis.b = color1.b + (color2.b - color1.b) * alpha;\n\t\treturn this;\n\t}\n\n\tlerpHSL(color, alpha) {\n\t\tthis.getHSL(_hslA);\n\t\tcolor.getHSL(_hslB);\n\t\tconst h = lerp(_hslA.h, _hslB.h, alpha);\n\t\tconst s = lerp(_hslA.s, _hslB.s, alpha);\n\t\tconst l = lerp(_hslA.l, _hslB.l, alpha);\n\t\tthis.setHSL(h, s, l);\n\t\treturn this;\n\t}\n\n\tequals(c) {\n\t\treturn c.r === this.r && c.g === this.g && c.b === this.b;\n\t}\n\n\tfromArray(array, offset = 0) {\n\t\tthis.r = array[offset];\n\t\tthis.g = array[offset + 1];\n\t\tthis.b = array[offset + 2];\n\t\treturn this;\n\t}\n\n\ttoArray(array = [], offset = 0) {\n\t\tarray[offset] = this.r;\n\t\tarray[offset + 1] = this.g;\n\t\tarray[offset + 2] = this.b;\n\t\treturn array;\n\t}\n\n\tfromBufferAttribute(attribute, index) {\n\t\tthis.r = attribute.getX(index);\n\t\tthis.g = attribute.getY(index);\n\t\tthis.b = attribute.getZ(index);\n\n\t\tif (attribute.normalized === true) {\n\t\t\t// assuming Uint8Array\n\t\t\tthis.r /= 255;\n\t\t\tthis.g /= 255;\n\t\t\tthis.b /= 255;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\treturn this.getHex();\n\t}\n\n\t*[Symbol.iterator]() {\n\t\tyield this.r;\n\t\tyield this.g;\n\t\tyield this.b;\n\t}\n\n}\n\nColor.NAMES = _colorKeywords;\n\nlet _canvas;\n\nclass ImageUtils {\n\tstatic getDataURL(image) {\n\t\tif (/^data:/i.test(image.src)) {\n\t\t\treturn image.src;\n\t\t}\n\n\t\tif (typeof HTMLCanvasElement == 'undefined') {\n\t\t\treturn image.src;\n\t\t}\n\n\t\tlet canvas;\n\n\t\tif (image instanceof HTMLCanvasElement) {\n\t\t\tcanvas = image;\n\t\t} else {\n\t\t\tif (_canvas === undefined) _canvas = createElementNS('canvas');\n\t\t\t_canvas.width = image.width;\n\t\t\t_canvas.height = image.height;\n\n\t\t\tconst context = _canvas.getContext('2d');\n\n\t\t\tif (image instanceof ImageData) {\n\t\t\t\tcontext.putImageData(image, 0, 0);\n\t\t\t} else {\n\t\t\t\tcontext.drawImage(image, 0, 0, image.width, image.height);\n\t\t\t}\n\n\t\t\tcanvas = _canvas;\n\t\t}\n\n\t\tif (canvas.width > 2048 || canvas.height > 2048) {\n\t\t\tconsole.warn('THREE.ImageUtils.getDataURL: Image converted to jpg for performance reasons', image);\n\t\t\treturn canvas.toDataURL('image/jpeg', 0.6);\n\t\t} else {\n\t\t\treturn canvas.toDataURL('image/png');\n\t\t}\n\t}\n\n\tstatic sRGBToLinear(image) {\n\t\tif (typeof HTMLImageElement !== 'undefined' && image instanceof HTMLImageElement || typeof HTMLCanvasElement !== 'undefined' && image instanceof HTMLCanvasElement || typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {\n\t\t\tconst canvas = createElementNS('canvas');\n\t\t\tcanvas.width = image.width;\n\t\t\tcanvas.height = image.height;\n\t\t\tconst context = canvas.getContext('2d');\n\t\t\tcontext.drawImage(image, 0, 0, image.width, image.height);\n\t\t\tconst imageData = context.getImageData(0, 0, image.width, image.height);\n\t\t\tconst data = imageData.data;\n\n\t\t\tfor (let i = 0; i < data.length; i++) {\n\t\t\t\tdata[i] = SRGBToLinear(data[i] / 255) * 255;\n\t\t\t}\n\n\t\t\tcontext.putImageData(imageData, 0, 0);\n\t\t\treturn canvas;\n\t\t} else if (image.data) {\n\t\t\tconst data = image.data.slice(0);\n\n\t\t\tfor (let i = 0; i < data.length; i++) {\n\t\t\t\tif (data instanceof Uint8Array || data instanceof Uint8ClampedArray) {\n\t\t\t\t\tdata[i] = Math.floor(SRGBToLinear(data[i] / 255) * 255);\n\t\t\t\t} else {\n\t\t\t\t\t// assuming float\n\t\t\t\t\tdata[i] = SRGBToLinear(data[i]);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn {\n\t\t\t\tdata: data,\n\t\t\t\twidth: image.width,\n\t\t\t\theight: image.height\n\t\t\t};\n\t\t} else {\n\t\t\tconsole.warn('THREE.ImageUtils.sRGBToLinear(): Unsupported image type. No color space conversion applied.');\n\t\t\treturn image;\n\t\t}\n\t}\n\n}\n\nclass Source {\n\tconstructor(data = null) {\n\t\tthis.isSource = true;\n\t\tthis.uuid = generateUUID();\n\t\tthis.data = data;\n\t\tthis.version = 0;\n\t}\n\n\tset needsUpdate(value) {\n\t\tif (value === true) this.version++;\n\t}\n\n\ttoJSON(meta) {\n\t\tconst isRootObject = meta === undefined || typeof meta === 'string';\n\n\t\tif (!isRootObject && meta.images[this.uuid] !== undefined) {\n\t\t\treturn meta.images[this.uuid];\n\t\t}\n\n\t\tconst output = {\n\t\t\tuuid: this.uuid,\n\t\t\turl: ''\n\t\t};\n\t\tconst data = this.data;\n\n\t\tif (data !== null) {\n\t\t\tlet url;\n\n\t\t\tif (Array.isArray(data)) {\n\t\t\t\t// cube texture\n\t\t\t\turl = [];\n\n\t\t\t\tfor (let i = 0, l = data.length; i < l; i++) {\n\t\t\t\t\tif (data[i].isDataTexture) {\n\t\t\t\t\t\turl.push(serializeImage(data[i].image));\n\t\t\t\t\t} else {\n\t\t\t\t\t\turl.push(serializeImage(data[i]));\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// texture\n\t\t\t\turl = serializeImage(data);\n\t\t\t}\n\n\t\t\toutput.url = url;\n\t\t}\n\n\t\tif (!isRootObject) {\n\t\t\tmeta.images[this.uuid] = output;\n\t\t}\n\n\t\treturn output;\n\t}\n\n}\n\nfunction serializeImage(image) {\n\tif (typeof HTMLImageElement !== 'undefined' && image instanceof HTMLImageElement || typeof HTMLCanvasElement !== 'undefined' && image instanceof HTMLCanvasElement || typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {\n\t\t// default images\n\t\treturn ImageUtils.getDataURL(image);\n\t} else {\n\t\tif (image.data) {\n\t\t\t// images of DataTexture\n\t\t\treturn {\n\t\t\t\tdata: Array.prototype.slice.call(image.data),\n\t\t\t\twidth: image.width,\n\t\t\t\theight: image.height,\n\t\t\t\ttype: image.data.constructor.name\n\t\t\t};\n\t\t} else {\n\t\t\tconsole.warn('THREE.Texture: Unable to serialize Texture.');\n\t\t\treturn {};\n\t\t}\n\t}\n}\n\nlet textureId = 0;\n\nclass Texture extends EventDispatcher {\n\tconstructor(image = Texture.DEFAULT_IMAGE, mapping = Texture.DEFAULT_MAPPING, wrapS = ClampToEdgeWrapping, wrapT = ClampToEdgeWrapping, magFilter = LinearFilter, minFilter = LinearMipmapLinearFilter, format = RGBAFormat, type = UnsignedByteType, anisotropy = 1, encoding = LinearEncoding) {\n\t\tsuper();\n\t\tthis.isTexture = true;\n\t\tObject.defineProperty(this, 'id', {\n\t\t\tvalue: textureId++\n\t\t});\n\t\tthis.uuid = generateUUID();\n\t\tthis.name = '';\n\t\tthis.source = new Source(image);\n\t\tthis.mipmaps = [];\n\t\tthis.mapping = mapping;\n\t\tthis.wrapS = wrapS;\n\t\tthis.wrapT = wrapT;\n\t\tthis.magFilter = magFilter;\n\t\tthis.minFilter = minFilter;\n\t\tthis.anisotropy = anisotropy;\n\t\tthis.format = format;\n\t\tthis.internalFormat = null;\n\t\tthis.type = type;\n\t\tthis.offset = new Vector2(0, 0);\n\t\tthis.repeat = new Vector2(1, 1);\n\t\tthis.center = new Vector2(0, 0);\n\t\tthis.rotation = 0;\n\t\tthis.matrixAutoUpdate = true;\n\t\tthis.matrix = new Matrix3();\n\t\tthis.generateMipmaps = true;\n\t\tthis.premultiplyAlpha = false;\n\t\tthis.flipY = true;\n\t\tthis.unpackAlignment = 4; // valid values: 1, 2, 4, 8 (see http://www.khronos.org/opengles/sdk/docs/man/xhtml/glPixelStorei.xml)\n\t\t// Values of encoding !== THREE.LinearEncoding only supported on map, envMap and emissiveMap.\n\t\t//\n\t\t// Also changing the encoding after already used by a Material will not automatically make the Material\n\t\t// update. You need to explicitly call Material.needsUpdate to trigger it to recompile.\n\n\t\tthis.encoding = encoding;\n\t\tthis.userData = {};\n\t\tthis.version = 0;\n\t\tthis.onUpdate = null;\n\t\tthis.isRenderTargetTexture = false; // indicates whether a texture belongs to a render target or not\n\n\t\tthis.needsPMREMUpdate = false; // indicates whether this texture should be processed by PMREMGenerator or not (only relevant for render target textures)\n\t}\n\n\tget image() {\n\t\treturn this.source.data;\n\t}\n\n\tset image(value) {\n\t\tthis.source.data = value;\n\t}\n\n\tupdateMatrix() {\n\t\tthis.matrix.setUvTransform(this.offset.x, this.offset.y, this.repeat.x, this.repeat.y, this.rotation, this.center.x, this.center.y);\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n\tcopy(source) {\n\t\tthis.name = source.name;\n\t\tthis.source = source.source;\n\t\tthis.mipmaps = source.mipmaps.slice(0);\n\t\tthis.mapping = source.mapping;\n\t\tthis.wrapS = source.wrapS;\n\t\tthis.wrapT = source.wrapT;\n\t\tthis.magFilter = source.magFilter;\n\t\tthis.minFilter = source.minFilter;\n\t\tthis.anisotropy = source.anisotropy;\n\t\tthis.format = source.format;\n\t\tthis.internalFormat = source.internalFormat;\n\t\tthis.type = source.type;\n\t\tthis.offset.copy(source.offset);\n\t\tthis.repeat.copy(source.repeat);\n\t\tthis.center.copy(source.center);\n\t\tthis.rotation = source.rotation;\n\t\tthis.matrixAutoUpdate = source.matrixAutoUpdate;\n\t\tthis.matrix.copy(source.matrix);\n\t\tthis.generateMipmaps = source.generateMipmaps;\n\t\tthis.premultiplyAlpha = source.premultiplyAlpha;\n\t\tthis.flipY = source.flipY;\n\t\tthis.unpackAlignment = source.unpackAlignment;\n\t\tthis.encoding = source.encoding;\n\t\tthis.userData = JSON.parse(JSON.stringify(source.userData));\n\t\tthis.needsUpdate = true;\n\t\treturn this;\n\t}\n\n\ttoJSON(meta) {\n\t\tconst isRootObject = meta === undefined || typeof meta === 'string';\n\n\t\tif (!isRootObject && meta.textures[this.uuid] !== undefined) {\n\t\t\treturn meta.textures[this.uuid];\n\t\t}\n\n\t\tconst output = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Texture',\n\t\t\t\tgenerator: 'Texture.toJSON'\n\t\t\t},\n\t\t\tuuid: this.uuid,\n\t\t\tname: this.name,\n\t\t\timage: this.source.toJSON(meta).uuid,\n\t\t\tmapping: this.mapping,\n\t\t\trepeat: [this.repeat.x, this.repeat.y],\n\t\t\toffset: [this.offset.x, this.offset.y],\n\t\t\tcenter: [this.center.x, this.center.y],\n\t\t\trotation: this.rotation,\n\t\t\twrap: [this.wrapS, this.wrapT],\n\t\t\tformat: this.format,\n\t\t\ttype: this.type,\n\t\t\tencoding: this.encoding,\n\t\t\tminFilter: this.minFilter,\n\t\t\tmagFilter: this.magFilter,\n\t\t\tanisotropy: this.anisotropy,\n\t\t\tflipY: this.flipY,\n\t\t\tpremultiplyAlpha: this.premultiplyAlpha,\n\t\t\tunpackAlignment: this.unpackAlignment\n\t\t};\n\t\tif (JSON.stringify(this.userData) !== '{}') output.userData = this.userData;\n\n\t\tif (!isRootObject) {\n\t\t\tmeta.textures[this.uuid] = output;\n\t\t}\n\n\t\treturn output;\n\t}\n\n\tdispose() {\n\t\tthis.dispatchEvent({\n\t\t\ttype: 'dispose'\n\t\t});\n\t}\n\n\ttransformUv(uv) {\n\t\tif (this.mapping !== UVMapping) return uv;\n\t\tuv.applyMatrix3(this.matrix);\n\n\t\tif (uv.x < 0 || uv.x > 1) {\n\t\t\tswitch (this.wrapS) {\n\t\t\t\tcase RepeatWrapping:\n\t\t\t\t\tuv.x = uv.x - Math.floor(uv.x);\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase ClampToEdgeWrapping:\n\t\t\t\t\tuv.x = uv.x < 0 ? 0 : 1;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase MirroredRepeatWrapping:\n\t\t\t\t\tif (Math.abs(Math.floor(uv.x) % 2) === 1) {\n\t\t\t\t\t\tuv.x = Math.ceil(uv.x) - uv.x;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tuv.x = uv.x - Math.floor(uv.x);\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tif (uv.y < 0 || uv.y > 1) {\n\t\t\tswitch (this.wrapT) {\n\t\t\t\tcase RepeatWrapping:\n\t\t\t\t\tuv.y = uv.y - Math.floor(uv.y);\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase ClampToEdgeWrapping:\n\t\t\t\t\tuv.y = uv.y < 0 ? 0 : 1;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase MirroredRepeatWrapping:\n\t\t\t\t\tif (Math.abs(Math.floor(uv.y) % 2) === 1) {\n\t\t\t\t\t\tuv.y = Math.ceil(uv.y) - uv.y;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tuv.y = uv.y - Math.floor(uv.y);\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tif (this.flipY) {\n\t\t\tuv.y = 1 - uv.y;\n\t\t}\n\n\t\treturn uv;\n\t}\n\n\tset needsUpdate(value) {\n\t\tif (value === true) {\n\t\t\tthis.version++;\n\t\t\tthis.source.needsUpdate = true;\n\t\t}\n\t}\n\n}\n\nTexture.DEFAULT_IMAGE = null;\nTexture.DEFAULT_MAPPING = UVMapping;\n\nclass Vector4 {\n\tconstructor(x = 0, y = 0, z = 0, w = 1) {\n\t\tthis.isVector4 = true;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.z = z;\n\t\tthis.w = w;\n\t}\n\n\tget width() {\n\t\treturn this.z;\n\t}\n\n\tset width(value) {\n\t\tthis.z = value;\n\t}\n\n\tget height() {\n\t\treturn this.w;\n\t}\n\n\tset height(value) {\n\t\tthis.w = value;\n\t}\n\n\tset(x, y, z, w) {\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.z = z;\n\t\tthis.w = w;\n\t\treturn this;\n\t}\n\n\tsetScalar(scalar) {\n\t\tthis.x = scalar;\n\t\tthis.y = scalar;\n\t\tthis.z = scalar;\n\t\tthis.w = scalar;\n\t\treturn this;\n\t}\n\n\tsetX(x) {\n\t\tthis.x = x;\n\t\treturn this;\n\t}\n\n\tsetY(y) {\n\t\tthis.y = y;\n\t\treturn this;\n\t}\n\n\tsetZ(z) {\n\t\tthis.z = z;\n\t\treturn this;\n\t}\n\n\tsetW(w) {\n\t\tthis.w = w;\n\t\treturn this;\n\t}\n\n\tsetComponent(index, value) {\n\t\tswitch (index) {\n\t\t\tcase 0:\n\t\t\t\tthis.x = value;\n\t\t\t\tbreak;\n\n\t\t\tcase 1:\n\t\t\t\tthis.y = value;\n\t\t\t\tbreak;\n\n\t\t\tcase 2:\n\t\t\t\tthis.z = value;\n\t\t\t\tbreak;\n\n\t\t\tcase 3:\n\t\t\t\tthis.w = value;\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tthrow new Error('index is out of range: ' + index);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tgetComponent(index) {\n\t\tswitch (index) {\n\t\t\tcase 0:\n\t\t\t\treturn this.x;\n\n\t\t\tcase 1:\n\t\t\t\treturn this.y;\n\n\t\t\tcase 2:\n\t\t\t\treturn this.z;\n\n\t\t\tcase 3:\n\t\t\t\treturn this.w;\n\n\t\t\tdefault:\n\t\t\t\tthrow new Error('index is out of range: ' + index);\n\t\t}\n\t}\n\n\tclone() {\n\t\treturn new this.constructor(this.x, this.y, this.z, this.w);\n\t}\n\n\tcopy(v) {\n\t\tthis.x = v.x;\n\t\tthis.y = v.y;\n\t\tthis.z = v.z;\n\t\tthis.w = v.w !== undefined ? v.w : 1;\n\t\treturn this;\n\t}\n\n\tadd(v, w) {\n\t\tif (w !== undefined) {\n\t\t\tconsole.warn('THREE.Vector4: .add() now only accepts one argument. Use .addVectors( a, b ) instead.');\n\t\t\treturn this.addVectors(v, w);\n\t\t}\n\n\t\tthis.x += v.x;\n\t\tthis.y += v.y;\n\t\tthis.z += v.z;\n\t\tthis.w += v.w;\n\t\treturn this;\n\t}\n\n\taddScalar(s) {\n\t\tthis.x += s;\n\t\tthis.y += s;\n\t\tthis.z += s;\n\t\tthis.w += s;\n\t\treturn this;\n\t}\n\n\taddVectors(a, b) {\n\t\tthis.x = a.x + b.x;\n\t\tthis.y = a.y + b.y;\n\t\tthis.z = a.z + b.z;\n\t\tthis.w = a.w + b.w;\n\t\treturn this;\n\t}\n\n\taddScaledVector(v, s) {\n\t\tthis.x += v.x * s;\n\t\tthis.y += v.y * s;\n\t\tthis.z += v.z * s;\n\t\tthis.w += v.w * s;\n\t\treturn this;\n\t}\n\n\tsub(v, w) {\n\t\tif (w !== undefined) {\n\t\t\tconsole.warn('THREE.Vector4: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.');\n\t\t\treturn this.subVectors(v, w);\n\t\t}\n\n\t\tthis.x -= v.x;\n\t\tthis.y -= v.y;\n\t\tthis.z -= v.z;\n\t\tthis.w -= v.w;\n\t\treturn this;\n\t}\n\n\tsubScalar(s) {\n\t\tthis.x -= s;\n\t\tthis.y -= s;\n\t\tthis.z -= s;\n\t\tthis.w -= s;\n\t\treturn this;\n\t}\n\n\tsubVectors(a, b) {\n\t\tthis.x = a.x - b.x;\n\t\tthis.y = a.y - b.y;\n\t\tthis.z = a.z - b.z;\n\t\tthis.w = a.w - b.w;\n\t\treturn this;\n\t}\n\n\tmultiply(v) {\n\t\tthis.x *= v.x;\n\t\tthis.y *= v.y;\n\t\tthis.z *= v.z;\n\t\tthis.w *= v.w;\n\t\treturn this;\n\t}\n\n\tmultiplyScalar(scalar) {\n\t\tthis.x *= scalar;\n\t\tthis.y *= scalar;\n\t\tthis.z *= scalar;\n\t\tthis.w *= scalar;\n\t\treturn this;\n\t}\n\n\tapplyMatrix4(m) {\n\t\tconst x = this.x,\n\t\t\t\t\ty = this.y,\n\t\t\t\t\tz = this.z,\n\t\t\t\t\tw = this.w;\n\t\tconst e = m.elements;\n\t\tthis.x = e[0] * x + e[4] * y + e[8] * z + e[12] * w;\n\t\tthis.y = e[1] * x + e[5] * y + e[9] * z + e[13] * w;\n\t\tthis.z = e[2] * x + e[6] * y + e[10] * z + e[14] * w;\n\t\tthis.w = e[3] * x + e[7] * y + e[11] * z + e[15] * w;\n\t\treturn this;\n\t}\n\n\tdivideScalar(scalar) {\n\t\treturn this.multiplyScalar(1 / scalar);\n\t}\n\n\tsetAxisAngleFromQuaternion(q) {\n\t\t// http://www.euclideanspace.com/maths/geometry/rotations/conversions/quaternionToAngle/index.htm\n\t\t// q is assumed to be normalized\n\t\tthis.w = 2 * Math.acos(q.w);\n\t\tconst s = Math.sqrt(1 - q.w * q.w);\n\n\t\tif (s < 0.0001) {\n\t\t\tthis.x = 1;\n\t\t\tthis.y = 0;\n\t\t\tthis.z = 0;\n\t\t} else {\n\t\t\tthis.x = q.x / s;\n\t\t\tthis.y = q.y / s;\n\t\t\tthis.z = q.z / s;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tsetAxisAngleFromRotationMatrix(m) {\n\t\t// http://www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToAngle/index.htm\n\t\t// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n\t\tlet angle, x, y, z; // variables for result\n\n\t\tconst epsilon = 0.01,\n\t\t\t\t\t// margin to allow for rounding errors\n\t\tepsilon2 = 0.1,\n\t\t\t\t\t// margin to distinguish between 0 and 180 degrees\n\t\tte = m.elements,\n\t\t\t\t\tm11 = te[0],\n\t\t\t\t\tm12 = te[4],\n\t\t\t\t\tm13 = te[8],\n\t\t\t\t\tm21 = te[1],\n\t\t\t\t\tm22 = te[5],\n\t\t\t\t\tm23 = te[9],\n\t\t\t\t\tm31 = te[2],\n\t\t\t\t\tm32 = te[6],\n\t\t\t\t\tm33 = te[10];\n\n\t\tif (Math.abs(m12 - m21) < epsilon && Math.abs(m13 - m31) < epsilon && Math.abs(m23 - m32) < epsilon) {\n\t\t\t// singularity found\n\t\t\t// first check for identity matrix which must have +1 for all terms\n\t\t\t// in leading diagonal and zero in other terms\n\t\t\tif (Math.abs(m12 + m21) < epsilon2 && Math.abs(m13 + m31) < epsilon2 && Math.abs(m23 + m32) < epsilon2 && Math.abs(m11 + m22 + m33 - 3) < epsilon2) {\n\t\t\t\t// this singularity is identity matrix so angle = 0\n\t\t\t\tthis.set(1, 0, 0, 0);\n\t\t\t\treturn this; // zero angle, arbitrary axis\n\t\t\t} // otherwise this singularity is angle = 180\n\n\n\t\t\tangle = Math.PI;\n\t\t\tconst xx = (m11 + 1) / 2;\n\t\t\tconst yy = (m22 + 1) / 2;\n\t\t\tconst zz = (m33 + 1) / 2;\n\t\t\tconst xy = (m12 + m21) / 4;\n\t\t\tconst xz = (m13 + m31) / 4;\n\t\t\tconst yz = (m23 + m32) / 4;\n\n\t\t\tif (xx > yy && xx > zz) {\n\t\t\t\t// m11 is the largest diagonal term\n\t\t\t\tif (xx < epsilon) {\n\t\t\t\t\tx = 0;\n\t\t\t\t\ty = 0.707106781;\n\t\t\t\t\tz = 0.707106781;\n\t\t\t\t} else {\n\t\t\t\t\tx = Math.sqrt(xx);\n\t\t\t\t\ty = xy / x;\n\t\t\t\t\tz = xz / x;\n\t\t\t\t}\n\t\t\t} else if (yy > zz) {\n\t\t\t\t// m22 is the largest diagonal term\n\t\t\t\tif (yy < epsilon) {\n\t\t\t\t\tx = 0.707106781;\n\t\t\t\t\ty = 0;\n\t\t\t\t\tz = 0.707106781;\n\t\t\t\t} else {\n\t\t\t\t\ty = Math.sqrt(yy);\n\t\t\t\t\tx = xy / y;\n\t\t\t\t\tz = yz / y;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// m33 is the largest diagonal term so base result on this\n\t\t\t\tif (zz < epsilon) {\n\t\t\t\t\tx = 0.707106781;\n\t\t\t\t\ty = 0.707106781;\n\t\t\t\t\tz = 0;\n\t\t\t\t} else {\n\t\t\t\t\tz = Math.sqrt(zz);\n\t\t\t\t\tx = xz / z;\n\t\t\t\t\ty = yz / z;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.set(x, y, z, angle);\n\t\t\treturn this; // return 180 deg rotation\n\t\t} // as we have reached here there are no singularities so we can handle normally\n\n\n\t\tlet s = Math.sqrt((m32 - m23) * (m32 - m23) + (m13 - m31) * (m13 - m31) + (m21 - m12) * (m21 - m12)); // used to normalize\n\n\t\tif (Math.abs(s) < 0.001) s = 1; // prevent divide by zero, should not happen if matrix is orthogonal and should be\n\t\t// caught by singularity test above, but I've left it in just in case\n\n\t\tthis.x = (m32 - m23) / s;\n\t\tthis.y = (m13 - m31) / s;\n\t\tthis.z = (m21 - m12) / s;\n\t\tthis.w = Math.acos((m11 + m22 + m33 - 1) / 2);\n\t\treturn this;\n\t}\n\n\tmin(v) {\n\t\tthis.x = Math.min(this.x, v.x);\n\t\tthis.y = Math.min(this.y, v.y);\n\t\tthis.z = Math.min(this.z, v.z);\n\t\tthis.w = Math.min(this.w, v.w);\n\t\treturn this;\n\t}\n\n\tmax(v) {\n\t\tthis.x = Math.max(this.x, v.x);\n\t\tthis.y = Math.max(this.y, v.y);\n\t\tthis.z = Math.max(this.z, v.z);\n\t\tthis.w = Math.max(this.w, v.w);\n\t\treturn this;\n\t}\n\n\tclamp(min, max) {\n\t\t// assumes min < max, componentwise\n\t\tthis.x = Math.max(min.x, Math.min(max.x, this.x));\n\t\tthis.y = Math.max(min.y, Math.min(max.y, this.y));\n\t\tthis.z = Math.max(min.z, Math.min(max.z, this.z));\n\t\tthis.w = Math.max(min.w, Math.min(max.w, this.w));\n\t\treturn this;\n\t}\n\n\tclampScalar(minVal, maxVal) {\n\t\tthis.x = Math.max(minVal, Math.min(maxVal, this.x));\n\t\tthis.y = Math.max(minVal, Math.min(maxVal, this.y));\n\t\tthis.z = Math.max(minVal, Math.min(maxVal, this.z));\n\t\tthis.w = Math.max(minVal, Math.min(maxVal, this.w));\n\t\treturn this;\n\t}\n\n\tclampLength(min, max) {\n\t\tconst length = this.length();\n\t\treturn this.divideScalar(length || 1).multiplyScalar(Math.max(min, Math.min(max, length)));\n\t}\n\n\tfloor() {\n\t\tthis.x = Math.floor(this.x);\n\t\tthis.y = Math.floor(this.y);\n\t\tthis.z = Math.floor(this.z);\n\t\tthis.w = Math.floor(this.w);\n\t\treturn this;\n\t}\n\n\tceil() {\n\t\tthis.x = Math.ceil(this.x);\n\t\tthis.y = Math.ceil(this.y);\n\t\tthis.z = Math.ceil(this.z);\n\t\tthis.w = Math.ceil(this.w);\n\t\treturn this;\n\t}\n\n\tround() {\n\t\tthis.x = Math.round(this.x);\n\t\tthis.y = Math.round(this.y);\n\t\tthis.z = Math.round(this.z);\n\t\tthis.w = Math.round(this.w);\n\t\treturn this;\n\t}\n\n\troundToZero() {\n\t\tthis.x = this.x < 0 ? Math.ceil(this.x) : Math.floor(this.x);\n\t\tthis.y = this.y < 0 ? Math.ceil(this.y) : Math.floor(this.y);\n\t\tthis.z = this.z < 0 ? Math.ceil(this.z) : Math.floor(this.z);\n\t\tthis.w = this.w < 0 ? Math.ceil(this.w) : Math.floor(this.w);\n\t\treturn this;\n\t}\n\n\tnegate() {\n\t\tthis.x = -this.x;\n\t\tthis.y = -this.y;\n\t\tthis.z = -this.z;\n\t\tthis.w = -this.w;\n\t\treturn this;\n\t}\n\n\tdot(v) {\n\t\treturn this.x * v.x + this.y * v.y + this.z * v.z + this.w * v.w;\n\t}\n\n\tlengthSq() {\n\t\treturn this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w;\n\t}\n\n\tlength() {\n\t\treturn Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w);\n\t}\n\n\tmanhattanLength() {\n\t\treturn Math.abs(this.x) + Math.abs(this.y) + Math.abs(this.z) + Math.abs(this.w);\n\t}\n\n\tnormalize() {\n\t\treturn this.divideScalar(this.length() || 1);\n\t}\n\n\tsetLength(length) {\n\t\treturn this.normalize().multiplyScalar(length);\n\t}\n\n\tlerp(v, alpha) {\n\t\tthis.x += (v.x - this.x) * alpha;\n\t\tthis.y += (v.y - this.y) * alpha;\n\t\tthis.z += (v.z - this.z) * alpha;\n\t\tthis.w += (v.w - this.w) * alpha;\n\t\treturn this;\n\t}\n\n\tlerpVectors(v1, v2, alpha) {\n\t\tthis.x = v1.x + (v2.x - v1.x) * alpha;\n\t\tthis.y = v1.y + (v2.y - v1.y) * alpha;\n\t\tthis.z = v1.z + (v2.z - v1.z) * alpha;\n\t\tthis.w = v1.w + (v2.w - v1.w) * alpha;\n\t\treturn this;\n\t}\n\n\tequals(v) {\n\t\treturn v.x === this.x && v.y === this.y && v.z === this.z && v.w === this.w;\n\t}\n\n\tfromArray(array, offset = 0) {\n\t\tthis.x = array[offset];\n\t\tthis.y = array[offset + 1];\n\t\tthis.z = array[offset + 2];\n\t\tthis.w = array[offset + 3];\n\t\treturn this;\n\t}\n\n\ttoArray(array = [], offset = 0) {\n\t\tarray[offset] = this.x;\n\t\tarray[offset + 1] = this.y;\n\t\tarray[offset + 2] = this.z;\n\t\tarray[offset + 3] = this.w;\n\t\treturn array;\n\t}\n\n\tfromBufferAttribute(attribute, index, offset) {\n\t\tif (offset !== undefined) {\n\t\t\tconsole.warn('THREE.Vector4: offset has been removed from .fromBufferAttribute().');\n\t\t}\n\n\t\tthis.x = attribute.getX(index);\n\t\tthis.y = attribute.getY(index);\n\t\tthis.z = attribute.getZ(index);\n\t\tthis.w = attribute.getW(index);\n\t\treturn this;\n\t}\n\n\trandom() {\n\t\tthis.x = Math.random();\n\t\tthis.y = Math.random();\n\t\tthis.z = Math.random();\n\t\tthis.w = Math.random();\n\t\treturn this;\n\t}\n\n\t*[Symbol.iterator]() {\n\t\tyield this.x;\n\t\tyield this.y;\n\t\tyield this.z;\n\t\tyield this.w;\n\t}\n\n}\n\n/*\n In options, we can specify:\n * Texture parameters for an auto-generated target texture\n * depthBuffer/stencilBuffer: Booleans to indicate if we should generate these buffers\n*/\n\nclass WebGLRenderTarget extends EventDispatcher {\n\tconstructor(width, height, options = {}) {\n\t\tsuper();\n\t\tthis.isWebGLRenderTarget = true;\n\t\tthis.width = width;\n\t\tthis.height = height;\n\t\tthis.depth = 1;\n\t\tthis.scissor = new Vector4(0, 0, width, height);\n\t\tthis.scissorTest = false;\n\t\tthis.viewport = new Vector4(0, 0, width, height);\n\t\tconst image = {\n\t\t\twidth: width,\n\t\t\theight: height,\n\t\t\tdepth: 1\n\t\t};\n\t\tthis.texture = new Texture(image, options.mapping, options.wrapS, options.wrapT, options.magFilter, options.minFilter, options.format, options.type, options.anisotropy, options.encoding);\n\t\tthis.texture.isRenderTargetTexture = true;\n\t\tthis.texture.flipY = false;\n\t\tthis.texture.generateMipmaps = options.generateMipmaps !== undefined ? options.generateMipmaps : false;\n\t\tthis.texture.internalFormat = options.internalFormat !== undefined ? options.internalFormat : null;\n\t\tthis.texture.minFilter = options.minFilter !== undefined ? options.minFilter : LinearFilter;\n\t\tthis.depthBuffer = options.depthBuffer !== undefined ? options.depthBuffer : true;\n\t\tthis.stencilBuffer = options.stencilBuffer !== undefined ? options.stencilBuffer : false;\n\t\tthis.depthTexture = options.depthTexture !== undefined ? options.depthTexture : null;\n\t\tthis.samples = options.samples !== undefined ? options.samples : 0;\n\t}\n\n\tsetSize(width, height, depth = 1) {\n\t\tif (this.width !== width || this.height !== height || this.depth !== depth) {\n\t\t\tthis.width = width;\n\t\t\tthis.height = height;\n\t\t\tthis.depth = depth;\n\t\t\tthis.texture.image.width = width;\n\t\t\tthis.texture.image.height = height;\n\t\t\tthis.texture.image.depth = depth;\n\t\t\tthis.dispose();\n\t\t}\n\n\t\tthis.viewport.set(0, 0, width, height);\n\t\tthis.scissor.set(0, 0, width, height);\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n\tcopy(source) {\n\t\tthis.width = source.width;\n\t\tthis.height = source.height;\n\t\tthis.depth = source.depth;\n\t\tthis.viewport.copy(source.viewport);\n\t\tthis.texture = source.texture.clone();\n\t\tthis.texture.isRenderTargetTexture = true; // ensure image object is not shared, see #20328\n\n\t\tconst image = Object.assign({}, source.texture.image);\n\t\tthis.texture.source = new Source(image);\n\t\tthis.depthBuffer = source.depthBuffer;\n\t\tthis.stencilBuffer = source.stencilBuffer;\n\t\tif (source.depthTexture !== null) this.depthTexture = source.depthTexture.clone();\n\t\tthis.samples = source.samples;\n\t\treturn this;\n\t}\n\n\tdispose() {\n\t\tthis.dispatchEvent({\n\t\t\ttype: 'dispose'\n\t\t});\n\t}\n\n}\n\nclass DataArrayTexture extends Texture {\n\tconstructor(data = null, width = 1, height = 1, depth = 1) {\n\t\tsuper(null);\n\t\tthis.isDataArrayTexture = true;\n\t\tthis.image = {\n\t\t\tdata,\n\t\t\twidth,\n\t\t\theight,\n\t\t\tdepth\n\t\t};\n\t\tthis.magFilter = NearestFilter;\n\t\tthis.minFilter = NearestFilter;\n\t\tthis.wrapR = ClampToEdgeWrapping;\n\t\tthis.generateMipmaps = false;\n\t\tthis.flipY = false;\n\t\tthis.unpackAlignment = 1;\n\t}\n\n}\n\nclass WebGLArrayRenderTarget extends WebGLRenderTarget {\n\tconstructor(width, height, depth) {\n\t\tsuper(width, height);\n\t\tthis.isWebGLArrayRenderTarget = true;\n\t\tthis.depth = depth;\n\t\tthis.texture = new DataArrayTexture(null, width, height, depth);\n\t\tthis.texture.isRenderTargetTexture = true;\n\t}\n\n}\n\nclass Data3DTexture extends Texture {\n\tconstructor(data = null, width = 1, height = 1, depth = 1) {\n\t\t// We're going to add .setXXX() methods for setting properties later.\n\t\t// Users can still set in DataTexture3D directly.\n\t\t//\n\t\t//\tconst texture = new THREE.DataTexture3D( data, width, height, depth );\n\t\t// \ttexture.anisotropy = 16;\n\t\t//\n\t\t// See #14839\n\t\tsuper(null);\n\t\tthis.isData3DTexture = true;\n\t\tthis.image = {\n\t\t\tdata,\n\t\t\twidth,\n\t\t\theight,\n\t\t\tdepth\n\t\t};\n\t\tthis.magFilter = NearestFilter;\n\t\tthis.minFilter = NearestFilter;\n\t\tthis.wrapR = ClampToEdgeWrapping;\n\t\tthis.generateMipmaps = false;\n\t\tthis.flipY = false;\n\t\tthis.unpackAlignment = 1;\n\t}\n\n}\n\nclass WebGL3DRenderTarget extends WebGLRenderTarget {\n\tconstructor(width, height, depth) {\n\t\tsuper(width, height);\n\t\tthis.isWebGL3DRenderTarget = true;\n\t\tthis.depth = depth;\n\t\tthis.texture = new Data3DTexture(null, width, height, depth);\n\t\tthis.texture.isRenderTargetTexture = true;\n\t}\n\n}\n\nclass WebGLMultipleRenderTargets extends WebGLRenderTarget {\n\tconstructor(width, height, count, options = {}) {\n\t\tsuper(width, height, options);\n\t\tthis.isWebGLMultipleRenderTargets = true;\n\t\tconst texture = this.texture;\n\t\tthis.texture = [];\n\n\t\tfor (let i = 0; i < count; i++) {\n\t\t\tthis.texture[i] = texture.clone();\n\t\t\tthis.texture[i].isRenderTargetTexture = true;\n\t\t}\n\t}\n\n\tsetSize(width, height, depth = 1) {\n\t\tif (this.width !== width || this.height !== height || this.depth !== depth) {\n\t\t\tthis.width = width;\n\t\t\tthis.height = height;\n\t\t\tthis.depth = depth;\n\n\t\t\tfor (let i = 0, il = this.texture.length; i < il; i++) {\n\t\t\t\tthis.texture[i].image.width = width;\n\t\t\t\tthis.texture[i].image.height = height;\n\t\t\t\tthis.texture[i].image.depth = depth;\n\t\t\t}\n\n\t\t\tthis.dispose();\n\t\t}\n\n\t\tthis.viewport.set(0, 0, width, height);\n\t\tthis.scissor.set(0, 0, width, height);\n\t\treturn this;\n\t}\n\n\tcopy(source) {\n\t\tthis.dispose();\n\t\tthis.width = source.width;\n\t\tthis.height = source.height;\n\t\tthis.depth = source.depth;\n\t\tthis.viewport.set(0, 0, this.width, this.height);\n\t\tthis.scissor.set(0, 0, this.width, this.height);\n\t\tthis.depthBuffer = source.depthBuffer;\n\t\tthis.stencilBuffer = source.stencilBuffer;\n\t\tif (source.depthTexture !== null) this.depthTexture = source.depthTexture.clone();\n\t\tthis.texture.length = 0;\n\n\t\tfor (let i = 0, il = source.texture.length; i < il; i++) {\n\t\t\tthis.texture[i] = source.texture[i].clone();\n\t\t\tthis.texture[i].isRenderTargetTexture = true;\n\t\t}\n\n\t\treturn this;\n\t}\n\n}\n\nclass Quaternion {\n\tconstructor(x = 0, y = 0, z = 0, w = 1) {\n\t\tthis.isQuaternion = true;\n\t\tthis._x = x;\n\t\tthis._y = y;\n\t\tthis._z = z;\n\t\tthis._w = w;\n\t}\n\n\tstatic slerp(qa, qb, qm, t) {\n\t\tconsole.warn('THREE.Quaternion: Static .slerp() has been deprecated. Use qm.slerpQuaternions( qa, qb, t ) instead.');\n\t\treturn qm.slerpQuaternions(qa, qb, t);\n\t}\n\n\tstatic slerpFlat(dst, dstOffset, src0, srcOffset0, src1, srcOffset1, t) {\n\t\t// fuzz-free, array-based Quaternion SLERP operation\n\t\tlet x0 = src0[srcOffset0 + 0],\n\t\t\t\ty0 = src0[srcOffset0 + 1],\n\t\t\t\tz0 = src0[srcOffset0 + 2],\n\t\t\t\tw0 = src0[srcOffset0 + 3];\n\t\tconst x1 = src1[srcOffset1 + 0],\n\t\t\t\t\ty1 = src1[srcOffset1 + 1],\n\t\t\t\t\tz1 = src1[srcOffset1 + 2],\n\t\t\t\t\tw1 = src1[srcOffset1 + 3];\n\n\t\tif (t === 0) {\n\t\t\tdst[dstOffset + 0] = x0;\n\t\t\tdst[dstOffset + 1] = y0;\n\t\t\tdst[dstOffset + 2] = z0;\n\t\t\tdst[dstOffset + 3] = w0;\n\t\t\treturn;\n\t\t}\n\n\t\tif (t === 1) {\n\t\t\tdst[dstOffset + 0] = x1;\n\t\t\tdst[dstOffset + 1] = y1;\n\t\t\tdst[dstOffset + 2] = z1;\n\t\t\tdst[dstOffset + 3] = w1;\n\t\t\treturn;\n\t\t}\n\n\t\tif (w0 !== w1 || x0 !== x1 || y0 !== y1 || z0 !== z1) {\n\t\t\tlet s = 1 - t;\n\t\t\tconst cos = x0 * x1 + y0 * y1 + z0 * z1 + w0 * w1,\n\t\t\t\t\t\tdir = cos >= 0 ? 1 : -1,\n\t\t\t\t\t\tsqrSin = 1 - cos * cos; // Skip the Slerp for tiny steps to avoid numeric problems:\n\n\t\t\tif (sqrSin > Number.EPSILON) {\n\t\t\t\tconst sin = Math.sqrt(sqrSin),\n\t\t\t\t\t\t\tlen = Math.atan2(sin, cos * dir);\n\t\t\t\ts = Math.sin(s * len) / sin;\n\t\t\t\tt = Math.sin(t * len) / sin;\n\t\t\t}\n\n\t\t\tconst tDir = t * dir;\n\t\t\tx0 = x0 * s + x1 * tDir;\n\t\t\ty0 = y0 * s + y1 * tDir;\n\t\t\tz0 = z0 * s + z1 * tDir;\n\t\t\tw0 = w0 * s + w1 * tDir; // Normalize in case we just did a lerp:\n\n\t\t\tif (s === 1 - t) {\n\t\t\t\tconst f = 1 / Math.sqrt(x0 * x0 + y0 * y0 + z0 * z0 + w0 * w0);\n\t\t\t\tx0 *= f;\n\t\t\t\ty0 *= f;\n\t\t\t\tz0 *= f;\n\t\t\t\tw0 *= f;\n\t\t\t}\n\t\t}\n\n\t\tdst[dstOffset] = x0;\n\t\tdst[dstOffset + 1] = y0;\n\t\tdst[dstOffset + 2] = z0;\n\t\tdst[dstOffset + 3] = w0;\n\t}\n\n\tstatic multiplyQuaternionsFlat(dst, dstOffset, src0, srcOffset0, src1, srcOffset1) {\n\t\tconst x0 = src0[srcOffset0];\n\t\tconst y0 = src0[srcOffset0 + 1];\n\t\tconst z0 = src0[srcOffset0 + 2];\n\t\tconst w0 = src0[srcOffset0 + 3];\n\t\tconst x1 = src1[srcOffset1];\n\t\tconst y1 = src1[srcOffset1 + 1];\n\t\tconst z1 = src1[srcOffset1 + 2];\n\t\tconst w1 = src1[srcOffset1 + 3];\n\t\tdst[dstOffset] = x0 * w1 + w0 * x1 + y0 * z1 - z0 * y1;\n\t\tdst[dstOffset + 1] = y0 * w1 + w0 * y1 + z0 * x1 - x0 * z1;\n\t\tdst[dstOffset + 2] = z0 * w1 + w0 * z1 + x0 * y1 - y0 * x1;\n\t\tdst[dstOffset + 3] = w0 * w1 - x0 * x1 - y0 * y1 - z0 * z1;\n\t\treturn dst;\n\t}\n\n\tget x() {\n\t\treturn this._x;\n\t}\n\n\tset x(value) {\n\t\tthis._x = value;\n\n\t\tthis._onChangeCallback();\n\t}\n\n\tget y() {\n\t\treturn this._y;\n\t}\n\n\tset y(value) {\n\t\tthis._y = value;\n\n\t\tthis._onChangeCallback();\n\t}\n\n\tget z() {\n\t\treturn this._z;\n\t}\n\n\tset z(value) {\n\t\tthis._z = value;\n\n\t\tthis._onChangeCallback();\n\t}\n\n\tget w() {\n\t\treturn this._w;\n\t}\n\n\tset w(value) {\n\t\tthis._w = value;\n\n\t\tthis._onChangeCallback();\n\t}\n\n\tset(x, y, z, w) {\n\t\tthis._x = x;\n\t\tthis._y = y;\n\t\tthis._z = z;\n\t\tthis._w = w;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor(this._x, this._y, this._z, this._w);\n\t}\n\n\tcopy(quaternion) {\n\t\tthis._x = quaternion.x;\n\t\tthis._y = quaternion.y;\n\t\tthis._z = quaternion.z;\n\t\tthis._w = quaternion.w;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\t}\n\n\tsetFromEuler(euler, update) {\n\t\tif (!(euler && euler.isEuler)) {\n\t\t\tthrow new Error('THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order.');\n\t\t}\n\n\t\tconst x = euler._x,\n\t\t\t\t\ty = euler._y,\n\t\t\t\t\tz = euler._z,\n\t\t\t\t\torder = euler._order; // http://www.mathworks.com/matlabcentral/fileexchange/\n\t\t// \t20696-function-to-convert-between-dcm-euler-angles-quaternions-and-euler-vectors/\n\t\t//\tcontent/SpinCalc.m\n\n\t\tconst cos = Math.cos;\n\t\tconst sin = Math.sin;\n\t\tconst c1 = cos(x / 2);\n\t\tconst c2 = cos(y / 2);\n\t\tconst c3 = cos(z / 2);\n\t\tconst s1 = sin(x / 2);\n\t\tconst s2 = sin(y / 2);\n\t\tconst s3 = sin(z / 2);\n\n\t\tswitch (order) {\n\t\t\tcase 'XYZ':\n\t\t\t\tthis._x = s1 * c2 * c3 + c1 * s2 * s3;\n\t\t\t\tthis._y = c1 * s2 * c3 - s1 * c2 * s3;\n\t\t\t\tthis._z = c1 * c2 * s3 + s1 * s2 * c3;\n\t\t\t\tthis._w = c1 * c2 * c3 - s1 * s2 * s3;\n\t\t\t\tbreak;\n\n\t\t\tcase 'YXZ':\n\t\t\t\tthis._x = s1 * c2 * c3 + c1 * s2 * s3;\n\t\t\t\tthis._y = c1 * s2 * c3 - s1 * c2 * s3;\n\t\t\t\tthis._z = c1 * c2 * s3 - s1 * s2 * c3;\n\t\t\t\tthis._w = c1 * c2 * c3 + s1 * s2 * s3;\n\t\t\t\tbreak;\n\n\t\t\tcase 'ZXY':\n\t\t\t\tthis._x = s1 * c2 * c3 - c1 * s2 * s3;\n\t\t\t\tthis._y = c1 * s2 * c3 + s1 * c2 * s3;\n\t\t\t\tthis._z = c1 * c2 * s3 + s1 * s2 * c3;\n\t\t\t\tthis._w = c1 * c2 * c3 - s1 * s2 * s3;\n\t\t\t\tbreak;\n\n\t\t\tcase 'ZYX':\n\t\t\t\tthis._x = s1 * c2 * c3 - c1 * s2 * s3;\n\t\t\t\tthis._y = c1 * s2 * c3 + s1 * c2 * s3;\n\t\t\t\tthis._z = c1 * c2 * s3 - s1 * s2 * c3;\n\t\t\t\tthis._w = c1 * c2 * c3 + s1 * s2 * s3;\n\t\t\t\tbreak;\n\n\t\t\tcase 'YZX':\n\t\t\t\tthis._x = s1 * c2 * c3 + c1 * s2 * s3;\n\t\t\t\tthis._y = c1 * s2 * c3 + s1 * c2 * s3;\n\t\t\t\tthis._z = c1 * c2 * s3 - s1 * s2 * c3;\n\t\t\t\tthis._w = c1 * c2 * c3 - s1 * s2 * s3;\n\t\t\t\tbreak;\n\n\t\t\tcase 'XZY':\n\t\t\t\tthis._x = s1 * c2 * c3 - c1 * s2 * s3;\n\t\t\t\tthis._y = c1 * s2 * c3 - s1 * c2 * s3;\n\t\t\t\tthis._z = c1 * c2 * s3 + s1 * s2 * c3;\n\t\t\t\tthis._w = c1 * c2 * c3 + s1 * s2 * s3;\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tconsole.warn('THREE.Quaternion: .setFromEuler() encountered an unknown order: ' + order);\n\t\t}\n\n\t\tif (update !== false) this._onChangeCallback();\n\t\treturn this;\n\t}\n\n\tsetFromAxisAngle(axis, angle) {\n\t\t// http://www.euclideanspace.com/maths/geometry/rotations/conversions/angleToQuaternion/index.htm\n\t\t// assumes axis is normalized\n\t\tconst halfAngle = angle / 2,\n\t\t\t\t\ts = Math.sin(halfAngle);\n\t\tthis._x = axis.x * s;\n\t\tthis._y = axis.y * s;\n\t\tthis._z = axis.z * s;\n\t\tthis._w = Math.cos(halfAngle);\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\t}\n\n\tsetFromRotationMatrix(m) {\n\t\t// http://www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToQuaternion/index.htm\n\t\t// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n\t\tconst te = m.elements,\n\t\t\t\t\tm11 = te[0],\n\t\t\t\t\tm12 = te[4],\n\t\t\t\t\tm13 = te[8],\n\t\t\t\t\tm21 = te[1],\n\t\t\t\t\tm22 = te[5],\n\t\t\t\t\tm23 = te[9],\n\t\t\t\t\tm31 = te[2],\n\t\t\t\t\tm32 = te[6],\n\t\t\t\t\tm33 = te[10],\n\t\t\t\t\ttrace = m11 + m22 + m33;\n\n\t\tif (trace > 0) {\n\t\t\tconst s = 0.5 / Math.sqrt(trace + 1.0);\n\t\t\tthis._w = 0.25 / s;\n\t\t\tthis._x = (m32 - m23) * s;\n\t\t\tthis._y = (m13 - m31) * s;\n\t\t\tthis._z = (m21 - m12) * s;\n\t\t} else if (m11 > m22 && m11 > m33) {\n\t\t\tconst s = 2.0 * Math.sqrt(1.0 + m11 - m22 - m33);\n\t\t\tthis._w = (m32 - m23) / s;\n\t\t\tthis._x = 0.25 * s;\n\t\t\tthis._y = (m12 + m21) / s;\n\t\t\tthis._z = (m13 + m31) / s;\n\t\t} else if (m22 > m33) {\n\t\t\tconst s = 2.0 * Math.sqrt(1.0 + m22 - m11 - m33);\n\t\t\tthis._w = (m13 - m31) / s;\n\t\t\tthis._x = (m12 + m21) / s;\n\t\t\tthis._y = 0.25 * s;\n\t\t\tthis._z = (m23 + m32) / s;\n\t\t} else {\n\t\t\tconst s = 2.0 * Math.sqrt(1.0 + m33 - m11 - m22);\n\t\t\tthis._w = (m21 - m12) / s;\n\t\t\tthis._x = (m13 + m31) / s;\n\t\t\tthis._y = (m23 + m32) / s;\n\t\t\tthis._z = 0.25 * s;\n\t\t}\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\t}\n\n\tsetFromUnitVectors(vFrom, vTo) {\n\t\t// assumes direction vectors vFrom and vTo are normalized\n\t\tlet r = vFrom.dot(vTo) + 1;\n\n\t\tif (r < Number.EPSILON) {\n\t\t\t// vFrom and vTo point in opposite directions\n\t\t\tr = 0;\n\n\t\t\tif (Math.abs(vFrom.x) > Math.abs(vFrom.z)) {\n\t\t\t\tthis._x = -vFrom.y;\n\t\t\t\tthis._y = vFrom.x;\n\t\t\t\tthis._z = 0;\n\t\t\t\tthis._w = r;\n\t\t\t} else {\n\t\t\t\tthis._x = 0;\n\t\t\t\tthis._y = -vFrom.z;\n\t\t\t\tthis._z = vFrom.y;\n\t\t\t\tthis._w = r;\n\t\t\t}\n\t\t} else {\n\t\t\t// crossVectors( vFrom, vTo ); // inlined to avoid cyclic dependency on Vector3\n\t\t\tthis._x = vFrom.y * vTo.z - vFrom.z * vTo.y;\n\t\t\tthis._y = vFrom.z * vTo.x - vFrom.x * vTo.z;\n\t\t\tthis._z = vFrom.x * vTo.y - vFrom.y * vTo.x;\n\t\t\tthis._w = r;\n\t\t}\n\n\t\treturn this.normalize();\n\t}\n\n\tangleTo(q) {\n\t\treturn 2 * Math.acos(Math.abs(clamp(this.dot(q), -1, 1)));\n\t}\n\n\trotateTowards(q, step) {\n\t\tconst angle = this.angleTo(q);\n\t\tif (angle === 0) return this;\n\t\tconst t = Math.min(1, step / angle);\n\t\tthis.slerp(q, t);\n\t\treturn this;\n\t}\n\n\tidentity() {\n\t\treturn this.set(0, 0, 0, 1);\n\t}\n\n\tinvert() {\n\t\t// quaternion is assumed to have unit length\n\t\treturn this.conjugate();\n\t}\n\n\tconjugate() {\n\t\tthis._x *= -1;\n\t\tthis._y *= -1;\n\t\tthis._z *= -1;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\t}\n\n\tdot(v) {\n\t\treturn this._x * v._x + this._y * v._y + this._z * v._z + this._w * v._w;\n\t}\n\n\tlengthSq() {\n\t\treturn this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w;\n\t}\n\n\tlength() {\n\t\treturn Math.sqrt(this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w);\n\t}\n\n\tnormalize() {\n\t\tlet l = this.length();\n\n\t\tif (l === 0) {\n\t\t\tthis._x = 0;\n\t\t\tthis._y = 0;\n\t\t\tthis._z = 0;\n\t\t\tthis._w = 1;\n\t\t} else {\n\t\t\tl = 1 / l;\n\t\t\tthis._x = this._x * l;\n\t\t\tthis._y = this._y * l;\n\t\t\tthis._z = this._z * l;\n\t\t\tthis._w = this._w * l;\n\t\t}\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\t}\n\n\tmultiply(q, p) {\n\t\tif (p !== undefined) {\n\t\t\tconsole.warn('THREE.Quaternion: .multiply() now only accepts one argument. Use .multiplyQuaternions( a, b ) instead.');\n\t\t\treturn this.multiplyQuaternions(q, p);\n\t\t}\n\n\t\treturn this.multiplyQuaternions(this, q);\n\t}\n\n\tpremultiply(q) {\n\t\treturn this.multiplyQuaternions(q, this);\n\t}\n\n\tmultiplyQuaternions(a, b) {\n\t\t// from http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/code/index.htm\n\t\tconst qax = a._x,\n\t\t\t\t\tqay = a._y,\n\t\t\t\t\tqaz = a._z,\n\t\t\t\t\tqaw = a._w;\n\t\tconst qbx = b._x,\n\t\t\t\t\tqby = b._y,\n\t\t\t\t\tqbz = b._z,\n\t\t\t\t\tqbw = b._w;\n\t\tthis._x = qax * qbw + qaw * qbx + qay * qbz - qaz * qby;\n\t\tthis._y = qay * qbw + qaw * qby + qaz * qbx - qax * qbz;\n\t\tthis._z = qaz * qbw + qaw * qbz + qax * qby - qay * qbx;\n\t\tthis._w = qaw * qbw - qax * qbx - qay * qby - qaz * qbz;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\t}\n\n\tslerp(qb, t) {\n\t\tif (t === 0) return this;\n\t\tif (t === 1) return this.copy(qb);\n\t\tconst x = this._x,\n\t\t\t\t\ty = this._y,\n\t\t\t\t\tz = this._z,\n\t\t\t\t\tw = this._w; // http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/slerp/\n\n\t\tlet cosHalfTheta = w * qb._w + x * qb._x + y * qb._y + z * qb._z;\n\n\t\tif (cosHalfTheta < 0) {\n\t\t\tthis._w = -qb._w;\n\t\t\tthis._x = -qb._x;\n\t\t\tthis._y = -qb._y;\n\t\t\tthis._z = -qb._z;\n\t\t\tcosHalfTheta = -cosHalfTheta;\n\t\t} else {\n\t\t\tthis.copy(qb);\n\t\t}\n\n\t\tif (cosHalfTheta >= 1.0) {\n\t\t\tthis._w = w;\n\t\t\tthis._x = x;\n\t\t\tthis._y = y;\n\t\t\tthis._z = z;\n\t\t\treturn this;\n\t\t}\n\n\t\tconst sqrSinHalfTheta = 1.0 - cosHalfTheta * cosHalfTheta;\n\n\t\tif (sqrSinHalfTheta <= Number.EPSILON) {\n\t\t\tconst s = 1 - t;\n\t\t\tthis._w = s * w + t * this._w;\n\t\t\tthis._x = s * x + t * this._x;\n\t\t\tthis._y = s * y + t * this._y;\n\t\t\tthis._z = s * z + t * this._z;\n\t\t\tthis.normalize();\n\n\t\t\tthis._onChangeCallback();\n\n\t\t\treturn this;\n\t\t}\n\n\t\tconst sinHalfTheta = Math.sqrt(sqrSinHalfTheta);\n\t\tconst halfTheta = Math.atan2(sinHalfTheta, cosHalfTheta);\n\t\tconst ratioA = Math.sin((1 - t) * halfTheta) / sinHalfTheta,\n\t\t\t\t\tratioB = Math.sin(t * halfTheta) / sinHalfTheta;\n\t\tthis._w = w * ratioA + this._w * ratioB;\n\t\tthis._x = x * ratioA + this._x * ratioB;\n\t\tthis._y = y * ratioA + this._y * ratioB;\n\t\tthis._z = z * ratioA + this._z * ratioB;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\t}\n\n\tslerpQuaternions(qa, qb, t) {\n\t\treturn this.copy(qa).slerp(qb, t);\n\t}\n\n\trandom() {\n\t\t// Derived from http://planning.cs.uiuc.edu/node198.html\n\t\t// Note, this source uses w, x, y, z ordering,\n\t\t// so we swap the order below.\n\t\tconst u1 = Math.random();\n\t\tconst sqrt1u1 = Math.sqrt(1 - u1);\n\t\tconst sqrtu1 = Math.sqrt(u1);\n\t\tconst u2 = 2 * Math.PI * Math.random();\n\t\tconst u3 = 2 * Math.PI * Math.random();\n\t\treturn this.set(sqrt1u1 * Math.cos(u2), sqrtu1 * Math.sin(u3), sqrtu1 * Math.cos(u3), sqrt1u1 * Math.sin(u2));\n\t}\n\n\tequals(quaternion) {\n\t\treturn quaternion._x === this._x && quaternion._y === this._y && quaternion._z === this._z && quaternion._w === this._w;\n\t}\n\n\tfromArray(array, offset = 0) {\n\t\tthis._x = array[offset];\n\t\tthis._y = array[offset + 1];\n\t\tthis._z = array[offset + 2];\n\t\tthis._w = array[offset + 3];\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\t}\n\n\ttoArray(array = [], offset = 0) {\n\t\tarray[offset] = this._x;\n\t\tarray[offset + 1] = this._y;\n\t\tarray[offset + 2] = this._z;\n\t\tarray[offset + 3] = this._w;\n\t\treturn array;\n\t}\n\n\tfromBufferAttribute(attribute, index) {\n\t\tthis._x = attribute.getX(index);\n\t\tthis._y = attribute.getY(index);\n\t\tthis._z = attribute.getZ(index);\n\t\tthis._w = attribute.getW(index);\n\t\treturn this;\n\t}\n\n\t_onChange(callback) {\n\t\tthis._onChangeCallback = callback;\n\t\treturn this;\n\t}\n\n\t_onChangeCallback() {}\n\n\t*[Symbol.iterator]() {\n\t\tyield this._x;\n\t\tyield this._y;\n\t\tyield this._z;\n\t\tyield this._w;\n\t}\n\n}\n\nclass Vector3 {\n\tconstructor(x = 0, y = 0, z = 0) {\n\t\tthis.isVector3 = true;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.z = z;\n\t}\n\n\tset(x, y, z) {\n\t\tif (z === undefined) z = this.z; // sprite.scale.set(x,y)\n\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.z = z;\n\t\treturn this;\n\t}\n\n\tsetScalar(scalar) {\n\t\tthis.x = scalar;\n\t\tthis.y = scalar;\n\t\tthis.z = scalar;\n\t\treturn this;\n\t}\n\n\tsetX(x) {\n\t\tthis.x = x;\n\t\treturn this;\n\t}\n\n\tsetY(y) {\n\t\tthis.y = y;\n\t\treturn this;\n\t}\n\n\tsetZ(z) {\n\t\tthis.z = z;\n\t\treturn this;\n\t}\n\n\tsetComponent(index, value) {\n\t\tswitch (index) {\n\t\t\tcase 0:\n\t\t\t\tthis.x = value;\n\t\t\t\tbreak;\n\n\t\t\tcase 1:\n\t\t\t\tthis.y = value;\n\t\t\t\tbreak;\n\n\t\t\tcase 2:\n\t\t\t\tthis.z = value;\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tthrow new Error('index is out of range: ' + index);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tgetComponent(index) {\n\t\tswitch (index) {\n\t\t\tcase 0:\n\t\t\t\treturn this.x;\n\n\t\t\tcase 1:\n\t\t\t\treturn this.y;\n\n\t\t\tcase 2:\n\t\t\t\treturn this.z;\n\n\t\t\tdefault:\n\t\t\t\tthrow new Error('index is out of range: ' + index);\n\t\t}\n\t}\n\n\tclone() {\n\t\treturn new this.constructor(this.x, this.y, this.z);\n\t}\n\n\tcopy(v) {\n\t\tthis.x = v.x;\n\t\tthis.y = v.y;\n\t\tthis.z = v.z;\n\t\treturn this;\n\t}\n\n\tadd(v, w) {\n\t\tif (w !== undefined) {\n\t\t\tconsole.warn('THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead.');\n\t\t\treturn this.addVectors(v, w);\n\t\t}\n\n\t\tthis.x += v.x;\n\t\tthis.y += v.y;\n\t\tthis.z += v.z;\n\t\treturn this;\n\t}\n\n\taddScalar(s) {\n\t\tthis.x += s;\n\t\tthis.y += s;\n\t\tthis.z += s;\n\t\treturn this;\n\t}\n\n\taddVectors(a, b) {\n\t\tthis.x = a.x + b.x;\n\t\tthis.y = a.y + b.y;\n\t\tthis.z = a.z + b.z;\n\t\treturn this;\n\t}\n\n\taddScaledVector(v, s) {\n\t\tthis.x += v.x * s;\n\t\tthis.y += v.y * s;\n\t\tthis.z += v.z * s;\n\t\treturn this;\n\t}\n\n\tsub(v, w) {\n\t\tif (w !== undefined) {\n\t\t\tconsole.warn('THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.');\n\t\t\treturn this.subVectors(v, w);\n\t\t}\n\n\t\tthis.x -= v.x;\n\t\tthis.y -= v.y;\n\t\tthis.z -= v.z;\n\t\treturn this;\n\t}\n\n\tsubScalar(s) {\n\t\tthis.x -= s;\n\t\tthis.y -= s;\n\t\tthis.z -= s;\n\t\treturn this;\n\t}\n\n\tsubVectors(a, b) {\n\t\tthis.x = a.x - b.x;\n\t\tthis.y = a.y - b.y;\n\t\tthis.z = a.z - b.z;\n\t\treturn this;\n\t}\n\n\tmultiply(v, w) {\n\t\tif (w !== undefined) {\n\t\t\tconsole.warn('THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead.');\n\t\t\treturn this.multiplyVectors(v, w);\n\t\t}\n\n\t\tthis.x *= v.x;\n\t\tthis.y *= v.y;\n\t\tthis.z *= v.z;\n\t\treturn this;\n\t}\n\n\tmultiplyScalar(scalar) {\n\t\tthis.x *= scalar;\n\t\tthis.y *= scalar;\n\t\tthis.z *= scalar;\n\t\treturn this;\n\t}\n\n\tmultiplyVectors(a, b) {\n\t\tthis.x = a.x * b.x;\n\t\tthis.y = a.y * b.y;\n\t\tthis.z = a.z * b.z;\n\t\treturn this;\n\t}\n\n\tapplyEuler(euler) {\n\t\tif (!(euler && euler.isEuler)) {\n\t\t\tconsole.error('THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order.');\n\t\t}\n\n\t\treturn this.applyQuaternion(_quaternion$4.setFromEuler(euler));\n\t}\n\n\tapplyAxisAngle(axis, angle) {\n\t\treturn this.applyQuaternion(_quaternion$4.setFromAxisAngle(axis, angle));\n\t}\n\n\tapplyMatrix3(m) {\n\t\tconst x = this.x,\n\t\t\t\t\ty = this.y,\n\t\t\t\t\tz = this.z;\n\t\tconst e = m.elements;\n\t\tthis.x = e[0] * x + e[3] * y + e[6] * z;\n\t\tthis.y = e[1] * x + e[4] * y + e[7] * z;\n\t\tthis.z = e[2] * x + e[5] * y + e[8] * z;\n\t\treturn this;\n\t}\n\n\tapplyNormalMatrix(m) {\n\t\treturn this.applyMatrix3(m).normalize();\n\t}\n\n\tapplyMatrix4(m) {\n\t\tconst x = this.x,\n\t\t\t\t\ty = this.y,\n\t\t\t\t\tz = this.z;\n\t\tconst e = m.elements;\n\t\tconst w = 1 / (e[3] * x + e[7] * y + e[11] * z + e[15]);\n\t\tthis.x = (e[0] * x + e[4] * y + e[8] * z + e[12]) * w;\n\t\tthis.y = (e[1] * x + e[5] * y + e[9] * z + e[13]) * w;\n\t\tthis.z = (e[2] * x + e[6] * y + e[10] * z + e[14]) * w;\n\t\treturn this;\n\t}\n\n\tapplyQuaternion(q) {\n\t\tconst x = this.x,\n\t\t\t\t\ty = this.y,\n\t\t\t\t\tz = this.z;\n\t\tconst qx = q.x,\n\t\t\t\t\tqy = q.y,\n\t\t\t\t\tqz = q.z,\n\t\t\t\t\tqw = q.w; // calculate quat * vector\n\n\t\tconst ix = qw * x + qy * z - qz * y;\n\t\tconst iy = qw * y + qz * x - qx * z;\n\t\tconst iz = qw * z + qx * y - qy * x;\n\t\tconst iw = -qx * x - qy * y - qz * z; // calculate result * inverse quat\n\n\t\tthis.x = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n\t\tthis.y = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n\t\tthis.z = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n\t\treturn this;\n\t}\n\n\tproject(camera) {\n\t\treturn this.applyMatrix4(camera.matrixWorldInverse).applyMatrix4(camera.projectionMatrix);\n\t}\n\n\tunproject(camera) {\n\t\treturn this.applyMatrix4(camera.projectionMatrixInverse).applyMatrix4(camera.matrixWorld);\n\t}\n\n\ttransformDirection(m) {\n\t\t// input: THREE.Matrix4 affine matrix\n\t\t// vector interpreted as a direction\n\t\tconst x = this.x,\n\t\t\t\t\ty = this.y,\n\t\t\t\t\tz = this.z;\n\t\tconst e = m.elements;\n\t\tthis.x = e[0] * x + e[4] * y + e[8] * z;\n\t\tthis.y = e[1] * x + e[5] * y + e[9] * z;\n\t\tthis.z = e[2] * x + e[6] * y + e[10] * z;\n\t\treturn this.normalize();\n\t}\n\n\tdivide(v) {\n\t\tthis.x /= v.x;\n\t\tthis.y /= v.y;\n\t\tthis.z /= v.z;\n\t\treturn this;\n\t}\n\n\tdivideScalar(scalar) {\n\t\treturn this.multiplyScalar(1 / scalar);\n\t}\n\n\tmin(v) {\n\t\tthis.x = Math.min(this.x, v.x);\n\t\tthis.y = Math.min(this.y, v.y);\n\t\tthis.z = Math.min(this.z, v.z);\n\t\treturn this;\n\t}\n\n\tmax(v) {\n\t\tthis.x = Math.max(this.x, v.x);\n\t\tthis.y = Math.max(this.y, v.y);\n\t\tthis.z = Math.max(this.z, v.z);\n\t\treturn this;\n\t}\n\n\tclamp(min, max) {\n\t\t// assumes min < max, componentwise\n\t\tthis.x = Math.max(min.x, Math.min(max.x, this.x));\n\t\tthis.y = Math.max(min.y, Math.min(max.y, this.y));\n\t\tthis.z = Math.max(min.z, Math.min(max.z, this.z));\n\t\treturn this;\n\t}\n\n\tclampScalar(minVal, maxVal) {\n\t\tthis.x = Math.max(minVal, Math.min(maxVal, this.x));\n\t\tthis.y = Math.max(minVal, Math.min(maxVal, this.y));\n\t\tthis.z = Math.max(minVal, Math.min(maxVal, this.z));\n\t\treturn this;\n\t}\n\n\tclampLength(min, max) {\n\t\tconst length = this.length();\n\t\treturn this.divideScalar(length || 1).multiplyScalar(Math.max(min, Math.min(max, length)));\n\t}\n\n\tfloor() {\n\t\tthis.x = Math.floor(this.x);\n\t\tthis.y = Math.floor(this.y);\n\t\tthis.z = Math.floor(this.z);\n\t\treturn this;\n\t}\n\n\tceil() {\n\t\tthis.x = Math.ceil(this.x);\n\t\tthis.y = Math.ceil(this.y);\n\t\tthis.z = Math.ceil(this.z);\n\t\treturn this;\n\t}\n\n\tround() {\n\t\tthis.x = Math.round(this.x);\n\t\tthis.y = Math.round(this.y);\n\t\tthis.z = Math.round(this.z);\n\t\treturn this;\n\t}\n\n\troundToZero() {\n\t\tthis.x = this.x < 0 ? Math.ceil(this.x) : Math.floor(this.x);\n\t\tthis.y = this.y < 0 ? Math.ceil(this.y) : Math.floor(this.y);\n\t\tthis.z = this.z < 0 ? Math.ceil(this.z) : Math.floor(this.z);\n\t\treturn this;\n\t}\n\n\tnegate() {\n\t\tthis.x = -this.x;\n\t\tthis.y = -this.y;\n\t\tthis.z = -this.z;\n\t\treturn this;\n\t}\n\n\tdot(v) {\n\t\treturn this.x * v.x + this.y * v.y + this.z * v.z;\n\t} // TODO lengthSquared?\n\n\n\tlengthSq() {\n\t\treturn this.x * this.x + this.y * this.y + this.z * this.z;\n\t}\n\n\tlength() {\n\t\treturn Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);\n\t}\n\n\tmanhattanLength() {\n\t\treturn Math.abs(this.x) + Math.abs(this.y) + Math.abs(this.z);\n\t}\n\n\tnormalize() {\n\t\treturn this.divideScalar(this.length() || 1);\n\t}\n\n\tsetLength(length) {\n\t\treturn this.normalize().multiplyScalar(length);\n\t}\n\n\tlerp(v, alpha) {\n\t\tthis.x += (v.x - this.x) * alpha;\n\t\tthis.y += (v.y - this.y) * alpha;\n\t\tthis.z += (v.z - this.z) * alpha;\n\t\treturn this;\n\t}\n\n\tlerpVectors(v1, v2, alpha) {\n\t\tthis.x = v1.x + (v2.x - v1.x) * alpha;\n\t\tthis.y = v1.y + (v2.y - v1.y) * alpha;\n\t\tthis.z = v1.z + (v2.z - v1.z) * alpha;\n\t\treturn this;\n\t}\n\n\tcross(v, w) {\n\t\tif (w !== undefined) {\n\t\t\tconsole.warn('THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead.');\n\t\t\treturn this.crossVectors(v, w);\n\t\t}\n\n\t\treturn this.crossVectors(this, v);\n\t}\n\n\tcrossVectors(a, b) {\n\t\tconst ax = a.x,\n\t\t\t\t\tay = a.y,\n\t\t\t\t\taz = a.z;\n\t\tconst bx = b.x,\n\t\t\t\t\tby = b.y,\n\t\t\t\t\tbz = b.z;\n\t\tthis.x = ay * bz - az * by;\n\t\tthis.y = az * bx - ax * bz;\n\t\tthis.z = ax * by - ay * bx;\n\t\treturn this;\n\t}\n\n\tprojectOnVector(v) {\n\t\tconst denominator = v.lengthSq();\n\t\tif (denominator === 0) return this.set(0, 0, 0);\n\t\tconst scalar = v.dot(this) / denominator;\n\t\treturn this.copy(v).multiplyScalar(scalar);\n\t}\n\n\tprojectOnPlane(planeNormal) {\n\t\t_vector$c.copy(this).projectOnVector(planeNormal);\n\n\t\treturn this.sub(_vector$c);\n\t}\n\n\treflect(normal) {\n\t\t// reflect incident vector off plane orthogonal to normal\n\t\t// normal is assumed to have unit length\n\t\treturn this.sub(_vector$c.copy(normal).multiplyScalar(2 * this.dot(normal)));\n\t}\n\n\tangleTo(v) {\n\t\tconst denominator = Math.sqrt(this.lengthSq() * v.lengthSq());\n\t\tif (denominator === 0) return Math.PI / 2;\n\t\tconst theta = this.dot(v) / denominator; // clamp, to handle numerical problems\n\n\t\treturn Math.acos(clamp(theta, -1, 1));\n\t}\n\n\tdistanceTo(v) {\n\t\treturn Math.sqrt(this.distanceToSquared(v));\n\t}\n\n\tdistanceToSquared(v) {\n\t\tconst dx = this.x - v.x,\n\t\t\t\t\tdy = this.y - v.y,\n\t\t\t\t\tdz = this.z - v.z;\n\t\treturn dx * dx + dy * dy + dz * dz;\n\t}\n\n\tmanhattanDistanceTo(v) {\n\t\treturn Math.abs(this.x - v.x) + Math.abs(this.y - v.y) + Math.abs(this.z - v.z);\n\t}\n\n\tsetFromSpherical(s) {\n\t\treturn this.setFromSphericalCoords(s.radius, s.phi, s.theta);\n\t}\n\n\tsetFromSphericalCoords(radius, phi, theta) {\n\t\tconst sinPhiRadius = Math.sin(phi) * radius;\n\t\tthis.x = sinPhiRadius * Math.sin(theta);\n\t\tthis.y = Math.cos(phi) * radius;\n\t\tthis.z = sinPhiRadius * Math.cos(theta);\n\t\treturn this;\n\t}\n\n\tsetFromCylindrical(c) {\n\t\treturn this.setFromCylindricalCoords(c.radius, c.theta, c.y);\n\t}\n\n\tsetFromCylindricalCoords(radius, theta, y) {\n\t\tthis.x = radius * Math.sin(theta);\n\t\tthis.y = y;\n\t\tthis.z = radius * Math.cos(theta);\n\t\treturn this;\n\t}\n\n\tsetFromMatrixPosition(m) {\n\t\tconst e = m.elements;\n\t\tthis.x = e[12];\n\t\tthis.y = e[13];\n\t\tthis.z = e[14];\n\t\treturn this;\n\t}\n\n\tsetFromMatrixScale(m) {\n\t\tconst sx = this.setFromMatrixColumn(m, 0).length();\n\t\tconst sy = this.setFromMatrixColumn(m, 1).length();\n\t\tconst sz = this.setFromMatrixColumn(m, 2).length();\n\t\tthis.x = sx;\n\t\tthis.y = sy;\n\t\tthis.z = sz;\n\t\treturn this;\n\t}\n\n\tsetFromMatrixColumn(m, index) {\n\t\treturn this.fromArray(m.elements, index * 4);\n\t}\n\n\tsetFromMatrix3Column(m, index) {\n\t\treturn this.fromArray(m.elements, index * 3);\n\t}\n\n\tsetFromEuler(e) {\n\t\tthis.x = e._x;\n\t\tthis.y = e._y;\n\t\tthis.z = e._z;\n\t\treturn this;\n\t}\n\n\tequals(v) {\n\t\treturn v.x === this.x && v.y === this.y && v.z === this.z;\n\t}\n\n\tfromArray(array, offset = 0) {\n\t\tthis.x = array[offset];\n\t\tthis.y = array[offset + 1];\n\t\tthis.z = array[offset + 2];\n\t\treturn this;\n\t}\n\n\ttoArray(array = [], offset = 0) {\n\t\tarray[offset] = this.x;\n\t\tarray[offset + 1] = this.y;\n\t\tarray[offset + 2] = this.z;\n\t\treturn array;\n\t}\n\n\tfromBufferAttribute(attribute, index, offset) {\n\t\tif (offset !== undefined) {\n\t\t\tconsole.warn('THREE.Vector3: offset has been removed from .fromBufferAttribute().');\n\t\t}\n\n\t\tthis.x = attribute.getX(index);\n\t\tthis.y = attribute.getY(index);\n\t\tthis.z = attribute.getZ(index);\n\t\treturn this;\n\t}\n\n\trandom() {\n\t\tthis.x = Math.random();\n\t\tthis.y = Math.random();\n\t\tthis.z = Math.random();\n\t\treturn this;\n\t}\n\n\trandomDirection() {\n\t\t// Derived from https://mathworld.wolfram.com/SpherePointPicking.html\n\t\tconst u = (Math.random() - 0.5) * 2;\n\t\tconst t = Math.random() * Math.PI * 2;\n\t\tconst f = Math.sqrt(1 - u ** 2);\n\t\tthis.x = f * Math.cos(t);\n\t\tthis.y = f * Math.sin(t);\n\t\tthis.z = u;\n\t\treturn this;\n\t}\n\n\t*[Symbol.iterator]() {\n\t\tyield this.x;\n\t\tyield this.y;\n\t\tyield this.z;\n\t}\n\n}\n\nconst _vector$c = /*@__PURE__*/new Vector3();\n\nconst _quaternion$4 = /*@__PURE__*/new Quaternion();\n\nclass Box3 {\n\tconstructor(min = new Vector3(+Infinity, +Infinity, +Infinity), max = new Vector3(-Infinity, -Infinity, -Infinity)) {\n\t\tthis.isBox3 = true;\n\t\tthis.min = min;\n\t\tthis.max = max;\n\t}\n\n\tset(min, max) {\n\t\tthis.min.copy(min);\n\t\tthis.max.copy(max);\n\t\treturn this;\n\t}\n\n\tsetFromArray(array) {\n\t\tlet minX = +Infinity;\n\t\tlet minY = +Infinity;\n\t\tlet minZ = +Infinity;\n\t\tlet maxX = -Infinity;\n\t\tlet maxY = -Infinity;\n\t\tlet maxZ = -Infinity;\n\n\t\tfor (let i = 0, l = array.length; i < l; i += 3) {\n\t\t\tconst x = array[i];\n\t\t\tconst y = array[i + 1];\n\t\t\tconst z = array[i + 2];\n\t\t\tif (x < minX) minX = x;\n\t\t\tif (y < minY) minY = y;\n\t\t\tif (z < minZ) minZ = z;\n\t\t\tif (x > maxX) maxX = x;\n\t\t\tif (y > maxY) maxY = y;\n\t\t\tif (z > maxZ) maxZ = z;\n\t\t}\n\n\t\tthis.min.set(minX, minY, minZ);\n\t\tthis.max.set(maxX, maxY, maxZ);\n\t\treturn this;\n\t}\n\n\tsetFromBufferAttribute(attribute) {\n\t\tlet minX = +Infinity;\n\t\tlet minY = +Infinity;\n\t\tlet minZ = +Infinity;\n\t\tlet maxX = -Infinity;\n\t\tlet maxY = -Infinity;\n\t\tlet maxZ = -Infinity;\n\n\t\tfor (let i = 0, l = attribute.count; i < l; i++) {\n\t\t\tconst x = attribute.getX(i);\n\t\t\tconst y = attribute.getY(i);\n\t\t\tconst z = attribute.getZ(i);\n\t\t\tif (x < minX) minX = x;\n\t\t\tif (y < minY) minY = y;\n\t\t\tif (z < minZ) minZ = z;\n\t\t\tif (x > maxX) maxX = x;\n\t\t\tif (y > maxY) maxY = y;\n\t\t\tif (z > maxZ) maxZ = z;\n\t\t}\n\n\t\tthis.min.set(minX, minY, minZ);\n\t\tthis.max.set(maxX, maxY, maxZ);\n\t\treturn this;\n\t}\n\n\tsetFromPoints(points) {\n\t\tthis.makeEmpty();\n\n\t\tfor (let i = 0, il = points.length; i < il; i++) {\n\t\t\tthis.expandByPoint(points[i]);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tsetFromCenterAndSize(center, size) {\n\t\tconst halfSize = _vector$b.copy(size).multiplyScalar(0.5);\n\n\t\tthis.min.copy(center).sub(halfSize);\n\t\tthis.max.copy(center).add(halfSize);\n\t\treturn this;\n\t}\n\n\tsetFromObject(object, precise = false) {\n\t\tthis.makeEmpty();\n\t\treturn this.expandByObject(object, precise);\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n\tcopy(box) {\n\t\tthis.min.copy(box.min);\n\t\tthis.max.copy(box.max);\n\t\treturn this;\n\t}\n\n\tmakeEmpty() {\n\t\tthis.min.x = this.min.y = this.min.z = +Infinity;\n\t\tthis.max.x = this.max.y = this.max.z = -Infinity;\n\t\treturn this;\n\t}\n\n\tisEmpty() {\n\t\t// this is a more robust check for empty than ( volume <= 0 ) because volume can get positive with two negative axes\n\t\treturn this.max.x < this.min.x || this.max.y < this.min.y || this.max.z < this.min.z;\n\t}\n\n\tgetCenter(target) {\n\t\treturn this.isEmpty() ? target.set(0, 0, 0) : target.addVectors(this.min, this.max).multiplyScalar(0.5);\n\t}\n\n\tgetSize(target) {\n\t\treturn this.isEmpty() ? target.set(0, 0, 0) : target.subVectors(this.max, this.min);\n\t}\n\n\texpandByPoint(point) {\n\t\tthis.min.min(point);\n\t\tthis.max.max(point);\n\t\treturn this;\n\t}\n\n\texpandByVector(vector) {\n\t\tthis.min.sub(vector);\n\t\tthis.max.add(vector);\n\t\treturn this;\n\t}\n\n\texpandByScalar(scalar) {\n\t\tthis.min.addScalar(-scalar);\n\t\tthis.max.addScalar(scalar);\n\t\treturn this;\n\t}\n\n\texpandByObject(object, precise = false) {\n\t\t// Computes the world-axis-aligned bounding box of an object (including its children),\n\t\t// accounting for both the object's, and children's, world transforms\n\t\tobject.updateWorldMatrix(false, false);\n\t\tconst geometry = object.geometry;\n\n\t\tif (geometry !== undefined) {\n\t\t\tif (precise && geometry.attributes != undefined && geometry.attributes.position !== undefined) {\n\t\t\t\tconst position = geometry.attributes.position;\n\n\t\t\t\tfor (let i = 0, l = position.count; i < l; i++) {\n\t\t\t\t\t_vector$b.fromBufferAttribute(position, i).applyMatrix4(object.matrixWorld);\n\n\t\t\t\t\tthis.expandByPoint(_vector$b);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (geometry.boundingBox === null) {\n\t\t\t\t\tgeometry.computeBoundingBox();\n\t\t\t\t}\n\n\t\t\t\t_box$3.copy(geometry.boundingBox);\n\n\t\t\t\t_box$3.applyMatrix4(object.matrixWorld);\n\n\t\t\t\tthis.union(_box$3);\n\t\t\t}\n\t\t}\n\n\t\tconst children = object.children;\n\n\t\tfor (let i = 0, l = children.length; i < l; i++) {\n\t\t\tthis.expandByObject(children[i], precise);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tcontainsPoint(point) {\n\t\treturn point.x < this.min.x || point.x > this.max.x || point.y < this.min.y || point.y > this.max.y || point.z < this.min.z || point.z > this.max.z ? false : true;\n\t}\n\n\tcontainsBox(box) {\n\t\treturn this.min.x <= box.min.x && box.max.x <= this.max.x && this.min.y <= box.min.y && box.max.y <= this.max.y && this.min.z <= box.min.z && box.max.z <= this.max.z;\n\t}\n\n\tgetParameter(point, target) {\n\t\t// This can potentially have a divide by zero if the box\n\t\t// has a size dimension of 0.\n\t\treturn target.set((point.x - this.min.x) / (this.max.x - this.min.x), (point.y - this.min.y) / (this.max.y - this.min.y), (point.z - this.min.z) / (this.max.z - this.min.z));\n\t}\n\n\tintersectsBox(box) {\n\t\t// using 6 splitting planes to rule out intersections.\n\t\treturn box.max.x < this.min.x || box.min.x > this.max.x || box.max.y < this.min.y || box.min.y > this.max.y || box.max.z < this.min.z || box.min.z > this.max.z ? false : true;\n\t}\n\n\tintersectsSphere(sphere) {\n\t\t// Find the point on the AABB closest to the sphere center.\n\t\tthis.clampPoint(sphere.center, _vector$b); // If that point is inside the sphere, the AABB and sphere intersect.\n\n\t\treturn _vector$b.distanceToSquared(sphere.center) <= sphere.radius * sphere.radius;\n\t}\n\n\tintersectsPlane(plane) {\n\t\t// We compute the minimum and maximum dot product values. If those values\n\t\t// are on the same side (back or front) of the plane, then there is no intersection.\n\t\tlet min, max;\n\n\t\tif (plane.normal.x > 0) {\n\t\t\tmin = plane.normal.x * this.min.x;\n\t\t\tmax = plane.normal.x * this.max.x;\n\t\t} else {\n\t\t\tmin = plane.normal.x * this.max.x;\n\t\t\tmax = plane.normal.x * this.min.x;\n\t\t}\n\n\t\tif (plane.normal.y > 0) {\n\t\t\tmin += plane.normal.y * this.min.y;\n\t\t\tmax += plane.normal.y * this.max.y;\n\t\t} else {\n\t\t\tmin += plane.normal.y * this.max.y;\n\t\t\tmax += plane.normal.y * this.min.y;\n\t\t}\n\n\t\tif (plane.normal.z > 0) {\n\t\t\tmin += plane.normal.z * this.min.z;\n\t\t\tmax += plane.normal.z * this.max.z;\n\t\t} else {\n\t\t\tmin += plane.normal.z * this.max.z;\n\t\t\tmax += plane.normal.z * this.min.z;\n\t\t}\n\n\t\treturn min <= -plane.constant && max >= -plane.constant;\n\t}\n\n\tintersectsTriangle(triangle) {\n\t\tif (this.isEmpty()) {\n\t\t\treturn false;\n\t\t} // compute box center and extents\n\n\n\t\tthis.getCenter(_center);\n\n\t\t_extents.subVectors(this.max, _center); // translate triangle to aabb origin\n\n\n\t\t_v0$2.subVectors(triangle.a, _center);\n\n\t\t_v1$7.subVectors(triangle.b, _center);\n\n\t\t_v2$3.subVectors(triangle.c, _center); // compute edge vectors for triangle\n\n\n\t\t_f0.subVectors(_v1$7, _v0$2);\n\n\t\t_f1.subVectors(_v2$3, _v1$7);\n\n\t\t_f2.subVectors(_v0$2, _v2$3); // test against axes that are given by cross product combinations of the edges of the triangle and the edges of the aabb\n\t\t// make an axis testing of each of the 3 sides of the aabb against each of the 3 sides of the triangle = 9 axis of separation\n\t\t// axis_ij = u_i x f_j (u0, u1, u2 = face normals of aabb = x,y,z axes vectors since aabb is axis aligned)\n\n\n\t\tlet axes = [0, -_f0.z, _f0.y, 0, -_f1.z, _f1.y, 0, -_f2.z, _f2.y, _f0.z, 0, -_f0.x, _f1.z, 0, -_f1.x, _f2.z, 0, -_f2.x, -_f0.y, _f0.x, 0, -_f1.y, _f1.x, 0, -_f2.y, _f2.x, 0];\n\n\t\tif (!satForAxes(axes, _v0$2, _v1$7, _v2$3, _extents)) {\n\t\t\treturn false;\n\t\t} // test 3 face normals from the aabb\n\n\n\t\taxes = [1, 0, 0, 0, 1, 0, 0, 0, 1];\n\n\t\tif (!satForAxes(axes, _v0$2, _v1$7, _v2$3, _extents)) {\n\t\t\treturn false;\n\t\t} // finally testing the face normal of the triangle\n\t\t// use already existing triangle edge vectors here\n\n\n\t\t_triangleNormal.crossVectors(_f0, _f1);\n\n\t\taxes = [_triangleNormal.x, _triangleNormal.y, _triangleNormal.z];\n\t\treturn satForAxes(axes, _v0$2, _v1$7, _v2$3, _extents);\n\t}\n\n\tclampPoint(point, target) {\n\t\treturn target.copy(point).clamp(this.min, this.max);\n\t}\n\n\tdistanceToPoint(point) {\n\t\tconst clampedPoint = _vector$b.copy(point).clamp(this.min, this.max);\n\n\t\treturn clampedPoint.sub(point).length();\n\t}\n\n\tgetBoundingSphere(target) {\n\t\tthis.getCenter(target.center);\n\t\ttarget.radius = this.getSize(_vector$b).length() * 0.5;\n\t\treturn target;\n\t}\n\n\tintersect(box) {\n\t\tthis.min.max(box.min);\n\t\tthis.max.min(box.max); // ensure that if there is no overlap, the result is fully empty, not slightly empty with non-inf/+inf values that will cause subsequence intersects to erroneously return valid values.\n\n\t\tif (this.isEmpty()) this.makeEmpty();\n\t\treturn this;\n\t}\n\n\tunion(box) {\n\t\tthis.min.min(box.min);\n\t\tthis.max.max(box.max);\n\t\treturn this;\n\t}\n\n\tapplyMatrix4(matrix) {\n\t\t// transform of empty box is an empty box.\n\t\tif (this.isEmpty()) return this; // NOTE: I am using a binary pattern to specify all 2^3 combinations below\n\n\t\t_points[0].set(this.min.x, this.min.y, this.min.z).applyMatrix4(matrix); // 000\n\n\n\t\t_points[1].set(this.min.x, this.min.y, this.max.z).applyMatrix4(matrix); // 001\n\n\n\t\t_points[2].set(this.min.x, this.max.y, this.min.z).applyMatrix4(matrix); // 010\n\n\n\t\t_points[3].set(this.min.x, this.max.y, this.max.z).applyMatrix4(matrix); // 011\n\n\n\t\t_points[4].set(this.max.x, this.min.y, this.min.z).applyMatrix4(matrix); // 100\n\n\n\t\t_points[5].set(this.max.x, this.min.y, this.max.z).applyMatrix4(matrix); // 101\n\n\n\t\t_points[6].set(this.max.x, this.max.y, this.min.z).applyMatrix4(matrix); // 110\n\n\n\t\t_points[7].set(this.max.x, this.max.y, this.max.z).applyMatrix4(matrix); // 111\n\n\n\t\tthis.setFromPoints(_points);\n\t\treturn this;\n\t}\n\n\ttranslate(offset) {\n\t\tthis.min.add(offset);\n\t\tthis.max.add(offset);\n\t\treturn this;\n\t}\n\n\tequals(box) {\n\t\treturn box.min.equals(this.min) && box.max.equals(this.max);\n\t}\n\n}\n\nconst _points = [/*@__PURE__*/new Vector3(), /*@__PURE__*/new Vector3(), /*@__PURE__*/new Vector3(), /*@__PURE__*/new Vector3(), /*@__PURE__*/new Vector3(), /*@__PURE__*/new Vector3(), /*@__PURE__*/new Vector3(), /*@__PURE__*/new Vector3()];\n\nconst _vector$b = /*@__PURE__*/new Vector3();\n\nconst _box$3 = /*@__PURE__*/new Box3(); // triangle centered vertices\n\n\nconst _v0$2 = /*@__PURE__*/new Vector3();\n\nconst _v1$7 = /*@__PURE__*/new Vector3();\n\nconst _v2$3 = /*@__PURE__*/new Vector3(); // triangle edge vectors\n\n\nconst _f0 = /*@__PURE__*/new Vector3();\n\nconst _f1 = /*@__PURE__*/new Vector3();\n\nconst _f2 = /*@__PURE__*/new Vector3();\n\nconst _center = /*@__PURE__*/new Vector3();\n\nconst _extents = /*@__PURE__*/new Vector3();\n\nconst _triangleNormal = /*@__PURE__*/new Vector3();\n\nconst _testAxis = /*@__PURE__*/new Vector3();\n\nfunction satForAxes(axes, v0, v1, v2, extents) {\n\tfor (let i = 0, j = axes.length - 3; i <= j; i += 3) {\n\t\t_testAxis.fromArray(axes, i); // project the aabb onto the separating axis\n\n\n\t\tconst r = extents.x * Math.abs(_testAxis.x) + extents.y * Math.abs(_testAxis.y) + extents.z * Math.abs(_testAxis.z); // project all 3 vertices of the triangle onto the separating axis\n\n\t\tconst p0 = v0.dot(_testAxis);\n\t\tconst p1 = v1.dot(_testAxis);\n\t\tconst p2 = v2.dot(_testAxis); // actual test, basically see if either of the most extreme of the triangle points intersects r\n\n\t\tif (Math.max(-Math.max(p0, p1, p2), Math.min(p0, p1, p2)) > r) {\n\t\t\t// points of the projected triangle are outside the projected half-length of the aabb\n\t\t\t// the axis is separating and we can exit\n\t\t\treturn false;\n\t\t}\n\t}\n\n\treturn true;\n}\n\nconst _box$2 = /*@__PURE__*/new Box3();\n\nconst _v1$6 = /*@__PURE__*/new Vector3();\n\nconst _toFarthestPoint = /*@__PURE__*/new Vector3();\n\nconst _toPoint = /*@__PURE__*/new Vector3();\n\nclass Sphere {\n\tconstructor(center = new Vector3(), radius = -1) {\n\t\tthis.center = center;\n\t\tthis.radius = radius;\n\t}\n\n\tset(center, radius) {\n\t\tthis.center.copy(center);\n\t\tthis.radius = radius;\n\t\treturn this;\n\t}\n\n\tsetFromPoints(points, optionalCenter) {\n\t\tconst center = this.center;\n\n\t\tif (optionalCenter !== undefined) {\n\t\t\tcenter.copy(optionalCenter);\n\t\t} else {\n\t\t\t_box$2.setFromPoints(points).getCenter(center);\n\t\t}\n\n\t\tlet maxRadiusSq = 0;\n\n\t\tfor (let i = 0, il = points.length; i < il; i++) {\n\t\t\tmaxRadiusSq = Math.max(maxRadiusSq, center.distanceToSquared(points[i]));\n\t\t}\n\n\t\tthis.radius = Math.sqrt(maxRadiusSq);\n\t\treturn this;\n\t}\n\n\tcopy(sphere) {\n\t\tthis.center.copy(sphere.center);\n\t\tthis.radius = sphere.radius;\n\t\treturn this;\n\t}\n\n\tisEmpty() {\n\t\treturn this.radius < 0;\n\t}\n\n\tmakeEmpty() {\n\t\tthis.center.set(0, 0, 0);\n\t\tthis.radius = -1;\n\t\treturn this;\n\t}\n\n\tcontainsPoint(point) {\n\t\treturn point.distanceToSquared(this.center) <= this.radius * this.radius;\n\t}\n\n\tdistanceToPoint(point) {\n\t\treturn point.distanceTo(this.center) - this.radius;\n\t}\n\n\tintersectsSphere(sphere) {\n\t\tconst radiusSum = this.radius + sphere.radius;\n\t\treturn sphere.center.distanceToSquared(this.center) <= radiusSum * radiusSum;\n\t}\n\n\tintersectsBox(box) {\n\t\treturn box.intersectsSphere(this);\n\t}\n\n\tintersectsPlane(plane) {\n\t\treturn Math.abs(plane.distanceToPoint(this.center)) <= this.radius;\n\t}\n\n\tclampPoint(point, target) {\n\t\tconst deltaLengthSq = this.center.distanceToSquared(point);\n\t\ttarget.copy(point);\n\n\t\tif (deltaLengthSq > this.radius * this.radius) {\n\t\t\ttarget.sub(this.center).normalize();\n\t\t\ttarget.multiplyScalar(this.radius).add(this.center);\n\t\t}\n\n\t\treturn target;\n\t}\n\n\tgetBoundingBox(target) {\n\t\tif (this.isEmpty()) {\n\t\t\t// Empty sphere produces empty bounding box\n\t\t\ttarget.makeEmpty();\n\t\t\treturn target;\n\t\t}\n\n\t\ttarget.set(this.center, this.center);\n\t\ttarget.expandByScalar(this.radius);\n\t\treturn target;\n\t}\n\n\tapplyMatrix4(matrix) {\n\t\tthis.center.applyMatrix4(matrix);\n\t\tthis.radius = this.radius * matrix.getMaxScaleOnAxis();\n\t\treturn this;\n\t}\n\n\ttranslate(offset) {\n\t\tthis.center.add(offset);\n\t\treturn this;\n\t}\n\n\texpandByPoint(point) {\n\t\t// from https://github.com/juj/MathGeoLib/blob/2940b99b99cfe575dd45103ef20f4019dee15b54/src/Geometry/Sphere.cpp#L649-L671\n\t\t_toPoint.subVectors(point, this.center);\n\n\t\tconst lengthSq = _toPoint.lengthSq();\n\n\t\tif (lengthSq > this.radius * this.radius) {\n\t\t\tconst length = Math.sqrt(lengthSq);\n\t\t\tconst missingRadiusHalf = (length - this.radius) * 0.5; // Nudge this sphere towards the target point. Add half the missing distance to radius,\n\t\t\t// and the other half to position. This gives a tighter enclosure, instead of if\n\t\t\t// the whole missing distance were just added to radius.\n\n\t\t\tthis.center.add(_toPoint.multiplyScalar(missingRadiusHalf / length));\n\t\t\tthis.radius += missingRadiusHalf;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tunion(sphere) {\n\t\t// from https://github.com/juj/MathGeoLib/blob/2940b99b99cfe575dd45103ef20f4019dee15b54/src/Geometry/Sphere.cpp#L759-L769\n\t\t// To enclose another sphere into this sphere, we only need to enclose two points:\n\t\t// 1) Enclose the farthest point on the other sphere into this sphere.\n\t\t// 2) Enclose the opposite point of the farthest point into this sphere.\n\t\tif (this.center.equals(sphere.center) === true) {\n\t\t\t_toFarthestPoint.set(0, 0, 1).multiplyScalar(sphere.radius);\n\t\t} else {\n\t\t\t_toFarthestPoint.subVectors(sphere.center, this.center).normalize().multiplyScalar(sphere.radius);\n\t\t}\n\n\t\tthis.expandByPoint(_v1$6.copy(sphere.center).add(_toFarthestPoint));\n\t\tthis.expandByPoint(_v1$6.copy(sphere.center).sub(_toFarthestPoint));\n\t\treturn this;\n\t}\n\n\tequals(sphere) {\n\t\treturn sphere.center.equals(this.center) && sphere.radius === this.radius;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n}\n\nconst _vector$a = /*@__PURE__*/new Vector3();\n\nconst _segCenter = /*@__PURE__*/new Vector3();\n\nconst _segDir = /*@__PURE__*/new Vector3();\n\nconst _diff = /*@__PURE__*/new Vector3();\n\nconst _edge1 = /*@__PURE__*/new Vector3();\n\nconst _edge2 = /*@__PURE__*/new Vector3();\n\nconst _normal$1 = /*@__PURE__*/new Vector3();\n\nclass Ray {\n\tconstructor(origin = new Vector3(), direction = new Vector3(0, 0, -1)) {\n\t\tthis.origin = origin;\n\t\tthis.direction = direction;\n\t}\n\n\tset(origin, direction) {\n\t\tthis.origin.copy(origin);\n\t\tthis.direction.copy(direction);\n\t\treturn this;\n\t}\n\n\tcopy(ray) {\n\t\tthis.origin.copy(ray.origin);\n\t\tthis.direction.copy(ray.direction);\n\t\treturn this;\n\t}\n\n\tat(t, target) {\n\t\treturn target.copy(this.direction).multiplyScalar(t).add(this.origin);\n\t}\n\n\tlookAt(v) {\n\t\tthis.direction.copy(v).sub(this.origin).normalize();\n\t\treturn this;\n\t}\n\n\trecast(t) {\n\t\tthis.origin.copy(this.at(t, _vector$a));\n\t\treturn this;\n\t}\n\n\tclosestPointToPoint(point, target) {\n\t\ttarget.subVectors(point, this.origin);\n\t\tconst directionDistance = target.dot(this.direction);\n\n\t\tif (directionDistance < 0) {\n\t\t\treturn target.copy(this.origin);\n\t\t}\n\n\t\treturn target.copy(this.direction).multiplyScalar(directionDistance).add(this.origin);\n\t}\n\n\tdistanceToPoint(point) {\n\t\treturn Math.sqrt(this.distanceSqToPoint(point));\n\t}\n\n\tdistanceSqToPoint(point) {\n\t\tconst directionDistance = _vector$a.subVectors(point, this.origin).dot(this.direction); // point behind the ray\n\n\n\t\tif (directionDistance < 0) {\n\t\t\treturn this.origin.distanceToSquared(point);\n\t\t}\n\n\t\t_vector$a.copy(this.direction).multiplyScalar(directionDistance).add(this.origin);\n\n\t\treturn _vector$a.distanceToSquared(point);\n\t}\n\n\tdistanceSqToSegment(v0, v1, optionalPointOnRay, optionalPointOnSegment) {\n\t\t// from https://github.com/pmjoniak/GeometricTools/blob/master/GTEngine/Include/Mathematics/GteDistRaySegment.h\n\t\t// It returns the min distance between the ray and the segment\n\t\t// defined by v0 and v1\n\t\t// It can also set two optional targets :\n\t\t// - The closest point on the ray\n\t\t// - The closest point on the segment\n\t\t_segCenter.copy(v0).add(v1).multiplyScalar(0.5);\n\n\t\t_segDir.copy(v1).sub(v0).normalize();\n\n\t\t_diff.copy(this.origin).sub(_segCenter);\n\n\t\tconst segExtent = v0.distanceTo(v1) * 0.5;\n\t\tconst a01 = -this.direction.dot(_segDir);\n\n\t\tconst b0 = _diff.dot(this.direction);\n\n\t\tconst b1 = -_diff.dot(_segDir);\n\n\t\tconst c = _diff.lengthSq();\n\n\t\tconst det = Math.abs(1 - a01 * a01);\n\t\tlet s0, s1, sqrDist, extDet;\n\n\t\tif (det > 0) {\n\t\t\t// The ray and segment are not parallel.\n\t\t\ts0 = a01 * b1 - b0;\n\t\t\ts1 = a01 * b0 - b1;\n\t\t\textDet = segExtent * det;\n\n\t\t\tif (s0 >= 0) {\n\t\t\t\tif (s1 >= -extDet) {\n\t\t\t\t\tif (s1 <= extDet) {\n\t\t\t\t\t\t// region 0\n\t\t\t\t\t\t// Minimum at interior points of ray and segment.\n\t\t\t\t\t\tconst invDet = 1 / det;\n\t\t\t\t\t\ts0 *= invDet;\n\t\t\t\t\t\ts1 *= invDet;\n\t\t\t\t\t\tsqrDist = s0 * (s0 + a01 * s1 + 2 * b0) + s1 * (a01 * s0 + s1 + 2 * b1) + c;\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// region 1\n\t\t\t\t\t\ts1 = segExtent;\n\t\t\t\t\t\ts0 = Math.max(0, -(a01 * s1 + b0));\n\t\t\t\t\t\tsqrDist = -s0 * s0 + s1 * (s1 + 2 * b1) + c;\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// region 5\n\t\t\t\t\ts1 = -segExtent;\n\t\t\t\t\ts0 = Math.max(0, -(a01 * s1 + b0));\n\t\t\t\t\tsqrDist = -s0 * s0 + s1 * (s1 + 2 * b1) + c;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (s1 <= -extDet) {\n\t\t\t\t\t// region 4\n\t\t\t\t\ts0 = Math.max(0, -(-a01 * segExtent + b0));\n\t\t\t\t\ts1 = s0 > 0 ? -segExtent : Math.min(Math.max(-segExtent, -b1), segExtent);\n\t\t\t\t\tsqrDist = -s0 * s0 + s1 * (s1 + 2 * b1) + c;\n\t\t\t\t} else if (s1 <= extDet) {\n\t\t\t\t\t// region 3\n\t\t\t\t\ts0 = 0;\n\t\t\t\t\ts1 = Math.min(Math.max(-segExtent, -b1), segExtent);\n\t\t\t\t\tsqrDist = s1 * (s1 + 2 * b1) + c;\n\t\t\t\t} else {\n\t\t\t\t\t// region 2\n\t\t\t\t\ts0 = Math.max(0, -(a01 * segExtent + b0));\n\t\t\t\t\ts1 = s0 > 0 ? segExtent : Math.min(Math.max(-segExtent, -b1), segExtent);\n\t\t\t\t\tsqrDist = -s0 * s0 + s1 * (s1 + 2 * b1) + c;\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\t// Ray and segment are parallel.\n\t\t\ts1 = a01 > 0 ? -segExtent : segExtent;\n\t\t\ts0 = Math.max(0, -(a01 * s1 + b0));\n\t\t\tsqrDist = -s0 * s0 + s1 * (s1 + 2 * b1) + c;\n\t\t}\n\n\t\tif (optionalPointOnRay) {\n\t\t\toptionalPointOnRay.copy(this.direction).multiplyScalar(s0).add(this.origin);\n\t\t}\n\n\t\tif (optionalPointOnSegment) {\n\t\t\toptionalPointOnSegment.copy(_segDir).multiplyScalar(s1).add(_segCenter);\n\t\t}\n\n\t\treturn sqrDist;\n\t}\n\n\tintersectSphere(sphere, target) {\n\t\t_vector$a.subVectors(sphere.center, this.origin);\n\n\t\tconst tca = _vector$a.dot(this.direction);\n\n\t\tconst d2 = _vector$a.dot(_vector$a) - tca * tca;\n\t\tconst radius2 = sphere.radius * sphere.radius;\n\t\tif (d2 > radius2) return null;\n\t\tconst thc = Math.sqrt(radius2 - d2); // t0 = first intersect point - entrance on front of sphere\n\n\t\tconst t0 = tca - thc; // t1 = second intersect point - exit point on back of sphere\n\n\t\tconst t1 = tca + thc; // test to see if both t0 and t1 are behind the ray - if so, return null\n\n\t\tif (t0 < 0 && t1 < 0) return null; // test to see if t0 is behind the ray:\n\t\t// if it is, the ray is inside the sphere, so return the second exit point scaled by t1,\n\t\t// in order to always return an intersect point that is in front of the ray.\n\n\t\tif (t0 < 0) return this.at(t1, target); // else t0 is in front of the ray, so return the first collision point scaled by t0\n\n\t\treturn this.at(t0, target);\n\t}\n\n\tintersectsSphere(sphere) {\n\t\treturn this.distanceSqToPoint(sphere.center) <= sphere.radius * sphere.radius;\n\t}\n\n\tdistanceToPlane(plane) {\n\t\tconst denominator = plane.normal.dot(this.direction);\n\n\t\tif (denominator === 0) {\n\t\t\t// line is coplanar, return origin\n\t\t\tif (plane.distanceToPoint(this.origin) === 0) {\n\t\t\t\treturn 0;\n\t\t\t} // Null is preferable to undefined since undefined means.... it is undefined\n\n\n\t\t\treturn null;\n\t\t}\n\n\t\tconst t = -(this.origin.dot(plane.normal) + plane.constant) / denominator; // Return if the ray never intersects the plane\n\n\t\treturn t >= 0 ? t : null;\n\t}\n\n\tintersectPlane(plane, target) {\n\t\tconst t = this.distanceToPlane(plane);\n\n\t\tif (t === null) {\n\t\t\treturn null;\n\t\t}\n\n\t\treturn this.at(t, target);\n\t}\n\n\tintersectsPlane(plane) {\n\t\t// check if the ray lies on the plane first\n\t\tconst distToPoint = plane.distanceToPoint(this.origin);\n\n\t\tif (distToPoint === 0) {\n\t\t\treturn true;\n\t\t}\n\n\t\tconst denominator = plane.normal.dot(this.direction);\n\n\t\tif (denominator * distToPoint < 0) {\n\t\t\treturn true;\n\t\t} // ray origin is behind the plane (and is pointing behind it)\n\n\n\t\treturn false;\n\t}\n\n\tintersectBox(box, target) {\n\t\tlet tmin, tmax, tymin, tymax, tzmin, tzmax;\n\t\tconst invdirx = 1 / this.direction.x,\n\t\t\t\t\tinvdiry = 1 / this.direction.y,\n\t\t\t\t\tinvdirz = 1 / this.direction.z;\n\t\tconst origin = this.origin;\n\n\t\tif (invdirx >= 0) {\n\t\t\ttmin = (box.min.x - origin.x) * invdirx;\n\t\t\ttmax = (box.max.x - origin.x) * invdirx;\n\t\t} else {\n\t\t\ttmin = (box.max.x - origin.x) * invdirx;\n\t\t\ttmax = (box.min.x - origin.x) * invdirx;\n\t\t}\n\n\t\tif (invdiry >= 0) {\n\t\t\ttymin = (box.min.y - origin.y) * invdiry;\n\t\t\ttymax = (box.max.y - origin.y) * invdiry;\n\t\t} else {\n\t\t\ttymin = (box.max.y - origin.y) * invdiry;\n\t\t\ttymax = (box.min.y - origin.y) * invdiry;\n\t\t}\n\n\t\tif (tmin > tymax || tymin > tmax) return null; // These lines also handle the case where tmin or tmax is NaN\n\t\t// (result of 0 * Infinity). x !== x returns true if x is NaN\n\n\t\tif (tymin > tmin || tmin !== tmin) tmin = tymin;\n\t\tif (tymax < tmax || tmax !== tmax) tmax = tymax;\n\n\t\tif (invdirz >= 0) {\n\t\t\ttzmin = (box.min.z - origin.z) * invdirz;\n\t\t\ttzmax = (box.max.z - origin.z) * invdirz;\n\t\t} else {\n\t\t\ttzmin = (box.max.z - origin.z) * invdirz;\n\t\t\ttzmax = (box.min.z - origin.z) * invdirz;\n\t\t}\n\n\t\tif (tmin > tzmax || tzmin > tmax) return null;\n\t\tif (tzmin > tmin || tmin !== tmin) tmin = tzmin;\n\t\tif (tzmax < tmax || tmax !== tmax) tmax = tzmax; //return point closest to the ray (positive side)\n\n\t\tif (tmax < 0) return null;\n\t\treturn this.at(tmin >= 0 ? tmin : tmax, target);\n\t}\n\n\tintersectsBox(box) {\n\t\treturn this.intersectBox(box, _vector$a) !== null;\n\t}\n\n\tintersectTriangle(a, b, c, backfaceCulling, target) {\n\t\t// Compute the offset origin, edges, and normal.\n\t\t// from https://github.com/pmjoniak/GeometricTools/blob/master/GTEngine/Include/Mathematics/GteIntrRay3Triangle3.h\n\t\t_edge1.subVectors(b, a);\n\n\t\t_edge2.subVectors(c, a);\n\n\t\t_normal$1.crossVectors(_edge1, _edge2); // Solve Q + t*D = b1*E1 + b2*E2 (Q = kDiff, D = ray direction,\n\t\t// E1 = kEdge1, E2 = kEdge2, N = Cross(E1,E2)) by\n\t\t//\t |Dot(D,N)|*b1 = sign(Dot(D,N))*Dot(D,Cross(Q,E2))\n\t\t//\t |Dot(D,N)|*b2 = sign(Dot(D,N))*Dot(D,Cross(E1,Q))\n\t\t//\t |Dot(D,N)|*t = -sign(Dot(D,N))*Dot(Q,N)\n\n\n\t\tlet DdN = this.direction.dot(_normal$1);\n\t\tlet sign;\n\n\t\tif (DdN > 0) {\n\t\t\tif (backfaceCulling) return null;\n\t\t\tsign = 1;\n\t\t} else if (DdN < 0) {\n\t\t\tsign = -1;\n\t\t\tDdN = -DdN;\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\n\t\t_diff.subVectors(this.origin, a);\n\n\t\tconst DdQxE2 = sign * this.direction.dot(_edge2.crossVectors(_diff, _edge2)); // b1 < 0, no intersection\n\n\t\tif (DdQxE2 < 0) {\n\t\t\treturn null;\n\t\t}\n\n\t\tconst DdE1xQ = sign * this.direction.dot(_edge1.cross(_diff)); // b2 < 0, no intersection\n\n\t\tif (DdE1xQ < 0) {\n\t\t\treturn null;\n\t\t} // b1+b2 > 1, no intersection\n\n\n\t\tif (DdQxE2 + DdE1xQ > DdN) {\n\t\t\treturn null;\n\t\t} // Line intersects triangle, check if ray does.\n\n\n\t\tconst QdN = -sign * _diff.dot(_normal$1); // t < 0, no intersection\n\n\n\t\tif (QdN < 0) {\n\t\t\treturn null;\n\t\t} // Ray intersects triangle.\n\n\n\t\treturn this.at(QdN / DdN, target);\n\t}\n\n\tapplyMatrix4(matrix4) {\n\t\tthis.origin.applyMatrix4(matrix4);\n\t\tthis.direction.transformDirection(matrix4);\n\t\treturn this;\n\t}\n\n\tequals(ray) {\n\t\treturn ray.origin.equals(this.origin) && ray.direction.equals(this.direction);\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n}\n\nclass Matrix4 {\n\tconstructor() {\n\t\tthis.isMatrix4 = true;\n\t\tthis.elements = [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\n\n\t\tif (arguments.length > 0) {\n\t\t\tconsole.error('THREE.Matrix4: the constructor no longer reads arguments. use .set() instead.');\n\t\t}\n\t}\n\n\tset(n11, n12, n13, n14, n21, n22, n23, n24, n31, n32, n33, n34, n41, n42, n43, n44) {\n\t\tconst te = this.elements;\n\t\tte[0] = n11;\n\t\tte[4] = n12;\n\t\tte[8] = n13;\n\t\tte[12] = n14;\n\t\tte[1] = n21;\n\t\tte[5] = n22;\n\t\tte[9] = n23;\n\t\tte[13] = n24;\n\t\tte[2] = n31;\n\t\tte[6] = n32;\n\t\tte[10] = n33;\n\t\tte[14] = n34;\n\t\tte[3] = n41;\n\t\tte[7] = n42;\n\t\tte[11] = n43;\n\t\tte[15] = n44;\n\t\treturn this;\n\t}\n\n\tidentity() {\n\t\tthis.set(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\treturn new Matrix4().fromArray(this.elements);\n\t}\n\n\tcopy(m) {\n\t\tconst te = this.elements;\n\t\tconst me = m.elements;\n\t\tte[0] = me[0];\n\t\tte[1] = me[1];\n\t\tte[2] = me[2];\n\t\tte[3] = me[3];\n\t\tte[4] = me[4];\n\t\tte[5] = me[5];\n\t\tte[6] = me[6];\n\t\tte[7] = me[7];\n\t\tte[8] = me[8];\n\t\tte[9] = me[9];\n\t\tte[10] = me[10];\n\t\tte[11] = me[11];\n\t\tte[12] = me[12];\n\t\tte[13] = me[13];\n\t\tte[14] = me[14];\n\t\tte[15] = me[15];\n\t\treturn this;\n\t}\n\n\tcopyPosition(m) {\n\t\tconst te = this.elements,\n\t\t\t\t\tme = m.elements;\n\t\tte[12] = me[12];\n\t\tte[13] = me[13];\n\t\tte[14] = me[14];\n\t\treturn this;\n\t}\n\n\tsetFromMatrix3(m) {\n\t\tconst me = m.elements;\n\t\tthis.set(me[0], me[3], me[6], 0, me[1], me[4], me[7], 0, me[2], me[5], me[8], 0, 0, 0, 0, 1);\n\t\treturn this;\n\t}\n\n\textractBasis(xAxis, yAxis, zAxis) {\n\t\txAxis.setFromMatrixColumn(this, 0);\n\t\tyAxis.setFromMatrixColumn(this, 1);\n\t\tzAxis.setFromMatrixColumn(this, 2);\n\t\treturn this;\n\t}\n\n\tmakeBasis(xAxis, yAxis, zAxis) {\n\t\tthis.set(xAxis.x, yAxis.x, zAxis.x, 0, xAxis.y, yAxis.y, zAxis.y, 0, xAxis.z, yAxis.z, zAxis.z, 0, 0, 0, 0, 1);\n\t\treturn this;\n\t}\n\n\textractRotation(m) {\n\t\t// this method does not support reflection matrices\n\t\tconst te = this.elements;\n\t\tconst me = m.elements;\n\n\t\tconst scaleX = 1 / _v1$5.setFromMatrixColumn(m, 0).length();\n\n\t\tconst scaleY = 1 / _v1$5.setFromMatrixColumn(m, 1).length();\n\n\t\tconst scaleZ = 1 / _v1$5.setFromMatrixColumn(m, 2).length();\n\n\t\tte[0] = me[0] * scaleX;\n\t\tte[1] = me[1] * scaleX;\n\t\tte[2] = me[2] * scaleX;\n\t\tte[3] = 0;\n\t\tte[4] = me[4] * scaleY;\n\t\tte[5] = me[5] * scaleY;\n\t\tte[6] = me[6] * scaleY;\n\t\tte[7] = 0;\n\t\tte[8] = me[8] * scaleZ;\n\t\tte[9] = me[9] * scaleZ;\n\t\tte[10] = me[10] * scaleZ;\n\t\tte[11] = 0;\n\t\tte[12] = 0;\n\t\tte[13] = 0;\n\t\tte[14] = 0;\n\t\tte[15] = 1;\n\t\treturn this;\n\t}\n\n\tmakeRotationFromEuler(euler) {\n\t\tif (!(euler && euler.isEuler)) {\n\t\t\tconsole.error('THREE.Matrix4: .makeRotationFromEuler() now expects a Euler rotation rather than a Vector3 and order.');\n\t\t}\n\n\t\tconst te = this.elements;\n\t\tconst x = euler.x,\n\t\t\t\t\ty = euler.y,\n\t\t\t\t\tz = euler.z;\n\t\tconst a = Math.cos(x),\n\t\t\t\t\tb = Math.sin(x);\n\t\tconst c = Math.cos(y),\n\t\t\t\t\td = Math.sin(y);\n\t\tconst e = Math.cos(z),\n\t\t\t\t\tf = Math.sin(z);\n\n\t\tif (euler.order === 'XYZ') {\n\t\t\tconst ae = a * e,\n\t\t\t\t\t\taf = a * f,\n\t\t\t\t\t\tbe = b * e,\n\t\t\t\t\t\tbf = b * f;\n\t\t\tte[0] = c * e;\n\t\t\tte[4] = -c * f;\n\t\t\tte[8] = d;\n\t\t\tte[1] = af + be * d;\n\t\t\tte[5] = ae - bf * d;\n\t\t\tte[9] = -b * c;\n\t\t\tte[2] = bf - ae * d;\n\t\t\tte[6] = be + af * d;\n\t\t\tte[10] = a * c;\n\t\t} else if (euler.order === 'YXZ') {\n\t\t\tconst ce = c * e,\n\t\t\t\t\t\tcf = c * f,\n\t\t\t\t\t\tde = d * e,\n\t\t\t\t\t\tdf = d * f;\n\t\t\tte[0] = ce + df * b;\n\t\t\tte[4] = de * b - cf;\n\t\t\tte[8] = a * d;\n\t\t\tte[1] = a * f;\n\t\t\tte[5] = a * e;\n\t\t\tte[9] = -b;\n\t\t\tte[2] = cf * b - de;\n\t\t\tte[6] = df + ce * b;\n\t\t\tte[10] = a * c;\n\t\t} else if (euler.order === 'ZXY') {\n\t\t\tconst ce = c * e,\n\t\t\t\t\t\tcf = c * f,\n\t\t\t\t\t\tde = d * e,\n\t\t\t\t\t\tdf = d * f;\n\t\t\tte[0] = ce - df * b;\n\t\t\tte[4] = -a * f;\n\t\t\tte[8] = de + cf * b;\n\t\t\tte[1] = cf + de * b;\n\t\t\tte[5] = a * e;\n\t\t\tte[9] = df - ce * b;\n\t\t\tte[2] = -a * d;\n\t\t\tte[6] = b;\n\t\t\tte[10] = a * c;\n\t\t} else if (euler.order === 'ZYX') {\n\t\t\tconst ae = a * e,\n\t\t\t\t\t\taf = a * f,\n\t\t\t\t\t\tbe = b * e,\n\t\t\t\t\t\tbf = b * f;\n\t\t\tte[0] = c * e;\n\t\t\tte[4] = be * d - af;\n\t\t\tte[8] = ae * d + bf;\n\t\t\tte[1] = c * f;\n\t\t\tte[5] = bf * d + ae;\n\t\t\tte[9] = af * d - be;\n\t\t\tte[2] = -d;\n\t\t\tte[6] = b * c;\n\t\t\tte[10] = a * c;\n\t\t} else if (euler.order === 'YZX') {\n\t\t\tconst ac = a * c,\n\t\t\t\t\t\tad = a * d,\n\t\t\t\t\t\tbc = b * c,\n\t\t\t\t\t\tbd = b * d;\n\t\t\tte[0] = c * e;\n\t\t\tte[4] = bd - ac * f;\n\t\t\tte[8] = bc * f + ad;\n\t\t\tte[1] = f;\n\t\t\tte[5] = a * e;\n\t\t\tte[9] = -b * e;\n\t\t\tte[2] = -d * e;\n\t\t\tte[6] = ad * f + bc;\n\t\t\tte[10] = ac - bd * f;\n\t\t} else if (euler.order === 'XZY') {\n\t\t\tconst ac = a * c,\n\t\t\t\t\t\tad = a * d,\n\t\t\t\t\t\tbc = b * c,\n\t\t\t\t\t\tbd = b * d;\n\t\t\tte[0] = c * e;\n\t\t\tte[4] = -f;\n\t\t\tte[8] = d * e;\n\t\t\tte[1] = ac * f + bd;\n\t\t\tte[5] = a * e;\n\t\t\tte[9] = ad * f - bc;\n\t\t\tte[2] = bc * f - ad;\n\t\t\tte[6] = b * e;\n\t\t\tte[10] = bd * f + ac;\n\t\t} // bottom row\n\n\n\t\tte[3] = 0;\n\t\tte[7] = 0;\n\t\tte[11] = 0; // last column\n\n\t\tte[12] = 0;\n\t\tte[13] = 0;\n\t\tte[14] = 0;\n\t\tte[15] = 1;\n\t\treturn this;\n\t}\n\n\tmakeRotationFromQuaternion(q) {\n\t\treturn this.compose(_zero, q, _one);\n\t}\n\n\tlookAt(eye, target, up) {\n\t\tconst te = this.elements;\n\n\t\t_z.subVectors(eye, target);\n\n\t\tif (_z.lengthSq() === 0) {\n\t\t\t// eye and target are in the same position\n\t\t\t_z.z = 1;\n\t\t}\n\n\t\t_z.normalize();\n\n\t\t_x.crossVectors(up, _z);\n\n\t\tif (_x.lengthSq() === 0) {\n\t\t\t// up and z are parallel\n\t\t\tif (Math.abs(up.z) === 1) {\n\t\t\t\t_z.x += 0.0001;\n\t\t\t} else {\n\t\t\t\t_z.z += 0.0001;\n\t\t\t}\n\n\t\t\t_z.normalize();\n\n\t\t\t_x.crossVectors(up, _z);\n\t\t}\n\n\t\t_x.normalize();\n\n\t\t_y.crossVectors(_z, _x);\n\n\t\tte[0] = _x.x;\n\t\tte[4] = _y.x;\n\t\tte[8] = _z.x;\n\t\tte[1] = _x.y;\n\t\tte[5] = _y.y;\n\t\tte[9] = _z.y;\n\t\tte[2] = _x.z;\n\t\tte[6] = _y.z;\n\t\tte[10] = _z.z;\n\t\treturn this;\n\t}\n\n\tmultiply(m, n) {\n\t\tif (n !== undefined) {\n\t\t\tconsole.warn('THREE.Matrix4: .multiply() now only accepts one argument. Use .multiplyMatrices( a, b ) instead.');\n\t\t\treturn this.multiplyMatrices(m, n);\n\t\t}\n\n\t\treturn this.multiplyMatrices(this, m);\n\t}\n\n\tpremultiply(m) {\n\t\treturn this.multiplyMatrices(m, this);\n\t}\n\n\tmultiplyMatrices(a, b) {\n\t\tconst ae = a.elements;\n\t\tconst be = b.elements;\n\t\tconst te = this.elements;\n\t\tconst a11 = ae[0],\n\t\t\t\t\ta12 = ae[4],\n\t\t\t\t\ta13 = ae[8],\n\t\t\t\t\ta14 = ae[12];\n\t\tconst a21 = ae[1],\n\t\t\t\t\ta22 = ae[5],\n\t\t\t\t\ta23 = ae[9],\n\t\t\t\t\ta24 = ae[13];\n\t\tconst a31 = ae[2],\n\t\t\t\t\ta32 = ae[6],\n\t\t\t\t\ta33 = ae[10],\n\t\t\t\t\ta34 = ae[14];\n\t\tconst a41 = ae[3],\n\t\t\t\t\ta42 = ae[7],\n\t\t\t\t\ta43 = ae[11],\n\t\t\t\t\ta44 = ae[15];\n\t\tconst b11 = be[0],\n\t\t\t\t\tb12 = be[4],\n\t\t\t\t\tb13 = be[8],\n\t\t\t\t\tb14 = be[12];\n\t\tconst b21 = be[1],\n\t\t\t\t\tb22 = be[5],\n\t\t\t\t\tb23 = be[9],\n\t\t\t\t\tb24 = be[13];\n\t\tconst b31 = be[2],\n\t\t\t\t\tb32 = be[6],\n\t\t\t\t\tb33 = be[10],\n\t\t\t\t\tb34 = be[14];\n\t\tconst b41 = be[3],\n\t\t\t\t\tb42 = be[7],\n\t\t\t\t\tb43 = be[11],\n\t\t\t\t\tb44 = be[15];\n\t\tte[0] = a11 * b11 + a12 * b21 + a13 * b31 + a14 * b41;\n\t\tte[4] = a11 * b12 + a12 * b22 + a13 * b32 + a14 * b42;\n\t\tte[8] = a11 * b13 + a12 * b23 + a13 * b33 + a14 * b43;\n\t\tte[12] = a11 * b14 + a12 * b24 + a13 * b34 + a14 * b44;\n\t\tte[1] = a21 * b11 + a22 * b21 + a23 * b31 + a24 * b41;\n\t\tte[5] = a21 * b12 + a22 * b22 + a23 * b32 + a24 * b42;\n\t\tte[9] = a21 * b13 + a22 * b23 + a23 * b33 + a24 * b43;\n\t\tte[13] = a21 * b14 + a22 * b24 + a23 * b34 + a24 * b44;\n\t\tte[2] = a31 * b11 + a32 * b21 + a33 * b31 + a34 * b41;\n\t\tte[6] = a31 * b12 + a32 * b22 + a33 * b32 + a34 * b42;\n\t\tte[10] = a31 * b13 + a32 * b23 + a33 * b33 + a34 * b43;\n\t\tte[14] = a31 * b14 + a32 * b24 + a33 * b34 + a34 * b44;\n\t\tte[3] = a41 * b11 + a42 * b21 + a43 * b31 + a44 * b41;\n\t\tte[7] = a41 * b12 + a42 * b22 + a43 * b32 + a44 * b42;\n\t\tte[11] = a41 * b13 + a42 * b23 + a43 * b33 + a44 * b43;\n\t\tte[15] = a41 * b14 + a42 * b24 + a43 * b34 + a44 * b44;\n\t\treturn this;\n\t}\n\n\tmultiplyScalar(s) {\n\t\tconst te = this.elements;\n\t\tte[0] *= s;\n\t\tte[4] *= s;\n\t\tte[8] *= s;\n\t\tte[12] *= s;\n\t\tte[1] *= s;\n\t\tte[5] *= s;\n\t\tte[9] *= s;\n\t\tte[13] *= s;\n\t\tte[2] *= s;\n\t\tte[6] *= s;\n\t\tte[10] *= s;\n\t\tte[14] *= s;\n\t\tte[3] *= s;\n\t\tte[7] *= s;\n\t\tte[11] *= s;\n\t\tte[15] *= s;\n\t\treturn this;\n\t}\n\n\tdeterminant() {\n\t\tconst te = this.elements;\n\t\tconst n11 = te[0],\n\t\t\t\t\tn12 = te[4],\n\t\t\t\t\tn13 = te[8],\n\t\t\t\t\tn14 = te[12];\n\t\tconst n21 = te[1],\n\t\t\t\t\tn22 = te[5],\n\t\t\t\t\tn23 = te[9],\n\t\t\t\t\tn24 = te[13];\n\t\tconst n31 = te[2],\n\t\t\t\t\tn32 = te[6],\n\t\t\t\t\tn33 = te[10],\n\t\t\t\t\tn34 = te[14];\n\t\tconst n41 = te[3],\n\t\t\t\t\tn42 = te[7],\n\t\t\t\t\tn43 = te[11],\n\t\t\t\t\tn44 = te[15]; //TODO: make this more efficient\n\t\t//( based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm )\n\n\t\treturn n41 * (+n14 * n23 * n32 - n13 * n24 * n32 - n14 * n22 * n33 + n12 * n24 * n33 + n13 * n22 * n34 - n12 * n23 * n34) + n42 * (+n11 * n23 * n34 - n11 * n24 * n33 + n14 * n21 * n33 - n13 * n21 * n34 + n13 * n24 * n31 - n14 * n23 * n31) + n43 * (+n11 * n24 * n32 - n11 * n22 * n34 - n14 * n21 * n32 + n12 * n21 * n34 + n14 * n22 * n31 - n12 * n24 * n31) + n44 * (-n13 * n22 * n31 - n11 * n23 * n32 + n11 * n22 * n33 + n13 * n21 * n32 - n12 * n21 * n33 + n12 * n23 * n31);\n\t}\n\n\ttranspose() {\n\t\tconst te = this.elements;\n\t\tlet tmp;\n\t\ttmp = te[1];\n\t\tte[1] = te[4];\n\t\tte[4] = tmp;\n\t\ttmp = te[2];\n\t\tte[2] = te[8];\n\t\tte[8] = tmp;\n\t\ttmp = te[6];\n\t\tte[6] = te[9];\n\t\tte[9] = tmp;\n\t\ttmp = te[3];\n\t\tte[3] = te[12];\n\t\tte[12] = tmp;\n\t\ttmp = te[7];\n\t\tte[7] = te[13];\n\t\tte[13] = tmp;\n\t\ttmp = te[11];\n\t\tte[11] = te[14];\n\t\tte[14] = tmp;\n\t\treturn this;\n\t}\n\n\tsetPosition(x, y, z) {\n\t\tconst te = this.elements;\n\n\t\tif (x.isVector3) {\n\t\t\tte[12] = x.x;\n\t\t\tte[13] = x.y;\n\t\t\tte[14] = x.z;\n\t\t} else {\n\t\t\tte[12] = x;\n\t\t\tte[13] = y;\n\t\t\tte[14] = z;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tinvert() {\n\t\t// based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm\n\t\tconst te = this.elements,\n\t\t\t\t\tn11 = te[0],\n\t\t\t\t\tn21 = te[1],\n\t\t\t\t\tn31 = te[2],\n\t\t\t\t\tn41 = te[3],\n\t\t\t\t\tn12 = te[4],\n\t\t\t\t\tn22 = te[5],\n\t\t\t\t\tn32 = te[6],\n\t\t\t\t\tn42 = te[7],\n\t\t\t\t\tn13 = te[8],\n\t\t\t\t\tn23 = te[9],\n\t\t\t\t\tn33 = te[10],\n\t\t\t\t\tn43 = te[11],\n\t\t\t\t\tn14 = te[12],\n\t\t\t\t\tn24 = te[13],\n\t\t\t\t\tn34 = te[14],\n\t\t\t\t\tn44 = te[15],\n\t\t\t\t\tt11 = n23 * n34 * n42 - n24 * n33 * n42 + n24 * n32 * n43 - n22 * n34 * n43 - n23 * n32 * n44 + n22 * n33 * n44,\n\t\t\t\t\tt12 = n14 * n33 * n42 - n13 * n34 * n42 - n14 * n32 * n43 + n12 * n34 * n43 + n13 * n32 * n44 - n12 * n33 * n44,\n\t\t\t\t\tt13 = n13 * n24 * n42 - n14 * n23 * n42 + n14 * n22 * n43 - n12 * n24 * n43 - n13 * n22 * n44 + n12 * n23 * n44,\n\t\t\t\t\tt14 = n14 * n23 * n32 - n13 * n24 * n32 - n14 * n22 * n33 + n12 * n24 * n33 + n13 * n22 * n34 - n12 * n23 * n34;\n\t\tconst det = n11 * t11 + n21 * t12 + n31 * t13 + n41 * t14;\n\t\tif (det === 0) return this.set(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);\n\t\tconst detInv = 1 / det;\n\t\tte[0] = t11 * detInv;\n\t\tte[1] = (n24 * n33 * n41 - n23 * n34 * n41 - n24 * n31 * n43 + n21 * n34 * n43 + n23 * n31 * n44 - n21 * n33 * n44) * detInv;\n\t\tte[2] = (n22 * n34 * n41 - n24 * n32 * n41 + n24 * n31 * n42 - n21 * n34 * n42 - n22 * n31 * n44 + n21 * n32 * n44) * detInv;\n\t\tte[3] = (n23 * n32 * n41 - n22 * n33 * n41 - n23 * n31 * n42 + n21 * n33 * n42 + n22 * n31 * n43 - n21 * n32 * n43) * detInv;\n\t\tte[4] = t12 * detInv;\n\t\tte[5] = (n13 * n34 * n41 - n14 * n33 * n41 + n14 * n31 * n43 - n11 * n34 * n43 - n13 * n31 * n44 + n11 * n33 * n44) * detInv;\n\t\tte[6] = (n14 * n32 * n41 - n12 * n34 * n41 - n14 * n31 * n42 + n11 * n34 * n42 + n12 * n31 * n44 - n11 * n32 * n44) * detInv;\n\t\tte[7] = (n12 * n33 * n41 - n13 * n32 * n41 + n13 * n31 * n42 - n11 * n33 * n42 - n12 * n31 * n43 + n11 * n32 * n43) * detInv;\n\t\tte[8] = t13 * detInv;\n\t\tte[9] = (n14 * n23 * n41 - n13 * n24 * n41 - n14 * n21 * n43 + n11 * n24 * n43 + n13 * n21 * n44 - n11 * n23 * n44) * detInv;\n\t\tte[10] = (n12 * n24 * n41 - n14 * n22 * n41 + n14 * n21 * n42 - n11 * n24 * n42 - n12 * n21 * n44 + n11 * n22 * n44) * detInv;\n\t\tte[11] = (n13 * n22 * n41 - n12 * n23 * n41 - n13 * n21 * n42 + n11 * n23 * n42 + n12 * n21 * n43 - n11 * n22 * n43) * detInv;\n\t\tte[12] = t14 * detInv;\n\t\tte[13] = (n13 * n24 * n31 - n14 * n23 * n31 + n14 * n21 * n33 - n11 * n24 * n33 - n13 * n21 * n34 + n11 * n23 * n34) * detInv;\n\t\tte[14] = (n14 * n22 * n31 - n12 * n24 * n31 - n14 * n21 * n32 + n11 * n24 * n32 + n12 * n21 * n34 - n11 * n22 * n34) * detInv;\n\t\tte[15] = (n12 * n23 * n31 - n13 * n22 * n31 + n13 * n21 * n32 - n11 * n23 * n32 - n12 * n21 * n33 + n11 * n22 * n33) * detInv;\n\t\treturn this;\n\t}\n\n\tscale(v) {\n\t\tconst te = this.elements;\n\t\tconst x = v.x,\n\t\t\t\t\ty = v.y,\n\t\t\t\t\tz = v.z;\n\t\tte[0] *= x;\n\t\tte[4] *= y;\n\t\tte[8] *= z;\n\t\tte[1] *= x;\n\t\tte[5] *= y;\n\t\tte[9] *= z;\n\t\tte[2] *= x;\n\t\tte[6] *= y;\n\t\tte[10] *= z;\n\t\tte[3] *= x;\n\t\tte[7] *= y;\n\t\tte[11] *= z;\n\t\treturn this;\n\t}\n\n\tgetMaxScaleOnAxis() {\n\t\tconst te = this.elements;\n\t\tconst scaleXSq = te[0] * te[0] + te[1] * te[1] + te[2] * te[2];\n\t\tconst scaleYSq = te[4] * te[4] + te[5] * te[5] + te[6] * te[6];\n\t\tconst scaleZSq = te[8] * te[8] + te[9] * te[9] + te[10] * te[10];\n\t\treturn Math.sqrt(Math.max(scaleXSq, scaleYSq, scaleZSq));\n\t}\n\n\tmakeTranslation(x, y, z) {\n\t\tthis.set(1, 0, 0, x, 0, 1, 0, y, 0, 0, 1, z, 0, 0, 0, 1);\n\t\treturn this;\n\t}\n\n\tmakeRotationX(theta) {\n\t\tconst c = Math.cos(theta),\n\t\t\t\t\ts = Math.sin(theta);\n\t\tthis.set(1, 0, 0, 0, 0, c, -s, 0, 0, s, c, 0, 0, 0, 0, 1);\n\t\treturn this;\n\t}\n\n\tmakeRotationY(theta) {\n\t\tconst c = Math.cos(theta),\n\t\t\t\t\ts = Math.sin(theta);\n\t\tthis.set(c, 0, s, 0, 0, 1, 0, 0, -s, 0, c, 0, 0, 0, 0, 1);\n\t\treturn this;\n\t}\n\n\tmakeRotationZ(theta) {\n\t\tconst c = Math.cos(theta),\n\t\t\t\t\ts = Math.sin(theta);\n\t\tthis.set(c, -s, 0, 0, s, c, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);\n\t\treturn this;\n\t}\n\n\tmakeRotationAxis(axis, angle) {\n\t\t// Based on http://www.gamedev.net/reference/articles/article1199.asp\n\t\tconst c = Math.cos(angle);\n\t\tconst s = Math.sin(angle);\n\t\tconst t = 1 - c;\n\t\tconst x = axis.x,\n\t\t\t\t\ty = axis.y,\n\t\t\t\t\tz = axis.z;\n\t\tconst tx = t * x,\n\t\t\t\t\tty = t * y;\n\t\tthis.set(tx * x + c, tx * y - s * z, tx * z + s * y, 0, tx * y + s * z, ty * y + c, ty * z - s * x, 0, tx * z - s * y, ty * z + s * x, t * z * z + c, 0, 0, 0, 0, 1);\n\t\treturn this;\n\t}\n\n\tmakeScale(x, y, z) {\n\t\tthis.set(x, 0, 0, 0, 0, y, 0, 0, 0, 0, z, 0, 0, 0, 0, 1);\n\t\treturn this;\n\t}\n\n\tmakeShear(xy, xz, yx, yz, zx, zy) {\n\t\tthis.set(1, yx, zx, 0, xy, 1, zy, 0, xz, yz, 1, 0, 0, 0, 0, 1);\n\t\treturn this;\n\t}\n\n\tcompose(position, quaternion, scale) {\n\t\tconst te = this.elements;\n\t\tconst x = quaternion._x,\n\t\t\t\t\ty = quaternion._y,\n\t\t\t\t\tz = quaternion._z,\n\t\t\t\t\tw = quaternion._w;\n\t\tconst x2 = x + x,\n\t\t\t\t\ty2 = y + y,\n\t\t\t\t\tz2 = z + z;\n\t\tconst xx = x * x2,\n\t\t\t\t\txy = x * y2,\n\t\t\t\t\txz = x * z2;\n\t\tconst yy = y * y2,\n\t\t\t\t\tyz = y * z2,\n\t\t\t\t\tzz = z * z2;\n\t\tconst wx = w * x2,\n\t\t\t\t\twy = w * y2,\n\t\t\t\t\twz = w * z2;\n\t\tconst sx = scale.x,\n\t\t\t\t\tsy = scale.y,\n\t\t\t\t\tsz = scale.z;\n\t\tte[0] = (1 - (yy + zz)) * sx;\n\t\tte[1] = (xy + wz) * sx;\n\t\tte[2] = (xz - wy) * sx;\n\t\tte[3] = 0;\n\t\tte[4] = (xy - wz) * sy;\n\t\tte[5] = (1 - (xx + zz)) * sy;\n\t\tte[6] = (yz + wx) * sy;\n\t\tte[7] = 0;\n\t\tte[8] = (xz + wy) * sz;\n\t\tte[9] = (yz - wx) * sz;\n\t\tte[10] = (1 - (xx + yy)) * sz;\n\t\tte[11] = 0;\n\t\tte[12] = position.x;\n\t\tte[13] = position.y;\n\t\tte[14] = position.z;\n\t\tte[15] = 1;\n\t\treturn this;\n\t}\n\n\tdecompose(position, quaternion, scale) {\n\t\tconst te = this.elements;\n\n\t\tlet sx = _v1$5.set(te[0], te[1], te[2]).length();\n\n\t\tconst sy = _v1$5.set(te[4], te[5], te[6]).length();\n\n\t\tconst sz = _v1$5.set(te[8], te[9], te[10]).length(); // if determine is negative, we need to invert one scale\n\n\n\t\tconst det = this.determinant();\n\t\tif (det < 0) sx = -sx;\n\t\tposition.x = te[12];\n\t\tposition.y = te[13];\n\t\tposition.z = te[14]; // scale the rotation part\n\n\t\t_m1$2.copy(this);\n\n\t\tconst invSX = 1 / sx;\n\t\tconst invSY = 1 / sy;\n\t\tconst invSZ = 1 / sz;\n\t\t_m1$2.elements[0] *= invSX;\n\t\t_m1$2.elements[1] *= invSX;\n\t\t_m1$2.elements[2] *= invSX;\n\t\t_m1$2.elements[4] *= invSY;\n\t\t_m1$2.elements[5] *= invSY;\n\t\t_m1$2.elements[6] *= invSY;\n\t\t_m1$2.elements[8] *= invSZ;\n\t\t_m1$2.elements[9] *= invSZ;\n\t\t_m1$2.elements[10] *= invSZ;\n\t\tquaternion.setFromRotationMatrix(_m1$2);\n\t\tscale.x = sx;\n\t\tscale.y = sy;\n\t\tscale.z = sz;\n\t\treturn this;\n\t}\n\n\tmakePerspective(left, right, top, bottom, near, far) {\n\t\tif (far === undefined) {\n\t\t\tconsole.warn('THREE.Matrix4: .makePerspective() has been redefined and has a new signature. Please check the docs.');\n\t\t}\n\n\t\tconst te = this.elements;\n\t\tconst x = 2 * near / (right - left);\n\t\tconst y = 2 * near / (top - bottom);\n\t\tconst a = (right + left) / (right - left);\n\t\tconst b = (top + bottom) / (top - bottom);\n\t\tconst c = -(far + near) / (far - near);\n\t\tconst d = -2 * far * near / (far - near);\n\t\tte[0] = x;\n\t\tte[4] = 0;\n\t\tte[8] = a;\n\t\tte[12] = 0;\n\t\tte[1] = 0;\n\t\tte[5] = y;\n\t\tte[9] = b;\n\t\tte[13] = 0;\n\t\tte[2] = 0;\n\t\tte[6] = 0;\n\t\tte[10] = c;\n\t\tte[14] = d;\n\t\tte[3] = 0;\n\t\tte[7] = 0;\n\t\tte[11] = -1;\n\t\tte[15] = 0;\n\t\treturn this;\n\t}\n\n\tmakeOrthographic(left, right, top, bottom, near, far) {\n\t\tconst te = this.elements;\n\t\tconst w = 1.0 / (right - left);\n\t\tconst h = 1.0 / (top - bottom);\n\t\tconst p = 1.0 / (far - near);\n\t\tconst x = (right + left) * w;\n\t\tconst y = (top + bottom) * h;\n\t\tconst z = (far + near) * p;\n\t\tte[0] = 2 * w;\n\t\tte[4] = 0;\n\t\tte[8] = 0;\n\t\tte[12] = -x;\n\t\tte[1] = 0;\n\t\tte[5] = 2 * h;\n\t\tte[9] = 0;\n\t\tte[13] = -y;\n\t\tte[2] = 0;\n\t\tte[6] = 0;\n\t\tte[10] = -2 * p;\n\t\tte[14] = -z;\n\t\tte[3] = 0;\n\t\tte[7] = 0;\n\t\tte[11] = 0;\n\t\tte[15] = 1;\n\t\treturn this;\n\t}\n\n\tequals(matrix) {\n\t\tconst te = this.elements;\n\t\tconst me = matrix.elements;\n\n\t\tfor (let i = 0; i < 16; i++) {\n\t\t\tif (te[i] !== me[i]) return false;\n\t\t}\n\n\t\treturn true;\n\t}\n\n\tfromArray(array, offset = 0) {\n\t\tfor (let i = 0; i < 16; i++) {\n\t\t\tthis.elements[i] = array[i + offset];\n\t\t}\n\n\t\treturn this;\n\t}\n\n\ttoArray(array = [], offset = 0) {\n\t\tconst te = this.elements;\n\t\tarray[offset] = te[0];\n\t\tarray[offset + 1] = te[1];\n\t\tarray[offset + 2] = te[2];\n\t\tarray[offset + 3] = te[3];\n\t\tarray[offset + 4] = te[4];\n\t\tarray[offset + 5] = te[5];\n\t\tarray[offset + 6] = te[6];\n\t\tarray[offset + 7] = te[7];\n\t\tarray[offset + 8] = te[8];\n\t\tarray[offset + 9] = te[9];\n\t\tarray[offset + 10] = te[10];\n\t\tarray[offset + 11] = te[11];\n\t\tarray[offset + 12] = te[12];\n\t\tarray[offset + 13] = te[13];\n\t\tarray[offset + 14] = te[14];\n\t\tarray[offset + 15] = te[15];\n\t\treturn array;\n\t}\n\n}\n\nconst _v1$5 = /*@__PURE__*/new Vector3();\n\nconst _m1$2 = /*@__PURE__*/new Matrix4();\n\nconst _zero = /*@__PURE__*/new Vector3(0, 0, 0);\n\nconst _one = /*@__PURE__*/new Vector3(1, 1, 1);\n\nconst _x = /*@__PURE__*/new Vector3();\n\nconst _y = /*@__PURE__*/new Vector3();\n\nconst _z = /*@__PURE__*/new Vector3();\n\nconst _matrix$1 = /*@__PURE__*/new Matrix4();\n\nconst _quaternion$3 = /*@__PURE__*/new Quaternion();\n\nclass Euler {\n\tconstructor(x = 0, y = 0, z = 0, order = Euler.DefaultOrder) {\n\t\tthis.isEuler = true;\n\t\tthis._x = x;\n\t\tthis._y = y;\n\t\tthis._z = z;\n\t\tthis._order = order;\n\t}\n\n\tget x() {\n\t\treturn this._x;\n\t}\n\n\tset x(value) {\n\t\tthis._x = value;\n\n\t\tthis._onChangeCallback();\n\t}\n\n\tget y() {\n\t\treturn this._y;\n\t}\n\n\tset y(value) {\n\t\tthis._y = value;\n\n\t\tthis._onChangeCallback();\n\t}\n\n\tget z() {\n\t\treturn this._z;\n\t}\n\n\tset z(value) {\n\t\tthis._z = value;\n\n\t\tthis._onChangeCallback();\n\t}\n\n\tget order() {\n\t\treturn this._order;\n\t}\n\n\tset order(value) {\n\t\tthis._order = value;\n\n\t\tthis._onChangeCallback();\n\t}\n\n\tset(x, y, z, order = this._order) {\n\t\tthis._x = x;\n\t\tthis._y = y;\n\t\tthis._z = z;\n\t\tthis._order = order;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor(this._x, this._y, this._z, this._order);\n\t}\n\n\tcopy(euler) {\n\t\tthis._x = euler._x;\n\t\tthis._y = euler._y;\n\t\tthis._z = euler._z;\n\t\tthis._order = euler._order;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\t}\n\n\tsetFromRotationMatrix(m, order = this._order, update = true) {\n\t\t// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n\t\tconst te = m.elements;\n\t\tconst m11 = te[0],\n\t\t\t\t\tm12 = te[4],\n\t\t\t\t\tm13 = te[8];\n\t\tconst m21 = te[1],\n\t\t\t\t\tm22 = te[5],\n\t\t\t\t\tm23 = te[9];\n\t\tconst m31 = te[2],\n\t\t\t\t\tm32 = te[6],\n\t\t\t\t\tm33 = te[10];\n\n\t\tswitch (order) {\n\t\t\tcase 'XYZ':\n\t\t\t\tthis._y = Math.asin(clamp(m13, -1, 1));\n\n\t\t\t\tif (Math.abs(m13) < 0.9999999) {\n\t\t\t\t\tthis._x = Math.atan2(-m23, m33);\n\t\t\t\t\tthis._z = Math.atan2(-m12, m11);\n\t\t\t\t} else {\n\t\t\t\t\tthis._x = Math.atan2(m32, m22);\n\t\t\t\t\tthis._z = 0;\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'YXZ':\n\t\t\t\tthis._x = Math.asin(-clamp(m23, -1, 1));\n\n\t\t\t\tif (Math.abs(m23) < 0.9999999) {\n\t\t\t\t\tthis._y = Math.atan2(m13, m33);\n\t\t\t\t\tthis._z = Math.atan2(m21, m22);\n\t\t\t\t} else {\n\t\t\t\t\tthis._y = Math.atan2(-m31, m11);\n\t\t\t\t\tthis._z = 0;\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'ZXY':\n\t\t\t\tthis._x = Math.asin(clamp(m32, -1, 1));\n\n\t\t\t\tif (Math.abs(m32) < 0.9999999) {\n\t\t\t\t\tthis._y = Math.atan2(-m31, m33);\n\t\t\t\t\tthis._z = Math.atan2(-m12, m22);\n\t\t\t\t} else {\n\t\t\t\t\tthis._y = 0;\n\t\t\t\t\tthis._z = Math.atan2(m21, m11);\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'ZYX':\n\t\t\t\tthis._y = Math.asin(-clamp(m31, -1, 1));\n\n\t\t\t\tif (Math.abs(m31) < 0.9999999) {\n\t\t\t\t\tthis._x = Math.atan2(m32, m33);\n\t\t\t\t\tthis._z = Math.atan2(m21, m11);\n\t\t\t\t} else {\n\t\t\t\t\tthis._x = 0;\n\t\t\t\t\tthis._z = Math.atan2(-m12, m22);\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'YZX':\n\t\t\t\tthis._z = Math.asin(clamp(m21, -1, 1));\n\n\t\t\t\tif (Math.abs(m21) < 0.9999999) {\n\t\t\t\t\tthis._x = Math.atan2(-m23, m22);\n\t\t\t\t\tthis._y = Math.atan2(-m31, m11);\n\t\t\t\t} else {\n\t\t\t\t\tthis._x = 0;\n\t\t\t\t\tthis._y = Math.atan2(m13, m33);\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'XZY':\n\t\t\t\tthis._z = Math.asin(-clamp(m12, -1, 1));\n\n\t\t\t\tif (Math.abs(m12) < 0.9999999) {\n\t\t\t\t\tthis._x = Math.atan2(m32, m22);\n\t\t\t\t\tthis._y = Math.atan2(m13, m11);\n\t\t\t\t} else {\n\t\t\t\t\tthis._x = Math.atan2(-m23, m33);\n\t\t\t\t\tthis._y = 0;\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tconsole.warn('THREE.Euler: .setFromRotationMatrix() encountered an unknown order: ' + order);\n\t\t}\n\n\t\tthis._order = order;\n\t\tif (update === true) this._onChangeCallback();\n\t\treturn this;\n\t}\n\n\tsetFromQuaternion(q, order, update) {\n\t\t_matrix$1.makeRotationFromQuaternion(q);\n\n\t\treturn this.setFromRotationMatrix(_matrix$1, order, update);\n\t}\n\n\tsetFromVector3(v, order = this._order) {\n\t\treturn this.set(v.x, v.y, v.z, order);\n\t}\n\n\treorder(newOrder) {\n\t\t// WARNING: this discards revolution information -bhouston\n\t\t_quaternion$3.setFromEuler(this);\n\n\t\treturn this.setFromQuaternion(_quaternion$3, newOrder);\n\t}\n\n\tequals(euler) {\n\t\treturn euler._x === this._x && euler._y === this._y && euler._z === this._z && euler._order === this._order;\n\t}\n\n\tfromArray(array) {\n\t\tthis._x = array[0];\n\t\tthis._y = array[1];\n\t\tthis._z = array[2];\n\t\tif (array[3] !== undefined) this._order = array[3];\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\t}\n\n\ttoArray(array = [], offset = 0) {\n\t\tarray[offset] = this._x;\n\t\tarray[offset + 1] = this._y;\n\t\tarray[offset + 2] = this._z;\n\t\tarray[offset + 3] = this._order;\n\t\treturn array;\n\t}\n\n\t_onChange(callback) {\n\t\tthis._onChangeCallback = callback;\n\t\treturn this;\n\t}\n\n\t_onChangeCallback() {}\n\n\t*[Symbol.iterator]() {\n\t\tyield this._x;\n\t\tyield this._y;\n\t\tyield this._z;\n\t\tyield this._order;\n\t} // @deprecated since r138, 02cf0df1cb4575d5842fef9c85bb5a89fe020d53\n\n\n\ttoVector3() {\n\t\tconsole.error('THREE.Euler: .toVector3() has been removed. Use Vector3.setFromEuler() instead');\n\t}\n\n}\n\nEuler.DefaultOrder = 'XYZ';\nEuler.RotationOrders = ['XYZ', 'YZX', 'ZXY', 'XZY', 'YXZ', 'ZYX'];\n\nclass Layers {\n\tconstructor() {\n\t\tthis.mask = 1 | 0;\n\t}\n\n\tset(channel) {\n\t\tthis.mask = (1 << channel | 0) >>> 0;\n\t}\n\n\tenable(channel) {\n\t\tthis.mask |= 1 << channel | 0;\n\t}\n\n\tenableAll() {\n\t\tthis.mask = 0xffffffff | 0;\n\t}\n\n\ttoggle(channel) {\n\t\tthis.mask ^= 1 << channel | 0;\n\t}\n\n\tdisable(channel) {\n\t\tthis.mask &= ~(1 << channel | 0);\n\t}\n\n\tdisableAll() {\n\t\tthis.mask = 0;\n\t}\n\n\ttest(layers) {\n\t\treturn (this.mask & layers.mask) !== 0;\n\t}\n\n\tisEnabled(channel) {\n\t\treturn (this.mask & (1 << channel | 0)) !== 0;\n\t}\n\n}\n\nlet _object3DId = 0;\n\nconst _v1$4 = /*@__PURE__*/new Vector3();\n\nconst _q1 = /*@__PURE__*/new Quaternion();\n\nconst _m1$1 = /*@__PURE__*/new Matrix4();\n\nconst _target = /*@__PURE__*/new Vector3();\n\nconst _position$3 = /*@__PURE__*/new Vector3();\n\nconst _scale$2 = /*@__PURE__*/new Vector3();\n\nconst _quaternion$2 = /*@__PURE__*/new Quaternion();\n\nconst _xAxis = /*@__PURE__*/new Vector3(1, 0, 0);\n\nconst _yAxis = /*@__PURE__*/new Vector3(0, 1, 0);\n\nconst _zAxis = /*@__PURE__*/new Vector3(0, 0, 1);\n\nconst _addedEvent = {\n\ttype: 'added'\n};\nconst _removedEvent = {\n\ttype: 'removed'\n};\n\nclass Object3D extends EventDispatcher {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.isObject3D = true;\n\t\tObject.defineProperty(this, 'id', {\n\t\t\tvalue: _object3DId++\n\t\t});\n\t\tthis.uuid = generateUUID();\n\t\tthis.name = '';\n\t\tthis.type = 'Object3D';\n\t\tthis.parent = null;\n\t\tthis.children = [];\n\t\tthis.up = Object3D.DefaultUp.clone();\n\t\tconst position = new Vector3();\n\t\tconst rotation = new Euler();\n\t\tconst quaternion = new Quaternion();\n\t\tconst scale = new Vector3(1, 1, 1);\n\n\t\tfunction onRotationChange() {\n\t\t\tquaternion.setFromEuler(rotation, false);\n\t\t}\n\n\t\tfunction onQuaternionChange() {\n\t\t\trotation.setFromQuaternion(quaternion, undefined, false);\n\t\t}\n\n\t\trotation._onChange(onRotationChange);\n\n\t\tquaternion._onChange(onQuaternionChange);\n\n\t\tObject.defineProperties(this, {\n\t\t\tposition: {\n\t\t\t\tconfigurable: true,\n\t\t\t\tenumerable: true,\n\t\t\t\tvalue: position\n\t\t\t},\n\t\t\trotation: {\n\t\t\t\tconfigurable: true,\n\t\t\t\tenumerable: true,\n\t\t\t\tvalue: rotation\n\t\t\t},\n\t\t\tquaternion: {\n\t\t\t\tconfigurable: true,\n\t\t\t\tenumerable: true,\n\t\t\t\tvalue: quaternion\n\t\t\t},\n\t\t\tscale: {\n\t\t\t\tconfigurable: true,\n\t\t\t\tenumerable: true,\n\t\t\t\tvalue: scale\n\t\t\t},\n\t\t\tmodelViewMatrix: {\n\t\t\t\tvalue: new Matrix4()\n\t\t\t},\n\t\t\tnormalMatrix: {\n\t\t\t\tvalue: new Matrix3()\n\t\t\t}\n\t\t});\n\t\tthis.matrix = new Matrix4();\n\t\tthis.matrixWorld = new Matrix4();\n\t\tthis.matrixAutoUpdate = Object3D.DefaultMatrixAutoUpdate;\n\t\tthis.matrixWorldNeedsUpdate = false;\n\t\tthis.layers = new Layers();\n\t\tthis.visible = true;\n\t\tthis.castShadow = false;\n\t\tthis.receiveShadow = false;\n\t\tthis.frustumCulled = true;\n\t\tthis.renderOrder = 0;\n\t\tthis.animations = [];\n\t\tthis.userData = {};\n\t}\n\n\tonBeforeRender() {}\n\n\tonAfterRender() {}\n\n\tapplyMatrix4(matrix) {\n\t\tif (this.matrixAutoUpdate) this.updateMatrix();\n\t\tthis.matrix.premultiply(matrix);\n\t\tthis.matrix.decompose(this.position, this.quaternion, this.scale);\n\t}\n\n\tapplyQuaternion(q) {\n\t\tthis.quaternion.premultiply(q);\n\t\treturn this;\n\t}\n\n\tsetRotationFromAxisAngle(axis, angle) {\n\t\t// assumes axis is normalized\n\t\tthis.quaternion.setFromAxisAngle(axis, angle);\n\t}\n\n\tsetRotationFromEuler(euler) {\n\t\tthis.quaternion.setFromEuler(euler, true);\n\t}\n\n\tsetRotationFromMatrix(m) {\n\t\t// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n\t\tthis.quaternion.setFromRotationMatrix(m);\n\t}\n\n\tsetRotationFromQuaternion(q) {\n\t\t// assumes q is normalized\n\t\tthis.quaternion.copy(q);\n\t}\n\n\trotateOnAxis(axis, angle) {\n\t\t// rotate object on axis in object space\n\t\t// axis is assumed to be normalized\n\t\t_q1.setFromAxisAngle(axis, angle);\n\n\t\tthis.quaternion.multiply(_q1);\n\t\treturn this;\n\t}\n\n\trotateOnWorldAxis(axis, angle) {\n\t\t// rotate object on axis in world space\n\t\t// axis is assumed to be normalized\n\t\t// method assumes no rotated parent\n\t\t_q1.setFromAxisAngle(axis, angle);\n\n\t\tthis.quaternion.premultiply(_q1);\n\t\treturn this;\n\t}\n\n\trotateX(angle) {\n\t\treturn this.rotateOnAxis(_xAxis, angle);\n\t}\n\n\trotateY(angle) {\n\t\treturn this.rotateOnAxis(_yAxis, angle);\n\t}\n\n\trotateZ(angle) {\n\t\treturn this.rotateOnAxis(_zAxis, angle);\n\t}\n\n\ttranslateOnAxis(axis, distance) {\n\t\t// translate object by distance along axis in object space\n\t\t// axis is assumed to be normalized\n\t\t_v1$4.copy(axis).applyQuaternion(this.quaternion);\n\n\t\tthis.position.add(_v1$4.multiplyScalar(distance));\n\t\treturn this;\n\t}\n\n\ttranslateX(distance) {\n\t\treturn this.translateOnAxis(_xAxis, distance);\n\t}\n\n\ttranslateY(distance) {\n\t\treturn this.translateOnAxis(_yAxis, distance);\n\t}\n\n\ttranslateZ(distance) {\n\t\treturn this.translateOnAxis(_zAxis, distance);\n\t}\n\n\tlocalToWorld(vector) {\n\t\treturn vector.applyMatrix4(this.matrixWorld);\n\t}\n\n\tworldToLocal(vector) {\n\t\treturn vector.applyMatrix4(_m1$1.copy(this.matrixWorld).invert());\n\t}\n\n\tlookAt(x, y, z) {\n\t\t// This method does not support objects having non-uniformly-scaled parent(s)\n\t\tif (x.isVector3) {\n\t\t\t_target.copy(x);\n\t\t} else {\n\t\t\t_target.set(x, y, z);\n\t\t}\n\n\t\tconst parent = this.parent;\n\t\tthis.updateWorldMatrix(true, false);\n\n\t\t_position$3.setFromMatrixPosition(this.matrixWorld);\n\n\t\tif (this.isCamera || this.isLight) {\n\t\t\t_m1$1.lookAt(_position$3, _target, this.up);\n\t\t} else {\n\t\t\t_m1$1.lookAt(_target, _position$3, this.up);\n\t\t}\n\n\t\tthis.quaternion.setFromRotationMatrix(_m1$1);\n\n\t\tif (parent) {\n\t\t\t_m1$1.extractRotation(parent.matrixWorld);\n\n\t\t\t_q1.setFromRotationMatrix(_m1$1);\n\n\t\t\tthis.quaternion.premultiply(_q1.invert());\n\t\t}\n\t}\n\n\tadd(object) {\n\t\tif (arguments.length > 1) {\n\t\t\tfor (let i = 0; i < arguments.length; i++) {\n\t\t\t\tthis.add(arguments[i]);\n\t\t\t}\n\n\t\t\treturn this;\n\t\t}\n\n\t\tif (object === this) {\n\t\t\tconsole.error('THREE.Object3D.add: object can\\'t be added as a child of itself.', object);\n\t\t\treturn this;\n\t\t}\n\n\t\tif (object && object.isObject3D) {\n\t\t\tif (object.parent !== null) {\n\t\t\t\tobject.parent.remove(object);\n\t\t\t}\n\n\t\t\tobject.parent = this;\n\t\t\tthis.children.push(object);\n\t\t\tobject.dispatchEvent(_addedEvent);\n\t\t} else {\n\t\t\tconsole.error('THREE.Object3D.add: object not an instance of THREE.Object3D.', object);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tremove(object) {\n\t\tif (arguments.length > 1) {\n\t\t\tfor (let i = 0; i < arguments.length; i++) {\n\t\t\t\tthis.remove(arguments[i]);\n\t\t\t}\n\n\t\t\treturn this;\n\t\t}\n\n\t\tconst index = this.children.indexOf(object);\n\n\t\tif (index !== -1) {\n\t\t\tobject.parent = null;\n\t\t\tthis.children.splice(index, 1);\n\t\t\tobject.dispatchEvent(_removedEvent);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tremoveFromParent() {\n\t\tconst parent = this.parent;\n\n\t\tif (parent !== null) {\n\t\t\tparent.remove(this);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tclear() {\n\t\tfor (let i = 0; i < this.children.length; i++) {\n\t\t\tconst object = this.children[i];\n\t\t\tobject.parent = null;\n\t\t\tobject.dispatchEvent(_removedEvent);\n\t\t}\n\n\t\tthis.children.length = 0;\n\t\treturn this;\n\t}\n\n\tattach(object) {\n\t\t// adds object as a child of this, while maintaining the object's world transform\n\t\t// Note: This method does not support scene graphs having non-uniformly-scaled nodes(s)\n\t\tthis.updateWorldMatrix(true, false);\n\n\t\t_m1$1.copy(this.matrixWorld).invert();\n\n\t\tif (object.parent !== null) {\n\t\t\tobject.parent.updateWorldMatrix(true, false);\n\n\t\t\t_m1$1.multiply(object.parent.matrixWorld);\n\t\t}\n\n\t\tobject.applyMatrix4(_m1$1);\n\t\tthis.add(object);\n\t\tobject.updateWorldMatrix(false, true);\n\t\treturn this;\n\t}\n\n\tgetObjectById(id) {\n\t\treturn this.getObjectByProperty('id', id);\n\t}\n\n\tgetObjectByName(name) {\n\t\treturn this.getObjectByProperty('name', name);\n\t}\n\n\tgetObjectByProperty(name, value) {\n\t\tif (this[name] === value) return this;\n\n\t\tfor (let i = 0, l = this.children.length; i < l; i++) {\n\t\t\tconst child = this.children[i];\n\t\t\tconst object = child.getObjectByProperty(name, value);\n\n\t\t\tif (object !== undefined) {\n\t\t\t\treturn object;\n\t\t\t}\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\tgetWorldPosition(target) {\n\t\tthis.updateWorldMatrix(true, false);\n\t\treturn target.setFromMatrixPosition(this.matrixWorld);\n\t}\n\n\tgetWorldQuaternion(target) {\n\t\tthis.updateWorldMatrix(true, false);\n\t\tthis.matrixWorld.decompose(_position$3, target, _scale$2);\n\t\treturn target;\n\t}\n\n\tgetWorldScale(target) {\n\t\tthis.updateWorldMatrix(true, false);\n\t\tthis.matrixWorld.decompose(_position$3, _quaternion$2, target);\n\t\treturn target;\n\t}\n\n\tgetWorldDirection(target) {\n\t\tthis.updateWorldMatrix(true, false);\n\t\tconst e = this.matrixWorld.elements;\n\t\treturn target.set(e[8], e[9], e[10]).normalize();\n\t}\n\n\traycast() {}\n\n\ttraverse(callback) {\n\t\tcallback(this);\n\t\tconst children = this.children;\n\n\t\tfor (let i = 0, l = children.length; i < l; i++) {\n\t\t\tchildren[i].traverse(callback);\n\t\t}\n\t}\n\n\ttraverseVisible(callback) {\n\t\tif (this.visible === false) return;\n\t\tcallback(this);\n\t\tconst children = this.children;\n\n\t\tfor (let i = 0, l = children.length; i < l; i++) {\n\t\t\tchildren[i].traverseVisible(callback);\n\t\t}\n\t}\n\n\ttraverseAncestors(callback) {\n\t\tconst parent = this.parent;\n\n\t\tif (parent !== null) {\n\t\t\tcallback(parent);\n\t\t\tparent.traverseAncestors(callback);\n\t\t}\n\t}\n\n\tupdateMatrix() {\n\t\tthis.matrix.compose(this.position, this.quaternion, this.scale);\n\t\tthis.matrixWorldNeedsUpdate = true;\n\t}\n\n\tupdateMatrixWorld(force) {\n\t\tif (this.matrixAutoUpdate) this.updateMatrix();\n\n\t\tif (this.matrixWorldNeedsUpdate || force) {\n\t\t\tif (this.parent === null) {\n\t\t\t\tthis.matrixWorld.copy(this.matrix);\n\t\t\t} else {\n\t\t\t\tthis.matrixWorld.multiplyMatrices(this.parent.matrixWorld, this.matrix);\n\t\t\t}\n\n\t\t\tthis.matrixWorldNeedsUpdate = false;\n\t\t\tforce = true;\n\t\t} // update children\n\n\n\t\tconst children = this.children;\n\n\t\tfor (let i = 0, l = children.length; i < l; i++) {\n\t\t\tchildren[i].updateMatrixWorld(force);\n\t\t}\n\t}\n\n\tupdateWorldMatrix(updateParents, updateChildren) {\n\t\tconst parent = this.parent;\n\n\t\tif (updateParents === true && parent !== null) {\n\t\t\tparent.updateWorldMatrix(true, false);\n\t\t}\n\n\t\tif (this.matrixAutoUpdate) this.updateMatrix();\n\n\t\tif (this.parent === null) {\n\t\t\tthis.matrixWorld.copy(this.matrix);\n\t\t} else {\n\t\t\tthis.matrixWorld.multiplyMatrices(this.parent.matrixWorld, this.matrix);\n\t\t} // update children\n\n\n\t\tif (updateChildren === true) {\n\t\t\tconst children = this.children;\n\n\t\t\tfor (let i = 0, l = children.length; i < l; i++) {\n\t\t\t\tchildren[i].updateWorldMatrix(false, true);\n\t\t\t}\n\t\t}\n\t}\n\n\ttoJSON(meta) {\n\t\t// meta is a string when called from JSON.stringify\n\t\tconst isRootObject = meta === undefined || typeof meta === 'string';\n\t\tconst output = {}; // meta is a hash used to collect geometries, materials.\n\t\t// not providing it implies that this is the root object\n\t\t// being serialized.\n\n\t\tif (isRootObject) {\n\t\t\t// initialize meta obj\n\t\t\tmeta = {\n\t\t\t\tgeometries: {},\n\t\t\t\tmaterials: {},\n\t\t\t\ttextures: {},\n\t\t\t\timages: {},\n\t\t\t\tshapes: {},\n\t\t\t\tskeletons: {},\n\t\t\t\tanimations: {},\n\t\t\t\tnodes: {}\n\t\t\t};\n\t\t\toutput.metadata = {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Object',\n\t\t\t\tgenerator: 'Object3D.toJSON'\n\t\t\t};\n\t\t} // standard Object3D serialization\n\n\n\t\tconst object = {};\n\t\tobject.uuid = this.uuid;\n\t\tobject.type = this.type;\n\t\tif (this.name !== '') object.name = this.name;\n\t\tif (this.castShadow === true) object.castShadow = true;\n\t\tif (this.receiveShadow === true) object.receiveShadow = true;\n\t\tif (this.visible === false) object.visible = false;\n\t\tif (this.frustumCulled === false) object.frustumCulled = false;\n\t\tif (this.renderOrder !== 0) object.renderOrder = this.renderOrder;\n\t\tif (JSON.stringify(this.userData) !== '{}') object.userData = this.userData;\n\t\tobject.layers = this.layers.mask;\n\t\tobject.matrix = this.matrix.toArray();\n\t\tif (this.matrixAutoUpdate === false) object.matrixAutoUpdate = false; // object specific properties\n\n\t\tif (this.isInstancedMesh) {\n\t\t\tobject.type = 'InstancedMesh';\n\t\t\tobject.count = this.count;\n\t\t\tobject.instanceMatrix = this.instanceMatrix.toJSON();\n\t\t\tif (this.instanceColor !== null) object.instanceColor = this.instanceColor.toJSON();\n\t\t} //\n\n\n\t\tfunction serialize(library, element) {\n\t\t\tif (library[element.uuid] === undefined) {\n\t\t\t\tlibrary[element.uuid] = element.toJSON(meta);\n\t\t\t}\n\n\t\t\treturn element.uuid;\n\t\t}\n\n\t\tif (this.isScene) {\n\t\t\tif (this.background) {\n\t\t\t\tif (this.background.isColor) {\n\t\t\t\t\tobject.background = this.background.toJSON();\n\t\t\t\t} else if (this.background.isTexture) {\n\t\t\t\t\tobject.background = this.background.toJSON(meta).uuid;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (this.environment && this.environment.isTexture) {\n\t\t\t\tobject.environment = this.environment.toJSON(meta).uuid;\n\t\t\t}\n\t\t} else if (this.isMesh || this.isLine || this.isPoints) {\n\t\t\tobject.geometry = serialize(meta.geometries, this.geometry);\n\t\t\tconst parameters = this.geometry.parameters;\n\n\t\t\tif (parameters !== undefined && parameters.shapes !== undefined) {\n\t\t\t\tconst shapes = parameters.shapes;\n\n\t\t\t\tif (Array.isArray(shapes)) {\n\t\t\t\t\tfor (let i = 0, l = shapes.length; i < l; i++) {\n\t\t\t\t\t\tconst shape = shapes[i];\n\t\t\t\t\t\tserialize(meta.shapes, shape);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tserialize(meta.shapes, shapes);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (this.isSkinnedMesh) {\n\t\t\tobject.bindMode = this.bindMode;\n\t\t\tobject.bindMatrix = this.bindMatrix.toArray();\n\n\t\t\tif (this.skeleton !== undefined) {\n\t\t\t\tserialize(meta.skeletons, this.skeleton);\n\t\t\t\tobject.skeleton = this.skeleton.uuid;\n\t\t\t}\n\t\t}\n\n\t\tif (this.material !== undefined) {\n\t\t\tif (Array.isArray(this.material)) {\n\t\t\t\tconst uuids = [];\n\n\t\t\t\tfor (let i = 0, l = this.material.length; i < l; i++) {\n\t\t\t\t\tuuids.push(serialize(meta.materials, this.material[i]));\n\t\t\t\t}\n\n\t\t\t\tobject.material = uuids;\n\t\t\t} else {\n\t\t\t\tobject.material = serialize(meta.materials, this.material);\n\t\t\t}\n\t\t} //\n\n\n\t\tif (this.children.length > 0) {\n\t\t\tobject.children = [];\n\n\t\t\tfor (let i = 0; i < this.children.length; i++) {\n\t\t\t\tobject.children.push(this.children[i].toJSON(meta).object);\n\t\t\t}\n\t\t} //\n\n\n\t\tif (this.animations.length > 0) {\n\t\t\tobject.animations = [];\n\n\t\t\tfor (let i = 0; i < this.animations.length; i++) {\n\t\t\t\tconst animation = this.animations[i];\n\t\t\t\tobject.animations.push(serialize(meta.animations, animation));\n\t\t\t}\n\t\t}\n\n\t\tif (isRootObject) {\n\t\t\tconst geometries = extractFromCache(meta.geometries);\n\t\t\tconst materials = extractFromCache(meta.materials);\n\t\t\tconst textures = extractFromCache(meta.textures);\n\t\t\tconst images = extractFromCache(meta.images);\n\t\t\tconst shapes = extractFromCache(meta.shapes);\n\t\t\tconst skeletons = extractFromCache(meta.skeletons);\n\t\t\tconst animations = extractFromCache(meta.animations);\n\t\t\tconst nodes = extractFromCache(meta.nodes);\n\t\t\tif (geometries.length > 0) output.geometries = geometries;\n\t\t\tif (materials.length > 0) output.materials = materials;\n\t\t\tif (textures.length > 0) output.textures = textures;\n\t\t\tif (images.length > 0) output.images = images;\n\t\t\tif (shapes.length > 0) output.shapes = shapes;\n\t\t\tif (skeletons.length > 0) output.skeletons = skeletons;\n\t\t\tif (animations.length > 0) output.animations = animations;\n\t\t\tif (nodes.length > 0) output.nodes = nodes;\n\t\t}\n\n\t\toutput.object = object;\n\t\treturn output; // extract data from the cache hash\n\t\t// remove metadata on each item\n\t\t// and return as array\n\n\t\tfunction extractFromCache(cache) {\n\t\t\tconst values = [];\n\n\t\t\tfor (const key in cache) {\n\t\t\t\tconst data = cache[key];\n\t\t\t\tdelete data.metadata;\n\t\t\t\tvalues.push(data);\n\t\t\t}\n\n\t\t\treturn values;\n\t\t}\n\t}\n\n\tclone(recursive) {\n\t\treturn new this.constructor().copy(this, recursive);\n\t}\n\n\tcopy(source, recursive = true) {\n\t\tthis.name = source.name;\n\t\tthis.up.copy(source.up);\n\t\tthis.position.copy(source.position);\n\t\tthis.rotation.order = source.rotation.order;\n\t\tthis.quaternion.copy(source.quaternion);\n\t\tthis.scale.copy(source.scale);\n\t\tthis.matrix.copy(source.matrix);\n\t\tthis.matrixWorld.copy(source.matrixWorld);\n\t\tthis.matrixAutoUpdate = source.matrixAutoUpdate;\n\t\tthis.matrixWorldNeedsUpdate = source.matrixWorldNeedsUpdate;\n\t\tthis.layers.mask = source.layers.mask;\n\t\tthis.visible = source.visible;\n\t\tthis.castShadow = source.castShadow;\n\t\tthis.receiveShadow = source.receiveShadow;\n\t\tthis.frustumCulled = source.frustumCulled;\n\t\tthis.renderOrder = source.renderOrder;\n\t\tthis.userData = JSON.parse(JSON.stringify(source.userData));\n\n\t\tif (recursive === true) {\n\t\t\tfor (let i = 0; i < source.children.length; i++) {\n\t\t\t\tconst child = source.children[i];\n\t\t\t\tthis.add(child.clone());\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t}\n\n}\n\nObject3D.DefaultUp = new Vector3(0, 1, 0);\nObject3D.DefaultMatrixAutoUpdate = true;\n\nconst _v0$1 = /*@__PURE__*/new Vector3();\n\nconst _v1$3 = /*@__PURE__*/new Vector3();\n\nconst _v2$2 = /*@__PURE__*/new Vector3();\n\nconst _v3$1 = /*@__PURE__*/new Vector3();\n\nconst _vab = /*@__PURE__*/new Vector3();\n\nconst _vac = /*@__PURE__*/new Vector3();\n\nconst _vbc = /*@__PURE__*/new Vector3();\n\nconst _vap = /*@__PURE__*/new Vector3();\n\nconst _vbp = /*@__PURE__*/new Vector3();\n\nconst _vcp = /*@__PURE__*/new Vector3();\n\nclass Triangle {\n\tconstructor(a = new Vector3(), b = new Vector3(), c = new Vector3()) {\n\t\tthis.a = a;\n\t\tthis.b = b;\n\t\tthis.c = c;\n\t}\n\n\tstatic getNormal(a, b, c, target) {\n\t\ttarget.subVectors(c, b);\n\n\t\t_v0$1.subVectors(a, b);\n\n\t\ttarget.cross(_v0$1);\n\t\tconst targetLengthSq = target.lengthSq();\n\n\t\tif (targetLengthSq > 0) {\n\t\t\treturn target.multiplyScalar(1 / Math.sqrt(targetLengthSq));\n\t\t}\n\n\t\treturn target.set(0, 0, 0);\n\t} // static/instance method to calculate barycentric coordinates\n\t// based on: http://www.blackpawn.com/texts/pointinpoly/default.html\n\n\n\tstatic getBarycoord(point, a, b, c, target) {\n\t\t_v0$1.subVectors(c, a);\n\n\t\t_v1$3.subVectors(b, a);\n\n\t\t_v2$2.subVectors(point, a);\n\n\t\tconst dot00 = _v0$1.dot(_v0$1);\n\n\t\tconst dot01 = _v0$1.dot(_v1$3);\n\n\t\tconst dot02 = _v0$1.dot(_v2$2);\n\n\t\tconst dot11 = _v1$3.dot(_v1$3);\n\n\t\tconst dot12 = _v1$3.dot(_v2$2);\n\n\t\tconst denom = dot00 * dot11 - dot01 * dot01; // collinear or singular triangle\n\n\t\tif (denom === 0) {\n\t\t\t// arbitrary location outside of triangle?\n\t\t\t// not sure if this is the best idea, maybe should be returning undefined\n\t\t\treturn target.set(-2, -1, -1);\n\t\t}\n\n\t\tconst invDenom = 1 / denom;\n\t\tconst u = (dot11 * dot02 - dot01 * dot12) * invDenom;\n\t\tconst v = (dot00 * dot12 - dot01 * dot02) * invDenom; // barycentric coordinates must always sum to 1\n\n\t\treturn target.set(1 - u - v, v, u);\n\t}\n\n\tstatic containsPoint(point, a, b, c) {\n\t\tthis.getBarycoord(point, a, b, c, _v3$1);\n\t\treturn _v3$1.x >= 0 && _v3$1.y >= 0 && _v3$1.x + _v3$1.y <= 1;\n\t}\n\n\tstatic getUV(point, p1, p2, p3, uv1, uv2, uv3, target) {\n\t\tthis.getBarycoord(point, p1, p2, p3, _v3$1);\n\t\ttarget.set(0, 0);\n\t\ttarget.addScaledVector(uv1, _v3$1.x);\n\t\ttarget.addScaledVector(uv2, _v3$1.y);\n\t\ttarget.addScaledVector(uv3, _v3$1.z);\n\t\treturn target;\n\t}\n\n\tstatic isFrontFacing(a, b, c, direction) {\n\t\t_v0$1.subVectors(c, b);\n\n\t\t_v1$3.subVectors(a, b); // strictly front facing\n\n\n\t\treturn _v0$1.cross(_v1$3).dot(direction) < 0 ? true : false;\n\t}\n\n\tset(a, b, c) {\n\t\tthis.a.copy(a);\n\t\tthis.b.copy(b);\n\t\tthis.c.copy(c);\n\t\treturn this;\n\t}\n\n\tsetFromPointsAndIndices(points, i0, i1, i2) {\n\t\tthis.a.copy(points[i0]);\n\t\tthis.b.copy(points[i1]);\n\t\tthis.c.copy(points[i2]);\n\t\treturn this;\n\t}\n\n\tsetFromAttributeAndIndices(attribute, i0, i1, i2) {\n\t\tthis.a.fromBufferAttribute(attribute, i0);\n\t\tthis.b.fromBufferAttribute(attribute, i1);\n\t\tthis.c.fromBufferAttribute(attribute, i2);\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n\tcopy(triangle) {\n\t\tthis.a.copy(triangle.a);\n\t\tthis.b.copy(triangle.b);\n\t\tthis.c.copy(triangle.c);\n\t\treturn this;\n\t}\n\n\tgetArea() {\n\t\t_v0$1.subVectors(this.c, this.b);\n\n\t\t_v1$3.subVectors(this.a, this.b);\n\n\t\treturn _v0$1.cross(_v1$3).length() * 0.5;\n\t}\n\n\tgetMidpoint(target) {\n\t\treturn target.addVectors(this.a, this.b).add(this.c).multiplyScalar(1 / 3);\n\t}\n\n\tgetNormal(target) {\n\t\treturn Triangle.getNormal(this.a, this.b, this.c, target);\n\t}\n\n\tgetPlane(target) {\n\t\treturn target.setFromCoplanarPoints(this.a, this.b, this.c);\n\t}\n\n\tgetBarycoord(point, target) {\n\t\treturn Triangle.getBarycoord(point, this.a, this.b, this.c, target);\n\t}\n\n\tgetUV(point, uv1, uv2, uv3, target) {\n\t\treturn Triangle.getUV(point, this.a, this.b, this.c, uv1, uv2, uv3, target);\n\t}\n\n\tcontainsPoint(point) {\n\t\treturn Triangle.containsPoint(point, this.a, this.b, this.c);\n\t}\n\n\tisFrontFacing(direction) {\n\t\treturn Triangle.isFrontFacing(this.a, this.b, this.c, direction);\n\t}\n\n\tintersectsBox(box) {\n\t\treturn box.intersectsTriangle(this);\n\t}\n\n\tclosestPointToPoint(p, target) {\n\t\tconst a = this.a,\n\t\t\t\t\tb = this.b,\n\t\t\t\t\tc = this.c;\n\t\tlet v, w; // algorithm thanks to Real-Time Collision Detection by Christer Ericson,\n\t\t// published by Morgan Kaufmann Publishers, (c) 2005 Elsevier Inc.,\n\t\t// under the accompanying license; see chapter 5.1.5 for detailed explanation.\n\t\t// basically, we're distinguishing which of the voronoi regions of the triangle\n\t\t// the point lies in with the minimum amount of redundant computation.\n\n\t\t_vab.subVectors(b, a);\n\n\t\t_vac.subVectors(c, a);\n\n\t\t_vap.subVectors(p, a);\n\n\t\tconst d1 = _vab.dot(_vap);\n\n\t\tconst d2 = _vac.dot(_vap);\n\n\t\tif (d1 <= 0 && d2 <= 0) {\n\t\t\t// vertex region of A; barycentric coords (1, 0, 0)\n\t\t\treturn target.copy(a);\n\t\t}\n\n\t\t_vbp.subVectors(p, b);\n\n\t\tconst d3 = _vab.dot(_vbp);\n\n\t\tconst d4 = _vac.dot(_vbp);\n\n\t\tif (d3 >= 0 && d4 <= d3) {\n\t\t\t// vertex region of B; barycentric coords (0, 1, 0)\n\t\t\treturn target.copy(b);\n\t\t}\n\n\t\tconst vc = d1 * d4 - d3 * d2;\n\n\t\tif (vc <= 0 && d1 >= 0 && d3 <= 0) {\n\t\t\tv = d1 / (d1 - d3); // edge region of AB; barycentric coords (1-v, v, 0)\n\n\t\t\treturn target.copy(a).addScaledVector(_vab, v);\n\t\t}\n\n\t\t_vcp.subVectors(p, c);\n\n\t\tconst d5 = _vab.dot(_vcp);\n\n\t\tconst d6 = _vac.dot(_vcp);\n\n\t\tif (d6 >= 0 && d5 <= d6) {\n\t\t\t// vertex region of C; barycentric coords (0, 0, 1)\n\t\t\treturn target.copy(c);\n\t\t}\n\n\t\tconst vb = d5 * d2 - d1 * d6;\n\n\t\tif (vb <= 0 && d2 >= 0 && d6 <= 0) {\n\t\t\tw = d2 / (d2 - d6); // edge region of AC; barycentric coords (1-w, 0, w)\n\n\t\t\treturn target.copy(a).addScaledVector(_vac, w);\n\t\t}\n\n\t\tconst va = d3 * d6 - d5 * d4;\n\n\t\tif (va <= 0 && d4 - d3 >= 0 && d5 - d6 >= 0) {\n\t\t\t_vbc.subVectors(c, b);\n\n\t\t\tw = (d4 - d3) / (d4 - d3 + (d5 - d6)); // edge region of BC; barycentric coords (0, 1-w, w)\n\n\t\t\treturn target.copy(b).addScaledVector(_vbc, w); // edge region of BC\n\t\t} // face region\n\n\n\t\tconst denom = 1 / (va + vb + vc); // u = va * denom\n\n\t\tv = vb * denom;\n\t\tw = vc * denom;\n\t\treturn target.copy(a).addScaledVector(_vab, v).addScaledVector(_vac, w);\n\t}\n\n\tequals(triangle) {\n\t\treturn triangle.a.equals(this.a) && triangle.b.equals(this.b) && triangle.c.equals(this.c);\n\t}\n\n}\n\nlet materialId = 0;\n\nclass Material extends EventDispatcher {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.isMaterial = true;\n\t\tObject.defineProperty(this, 'id', {\n\t\t\tvalue: materialId++\n\t\t});\n\t\tthis.uuid = generateUUID();\n\t\tthis.name = '';\n\t\tthis.type = 'Material';\n\t\tthis.blending = NormalBlending;\n\t\tthis.side = FrontSide;\n\t\tthis.vertexColors = false;\n\t\tthis.opacity = 1;\n\t\tthis.transparent = false;\n\t\tthis.blendSrc = SrcAlphaFactor;\n\t\tthis.blendDst = OneMinusSrcAlphaFactor;\n\t\tthis.blendEquation = AddEquation;\n\t\tthis.blendSrcAlpha = null;\n\t\tthis.blendDstAlpha = null;\n\t\tthis.blendEquationAlpha = null;\n\t\tthis.depthFunc = LessEqualDepth;\n\t\tthis.depthTest = true;\n\t\tthis.depthWrite = true;\n\t\tthis.stencilWriteMask = 0xff;\n\t\tthis.stencilFunc = AlwaysStencilFunc;\n\t\tthis.stencilRef = 0;\n\t\tthis.stencilFuncMask = 0xff;\n\t\tthis.stencilFail = KeepStencilOp;\n\t\tthis.stencilZFail = KeepStencilOp;\n\t\tthis.stencilZPass = KeepStencilOp;\n\t\tthis.stencilWrite = false;\n\t\tthis.clippingPlanes = null;\n\t\tthis.clipIntersection = false;\n\t\tthis.clipShadows = false;\n\t\tthis.shadowSide = null;\n\t\tthis.colorWrite = true;\n\t\tthis.precision = null; // override the renderer's default precision for this material\n\n\t\tthis.polygonOffset = false;\n\t\tthis.polygonOffsetFactor = 0;\n\t\tthis.polygonOffsetUnits = 0;\n\t\tthis.dithering = false;\n\t\tthis.alphaToCoverage = false;\n\t\tthis.premultipliedAlpha = false;\n\t\tthis.visible = true;\n\t\tthis.toneMapped = true;\n\t\tthis.userData = {};\n\t\tthis.version = 0;\n\t\tthis._alphaTest = 0;\n\t}\n\n\tget alphaTest() {\n\t\treturn this._alphaTest;\n\t}\n\n\tset alphaTest(value) {\n\t\tif (this._alphaTest > 0 !== value > 0) {\n\t\t\tthis.version++;\n\t\t}\n\n\t\tthis._alphaTest = value;\n\t}\n\n\tonBuild() {}\n\n\tonBeforeRender() {}\n\n\tonBeforeCompile() {}\n\n\tcustomProgramCacheKey() {\n\t\treturn this.onBeforeCompile.toString();\n\t}\n\n\tsetValues(values) {\n\t\tif (values === undefined) return;\n\n\t\tfor (const key in values) {\n\t\t\tconst newValue = values[key];\n\n\t\t\tif (newValue === undefined) {\n\t\t\t\tconsole.warn('THREE.Material: \\'' + key + '\\' parameter is undefined.');\n\t\t\t\tcontinue;\n\t\t\t} // for backward compatibility if shading is set in the constructor\n\n\n\t\t\tif (key === 'shading') {\n\t\t\t\tconsole.warn('THREE.' + this.type + ': .shading has been removed. Use the boolean .flatShading instead.');\n\t\t\t\tthis.flatShading = newValue === FlatShading ? true : false;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tconst currentValue = this[key];\n\n\t\t\tif (currentValue === undefined) {\n\t\t\t\tconsole.warn('THREE.' + this.type + ': \\'' + key + '\\' is not a property of this material.');\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (currentValue && currentValue.isColor) {\n\t\t\t\tcurrentValue.set(newValue);\n\t\t\t} else if (currentValue && currentValue.isVector3 && newValue && newValue.isVector3) {\n\t\t\t\tcurrentValue.copy(newValue);\n\t\t\t} else {\n\t\t\t\tthis[key] = newValue;\n\t\t\t}\n\t\t}\n\t}\n\n\ttoJSON(meta) {\n\t\tconst isRootObject = meta === undefined || typeof meta === 'string';\n\n\t\tif (isRootObject) {\n\t\t\tmeta = {\n\t\t\t\ttextures: {},\n\t\t\t\timages: {}\n\t\t\t};\n\t\t}\n\n\t\tconst data = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Material',\n\t\t\t\tgenerator: 'Material.toJSON'\n\t\t\t}\n\t\t}; // standard Material serialization\n\n\t\tdata.uuid = this.uuid;\n\t\tdata.type = this.type;\n\t\tif (this.name !== '') data.name = this.name;\n\t\tif (this.color && this.color.isColor) data.color = this.color.getHex();\n\t\tif (this.roughness !== undefined) data.roughness = this.roughness;\n\t\tif (this.metalness !== undefined) data.metalness = this.metalness;\n\t\tif (this.sheen !== undefined) data.sheen = this.sheen;\n\t\tif (this.sheenColor && this.sheenColor.isColor) data.sheenColor = this.sheenColor.getHex();\n\t\tif (this.sheenRoughness !== undefined) data.sheenRoughness = this.sheenRoughness;\n\t\tif (this.emissive && this.emissive.isColor) data.emissive = this.emissive.getHex();\n\t\tif (this.emissiveIntensity && this.emissiveIntensity !== 1) data.emissiveIntensity = this.emissiveIntensity;\n\t\tif (this.specular && this.specular.isColor) data.specular = this.specular.getHex();\n\t\tif (this.specularIntensity !== undefined) data.specularIntensity = this.specularIntensity;\n\t\tif (this.specularColor && this.specularColor.isColor) data.specularColor = this.specularColor.getHex();\n\t\tif (this.shininess !== undefined) data.shininess = this.shininess;\n\t\tif (this.clearcoat !== undefined) data.clearcoat = this.clearcoat;\n\t\tif (this.clearcoatRoughness !== undefined) data.clearcoatRoughness = this.clearcoatRoughness;\n\n\t\tif (this.clearcoatMap && this.clearcoatMap.isTexture) {\n\t\t\tdata.clearcoatMap = this.clearcoatMap.toJSON(meta).uuid;\n\t\t}\n\n\t\tif (this.clearcoatRoughnessMap && this.clearcoatRoughnessMap.isTexture) {\n\t\t\tdata.clearcoatRoughnessMap = this.clearcoatRoughnessMap.toJSON(meta).uuid;\n\t\t}\n\n\t\tif (this.clearcoatNormalMap && this.clearcoatNormalMap.isTexture) {\n\t\t\tdata.clearcoatNormalMap = this.clearcoatNormalMap.toJSON(meta).uuid;\n\t\t\tdata.clearcoatNormalScale = this.clearcoatNormalScale.toArray();\n\t\t}\n\n\t\tif (this.iridescence !== undefined) data.iridescence = this.iridescence;\n\t\tif (this.iridescenceIOR !== undefined) data.iridescenceIOR = this.iridescenceIOR;\n\t\tif (this.iridescenceThicknessRange !== undefined) data.iridescenceThicknessRange = this.iridescenceThicknessRange;\n\n\t\tif (this.iridescenceMap && this.iridescenceMap.isTexture) {\n\t\t\tdata.iridescenceMap = this.iridescenceMap.toJSON(meta).uuid;\n\t\t}\n\n\t\tif (this.iridescenceThicknessMap && this.iridescenceThicknessMap.isTexture) {\n\t\t\tdata.iridescenceThicknessMap = this.iridescenceThicknessMap.toJSON(meta).uuid;\n\t\t}\n\n\t\tif (this.map && this.map.isTexture) data.map = this.map.toJSON(meta).uuid;\n\t\tif (this.matcap && this.matcap.isTexture) data.matcap = this.matcap.toJSON(meta).uuid;\n\t\tif (this.alphaMap && this.alphaMap.isTexture) data.alphaMap = this.alphaMap.toJSON(meta).uuid;\n\n\t\tif (this.lightMap && this.lightMap.isTexture) {\n\t\t\tdata.lightMap = this.lightMap.toJSON(meta).uuid;\n\t\t\tdata.lightMapIntensity = this.lightMapIntensity;\n\t\t}\n\n\t\tif (this.aoMap && this.aoMap.isTexture) {\n\t\t\tdata.aoMap = this.aoMap.toJSON(meta).uuid;\n\t\t\tdata.aoMapIntensity = this.aoMapIntensity;\n\t\t}\n\n\t\tif (this.bumpMap && this.bumpMap.isTexture) {\n\t\t\tdata.bumpMap = this.bumpMap.toJSON(meta).uuid;\n\t\t\tdata.bumpScale = this.bumpScale;\n\t\t}\n\n\t\tif (this.normalMap && this.normalMap.isTexture) {\n\t\t\tdata.normalMap = this.normalMap.toJSON(meta).uuid;\n\t\t\tdata.normalMapType = this.normalMapType;\n\t\t\tdata.normalScale = this.normalScale.toArray();\n\t\t}\n\n\t\tif (this.displacementMap && this.displacementMap.isTexture) {\n\t\t\tdata.displacementMap = this.displacementMap.toJSON(meta).uuid;\n\t\t\tdata.displacementScale = this.displacementScale;\n\t\t\tdata.displacementBias = this.displacementBias;\n\t\t}\n\n\t\tif (this.roughnessMap && this.roughnessMap.isTexture) data.roughnessMap = this.roughnessMap.toJSON(meta).uuid;\n\t\tif (this.metalnessMap && this.metalnessMap.isTexture) data.metalnessMap = this.metalnessMap.toJSON(meta).uuid;\n\t\tif (this.emissiveMap && this.emissiveMap.isTexture) data.emissiveMap = this.emissiveMap.toJSON(meta).uuid;\n\t\tif (this.specularMap && this.specularMap.isTexture) data.specularMap = this.specularMap.toJSON(meta).uuid;\n\t\tif (this.specularIntensityMap && this.specularIntensityMap.isTexture) data.specularIntensityMap = this.specularIntensityMap.toJSON(meta).uuid;\n\t\tif (this.specularColorMap && this.specularColorMap.isTexture) data.specularColorMap = this.specularColorMap.toJSON(meta).uuid;\n\n\t\tif (this.envMap && this.envMap.isTexture) {\n\t\t\tdata.envMap = this.envMap.toJSON(meta).uuid;\n\t\t\tif (this.combine !== undefined) data.combine = this.combine;\n\t\t}\n\n\t\tif (this.envMapIntensity !== undefined) data.envMapIntensity = this.envMapIntensity;\n\t\tif (this.reflectivity !== undefined) data.reflectivity = this.reflectivity;\n\t\tif (this.refractionRatio !== undefined) data.refractionRatio = this.refractionRatio;\n\n\t\tif (this.gradientMap && this.gradientMap.isTexture) {\n\t\t\tdata.gradientMap = this.gradientMap.toJSON(meta).uuid;\n\t\t}\n\n\t\tif (this.transmission !== undefined) data.transmission = this.transmission;\n\t\tif (this.transmissionMap && this.transmissionMap.isTexture) data.transmissionMap = this.transmissionMap.toJSON(meta).uuid;\n\t\tif (this.thickness !== undefined) data.thickness = this.thickness;\n\t\tif (this.thicknessMap && this.thicknessMap.isTexture) data.thicknessMap = this.thicknessMap.toJSON(meta).uuid;\n\t\tif (this.attenuationDistance !== undefined) data.attenuationDistance = this.attenuationDistance;\n\t\tif (this.attenuationColor !== undefined) data.attenuationColor = this.attenuationColor.getHex();\n\t\tif (this.size !== undefined) data.size = this.size;\n\t\tif (this.shadowSide !== null) data.shadowSide = this.shadowSide;\n\t\tif (this.sizeAttenuation !== undefined) data.sizeAttenuation = this.sizeAttenuation;\n\t\tif (this.blending !== NormalBlending) data.blending = this.blending;\n\t\tif (this.side !== FrontSide) data.side = this.side;\n\t\tif (this.vertexColors) data.vertexColors = true;\n\t\tif (this.opacity < 1) data.opacity = this.opacity;\n\t\tif (this.transparent === true) data.transparent = this.transparent;\n\t\tdata.depthFunc = this.depthFunc;\n\t\tdata.depthTest = this.depthTest;\n\t\tdata.depthWrite = this.depthWrite;\n\t\tdata.colorWrite = this.colorWrite;\n\t\tdata.stencilWrite = this.stencilWrite;\n\t\tdata.stencilWriteMask = this.stencilWriteMask;\n\t\tdata.stencilFunc = this.stencilFunc;\n\t\tdata.stencilRef = this.stencilRef;\n\t\tdata.stencilFuncMask = this.stencilFuncMask;\n\t\tdata.stencilFail = this.stencilFail;\n\t\tdata.stencilZFail = this.stencilZFail;\n\t\tdata.stencilZPass = this.stencilZPass; // rotation (SpriteMaterial)\n\n\t\tif (this.rotation !== undefined && this.rotation !== 0) data.rotation = this.rotation;\n\t\tif (this.polygonOffset === true) data.polygonOffset = true;\n\t\tif (this.polygonOffsetFactor !== 0) data.polygonOffsetFactor = this.polygonOffsetFactor;\n\t\tif (this.polygonOffsetUnits !== 0) data.polygonOffsetUnits = this.polygonOffsetUnits;\n\t\tif (this.linewidth !== undefined && this.linewidth !== 1) data.linewidth = this.linewidth;\n\t\tif (this.dashSize !== undefined) data.dashSize = this.dashSize;\n\t\tif (this.gapSize !== undefined) data.gapSize = this.gapSize;\n\t\tif (this.scale !== undefined) data.scale = this.scale;\n\t\tif (this.dithering === true) data.dithering = true;\n\t\tif (this.alphaTest > 0) data.alphaTest = this.alphaTest;\n\t\tif (this.alphaToCoverage === true) data.alphaToCoverage = this.alphaToCoverage;\n\t\tif (this.premultipliedAlpha === true) data.premultipliedAlpha = this.premultipliedAlpha;\n\t\tif (this.wireframe === true) data.wireframe = this.wireframe;\n\t\tif (this.wireframeLinewidth > 1) data.wireframeLinewidth = this.wireframeLinewidth;\n\t\tif (this.wireframeLinecap !== 'round') data.wireframeLinecap = this.wireframeLinecap;\n\t\tif (this.wireframeLinejoin !== 'round') data.wireframeLinejoin = this.wireframeLinejoin;\n\t\tif (this.flatShading === true) data.flatShading = this.flatShading;\n\t\tif (this.visible === false) data.visible = false;\n\t\tif (this.toneMapped === false) data.toneMapped = false;\n\t\tif (this.fog === false) data.fog = false;\n\t\tif (JSON.stringify(this.userData) !== '{}') data.userData = this.userData; // TODO: Copied from Object3D.toJSON\n\n\t\tfunction extractFromCache(cache) {\n\t\t\tconst values = [];\n\n\t\t\tfor (const key in cache) {\n\t\t\t\tconst data = cache[key];\n\t\t\t\tdelete data.metadata;\n\t\t\t\tvalues.push(data);\n\t\t\t}\n\n\t\t\treturn values;\n\t\t}\n\n\t\tif (isRootObject) {\n\t\t\tconst textures = extractFromCache(meta.textures);\n\t\t\tconst images = extractFromCache(meta.images);\n\t\t\tif (textures.length > 0) data.textures = textures;\n\t\t\tif (images.length > 0) data.images = images;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n\tcopy(source) {\n\t\tthis.name = source.name;\n\t\tthis.blending = source.blending;\n\t\tthis.side = source.side;\n\t\tthis.vertexColors = source.vertexColors;\n\t\tthis.opacity = source.opacity;\n\t\tthis.transparent = source.transparent;\n\t\tthis.blendSrc = source.blendSrc;\n\t\tthis.blendDst = source.blendDst;\n\t\tthis.blendEquation = source.blendEquation;\n\t\tthis.blendSrcAlpha = source.blendSrcAlpha;\n\t\tthis.blendDstAlpha = source.blendDstAlpha;\n\t\tthis.blendEquationAlpha = source.blendEquationAlpha;\n\t\tthis.depthFunc = source.depthFunc;\n\t\tthis.depthTest = source.depthTest;\n\t\tthis.depthWrite = source.depthWrite;\n\t\tthis.stencilWriteMask = source.stencilWriteMask;\n\t\tthis.stencilFunc = source.stencilFunc;\n\t\tthis.stencilRef = source.stencilRef;\n\t\tthis.stencilFuncMask = source.stencilFuncMask;\n\t\tthis.stencilFail = source.stencilFail;\n\t\tthis.stencilZFail = source.stencilZFail;\n\t\tthis.stencilZPass = source.stencilZPass;\n\t\tthis.stencilWrite = source.stencilWrite;\n\t\tconst srcPlanes = source.clippingPlanes;\n\t\tlet dstPlanes = null;\n\n\t\tif (srcPlanes !== null) {\n\t\t\tconst n = srcPlanes.length;\n\t\t\tdstPlanes = new Array(n);\n\n\t\t\tfor (let i = 0; i !== n; ++i) {\n\t\t\t\tdstPlanes[i] = srcPlanes[i].clone();\n\t\t\t}\n\t\t}\n\n\t\tthis.clippingPlanes = dstPlanes;\n\t\tthis.clipIntersection = source.clipIntersection;\n\t\tthis.clipShadows = source.clipShadows;\n\t\tthis.shadowSide = source.shadowSide;\n\t\tthis.colorWrite = source.colorWrite;\n\t\tthis.precision = source.precision;\n\t\tthis.polygonOffset = source.polygonOffset;\n\t\tthis.polygonOffsetFactor = source.polygonOffsetFactor;\n\t\tthis.polygonOffsetUnits = source.polygonOffsetUnits;\n\t\tthis.dithering = source.dithering;\n\t\tthis.alphaTest = source.alphaTest;\n\t\tthis.alphaToCoverage = source.alphaToCoverage;\n\t\tthis.premultipliedAlpha = source.premultipliedAlpha;\n\t\tthis.visible = source.visible;\n\t\tthis.toneMapped = source.toneMapped;\n\t\tthis.userData = JSON.parse(JSON.stringify(source.userData));\n\t\treturn this;\n\t}\n\n\tdispose() {\n\t\tthis.dispatchEvent({\n\t\t\ttype: 'dispose'\n\t\t});\n\t}\n\n\tset needsUpdate(value) {\n\t\tif (value === true) this.version++;\n\t} // @deprecated since r131, f5803c62cc4a29d90744e9dc7811d086e354c1d8\n\n\n\tget vertexTangents() {\n\t\tconsole.warn('THREE.' + this.type + ': .vertexTangents has been removed.');\n\t\treturn false;\n\t}\n\n\tset vertexTangents(value) {\n\t\tconsole.warn('THREE.' + this.type + ': .vertexTangents has been removed.');\n\t}\n\n}\n\nMaterial.fromType = function\n\t/*type*/\n() {\n\t// TODO: Behavior added in Materials.js\n\treturn null;\n};\n\nclass MeshBasicMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isMeshBasicMaterial = true;\n\t\tthis.type = 'MeshBasicMaterial';\n\t\tthis.color = new Color(0xffffff); // emissive\n\n\t\tthis.map = null;\n\t\tthis.lightMap = null;\n\t\tthis.lightMapIntensity = 1.0;\n\t\tthis.aoMap = null;\n\t\tthis.aoMapIntensity = 1.0;\n\t\tthis.specularMap = null;\n\t\tthis.alphaMap = null;\n\t\tthis.envMap = null;\n\t\tthis.combine = MultiplyOperation;\n\t\tthis.reflectivity = 1;\n\t\tthis.refractionRatio = 0.98;\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.wireframeLinecap = 'round';\n\t\tthis.wireframeLinejoin = 'round';\n\t\tthis.fog = true;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.color.copy(source.color);\n\t\tthis.map = source.map;\n\t\tthis.lightMap = source.lightMap;\n\t\tthis.lightMapIntensity = source.lightMapIntensity;\n\t\tthis.aoMap = source.aoMap;\n\t\tthis.aoMapIntensity = source.aoMapIntensity;\n\t\tthis.specularMap = source.specularMap;\n\t\tthis.alphaMap = source.alphaMap;\n\t\tthis.envMap = source.envMap;\n\t\tthis.combine = source.combine;\n\t\tthis.reflectivity = source.reflectivity;\n\t\tthis.refractionRatio = source.refractionRatio;\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\tthis.wireframeLinecap = source.wireframeLinecap;\n\t\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\t\tthis.fog = source.fog;\n\t\treturn this;\n\t}\n\n}\n\nconst _vector$9 = /*@__PURE__*/new Vector3();\n\nconst _vector2$1 = /*@__PURE__*/new Vector2();\n\nclass BufferAttribute {\n\tconstructor(array, itemSize, normalized) {\n\t\tif (Array.isArray(array)) {\n\t\t\tthrow new TypeError('THREE.BufferAttribute: array should be a Typed Array.');\n\t\t}\n\n\t\tthis.isBufferAttribute = true;\n\t\tthis.name = '';\n\t\tthis.array = array;\n\t\tthis.itemSize = itemSize;\n\t\tthis.count = array !== undefined ? array.length / itemSize : 0;\n\t\tthis.normalized = normalized === true;\n\t\tthis.usage = StaticDrawUsage;\n\t\tthis.updateRange = {\n\t\t\toffset: 0,\n\t\t\tcount: -1\n\t\t};\n\t\tthis.version = 0;\n\t}\n\n\tonUploadCallback() {}\n\n\tset needsUpdate(value) {\n\t\tif (value === true) this.version++;\n\t}\n\n\tsetUsage(value) {\n\t\tthis.usage = value;\n\t\treturn this;\n\t}\n\n\tcopy(source) {\n\t\tthis.name = source.name;\n\t\tthis.array = new source.array.constructor(source.array);\n\t\tthis.itemSize = source.itemSize;\n\t\tthis.count = source.count;\n\t\tthis.normalized = source.normalized;\n\t\tthis.usage = source.usage;\n\t\treturn this;\n\t}\n\n\tcopyAt(index1, attribute, index2) {\n\t\tindex1 *= this.itemSize;\n\t\tindex2 *= attribute.itemSize;\n\n\t\tfor (let i = 0, l = this.itemSize; i < l; i++) {\n\t\t\tthis.array[index1 + i] = attribute.array[index2 + i];\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tcopyArray(array) {\n\t\tthis.array.set(array);\n\t\treturn this;\n\t}\n\n\tcopyColorsArray(colors) {\n\t\tconst array = this.array;\n\t\tlet offset = 0;\n\n\t\tfor (let i = 0, l = colors.length; i < l; i++) {\n\t\t\tlet color = colors[i];\n\n\t\t\tif (color === undefined) {\n\t\t\t\tconsole.warn('THREE.BufferAttribute.copyColorsArray(): color is undefined', i);\n\t\t\t\tcolor = new Color();\n\t\t\t}\n\n\t\t\tarray[offset++] = color.r;\n\t\t\tarray[offset++] = color.g;\n\t\t\tarray[offset++] = color.b;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tcopyVector2sArray(vectors) {\n\t\tconst array = this.array;\n\t\tlet offset = 0;\n\n\t\tfor (let i = 0, l = vectors.length; i < l; i++) {\n\t\t\tlet vector = vectors[i];\n\n\t\t\tif (vector === undefined) {\n\t\t\t\tconsole.warn('THREE.BufferAttribute.copyVector2sArray(): vector is undefined', i);\n\t\t\t\tvector = new Vector2();\n\t\t\t}\n\n\t\t\tarray[offset++] = vector.x;\n\t\t\tarray[offset++] = vector.y;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tcopyVector3sArray(vectors) {\n\t\tconst array = this.array;\n\t\tlet offset = 0;\n\n\t\tfor (let i = 0, l = vectors.length; i < l; i++) {\n\t\t\tlet vector = vectors[i];\n\n\t\t\tif (vector === undefined) {\n\t\t\t\tconsole.warn('THREE.BufferAttribute.copyVector3sArray(): vector is undefined', i);\n\t\t\t\tvector = new Vector3();\n\t\t\t}\n\n\t\t\tarray[offset++] = vector.x;\n\t\t\tarray[offset++] = vector.y;\n\t\t\tarray[offset++] = vector.z;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tcopyVector4sArray(vectors) {\n\t\tconst array = this.array;\n\t\tlet offset = 0;\n\n\t\tfor (let i = 0, l = vectors.length; i < l; i++) {\n\t\t\tlet vector = vectors[i];\n\n\t\t\tif (vector === undefined) {\n\t\t\t\tconsole.warn('THREE.BufferAttribute.copyVector4sArray(): vector is undefined', i);\n\t\t\t\tvector = new Vector4();\n\t\t\t}\n\n\t\t\tarray[offset++] = vector.x;\n\t\t\tarray[offset++] = vector.y;\n\t\t\tarray[offset++] = vector.z;\n\t\t\tarray[offset++] = vector.w;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tapplyMatrix3(m) {\n\t\tif (this.itemSize === 2) {\n\t\t\tfor (let i = 0, l = this.count; i < l; i++) {\n\t\t\t\t_vector2$1.fromBufferAttribute(this, i);\n\n\t\t\t\t_vector2$1.applyMatrix3(m);\n\n\t\t\t\tthis.setXY(i, _vector2$1.x, _vector2$1.y);\n\t\t\t}\n\t\t} else if (this.itemSize === 3) {\n\t\t\tfor (let i = 0, l = this.count; i < l; i++) {\n\t\t\t\t_vector$9.fromBufferAttribute(this, i);\n\n\t\t\t\t_vector$9.applyMatrix3(m);\n\n\t\t\t\tthis.setXYZ(i, _vector$9.x, _vector$9.y, _vector$9.z);\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tapplyMatrix4(m) {\n\t\tfor (let i = 0, l = this.count; i < l; i++) {\n\t\t\t_vector$9.fromBufferAttribute(this, i);\n\n\t\t\t_vector$9.applyMatrix4(m);\n\n\t\t\tthis.setXYZ(i, _vector$9.x, _vector$9.y, _vector$9.z);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tapplyNormalMatrix(m) {\n\t\tfor (let i = 0, l = this.count; i < l; i++) {\n\t\t\t_vector$9.fromBufferAttribute(this, i);\n\n\t\t\t_vector$9.applyNormalMatrix(m);\n\n\t\t\tthis.setXYZ(i, _vector$9.x, _vector$9.y, _vector$9.z);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\ttransformDirection(m) {\n\t\tfor (let i = 0, l = this.count; i < l; i++) {\n\t\t\t_vector$9.fromBufferAttribute(this, i);\n\n\t\t\t_vector$9.transformDirection(m);\n\n\t\t\tthis.setXYZ(i, _vector$9.x, _vector$9.y, _vector$9.z);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tset(value, offset = 0) {\n\t\tthis.array.set(value, offset);\n\t\treturn this;\n\t}\n\n\tgetX(index) {\n\t\treturn this.array[index * this.itemSize];\n\t}\n\n\tsetX(index, x) {\n\t\tthis.array[index * this.itemSize] = x;\n\t\treturn this;\n\t}\n\n\tgetY(index) {\n\t\treturn this.array[index * this.itemSize + 1];\n\t}\n\n\tsetY(index, y) {\n\t\tthis.array[index * this.itemSize + 1] = y;\n\t\treturn this;\n\t}\n\n\tgetZ(index) {\n\t\treturn this.array[index * this.itemSize + 2];\n\t}\n\n\tsetZ(index, z) {\n\t\tthis.array[index * this.itemSize + 2] = z;\n\t\treturn this;\n\t}\n\n\tgetW(index) {\n\t\treturn this.array[index * this.itemSize + 3];\n\t}\n\n\tsetW(index, w) {\n\t\tthis.array[index * this.itemSize + 3] = w;\n\t\treturn this;\n\t}\n\n\tsetXY(index, x, y) {\n\t\tindex *= this.itemSize;\n\t\tthis.array[index + 0] = x;\n\t\tthis.array[index + 1] = y;\n\t\treturn this;\n\t}\n\n\tsetXYZ(index, x, y, z) {\n\t\tindex *= this.itemSize;\n\t\tthis.array[index + 0] = x;\n\t\tthis.array[index + 1] = y;\n\t\tthis.array[index + 2] = z;\n\t\treturn this;\n\t}\n\n\tsetXYZW(index, x, y, z, w) {\n\t\tindex *= this.itemSize;\n\t\tthis.array[index + 0] = x;\n\t\tthis.array[index + 1] = y;\n\t\tthis.array[index + 2] = z;\n\t\tthis.array[index + 3] = w;\n\t\treturn this;\n\t}\n\n\tonUpload(callback) {\n\t\tthis.onUploadCallback = callback;\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor(this.array, this.itemSize).copy(this);\n\t}\n\n\ttoJSON() {\n\t\tconst data = {\n\t\t\titemSize: this.itemSize,\n\t\t\ttype: this.array.constructor.name,\n\t\t\tarray: Array.prototype.slice.call(this.array),\n\t\t\tnormalized: this.normalized\n\t\t};\n\t\tif (this.name !== '') data.name = this.name;\n\t\tif (this.usage !== StaticDrawUsage) data.usage = this.usage;\n\t\tif (this.updateRange.offset !== 0 || this.updateRange.count !== -1) data.updateRange = this.updateRange;\n\t\treturn data;\n\t}\n\n} //\n\n\nclass Int8BufferAttribute extends BufferAttribute {\n\tconstructor(array, itemSize, normalized) {\n\t\tsuper(new Int8Array(array), itemSize, normalized);\n\t}\n\n}\n\nclass Uint8BufferAttribute extends BufferAttribute {\n\tconstructor(array, itemSize, normalized) {\n\t\tsuper(new Uint8Array(array), itemSize, normalized);\n\t}\n\n}\n\nclass Uint8ClampedBufferAttribute extends BufferAttribute {\n\tconstructor(array, itemSize, normalized) {\n\t\tsuper(new Uint8ClampedArray(array), itemSize, normalized);\n\t}\n\n}\n\nclass Int16BufferAttribute extends BufferAttribute {\n\tconstructor(array, itemSize, normalized) {\n\t\tsuper(new Int16Array(array), itemSize, normalized);\n\t}\n\n}\n\nclass Uint16BufferAttribute extends BufferAttribute {\n\tconstructor(array, itemSize, normalized) {\n\t\tsuper(new Uint16Array(array), itemSize, normalized);\n\t}\n\n}\n\nclass Int32BufferAttribute extends BufferAttribute {\n\tconstructor(array, itemSize, normalized) {\n\t\tsuper(new Int32Array(array), itemSize, normalized);\n\t}\n\n}\n\nclass Uint32BufferAttribute extends BufferAttribute {\n\tconstructor(array, itemSize, normalized) {\n\t\tsuper(new Uint32Array(array), itemSize, normalized);\n\t}\n\n}\n\nclass Float16BufferAttribute extends BufferAttribute {\n\tconstructor(array, itemSize, normalized) {\n\t\tsuper(new Uint16Array(array), itemSize, normalized);\n\t\tthis.isFloat16BufferAttribute = true;\n\t}\n\n}\n\nclass Float32BufferAttribute extends BufferAttribute {\n\tconstructor(array, itemSize, normalized) {\n\t\tsuper(new Float32Array(array), itemSize, normalized);\n\t}\n\n}\n\nclass Float64BufferAttribute extends BufferAttribute {\n\tconstructor(array, itemSize, normalized) {\n\t\tsuper(new Float64Array(array), itemSize, normalized);\n\t}\n\n} //\n\nlet _id$1 = 0;\n\nconst _m1 = /*@__PURE__*/new Matrix4();\n\nconst _obj = /*@__PURE__*/new Object3D();\n\nconst _offset = /*@__PURE__*/new Vector3();\n\nconst _box$1 = /*@__PURE__*/new Box3();\n\nconst _boxMorphTargets = /*@__PURE__*/new Box3();\n\nconst _vector$8 = /*@__PURE__*/new Vector3();\n\nclass BufferGeometry extends EventDispatcher {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.isBufferGeometry = true;\n\t\tObject.defineProperty(this, 'id', {\n\t\t\tvalue: _id$1++\n\t\t});\n\t\tthis.uuid = generateUUID();\n\t\tthis.name = '';\n\t\tthis.type = 'BufferGeometry';\n\t\tthis.index = null;\n\t\tthis.attributes = {};\n\t\tthis.morphAttributes = {};\n\t\tthis.morphTargetsRelative = false;\n\t\tthis.groups = [];\n\t\tthis.boundingBox = null;\n\t\tthis.boundingSphere = null;\n\t\tthis.drawRange = {\n\t\t\tstart: 0,\n\t\t\tcount: Infinity\n\t\t};\n\t\tthis.userData = {};\n\t}\n\n\tgetIndex() {\n\t\treturn this.index;\n\t}\n\n\tsetIndex(index) {\n\t\tif (Array.isArray(index)) {\n\t\t\tthis.index = new (arrayNeedsUint32(index) ? Uint32BufferAttribute : Uint16BufferAttribute)(index, 1);\n\t\t} else {\n\t\t\tthis.index = index;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tgetAttribute(name) {\n\t\treturn this.attributes[name];\n\t}\n\n\tsetAttribute(name, attribute) {\n\t\tthis.attributes[name] = attribute;\n\t\treturn this;\n\t}\n\n\tdeleteAttribute(name) {\n\t\tdelete this.attributes[name];\n\t\treturn this;\n\t}\n\n\thasAttribute(name) {\n\t\treturn this.attributes[name] !== undefined;\n\t}\n\n\taddGroup(start, count, materialIndex = 0) {\n\t\tthis.groups.push({\n\t\t\tstart: start,\n\t\t\tcount: count,\n\t\t\tmaterialIndex: materialIndex\n\t\t});\n\t}\n\n\tclearGroups() {\n\t\tthis.groups = [];\n\t}\n\n\tsetDrawRange(start, count) {\n\t\tthis.drawRange.start = start;\n\t\tthis.drawRange.count = count;\n\t}\n\n\tapplyMatrix4(matrix) {\n\t\tconst position = this.attributes.position;\n\n\t\tif (position !== undefined) {\n\t\t\tposition.applyMatrix4(matrix);\n\t\t\tposition.needsUpdate = true;\n\t\t}\n\n\t\tconst normal = this.attributes.normal;\n\n\t\tif (normal !== undefined) {\n\t\t\tconst normalMatrix = new Matrix3().getNormalMatrix(matrix);\n\t\t\tnormal.applyNormalMatrix(normalMatrix);\n\t\t\tnormal.needsUpdate = true;\n\t\t}\n\n\t\tconst tangent = this.attributes.tangent;\n\n\t\tif (tangent !== undefined) {\n\t\t\ttangent.transformDirection(matrix);\n\t\t\ttangent.needsUpdate = true;\n\t\t}\n\n\t\tif (this.boundingBox !== null) {\n\t\t\tthis.computeBoundingBox();\n\t\t}\n\n\t\tif (this.boundingSphere !== null) {\n\t\t\tthis.computeBoundingSphere();\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tapplyQuaternion(q) {\n\t\t_m1.makeRotationFromQuaternion(q);\n\n\t\tthis.applyMatrix4(_m1);\n\t\treturn this;\n\t}\n\n\trotateX(angle) {\n\t\t// rotate geometry around world x-axis\n\t\t_m1.makeRotationX(angle);\n\n\t\tthis.applyMatrix4(_m1);\n\t\treturn this;\n\t}\n\n\trotateY(angle) {\n\t\t// rotate geometry around world y-axis\n\t\t_m1.makeRotationY(angle);\n\n\t\tthis.applyMatrix4(_m1);\n\t\treturn this;\n\t}\n\n\trotateZ(angle) {\n\t\t// rotate geometry around world z-axis\n\t\t_m1.makeRotationZ(angle);\n\n\t\tthis.applyMatrix4(_m1);\n\t\treturn this;\n\t}\n\n\ttranslate(x, y, z) {\n\t\t// translate geometry\n\t\t_m1.makeTranslation(x, y, z);\n\n\t\tthis.applyMatrix4(_m1);\n\t\treturn this;\n\t}\n\n\tscale(x, y, z) {\n\t\t// scale geometry\n\t\t_m1.makeScale(x, y, z);\n\n\t\tthis.applyMatrix4(_m1);\n\t\treturn this;\n\t}\n\n\tlookAt(vector) {\n\t\t_obj.lookAt(vector);\n\n\t\t_obj.updateMatrix();\n\n\t\tthis.applyMatrix4(_obj.matrix);\n\t\treturn this;\n\t}\n\n\tcenter() {\n\t\tthis.computeBoundingBox();\n\t\tthis.boundingBox.getCenter(_offset).negate();\n\t\tthis.translate(_offset.x, _offset.y, _offset.z);\n\t\treturn this;\n\t}\n\n\tsetFromPoints(points) {\n\t\tconst position = [];\n\n\t\tfor (let i = 0, l = points.length; i < l; i++) {\n\t\t\tconst point = points[i];\n\t\t\tposition.push(point.x, point.y, point.z || 0);\n\t\t}\n\n\t\tthis.setAttribute('position', new Float32BufferAttribute(position, 3));\n\t\treturn this;\n\t}\n\n\tcomputeBoundingBox() {\n\t\tif (this.boundingBox === null) {\n\t\t\tthis.boundingBox = new Box3();\n\t\t}\n\n\t\tconst position = this.attributes.position;\n\t\tconst morphAttributesPosition = this.morphAttributes.position;\n\n\t\tif (position && position.isGLBufferAttribute) {\n\t\t\tconsole.error('THREE.BufferGeometry.computeBoundingBox(): GLBufferAttribute requires a manual bounding box. Alternatively set \"mesh.frustumCulled\" to \"false\".', this);\n\t\t\tthis.boundingBox.set(new Vector3(-Infinity, -Infinity, -Infinity), new Vector3(+Infinity, +Infinity, +Infinity));\n\t\t\treturn;\n\t\t}\n\n\t\tif (position !== undefined) {\n\t\t\tthis.boundingBox.setFromBufferAttribute(position); // process morph attributes if present\n\n\t\t\tif (morphAttributesPosition) {\n\t\t\t\tfor (let i = 0, il = morphAttributesPosition.length; i < il; i++) {\n\t\t\t\t\tconst morphAttribute = morphAttributesPosition[i];\n\n\t\t\t\t\t_box$1.setFromBufferAttribute(morphAttribute);\n\n\t\t\t\t\tif (this.morphTargetsRelative) {\n\t\t\t\t\t\t_vector$8.addVectors(this.boundingBox.min, _box$1.min);\n\n\t\t\t\t\t\tthis.boundingBox.expandByPoint(_vector$8);\n\n\t\t\t\t\t\t_vector$8.addVectors(this.boundingBox.max, _box$1.max);\n\n\t\t\t\t\t\tthis.boundingBox.expandByPoint(_vector$8);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.boundingBox.expandByPoint(_box$1.min);\n\t\t\t\t\t\tthis.boundingBox.expandByPoint(_box$1.max);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tthis.boundingBox.makeEmpty();\n\t\t}\n\n\t\tif (isNaN(this.boundingBox.min.x) || isNaN(this.boundingBox.min.y) || isNaN(this.boundingBox.min.z)) {\n\t\t\tconsole.error('THREE.BufferGeometry.computeBoundingBox(): Computed min/max have NaN values. The \"position\" attribute is likely to have NaN values.', this);\n\t\t}\n\t}\n\n\tcomputeBoundingSphere() {\n\t\tif (this.boundingSphere === null) {\n\t\t\tthis.boundingSphere = new Sphere();\n\t\t}\n\n\t\tconst position = this.attributes.position;\n\t\tconst morphAttributesPosition = this.morphAttributes.position;\n\n\t\tif (position && position.isGLBufferAttribute) {\n\t\t\tconsole.error('THREE.BufferGeometry.computeBoundingSphere(): GLBufferAttribute requires a manual bounding sphere. Alternatively set \"mesh.frustumCulled\" to \"false\".', this);\n\t\t\tthis.boundingSphere.set(new Vector3(), Infinity);\n\t\t\treturn;\n\t\t}\n\n\t\tif (position) {\n\t\t\t// first, find the center of the bounding sphere\n\t\t\tconst center = this.boundingSphere.center;\n\n\t\t\t_box$1.setFromBufferAttribute(position); // process morph attributes if present\n\n\n\t\t\tif (morphAttributesPosition) {\n\t\t\t\tfor (let i = 0, il = morphAttributesPosition.length; i < il; i++) {\n\t\t\t\t\tconst morphAttribute = morphAttributesPosition[i];\n\n\t\t\t\t\t_boxMorphTargets.setFromBufferAttribute(morphAttribute);\n\n\t\t\t\t\tif (this.morphTargetsRelative) {\n\t\t\t\t\t\t_vector$8.addVectors(_box$1.min, _boxMorphTargets.min);\n\n\t\t\t\t\t\t_box$1.expandByPoint(_vector$8);\n\n\t\t\t\t\t\t_vector$8.addVectors(_box$1.max, _boxMorphTargets.max);\n\n\t\t\t\t\t\t_box$1.expandByPoint(_vector$8);\n\t\t\t\t\t} else {\n\t\t\t\t\t\t_box$1.expandByPoint(_boxMorphTargets.min);\n\n\t\t\t\t\t\t_box$1.expandByPoint(_boxMorphTargets.max);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t_box$1.getCenter(center); // second, try to find a boundingSphere with a radius smaller than the\n\t\t\t// boundingSphere of the boundingBox: sqrt(3) smaller in the best case\n\n\n\t\t\tlet maxRadiusSq = 0;\n\n\t\t\tfor (let i = 0, il = position.count; i < il; i++) {\n\t\t\t\t_vector$8.fromBufferAttribute(position, i);\n\n\t\t\t\tmaxRadiusSq = Math.max(maxRadiusSq, center.distanceToSquared(_vector$8));\n\t\t\t} // process morph attributes if present\n\n\n\t\t\tif (morphAttributesPosition) {\n\t\t\t\tfor (let i = 0, il = morphAttributesPosition.length; i < il; i++) {\n\t\t\t\t\tconst morphAttribute = morphAttributesPosition[i];\n\t\t\t\t\tconst morphTargetsRelative = this.morphTargetsRelative;\n\n\t\t\t\t\tfor (let j = 0, jl = morphAttribute.count; j < jl; j++) {\n\t\t\t\t\t\t_vector$8.fromBufferAttribute(morphAttribute, j);\n\n\t\t\t\t\t\tif (morphTargetsRelative) {\n\t\t\t\t\t\t\t_offset.fromBufferAttribute(position, j);\n\n\t\t\t\t\t\t\t_vector$8.add(_offset);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tmaxRadiusSq = Math.max(maxRadiusSq, center.distanceToSquared(_vector$8));\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.boundingSphere.radius = Math.sqrt(maxRadiusSq);\n\n\t\t\tif (isNaN(this.boundingSphere.radius)) {\n\t\t\t\tconsole.error('THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The \"position\" attribute is likely to have NaN values.', this);\n\t\t\t}\n\t\t}\n\t}\n\n\tcomputeTangents() {\n\t\tconst index = this.index;\n\t\tconst attributes = this.attributes; // based on http://www.terathon.com/code/tangent.html\n\t\t// (per vertex tangents)\n\n\t\tif (index === null || attributes.position === undefined || attributes.normal === undefined || attributes.uv === undefined) {\n\t\t\tconsole.error('THREE.BufferGeometry: .computeTangents() failed. Missing required attributes (index, position, normal or uv)');\n\t\t\treturn;\n\t\t}\n\n\t\tconst indices = index.array;\n\t\tconst positions = attributes.position.array;\n\t\tconst normals = attributes.normal.array;\n\t\tconst uvs = attributes.uv.array;\n\t\tconst nVertices = positions.length / 3;\n\n\t\tif (this.hasAttribute('tangent') === false) {\n\t\t\tthis.setAttribute('tangent', new BufferAttribute(new Float32Array(4 * nVertices), 4));\n\t\t}\n\n\t\tconst tangents = this.getAttribute('tangent').array;\n\t\tconst tan1 = [],\n\t\t\t\t\ttan2 = [];\n\n\t\tfor (let i = 0; i < nVertices; i++) {\n\t\t\ttan1[i] = new Vector3();\n\t\t\ttan2[i] = new Vector3();\n\t\t}\n\n\t\tconst vA = new Vector3(),\n\t\t\t\t\tvB = new Vector3(),\n\t\t\t\t\tvC = new Vector3(),\n\t\t\t\t\tuvA = new Vector2(),\n\t\t\t\t\tuvB = new Vector2(),\n\t\t\t\t\tuvC = new Vector2(),\n\t\t\t\t\tsdir = new Vector3(),\n\t\t\t\t\ttdir = new Vector3();\n\n\t\tfunction handleTriangle(a, b, c) {\n\t\t\tvA.fromArray(positions, a * 3);\n\t\t\tvB.fromArray(positions, b * 3);\n\t\t\tvC.fromArray(positions, c * 3);\n\t\t\tuvA.fromArray(uvs, a * 2);\n\t\t\tuvB.fromArray(uvs, b * 2);\n\t\t\tuvC.fromArray(uvs, c * 2);\n\t\t\tvB.sub(vA);\n\t\t\tvC.sub(vA);\n\t\t\tuvB.sub(uvA);\n\t\t\tuvC.sub(uvA);\n\t\t\tconst r = 1.0 / (uvB.x * uvC.y - uvC.x * uvB.y); // silently ignore degenerate uv triangles having coincident or colinear vertices\n\n\t\t\tif (!isFinite(r)) return;\n\t\t\tsdir.copy(vB).multiplyScalar(uvC.y).addScaledVector(vC, -uvB.y).multiplyScalar(r);\n\t\t\ttdir.copy(vC).multiplyScalar(uvB.x).addScaledVector(vB, -uvC.x).multiplyScalar(r);\n\t\t\ttan1[a].add(sdir);\n\t\t\ttan1[b].add(sdir);\n\t\t\ttan1[c].add(sdir);\n\t\t\ttan2[a].add(tdir);\n\t\t\ttan2[b].add(tdir);\n\t\t\ttan2[c].add(tdir);\n\t\t}\n\n\t\tlet groups = this.groups;\n\n\t\tif (groups.length === 0) {\n\t\t\tgroups = [{\n\t\t\t\tstart: 0,\n\t\t\t\tcount: indices.length\n\t\t\t}];\n\t\t}\n\n\t\tfor (let i = 0, il = groups.length; i < il; ++i) {\n\t\t\tconst group = groups[i];\n\t\t\tconst start = group.start;\n\t\t\tconst count = group.count;\n\n\t\t\tfor (let j = start, jl = start + count; j < jl; j += 3) {\n\t\t\t\thandleTriangle(indices[j + 0], indices[j + 1], indices[j + 2]);\n\t\t\t}\n\t\t}\n\n\t\tconst tmp = new Vector3(),\n\t\t\t\t\ttmp2 = new Vector3();\n\t\tconst n = new Vector3(),\n\t\t\t\t\tn2 = new Vector3();\n\n\t\tfunction handleVertex(v) {\n\t\t\tn.fromArray(normals, v * 3);\n\t\t\tn2.copy(n);\n\t\t\tconst t = tan1[v]; // Gram-Schmidt orthogonalize\n\n\t\t\ttmp.copy(t);\n\t\t\ttmp.sub(n.multiplyScalar(n.dot(t))).normalize(); // Calculate handedness\n\n\t\t\ttmp2.crossVectors(n2, t);\n\t\t\tconst test = tmp2.dot(tan2[v]);\n\t\t\tconst w = test < 0.0 ? -1.0 : 1.0;\n\t\t\ttangents[v * 4] = tmp.x;\n\t\t\ttangents[v * 4 + 1] = tmp.y;\n\t\t\ttangents[v * 4 + 2] = tmp.z;\n\t\t\ttangents[v * 4 + 3] = w;\n\t\t}\n\n\t\tfor (let i = 0, il = groups.length; i < il; ++i) {\n\t\t\tconst group = groups[i];\n\t\t\tconst start = group.start;\n\t\t\tconst count = group.count;\n\n\t\t\tfor (let j = start, jl = start + count; j < jl; j += 3) {\n\t\t\t\thandleVertex(indices[j + 0]);\n\t\t\t\thandleVertex(indices[j + 1]);\n\t\t\t\thandleVertex(indices[j + 2]);\n\t\t\t}\n\t\t}\n\t}\n\n\tcomputeVertexNormals() {\n\t\tconst index = this.index;\n\t\tconst positionAttribute = this.getAttribute('position');\n\n\t\tif (positionAttribute !== undefined) {\n\t\t\tlet normalAttribute = this.getAttribute('normal');\n\n\t\t\tif (normalAttribute === undefined) {\n\t\t\t\tnormalAttribute = new BufferAttribute(new Float32Array(positionAttribute.count * 3), 3);\n\t\t\t\tthis.setAttribute('normal', normalAttribute);\n\t\t\t} else {\n\t\t\t\t// reset existing normals to zero\n\t\t\t\tfor (let i = 0, il = normalAttribute.count; i < il; i++) {\n\t\t\t\t\tnormalAttribute.setXYZ(i, 0, 0, 0);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst pA = new Vector3(),\n\t\t\t\t\t\tpB = new Vector3(),\n\t\t\t\t\t\tpC = new Vector3();\n\t\t\tconst nA = new Vector3(),\n\t\t\t\t\t\tnB = new Vector3(),\n\t\t\t\t\t\tnC = new Vector3();\n\t\t\tconst cb = new Vector3(),\n\t\t\t\t\t\tab = new Vector3(); // indexed elements\n\n\t\t\tif (index) {\n\t\t\t\tfor (let i = 0, il = index.count; i < il; i += 3) {\n\t\t\t\t\tconst vA = index.getX(i + 0);\n\t\t\t\t\tconst vB = index.getX(i + 1);\n\t\t\t\t\tconst vC = index.getX(i + 2);\n\t\t\t\t\tpA.fromBufferAttribute(positionAttribute, vA);\n\t\t\t\t\tpB.fromBufferAttribute(positionAttribute, vB);\n\t\t\t\t\tpC.fromBufferAttribute(positionAttribute, vC);\n\t\t\t\t\tcb.subVectors(pC, pB);\n\t\t\t\t\tab.subVectors(pA, pB);\n\t\t\t\t\tcb.cross(ab);\n\t\t\t\t\tnA.fromBufferAttribute(normalAttribute, vA);\n\t\t\t\t\tnB.fromBufferAttribute(normalAttribute, vB);\n\t\t\t\t\tnC.fromBufferAttribute(normalAttribute, vC);\n\t\t\t\t\tnA.add(cb);\n\t\t\t\t\tnB.add(cb);\n\t\t\t\t\tnC.add(cb);\n\t\t\t\t\tnormalAttribute.setXYZ(vA, nA.x, nA.y, nA.z);\n\t\t\t\t\tnormalAttribute.setXYZ(vB, nB.x, nB.y, nB.z);\n\t\t\t\t\tnormalAttribute.setXYZ(vC, nC.x, nC.y, nC.z);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// non-indexed elements (unconnected triangle soup)\n\t\t\t\tfor (let i = 0, il = positionAttribute.count; i < il; i += 3) {\n\t\t\t\t\tpA.fromBufferAttribute(positionAttribute, i + 0);\n\t\t\t\t\tpB.fromBufferAttribute(positionAttribute, i + 1);\n\t\t\t\t\tpC.fromBufferAttribute(positionAttribute, i + 2);\n\t\t\t\t\tcb.subVectors(pC, pB);\n\t\t\t\t\tab.subVectors(pA, pB);\n\t\t\t\t\tcb.cross(ab);\n\t\t\t\t\tnormalAttribute.setXYZ(i + 0, cb.x, cb.y, cb.z);\n\t\t\t\t\tnormalAttribute.setXYZ(i + 1, cb.x, cb.y, cb.z);\n\t\t\t\t\tnormalAttribute.setXYZ(i + 2, cb.x, cb.y, cb.z);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.normalizeNormals();\n\t\t\tnormalAttribute.needsUpdate = true;\n\t\t}\n\t}\n\n\tmerge(geometry, offset) {\n\t\tif (!(geometry && geometry.isBufferGeometry)) {\n\t\t\tconsole.error('THREE.BufferGeometry.merge(): geometry not an instance of THREE.BufferGeometry.', geometry);\n\t\t\treturn;\n\t\t}\n\n\t\tif (offset === undefined) {\n\t\t\toffset = 0;\n\t\t\tconsole.warn('THREE.BufferGeometry.merge(): Overwriting original geometry, starting at offset=0. ' + 'Use BufferGeometryUtils.mergeBufferGeometries() for lossless merge.');\n\t\t}\n\n\t\tconst attributes = this.attributes;\n\n\t\tfor (const key in attributes) {\n\t\t\tif (geometry.attributes[key] === undefined) continue;\n\t\t\tconst attribute1 = attributes[key];\n\t\t\tconst attributeArray1 = attribute1.array;\n\t\t\tconst attribute2 = geometry.attributes[key];\n\t\t\tconst attributeArray2 = attribute2.array;\n\t\t\tconst attributeOffset = attribute2.itemSize * offset;\n\t\t\tconst length = Math.min(attributeArray2.length, attributeArray1.length - attributeOffset);\n\n\t\t\tfor (let i = 0, j = attributeOffset; i < length; i++, j++) {\n\t\t\t\tattributeArray1[j] = attributeArray2[i];\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tnormalizeNormals() {\n\t\tconst normals = this.attributes.normal;\n\n\t\tfor (let i = 0, il = normals.count; i < il; i++) {\n\t\t\t_vector$8.fromBufferAttribute(normals, i);\n\n\t\t\t_vector$8.normalize();\n\n\t\t\tnormals.setXYZ(i, _vector$8.x, _vector$8.y, _vector$8.z);\n\t\t}\n\t}\n\n\ttoNonIndexed() {\n\t\tfunction convertBufferAttribute(attribute, indices) {\n\t\t\tconst array = attribute.array;\n\t\t\tconst itemSize = attribute.itemSize;\n\t\t\tconst normalized = attribute.normalized;\n\t\t\tconst array2 = new array.constructor(indices.length * itemSize);\n\t\t\tlet index = 0,\n\t\t\t\t\tindex2 = 0;\n\n\t\t\tfor (let i = 0, l = indices.length; i < l; i++) {\n\t\t\t\tif (attribute.isInterleavedBufferAttribute) {\n\t\t\t\t\tindex = indices[i] * attribute.data.stride + attribute.offset;\n\t\t\t\t} else {\n\t\t\t\t\tindex = indices[i] * itemSize;\n\t\t\t\t}\n\n\t\t\t\tfor (let j = 0; j < itemSize; j++) {\n\t\t\t\t\tarray2[index2++] = array[index++];\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn new BufferAttribute(array2, itemSize, normalized);\n\t\t} //\n\n\n\t\tif (this.index === null) {\n\t\t\tconsole.warn('THREE.BufferGeometry.toNonIndexed(): BufferGeometry is already non-indexed.');\n\t\t\treturn this;\n\t\t}\n\n\t\tconst geometry2 = new BufferGeometry();\n\t\tconst indices = this.index.array;\n\t\tconst attributes = this.attributes; // attributes\n\n\t\tfor (const name in attributes) {\n\t\t\tconst attribute = attributes[name];\n\t\t\tconst newAttribute = convertBufferAttribute(attribute, indices);\n\t\t\tgeometry2.setAttribute(name, newAttribute);\n\t\t} // morph attributes\n\n\n\t\tconst morphAttributes = this.morphAttributes;\n\n\t\tfor (const name in morphAttributes) {\n\t\t\tconst morphArray = [];\n\t\t\tconst morphAttribute = morphAttributes[name]; // morphAttribute: array of Float32BufferAttributes\n\n\t\t\tfor (let i = 0, il = morphAttribute.length; i < il; i++) {\n\t\t\t\tconst attribute = morphAttribute[i];\n\t\t\t\tconst newAttribute = convertBufferAttribute(attribute, indices);\n\t\t\t\tmorphArray.push(newAttribute);\n\t\t\t}\n\n\t\t\tgeometry2.morphAttributes[name] = morphArray;\n\t\t}\n\n\t\tgeometry2.morphTargetsRelative = this.morphTargetsRelative; // groups\n\n\t\tconst groups = this.groups;\n\n\t\tfor (let i = 0, l = groups.length; i < l; i++) {\n\t\t\tconst group = groups[i];\n\t\t\tgeometry2.addGroup(group.start, group.count, group.materialIndex);\n\t\t}\n\n\t\treturn geometry2;\n\t}\n\n\ttoJSON() {\n\t\tconst data = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'BufferGeometry',\n\t\t\t\tgenerator: 'BufferGeometry.toJSON'\n\t\t\t}\n\t\t}; // standard BufferGeometry serialization\n\n\t\tdata.uuid = this.uuid;\n\t\tdata.type = this.type;\n\t\tif (this.name !== '') data.name = this.name;\n\t\tif (Object.keys(this.userData).length > 0) data.userData = this.userData;\n\n\t\tif (this.parameters !== undefined) {\n\t\t\tconst parameters = this.parameters;\n\n\t\t\tfor (const key in parameters) {\n\t\t\t\tif (parameters[key] !== undefined) data[key] = parameters[key];\n\t\t\t}\n\n\t\t\treturn data;\n\t\t} // for simplicity the code assumes attributes are not shared across geometries, see #15811\n\n\n\t\tdata.data = {\n\t\t\tattributes: {}\n\t\t};\n\t\tconst index = this.index;\n\n\t\tif (index !== null) {\n\t\t\tdata.data.index = {\n\t\t\t\ttype: index.array.constructor.name,\n\t\t\t\tarray: Array.prototype.slice.call(index.array)\n\t\t\t};\n\t\t}\n\n\t\tconst attributes = this.attributes;\n\n\t\tfor (const key in attributes) {\n\t\t\tconst attribute = attributes[key];\n\t\t\tdata.data.attributes[key] = attribute.toJSON(data.data);\n\t\t}\n\n\t\tconst morphAttributes = {};\n\t\tlet hasMorphAttributes = false;\n\n\t\tfor (const key in this.morphAttributes) {\n\t\t\tconst attributeArray = this.morphAttributes[key];\n\t\t\tconst array = [];\n\n\t\t\tfor (let i = 0, il = attributeArray.length; i < il; i++) {\n\t\t\t\tconst attribute = attributeArray[i];\n\t\t\t\tarray.push(attribute.toJSON(data.data));\n\t\t\t}\n\n\t\t\tif (array.length > 0) {\n\t\t\t\tmorphAttributes[key] = array;\n\t\t\t\thasMorphAttributes = true;\n\t\t\t}\n\t\t}\n\n\t\tif (hasMorphAttributes) {\n\t\t\tdata.data.morphAttributes = morphAttributes;\n\t\t\tdata.data.morphTargetsRelative = this.morphTargetsRelative;\n\t\t}\n\n\t\tconst groups = this.groups;\n\n\t\tif (groups.length > 0) {\n\t\t\tdata.data.groups = JSON.parse(JSON.stringify(groups));\n\t\t}\n\n\t\tconst boundingSphere = this.boundingSphere;\n\n\t\tif (boundingSphere !== null) {\n\t\t\tdata.data.boundingSphere = {\n\t\t\t\tcenter: boundingSphere.center.toArray(),\n\t\t\t\tradius: boundingSphere.radius\n\t\t\t};\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n\tcopy(source) {\n\t\t// reset\n\t\tthis.index = null;\n\t\tthis.attributes = {};\n\t\tthis.morphAttributes = {};\n\t\tthis.groups = [];\n\t\tthis.boundingBox = null;\n\t\tthis.boundingSphere = null; // used for storing cloned, shared data\n\n\t\tconst data = {}; // name\n\n\t\tthis.name = source.name; // index\n\n\t\tconst index = source.index;\n\n\t\tif (index !== null) {\n\t\t\tthis.setIndex(index.clone(data));\n\t\t} // attributes\n\n\n\t\tconst attributes = source.attributes;\n\n\t\tfor (const name in attributes) {\n\t\t\tconst attribute = attributes[name];\n\t\t\tthis.setAttribute(name, attribute.clone(data));\n\t\t} // morph attributes\n\n\n\t\tconst morphAttributes = source.morphAttributes;\n\n\t\tfor (const name in morphAttributes) {\n\t\t\tconst array = [];\n\t\t\tconst morphAttribute = morphAttributes[name]; // morphAttribute: array of Float32BufferAttributes\n\n\t\t\tfor (let i = 0, l = morphAttribute.length; i < l; i++) {\n\t\t\t\tarray.push(morphAttribute[i].clone(data));\n\t\t\t}\n\n\t\t\tthis.morphAttributes[name] = array;\n\t\t}\n\n\t\tthis.morphTargetsRelative = source.morphTargetsRelative; // groups\n\n\t\tconst groups = source.groups;\n\n\t\tfor (let i = 0, l = groups.length; i < l; i++) {\n\t\t\tconst group = groups[i];\n\t\t\tthis.addGroup(group.start, group.count, group.materialIndex);\n\t\t} // bounding box\n\n\n\t\tconst boundingBox = source.boundingBox;\n\n\t\tif (boundingBox !== null) {\n\t\t\tthis.boundingBox = boundingBox.clone();\n\t\t} // bounding sphere\n\n\n\t\tconst boundingSphere = source.boundingSphere;\n\n\t\tif (boundingSphere !== null) {\n\t\t\tthis.boundingSphere = boundingSphere.clone();\n\t\t} // draw range\n\n\n\t\tthis.drawRange.start = source.drawRange.start;\n\t\tthis.drawRange.count = source.drawRange.count; // user data\n\n\t\tthis.userData = source.userData; // geometry generator parameters\n\n\t\tif (source.parameters !== undefined) this.parameters = Object.assign({}, source.parameters);\n\t\treturn this;\n\t}\n\n\tdispose() {\n\t\tthis.dispatchEvent({\n\t\t\ttype: 'dispose'\n\t\t});\n\t}\n\n}\n\nconst _inverseMatrix$2 = /*@__PURE__*/new Matrix4();\n\nconst _ray$2 = /*@__PURE__*/new Ray();\n\nconst _sphere$3 = /*@__PURE__*/new Sphere();\n\nconst _vA$1 = /*@__PURE__*/new Vector3();\n\nconst _vB$1 = /*@__PURE__*/new Vector3();\n\nconst _vC$1 = /*@__PURE__*/new Vector3();\n\nconst _tempA = /*@__PURE__*/new Vector3();\n\nconst _tempB = /*@__PURE__*/new Vector3();\n\nconst _tempC = /*@__PURE__*/new Vector3();\n\nconst _morphA = /*@__PURE__*/new Vector3();\n\nconst _morphB = /*@__PURE__*/new Vector3();\n\nconst _morphC = /*@__PURE__*/new Vector3();\n\nconst _uvA$1 = /*@__PURE__*/new Vector2();\n\nconst _uvB$1 = /*@__PURE__*/new Vector2();\n\nconst _uvC$1 = /*@__PURE__*/new Vector2();\n\nconst _intersectionPoint = /*@__PURE__*/new Vector3();\n\nconst _intersectionPointWorld = /*@__PURE__*/new Vector3();\n\nclass Mesh extends Object3D {\n\tconstructor(geometry = new BufferGeometry(), material = new MeshBasicMaterial()) {\n\t\tsuper();\n\t\tthis.isMesh = true;\n\t\tthis.type = 'Mesh';\n\t\tthis.geometry = geometry;\n\t\tthis.material = material;\n\t\tthis.updateMorphTargets();\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\n\t\tif (source.morphTargetInfluences !== undefined) {\n\t\t\tthis.morphTargetInfluences = source.morphTargetInfluences.slice();\n\t\t}\n\n\t\tif (source.morphTargetDictionary !== undefined) {\n\t\t\tthis.morphTargetDictionary = Object.assign({}, source.morphTargetDictionary);\n\t\t}\n\n\t\tthis.material = source.material;\n\t\tthis.geometry = source.geometry;\n\t\treturn this;\n\t}\n\n\tupdateMorphTargets() {\n\t\tconst geometry = this.geometry;\n\t\tconst morphAttributes = geometry.morphAttributes;\n\t\tconst keys = Object.keys(morphAttributes);\n\n\t\tif (keys.length > 0) {\n\t\t\tconst morphAttribute = morphAttributes[keys[0]];\n\n\t\t\tif (morphAttribute !== undefined) {\n\t\t\t\tthis.morphTargetInfluences = [];\n\t\t\t\tthis.morphTargetDictionary = {};\n\n\t\t\t\tfor (let m = 0, ml = morphAttribute.length; m < ml; m++) {\n\t\t\t\t\tconst name = morphAttribute[m].name || String(m);\n\t\t\t\t\tthis.morphTargetInfluences.push(0);\n\t\t\t\t\tthis.morphTargetDictionary[name] = m;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\traycast(raycaster, intersects) {\n\t\tconst geometry = this.geometry;\n\t\tconst material = this.material;\n\t\tconst matrixWorld = this.matrixWorld;\n\t\tif (material === undefined) return; // Checking boundingSphere distance to ray\n\n\t\tif (geometry.boundingSphere === null) geometry.computeBoundingSphere();\n\n\t\t_sphere$3.copy(geometry.boundingSphere);\n\n\t\t_sphere$3.applyMatrix4(matrixWorld);\n\n\t\tif (raycaster.ray.intersectsSphere(_sphere$3) === false) return; //\n\n\t\t_inverseMatrix$2.copy(matrixWorld).invert();\n\n\t\t_ray$2.copy(raycaster.ray).applyMatrix4(_inverseMatrix$2); // Check boundingBox before continuing\n\n\n\t\tif (geometry.boundingBox !== null) {\n\t\t\tif (_ray$2.intersectsBox(geometry.boundingBox) === false) return;\n\t\t}\n\n\t\tlet intersection;\n\t\tconst index = geometry.index;\n\t\tconst position = geometry.attributes.position;\n\t\tconst morphPosition = geometry.morphAttributes.position;\n\t\tconst morphTargetsRelative = geometry.morphTargetsRelative;\n\t\tconst uv = geometry.attributes.uv;\n\t\tconst uv2 = geometry.attributes.uv2;\n\t\tconst groups = geometry.groups;\n\t\tconst drawRange = geometry.drawRange;\n\n\t\tif (index !== null) {\n\t\t\t// indexed buffer geometry\n\t\t\tif (Array.isArray(material)) {\n\t\t\t\tfor (let i = 0, il = groups.length; i < il; i++) {\n\t\t\t\t\tconst group = groups[i];\n\t\t\t\t\tconst groupMaterial = material[group.materialIndex];\n\t\t\t\t\tconst start = Math.max(group.start, drawRange.start);\n\t\t\t\t\tconst end = Math.min(index.count, Math.min(group.start + group.count, drawRange.start + drawRange.count));\n\n\t\t\t\t\tfor (let j = start, jl = end; j < jl; j += 3) {\n\t\t\t\t\t\tconst a = index.getX(j);\n\t\t\t\t\t\tconst b = index.getX(j + 1);\n\t\t\t\t\t\tconst c = index.getX(j + 2);\n\t\t\t\t\t\tintersection = checkBufferGeometryIntersection(this, groupMaterial, raycaster, _ray$2, position, morphPosition, morphTargetsRelative, uv, uv2, a, b, c);\n\n\t\t\t\t\t\tif (intersection) {\n\t\t\t\t\t\t\tintersection.faceIndex = Math.floor(j / 3); // triangle number in indexed buffer semantics\n\n\t\t\t\t\t\t\tintersection.face.materialIndex = group.materialIndex;\n\t\t\t\t\t\t\tintersects.push(intersection);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tconst start = Math.max(0, drawRange.start);\n\t\t\t\tconst end = Math.min(index.count, drawRange.start + drawRange.count);\n\n\t\t\t\tfor (let i = start, il = end; i < il; i += 3) {\n\t\t\t\t\tconst a = index.getX(i);\n\t\t\t\t\tconst b = index.getX(i + 1);\n\t\t\t\t\tconst c = index.getX(i + 2);\n\t\t\t\t\tintersection = checkBufferGeometryIntersection(this, material, raycaster, _ray$2, position, morphPosition, morphTargetsRelative, uv, uv2, a, b, c);\n\n\t\t\t\t\tif (intersection) {\n\t\t\t\t\t\tintersection.faceIndex = Math.floor(i / 3); // triangle number in indexed buffer semantics\n\n\t\t\t\t\t\tintersects.push(intersection);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} else if (position !== undefined) {\n\t\t\t// non-indexed buffer geometry\n\t\t\tif (Array.isArray(material)) {\n\t\t\t\tfor (let i = 0, il = groups.length; i < il; i++) {\n\t\t\t\t\tconst group = groups[i];\n\t\t\t\t\tconst groupMaterial = material[group.materialIndex];\n\t\t\t\t\tconst start = Math.max(group.start, drawRange.start);\n\t\t\t\t\tconst end = Math.min(position.count, Math.min(group.start + group.count, drawRange.start + drawRange.count));\n\n\t\t\t\t\tfor (let j = start, jl = end; j < jl; j += 3) {\n\t\t\t\t\t\tconst a = j;\n\t\t\t\t\t\tconst b = j + 1;\n\t\t\t\t\t\tconst c = j + 2;\n\t\t\t\t\t\tintersection = checkBufferGeometryIntersection(this, groupMaterial, raycaster, _ray$2, position, morphPosition, morphTargetsRelative, uv, uv2, a, b, c);\n\n\t\t\t\t\t\tif (intersection) {\n\t\t\t\t\t\t\tintersection.faceIndex = Math.floor(j / 3); // triangle number in non-indexed buffer semantics\n\n\t\t\t\t\t\t\tintersection.face.materialIndex = group.materialIndex;\n\t\t\t\t\t\t\tintersects.push(intersection);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tconst start = Math.max(0, drawRange.start);\n\t\t\t\tconst end = Math.min(position.count, drawRange.start + drawRange.count);\n\n\t\t\t\tfor (let i = start, il = end; i < il; i += 3) {\n\t\t\t\t\tconst a = i;\n\t\t\t\t\tconst b = i + 1;\n\t\t\t\t\tconst c = i + 2;\n\t\t\t\t\tintersection = checkBufferGeometryIntersection(this, material, raycaster, _ray$2, position, morphPosition, morphTargetsRelative, uv, uv2, a, b, c);\n\n\t\t\t\t\tif (intersection) {\n\t\t\t\t\t\tintersection.faceIndex = Math.floor(i / 3); // triangle number in non-indexed buffer semantics\n\n\t\t\t\t\t\tintersects.push(intersection);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n}\n\nfunction checkIntersection(object, material, raycaster, ray, pA, pB, pC, point) {\n\tlet intersect;\n\n\tif (material.side === BackSide) {\n\t\tintersect = ray.intersectTriangle(pC, pB, pA, true, point);\n\t} else {\n\t\tintersect = ray.intersectTriangle(pA, pB, pC, material.side !== DoubleSide, point);\n\t}\n\n\tif (intersect === null) return null;\n\n\t_intersectionPointWorld.copy(point);\n\n\t_intersectionPointWorld.applyMatrix4(object.matrixWorld);\n\n\tconst distance = raycaster.ray.origin.distanceTo(_intersectionPointWorld);\n\tif (distance < raycaster.near || distance > raycaster.far) return null;\n\treturn {\n\t\tdistance: distance,\n\t\tpoint: _intersectionPointWorld.clone(),\n\t\tobject: object\n\t};\n}\n\nfunction checkBufferGeometryIntersection(object, material, raycaster, ray, position, morphPosition, morphTargetsRelative, uv, uv2, a, b, c) {\n\t_vA$1.fromBufferAttribute(position, a);\n\n\t_vB$1.fromBufferAttribute(position, b);\n\n\t_vC$1.fromBufferAttribute(position, c);\n\n\tconst morphInfluences = object.morphTargetInfluences;\n\n\tif (morphPosition && morphInfluences) {\n\t\t_morphA.set(0, 0, 0);\n\n\t\t_morphB.set(0, 0, 0);\n\n\t\t_morphC.set(0, 0, 0);\n\n\t\tfor (let i = 0, il = morphPosition.length; i < il; i++) {\n\t\t\tconst influence = morphInfluences[i];\n\t\t\tconst morphAttribute = morphPosition[i];\n\t\t\tif (influence === 0) continue;\n\n\t\t\t_tempA.fromBufferAttribute(morphAttribute, a);\n\n\t\t\t_tempB.fromBufferAttribute(morphAttribute, b);\n\n\t\t\t_tempC.fromBufferAttribute(morphAttribute, c);\n\n\t\t\tif (morphTargetsRelative) {\n\t\t\t\t_morphA.addScaledVector(_tempA, influence);\n\n\t\t\t\t_morphB.addScaledVector(_tempB, influence);\n\n\t\t\t\t_morphC.addScaledVector(_tempC, influence);\n\t\t\t} else {\n\t\t\t\t_morphA.addScaledVector(_tempA.sub(_vA$1), influence);\n\n\t\t\t\t_morphB.addScaledVector(_tempB.sub(_vB$1), influence);\n\n\t\t\t\t_morphC.addScaledVector(_tempC.sub(_vC$1), influence);\n\t\t\t}\n\t\t}\n\n\t\t_vA$1.add(_morphA);\n\n\t\t_vB$1.add(_morphB);\n\n\t\t_vC$1.add(_morphC);\n\t}\n\n\tif (object.isSkinnedMesh) {\n\t\tobject.boneTransform(a, _vA$1);\n\t\tobject.boneTransform(b, _vB$1);\n\t\tobject.boneTransform(c, _vC$1);\n\t}\n\n\tconst intersection = checkIntersection(object, material, raycaster, ray, _vA$1, _vB$1, _vC$1, _intersectionPoint);\n\n\tif (intersection) {\n\t\tif (uv) {\n\t\t\t_uvA$1.fromBufferAttribute(uv, a);\n\n\t\t\t_uvB$1.fromBufferAttribute(uv, b);\n\n\t\t\t_uvC$1.fromBufferAttribute(uv, c);\n\n\t\t\tintersection.uv = Triangle.getUV(_intersectionPoint, _vA$1, _vB$1, _vC$1, _uvA$1, _uvB$1, _uvC$1, new Vector2());\n\t\t}\n\n\t\tif (uv2) {\n\t\t\t_uvA$1.fromBufferAttribute(uv2, a);\n\n\t\t\t_uvB$1.fromBufferAttribute(uv2, b);\n\n\t\t\t_uvC$1.fromBufferAttribute(uv2, c);\n\n\t\t\tintersection.uv2 = Triangle.getUV(_intersectionPoint, _vA$1, _vB$1, _vC$1, _uvA$1, _uvB$1, _uvC$1, new Vector2());\n\t\t}\n\n\t\tconst face = {\n\t\t\ta: a,\n\t\t\tb: b,\n\t\t\tc: c,\n\t\t\tnormal: new Vector3(),\n\t\t\tmaterialIndex: 0\n\t\t};\n\t\tTriangle.getNormal(_vA$1, _vB$1, _vC$1, face.normal);\n\t\tintersection.face = face;\n\t}\n\n\treturn intersection;\n}\n\nclass BoxGeometry extends BufferGeometry {\n\tconstructor(width = 1, height = 1, depth = 1, widthSegments = 1, heightSegments = 1, depthSegments = 1) {\n\t\tsuper();\n\t\tthis.type = 'BoxGeometry';\n\t\tthis.parameters = {\n\t\t\twidth: width,\n\t\t\theight: height,\n\t\t\tdepth: depth,\n\t\t\twidthSegments: widthSegments,\n\t\t\theightSegments: heightSegments,\n\t\t\tdepthSegments: depthSegments\n\t\t};\n\t\tconst scope = this; // segments\n\n\t\twidthSegments = Math.floor(widthSegments);\n\t\theightSegments = Math.floor(heightSegments);\n\t\tdepthSegments = Math.floor(depthSegments); // buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = []; // helper variables\n\n\t\tlet numberOfVertices = 0;\n\t\tlet groupStart = 0; // build each side of the box geometry\n\n\t\tbuildPlane('z', 'y', 'x', -1, -1, depth, height, width, depthSegments, heightSegments, 0); // px\n\n\t\tbuildPlane('z', 'y', 'x', 1, -1, depth, height, -width, depthSegments, heightSegments, 1); // nx\n\n\t\tbuildPlane('x', 'z', 'y', 1, 1, width, depth, height, widthSegments, depthSegments, 2); // py\n\n\t\tbuildPlane('x', 'z', 'y', 1, -1, width, depth, -height, widthSegments, depthSegments, 3); // ny\n\n\t\tbuildPlane('x', 'y', 'z', 1, -1, width, height, depth, widthSegments, heightSegments, 4); // pz\n\n\t\tbuildPlane('x', 'y', 'z', -1, -1, width, height, -depth, widthSegments, heightSegments, 5); // nz\n\t\t// build geometry\n\n\t\tthis.setIndex(indices);\n\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tthis.setAttribute('normal', new Float32BufferAttribute(normals, 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvs, 2));\n\n\t\tfunction buildPlane(u, v, w, udir, vdir, width, height, depth, gridX, gridY, materialIndex) {\n\t\t\tconst segmentWidth = width / gridX;\n\t\t\tconst segmentHeight = height / gridY;\n\t\t\tconst widthHalf = width / 2;\n\t\t\tconst heightHalf = height / 2;\n\t\t\tconst depthHalf = depth / 2;\n\t\t\tconst gridX1 = gridX + 1;\n\t\t\tconst gridY1 = gridY + 1;\n\t\t\tlet vertexCounter = 0;\n\t\t\tlet groupCount = 0;\n\t\t\tconst vector = new Vector3(); // generate vertices, normals and uvs\n\n\t\t\tfor (let iy = 0; iy < gridY1; iy++) {\n\t\t\t\tconst y = iy * segmentHeight - heightHalf;\n\n\t\t\t\tfor (let ix = 0; ix < gridX1; ix++) {\n\t\t\t\t\tconst x = ix * segmentWidth - widthHalf; // set values to correct vector component\n\n\t\t\t\t\tvector[u] = x * udir;\n\t\t\t\t\tvector[v] = y * vdir;\n\t\t\t\t\tvector[w] = depthHalf; // now apply vector to vertex buffer\n\n\t\t\t\t\tvertices.push(vector.x, vector.y, vector.z); // set values to correct vector component\n\n\t\t\t\t\tvector[u] = 0;\n\t\t\t\t\tvector[v] = 0;\n\t\t\t\t\tvector[w] = depth > 0 ? 1 : -1; // now apply vector to normal buffer\n\n\t\t\t\t\tnormals.push(vector.x, vector.y, vector.z); // uvs\n\n\t\t\t\t\tuvs.push(ix / gridX);\n\t\t\t\t\tuvs.push(1 - iy / gridY); // counters\n\n\t\t\t\t\tvertexCounter += 1;\n\t\t\t\t}\n\t\t\t} // indices\n\t\t\t// 1. you need three indices to draw a single face\n\t\t\t// 2. a single segment consists of two faces\n\t\t\t// 3. so we need to generate six (2*3) indices per segment\n\n\n\t\t\tfor (let iy = 0; iy < gridY; iy++) {\n\t\t\t\tfor (let ix = 0; ix < gridX; ix++) {\n\t\t\t\t\tconst a = numberOfVertices + ix + gridX1 * iy;\n\t\t\t\t\tconst b = numberOfVertices + ix + gridX1 * (iy + 1);\n\t\t\t\t\tconst c = numberOfVertices + (ix + 1) + gridX1 * (iy + 1);\n\t\t\t\t\tconst d = numberOfVertices + (ix + 1) + gridX1 * iy; // faces\n\n\t\t\t\t\tindices.push(a, b, d);\n\t\t\t\t\tindices.push(b, c, d); // increase counter\n\n\t\t\t\t\tgroupCount += 6;\n\t\t\t\t}\n\t\t\t} // add a group to the geometry. this will ensure multi material support\n\n\n\t\t\tscope.addGroup(groupStart, groupCount, materialIndex); // calculate new start value for groups\n\n\t\t\tgroupStart += groupCount; // update total number of vertices\n\n\t\t\tnumberOfVertices += vertexCounter;\n\t\t}\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new BoxGeometry(data.width, data.height, data.depth, data.widthSegments, data.heightSegments, data.depthSegments);\n\t}\n\n}\n\n/**\n * Uniform Utilities\n */\nfunction cloneUniforms(src) {\n\tconst dst = {};\n\n\tfor (const u in src) {\n\t\tdst[u] = {};\n\n\t\tfor (const p in src[u]) {\n\t\t\tconst property = src[u][p];\n\n\t\t\tif (property && (property.isColor || property.isMatrix3 || property.isMatrix4 || property.isVector2 || property.isVector3 || property.isVector4 || property.isTexture || property.isQuaternion)) {\n\t\t\t\tdst[u][p] = property.clone();\n\t\t\t} else if (Array.isArray(property)) {\n\t\t\t\tdst[u][p] = property.slice();\n\t\t\t} else {\n\t\t\t\tdst[u][p] = property;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn dst;\n}\nfunction mergeUniforms(uniforms) {\n\tconst merged = {};\n\n\tfor (let u = 0; u < uniforms.length; u++) {\n\t\tconst tmp = cloneUniforms(uniforms[u]);\n\n\t\tfor (const p in tmp) {\n\t\t\tmerged[p] = tmp[p];\n\t\t}\n\t}\n\n\treturn merged;\n} // Legacy\n\nconst UniformsUtils = {\n\tclone: cloneUniforms,\n\tmerge: mergeUniforms\n};\n\nvar default_vertex = \"void main() {\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\\n}\";\n\nvar default_fragment = \"void main() {\\n\\tgl_FragColor = vec4( 1.0, 0.0, 0.0, 1.0 );\\n}\";\n\nclass ShaderMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isShaderMaterial = true;\n\t\tthis.type = 'ShaderMaterial';\n\t\tthis.defines = {};\n\t\tthis.uniforms = {};\n\t\tthis.vertexShader = default_vertex;\n\t\tthis.fragmentShader = default_fragment;\n\t\tthis.linewidth = 1;\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.fog = false; // set to use scene fog\n\n\t\tthis.lights = false; // set to use scene lights\n\n\t\tthis.clipping = false; // set to use user-defined clipping planes\n\n\t\tthis.extensions = {\n\t\t\tderivatives: false,\n\t\t\t// set to use derivatives\n\t\t\tfragDepth: false,\n\t\t\t// set to use fragment depth values\n\t\t\tdrawBuffers: false,\n\t\t\t// set to use draw buffers\n\t\t\tshaderTextureLOD: false // set to use shader texture LOD\n\n\t\t}; // When rendered geometry doesn't include these attributes but the material does,\n\t\t// use these default values in WebGL. This avoids errors when buffer data is missing.\n\n\t\tthis.defaultAttributeValues = {\n\t\t\t'color': [1, 1, 1],\n\t\t\t'uv': [0, 0],\n\t\t\t'uv2': [0, 0]\n\t\t};\n\t\tthis.index0AttributeName = undefined;\n\t\tthis.uniformsNeedUpdate = false;\n\t\tthis.glslVersion = null;\n\n\t\tif (parameters !== undefined) {\n\t\t\tif (parameters.attributes !== undefined) {\n\t\t\t\tconsole.error('THREE.ShaderMaterial: attributes should now be defined in THREE.BufferGeometry instead.');\n\t\t\t}\n\n\t\t\tthis.setValues(parameters);\n\t\t}\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.fragmentShader = source.fragmentShader;\n\t\tthis.vertexShader = source.vertexShader;\n\t\tthis.uniforms = cloneUniforms(source.uniforms);\n\t\tthis.defines = Object.assign({}, source.defines);\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\tthis.fog = source.fog;\n\t\tthis.lights = source.lights;\n\t\tthis.clipping = source.clipping;\n\t\tthis.extensions = Object.assign({}, source.extensions);\n\t\tthis.glslVersion = source.glslVersion;\n\t\treturn this;\n\t}\n\n\ttoJSON(meta) {\n\t\tconst data = super.toJSON(meta);\n\t\tdata.glslVersion = this.glslVersion;\n\t\tdata.uniforms = {};\n\n\t\tfor (const name in this.uniforms) {\n\t\t\tconst uniform = this.uniforms[name];\n\t\t\tconst value = uniform.value;\n\n\t\t\tif (value && value.isTexture) {\n\t\t\t\tdata.uniforms[name] = {\n\t\t\t\t\ttype: 't',\n\t\t\t\t\tvalue: value.toJSON(meta).uuid\n\t\t\t\t};\n\t\t\t} else if (value && value.isColor) {\n\t\t\t\tdata.uniforms[name] = {\n\t\t\t\t\ttype: 'c',\n\t\t\t\t\tvalue: value.getHex()\n\t\t\t\t};\n\t\t\t} else if (value && value.isVector2) {\n\t\t\t\tdata.uniforms[name] = {\n\t\t\t\t\ttype: 'v2',\n\t\t\t\t\tvalue: value.toArray()\n\t\t\t\t};\n\t\t\t} else if (value && value.isVector3) {\n\t\t\t\tdata.uniforms[name] = {\n\t\t\t\t\ttype: 'v3',\n\t\t\t\t\tvalue: value.toArray()\n\t\t\t\t};\n\t\t\t} else if (value && value.isVector4) {\n\t\t\t\tdata.uniforms[name] = {\n\t\t\t\t\ttype: 'v4',\n\t\t\t\t\tvalue: value.toArray()\n\t\t\t\t};\n\t\t\t} else if (value && value.isMatrix3) {\n\t\t\t\tdata.uniforms[name] = {\n\t\t\t\t\ttype: 'm3',\n\t\t\t\t\tvalue: value.toArray()\n\t\t\t\t};\n\t\t\t} else if (value && value.isMatrix4) {\n\t\t\t\tdata.uniforms[name] = {\n\t\t\t\t\ttype: 'm4',\n\t\t\t\t\tvalue: value.toArray()\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\tdata.uniforms[name] = {\n\t\t\t\t\tvalue: value\n\t\t\t\t}; // note: the array variants v2v, v3v, v4v, m4v and tv are not supported so far\n\t\t\t}\n\t\t}\n\n\t\tif (Object.keys(this.defines).length > 0) data.defines = this.defines;\n\t\tdata.vertexShader = this.vertexShader;\n\t\tdata.fragmentShader = this.fragmentShader;\n\t\tconst extensions = {};\n\n\t\tfor (const key in this.extensions) {\n\t\t\tif (this.extensions[key] === true) extensions[key] = true;\n\t\t}\n\n\t\tif (Object.keys(extensions).length > 0) data.extensions = extensions;\n\t\treturn data;\n\t}\n\n}\n\nclass Camera extends Object3D {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.isCamera = true;\n\t\tthis.type = 'Camera';\n\t\tthis.matrixWorldInverse = new Matrix4();\n\t\tthis.projectionMatrix = new Matrix4();\n\t\tthis.projectionMatrixInverse = new Matrix4();\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tthis.matrixWorldInverse.copy(source.matrixWorldInverse);\n\t\tthis.projectionMatrix.copy(source.projectionMatrix);\n\t\tthis.projectionMatrixInverse.copy(source.projectionMatrixInverse);\n\t\treturn this;\n\t}\n\n\tgetWorldDirection(target) {\n\t\tthis.updateWorldMatrix(true, false);\n\t\tconst e = this.matrixWorld.elements;\n\t\treturn target.set(-e[8], -e[9], -e[10]).normalize();\n\t}\n\n\tupdateMatrixWorld(force) {\n\t\tsuper.updateMatrixWorld(force);\n\t\tthis.matrixWorldInverse.copy(this.matrixWorld).invert();\n\t}\n\n\tupdateWorldMatrix(updateParents, updateChildren) {\n\t\tsuper.updateWorldMatrix(updateParents, updateChildren);\n\t\tthis.matrixWorldInverse.copy(this.matrixWorld).invert();\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n}\n\nclass PerspectiveCamera extends Camera {\n\tconstructor(fov = 50, aspect = 1, near = 0.1, far = 2000) {\n\t\tsuper();\n\t\tthis.isPerspectiveCamera = true;\n\t\tthis.type = 'PerspectiveCamera';\n\t\tthis.fov = fov;\n\t\tthis.zoom = 1;\n\t\tthis.near = near;\n\t\tthis.far = far;\n\t\tthis.focus = 10;\n\t\tthis.aspect = aspect;\n\t\tthis.view = null;\n\t\tthis.filmGauge = 35; // width of the film (default in millimeters)\n\n\t\tthis.filmOffset = 0; // horizontal film offset (same unit as gauge)\n\n\t\tthis.updateProjectionMatrix();\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tthis.fov = source.fov;\n\t\tthis.zoom = source.zoom;\n\t\tthis.near = source.near;\n\t\tthis.far = source.far;\n\t\tthis.focus = source.focus;\n\t\tthis.aspect = source.aspect;\n\t\tthis.view = source.view === null ? null : Object.assign({}, source.view);\n\t\tthis.filmGauge = source.filmGauge;\n\t\tthis.filmOffset = source.filmOffset;\n\t\treturn this;\n\t}\n\t/**\n\t * Sets the FOV by focal length in respect to the current .filmGauge.\n\t *\n\t * The default film gauge is 35, so that the focal length can be specified for\n\t * a 35mm (full frame) camera.\n\t *\n\t * Values for focal length and film gauge must have the same unit.\n\t */\n\n\n\tsetFocalLength(focalLength) {\n\t\t/** see {@link http://www.bobatkins.com/photography/technical/field_of_view.html} */\n\t\tconst vExtentSlope = 0.5 * this.getFilmHeight() / focalLength;\n\t\tthis.fov = RAD2DEG * 2 * Math.atan(vExtentSlope);\n\t\tthis.updateProjectionMatrix();\n\t}\n\t/**\n\t * Calculates the focal length from the current .fov and .filmGauge.\n\t */\n\n\n\tgetFocalLength() {\n\t\tconst vExtentSlope = Math.tan(DEG2RAD * 0.5 * this.fov);\n\t\treturn 0.5 * this.getFilmHeight() / vExtentSlope;\n\t}\n\n\tgetEffectiveFOV() {\n\t\treturn RAD2DEG * 2 * Math.atan(Math.tan(DEG2RAD * 0.5 * this.fov) / this.zoom);\n\t}\n\n\tgetFilmWidth() {\n\t\t// film not completely covered in portrait format (aspect < 1)\n\t\treturn this.filmGauge * Math.min(this.aspect, 1);\n\t}\n\n\tgetFilmHeight() {\n\t\t// film not completely covered in landscape format (aspect > 1)\n\t\treturn this.filmGauge / Math.max(this.aspect, 1);\n\t}\n\t/**\n\t * Sets an offset in a larger frustum. This is useful for multi-window or\n\t * multi-monitor/multi-machine setups.\n\t *\n\t * For example, if you have 3x2 monitors and each monitor is 1920x1080 and\n\t * the monitors are in grid like this\n\t *\n\t *\t +---+---+---+\n\t *\t | A | B | C |\n\t *\t +---+---+---+\n\t *\t | D | E | F |\n\t *\t +---+---+---+\n\t *\n\t * then for each monitor you would call it like this\n\t *\n\t *\t const w = 1920;\n\t *\t const h = 1080;\n\t *\t const fullWidth = w * 3;\n\t *\t const fullHeight = h * 2;\n\t *\n\t *\t --A--\n\t *\t camera.setViewOffset( fullWidth, fullHeight, w * 0, h * 0, w, h );\n\t *\t --B--\n\t *\t camera.setViewOffset( fullWidth, fullHeight, w * 1, h * 0, w, h );\n\t *\t --C--\n\t *\t camera.setViewOffset( fullWidth, fullHeight, w * 2, h * 0, w, h );\n\t *\t --D--\n\t *\t camera.setViewOffset( fullWidth, fullHeight, w * 0, h * 1, w, h );\n\t *\t --E--\n\t *\t camera.setViewOffset( fullWidth, fullHeight, w * 1, h * 1, w, h );\n\t *\t --F--\n\t *\t camera.setViewOffset( fullWidth, fullHeight, w * 2, h * 1, w, h );\n\t *\n\t *\t Note there is no reason monitors have to be the same size or in a grid.\n\t */\n\n\n\tsetViewOffset(fullWidth, fullHeight, x, y, width, height) {\n\t\tthis.aspect = fullWidth / fullHeight;\n\n\t\tif (this.view === null) {\n\t\t\tthis.view = {\n\t\t\t\tenabled: true,\n\t\t\t\tfullWidth: 1,\n\t\t\t\tfullHeight: 1,\n\t\t\t\toffsetX: 0,\n\t\t\t\toffsetY: 0,\n\t\t\t\twidth: 1,\n\t\t\t\theight: 1\n\t\t\t};\n\t\t}\n\n\t\tthis.view.enabled = true;\n\t\tthis.view.fullWidth = fullWidth;\n\t\tthis.view.fullHeight = fullHeight;\n\t\tthis.view.offsetX = x;\n\t\tthis.view.offsetY = y;\n\t\tthis.view.width = width;\n\t\tthis.view.height = height;\n\t\tthis.updateProjectionMatrix();\n\t}\n\n\tclearViewOffset() {\n\t\tif (this.view !== null) {\n\t\t\tthis.view.enabled = false;\n\t\t}\n\n\t\tthis.updateProjectionMatrix();\n\t}\n\n\tupdateProjectionMatrix() {\n\t\tconst near = this.near;\n\t\tlet top = near * Math.tan(DEG2RAD * 0.5 * this.fov) / this.zoom;\n\t\tlet height = 2 * top;\n\t\tlet width = this.aspect * height;\n\t\tlet left = -0.5 * width;\n\t\tconst view = this.view;\n\n\t\tif (this.view !== null && this.view.enabled) {\n\t\t\tconst fullWidth = view.fullWidth,\n\t\t\t\t\t\tfullHeight = view.fullHeight;\n\t\t\tleft += view.offsetX * width / fullWidth;\n\t\t\ttop -= view.offsetY * height / fullHeight;\n\t\t\twidth *= view.width / fullWidth;\n\t\t\theight *= view.height / fullHeight;\n\t\t}\n\n\t\tconst skew = this.filmOffset;\n\t\tif (skew !== 0) left += near * skew / this.getFilmWidth();\n\t\tthis.projectionMatrix.makePerspective(left, left + width, top, top - height, near, this.far);\n\t\tthis.projectionMatrixInverse.copy(this.projectionMatrix).invert();\n\t}\n\n\ttoJSON(meta) {\n\t\tconst data = super.toJSON(meta);\n\t\tdata.object.fov = this.fov;\n\t\tdata.object.zoom = this.zoom;\n\t\tdata.object.near = this.near;\n\t\tdata.object.far = this.far;\n\t\tdata.object.focus = this.focus;\n\t\tdata.object.aspect = this.aspect;\n\t\tif (this.view !== null) data.object.view = Object.assign({}, this.view);\n\t\tdata.object.filmGauge = this.filmGauge;\n\t\tdata.object.filmOffset = this.filmOffset;\n\t\treturn data;\n\t}\n\n}\n\nconst fov = 90,\n\t\t\taspect = 1;\n\nclass CubeCamera extends Object3D {\n\tconstructor(near, far, renderTarget) {\n\t\tsuper();\n\t\tthis.type = 'CubeCamera';\n\n\t\tif (renderTarget.isWebGLCubeRenderTarget !== true) {\n\t\t\tconsole.error('THREE.CubeCamera: The constructor now expects an instance of WebGLCubeRenderTarget as third parameter.');\n\t\t\treturn;\n\t\t}\n\n\t\tthis.renderTarget = renderTarget;\n\t\tconst cameraPX = new PerspectiveCamera(fov, aspect, near, far);\n\t\tcameraPX.layers = this.layers;\n\t\tcameraPX.up.set(0, -1, 0);\n\t\tcameraPX.lookAt(new Vector3(1, 0, 0));\n\t\tthis.add(cameraPX);\n\t\tconst cameraNX = new PerspectiveCamera(fov, aspect, near, far);\n\t\tcameraNX.layers = this.layers;\n\t\tcameraNX.up.set(0, -1, 0);\n\t\tcameraNX.lookAt(new Vector3(-1, 0, 0));\n\t\tthis.add(cameraNX);\n\t\tconst cameraPY = new PerspectiveCamera(fov, aspect, near, far);\n\t\tcameraPY.layers = this.layers;\n\t\tcameraPY.up.set(0, 0, 1);\n\t\tcameraPY.lookAt(new Vector3(0, 1, 0));\n\t\tthis.add(cameraPY);\n\t\tconst cameraNY = new PerspectiveCamera(fov, aspect, near, far);\n\t\tcameraNY.layers = this.layers;\n\t\tcameraNY.up.set(0, 0, -1);\n\t\tcameraNY.lookAt(new Vector3(0, -1, 0));\n\t\tthis.add(cameraNY);\n\t\tconst cameraPZ = new PerspectiveCamera(fov, aspect, near, far);\n\t\tcameraPZ.layers = this.layers;\n\t\tcameraPZ.up.set(0, -1, 0);\n\t\tcameraPZ.lookAt(new Vector3(0, 0, 1));\n\t\tthis.add(cameraPZ);\n\t\tconst cameraNZ = new PerspectiveCamera(fov, aspect, near, far);\n\t\tcameraNZ.layers = this.layers;\n\t\tcameraNZ.up.set(0, -1, 0);\n\t\tcameraNZ.lookAt(new Vector3(0, 0, -1));\n\t\tthis.add(cameraNZ);\n\t}\n\n\tupdate(renderer, scene) {\n\t\tif (this.parent === null) this.updateMatrixWorld();\n\t\tconst renderTarget = this.renderTarget;\n\t\tconst [cameraPX, cameraNX, cameraPY, cameraNY, cameraPZ, cameraNZ] = this.children;\n\t\tconst currentRenderTarget = renderer.getRenderTarget();\n\t\tconst currentToneMapping = renderer.toneMapping;\n\t\tconst currentXrEnabled = renderer.xr.enabled;\n\t\trenderer.toneMapping = NoToneMapping;\n\t\trenderer.xr.enabled = false;\n\t\tconst generateMipmaps = renderTarget.texture.generateMipmaps;\n\t\trenderTarget.texture.generateMipmaps = false;\n\t\trenderer.setRenderTarget(renderTarget, 0);\n\t\trenderer.render(scene, cameraPX);\n\t\trenderer.setRenderTarget(renderTarget, 1);\n\t\trenderer.render(scene, cameraNX);\n\t\trenderer.setRenderTarget(renderTarget, 2);\n\t\trenderer.render(scene, cameraPY);\n\t\trenderer.setRenderTarget(renderTarget, 3);\n\t\trenderer.render(scene, cameraNY);\n\t\trenderer.setRenderTarget(renderTarget, 4);\n\t\trenderer.render(scene, cameraPZ);\n\t\trenderTarget.texture.generateMipmaps = generateMipmaps;\n\t\trenderer.setRenderTarget(renderTarget, 5);\n\t\trenderer.render(scene, cameraNZ);\n\t\trenderer.setRenderTarget(currentRenderTarget);\n\t\trenderer.toneMapping = currentToneMapping;\n\t\trenderer.xr.enabled = currentXrEnabled;\n\t\trenderTarget.texture.needsPMREMUpdate = true;\n\t}\n\n}\n\nclass CubeTexture extends Texture {\n\tconstructor(images, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding) {\n\t\timages = images !== undefined ? images : [];\n\t\tmapping = mapping !== undefined ? mapping : CubeReflectionMapping;\n\t\tsuper(images, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding);\n\t\tthis.isCubeTexture = true;\n\t\tthis.flipY = false;\n\t}\n\n\tget images() {\n\t\treturn this.image;\n\t}\n\n\tset images(value) {\n\t\tthis.image = value;\n\t}\n\n}\n\nclass WebGLCubeRenderTarget extends WebGLRenderTarget {\n\tconstructor(size, options = {}) {\n\t\tsuper(size, size, options);\n\t\tthis.isWebGLCubeRenderTarget = true;\n\t\tconst image = {\n\t\t\twidth: size,\n\t\t\theight: size,\n\t\t\tdepth: 1\n\t\t};\n\t\tconst images = [image, image, image, image, image, image];\n\t\tthis.texture = new CubeTexture(images, options.mapping, options.wrapS, options.wrapT, options.magFilter, options.minFilter, options.format, options.type, options.anisotropy, options.encoding); // By convention -- likely based on the RenderMan spec from the 1990's -- cube maps are specified by WebGL (and three.js)\n\t\t// in a coordinate system in which positive-x is to the right when looking up the positive-z axis -- in other words,\n\t\t// in a left-handed coordinate system. By continuing this convention, preexisting cube maps continued to render correctly.\n\t\t// three.js uses a right-handed coordinate system. So environment maps used in three.js appear to have px and nx swapped\n\t\t// and the flag isRenderTargetTexture controls this conversion. The flip is not required when using WebGLCubeRenderTarget.texture\n\t\t// as a cube texture (this is detected when isRenderTargetTexture is set to true for cube textures).\n\n\t\tthis.texture.isRenderTargetTexture = true;\n\t\tthis.texture.generateMipmaps = options.generateMipmaps !== undefined ? options.generateMipmaps : false;\n\t\tthis.texture.minFilter = options.minFilter !== undefined ? options.minFilter : LinearFilter;\n\t}\n\n\tfromEquirectangularTexture(renderer, texture) {\n\t\tthis.texture.type = texture.type;\n\t\tthis.texture.encoding = texture.encoding;\n\t\tthis.texture.generateMipmaps = texture.generateMipmaps;\n\t\tthis.texture.minFilter = texture.minFilter;\n\t\tthis.texture.magFilter = texture.magFilter;\n\t\tconst shader = {\n\t\t\tuniforms: {\n\t\t\t\ttEquirect: {\n\t\t\t\t\tvalue: null\n\t\t\t\t}\n\t\t\t},\n\t\t\tvertexShader:\n\t\t\t/* glsl */\n\t\t\t`\n\n\t\t\t\tvarying vec3 vWorldDirection;\n\n\t\t\t\tvec3 transformDirection( in vec3 dir, in mat4 matrix ) {\n\n\t\t\t\t\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );\n\n\t\t\t\t}\n\n\t\t\t\tvoid main() {\n\n\t\t\t\t\tvWorldDirection = transformDirection( position, modelMatrix );\n\n\t\t\t\t\t#include \n\t\t\t\t\t#include \n\n\t\t\t\t}\n\t\t\t`,\n\t\t\tfragmentShader:\n\t\t\t/* glsl */\n\t\t\t`\n\n\t\t\t\tuniform sampler2D tEquirect;\n\n\t\t\t\tvarying vec3 vWorldDirection;\n\n\t\t\t\t#include \n\n\t\t\t\tvoid main() {\n\n\t\t\t\t\tvec3 direction = normalize( vWorldDirection );\n\n\t\t\t\t\tvec2 sampleUV = equirectUv( direction );\n\n\t\t\t\t\tgl_FragColor = texture2D( tEquirect, sampleUV );\n\n\t\t\t\t}\n\t\t\t`\n\t\t};\n\t\tconst geometry = new BoxGeometry(5, 5, 5);\n\t\tconst material = new ShaderMaterial({\n\t\t\tname: 'CubemapFromEquirect',\n\t\t\tuniforms: cloneUniforms(shader.uniforms),\n\t\t\tvertexShader: shader.vertexShader,\n\t\t\tfragmentShader: shader.fragmentShader,\n\t\t\tside: BackSide,\n\t\t\tblending: NoBlending\n\t\t});\n\t\tmaterial.uniforms.tEquirect.value = texture;\n\t\tconst mesh = new Mesh(geometry, material);\n\t\tconst currentMinFilter = texture.minFilter; // Avoid blurred poles\n\n\t\tif (texture.minFilter === LinearMipmapLinearFilter) texture.minFilter = LinearFilter;\n\t\tconst camera = new CubeCamera(1, 10, this);\n\t\tcamera.update(renderer, mesh);\n\t\ttexture.minFilter = currentMinFilter;\n\t\tmesh.geometry.dispose();\n\t\tmesh.material.dispose();\n\t\treturn this;\n\t}\n\n\tclear(renderer, color, depth, stencil) {\n\t\tconst currentRenderTarget = renderer.getRenderTarget();\n\n\t\tfor (let i = 0; i < 6; i++) {\n\t\t\trenderer.setRenderTarget(this, i);\n\t\t\trenderer.clear(color, depth, stencil);\n\t\t}\n\n\t\trenderer.setRenderTarget(currentRenderTarget);\n\t}\n\n}\n\nconst _vector1 = /*@__PURE__*/new Vector3();\n\nconst _vector2 = /*@__PURE__*/new Vector3();\n\nconst _normalMatrix = /*@__PURE__*/new Matrix3();\n\nclass Plane {\n\tconstructor(normal = new Vector3(1, 0, 0), constant = 0) {\n\t\tthis.isPlane = true; // normal is assumed to be normalized\n\n\t\tthis.normal = normal;\n\t\tthis.constant = constant;\n\t}\n\n\tset(normal, constant) {\n\t\tthis.normal.copy(normal);\n\t\tthis.constant = constant;\n\t\treturn this;\n\t}\n\n\tsetComponents(x, y, z, w) {\n\t\tthis.normal.set(x, y, z);\n\t\tthis.constant = w;\n\t\treturn this;\n\t}\n\n\tsetFromNormalAndCoplanarPoint(normal, point) {\n\t\tthis.normal.copy(normal);\n\t\tthis.constant = -point.dot(this.normal);\n\t\treturn this;\n\t}\n\n\tsetFromCoplanarPoints(a, b, c) {\n\t\tconst normal = _vector1.subVectors(c, b).cross(_vector2.subVectors(a, b)).normalize(); // Q: should an error be thrown if normal is zero (e.g. degenerate plane)?\n\n\n\t\tthis.setFromNormalAndCoplanarPoint(normal, a);\n\t\treturn this;\n\t}\n\n\tcopy(plane) {\n\t\tthis.normal.copy(plane.normal);\n\t\tthis.constant = plane.constant;\n\t\treturn this;\n\t}\n\n\tnormalize() {\n\t\t// Note: will lead to a divide by zero if the plane is invalid.\n\t\tconst inverseNormalLength = 1.0 / this.normal.length();\n\t\tthis.normal.multiplyScalar(inverseNormalLength);\n\t\tthis.constant *= inverseNormalLength;\n\t\treturn this;\n\t}\n\n\tnegate() {\n\t\tthis.constant *= -1;\n\t\tthis.normal.negate();\n\t\treturn this;\n\t}\n\n\tdistanceToPoint(point) {\n\t\treturn this.normal.dot(point) + this.constant;\n\t}\n\n\tdistanceToSphere(sphere) {\n\t\treturn this.distanceToPoint(sphere.center) - sphere.radius;\n\t}\n\n\tprojectPoint(point, target) {\n\t\treturn target.copy(this.normal).multiplyScalar(-this.distanceToPoint(point)).add(point);\n\t}\n\n\tintersectLine(line, target) {\n\t\tconst direction = line.delta(_vector1);\n\t\tconst denominator = this.normal.dot(direction);\n\n\t\tif (denominator === 0) {\n\t\t\t// line is coplanar, return origin\n\t\t\tif (this.distanceToPoint(line.start) === 0) {\n\t\t\t\treturn target.copy(line.start);\n\t\t\t} // Unsure if this is the correct method to handle this case.\n\n\n\t\t\treturn null;\n\t\t}\n\n\t\tconst t = -(line.start.dot(this.normal) + this.constant) / denominator;\n\n\t\tif (t < 0 || t > 1) {\n\t\t\treturn null;\n\t\t}\n\n\t\treturn target.copy(direction).multiplyScalar(t).add(line.start);\n\t}\n\n\tintersectsLine(line) {\n\t\t// Note: this tests if a line intersects the plane, not whether it (or its end-points) are coplanar with it.\n\t\tconst startSign = this.distanceToPoint(line.start);\n\t\tconst endSign = this.distanceToPoint(line.end);\n\t\treturn startSign < 0 && endSign > 0 || endSign < 0 && startSign > 0;\n\t}\n\n\tintersectsBox(box) {\n\t\treturn box.intersectsPlane(this);\n\t}\n\n\tintersectsSphere(sphere) {\n\t\treturn sphere.intersectsPlane(this);\n\t}\n\n\tcoplanarPoint(target) {\n\t\treturn target.copy(this.normal).multiplyScalar(-this.constant);\n\t}\n\n\tapplyMatrix4(matrix, optionalNormalMatrix) {\n\t\tconst normalMatrix = optionalNormalMatrix || _normalMatrix.getNormalMatrix(matrix);\n\n\t\tconst referencePoint = this.coplanarPoint(_vector1).applyMatrix4(matrix);\n\t\tconst normal = this.normal.applyMatrix3(normalMatrix).normalize();\n\t\tthis.constant = -referencePoint.dot(normal);\n\t\treturn this;\n\t}\n\n\ttranslate(offset) {\n\t\tthis.constant -= offset.dot(this.normal);\n\t\treturn this;\n\t}\n\n\tequals(plane) {\n\t\treturn plane.normal.equals(this.normal) && plane.constant === this.constant;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n}\n\nconst _sphere$2 = /*@__PURE__*/new Sphere();\n\nconst _vector$7 = /*@__PURE__*/new Vector3();\n\nclass Frustum {\n\tconstructor(p0 = new Plane(), p1 = new Plane(), p2 = new Plane(), p3 = new Plane(), p4 = new Plane(), p5 = new Plane()) {\n\t\tthis.planes = [p0, p1, p2, p3, p4, p5];\n\t}\n\n\tset(p0, p1, p2, p3, p4, p5) {\n\t\tconst planes = this.planes;\n\t\tplanes[0].copy(p0);\n\t\tplanes[1].copy(p1);\n\t\tplanes[2].copy(p2);\n\t\tplanes[3].copy(p3);\n\t\tplanes[4].copy(p4);\n\t\tplanes[5].copy(p5);\n\t\treturn this;\n\t}\n\n\tcopy(frustum) {\n\t\tconst planes = this.planes;\n\n\t\tfor (let i = 0; i < 6; i++) {\n\t\t\tplanes[i].copy(frustum.planes[i]);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tsetFromProjectionMatrix(m) {\n\t\tconst planes = this.planes;\n\t\tconst me = m.elements;\n\t\tconst me0 = me[0],\n\t\t\t\t\tme1 = me[1],\n\t\t\t\t\tme2 = me[2],\n\t\t\t\t\tme3 = me[3];\n\t\tconst me4 = me[4],\n\t\t\t\t\tme5 = me[5],\n\t\t\t\t\tme6 = me[6],\n\t\t\t\t\tme7 = me[7];\n\t\tconst me8 = me[8],\n\t\t\t\t\tme9 = me[9],\n\t\t\t\t\tme10 = me[10],\n\t\t\t\t\tme11 = me[11];\n\t\tconst me12 = me[12],\n\t\t\t\t\tme13 = me[13],\n\t\t\t\t\tme14 = me[14],\n\t\t\t\t\tme15 = me[15];\n\t\tplanes[0].setComponents(me3 - me0, me7 - me4, me11 - me8, me15 - me12).normalize();\n\t\tplanes[1].setComponents(me3 + me0, me7 + me4, me11 + me8, me15 + me12).normalize();\n\t\tplanes[2].setComponents(me3 + me1, me7 + me5, me11 + me9, me15 + me13).normalize();\n\t\tplanes[3].setComponents(me3 - me1, me7 - me5, me11 - me9, me15 - me13).normalize();\n\t\tplanes[4].setComponents(me3 - me2, me7 - me6, me11 - me10, me15 - me14).normalize();\n\t\tplanes[5].setComponents(me3 + me2, me7 + me6, me11 + me10, me15 + me14).normalize();\n\t\treturn this;\n\t}\n\n\tintersectsObject(object) {\n\t\tconst geometry = object.geometry;\n\t\tif (geometry.boundingSphere === null) geometry.computeBoundingSphere();\n\n\t\t_sphere$2.copy(geometry.boundingSphere).applyMatrix4(object.matrixWorld);\n\n\t\treturn this.intersectsSphere(_sphere$2);\n\t}\n\n\tintersectsSprite(sprite) {\n\t\t_sphere$2.center.set(0, 0, 0);\n\n\t\t_sphere$2.radius = 0.7071067811865476;\n\n\t\t_sphere$2.applyMatrix4(sprite.matrixWorld);\n\n\t\treturn this.intersectsSphere(_sphere$2);\n\t}\n\n\tintersectsSphere(sphere) {\n\t\tconst planes = this.planes;\n\t\tconst center = sphere.center;\n\t\tconst negRadius = -sphere.radius;\n\n\t\tfor (let i = 0; i < 6; i++) {\n\t\t\tconst distance = planes[i].distanceToPoint(center);\n\n\t\t\tif (distance < negRadius) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\treturn true;\n\t}\n\n\tintersectsBox(box) {\n\t\tconst planes = this.planes;\n\n\t\tfor (let i = 0; i < 6; i++) {\n\t\t\tconst plane = planes[i]; // corner at max distance\n\n\t\t\t_vector$7.x = plane.normal.x > 0 ? box.max.x : box.min.x;\n\t\t\t_vector$7.y = plane.normal.y > 0 ? box.max.y : box.min.y;\n\t\t\t_vector$7.z = plane.normal.z > 0 ? box.max.z : box.min.z;\n\n\t\t\tif (plane.distanceToPoint(_vector$7) < 0) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\treturn true;\n\t}\n\n\tcontainsPoint(point) {\n\t\tconst planes = this.planes;\n\n\t\tfor (let i = 0; i < 6; i++) {\n\t\t\tif (planes[i].distanceToPoint(point) < 0) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\treturn true;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n}\n\nfunction WebGLAnimation() {\n\tlet context = null;\n\tlet isAnimating = false;\n\tlet animationLoop = null;\n\tlet requestId = null;\n\n\tfunction onAnimationFrame(time, frame) {\n\t\tanimationLoop(time, frame);\n\t\trequestId = context.requestAnimationFrame(onAnimationFrame);\n\t}\n\n\treturn {\n\t\tstart: function () {\n\t\t\tif (isAnimating === true) return;\n\t\t\tif (animationLoop === null) return;\n\t\t\trequestId = context.requestAnimationFrame(onAnimationFrame);\n\t\t\tisAnimating = true;\n\t\t},\n\t\tstop: function () {\n\t\t\tcontext.cancelAnimationFrame(requestId);\n\t\t\tisAnimating = false;\n\t\t},\n\t\tsetAnimationLoop: function (callback) {\n\t\t\tanimationLoop = callback;\n\t\t},\n\t\tsetContext: function (value) {\n\t\t\tcontext = value;\n\t\t}\n\t};\n}\n\nfunction WebGLAttributes(gl, capabilities) {\n\tconst isWebGL2 = capabilities.isWebGL2;\n\tconst buffers = new WeakMap();\n\n\tfunction createBuffer(attribute, bufferType) {\n\t\tconst array = attribute.array;\n\t\tconst usage = attribute.usage;\n\t\tconst buffer = gl.createBuffer();\n\t\tgl.bindBuffer(bufferType, buffer);\n\t\tgl.bufferData(bufferType, array, usage);\n\t\tattribute.onUploadCallback();\n\t\tlet type;\n\n\t\tif (array instanceof Float32Array) {\n\t\t\ttype = gl.FLOAT;\n\t\t} else if (array instanceof Uint16Array) {\n\t\t\tif (attribute.isFloat16BufferAttribute) {\n\t\t\t\tif (isWebGL2) {\n\t\t\t\t\ttype = gl.HALF_FLOAT;\n\t\t\t\t} else {\n\t\t\t\t\tthrow new Error('THREE.WebGLAttributes: Usage of Float16BufferAttribute requires WebGL2.');\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\ttype = gl.UNSIGNED_SHORT;\n\t\t\t}\n\t\t} else if (array instanceof Int16Array) {\n\t\t\ttype = gl.SHORT;\n\t\t} else if (array instanceof Uint32Array) {\n\t\t\ttype = gl.UNSIGNED_INT;\n\t\t} else if (array instanceof Int32Array) {\n\t\t\ttype = gl.INT;\n\t\t} else if (array instanceof Int8Array) {\n\t\t\ttype = gl.BYTE;\n\t\t} else if (array instanceof Uint8Array) {\n\t\t\ttype = gl.UNSIGNED_BYTE;\n\t\t} else if (array instanceof Uint8ClampedArray) {\n\t\t\ttype = gl.UNSIGNED_BYTE;\n\t\t} else {\n\t\t\tthrow new Error('THREE.WebGLAttributes: Unsupported buffer data format: ' + array);\n\t\t}\n\n\t\treturn {\n\t\t\tbuffer: buffer,\n\t\t\ttype: type,\n\t\t\tbytesPerElement: array.BYTES_PER_ELEMENT,\n\t\t\tversion: attribute.version\n\t\t};\n\t}\n\n\tfunction updateBuffer(buffer, attribute, bufferType) {\n\t\tconst array = attribute.array;\n\t\tconst updateRange = attribute.updateRange;\n\t\tgl.bindBuffer(bufferType, buffer);\n\n\t\tif (updateRange.count === -1) {\n\t\t\t// Not using update ranges\n\t\t\tgl.bufferSubData(bufferType, 0, array);\n\t\t} else {\n\t\t\tif (isWebGL2) {\n\t\t\t\tgl.bufferSubData(bufferType, updateRange.offset * array.BYTES_PER_ELEMENT, array, updateRange.offset, updateRange.count);\n\t\t\t} else {\n\t\t\t\tgl.bufferSubData(bufferType, updateRange.offset * array.BYTES_PER_ELEMENT, array.subarray(updateRange.offset, updateRange.offset + updateRange.count));\n\t\t\t}\n\n\t\t\tupdateRange.count = -1; // reset range\n\t\t}\n\t} //\n\n\n\tfunction get(attribute) {\n\t\tif (attribute.isInterleavedBufferAttribute) attribute = attribute.data;\n\t\treturn buffers.get(attribute);\n\t}\n\n\tfunction remove(attribute) {\n\t\tif (attribute.isInterleavedBufferAttribute) attribute = attribute.data;\n\t\tconst data = buffers.get(attribute);\n\n\t\tif (data) {\n\t\t\tgl.deleteBuffer(data.buffer);\n\t\t\tbuffers.delete(attribute);\n\t\t}\n\t}\n\n\tfunction update(attribute, bufferType) {\n\t\tif (attribute.isGLBufferAttribute) {\n\t\t\tconst cached = buffers.get(attribute);\n\n\t\t\tif (!cached || cached.version < attribute.version) {\n\t\t\t\tbuffers.set(attribute, {\n\t\t\t\t\tbuffer: attribute.buffer,\n\t\t\t\t\ttype: attribute.type,\n\t\t\t\t\tbytesPerElement: attribute.elementSize,\n\t\t\t\t\tversion: attribute.version\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\tif (attribute.isInterleavedBufferAttribute) attribute = attribute.data;\n\t\tconst data = buffers.get(attribute);\n\n\t\tif (data === undefined) {\n\t\t\tbuffers.set(attribute, createBuffer(attribute, bufferType));\n\t\t} else if (data.version < attribute.version) {\n\t\t\tupdateBuffer(data.buffer, attribute, bufferType);\n\t\t\tdata.version = attribute.version;\n\t\t}\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tremove: remove,\n\t\tupdate: update\n\t};\n}\n\nclass PlaneGeometry extends BufferGeometry {\n\tconstructor(width = 1, height = 1, widthSegments = 1, heightSegments = 1) {\n\t\tsuper();\n\t\tthis.type = 'PlaneGeometry';\n\t\tthis.parameters = {\n\t\t\twidth: width,\n\t\t\theight: height,\n\t\t\twidthSegments: widthSegments,\n\t\t\theightSegments: heightSegments\n\t\t};\n\t\tconst width_half = width / 2;\n\t\tconst height_half = height / 2;\n\t\tconst gridX = Math.floor(widthSegments);\n\t\tconst gridY = Math.floor(heightSegments);\n\t\tconst gridX1 = gridX + 1;\n\t\tconst gridY1 = gridY + 1;\n\t\tconst segment_width = width / gridX;\n\t\tconst segment_height = height / gridY; //\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\n\t\tfor (let iy = 0; iy < gridY1; iy++) {\n\t\t\tconst y = iy * segment_height - height_half;\n\n\t\t\tfor (let ix = 0; ix < gridX1; ix++) {\n\t\t\t\tconst x = ix * segment_width - width_half;\n\t\t\t\tvertices.push(x, -y, 0);\n\t\t\t\tnormals.push(0, 0, 1);\n\t\t\t\tuvs.push(ix / gridX);\n\t\t\t\tuvs.push(1 - iy / gridY);\n\t\t\t}\n\t\t}\n\n\t\tfor (let iy = 0; iy < gridY; iy++) {\n\t\t\tfor (let ix = 0; ix < gridX; ix++) {\n\t\t\t\tconst a = ix + gridX1 * iy;\n\t\t\t\tconst b = ix + gridX1 * (iy + 1);\n\t\t\t\tconst c = ix + 1 + gridX1 * (iy + 1);\n\t\t\t\tconst d = ix + 1 + gridX1 * iy;\n\t\t\t\tindices.push(a, b, d);\n\t\t\t\tindices.push(b, c, d);\n\t\t\t}\n\t\t}\n\n\t\tthis.setIndex(indices);\n\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tthis.setAttribute('normal', new Float32BufferAttribute(normals, 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvs, 2));\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new PlaneGeometry(data.width, data.height, data.widthSegments, data.heightSegments);\n\t}\n\n}\n\nvar alphamap_fragment = \"#ifdef USE_ALPHAMAP\\n\\tdiffuseColor.a *= texture2D( alphaMap, vUv ).g;\\n#endif\";\n\nvar alphamap_pars_fragment = \"#ifdef USE_ALPHAMAP\\n\\tuniform sampler2D alphaMap;\\n#endif\";\n\nvar alphatest_fragment = \"#ifdef USE_ALPHATEST\\n\\tif ( diffuseColor.a < alphaTest ) discard;\\n#endif\";\n\nvar alphatest_pars_fragment = \"#ifdef USE_ALPHATEST\\n\\tuniform float alphaTest;\\n#endif\";\n\nvar aomap_fragment = \"#ifdef USE_AOMAP\\n\\tfloat ambientOcclusion = ( texture2D( aoMap, vUv2 ).r - 1.0 ) * aoMapIntensity + 1.0;\\n\\treflectedLight.indirectDiffuse *= ambientOcclusion;\\n\\t#if defined( USE_ENVMAP ) && defined( STANDARD )\\n\\t\\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\\n\\t\\treflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.roughness );\\n\\t#endif\\n#endif\";\n\nvar aomap_pars_fragment = \"#ifdef USE_AOMAP\\n\\tuniform sampler2D aoMap;\\n\\tuniform float aoMapIntensity;\\n#endif\";\n\nvar begin_vertex = \"vec3 transformed = vec3( position );\";\n\nvar beginnormal_vertex = \"vec3 objectNormal = vec3( normal );\\n#ifdef USE_TANGENT\\n\\tvec3 objectTangent = vec3( tangent.xyz );\\n#endif\";\n\nvar bsdfs = \"vec3 BRDF_Lambert( const in vec3 diffuseColor ) {\\n\\treturn RECIPROCAL_PI * diffuseColor;\\n}\\nvec3 F_Schlick( const in vec3 f0, const in float f90, const in float dotVH ) {\\n\\tfloat fresnel = exp2( ( - 5.55473 * dotVH - 6.98316 ) * dotVH );\\n\\treturn f0 * ( 1.0 - fresnel ) + ( f90 * fresnel );\\n}\\nfloat F_Schlick( const in float f0, const in float f90, const in float dotVH ) {\\n\\tfloat fresnel = exp2( ( - 5.55473 * dotVH - 6.98316 ) * dotVH );\\n\\treturn f0 * ( 1.0 - fresnel ) + ( f90 * fresnel );\\n}\\nvec3 Schlick_to_F0( const in vec3 f, const in float f90, const in float dotVH ) {\\n\t\tfloat x = clamp( 1.0 - dotVH, 0.0, 1.0 );\\n\t\tfloat x2 = x * x;\\n\t\tfloat x5 = clamp( x * x2 * x2, 0.0, 0.9999 );\\n\t\treturn ( f - vec3( f90 ) * x5 ) / ( 1.0 - x5 );\\n}\\nfloat V_GGX_SmithCorrelated( const in float alpha, const in float dotNL, const in float dotNV ) {\\n\\tfloat a2 = pow2( alpha );\\n\\tfloat gv = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\\n\\tfloat gl = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\\n\\treturn 0.5 / max( gv + gl, EPSILON );\\n}\\nfloat D_GGX( const in float alpha, const in float dotNH ) {\\n\\tfloat a2 = pow2( alpha );\\n\\tfloat denom = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0;\\n\\treturn RECIPROCAL_PI * a2 / pow2( denom );\\n}\\nvec3 BRDF_GGX( const in vec3 lightDir, const in vec3 viewDir, const in vec3 normal, const in vec3 f0, const in float f90, const in float roughness ) {\\n\\tfloat alpha = pow2( roughness );\\n\\tvec3 halfDir = normalize( lightDir + viewDir );\\n\\tfloat dotNL = saturate( dot( normal, lightDir ) );\\n\\tfloat dotNV = saturate( dot( normal, viewDir ) );\\n\\tfloat dotNH = saturate( dot( normal, halfDir ) );\\n\\tfloat dotVH = saturate( dot( viewDir, halfDir ) );\\n\\tvec3 F = F_Schlick( f0, f90, dotVH );\\n\\tfloat V = V_GGX_SmithCorrelated( alpha, dotNL, dotNV );\\n\\tfloat D = D_GGX( alpha, dotNH );\\n\\treturn F * ( V * D );\\n}\\n#ifdef USE_IRIDESCENCE\\nvec3 BRDF_GGX_Iridescence( const in vec3 lightDir, const in vec3 viewDir, const in vec3 normal, const in vec3 f0, const in float f90, const in float iridescence, const in vec3 iridescenceFresnel, const in float roughness ) {\\n\\tfloat alpha = pow2( roughness );\\n\\tvec3 halfDir = normalize( lightDir + viewDir );\\n\\tfloat dotNL = saturate( dot( normal, lightDir ) );\\n\\tfloat dotNV = saturate( dot( normal, viewDir ) );\\n\\tfloat dotNH = saturate( dot( normal, halfDir ) );\\n\\tfloat dotVH = saturate( dot( viewDir, halfDir ) );\\n\\tvec3 F = mix(F_Schlick( f0, f90, dotVH ), iridescenceFresnel, iridescence);\\n\\tfloat V = V_GGX_SmithCorrelated( alpha, dotNL, dotNV );\\n\\tfloat D = D_GGX( alpha, dotNH );\\n\\treturn F * ( V * D );\\n}\\n#endif\\nvec2 LTC_Uv( const in vec3 N, const in vec3 V, const in float roughness ) {\\n\\tconst float LUT_SIZE = 64.0;\\n\\tconst float LUT_SCALE = ( LUT_SIZE - 1.0 ) / LUT_SIZE;\\n\\tconst float LUT_BIAS = 0.5 / LUT_SIZE;\\n\\tfloat dotNV = saturate( dot( N, V ) );\\n\\tvec2 uv = vec2( roughness, sqrt( 1.0 - dotNV ) );\\n\\tuv = uv * LUT_SCALE + LUT_BIAS;\\n\\treturn uv;\\n}\\nfloat LTC_ClippedSphereFormFactor( const in vec3 f ) {\\n\\tfloat l = length( f );\\n\\treturn max( ( l * l + f.z ) / ( l + 1.0 ), 0.0 );\\n}\\nvec3 LTC_EdgeVectorFormFactor( const in vec3 v1, const in vec3 v2 ) {\\n\\tfloat x = dot( v1, v2 );\\n\\tfloat y = abs( x );\\n\\tfloat a = 0.8543985 + ( 0.4965155 + 0.0145206 * y ) * y;\\n\\tfloat b = 3.4175940 + ( 4.1616724 + y ) * y;\\n\\tfloat v = a / b;\\n\\tfloat theta_sintheta = ( x > 0.0 ) ? v : 0.5 * inversesqrt( max( 1.0 - x * x, 1e-7 ) ) - v;\\n\\treturn cross( v1, v2 ) * theta_sintheta;\\n}\\nvec3 LTC_Evaluate( const in vec3 N, const in vec3 V, const in vec3 P, const in mat3 mInv, const in vec3 rectCoords[ 4 ] ) {\\n\\tvec3 v1 = rectCoords[ 1 ] - rectCoords[ 0 ];\\n\\tvec3 v2 = rectCoords[ 3 ] - rectCoords[ 0 ];\\n\\tvec3 lightNormal = cross( v1, v2 );\\n\\tif( dot( lightNormal, P - rectCoords[ 0 ] ) < 0.0 ) return vec3( 0.0 );\\n\\tvec3 T1, T2;\\n\\tT1 = normalize( V - N * dot( V, N ) );\\n\\tT2 = - cross( N, T1 );\\n\\tmat3 mat = mInv * transposeMat3( mat3( T1, T2, N ) );\\n\\tvec3 coords[ 4 ];\\n\\tcoords[ 0 ] = mat * ( rectCoords[ 0 ] - P );\\n\\tcoords[ 1 ] = mat * ( rectCoords[ 1 ] - P );\\n\\tcoords[ 2 ] = mat * ( rectCoords[ 2 ] - P );\\n\\tcoords[ 3 ] = mat * ( rectCoords[ 3 ] - P );\\n\\tcoords[ 0 ] = normalize( coords[ 0 ] );\\n\\tcoords[ 1 ] = normalize( coords[ 1 ] );\\n\\tcoords[ 2 ] = normalize( coords[ 2 ] );\\n\\tcoords[ 3 ] = normalize( coords[ 3 ] );\\n\\tvec3 vectorFormFactor = vec3( 0.0 );\\n\\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 0 ], coords[ 1 ] );\\n\\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 1 ], coords[ 2 ] );\\n\\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 2 ], coords[ 3 ] );\\n\\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 3 ], coords[ 0 ] );\\n\\tfloat result = LTC_ClippedSphereFormFactor( vectorFormFactor );\\n\\treturn vec3( result );\\n}\\nfloat G_BlinnPhong_Implicit( ) {\\n\\treturn 0.25;\\n}\\nfloat D_BlinnPhong( const in float shininess, const in float dotNH ) {\\n\\treturn RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow( dotNH, shininess );\\n}\\nvec3 BRDF_BlinnPhong( const in vec3 lightDir, const in vec3 viewDir, const in vec3 normal, const in vec3 specularColor, const in float shininess ) {\\n\\tvec3 halfDir = normalize( lightDir + viewDir );\\n\\tfloat dotNH = saturate( dot( normal, halfDir ) );\\n\\tfloat dotVH = saturate( dot( viewDir, halfDir ) );\\n\\tvec3 F = F_Schlick( specularColor, 1.0, dotVH );\\n\\tfloat G = G_BlinnPhong_Implicit( );\\n\\tfloat D = D_BlinnPhong( shininess, dotNH );\\n\\treturn F * ( G * D );\\n}\\n#if defined( USE_SHEEN )\\nfloat D_Charlie( float roughness, float dotNH ) {\\n\\tfloat alpha = pow2( roughness );\\n\\tfloat invAlpha = 1.0 / alpha;\\n\\tfloat cos2h = dotNH * dotNH;\\n\\tfloat sin2h = max( 1.0 - cos2h, 0.0078125 );\\n\\treturn ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI );\\n}\\nfloat V_Neubelt( float dotNV, float dotNL ) {\\n\\treturn saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) );\\n}\\nvec3 BRDF_Sheen( const in vec3 lightDir, const in vec3 viewDir, const in vec3 normal, vec3 sheenColor, const in float sheenRoughness ) {\\n\\tvec3 halfDir = normalize( lightDir + viewDir );\\n\\tfloat dotNL = saturate( dot( normal, lightDir ) );\\n\\tfloat dotNV = saturate( dot( normal, viewDir ) );\\n\\tfloat dotNH = saturate( dot( normal, halfDir ) );\\n\\tfloat D = D_Charlie( sheenRoughness, dotNH );\\n\\tfloat V = V_Neubelt( dotNV, dotNL );\\n\\treturn sheenColor * ( D * V );\\n}\\n#endif\";\n\nvar iridescence_fragment = \"#ifdef USE_IRIDESCENCE\\nconst mat3 XYZ_TO_REC709 = mat3(\\n\t\t3.2404542, -0.9692660,\t0.0556434,\\n\t -1.5371385,\t1.8760108, -0.2040259,\\n\t -0.4985314,\t0.0415560,\t1.0572252\\n);\\nvec3 Fresnel0ToIor( vec3 fresnel0 ) {\\n\t vec3 sqrtF0 = sqrt( fresnel0 );\\n\t return ( vec3( 1.0 ) + sqrtF0 ) / ( vec3( 1.0 ) - sqrtF0 );\\n}\\nvec3 IorToFresnel0( vec3 transmittedIor, float incidentIor ) {\\n\t return pow2( ( transmittedIor - vec3( incidentIor ) ) / ( transmittedIor + vec3( incidentIor ) ) );\\n}\\nfloat IorToFresnel0( float transmittedIor, float incidentIor ) {\\n\t return pow2( ( transmittedIor - incidentIor ) / ( transmittedIor + incidentIor ));\\n}\\nvec3 evalSensitivity( float OPD, vec3 shift ) {\\n\t float phase = 2.0 * PI * OPD * 1.0e-9;\\n\t vec3 val = vec3( 5.4856e-13, 4.4201e-13, 5.2481e-13 );\\n\t vec3 pos = vec3( 1.6810e+06, 1.7953e+06, 2.2084e+06 );\\n\t vec3 var = vec3( 4.3278e+09, 9.3046e+09, 6.6121e+09 );\\n\t vec3 xyz = val * sqrt( 2.0 * PI * var ) * cos( pos * phase + shift ) * exp( -pow2( phase ) * var );\\n\t xyz.x += 9.7470e-14 * sqrt( 2.0 * PI * 4.5282e+09 ) * cos( 2.2399e+06 * phase + shift[0] ) * exp( -4.5282e+09 * pow2( phase ) );\\n\t xyz /= 1.0685e-7;\\n\t vec3 srgb = XYZ_TO_REC709 * xyz;\\n\t return srgb;\\n}\\nvec3 evalIridescence( float outsideIOR, float eta2, float cosTheta1, float thinFilmThickness, vec3 baseF0 ) {\\n\t vec3 I;\\n\t float iridescenceIOR = mix( outsideIOR, eta2, smoothstep( 0.0, 0.03, thinFilmThickness ) );\\n\t float sinTheta2Sq = pow2( outsideIOR / iridescenceIOR ) * ( 1.0 - pow2( cosTheta1 ) );\\n\t float cosTheta2Sq = 1.0 - sinTheta2Sq;\\n\t if ( cosTheta2Sq < 0.0 ) {\\n\t\t\t return vec3( 1.0 );\\n\t }\\n\t float cosTheta2 = sqrt( cosTheta2Sq );\\n\t float R0 = IorToFresnel0( iridescenceIOR, outsideIOR );\\n\t float R12 = F_Schlick( R0, 1.0, cosTheta1 );\\n\t float R21 = R12;\\n\t float T121 = 1.0 - R12;\\n\t float phi12 = 0.0;\\n\t if ( iridescenceIOR < outsideIOR ) phi12 = PI;\\n\t float phi21 = PI - phi12;\\n\t vec3 baseIOR = Fresnel0ToIor( clamp( baseF0, 0.0, 0.9999 ) );\t vec3 R1 = IorToFresnel0( baseIOR, iridescenceIOR );\\n\t vec3 R23 = F_Schlick( R1, 1.0, cosTheta2 );\\n\t vec3 phi23 = vec3( 0.0 );\\n\t if ( baseIOR[0] < iridescenceIOR ) phi23[0] = PI;\\n\t if ( baseIOR[1] < iridescenceIOR ) phi23[1] = PI;\\n\t if ( baseIOR[2] < iridescenceIOR ) phi23[2] = PI;\\n\t float OPD = 2.0 * iridescenceIOR * thinFilmThickness * cosTheta2;\\n\t vec3 phi = vec3( phi21 ) + phi23;\\n\t vec3 R123 = clamp( R12 * R23, 1e-5, 0.9999 );\\n\t vec3 r123 = sqrt( R123 );\\n\t vec3 Rs = pow2( T121 ) * R23 / ( vec3( 1.0 ) - R123 );\\n\t vec3 C0 = R12 + Rs;\\n\t I = C0;\\n\t vec3 Cm = Rs - T121;\\n\t for ( int m = 1; m <= 2; ++m ) {\\n\t\t\t Cm *= r123;\\n\t\t\t vec3 Sm = 2.0 * evalSensitivity( float( m ) * OPD, float( m ) * phi );\\n\t\t\t I += Cm * Sm;\\n\t }\\n\t return max( I, vec3( 0.0 ) );\\n}\\n#endif\";\n\nvar bumpmap_pars_fragment = \"#ifdef USE_BUMPMAP\\n\\tuniform sampler2D bumpMap;\\n\\tuniform float bumpScale;\\n\\tvec2 dHdxy_fwd() {\\n\\t\\tvec2 dSTdx = dFdx( vUv );\\n\\t\\tvec2 dSTdy = dFdy( vUv );\\n\\t\\tfloat Hll = bumpScale * texture2D( bumpMap, vUv ).x;\\n\\t\\tfloat dBx = bumpScale * texture2D( bumpMap, vUv + dSTdx ).x - Hll;\\n\\t\\tfloat dBy = bumpScale * texture2D( bumpMap, vUv + dSTdy ).x - Hll;\\n\\t\\treturn vec2( dBx, dBy );\\n\\t}\\n\\tvec3 perturbNormalArb( vec3 surf_pos, vec3 surf_norm, vec2 dHdxy, float faceDirection ) {\\n\\t\\tvec3 vSigmaX = vec3( dFdx( surf_pos.x ), dFdx( surf_pos.y ), dFdx( surf_pos.z ) );\\n\\t\\tvec3 vSigmaY = vec3( dFdy( surf_pos.x ), dFdy( surf_pos.y ), dFdy( surf_pos.z ) );\\n\\t\\tvec3 vN = surf_norm;\\n\\t\\tvec3 R1 = cross( vSigmaY, vN );\\n\\t\\tvec3 R2 = cross( vN, vSigmaX );\\n\\t\\tfloat fDet = dot( vSigmaX, R1 ) * faceDirection;\\n\\t\\tvec3 vGrad = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 );\\n\\t\\treturn normalize( abs( fDet ) * surf_norm - vGrad );\\n\\t}\\n#endif\";\n\nvar clipping_planes_fragment = \"#if NUM_CLIPPING_PLANES > 0\\n\\tvec4 plane;\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < UNION_CLIPPING_PLANES; i ++ ) {\\n\\t\\tplane = clippingPlanes[ i ];\\n\\t\\tif ( dot( vClipPosition, plane.xyz ) > plane.w ) discard;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#if UNION_CLIPPING_PLANES < NUM_CLIPPING_PLANES\\n\\t\\tbool clipped = true;\\n\\t\\t#pragma unroll_loop_start\\n\\t\\tfor ( int i = UNION_CLIPPING_PLANES; i < NUM_CLIPPING_PLANES; i ++ ) {\\n\\t\\t\\tplane = clippingPlanes[ i ];\\n\\t\\t\\tclipped = ( dot( vClipPosition, plane.xyz ) > plane.w ) && clipped;\\n\\t\\t}\\n\\t\\t#pragma unroll_loop_end\\n\\t\\tif ( clipped ) discard;\\n\\t#endif\\n#endif\";\n\nvar clipping_planes_pars_fragment = \"#if NUM_CLIPPING_PLANES > 0\\n\\tvarying vec3 vClipPosition;\\n\\tuniform vec4 clippingPlanes[ NUM_CLIPPING_PLANES ];\\n#endif\";\n\nvar clipping_planes_pars_vertex = \"#if NUM_CLIPPING_PLANES > 0\\n\\tvarying vec3 vClipPosition;\\n#endif\";\n\nvar clipping_planes_vertex = \"#if NUM_CLIPPING_PLANES > 0\\n\\tvClipPosition = - mvPosition.xyz;\\n#endif\";\n\nvar color_fragment = \"#if defined( USE_COLOR_ALPHA )\\n\\tdiffuseColor *= vColor;\\n#elif defined( USE_COLOR )\\n\\tdiffuseColor.rgb *= vColor;\\n#endif\";\n\nvar color_pars_fragment = \"#if defined( USE_COLOR_ALPHA )\\n\\tvarying vec4 vColor;\\n#elif defined( USE_COLOR )\\n\\tvarying vec3 vColor;\\n#endif\";\n\nvar color_pars_vertex = \"#if defined( USE_COLOR_ALPHA )\\n\\tvarying vec4 vColor;\\n#elif defined( USE_COLOR ) || defined( USE_INSTANCING_COLOR )\\n\\tvarying vec3 vColor;\\n#endif\";\n\nvar color_vertex = \"#if defined( USE_COLOR_ALPHA )\\n\\tvColor = vec4( 1.0 );\\n#elif defined( USE_COLOR ) || defined( USE_INSTANCING_COLOR )\\n\\tvColor = vec3( 1.0 );\\n#endif\\n#ifdef USE_COLOR\\n\\tvColor *= color;\\n#endif\\n#ifdef USE_INSTANCING_COLOR\\n\\tvColor.xyz *= instanceColor.xyz;\\n#endif\";\n\nvar common = \"#define PI 3.141592653589793\\n#define PI2 6.283185307179586\\n#define PI_HALF 1.5707963267948966\\n#define RECIPROCAL_PI 0.3183098861837907\\n#define RECIPROCAL_PI2 0.15915494309189535\\n#define EPSILON 1e-6\\n#ifndef saturate\\n#define saturate( a ) clamp( a, 0.0, 1.0 )\\n#endif\\n#define whiteComplement( a ) ( 1.0 - saturate( a ) )\\nfloat pow2( const in float x ) { return x*x; }\\nvec3 pow2( const in vec3 x ) { return x*x; }\\nfloat pow3( const in float x ) { return x*x*x; }\\nfloat pow4( const in float x ) { float x2 = x*x; return x2*x2; }\\nfloat max3( const in vec3 v ) { return max( max( v.x, v.y ), v.z ); }\\nfloat average( const in vec3 color ) { return dot( color, vec3( 0.3333 ) ); }\\nhighp float rand( const in vec2 uv ) {\\n\\tconst highp float a = 12.9898, b = 78.233, c = 43758.5453;\\n\\thighp float dt = dot( uv.xy, vec2( a,b ) ), sn = mod( dt, PI );\\n\\treturn fract( sin( sn ) * c );\\n}\\n#ifdef HIGH_PRECISION\\n\\tfloat precisionSafeLength( vec3 v ) { return length( v ); }\\n#else\\n\\tfloat precisionSafeLength( vec3 v ) {\\n\\t\\tfloat maxComponent = max3( abs( v ) );\\n\\t\\treturn length( v / maxComponent ) * maxComponent;\\n\\t}\\n#endif\\nstruct IncidentLight {\\n\\tvec3 color;\\n\\tvec3 direction;\\n\\tbool visible;\\n};\\nstruct ReflectedLight {\\n\\tvec3 directDiffuse;\\n\\tvec3 directSpecular;\\n\\tvec3 indirectDiffuse;\\n\\tvec3 indirectSpecular;\\n};\\nstruct GeometricContext {\\n\\tvec3 position;\\n\\tvec3 normal;\\n\\tvec3 viewDir;\\n#ifdef USE_CLEARCOAT\\n\\tvec3 clearcoatNormal;\\n#endif\\n};\\nvec3 transformDirection( in vec3 dir, in mat4 matrix ) {\\n\\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );\\n}\\nvec3 inverseTransformDirection( in vec3 dir, in mat4 matrix ) {\\n\\treturn normalize( ( vec4( dir, 0.0 ) * matrix ).xyz );\\n}\\nmat3 transposeMat3( const in mat3 m ) {\\n\\tmat3 tmp;\\n\\ttmp[ 0 ] = vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x );\\n\\ttmp[ 1 ] = vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y );\\n\\ttmp[ 2 ] = vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z );\\n\\treturn tmp;\\n}\\nfloat linearToRelativeLuminance( const in vec3 color ) {\\n\\tvec3 weights = vec3( 0.2126, 0.7152, 0.0722 );\\n\\treturn dot( weights, color.rgb );\\n}\\nbool isPerspectiveMatrix( mat4 m ) {\\n\\treturn m[ 2 ][ 3 ] == - 1.0;\\n}\\nvec2 equirectUv( in vec3 dir ) {\\n\\tfloat u = atan( dir.z, dir.x ) * RECIPROCAL_PI2 + 0.5;\\n\\tfloat v = asin( clamp( dir.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\\n\\treturn vec2( u, v );\\n}\";\n\nvar cube_uv_reflection_fragment = \"#ifdef ENVMAP_TYPE_CUBE_UV\\n\\t#define cubeUV_minMipLevel 4.0\\n\\t#define cubeUV_minTileSize 16.0\\n\\tfloat getFace( vec3 direction ) {\\n\\t\\tvec3 absDirection = abs( direction );\\n\\t\\tfloat face = - 1.0;\\n\\t\\tif ( absDirection.x > absDirection.z ) {\\n\\t\\t\\tif ( absDirection.x > absDirection.y )\\n\\t\\t\\t\\tface = direction.x > 0.0 ? 0.0 : 3.0;\\n\\t\\t\\telse\\n\\t\\t\\t\\tface = direction.y > 0.0 ? 1.0 : 4.0;\\n\\t\\t} else {\\n\\t\\t\\tif ( absDirection.z > absDirection.y )\\n\\t\\t\\t\\tface = direction.z > 0.0 ? 2.0 : 5.0;\\n\\t\\t\\telse\\n\\t\\t\\t\\tface = direction.y > 0.0 ? 1.0 : 4.0;\\n\\t\\t}\\n\\t\\treturn face;\\n\\t}\\n\\tvec2 getUV( vec3 direction, float face ) {\\n\\t\\tvec2 uv;\\n\\t\\tif ( face == 0.0 ) {\\n\\t\\t\\tuv = vec2( direction.z, direction.y ) / abs( direction.x );\\n\\t\\t} else if ( face == 1.0 ) {\\n\\t\\t\\tuv = vec2( - direction.x, - direction.z ) / abs( direction.y );\\n\\t\\t} else if ( face == 2.0 ) {\\n\\t\\t\\tuv = vec2( - direction.x, direction.y ) / abs( direction.z );\\n\\t\\t} else if ( face == 3.0 ) {\\n\\t\\t\\tuv = vec2( - direction.z, direction.y ) / abs( direction.x );\\n\\t\\t} else if ( face == 4.0 ) {\\n\\t\\t\\tuv = vec2( - direction.x, direction.z ) / abs( direction.y );\\n\\t\\t} else {\\n\\t\\t\\tuv = vec2( direction.x, direction.y ) / abs( direction.z );\\n\\t\\t}\\n\\t\\treturn 0.5 * ( uv + 1.0 );\\n\\t}\\n\\tvec3 bilinearCubeUV( sampler2D envMap, vec3 direction, float mipInt ) {\\n\\t\\tfloat face = getFace( direction );\\n\\t\\tfloat filterInt = max( cubeUV_minMipLevel - mipInt, 0.0 );\\n\\t\\tmipInt = max( mipInt, cubeUV_minMipLevel );\\n\\t\\tfloat faceSize = exp2( mipInt );\\n\\t\\tvec2 uv = getUV( direction, face ) * ( faceSize - 2.0 ) + 1.0;\\n\\t\\tif ( face > 2.0 ) {\\n\\t\\t\\tuv.y += faceSize;\\n\\t\\t\\tface -= 3.0;\\n\\t\\t}\\n\\t\\tuv.x += face * faceSize;\\n\\t\\tuv.x += filterInt * 3.0 * cubeUV_minTileSize;\\n\\t\\tuv.y += 4.0 * ( exp2( CUBEUV_MAX_MIP ) - faceSize );\\n\\t\\tuv.x *= CUBEUV_TEXEL_WIDTH;\\n\\t\\tuv.y *= CUBEUV_TEXEL_HEIGHT;\\n\\t\\t#ifdef texture2DGradEXT\\n\\t\\t\\treturn texture2DGradEXT( envMap, uv, vec2( 0.0 ), vec2( 0.0 ) ).rgb;\\n\\t\\t#else\\n\\t\\t\\treturn texture2D( envMap, uv ).rgb;\\n\\t\\t#endif\\n\\t}\\n\\t#define r0 1.0\\n\\t#define v0 0.339\\n\\t#define m0 - 2.0\\n\\t#define r1 0.8\\n\\t#define v1 0.276\\n\\t#define m1 - 1.0\\n\\t#define r4 0.4\\n\\t#define v4 0.046\\n\\t#define m4 2.0\\n\\t#define r5 0.305\\n\\t#define v5 0.016\\n\\t#define m5 3.0\\n\\t#define r6 0.21\\n\\t#define v6 0.0038\\n\\t#define m6 4.0\\n\\tfloat roughnessToMip( float roughness ) {\\n\\t\\tfloat mip = 0.0;\\n\\t\\tif ( roughness >= r1 ) {\\n\\t\\t\\tmip = ( r0 - roughness ) * ( m1 - m0 ) / ( r0 - r1 ) + m0;\\n\\t\\t} else if ( roughness >= r4 ) {\\n\\t\\t\\tmip = ( r1 - roughness ) * ( m4 - m1 ) / ( r1 - r4 ) + m1;\\n\\t\\t} else if ( roughness >= r5 ) {\\n\\t\\t\\tmip = ( r4 - roughness ) * ( m5 - m4 ) / ( r4 - r5 ) + m4;\\n\\t\\t} else if ( roughness >= r6 ) {\\n\\t\\t\\tmip = ( r5 - roughness ) * ( m6 - m5 ) / ( r5 - r6 ) + m5;\\n\\t\\t} else {\\n\\t\\t\\tmip = - 2.0 * log2( 1.16 * roughness );\\t\\t}\\n\\t\\treturn mip;\\n\\t}\\n\\tvec4 textureCubeUV( sampler2D envMap, vec3 sampleDir, float roughness ) {\\n\\t\\tfloat mip = clamp( roughnessToMip( roughness ), m0, CUBEUV_MAX_MIP );\\n\\t\\tfloat mipF = fract( mip );\\n\\t\\tfloat mipInt = floor( mip );\\n\\t\\tvec3 color0 = bilinearCubeUV( envMap, sampleDir, mipInt );\\n\\t\\tif ( mipF == 0.0 ) {\\n\\t\\t\\treturn vec4( color0, 1.0 );\\n\\t\\t} else {\\n\\t\\t\\tvec3 color1 = bilinearCubeUV( envMap, sampleDir, mipInt + 1.0 );\\n\\t\\t\\treturn vec4( mix( color0, color1, mipF ), 1.0 );\\n\\t\\t}\\n\\t}\\n#endif\";\n\nvar defaultnormal_vertex = \"vec3 transformedNormal = objectNormal;\\n#ifdef USE_INSTANCING\\n\\tmat3 m = mat3( instanceMatrix );\\n\\ttransformedNormal /= vec3( dot( m[ 0 ], m[ 0 ] ), dot( m[ 1 ], m[ 1 ] ), dot( m[ 2 ], m[ 2 ] ) );\\n\\ttransformedNormal = m * transformedNormal;\\n#endif\\ntransformedNormal = normalMatrix * transformedNormal;\\n#ifdef FLIP_SIDED\\n\\ttransformedNormal = - transformedNormal;\\n#endif\\n#ifdef USE_TANGENT\\n\\tvec3 transformedTangent = ( modelViewMatrix * vec4( objectTangent, 0.0 ) ).xyz;\\n\\t#ifdef FLIP_SIDED\\n\\t\\ttransformedTangent = - transformedTangent;\\n\\t#endif\\n#endif\";\n\nvar displacementmap_pars_vertex = \"#ifdef USE_DISPLACEMENTMAP\\n\\tuniform sampler2D displacementMap;\\n\\tuniform float displacementScale;\\n\\tuniform float displacementBias;\\n#endif\";\n\nvar displacementmap_vertex = \"#ifdef USE_DISPLACEMENTMAP\\n\\ttransformed += normalize( objectNormal ) * ( texture2D( displacementMap, vUv ).x * displacementScale + displacementBias );\\n#endif\";\n\nvar emissivemap_fragment = \"#ifdef USE_EMISSIVEMAP\\n\\tvec4 emissiveColor = texture2D( emissiveMap, vUv );\\n\\ttotalEmissiveRadiance *= emissiveColor.rgb;\\n#endif\";\n\nvar emissivemap_pars_fragment = \"#ifdef USE_EMISSIVEMAP\\n\\tuniform sampler2D emissiveMap;\\n#endif\";\n\nvar encodings_fragment = \"gl_FragColor = linearToOutputTexel( gl_FragColor );\";\n\nvar encodings_pars_fragment = \"vec4 LinearToLinear( in vec4 value ) {\\n\\treturn value;\\n}\\nvec4 LinearTosRGB( in vec4 value ) {\\n\\treturn vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a );\\n}\";\n\nvar envmap_fragment = \"#ifdef USE_ENVMAP\\n\\t#ifdef ENV_WORLDPOS\\n\\t\\tvec3 cameraToFrag;\\n\\t\\tif ( isOrthographic ) {\\n\\t\\t\\tcameraToFrag = normalize( vec3( - viewMatrix[ 0 ][ 2 ], - viewMatrix[ 1 ][ 2 ], - viewMatrix[ 2 ][ 2 ] ) );\\n\\t\\t} else {\\n\\t\\t\\tcameraToFrag = normalize( vWorldPosition - cameraPosition );\\n\\t\\t}\\n\\t\\tvec3 worldNormal = inverseTransformDirection( normal, viewMatrix );\\n\\t\\t#ifdef ENVMAP_MODE_REFLECTION\\n\\t\\t\\tvec3 reflectVec = reflect( cameraToFrag, worldNormal );\\n\\t\\t#else\\n\\t\\t\\tvec3 reflectVec = refract( cameraToFrag, worldNormal, refractionRatio );\\n\\t\\t#endif\\n\\t#else\\n\\t\\tvec3 reflectVec = vReflect;\\n\\t#endif\\n\\t#ifdef ENVMAP_TYPE_CUBE\\n\\t\\tvec4 envColor = textureCube( envMap, vec3( flipEnvMap * reflectVec.x, reflectVec.yz ) );\\n\\t#elif defined( ENVMAP_TYPE_CUBE_UV )\\n\\t\\tvec4 envColor = textureCubeUV( envMap, reflectVec, 0.0 );\\n\\t#else\\n\\t\\tvec4 envColor = vec4( 0.0 );\\n\\t#endif\\n\\t#ifdef ENVMAP_BLENDING_MULTIPLY\\n\\t\\toutgoingLight = mix( outgoingLight, outgoingLight * envColor.xyz, specularStrength * reflectivity );\\n\\t#elif defined( ENVMAP_BLENDING_MIX )\\n\\t\\toutgoingLight = mix( outgoingLight, envColor.xyz, specularStrength * reflectivity );\\n\\t#elif defined( ENVMAP_BLENDING_ADD )\\n\\t\\toutgoingLight += envColor.xyz * specularStrength * reflectivity;\\n\\t#endif\\n#endif\";\n\nvar envmap_common_pars_fragment = \"#ifdef USE_ENVMAP\\n\\tuniform float envMapIntensity;\\n\\tuniform float flipEnvMap;\\n\\t#ifdef ENVMAP_TYPE_CUBE\\n\\t\\tuniform samplerCube envMap;\\n\\t#else\\n\\t\\tuniform sampler2D envMap;\\n\\t#endif\\n\\t\\n#endif\";\n\nvar envmap_pars_fragment = \"#ifdef USE_ENVMAP\\n\\tuniform float reflectivity;\\n\\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\\n\\t\\t#define ENV_WORLDPOS\\n\\t#endif\\n\\t#ifdef ENV_WORLDPOS\\n\\t\\tvarying vec3 vWorldPosition;\\n\\t\\tuniform float refractionRatio;\\n\\t#else\\n\\t\\tvarying vec3 vReflect;\\n\\t#endif\\n#endif\";\n\nvar envmap_pars_vertex = \"#ifdef USE_ENVMAP\\n\\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) ||defined( PHONG )\\n\\t\\t#define ENV_WORLDPOS\\n\\t#endif\\n\\t#ifdef ENV_WORLDPOS\\n\\t\\t\\n\\t\\tvarying vec3 vWorldPosition;\\n\\t#else\\n\\t\\tvarying vec3 vReflect;\\n\\t\\tuniform float refractionRatio;\\n\\t#endif\\n#endif\";\n\nvar envmap_vertex = \"#ifdef USE_ENVMAP\\n\\t#ifdef ENV_WORLDPOS\\n\\t\\tvWorldPosition = worldPosition.xyz;\\n\\t#else\\n\\t\\tvec3 cameraToVertex;\\n\\t\\tif ( isOrthographic ) {\\n\\t\\t\\tcameraToVertex = normalize( vec3( - viewMatrix[ 0 ][ 2 ], - viewMatrix[ 1 ][ 2 ], - viewMatrix[ 2 ][ 2 ] ) );\\n\\t\\t} else {\\n\\t\\t\\tcameraToVertex = normalize( worldPosition.xyz - cameraPosition );\\n\\t\\t}\\n\\t\\tvec3 worldNormal = inverseTransformDirection( transformedNormal, viewMatrix );\\n\\t\\t#ifdef ENVMAP_MODE_REFLECTION\\n\\t\\t\\tvReflect = reflect( cameraToVertex, worldNormal );\\n\\t\\t#else\\n\\t\\t\\tvReflect = refract( cameraToVertex, worldNormal, refractionRatio );\\n\\t\\t#endif\\n\\t#endif\\n#endif\";\n\nvar fog_vertex = \"#ifdef USE_FOG\\n\\tvFogDepth = - mvPosition.z;\\n#endif\";\n\nvar fog_pars_vertex = \"#ifdef USE_FOG\\n\\tvarying float vFogDepth;\\n#endif\";\n\nvar fog_fragment = \"#ifdef USE_FOG\\n\\t#ifdef FOG_EXP2\\n\\t\\tfloat fogFactor = 1.0 - exp( - fogDensity * fogDensity * vFogDepth * vFogDepth );\\n\\t#else\\n\\t\\tfloat fogFactor = smoothstep( fogNear, fogFar, vFogDepth );\\n\\t#endif\\n\\tgl_FragColor.rgb = mix( gl_FragColor.rgb, fogColor, fogFactor );\\n#endif\";\n\nvar fog_pars_fragment = \"#ifdef USE_FOG\\n\\tuniform vec3 fogColor;\\n\\tvarying float vFogDepth;\\n\\t#ifdef FOG_EXP2\\n\\t\\tuniform float fogDensity;\\n\\t#else\\n\\t\\tuniform float fogNear;\\n\\t\\tuniform float fogFar;\\n\\t#endif\\n#endif\";\n\nvar gradientmap_pars_fragment = \"#ifdef USE_GRADIENTMAP\\n\\tuniform sampler2D gradientMap;\\n#endif\\nvec3 getGradientIrradiance( vec3 normal, vec3 lightDirection ) {\\n\\tfloat dotNL = dot( normal, lightDirection );\\n\\tvec2 coord = vec2( dotNL * 0.5 + 0.5, 0.0 );\\n\\t#ifdef USE_GRADIENTMAP\\n\\t\\treturn vec3( texture2D( gradientMap, coord ).r );\\n\\t#else\\n\\t\\treturn ( coord.x < 0.7 ) ? vec3( 0.7 ) : vec3( 1.0 );\\n\\t#endif\\n}\";\n\nvar lightmap_fragment = \"#ifdef USE_LIGHTMAP\\n\\tvec4 lightMapTexel = texture2D( lightMap, vUv2 );\\n\\tvec3 lightMapIrradiance = lightMapTexel.rgb * lightMapIntensity;\\n\\treflectedLight.indirectDiffuse += lightMapIrradiance;\\n#endif\";\n\nvar lightmap_pars_fragment = \"#ifdef USE_LIGHTMAP\\n\\tuniform sampler2D lightMap;\\n\\tuniform float lightMapIntensity;\\n#endif\";\n\nvar lights_lambert_vertex = \"vec3 diffuse = vec3( 1.0 );\\nGeometricContext geometry;\\ngeometry.position = mvPosition.xyz;\\ngeometry.normal = normalize( transformedNormal );\\ngeometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( -mvPosition.xyz );\\nGeometricContext backGeometry;\\nbackGeometry.position = geometry.position;\\nbackGeometry.normal = -geometry.normal;\\nbackGeometry.viewDir = geometry.viewDir;\\nvLightFront = vec3( 0.0 );\\nvIndirectFront = vec3( 0.0 );\\n#ifdef DOUBLE_SIDED\\n\\tvLightBack = vec3( 0.0 );\\n\\tvIndirectBack = vec3( 0.0 );\\n#endif\\nIncidentLight directLight;\\nfloat dotNL;\\nvec3 directLightColor_Diffuse;\\nvIndirectFront += getAmbientLightIrradiance( ambientLightColor );\\nvIndirectFront += getLightProbeIrradiance( lightProbe, geometry.normal );\\n#ifdef DOUBLE_SIDED\\n\\tvIndirectBack += getAmbientLightIrradiance( ambientLightColor );\\n\\tvIndirectBack += getLightProbeIrradiance( lightProbe, backGeometry.normal );\\n#endif\\n#if NUM_POINT_LIGHTS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\\n\\t\\tgetPointLightInfo( pointLights[ i ], geometry, directLight );\\n\\t\\tdotNL = dot( geometry.normal, directLight.direction );\\n\\t\\tdirectLightColor_Diffuse = directLight.color;\\n\\t\\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\tvLightBack += saturate( - dotNL ) * directLightColor_Diffuse;\\n\\t\\t#endif\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if NUM_SPOT_LIGHTS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\\n\\t\\tgetSpotLightInfo( spotLights[ i ], geometry, directLight );\\n\\t\\tdotNL = dot( geometry.normal, directLight.direction );\\n\\t\\tdirectLightColor_Diffuse = directLight.color;\\n\\t\\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\tvLightBack += saturate( - dotNL ) * directLightColor_Diffuse;\\n\\t\\t#endif\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if NUM_DIR_LIGHTS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\\n\\t\\tgetDirectionalLightInfo( directionalLights[ i ], geometry, directLight );\\n\\t\\tdotNL = dot( geometry.normal, directLight.direction );\\n\\t\\tdirectLightColor_Diffuse = directLight.color;\\n\\t\\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\tvLightBack += saturate( - dotNL ) * directLightColor_Diffuse;\\n\\t\\t#endif\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if NUM_HEMI_LIGHTS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\\n\\t\\tvIndirectFront += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry.normal );\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\tvIndirectBack += getHemisphereLightIrradiance( hemisphereLights[ i ], backGeometry.normal );\\n\\t\\t#endif\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\";\n\nvar lights_pars_begin = \"uniform bool receiveShadow;\\nuniform vec3 ambientLightColor;\\nuniform vec3 lightProbe[ 9 ];\\nvec3 shGetIrradianceAt( in vec3 normal, in vec3 shCoefficients[ 9 ] ) {\\n\\tfloat x = normal.x, y = normal.y, z = normal.z;\\n\\tvec3 result = shCoefficients[ 0 ] * 0.886227;\\n\\tresult += shCoefficients[ 1 ] * 2.0 * 0.511664 * y;\\n\\tresult += shCoefficients[ 2 ] * 2.0 * 0.511664 * z;\\n\\tresult += shCoefficients[ 3 ] * 2.0 * 0.511664 * x;\\n\\tresult += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;\\n\\tresult += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;\\n\\tresult += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );\\n\\tresult += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;\\n\\tresult += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );\\n\\treturn result;\\n}\\nvec3 getLightProbeIrradiance( const in vec3 lightProbe[ 9 ], const in vec3 normal ) {\\n\\tvec3 worldNormal = inverseTransformDirection( normal, viewMatrix );\\n\\tvec3 irradiance = shGetIrradianceAt( worldNormal, lightProbe );\\n\\treturn irradiance;\\n}\\nvec3 getAmbientLightIrradiance( const in vec3 ambientLightColor ) {\\n\\tvec3 irradiance = ambientLightColor;\\n\\treturn irradiance;\\n}\\nfloat getDistanceAttenuation( const in float lightDistance, const in float cutoffDistance, const in float decayExponent ) {\\n\\t#if defined ( PHYSICALLY_CORRECT_LIGHTS )\\n\\t\\tfloat distanceFalloff = 1.0 / max( pow( lightDistance, decayExponent ), 0.01 );\\n\\t\\tif ( cutoffDistance > 0.0 ) {\\n\\t\\t\\tdistanceFalloff *= pow2( saturate( 1.0 - pow4( lightDistance / cutoffDistance ) ) );\\n\\t\\t}\\n\\t\\treturn distanceFalloff;\\n\\t#else\\n\\t\\tif ( cutoffDistance > 0.0 && decayExponent > 0.0 ) {\\n\\t\\t\\treturn pow( saturate( - lightDistance / cutoffDistance + 1.0 ), decayExponent );\\n\\t\\t}\\n\\t\\treturn 1.0;\\n\\t#endif\\n}\\nfloat getSpotAttenuation( const in float coneCosine, const in float penumbraCosine, const in float angleCosine ) {\\n\\treturn smoothstep( coneCosine, penumbraCosine, angleCosine );\\n}\\n#if NUM_DIR_LIGHTS > 0\\n\\tstruct DirectionalLight {\\n\\t\\tvec3 direction;\\n\\t\\tvec3 color;\\n\\t};\\n\\tuniform DirectionalLight directionalLights[ NUM_DIR_LIGHTS ];\\n\\tvoid getDirectionalLightInfo( const in DirectionalLight directionalLight, const in GeometricContext geometry, out IncidentLight light ) {\\n\\t\\tlight.color = directionalLight.color;\\n\\t\\tlight.direction = directionalLight.direction;\\n\\t\\tlight.visible = true;\\n\\t}\\n#endif\\n#if NUM_POINT_LIGHTS > 0\\n\\tstruct PointLight {\\n\\t\\tvec3 position;\\n\\t\\tvec3 color;\\n\\t\\tfloat distance;\\n\\t\\tfloat decay;\\n\\t};\\n\\tuniform PointLight pointLights[ NUM_POINT_LIGHTS ];\\n\\tvoid getPointLightInfo( const in PointLight pointLight, const in GeometricContext geometry, out IncidentLight light ) {\\n\\t\\tvec3 lVector = pointLight.position - geometry.position;\\n\\t\\tlight.direction = normalize( lVector );\\n\\t\\tfloat lightDistance = length( lVector );\\n\\t\\tlight.color = pointLight.color;\\n\\t\\tlight.color *= getDistanceAttenuation( lightDistance, pointLight.distance, pointLight.decay );\\n\\t\\tlight.visible = ( light.color != vec3( 0.0 ) );\\n\\t}\\n#endif\\n#if NUM_SPOT_LIGHTS > 0\\n\\tstruct SpotLight {\\n\\t\\tvec3 position;\\n\\t\\tvec3 direction;\\n\\t\\tvec3 color;\\n\\t\\tfloat distance;\\n\\t\\tfloat decay;\\n\\t\\tfloat coneCos;\\n\\t\\tfloat penumbraCos;\\n\\t};\\n\\tuniform SpotLight spotLights[ NUM_SPOT_LIGHTS ];\\n\\tvoid getSpotLightInfo( const in SpotLight spotLight, const in GeometricContext geometry, out IncidentLight light ) {\\n\\t\\tvec3 lVector = spotLight.position - geometry.position;\\n\\t\\tlight.direction = normalize( lVector );\\n\\t\\tfloat angleCos = dot( light.direction, spotLight.direction );\\n\\t\\tfloat spotAttenuation = getSpotAttenuation( spotLight.coneCos, spotLight.penumbraCos, angleCos );\\n\\t\\tif ( spotAttenuation > 0.0 ) {\\n\\t\\t\\tfloat lightDistance = length( lVector );\\n\\t\\t\\tlight.color = spotLight.color * spotAttenuation;\\n\\t\\t\\tlight.color *= getDistanceAttenuation( lightDistance, spotLight.distance, spotLight.decay );\\n\\t\\t\\tlight.visible = ( light.color != vec3( 0.0 ) );\\n\\t\\t} else {\\n\\t\\t\\tlight.color = vec3( 0.0 );\\n\\t\\t\\tlight.visible = false;\\n\\t\\t}\\n\\t}\\n#endif\\n#if NUM_RECT_AREA_LIGHTS > 0\\n\\tstruct RectAreaLight {\\n\\t\\tvec3 color;\\n\\t\\tvec3 position;\\n\\t\\tvec3 halfWidth;\\n\\t\\tvec3 halfHeight;\\n\\t};\\n\\tuniform sampler2D ltc_1;\\tuniform sampler2D ltc_2;\\n\\tuniform RectAreaLight rectAreaLights[ NUM_RECT_AREA_LIGHTS ];\\n#endif\\n#if NUM_HEMI_LIGHTS > 0\\n\\tstruct HemisphereLight {\\n\\t\\tvec3 direction;\\n\\t\\tvec3 skyColor;\\n\\t\\tvec3 groundColor;\\n\\t};\\n\\tuniform HemisphereLight hemisphereLights[ NUM_HEMI_LIGHTS ];\\n\\tvec3 getHemisphereLightIrradiance( const in HemisphereLight hemiLight, const in vec3 normal ) {\\n\\t\\tfloat dotNL = dot( normal, hemiLight.direction );\\n\\t\\tfloat hemiDiffuseWeight = 0.5 * dotNL + 0.5;\\n\\t\\tvec3 irradiance = mix( hemiLight.groundColor, hemiLight.skyColor, hemiDiffuseWeight );\\n\\t\\treturn irradiance;\\n\\t}\\n#endif\";\n\nvar envmap_physical_pars_fragment = \"#if defined( USE_ENVMAP )\\n\\tvec3 getIBLIrradiance( const in vec3 normal ) {\\n\\t\\t#if defined( ENVMAP_TYPE_CUBE_UV )\\n\\t\\t\\tvec3 worldNormal = inverseTransformDirection( normal, viewMatrix );\\n\\t\\t\\tvec4 envMapColor = textureCubeUV( envMap, worldNormal, 1.0 );\\n\\t\\t\\treturn PI * envMapColor.rgb * envMapIntensity;\\n\\t\\t#else\\n\\t\\t\\treturn vec3( 0.0 );\\n\\t\\t#endif\\n\\t}\\n\\tvec3 getIBLRadiance( const in vec3 viewDir, const in vec3 normal, const in float roughness ) {\\n\\t\\t#if defined( ENVMAP_TYPE_CUBE_UV )\\n\\t\\t\\tvec3 reflectVec = reflect( - viewDir, normal );\\n\\t\\t\\treflectVec = normalize( mix( reflectVec, normal, roughness * roughness) );\\n\\t\\t\\treflectVec = inverseTransformDirection( reflectVec, viewMatrix );\\n\\t\\t\\tvec4 envMapColor = textureCubeUV( envMap, reflectVec, roughness );\\n\\t\\t\\treturn envMapColor.rgb * envMapIntensity;\\n\\t\\t#else\\n\\t\\t\\treturn vec3( 0.0 );\\n\\t\\t#endif\\n\\t}\\n#endif\";\n\nvar lights_toon_fragment = \"ToonMaterial material;\\nmaterial.diffuseColor = diffuseColor.rgb;\";\n\nvar lights_toon_pars_fragment = \"varying vec3 vViewPosition;\\nstruct ToonMaterial {\\n\\tvec3 diffuseColor;\\n};\\nvoid RE_Direct_Toon( const in IncidentLight directLight, const in GeometricContext geometry, const in ToonMaterial material, inout ReflectedLight reflectedLight ) {\\n\\tvec3 irradiance = getGradientIrradiance( geometry.normal, directLight.direction ) * directLight.color;\\n\\treflectedLight.directDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\\n}\\nvoid RE_IndirectDiffuse_Toon( const in vec3 irradiance, const in GeometricContext geometry, const in ToonMaterial material, inout ReflectedLight reflectedLight ) {\\n\\treflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\\n}\\n#define RE_Direct\\t\\t\\t\\tRE_Direct_Toon\\n#define RE_IndirectDiffuse\\t\\tRE_IndirectDiffuse_Toon\\n#define Material_LightProbeLOD( material )\\t(0)\";\n\nvar lights_phong_fragment = \"BlinnPhongMaterial material;\\nmaterial.diffuseColor = diffuseColor.rgb;\\nmaterial.specularColor = specular;\\nmaterial.specularShininess = shininess;\\nmaterial.specularStrength = specularStrength;\";\n\nvar lights_phong_pars_fragment = \"varying vec3 vViewPosition;\\nstruct BlinnPhongMaterial {\\n\\tvec3 diffuseColor;\\n\\tvec3 specularColor;\\n\\tfloat specularShininess;\\n\\tfloat specularStrength;\\n};\\nvoid RE_Direct_BlinnPhong( const in IncidentLight directLight, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\\n\\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\\n\\tvec3 irradiance = dotNL * directLight.color;\\n\\treflectedLight.directDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\\n\\treflectedLight.directSpecular += irradiance * BRDF_BlinnPhong( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularShininess ) * material.specularStrength;\\n}\\nvoid RE_IndirectDiffuse_BlinnPhong( const in vec3 irradiance, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\\n\\treflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\\n}\\n#define RE_Direct\\t\\t\\t\\tRE_Direct_BlinnPhong\\n#define RE_IndirectDiffuse\\t\\tRE_IndirectDiffuse_BlinnPhong\\n#define Material_LightProbeLOD( material )\\t(0)\";\n\nvar lights_physical_fragment = \"PhysicalMaterial material;\\nmaterial.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor );\\nvec3 dxy = max( abs( dFdx( geometryNormal ) ), abs( dFdy( geometryNormal ) ) );\\nfloat geometryRoughness = max( max( dxy.x, dxy.y ), dxy.z );\\nmaterial.roughness = max( roughnessFactor, 0.0525 );material.roughness += geometryRoughness;\\nmaterial.roughness = min( material.roughness, 1.0 );\\n#ifdef IOR\\n\\t#ifdef SPECULAR\\n\\t\\tfloat specularIntensityFactor = specularIntensity;\\n\\t\\tvec3 specularColorFactor = specularColor;\\n\\t\\t#ifdef USE_SPECULARINTENSITYMAP\\n\\t\\t\\tspecularIntensityFactor *= texture2D( specularIntensityMap, vUv ).a;\\n\\t\\t#endif\\n\\t\\t#ifdef USE_SPECULARCOLORMAP\\n\\t\\t\\tspecularColorFactor *= texture2D( specularColorMap, vUv ).rgb;\\n\\t\\t#endif\\n\\t\\tmaterial.specularF90 = mix( specularIntensityFactor, 1.0, metalnessFactor );\\n\\t#else\\n\\t\\tfloat specularIntensityFactor = 1.0;\\n\\t\\tvec3 specularColorFactor = vec3( 1.0 );\\n\\t\\tmaterial.specularF90 = 1.0;\\n\\t#endif\\n\\tmaterial.specularColor = mix( min( pow2( ( ior - 1.0 ) / ( ior + 1.0 ) ) * specularColorFactor, vec3( 1.0 ) ) * specularIntensityFactor, diffuseColor.rgb, metalnessFactor );\\n#else\\n\\tmaterial.specularColor = mix( vec3( 0.04 ), diffuseColor.rgb, metalnessFactor );\\n\\tmaterial.specularF90 = 1.0;\\n#endif\\n#ifdef USE_CLEARCOAT\\n\\tmaterial.clearcoat = clearcoat;\\n\\tmaterial.clearcoatRoughness = clearcoatRoughness;\\n\\tmaterial.clearcoatF0 = vec3( 0.04 );\\n\\tmaterial.clearcoatF90 = 1.0;\\n\\t#ifdef USE_CLEARCOATMAP\\n\\t\\tmaterial.clearcoat *= texture2D( clearcoatMap, vUv ).x;\\n\\t#endif\\n\\t#ifdef USE_CLEARCOAT_ROUGHNESSMAP\\n\\t\\tmaterial.clearcoatRoughness *= texture2D( clearcoatRoughnessMap, vUv ).y;\\n\\t#endif\\n\\tmaterial.clearcoat = saturate( material.clearcoat );\\tmaterial.clearcoatRoughness = max( material.clearcoatRoughness, 0.0525 );\\n\\tmaterial.clearcoatRoughness += geometryRoughness;\\n\\tmaterial.clearcoatRoughness = min( material.clearcoatRoughness, 1.0 );\\n#endif\\n#ifdef USE_IRIDESCENCE\\n\\tmaterial.iridescence = iridescence;\\n\\tmaterial.iridescenceIOR = iridescenceIOR;\\n\\t#ifdef USE_IRIDESCENCEMAP\\n\\t\\tmaterial.iridescence *= texture2D( iridescenceMap, vUv ).r;\\n\\t#endif\\n\\t#ifdef USE_IRIDESCENCE_THICKNESSMAP\\n\\t\\tmaterial.iridescenceThickness = (iridescenceThicknessMaximum - iridescenceThicknessMinimum) * texture2D( iridescenceThicknessMap, vUv ).g + iridescenceThicknessMinimum;\\n\\t#else\\n\\t\\tmaterial.iridescenceThickness = iridescenceThicknessMaximum;\\n\\t#endif\\n#endif\\n#ifdef USE_SHEEN\\n\\tmaterial.sheenColor = sheenColor;\\n\\t#ifdef USE_SHEENCOLORMAP\\n\\t\\tmaterial.sheenColor *= texture2D( sheenColorMap, vUv ).rgb;\\n\\t#endif\\n\\tmaterial.sheenRoughness = clamp( sheenRoughness, 0.07, 1.0 );\\n\\t#ifdef USE_SHEENROUGHNESSMAP\\n\\t\\tmaterial.sheenRoughness *= texture2D( sheenRoughnessMap, vUv ).a;\\n\\t#endif\\n#endif\";\n\nvar lights_physical_pars_fragment = \"struct PhysicalMaterial {\\n\\tvec3 diffuseColor;\\n\\tfloat roughness;\\n\\tvec3 specularColor;\\n\\tfloat specularF90;\\n\\t#ifdef USE_CLEARCOAT\\n\\t\\tfloat clearcoat;\\n\\t\\tfloat clearcoatRoughness;\\n\\t\\tvec3 clearcoatF0;\\n\\t\\tfloat clearcoatF90;\\n\\t#endif\\n\\t#ifdef USE_IRIDESCENCE\\n\\t\\tfloat iridescence;\\n\\t\\tfloat iridescenceIOR;\\n\\t\\tfloat iridescenceThickness;\\n\\t\\tvec3 iridescenceFresnel;\\n\\t\\tvec3 iridescenceF0;\\n\\t#endif\\n\\t#ifdef USE_SHEEN\\n\\t\\tvec3 sheenColor;\\n\\t\\tfloat sheenRoughness;\\n\\t#endif\\n};\\nvec3 clearcoatSpecular = vec3( 0.0 );\\nvec3 sheenSpecular = vec3( 0.0 );\\nfloat IBLSheenBRDF( const in vec3 normal, const in vec3 viewDir, const in float roughness) {\\n\\tfloat dotNV = saturate( dot( normal, viewDir ) );\\n\\tfloat r2 = roughness * roughness;\\n\\tfloat a = roughness < 0.25 ? -339.2 * r2 + 161.4 * roughness - 25.9 : -8.48 * r2 + 14.3 * roughness - 9.95;\\n\\tfloat b = roughness < 0.25 ? 44.0 * r2 - 23.7 * roughness + 3.26 : 1.97 * r2 - 3.27 * roughness + 0.72;\\n\\tfloat DG = exp( a * dotNV + b ) + ( roughness < 0.25 ? 0.0 : 0.1 * ( roughness - 0.25 ) );\\n\\treturn saturate( DG * RECIPROCAL_PI );\\n}\\nvec2 DFGApprox( const in vec3 normal, const in vec3 viewDir, const in float roughness ) {\\n\\tfloat dotNV = saturate( dot( normal, viewDir ) );\\n\\tconst vec4 c0 = vec4( - 1, - 0.0275, - 0.572, 0.022 );\\n\\tconst vec4 c1 = vec4( 1, 0.0425, 1.04, - 0.04 );\\n\\tvec4 r = roughness * c0 + c1;\\n\\tfloat a004 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\\n\\tvec2 fab = vec2( - 1.04, 1.04 ) * a004 + r.zw;\\n\\treturn fab;\\n}\\nvec3 EnvironmentBRDF( const in vec3 normal, const in vec3 viewDir, const in vec3 specularColor, const in float specularF90, const in float roughness ) {\\n\\tvec2 fab = DFGApprox( normal, viewDir, roughness );\\n\\treturn specularColor * fab.x + specularF90 * fab.y;\\n}\\n#ifdef USE_IRIDESCENCE\\nvoid computeMultiscatteringIridescence( const in vec3 normal, const in vec3 viewDir, const in vec3 specularColor, const in float specularF90, const in float iridescence, const in vec3 iridescenceF0, const in float roughness, inout vec3 singleScatter, inout vec3 multiScatter ) {\\n#else\\nvoid computeMultiscattering( const in vec3 normal, const in vec3 viewDir, const in vec3 specularColor, const in float specularF90, const in float roughness, inout vec3 singleScatter, inout vec3 multiScatter ) {\\n#endif\\n\\tvec2 fab = DFGApprox( normal, viewDir, roughness );\\n\\t#ifdef USE_IRIDESCENCE\\n\\t\\tvec3 Fr = mix( specularColor, iridescenceF0, iridescence );\\n\\t#else\\n\\t\\tvec3 Fr = specularColor;\\n\\t#endif\\n\\tvec3 FssEss = Fr * fab.x + specularF90 * fab.y;\\n\\tfloat Ess = fab.x + fab.y;\\n\\tfloat Ems = 1.0 - Ess;\\n\\tvec3 Favg = Fr + ( 1.0 - Fr ) * 0.047619;\\tvec3 Fms = FssEss * Favg / ( 1.0 - Ems * Favg );\\n\\tsingleScatter += FssEss;\\n\\tmultiScatter += Fms * Ems;\\n}\\n#if NUM_RECT_AREA_LIGHTS > 0\\n\\tvoid RE_Direct_RectArea_Physical( const in RectAreaLight rectAreaLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\\n\\t\\tvec3 normal = geometry.normal;\\n\\t\\tvec3 viewDir = geometry.viewDir;\\n\\t\\tvec3 position = geometry.position;\\n\\t\\tvec3 lightPos = rectAreaLight.position;\\n\\t\\tvec3 halfWidth = rectAreaLight.halfWidth;\\n\\t\\tvec3 halfHeight = rectAreaLight.halfHeight;\\n\\t\\tvec3 lightColor = rectAreaLight.color;\\n\\t\\tfloat roughness = material.roughness;\\n\\t\\tvec3 rectCoords[ 4 ];\\n\\t\\trectCoords[ 0 ] = lightPos + halfWidth - halfHeight;\\t\\trectCoords[ 1 ] = lightPos - halfWidth - halfHeight;\\n\\t\\trectCoords[ 2 ] = lightPos - halfWidth + halfHeight;\\n\\t\\trectCoords[ 3 ] = lightPos + halfWidth + halfHeight;\\n\\t\\tvec2 uv = LTC_Uv( normal, viewDir, roughness );\\n\\t\\tvec4 t1 = texture2D( ltc_1, uv );\\n\\t\\tvec4 t2 = texture2D( ltc_2, uv );\\n\\t\\tmat3 mInv = mat3(\\n\\t\\t\\tvec3( t1.x, 0, t1.y ),\\n\\t\\t\\tvec3(\t\t0, 1,\t\t0 ),\\n\\t\\t\\tvec3( t1.z, 0, t1.w )\\n\\t\\t);\\n\\t\\tvec3 fresnel = ( material.specularColor * t2.x + ( vec3( 1.0 ) - material.specularColor ) * t2.y );\\n\\t\\treflectedLight.directSpecular += lightColor * fresnel * LTC_Evaluate( normal, viewDir, position, mInv, rectCoords );\\n\\t\\treflectedLight.directDiffuse += lightColor * material.diffuseColor * LTC_Evaluate( normal, viewDir, position, mat3( 1.0 ), rectCoords );\\n\\t}\\n#endif\\nvoid RE_Direct_Physical( const in IncidentLight directLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\\n\\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\\n\\tvec3 irradiance = dotNL * directLight.color;\\n\\t#ifdef USE_CLEARCOAT\\n\\t\\tfloat dotNLcc = saturate( dot( geometry.clearcoatNormal, directLight.direction ) );\\n\\t\\tvec3 ccIrradiance = dotNLcc * directLight.color;\\n\\t\\tclearcoatSpecular += ccIrradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.clearcoatNormal, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness );\\n\\t#endif\\n\\t#ifdef USE_SHEEN\\n\\t\\tsheenSpecular += irradiance * BRDF_Sheen( directLight.direction, geometry.viewDir, geometry.normal, material.sheenColor, material.sheenRoughness );\\n\\t#endif\\n\\t#ifdef USE_IRIDESCENCE\\n\\t\\treflectedLight.directSpecular += irradiance * BRDF_GGX_Iridescence( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness );\\n\\t#else\\n\\t\\treflectedLight.directSpecular += irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.roughness );\\n\\t#endif\\n\\treflectedLight.directDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\\n}\\nvoid RE_IndirectDiffuse_Physical( const in vec3 irradiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\\n\\treflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\\n}\\nvoid RE_IndirectSpecular_Physical( const in vec3 radiance, const in vec3 irradiance, const in vec3 clearcoatRadiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight) {\\n\\t#ifdef USE_CLEARCOAT\\n\\t\\tclearcoatSpecular += clearcoatRadiance * EnvironmentBRDF( geometry.clearcoatNormal, geometry.viewDir, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness );\\n\\t#endif\\n\\t#ifdef USE_SHEEN\\n\\t\\tsheenSpecular += irradiance * material.sheenColor * IBLSheenBRDF( geometry.normal, geometry.viewDir, material.sheenRoughness );\\n\\t#endif\\n\\tvec3 singleScattering = vec3( 0.0 );\\n\\tvec3 multiScattering = vec3( 0.0 );\\n\\tvec3 cosineWeightedIrradiance = irradiance * RECIPROCAL_PI;\\n\\t#ifdef USE_IRIDESCENCE\\n\\t\\tcomputeMultiscatteringIridescence( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness, singleScattering, multiScattering );\\n\\t#else\\n\\t\\tcomputeMultiscattering( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.roughness, singleScattering, multiScattering );\\n\\t#endif\\n\\tvec3 totalScattering = singleScattering + multiScattering;\\n\\tvec3 diffuse = material.diffuseColor * ( 1.0 - max( max( totalScattering.r, totalScattering.g ), totalScattering.b ) );\\n\\treflectedLight.indirectSpecular += radiance * singleScattering;\\n\\treflectedLight.indirectSpecular += multiScattering * cosineWeightedIrradiance;\\n\\treflectedLight.indirectDiffuse += diffuse * cosineWeightedIrradiance;\\n}\\n#define RE_Direct\\t\\t\\t\\tRE_Direct_Physical\\n#define RE_Direct_RectArea\\t\\tRE_Direct_RectArea_Physical\\n#define RE_IndirectDiffuse\\t\\tRE_IndirectDiffuse_Physical\\n#define RE_IndirectSpecular\\t\\tRE_IndirectSpecular_Physical\\nfloat computeSpecularOcclusion( const in float dotNV, const in float ambientOcclusion, const in float roughness ) {\\n\\treturn saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion );\\n}\";\n\nvar lights_fragment_begin = \"\\nGeometricContext geometry;\\ngeometry.position = - vViewPosition;\\ngeometry.normal = normal;\\ngeometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( vViewPosition );\\n#ifdef USE_CLEARCOAT\\n\\tgeometry.clearcoatNormal = clearcoatNormal;\\n#endif\\n#ifdef USE_IRIDESCENCE\\nfloat dotNVi = saturate( dot( normal, geometry.viewDir ) );\\nif ( material.iridescenceThickness == 0.0 ) {\\n\\tmaterial.iridescence = 0.0;\\n} else {\\n\\tmaterial.iridescence = saturate( material.iridescence );\\n}\\nif ( material.iridescence > 0.0 ) {\\n\\tmaterial.iridescenceFresnel = evalIridescence( 1.0, material.iridescenceIOR, dotNVi, material.iridescenceThickness, material.specularColor );\\n\\tmaterial.iridescenceF0 = Schlick_to_F0( material.iridescenceFresnel, 1.0, dotNVi );\\n}\\n#endif\\nIncidentLight directLight;\\n#if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )\\n\\tPointLight pointLight;\\n\\t#if defined( USE_SHADOWMAP ) && NUM_POINT_LIGHT_SHADOWS > 0\\n\\tPointLightShadow pointLightShadow;\\n\\t#endif\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\\n\\t\\tpointLight = pointLights[ i ];\\n\\t\\tgetPointLightInfo( pointLight, geometry, directLight );\\n\\t\\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_POINT_LIGHT_SHADOWS )\\n\\t\\tpointLightShadow = pointLightShadows[ i ];\\n\\t\\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getPointShadow( pointShadowMap[ i ], pointLightShadow.shadowMapSize, pointLightShadow.shadowBias, pointLightShadow.shadowRadius, vPointShadowCoord[ i ], pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar ) : 1.0;\\n\\t\\t#endif\\n\\t\\tRE_Direct( directLight, geometry, material, reflectedLight );\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )\\n\\tSpotLight spotLight;\\n\\t#if defined( USE_SHADOWMAP ) && NUM_SPOT_LIGHT_SHADOWS > 0\\n\\tSpotLightShadow spotLightShadow;\\n\\t#endif\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\\n\\t\\tspotLight = spotLights[ i ];\\n\\t\\tgetSpotLightInfo( spotLight, geometry, directLight );\\n\\t\\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_SPOT_LIGHT_SHADOWS )\\n\\t\\tspotLightShadow = spotLightShadows[ i ];\\n\\t\\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( spotShadowMap[ i ], spotLightShadow.shadowMapSize, spotLightShadow.shadowBias, spotLightShadow.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\\n\\t\\t#endif\\n\\t\\tRE_Direct( directLight, geometry, material, reflectedLight );\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct )\\n\\tDirectionalLight directionalLight;\\n\\t#if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\\n\\tDirectionalLightShadow directionalLightShadow;\\n\\t#endif\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\\n\\t\\tdirectionalLight = directionalLights[ i ];\\n\\t\\tgetDirectionalLightInfo( directionalLight, geometry, directLight );\\n\\t\\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )\\n\\t\\tdirectionalLightShadow = directionalLightShadows[ i ];\\n\\t\\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\\n\\t\\t#endif\\n\\t\\tRE_Direct( directLight, geometry, material, reflectedLight );\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )\\n\\tRectAreaLight rectAreaLight;\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {\\n\\t\\trectAreaLight = rectAreaLights[ i ];\\n\\t\\tRE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if defined( RE_IndirectDiffuse )\\n\\tvec3 iblIrradiance = vec3( 0.0 );\\n\\tvec3 irradiance = getAmbientLightIrradiance( ambientLightColor );\\n\\tirradiance += getLightProbeIrradiance( lightProbe, geometry.normal );\\n\\t#if ( NUM_HEMI_LIGHTS > 0 )\\n\\t\\t#pragma unroll_loop_start\\n\\t\\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\\n\\t\\t\\tirradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry.normal );\\n\\t\\t}\\n\\t\\t#pragma unroll_loop_end\\n\\t#endif\\n#endif\\n#if defined( RE_IndirectSpecular )\\n\\tvec3 radiance = vec3( 0.0 );\\n\\tvec3 clearcoatRadiance = vec3( 0.0 );\\n#endif\";\n\nvar lights_fragment_maps = \"#if defined( RE_IndirectDiffuse )\\n\\t#ifdef USE_LIGHTMAP\\n\\t\\tvec4 lightMapTexel = texture2D( lightMap, vUv2 );\\n\\t\\tvec3 lightMapIrradiance = lightMapTexel.rgb * lightMapIntensity;\\n\\t\\tirradiance += lightMapIrradiance;\\n\\t#endif\\n\\t#if defined( USE_ENVMAP ) && defined( STANDARD ) && defined( ENVMAP_TYPE_CUBE_UV )\\n\\t\\tiblIrradiance += getIBLIrradiance( geometry.normal );\\n\\t#endif\\n#endif\\n#if defined( USE_ENVMAP ) && defined( RE_IndirectSpecular )\\n\\tradiance += getIBLRadiance( geometry.viewDir, geometry.normal, material.roughness );\\n\\t#ifdef USE_CLEARCOAT\\n\\t\\tclearcoatRadiance += getIBLRadiance( geometry.viewDir, geometry.clearcoatNormal, material.clearcoatRoughness );\\n\\t#endif\\n#endif\";\n\nvar lights_fragment_end = \"#if defined( RE_IndirectDiffuse )\\n\\tRE_IndirectDiffuse( irradiance, geometry, material, reflectedLight );\\n#endif\\n#if defined( RE_IndirectSpecular )\\n\\tRE_IndirectSpecular( radiance, iblIrradiance, clearcoatRadiance, geometry, material, reflectedLight );\\n#endif\";\n\nvar logdepthbuf_fragment = \"#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\\n\\tgl_FragDepthEXT = vIsPerspective == 0.0 ? gl_FragCoord.z : log2( vFragDepth ) * logDepthBufFC * 0.5;\\n#endif\";\n\nvar logdepthbuf_pars_fragment = \"#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\\n\\tuniform float logDepthBufFC;\\n\\tvarying float vFragDepth;\\n\\tvarying float vIsPerspective;\\n#endif\";\n\nvar logdepthbuf_pars_vertex = \"#ifdef USE_LOGDEPTHBUF\\n\\t#ifdef USE_LOGDEPTHBUF_EXT\\n\\t\\tvarying float vFragDepth;\\n\\t\\tvarying float vIsPerspective;\\n\\t#else\\n\\t\\tuniform float logDepthBufFC;\\n\\t#endif\\n#endif\";\n\nvar logdepthbuf_vertex = \"#ifdef USE_LOGDEPTHBUF\\n\\t#ifdef USE_LOGDEPTHBUF_EXT\\n\\t\\tvFragDepth = 1.0 + gl_Position.w;\\n\\t\\tvIsPerspective = float( isPerspectiveMatrix( projectionMatrix ) );\\n\\t#else\\n\\t\\tif ( isPerspectiveMatrix( projectionMatrix ) ) {\\n\\t\\t\\tgl_Position.z = log2( max( EPSILON, gl_Position.w + 1.0 ) ) * logDepthBufFC - 1.0;\\n\\t\\t\\tgl_Position.z *= gl_Position.w;\\n\\t\\t}\\n\\t#endif\\n#endif\";\n\nvar map_fragment = \"#ifdef USE_MAP\\n\\tvec4 sampledDiffuseColor = texture2D( map, vUv );\\n\\t#ifdef DECODE_VIDEO_TEXTURE\\n\\t\\tsampledDiffuseColor = vec4( mix( pow( sampledDiffuseColor.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), sampledDiffuseColor.rgb * 0.0773993808, vec3( lessThanEqual( sampledDiffuseColor.rgb, vec3( 0.04045 ) ) ) ), sampledDiffuseColor.w );\\n\\t#endif\\n\\tdiffuseColor *= sampledDiffuseColor;\\n#endif\";\n\nvar map_pars_fragment = \"#ifdef USE_MAP\\n\\tuniform sampler2D map;\\n#endif\";\n\nvar map_particle_fragment = \"#if defined( USE_MAP ) || defined( USE_ALPHAMAP )\\n\\tvec2 uv = ( uvTransform * vec3( gl_PointCoord.x, 1.0 - gl_PointCoord.y, 1 ) ).xy;\\n#endif\\n#ifdef USE_MAP\\n\\tdiffuseColor *= texture2D( map, uv );\\n#endif\\n#ifdef USE_ALPHAMAP\\n\\tdiffuseColor.a *= texture2D( alphaMap, uv ).g;\\n#endif\";\n\nvar map_particle_pars_fragment = \"#if defined( USE_MAP ) || defined( USE_ALPHAMAP )\\n\\tuniform mat3 uvTransform;\\n#endif\\n#ifdef USE_MAP\\n\\tuniform sampler2D map;\\n#endif\\n#ifdef USE_ALPHAMAP\\n\\tuniform sampler2D alphaMap;\\n#endif\";\n\nvar metalnessmap_fragment = \"float metalnessFactor = metalness;\\n#ifdef USE_METALNESSMAP\\n\\tvec4 texelMetalness = texture2D( metalnessMap, vUv );\\n\\tmetalnessFactor *= texelMetalness.b;\\n#endif\";\n\nvar metalnessmap_pars_fragment = \"#ifdef USE_METALNESSMAP\\n\\tuniform sampler2D metalnessMap;\\n#endif\";\n\nvar morphcolor_vertex = \"#if defined( USE_MORPHCOLORS ) && defined( MORPHTARGETS_TEXTURE )\\n\\tvColor *= morphTargetBaseInfluence;\\n\\tfor ( int i = 0; i < MORPHTARGETS_COUNT; i ++ ) {\\n\\t\\t#if defined( USE_COLOR_ALPHA )\\n\\t\\t\\tif ( morphTargetInfluences[ i ] != 0.0 ) vColor += getMorph( gl_VertexID, i, 2 ) * morphTargetInfluences[ i ];\\n\\t\\t#elif defined( USE_COLOR )\\n\\t\\t\\tif ( morphTargetInfluences[ i ] != 0.0 ) vColor += getMorph( gl_VertexID, i, 2 ).rgb * morphTargetInfluences[ i ];\\n\\t\\t#endif\\n\\t}\\n#endif\";\n\nvar morphnormal_vertex = \"#ifdef USE_MORPHNORMALS\\n\\tobjectNormal *= morphTargetBaseInfluence;\\n\\t#ifdef MORPHTARGETS_TEXTURE\\n\\t\\tfor ( int i = 0; i < MORPHTARGETS_COUNT; i ++ ) {\\n\\t\\t\\tif ( morphTargetInfluences[ i ] != 0.0 ) objectNormal += getMorph( gl_VertexID, i, 1 ).xyz * morphTargetInfluences[ i ];\\n\\t\\t}\\n\\t#else\\n\\t\\tobjectNormal += morphNormal0 * morphTargetInfluences[ 0 ];\\n\\t\\tobjectNormal += morphNormal1 * morphTargetInfluences[ 1 ];\\n\\t\\tobjectNormal += morphNormal2 * morphTargetInfluences[ 2 ];\\n\\t\\tobjectNormal += morphNormal3 * morphTargetInfluences[ 3 ];\\n\\t#endif\\n#endif\";\n\nvar morphtarget_pars_vertex = \"#ifdef USE_MORPHTARGETS\\n\\tuniform float morphTargetBaseInfluence;\\n\\t#ifdef MORPHTARGETS_TEXTURE\\n\\t\\tuniform float morphTargetInfluences[ MORPHTARGETS_COUNT ];\\n\\t\\tuniform sampler2DArray morphTargetsTexture;\\n\\t\\tuniform ivec2 morphTargetsTextureSize;\\n\\t\\tvec4 getMorph( const in int vertexIndex, const in int morphTargetIndex, const in int offset ) {\\n\\t\\t\\tint texelIndex = vertexIndex * MORPHTARGETS_TEXTURE_STRIDE + offset;\\n\\t\\t\\tint y = texelIndex / morphTargetsTextureSize.x;\\n\\t\\t\\tint x = texelIndex - y * morphTargetsTextureSize.x;\\n\\t\\t\\tivec3 morphUV = ivec3( x, y, morphTargetIndex );\\n\\t\\t\\treturn texelFetch( morphTargetsTexture, morphUV, 0 );\\n\\t\\t}\\n\\t#else\\n\\t\\t#ifndef USE_MORPHNORMALS\\n\\t\\t\\tuniform float morphTargetInfluences[ 8 ];\\n\\t\\t#else\\n\\t\\t\\tuniform float morphTargetInfluences[ 4 ];\\n\\t\\t#endif\\n\\t#endif\\n#endif\";\n\nvar morphtarget_vertex = \"#ifdef USE_MORPHTARGETS\\n\\ttransformed *= morphTargetBaseInfluence;\\n\\t#ifdef MORPHTARGETS_TEXTURE\\n\\t\\tfor ( int i = 0; i < MORPHTARGETS_COUNT; i ++ ) {\\n\\t\\t\\tif ( morphTargetInfluences[ i ] != 0.0 ) transformed += getMorph( gl_VertexID, i, 0 ).xyz * morphTargetInfluences[ i ];\\n\\t\\t}\\n\\t#else\\n\\t\\ttransformed += morphTarget0 * morphTargetInfluences[ 0 ];\\n\\t\\ttransformed += morphTarget1 * morphTargetInfluences[ 1 ];\\n\\t\\ttransformed += morphTarget2 * morphTargetInfluences[ 2 ];\\n\\t\\ttransformed += morphTarget3 * morphTargetInfluences[ 3 ];\\n\\t\\t#ifndef USE_MORPHNORMALS\\n\\t\\t\\ttransformed += morphTarget4 * morphTargetInfluences[ 4 ];\\n\\t\\t\\ttransformed += morphTarget5 * morphTargetInfluences[ 5 ];\\n\\t\\t\\ttransformed += morphTarget6 * morphTargetInfluences[ 6 ];\\n\\t\\t\\ttransformed += morphTarget7 * morphTargetInfluences[ 7 ];\\n\\t\\t#endif\\n\\t#endif\\n#endif\";\n\nvar normal_fragment_begin = \"float faceDirection = gl_FrontFacing ? 1.0 : - 1.0;\\n#ifdef FLAT_SHADED\\n\\tvec3 fdx = vec3( dFdx( vViewPosition.x ), dFdx( vViewPosition.y ), dFdx( vViewPosition.z ) );\\n\\tvec3 fdy = vec3( dFdy( vViewPosition.x ), dFdy( vViewPosition.y ), dFdy( vViewPosition.z ) );\\n\\tvec3 normal = normalize( cross( fdx, fdy ) );\\n#else\\n\\tvec3 normal = normalize( vNormal );\\n\\t#ifdef DOUBLE_SIDED\\n\\t\\tnormal = normal * faceDirection;\\n\\t#endif\\n\\t#ifdef USE_TANGENT\\n\\t\\tvec3 tangent = normalize( vTangent );\\n\\t\\tvec3 bitangent = normalize( vBitangent );\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\ttangent = tangent * faceDirection;\\n\\t\\t\\tbitangent = bitangent * faceDirection;\\n\\t\\t#endif\\n\\t\\t#if defined( TANGENTSPACE_NORMALMAP ) || defined( USE_CLEARCOAT_NORMALMAP )\\n\\t\\t\\tmat3 vTBN = mat3( tangent, bitangent, normal );\\n\\t\\t#endif\\n\\t#endif\\n#endif\\nvec3 geometryNormal = normal;\";\n\nvar normal_fragment_maps = \"#ifdef OBJECTSPACE_NORMALMAP\\n\\tnormal = texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\\n\\t#ifdef FLIP_SIDED\\n\\t\\tnormal = - normal;\\n\\t#endif\\n\\t#ifdef DOUBLE_SIDED\\n\\t\\tnormal = normal * faceDirection;\\n\\t#endif\\n\\tnormal = normalize( normalMatrix * normal );\\n#elif defined( TANGENTSPACE_NORMALMAP )\\n\\tvec3 mapN = texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\\n\\tmapN.xy *= normalScale;\\n\\t#ifdef USE_TANGENT\\n\\t\\tnormal = normalize( vTBN * mapN );\\n\\t#else\\n\\t\\tnormal = perturbNormal2Arb( - vViewPosition, normal, mapN, faceDirection );\\n\\t#endif\\n#elif defined( USE_BUMPMAP )\\n\\tnormal = perturbNormalArb( - vViewPosition, normal, dHdxy_fwd(), faceDirection );\\n#endif\";\n\nvar normal_pars_fragment = \"#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n\\t#ifdef USE_TANGENT\\n\\t\\tvarying vec3 vTangent;\\n\\t\\tvarying vec3 vBitangent;\\n\\t#endif\\n#endif\";\n\nvar normal_pars_vertex = \"#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n\\t#ifdef USE_TANGENT\\n\\t\\tvarying vec3 vTangent;\\n\\t\\tvarying vec3 vBitangent;\\n\\t#endif\\n#endif\";\n\nvar normal_vertex = \"#ifndef FLAT_SHADED\\n\\tvNormal = normalize( transformedNormal );\\n\\t#ifdef USE_TANGENT\\n\\t\\tvTangent = normalize( transformedTangent );\\n\\t\\tvBitangent = normalize( cross( vNormal, vTangent ) * tangent.w );\\n\\t#endif\\n#endif\";\n\nvar normalmap_pars_fragment = \"#ifdef USE_NORMALMAP\\n\\tuniform sampler2D normalMap;\\n\\tuniform vec2 normalScale;\\n#endif\\n#ifdef OBJECTSPACE_NORMALMAP\\n\\tuniform mat3 normalMatrix;\\n#endif\\n#if ! defined ( USE_TANGENT ) && ( defined ( TANGENTSPACE_NORMALMAP ) || defined ( USE_CLEARCOAT_NORMALMAP ) )\\n\\tvec3 perturbNormal2Arb( vec3 eye_pos, vec3 surf_norm, vec3 mapN, float faceDirection ) {\\n\\t\\tvec3 q0 = vec3( dFdx( eye_pos.x ), dFdx( eye_pos.y ), dFdx( eye_pos.z ) );\\n\\t\\tvec3 q1 = vec3( dFdy( eye_pos.x ), dFdy( eye_pos.y ), dFdy( eye_pos.z ) );\\n\\t\\tvec2 st0 = dFdx( vUv.st );\\n\\t\\tvec2 st1 = dFdy( vUv.st );\\n\\t\\tvec3 N = surf_norm;\\n\\t\\tvec3 q1perp = cross( q1, N );\\n\\t\\tvec3 q0perp = cross( N, q0 );\\n\\t\\tvec3 T = q1perp * st0.x + q0perp * st1.x;\\n\\t\\tvec3 B = q1perp * st0.y + q0perp * st1.y;\\n\\t\\tfloat det = max( dot( T, T ), dot( B, B ) );\\n\\t\\tfloat scale = ( det == 0.0 ) ? 0.0 : faceDirection * inversesqrt( det );\\n\\t\\treturn normalize( T * ( mapN.x * scale ) + B * ( mapN.y * scale ) + N * mapN.z );\\n\\t}\\n#endif\";\n\nvar clearcoat_normal_fragment_begin = \"#ifdef USE_CLEARCOAT\\n\\tvec3 clearcoatNormal = geometryNormal;\\n#endif\";\n\nvar clearcoat_normal_fragment_maps = \"#ifdef USE_CLEARCOAT_NORMALMAP\\n\\tvec3 clearcoatMapN = texture2D( clearcoatNormalMap, vUv ).xyz * 2.0 - 1.0;\\n\\tclearcoatMapN.xy *= clearcoatNormalScale;\\n\\t#ifdef USE_TANGENT\\n\\t\\tclearcoatNormal = normalize( vTBN * clearcoatMapN );\\n\\t#else\\n\\t\\tclearcoatNormal = perturbNormal2Arb( - vViewPosition, clearcoatNormal, clearcoatMapN, faceDirection );\\n\\t#endif\\n#endif\";\n\nvar clearcoat_pars_fragment = \"#ifdef USE_CLEARCOATMAP\\n\\tuniform sampler2D clearcoatMap;\\n#endif\\n#ifdef USE_CLEARCOAT_ROUGHNESSMAP\\n\\tuniform sampler2D clearcoatRoughnessMap;\\n#endif\\n#ifdef USE_CLEARCOAT_NORMALMAP\\n\\tuniform sampler2D clearcoatNormalMap;\\n\\tuniform vec2 clearcoatNormalScale;\\n#endif\";\n\nvar iridescence_pars_fragment = \"#ifdef USE_IRIDESCENCEMAP\\n\\tuniform sampler2D iridescenceMap;\\n#endif\\n#ifdef USE_IRIDESCENCE_THICKNESSMAP\\n\\tuniform sampler2D iridescenceThicknessMap;\\n#endif\";\n\nvar output_fragment = \"#ifdef OPAQUE\\ndiffuseColor.a = 1.0;\\n#endif\\n#ifdef USE_TRANSMISSION\\ndiffuseColor.a *= transmissionAlpha + 0.1;\\n#endif\\ngl_FragColor = vec4( outgoingLight, diffuseColor.a );\";\n\nvar packing = \"vec3 packNormalToRGB( const in vec3 normal ) {\\n\\treturn normalize( normal ) * 0.5 + 0.5;\\n}\\nvec3 unpackRGBToNormal( const in vec3 rgb ) {\\n\\treturn 2.0 * rgb.xyz - 1.0;\\n}\\nconst float PackUpscale = 256. / 255.;const float UnpackDownscale = 255. / 256.;\\nconst vec3 PackFactors = vec3( 256. * 256. * 256., 256. * 256., 256. );\\nconst vec4 UnpackFactors = UnpackDownscale / vec4( PackFactors, 1. );\\nconst float ShiftRight8 = 1. / 256.;\\nvec4 packDepthToRGBA( const in float v ) {\\n\\tvec4 r = vec4( fract( v * PackFactors ), v );\\n\\tr.yzw -= r.xyz * ShiftRight8;\\treturn r * PackUpscale;\\n}\\nfloat unpackRGBAToDepth( const in vec4 v ) {\\n\\treturn dot( v, UnpackFactors );\\n}\\nvec4 pack2HalfToRGBA( vec2 v ) {\\n\\tvec4 r = vec4( v.x, fract( v.x * 255.0 ), v.y, fract( v.y * 255.0 ) );\\n\\treturn vec4( r.x - r.y / 255.0, r.y, r.z - r.w / 255.0, r.w );\\n}\\nvec2 unpackRGBATo2Half( vec4 v ) {\\n\\treturn vec2( v.x + ( v.y / 255.0 ), v.z + ( v.w / 255.0 ) );\\n}\\nfloat viewZToOrthographicDepth( const in float viewZ, const in float near, const in float far ) {\\n\\treturn ( viewZ + near ) / ( near - far );\\n}\\nfloat orthographicDepthToViewZ( const in float linearClipZ, const in float near, const in float far ) {\\n\\treturn linearClipZ * ( near - far ) - near;\\n}\\nfloat viewZToPerspectiveDepth( const in float viewZ, const in float near, const in float far ) {\\n\\treturn ( ( near + viewZ ) * far ) / ( ( far - near ) * viewZ );\\n}\\nfloat perspectiveDepthToViewZ( const in float invClipZ, const in float near, const in float far ) {\\n\\treturn ( near * far ) / ( ( far - near ) * invClipZ - far );\\n}\";\n\nvar premultiplied_alpha_fragment = \"#ifdef PREMULTIPLIED_ALPHA\\n\\tgl_FragColor.rgb *= gl_FragColor.a;\\n#endif\";\n\nvar project_vertex = \"vec4 mvPosition = vec4( transformed, 1.0 );\\n#ifdef USE_INSTANCING\\n\\tmvPosition = instanceMatrix * mvPosition;\\n#endif\\nmvPosition = modelViewMatrix * mvPosition;\\ngl_Position = projectionMatrix * mvPosition;\";\n\nvar dithering_fragment = \"#ifdef DITHERING\\n\\tgl_FragColor.rgb = dithering( gl_FragColor.rgb );\\n#endif\";\n\nvar dithering_pars_fragment = \"#ifdef DITHERING\\n\\tvec3 dithering( vec3 color ) {\\n\\t\\tfloat grid_position = rand( gl_FragCoord.xy );\\n\\t\\tvec3 dither_shift_RGB = vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 );\\n\\t\\tdither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position );\\n\\t\\treturn color + dither_shift_RGB;\\n\\t}\\n#endif\";\n\nvar roughnessmap_fragment = \"float roughnessFactor = roughness;\\n#ifdef USE_ROUGHNESSMAP\\n\\tvec4 texelRoughness = texture2D( roughnessMap, vUv );\\n\\troughnessFactor *= texelRoughness.g;\\n#endif\";\n\nvar roughnessmap_pars_fragment = \"#ifdef USE_ROUGHNESSMAP\\n\\tuniform sampler2D roughnessMap;\\n#endif\";\n\nvar shadowmap_pars_fragment = \"#ifdef USE_SHADOWMAP\\n\\t#if NUM_DIR_LIGHT_SHADOWS > 0\\n\\t\\tuniform sampler2D directionalShadowMap[ NUM_DIR_LIGHT_SHADOWS ];\\n\\t\\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHT_SHADOWS ];\\n\\t\\tstruct DirectionalLightShadow {\\n\\t\\t\\tfloat shadowBias;\\n\\t\\t\\tfloat shadowNormalBias;\\n\\t\\t\\tfloat shadowRadius;\\n\\t\\t\\tvec2 shadowMapSize;\\n\\t\\t};\\n\\t\\tuniform DirectionalLightShadow directionalLightShadows[ NUM_DIR_LIGHT_SHADOWS ];\\n\\t#endif\\n\\t#if NUM_SPOT_LIGHT_SHADOWS > 0\\n\\t\\tuniform sampler2D spotShadowMap[ NUM_SPOT_LIGHT_SHADOWS ];\\n\\t\\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHT_SHADOWS ];\\n\\t\\tstruct SpotLightShadow {\\n\\t\\t\\tfloat shadowBias;\\n\\t\\t\\tfloat shadowNormalBias;\\n\\t\\t\\tfloat shadowRadius;\\n\\t\\t\\tvec2 shadowMapSize;\\n\\t\\t};\\n\\t\\tuniform SpotLightShadow spotLightShadows[ NUM_SPOT_LIGHT_SHADOWS ];\\n\\t#endif\\n\\t#if NUM_POINT_LIGHT_SHADOWS > 0\\n\\t\\tuniform sampler2D pointShadowMap[ NUM_POINT_LIGHT_SHADOWS ];\\n\\t\\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHT_SHADOWS ];\\n\\t\\tstruct PointLightShadow {\\n\\t\\t\\tfloat shadowBias;\\n\\t\\t\\tfloat shadowNormalBias;\\n\\t\\t\\tfloat shadowRadius;\\n\\t\\t\\tvec2 shadowMapSize;\\n\\t\\t\\tfloat shadowCameraNear;\\n\\t\\t\\tfloat shadowCameraFar;\\n\\t\\t};\\n\\t\\tuniform PointLightShadow pointLightShadows[ NUM_POINT_LIGHT_SHADOWS ];\\n\\t#endif\\n\\tfloat texture2DCompare( sampler2D depths, vec2 uv, float compare ) {\\n\\t\\treturn step( compare, unpackRGBAToDepth( texture2D( depths, uv ) ) );\\n\\t}\\n\\tvec2 texture2DDistribution( sampler2D shadow, vec2 uv ) {\\n\\t\\treturn unpackRGBATo2Half( texture2D( shadow, uv ) );\\n\\t}\\n\\tfloat VSMShadow (sampler2D shadow, vec2 uv, float compare ){\\n\\t\\tfloat occlusion = 1.0;\\n\\t\\tvec2 distribution = texture2DDistribution( shadow, uv );\\n\\t\\tfloat hard_shadow = step( compare , distribution.x );\\n\\t\\tif (hard_shadow != 1.0 ) {\\n\\t\\t\\tfloat distance = compare - distribution.x ;\\n\\t\\t\\tfloat variance = max( 0.00000, distribution.y * distribution.y );\\n\\t\\t\\tfloat softness_probability = variance / (variance + distance * distance );\\t\\t\\tsoftness_probability = clamp( ( softness_probability - 0.3 ) / ( 0.95 - 0.3 ), 0.0, 1.0 );\\t\\t\\tocclusion = clamp( max( hard_shadow, softness_probability ), 0.0, 1.0 );\\n\\t\\t}\\n\\t\\treturn occlusion;\\n\\t}\\n\\tfloat getShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord ) {\\n\\t\\tfloat shadow = 1.0;\\n\\t\\tshadowCoord.xyz /= shadowCoord.w;\\n\\t\\tshadowCoord.z += shadowBias;\\n\\t\\tbvec4 inFrustumVec = bvec4 ( shadowCoord.x >= 0.0, shadowCoord.x <= 1.0, shadowCoord.y >= 0.0, shadowCoord.y <= 1.0 );\\n\\t\\tbool inFrustum = all( inFrustumVec );\\n\\t\\tbvec2 frustumTestVec = bvec2( inFrustum, shadowCoord.z <= 1.0 );\\n\\t\\tbool frustumTest = all( frustumTestVec );\\n\\t\\tif ( frustumTest ) {\\n\\t\\t#if defined( SHADOWMAP_TYPE_PCF )\\n\\t\\t\\tvec2 texelSize = vec2( 1.0 ) / shadowMapSize;\\n\\t\\t\\tfloat dx0 = - texelSize.x * shadowRadius;\\n\\t\\t\\tfloat dy0 = - texelSize.y * shadowRadius;\\n\\t\\t\\tfloat dx1 = + texelSize.x * shadowRadius;\\n\\t\\t\\tfloat dy1 = + texelSize.y * shadowRadius;\\n\\t\\t\\tfloat dx2 = dx0 / 2.0;\\n\\t\\t\\tfloat dy2 = dy0 / 2.0;\\n\\t\\t\\tfloat dx3 = dx1 / 2.0;\\n\\t\\t\\tfloat dy3 = dy1 / 2.0;\\n\\t\\t\\tshadow = (\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, dy2 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy2 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, dy2 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, dy3 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy3 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, dy3 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\\n\\t\\t\\t) * ( 1.0 / 17.0 );\\n\\t\\t#elif defined( SHADOWMAP_TYPE_PCF_SOFT )\\n\\t\\t\\tvec2 texelSize = vec2( 1.0 ) / shadowMapSize;\\n\\t\\t\\tfloat dx = texelSize.x;\\n\\t\\t\\tfloat dy = texelSize.y;\\n\\t\\t\\tvec2 uv = shadowCoord.xy;\\n\\t\\t\\tvec2 f = fract( uv * shadowMapSize + 0.5 );\\n\\t\\t\\tuv -= f * texelSize;\\n\\t\\t\\tshadow = (\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, uv, shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, uv + vec2( dx, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, uv + vec2( 0.0, dy ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, uv + texelSize, shadowCoord.z ) +\\n\\t\\t\\t\\tmix( texture2DCompare( shadowMap, uv + vec2( -dx, 0.0 ), shadowCoord.z ), \\n\\t\\t\\t\\t\\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, 0.0 ), shadowCoord.z ),\\n\\t\\t\\t\\t\\t f.x ) +\\n\\t\\t\\t\\tmix( texture2DCompare( shadowMap, uv + vec2( -dx, dy ), shadowCoord.z ), \\n\\t\\t\\t\\t\\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, dy ), shadowCoord.z ),\\n\\t\\t\\t\\t\\t f.x ) +\\n\\t\\t\\t\\tmix( texture2DCompare( shadowMap, uv + vec2( 0.0, -dy ), shadowCoord.z ), \\n\\t\\t\\t\\t\\t texture2DCompare( shadowMap, uv + vec2( 0.0, 2.0 * dy ), shadowCoord.z ),\\n\\t\\t\\t\\t\\t f.y ) +\\n\\t\\t\\t\\tmix( texture2DCompare( shadowMap, uv + vec2( dx, -dy ), shadowCoord.z ), \\n\\t\\t\\t\\t\\t texture2DCompare( shadowMap, uv + vec2( dx, 2.0 * dy ), shadowCoord.z ),\\n\\t\\t\\t\\t\\t f.y ) +\\n\\t\\t\\t\\tmix( mix( texture2DCompare( shadowMap, uv + vec2( -dx, -dy ), shadowCoord.z ), \\n\\t\\t\\t\\t\\t\\t\ttexture2DCompare( shadowMap, uv + vec2( 2.0 * dx, -dy ), shadowCoord.z ),\\n\\t\\t\\t\\t\\t\\t\tf.x ),\\n\\t\\t\\t\\t\\t mix( texture2DCompare( shadowMap, uv + vec2( -dx, 2.0 * dy ), shadowCoord.z ), \\n\\t\\t\\t\\t\\t\\t\ttexture2DCompare( shadowMap, uv + vec2( 2.0 * dx, 2.0 * dy ), shadowCoord.z ),\\n\\t\\t\\t\\t\\t\\t\tf.x ),\\n\\t\\t\\t\\t\\t f.y )\\n\\t\\t\\t) * ( 1.0 / 9.0 );\\n\\t\\t#elif defined( SHADOWMAP_TYPE_VSM )\\n\\t\\t\\tshadow = VSMShadow( shadowMap, shadowCoord.xy, shadowCoord.z );\\n\\t\\t#else\\n\\t\\t\\tshadow = texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z );\\n\\t\\t#endif\\n\\t\\t}\\n\\t\\treturn shadow;\\n\\t}\\n\\tvec2 cubeToUV( vec3 v, float texelSizeY ) {\\n\\t\\tvec3 absV = abs( v );\\n\\t\\tfloat scaleToCube = 1.0 / max( absV.x, max( absV.y, absV.z ) );\\n\\t\\tabsV *= scaleToCube;\\n\\t\\tv *= scaleToCube * ( 1.0 - 2.0 * texelSizeY );\\n\\t\\tvec2 planar = v.xy;\\n\\t\\tfloat almostATexel = 1.5 * texelSizeY;\\n\\t\\tfloat almostOne = 1.0 - almostATexel;\\n\\t\\tif ( absV.z >= almostOne ) {\\n\\t\\t\\tif ( v.z > 0.0 )\\n\\t\\t\\t\\tplanar.x = 4.0 - v.x;\\n\\t\\t} else if ( absV.x >= almostOne ) {\\n\\t\\t\\tfloat signX = sign( v.x );\\n\\t\\t\\tplanar.x = v.z * signX + 2.0 * signX;\\n\\t\\t} else if ( absV.y >= almostOne ) {\\n\\t\\t\\tfloat signY = sign( v.y );\\n\\t\\t\\tplanar.x = v.x + 2.0 * signY + 2.0;\\n\\t\\t\\tplanar.y = v.z * signY - 2.0;\\n\\t\\t}\\n\\t\\treturn vec2( 0.125, 0.25 ) * planar + vec2( 0.375, 0.75 );\\n\\t}\\n\\tfloat getPointShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord, float shadowCameraNear, float shadowCameraFar ) {\\n\\t\\tvec2 texelSize = vec2( 1.0 ) / ( shadowMapSize * vec2( 4.0, 2.0 ) );\\n\\t\\tvec3 lightToPosition = shadowCoord.xyz;\\n\\t\\tfloat dp = ( length( lightToPosition ) - shadowCameraNear ) / ( shadowCameraFar - shadowCameraNear );\\t\\tdp += shadowBias;\\n\\t\\tvec3 bd3D = normalize( lightToPosition );\\n\\t\\t#if defined( SHADOWMAP_TYPE_PCF ) || defined( SHADOWMAP_TYPE_PCF_SOFT ) || defined( SHADOWMAP_TYPE_VSM )\\n\\t\\t\\tvec2 offset = vec2( - 1, 1 ) * shadowRadius * texelSize.y;\\n\\t\\t\\treturn (\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyy, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyy, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyx, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyx, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxy, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxy, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxx, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxx, texelSize.y ), dp )\\n\\t\\t\\t) * ( 1.0 / 9.0 );\\n\\t\\t#else\\n\\t\\t\\treturn texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp );\\n\\t\\t#endif\\n\\t}\\n#endif\";\n\nvar shadowmap_pars_vertex = \"#ifdef USE_SHADOWMAP\\n\\t#if NUM_DIR_LIGHT_SHADOWS > 0\\n\\t\\tuniform mat4 directionalShadowMatrix[ NUM_DIR_LIGHT_SHADOWS ];\\n\\t\\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHT_SHADOWS ];\\n\\t\\tstruct DirectionalLightShadow {\\n\\t\\t\\tfloat shadowBias;\\n\\t\\t\\tfloat shadowNormalBias;\\n\\t\\t\\tfloat shadowRadius;\\n\\t\\t\\tvec2 shadowMapSize;\\n\\t\\t};\\n\\t\\tuniform DirectionalLightShadow directionalLightShadows[ NUM_DIR_LIGHT_SHADOWS ];\\n\\t#endif\\n\\t#if NUM_SPOT_LIGHT_SHADOWS > 0\\n\\t\\tuniform mat4 spotShadowMatrix[ NUM_SPOT_LIGHT_SHADOWS ];\\n\\t\\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHT_SHADOWS ];\\n\\t\\tstruct SpotLightShadow {\\n\\t\\t\\tfloat shadowBias;\\n\\t\\t\\tfloat shadowNormalBias;\\n\\t\\t\\tfloat shadowRadius;\\n\\t\\t\\tvec2 shadowMapSize;\\n\\t\\t};\\n\\t\\tuniform SpotLightShadow spotLightShadows[ NUM_SPOT_LIGHT_SHADOWS ];\\n\\t#endif\\n\\t#if NUM_POINT_LIGHT_SHADOWS > 0\\n\\t\\tuniform mat4 pointShadowMatrix[ NUM_POINT_LIGHT_SHADOWS ];\\n\\t\\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHT_SHADOWS ];\\n\\t\\tstruct PointLightShadow {\\n\\t\\t\\tfloat shadowBias;\\n\\t\\t\\tfloat shadowNormalBias;\\n\\t\\t\\tfloat shadowRadius;\\n\\t\\t\\tvec2 shadowMapSize;\\n\\t\\t\\tfloat shadowCameraNear;\\n\\t\\t\\tfloat shadowCameraFar;\\n\\t\\t};\\n\\t\\tuniform PointLightShadow pointLightShadows[ NUM_POINT_LIGHT_SHADOWS ];\\n\\t#endif\\n#endif\";\n\nvar shadowmap_vertex = \"#ifdef USE_SHADOWMAP\\n\\t#if NUM_DIR_LIGHT_SHADOWS > 0 || NUM_SPOT_LIGHT_SHADOWS > 0 || NUM_POINT_LIGHT_SHADOWS > 0\\n\\t\\tvec3 shadowWorldNormal = inverseTransformDirection( transformedNormal, viewMatrix );\\n\\t\\tvec4 shadowWorldPosition;\\n\\t#endif\\n\\t#if NUM_DIR_LIGHT_SHADOWS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_DIR_LIGHT_SHADOWS; i ++ ) {\\n\\t\\tshadowWorldPosition = worldPosition + vec4( shadowWorldNormal * directionalLightShadows[ i ].shadowNormalBias, 0 );\\n\\t\\tvDirectionalShadowCoord[ i ] = directionalShadowMatrix[ i ] * shadowWorldPosition;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#endif\\n\\t#if NUM_SPOT_LIGHT_SHADOWS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_SPOT_LIGHT_SHADOWS; i ++ ) {\\n\\t\\tshadowWorldPosition = worldPosition + vec4( shadowWorldNormal * spotLightShadows[ i ].shadowNormalBias, 0 );\\n\\t\\tvSpotShadowCoord[ i ] = spotShadowMatrix[ i ] * shadowWorldPosition;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#endif\\n\\t#if NUM_POINT_LIGHT_SHADOWS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_POINT_LIGHT_SHADOWS; i ++ ) {\\n\\t\\tshadowWorldPosition = worldPosition + vec4( shadowWorldNormal * pointLightShadows[ i ].shadowNormalBias, 0 );\\n\\t\\tvPointShadowCoord[ i ] = pointShadowMatrix[ i ] * shadowWorldPosition;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#endif\\n#endif\";\n\nvar shadowmask_pars_fragment = \"float getShadowMask() {\\n\\tfloat shadow = 1.0;\\n\\t#ifdef USE_SHADOWMAP\\n\\t#if NUM_DIR_LIGHT_SHADOWS > 0\\n\\tDirectionalLightShadow directionalLight;\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_DIR_LIGHT_SHADOWS; i ++ ) {\\n\\t\\tdirectionalLight = directionalLightShadows[ i ];\\n\\t\\tshadow *= receiveShadow ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#endif\\n\\t#if NUM_SPOT_LIGHT_SHADOWS > 0\\n\\tSpotLightShadow spotLight;\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_SPOT_LIGHT_SHADOWS; i ++ ) {\\n\\t\\tspotLight = spotLightShadows[ i ];\\n\\t\\tshadow *= receiveShadow ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#endif\\n\\t#if NUM_POINT_LIGHT_SHADOWS > 0\\n\\tPointLightShadow pointLight;\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_POINT_LIGHT_SHADOWS; i ++ ) {\\n\\t\\tpointLight = pointLightShadows[ i ];\\n\\t\\tshadow *= receiveShadow ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#endif\\n\\t#endif\\n\\treturn shadow;\\n}\";\n\nvar skinbase_vertex = \"#ifdef USE_SKINNING\\n\\tmat4 boneMatX = getBoneMatrix( skinIndex.x );\\n\\tmat4 boneMatY = getBoneMatrix( skinIndex.y );\\n\\tmat4 boneMatZ = getBoneMatrix( skinIndex.z );\\n\\tmat4 boneMatW = getBoneMatrix( skinIndex.w );\\n#endif\";\n\nvar skinning_pars_vertex = \"#ifdef USE_SKINNING\\n\\tuniform mat4 bindMatrix;\\n\\tuniform mat4 bindMatrixInverse;\\n\\tuniform highp sampler2D boneTexture;\\n\\tuniform int boneTextureSize;\\n\\tmat4 getBoneMatrix( const in float i ) {\\n\\t\\tfloat j = i * 4.0;\\n\\t\\tfloat x = mod( j, float( boneTextureSize ) );\\n\\t\\tfloat y = floor( j / float( boneTextureSize ) );\\n\\t\\tfloat dx = 1.0 / float( boneTextureSize );\\n\\t\\tfloat dy = 1.0 / float( boneTextureSize );\\n\\t\\ty = dy * ( y + 0.5 );\\n\\t\\tvec4 v1 = texture2D( boneTexture, vec2( dx * ( x + 0.5 ), y ) );\\n\\t\\tvec4 v2 = texture2D( boneTexture, vec2( dx * ( x + 1.5 ), y ) );\\n\\t\\tvec4 v3 = texture2D( boneTexture, vec2( dx * ( x + 2.5 ), y ) );\\n\\t\\tvec4 v4 = texture2D( boneTexture, vec2( dx * ( x + 3.5 ), y ) );\\n\\t\\tmat4 bone = mat4( v1, v2, v3, v4 );\\n\\t\\treturn bone;\\n\\t}\\n#endif\";\n\nvar skinning_vertex = \"#ifdef USE_SKINNING\\n\\tvec4 skinVertex = bindMatrix * vec4( transformed, 1.0 );\\n\\tvec4 skinned = vec4( 0.0 );\\n\\tskinned += boneMatX * skinVertex * skinWeight.x;\\n\\tskinned += boneMatY * skinVertex * skinWeight.y;\\n\\tskinned += boneMatZ * skinVertex * skinWeight.z;\\n\\tskinned += boneMatW * skinVertex * skinWeight.w;\\n\\ttransformed = ( bindMatrixInverse * skinned ).xyz;\\n#endif\";\n\nvar skinnormal_vertex = \"#ifdef USE_SKINNING\\n\\tmat4 skinMatrix = mat4( 0.0 );\\n\\tskinMatrix += skinWeight.x * boneMatX;\\n\\tskinMatrix += skinWeight.y * boneMatY;\\n\\tskinMatrix += skinWeight.z * boneMatZ;\\n\\tskinMatrix += skinWeight.w * boneMatW;\\n\\tskinMatrix = bindMatrixInverse * skinMatrix * bindMatrix;\\n\\tobjectNormal = vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz;\\n\\t#ifdef USE_TANGENT\\n\\t\\tobjectTangent = vec4( skinMatrix * vec4( objectTangent, 0.0 ) ).xyz;\\n\\t#endif\\n#endif\";\n\nvar specularmap_fragment = \"float specularStrength;\\n#ifdef USE_SPECULARMAP\\n\\tvec4 texelSpecular = texture2D( specularMap, vUv );\\n\\tspecularStrength = texelSpecular.r;\\n#else\\n\\tspecularStrength = 1.0;\\n#endif\";\n\nvar specularmap_pars_fragment = \"#ifdef USE_SPECULARMAP\\n\\tuniform sampler2D specularMap;\\n#endif\";\n\nvar tonemapping_fragment = \"#if defined( TONE_MAPPING )\\n\\tgl_FragColor.rgb = toneMapping( gl_FragColor.rgb );\\n#endif\";\n\nvar tonemapping_pars_fragment = \"#ifndef saturate\\n#define saturate( a ) clamp( a, 0.0, 1.0 )\\n#endif\\nuniform float toneMappingExposure;\\nvec3 LinearToneMapping( vec3 color ) {\\n\\treturn toneMappingExposure * color;\\n}\\nvec3 ReinhardToneMapping( vec3 color ) {\\n\\tcolor *= toneMappingExposure;\\n\\treturn saturate( color / ( vec3( 1.0 ) + color ) );\\n}\\nvec3 OptimizedCineonToneMapping( vec3 color ) {\\n\\tcolor *= toneMappingExposure;\\n\\tcolor = max( vec3( 0.0 ), color - 0.004 );\\n\\treturn pow( ( color * ( 6.2 * color + 0.5 ) ) / ( color * ( 6.2 * color + 1.7 ) + 0.06 ), vec3( 2.2 ) );\\n}\\nvec3 RRTAndODTFit( vec3 v ) {\\n\\tvec3 a = v * ( v + 0.0245786 ) - 0.000090537;\\n\\tvec3 b = v * ( 0.983729 * v + 0.4329510 ) + 0.238081;\\n\\treturn a / b;\\n}\\nvec3 ACESFilmicToneMapping( vec3 color ) {\\n\\tconst mat3 ACESInputMat = mat3(\\n\\t\\tvec3( 0.59719, 0.07600, 0.02840 ),\\t\\tvec3( 0.35458, 0.90834, 0.13383 ),\\n\\t\\tvec3( 0.04823, 0.01566, 0.83777 )\\n\\t);\\n\\tconst mat3 ACESOutputMat = mat3(\\n\\t\\tvec3(\t1.60475, -0.10208, -0.00327 ),\\t\\tvec3( -0.53108,\t1.10813, -0.07276 ),\\n\\t\\tvec3( -0.07367, -0.00605,\t1.07602 )\\n\\t);\\n\\tcolor *= toneMappingExposure / 0.6;\\n\\tcolor = ACESInputMat * color;\\n\\tcolor = RRTAndODTFit( color );\\n\\tcolor = ACESOutputMat * color;\\n\\treturn saturate( color );\\n}\\nvec3 CustomToneMapping( vec3 color ) { return color; }\";\n\nvar transmission_fragment = \"#ifdef USE_TRANSMISSION\\n\\tfloat transmissionAlpha = 1.0;\\n\\tfloat transmissionFactor = transmission;\\n\\tfloat thicknessFactor = thickness;\\n\\t#ifdef USE_TRANSMISSIONMAP\\n\\t\\ttransmissionFactor *= texture2D( transmissionMap, vUv ).r;\\n\\t#endif\\n\\t#ifdef USE_THICKNESSMAP\\n\\t\\tthicknessFactor *= texture2D( thicknessMap, vUv ).g;\\n\\t#endif\\n\\tvec3 pos = vWorldPosition;\\n\\tvec3 v = normalize( cameraPosition - pos );\\n\\tvec3 n = inverseTransformDirection( normal, viewMatrix );\\n\\tvec4 transmission = getIBLVolumeRefraction(\\n\\t\\tn, v, roughnessFactor, material.diffuseColor, material.specularColor, material.specularF90,\\n\\t\\tpos, modelMatrix, viewMatrix, projectionMatrix, ior, thicknessFactor,\\n\\t\\tattenuationColor, attenuationDistance );\\n\\ttotalDiffuse = mix( totalDiffuse, transmission.rgb, transmissionFactor );\\n\\ttransmissionAlpha = mix( transmissionAlpha, transmission.a, transmissionFactor );\\n#endif\";\n\nvar transmission_pars_fragment = \"#ifdef USE_TRANSMISSION\\n\\tuniform float transmission;\\n\\tuniform float thickness;\\n\\tuniform float attenuationDistance;\\n\\tuniform vec3 attenuationColor;\\n\\t#ifdef USE_TRANSMISSIONMAP\\n\\t\\tuniform sampler2D transmissionMap;\\n\\t#endif\\n\\t#ifdef USE_THICKNESSMAP\\n\\t\\tuniform sampler2D thicknessMap;\\n\\t#endif\\n\\tuniform vec2 transmissionSamplerSize;\\n\\tuniform sampler2D transmissionSamplerMap;\\n\\tuniform mat4 modelMatrix;\\n\\tuniform mat4 projectionMatrix;\\n\\tvarying vec3 vWorldPosition;\\n\\tvec3 getVolumeTransmissionRay( const in vec3 n, const in vec3 v, const in float thickness, const in float ior, const in mat4 modelMatrix ) {\\n\\t\\tvec3 refractionVector = refract( - v, normalize( n ), 1.0 / ior );\\n\\t\\tvec3 modelScale;\\n\\t\\tmodelScale.x = length( vec3( modelMatrix[ 0 ].xyz ) );\\n\\t\\tmodelScale.y = length( vec3( modelMatrix[ 1 ].xyz ) );\\n\\t\\tmodelScale.z = length( vec3( modelMatrix[ 2 ].xyz ) );\\n\\t\\treturn normalize( refractionVector ) * thickness * modelScale;\\n\\t}\\n\\tfloat applyIorToRoughness( const in float roughness, const in float ior ) {\\n\\t\\treturn roughness * clamp( ior * 2.0 - 2.0, 0.0, 1.0 );\\n\\t}\\n\\tvec4 getTransmissionSample( const in vec2 fragCoord, const in float roughness, const in float ior ) {\\n\\t\\tfloat framebufferLod = log2( transmissionSamplerSize.x ) * applyIorToRoughness( roughness, ior );\\n\\t\\t#ifdef texture2DLodEXT\\n\\t\\t\\treturn texture2DLodEXT( transmissionSamplerMap, fragCoord.xy, framebufferLod );\\n\\t\\t#else\\n\\t\\t\\treturn texture2D( transmissionSamplerMap, fragCoord.xy, framebufferLod );\\n\\t\\t#endif\\n\\t}\\n\\tvec3 applyVolumeAttenuation( const in vec3 radiance, const in float transmissionDistance, const in vec3 attenuationColor, const in float attenuationDistance ) {\\n\\t\\tif ( attenuationDistance == 0.0 ) {\\n\\t\\t\\treturn radiance;\\n\\t\\t} else {\\n\\t\\t\\tvec3 attenuationCoefficient = -log( attenuationColor ) / attenuationDistance;\\n\\t\\t\\tvec3 transmittance = exp( - attenuationCoefficient * transmissionDistance );\\t\\t\\treturn transmittance * radiance;\\n\\t\\t}\\n\\t}\\n\\tvec4 getIBLVolumeRefraction( const in vec3 n, const in vec3 v, const in float roughness, const in vec3 diffuseColor,\\n\\t\\tconst in vec3 specularColor, const in float specularF90, const in vec3 position, const in mat4 modelMatrix,\\n\\t\\tconst in mat4 viewMatrix, const in mat4 projMatrix, const in float ior, const in float thickness,\\n\\t\\tconst in vec3 attenuationColor, const in float attenuationDistance ) {\\n\\t\\tvec3 transmissionRay = getVolumeTransmissionRay( n, v, thickness, ior, modelMatrix );\\n\\t\\tvec3 refractedRayExit = position + transmissionRay;\\n\\t\\tvec4 ndcPos = projMatrix * viewMatrix * vec4( refractedRayExit, 1.0 );\\n\\t\\tvec2 refractionCoords = ndcPos.xy / ndcPos.w;\\n\\t\\trefractionCoords += 1.0;\\n\\t\\trefractionCoords /= 2.0;\\n\\t\\tvec4 transmittedLight = getTransmissionSample( refractionCoords, roughness, ior );\\n\\t\\tvec3 attenuatedColor = applyVolumeAttenuation( transmittedLight.rgb, length( transmissionRay ), attenuationColor, attenuationDistance );\\n\\t\\tvec3 F = EnvironmentBRDF( n, v, specularColor, specularF90, roughness );\\n\\t\\treturn vec4( ( 1.0 - F ) * attenuatedColor * diffuseColor, transmittedLight.a );\\n\\t}\\n#endif\";\n\nvar uv_pars_fragment = \"#if ( defined( USE_UV ) && ! defined( UVS_VERTEX_ONLY ) )\\n\\tvarying vec2 vUv;\\n#endif\";\n\nvar uv_pars_vertex = \"#ifdef USE_UV\\n\\t#ifdef UVS_VERTEX_ONLY\\n\\t\\tvec2 vUv;\\n\\t#else\\n\\t\\tvarying vec2 vUv;\\n\\t#endif\\n\\tuniform mat3 uvTransform;\\n#endif\";\n\nvar uv_vertex = \"#ifdef USE_UV\\n\\tvUv = ( uvTransform * vec3( uv, 1 ) ).xy;\\n#endif\";\n\nvar uv2_pars_fragment = \"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\\n\\tvarying vec2 vUv2;\\n#endif\";\n\nvar uv2_pars_vertex = \"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\\n\\tattribute vec2 uv2;\\n\\tvarying vec2 vUv2;\\n\\tuniform mat3 uv2Transform;\\n#endif\";\n\nvar uv2_vertex = \"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\\n\\tvUv2 = ( uv2Transform * vec3( uv2, 1 ) ).xy;\\n#endif\";\n\nvar worldpos_vertex = \"#if defined( USE_ENVMAP ) || defined( DISTANCE ) || defined ( USE_SHADOWMAP ) || defined ( USE_TRANSMISSION )\\n\\tvec4 worldPosition = vec4( transformed, 1.0 );\\n\\t#ifdef USE_INSTANCING\\n\\t\\tworldPosition = instanceMatrix * worldPosition;\\n\\t#endif\\n\\tworldPosition = modelMatrix * worldPosition;\\n#endif\";\n\nconst vertex$g = \"varying vec2 vUv;\\nuniform mat3 uvTransform;\\nvoid main() {\\n\\tvUv = ( uvTransform * vec3( uv, 1 ) ).xy;\\n\\tgl_Position = vec4( position.xy, 1.0, 1.0 );\\n}\";\nconst fragment$g = \"uniform sampler2D t2D;\\nvarying vec2 vUv;\\nvoid main() {\\n\\tgl_FragColor = texture2D( t2D, vUv );\\n\\t#ifdef DECODE_VIDEO_TEXTURE\\n\\t\\tgl_FragColor = vec4( mix( pow( gl_FragColor.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), gl_FragColor.rgb * 0.0773993808, vec3( lessThanEqual( gl_FragColor.rgb, vec3( 0.04045 ) ) ) ), gl_FragColor.w );\\n\\t#endif\\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$f = \"varying vec3 vWorldDirection;\\n#include \\nvoid main() {\\n\\tvWorldDirection = transformDirection( position, modelMatrix );\\n\\t#include \\n\\t#include \\n\\tgl_Position.z = gl_Position.w;\\n}\";\nconst fragment$f = \"#include \\nuniform float opacity;\\nvarying vec3 vWorldDirection;\\n#include \\nvoid main() {\\n\\tvec3 vReflect = vWorldDirection;\\n\\t#include \\n\\tgl_FragColor = envColor;\\n\\tgl_FragColor.a *= opacity;\\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$e = \"#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvarying vec2 vHighPrecisionZW;\\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#ifdef USE_DISPLACEMENTMAP\\n\\t\\t#include \\n\\t\\t#include \\n\\t\\t#include \\n\\t#endif\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvHighPrecisionZW = gl_Position.zw;\\n}\";\nconst fragment$e = \"#if DEPTH_PACKING == 3200\\n\\tuniform float opacity;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvarying vec2 vHighPrecisionZW;\\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( 1.0 );\\n\\t#if DEPTH_PACKING == 3200\\n\\t\\tdiffuseColor.a = opacity;\\n\\t#endif\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tfloat fragCoordZ = 0.5 * vHighPrecisionZW[0] / vHighPrecisionZW[1] + 0.5;\\n\\t#if DEPTH_PACKING == 3200\\n\\t\\tgl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity );\\n\\t#elif DEPTH_PACKING == 3201\\n\\t\\tgl_FragColor = packDepthToRGBA( fragCoordZ );\\n\\t#endif\\n}\";\n\nconst vertex$d = \"#define DISTANCE\\nvarying vec3 vWorldPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#ifdef USE_DISPLACEMENTMAP\\n\\t\\t#include \\n\\t\\t#include \\n\\t\\t#include \\n\\t#endif\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvWorldPosition = worldPosition.xyz;\\n}\";\nconst fragment$d = \"#define DISTANCE\\nuniform vec3 referencePosition;\\nuniform float nearDistance;\\nuniform float farDistance;\\nvarying vec3 vWorldPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main () {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( 1.0 );\\n\\t#include \\n\\t#include \\n\\t#include \\n\\tfloat dist = length( vWorldPosition - referencePosition );\\n\\tdist = ( dist - nearDistance ) / ( farDistance - nearDistance );\\n\\tdist = saturate( dist );\\n\\tgl_FragColor = packDepthToRGBA( dist );\\n}\";\n\nconst vertex$c = \"varying vec3 vWorldDirection;\\n#include \\nvoid main() {\\n\\tvWorldDirection = transformDirection( position, modelMatrix );\\n\\t#include \\n\\t#include \\n}\";\nconst fragment$c = \"uniform sampler2D tEquirect;\\nvarying vec3 vWorldDirection;\\n#include \\nvoid main() {\\n\\tvec3 direction = normalize( vWorldDirection );\\n\\tvec2 sampleUV = equirectUv( direction );\\n\\tgl_FragColor = texture2D( tEquirect, sampleUV );\\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$b = \"uniform float scale;\\nattribute float lineDistance;\\nvarying float vLineDistance;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\tvLineDistance = scale * lineDistance;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\nconst fragment$b = \"uniform vec3 diffuse;\\nuniform float opacity;\\nuniform float dashSize;\\nuniform float totalSize;\\nvarying float vLineDistance;\\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tif ( mod( vLineDistance, totalSize ) > dashSize ) {\\n\\t\\tdiscard;\\n\\t}\\n\\tvec3 outgoingLight = vec3( 0.0 );\\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include \\n\\t#include \\n\\toutgoingLight = diffuseColor.rgb;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$a = \"#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#if defined ( USE_ENVMAP ) || defined ( USE_SKINNING )\\n\\t\\t#include \\n\\t\\t#include \\n\\t\\t#include \\n\\t\\t#include \\n\\t\\t#include \\n\\t#endif\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\nconst fragment$a = \"uniform vec3 diffuse;\\nuniform float opacity;\\n#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\t#ifdef USE_LIGHTMAP\\n\\t\\tvec4 lightMapTexel = texture2D( lightMap, vUv2 );\\n\\t\\treflectedLight.indirectDiffuse += lightMapTexel.rgb * lightMapIntensity * RECIPROCAL_PI;\\n\\t#else\\n\\t\\treflectedLight.indirectDiffuse += vec3( 1.0 );\\n\\t#endif\\n\\t#include \\n\\treflectedLight.indirectDiffuse *= diffuseColor.rgb;\\n\\tvec3 outgoingLight = reflectedLight.indirectDiffuse;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$9 = \"#define LAMBERT\\nvarying vec3 vLightFront;\\nvarying vec3 vIndirectFront;\\n#ifdef DOUBLE_SIDED\\n\\tvarying vec3 vLightBack;\\n\\tvarying vec3 vIndirectBack;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\nconst fragment$9 = \"uniform vec3 diffuse;\\nuniform vec3 emissive;\\nuniform float opacity;\\nvarying vec3 vLightFront;\\nvarying vec3 vIndirectFront;\\n#ifdef DOUBLE_SIDED\\n\\tvarying vec3 vLightBack;\\n\\tvarying vec3 vIndirectBack;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\tvec3 totalEmissiveRadiance = emissive;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#ifdef DOUBLE_SIDED\\n\\t\\treflectedLight.indirectDiffuse += ( gl_FrontFacing ) ? vIndirectFront : vIndirectBack;\\n\\t#else\\n\\t\\treflectedLight.indirectDiffuse += vIndirectFront;\\n\\t#endif\\n\\t#include \\n\\treflectedLight.indirectDiffuse *= BRDF_Lambert( diffuseColor.rgb );\\n\\t#ifdef DOUBLE_SIDED\\n\\t\\treflectedLight.directDiffuse = ( gl_FrontFacing ) ? vLightFront : vLightBack;\\n\\t#else\\n\\t\\treflectedLight.directDiffuse = vLightFront;\\n\\t#endif\\n\\treflectedLight.directDiffuse *= BRDF_Lambert( diffuseColor.rgb ) * getShadowMask();\\n\\t#include \\n\\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$8 = \"#define MATCAP\\nvarying vec3 vViewPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvViewPosition = - mvPosition.xyz;\\n}\";\nconst fragment$8 = \"#define MATCAP\\nuniform vec3 diffuse;\\nuniform float opacity;\\nuniform sampler2D matcap;\\nvarying vec3 vViewPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvec3 viewDir = normalize( vViewPosition );\\n\\tvec3 x = normalize( vec3( viewDir.z, 0.0, - viewDir.x ) );\\n\\tvec3 y = cross( viewDir, x );\\n\\tvec2 uv = vec2( dot( x, normal ), dot( y, normal ) ) * 0.495 + 0.5;\\n\\t#ifdef USE_MATCAP\\n\\t\\tvec4 matcapColor = texture2D( matcap, uv );\\n\\t#else\\n\\t\\tvec4 matcapColor = vec4( vec3( mix( 0.2, 0.8, uv.y ) ), 1.0 );\\n\\t#endif\\n\\tvec3 outgoingLight = diffuseColor.rgb * matcapColor.rgb;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$7 = \"#define NORMAL\\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\\n\\tvarying vec3 vViewPosition;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\\n\\tvViewPosition = - mvPosition.xyz;\\n#endif\\n}\";\nconst fragment$7 = \"#define NORMAL\\nuniform float opacity;\\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\\n\\tvarying vec3 vViewPosition;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tgl_FragColor = vec4( packNormalToRGB( normal ), opacity );\\n\\t#ifdef OPAQUE\\n\\t\\tgl_FragColor.a = 1.0;\\n\\t#endif\\n}\";\n\nconst vertex$6 = \"#define PHONG\\nvarying vec3 vViewPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvViewPosition = - mvPosition.xyz;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\nconst fragment$6 = \"#define PHONG\\nuniform vec3 diffuse;\\nuniform vec3 emissive;\\nuniform vec3 specular;\\nuniform float shininess;\\nuniform float opacity;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\tvec3 totalEmissiveRadiance = emissive;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$5 = \"#define STANDARD\\nvarying vec3 vViewPosition;\\n#ifdef USE_TRANSMISSION\\n\\tvarying vec3 vWorldPosition;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvViewPosition = - mvPosition.xyz;\\n\\t#include \\n\\t#include \\n\\t#include \\n#ifdef USE_TRANSMISSION\\n\\tvWorldPosition = worldPosition.xyz;\\n#endif\\n}\";\nconst fragment$5 = \"#define STANDARD\\n#ifdef PHYSICAL\\n\\t#define IOR\\n\\t#define SPECULAR\\n#endif\\nuniform vec3 diffuse;\\nuniform vec3 emissive;\\nuniform float roughness;\\nuniform float metalness;\\nuniform float opacity;\\n#ifdef IOR\\n\\tuniform float ior;\\n#endif\\n#ifdef SPECULAR\\n\\tuniform float specularIntensity;\\n\\tuniform vec3 specularColor;\\n\\t#ifdef USE_SPECULARINTENSITYMAP\\n\\t\\tuniform sampler2D specularIntensityMap;\\n\\t#endif\\n\\t#ifdef USE_SPECULARCOLORMAP\\n\\t\\tuniform sampler2D specularColorMap;\\n\\t#endif\\n#endif\\n#ifdef USE_CLEARCOAT\\n\\tuniform float clearcoat;\\n\\tuniform float clearcoatRoughness;\\n#endif\\n#ifdef USE_IRIDESCENCE\\n\\tuniform float iridescence;\\n\\tuniform float iridescenceIOR;\\n\\tuniform float iridescenceThicknessMinimum;\\n\\tuniform float iridescenceThicknessMaximum;\\n#endif\\n#ifdef USE_SHEEN\\n\\tuniform vec3 sheenColor;\\n\\tuniform float sheenRoughness;\\n\\t#ifdef USE_SHEENCOLORMAP\\n\\t\\tuniform sampler2D sheenColorMap;\\n\\t#endif\\n\\t#ifdef USE_SHEENROUGHNESSMAP\\n\\t\\tuniform sampler2D sheenRoughnessMap;\\n\\t#endif\\n#endif\\nvarying vec3 vViewPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\tvec3 totalEmissiveRadiance = emissive;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvec3 totalDiffuse = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse;\\n\\tvec3 totalSpecular = reflectedLight.directSpecular + reflectedLight.indirectSpecular;\\n\\t#include \\n\\tvec3 outgoingLight = totalDiffuse + totalSpecular + totalEmissiveRadiance;\\n\\t#ifdef USE_SHEEN\\n\\t\\tfloat sheenEnergyComp = 1.0 - 0.157 * max3( material.sheenColor );\\n\\t\\toutgoingLight = outgoingLight * sheenEnergyComp + sheenSpecular;\\n\\t#endif\\n\\t#ifdef USE_CLEARCOAT\\n\\t\\tfloat dotNVcc = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) );\\n\\t\\tvec3 Fcc = F_Schlick( material.clearcoatF0, material.clearcoatF90, dotNVcc );\\n\\t\\toutgoingLight = outgoingLight * ( 1.0 - material.clearcoat * Fcc ) + clearcoatSpecular * material.clearcoat;\\n\\t#endif\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$4 = \"#define TOON\\nvarying vec3 vViewPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvViewPosition = - mvPosition.xyz;\\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\nconst fragment$4 = \"#define TOON\\nuniform vec3 diffuse;\\nuniform vec3 emissive;\\nuniform float opacity;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\tvec3 totalEmissiveRadiance = emissive;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$3 = \"uniform float size;\\nuniform float scale;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tgl_PointSize = size;\\n\\t#ifdef USE_SIZEATTENUATION\\n\\t\\tbool isPerspective = isPerspectiveMatrix( projectionMatrix );\\n\\t\\tif ( isPerspective ) gl_PointSize *= ( scale / - mvPosition.z );\\n\\t#endif\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\nconst fragment$3 = \"uniform vec3 diffuse;\\nuniform float opacity;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec3 outgoingLight = vec3( 0.0 );\\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\toutgoingLight = diffuseColor.rgb;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$2 = \"#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\nconst fragment$2 = \"uniform vec3 color;\\nuniform float opacity;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\tgl_FragColor = vec4( color, opacity * ( 1.0 - getShadowMask() ) );\\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$1 = \"uniform float rotation;\\nuniform vec2 center;\\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 mvPosition = modelViewMatrix * vec4( 0.0, 0.0, 0.0, 1.0 );\\n\\tvec2 scale;\\n\\tscale.x = length( vec3( modelMatrix[ 0 ].x, modelMatrix[ 0 ].y, modelMatrix[ 0 ].z ) );\\n\\tscale.y = length( vec3( modelMatrix[ 1 ].x, modelMatrix[ 1 ].y, modelMatrix[ 1 ].z ) );\\n\\t#ifndef USE_SIZEATTENUATION\\n\\t\\tbool isPerspective = isPerspectiveMatrix( projectionMatrix );\\n\\t\\tif ( isPerspective ) scale *= - mvPosition.z;\\n\\t#endif\\n\\tvec2 alignedPosition = ( position.xy - ( center - vec2( 0.5 ) ) ) * scale;\\n\\tvec2 rotatedPosition;\\n\\trotatedPosition.x = cos( rotation ) * alignedPosition.x - sin( rotation ) * alignedPosition.y;\\n\\trotatedPosition.y = sin( rotation ) * alignedPosition.x + cos( rotation ) * alignedPosition.y;\\n\\tmvPosition.xy += rotatedPosition;\\n\\tgl_Position = projectionMatrix * mvPosition;\\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\nconst fragment$1 = \"uniform vec3 diffuse;\\nuniform float opacity;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec3 outgoingLight = vec3( 0.0 );\\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\toutgoingLight = diffuseColor.rgb;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst ShaderChunk = {\n\talphamap_fragment: alphamap_fragment,\n\talphamap_pars_fragment: alphamap_pars_fragment,\n\talphatest_fragment: alphatest_fragment,\n\talphatest_pars_fragment: alphatest_pars_fragment,\n\taomap_fragment: aomap_fragment,\n\taomap_pars_fragment: aomap_pars_fragment,\n\tbegin_vertex: begin_vertex,\n\tbeginnormal_vertex: beginnormal_vertex,\n\tbsdfs: bsdfs,\n\tiridescence_fragment: iridescence_fragment,\n\tbumpmap_pars_fragment: bumpmap_pars_fragment,\n\tclipping_planes_fragment: clipping_planes_fragment,\n\tclipping_planes_pars_fragment: clipping_planes_pars_fragment,\n\tclipping_planes_pars_vertex: clipping_planes_pars_vertex,\n\tclipping_planes_vertex: clipping_planes_vertex,\n\tcolor_fragment: color_fragment,\n\tcolor_pars_fragment: color_pars_fragment,\n\tcolor_pars_vertex: color_pars_vertex,\n\tcolor_vertex: color_vertex,\n\tcommon: common,\n\tcube_uv_reflection_fragment: cube_uv_reflection_fragment,\n\tdefaultnormal_vertex: defaultnormal_vertex,\n\tdisplacementmap_pars_vertex: displacementmap_pars_vertex,\n\tdisplacementmap_vertex: displacementmap_vertex,\n\temissivemap_fragment: emissivemap_fragment,\n\temissivemap_pars_fragment: emissivemap_pars_fragment,\n\tencodings_fragment: encodings_fragment,\n\tencodings_pars_fragment: encodings_pars_fragment,\n\tenvmap_fragment: envmap_fragment,\n\tenvmap_common_pars_fragment: envmap_common_pars_fragment,\n\tenvmap_pars_fragment: envmap_pars_fragment,\n\tenvmap_pars_vertex: envmap_pars_vertex,\n\tenvmap_physical_pars_fragment: envmap_physical_pars_fragment,\n\tenvmap_vertex: envmap_vertex,\n\tfog_vertex: fog_vertex,\n\tfog_pars_vertex: fog_pars_vertex,\n\tfog_fragment: fog_fragment,\n\tfog_pars_fragment: fog_pars_fragment,\n\tgradientmap_pars_fragment: gradientmap_pars_fragment,\n\tlightmap_fragment: lightmap_fragment,\n\tlightmap_pars_fragment: lightmap_pars_fragment,\n\tlights_lambert_vertex: lights_lambert_vertex,\n\tlights_pars_begin: lights_pars_begin,\n\tlights_toon_fragment: lights_toon_fragment,\n\tlights_toon_pars_fragment: lights_toon_pars_fragment,\n\tlights_phong_fragment: lights_phong_fragment,\n\tlights_phong_pars_fragment: lights_phong_pars_fragment,\n\tlights_physical_fragment: lights_physical_fragment,\n\tlights_physical_pars_fragment: lights_physical_pars_fragment,\n\tlights_fragment_begin: lights_fragment_begin,\n\tlights_fragment_maps: lights_fragment_maps,\n\tlights_fragment_end: lights_fragment_end,\n\tlogdepthbuf_fragment: logdepthbuf_fragment,\n\tlogdepthbuf_pars_fragment: logdepthbuf_pars_fragment,\n\tlogdepthbuf_pars_vertex: logdepthbuf_pars_vertex,\n\tlogdepthbuf_vertex: logdepthbuf_vertex,\n\tmap_fragment: map_fragment,\n\tmap_pars_fragment: map_pars_fragment,\n\tmap_particle_fragment: map_particle_fragment,\n\tmap_particle_pars_fragment: map_particle_pars_fragment,\n\tmetalnessmap_fragment: metalnessmap_fragment,\n\tmetalnessmap_pars_fragment: metalnessmap_pars_fragment,\n\tmorphcolor_vertex: morphcolor_vertex,\n\tmorphnormal_vertex: morphnormal_vertex,\n\tmorphtarget_pars_vertex: morphtarget_pars_vertex,\n\tmorphtarget_vertex: morphtarget_vertex,\n\tnormal_fragment_begin: normal_fragment_begin,\n\tnormal_fragment_maps: normal_fragment_maps,\n\tnormal_pars_fragment: normal_pars_fragment,\n\tnormal_pars_vertex: normal_pars_vertex,\n\tnormal_vertex: normal_vertex,\n\tnormalmap_pars_fragment: normalmap_pars_fragment,\n\tclearcoat_normal_fragment_begin: clearcoat_normal_fragment_begin,\n\tclearcoat_normal_fragment_maps: clearcoat_normal_fragment_maps,\n\tclearcoat_pars_fragment: clearcoat_pars_fragment,\n\tiridescence_pars_fragment: iridescence_pars_fragment,\n\toutput_fragment: output_fragment,\n\tpacking: packing,\n\tpremultiplied_alpha_fragment: premultiplied_alpha_fragment,\n\tproject_vertex: project_vertex,\n\tdithering_fragment: dithering_fragment,\n\tdithering_pars_fragment: dithering_pars_fragment,\n\troughnessmap_fragment: roughnessmap_fragment,\n\troughnessmap_pars_fragment: roughnessmap_pars_fragment,\n\tshadowmap_pars_fragment: shadowmap_pars_fragment,\n\tshadowmap_pars_vertex: shadowmap_pars_vertex,\n\tshadowmap_vertex: shadowmap_vertex,\n\tshadowmask_pars_fragment: shadowmask_pars_fragment,\n\tskinbase_vertex: skinbase_vertex,\n\tskinning_pars_vertex: skinning_pars_vertex,\n\tskinning_vertex: skinning_vertex,\n\tskinnormal_vertex: skinnormal_vertex,\n\tspecularmap_fragment: specularmap_fragment,\n\tspecularmap_pars_fragment: specularmap_pars_fragment,\n\ttonemapping_fragment: tonemapping_fragment,\n\ttonemapping_pars_fragment: tonemapping_pars_fragment,\n\ttransmission_fragment: transmission_fragment,\n\ttransmission_pars_fragment: transmission_pars_fragment,\n\tuv_pars_fragment: uv_pars_fragment,\n\tuv_pars_vertex: uv_pars_vertex,\n\tuv_vertex: uv_vertex,\n\tuv2_pars_fragment: uv2_pars_fragment,\n\tuv2_pars_vertex: uv2_pars_vertex,\n\tuv2_vertex: uv2_vertex,\n\tworldpos_vertex: worldpos_vertex,\n\tbackground_vert: vertex$g,\n\tbackground_frag: fragment$g,\n\tcube_vert: vertex$f,\n\tcube_frag: fragment$f,\n\tdepth_vert: vertex$e,\n\tdepth_frag: fragment$e,\n\tdistanceRGBA_vert: vertex$d,\n\tdistanceRGBA_frag: fragment$d,\n\tequirect_vert: vertex$c,\n\tequirect_frag: fragment$c,\n\tlinedashed_vert: vertex$b,\n\tlinedashed_frag: fragment$b,\n\tmeshbasic_vert: vertex$a,\n\tmeshbasic_frag: fragment$a,\n\tmeshlambert_vert: vertex$9,\n\tmeshlambert_frag: fragment$9,\n\tmeshmatcap_vert: vertex$8,\n\tmeshmatcap_frag: fragment$8,\n\tmeshnormal_vert: vertex$7,\n\tmeshnormal_frag: fragment$7,\n\tmeshphong_vert: vertex$6,\n\tmeshphong_frag: fragment$6,\n\tmeshphysical_vert: vertex$5,\n\tmeshphysical_frag: fragment$5,\n\tmeshtoon_vert: vertex$4,\n\tmeshtoon_frag: fragment$4,\n\tpoints_vert: vertex$3,\n\tpoints_frag: fragment$3,\n\tshadow_vert: vertex$2,\n\tshadow_frag: fragment$2,\n\tsprite_vert: vertex$1,\n\tsprite_frag: fragment$1\n};\n\n/**\n * Uniforms library for shared webgl shaders\n */\n\nconst UniformsLib = {\n\tcommon: {\n\t\tdiffuse: {\n\t\t\tvalue: new Color(0xffffff)\n\t\t},\n\t\topacity: {\n\t\t\tvalue: 1.0\n\t\t},\n\t\tmap: {\n\t\t\tvalue: null\n\t\t},\n\t\tuvTransform: {\n\t\t\tvalue: new Matrix3()\n\t\t},\n\t\tuv2Transform: {\n\t\t\tvalue: new Matrix3()\n\t\t},\n\t\talphaMap: {\n\t\t\tvalue: null\n\t\t},\n\t\talphaTest: {\n\t\t\tvalue: 0\n\t\t}\n\t},\n\tspecularmap: {\n\t\tspecularMap: {\n\t\t\tvalue: null\n\t\t}\n\t},\n\tenvmap: {\n\t\tenvMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tflipEnvMap: {\n\t\t\tvalue: -1\n\t\t},\n\t\treflectivity: {\n\t\t\tvalue: 1.0\n\t\t},\n\t\t// basic, lambert, phong\n\t\tior: {\n\t\t\tvalue: 1.5\n\t\t},\n\t\t// physical\n\t\trefractionRatio: {\n\t\t\tvalue: 0.98\n\t\t} // basic, lambert, phong\n\n\t},\n\taomap: {\n\t\taoMap: {\n\t\t\tvalue: null\n\t\t},\n\t\taoMapIntensity: {\n\t\t\tvalue: 1\n\t\t}\n\t},\n\tlightmap: {\n\t\tlightMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tlightMapIntensity: {\n\t\t\tvalue: 1\n\t\t}\n\t},\n\temissivemap: {\n\t\temissiveMap: {\n\t\t\tvalue: null\n\t\t}\n\t},\n\tbumpmap: {\n\t\tbumpMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tbumpScale: {\n\t\t\tvalue: 1\n\t\t}\n\t},\n\tnormalmap: {\n\t\tnormalMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tnormalScale: {\n\t\t\tvalue: new Vector2(1, 1)\n\t\t}\n\t},\n\tdisplacementmap: {\n\t\tdisplacementMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tdisplacementScale: {\n\t\t\tvalue: 1\n\t\t},\n\t\tdisplacementBias: {\n\t\t\tvalue: 0\n\t\t}\n\t},\n\troughnessmap: {\n\t\troughnessMap: {\n\t\t\tvalue: null\n\t\t}\n\t},\n\tmetalnessmap: {\n\t\tmetalnessMap: {\n\t\t\tvalue: null\n\t\t}\n\t},\n\tgradientmap: {\n\t\tgradientMap: {\n\t\t\tvalue: null\n\t\t}\n\t},\n\tfog: {\n\t\tfogDensity: {\n\t\t\tvalue: 0.00025\n\t\t},\n\t\tfogNear: {\n\t\t\tvalue: 1\n\t\t},\n\t\tfogFar: {\n\t\t\tvalue: 2000\n\t\t},\n\t\tfogColor: {\n\t\t\tvalue: new Color(0xffffff)\n\t\t}\n\t},\n\tlights: {\n\t\tambientLightColor: {\n\t\t\tvalue: []\n\t\t},\n\t\tlightProbe: {\n\t\t\tvalue: []\n\t\t},\n\t\tdirectionalLights: {\n\t\t\tvalue: [],\n\t\t\tproperties: {\n\t\t\t\tdirection: {},\n\t\t\t\tcolor: {}\n\t\t\t}\n\t\t},\n\t\tdirectionalLightShadows: {\n\t\t\tvalue: [],\n\t\t\tproperties: {\n\t\t\t\tshadowBias: {},\n\t\t\t\tshadowNormalBias: {},\n\t\t\t\tshadowRadius: {},\n\t\t\t\tshadowMapSize: {}\n\t\t\t}\n\t\t},\n\t\tdirectionalShadowMap: {\n\t\t\tvalue: []\n\t\t},\n\t\tdirectionalShadowMatrix: {\n\t\t\tvalue: []\n\t\t},\n\t\tspotLights: {\n\t\t\tvalue: [],\n\t\t\tproperties: {\n\t\t\t\tcolor: {},\n\t\t\t\tposition: {},\n\t\t\t\tdirection: {},\n\t\t\t\tdistance: {},\n\t\t\t\tconeCos: {},\n\t\t\t\tpenumbraCos: {},\n\t\t\t\tdecay: {}\n\t\t\t}\n\t\t},\n\t\tspotLightShadows: {\n\t\t\tvalue: [],\n\t\t\tproperties: {\n\t\t\t\tshadowBias: {},\n\t\t\t\tshadowNormalBias: {},\n\t\t\t\tshadowRadius: {},\n\t\t\t\tshadowMapSize: {}\n\t\t\t}\n\t\t},\n\t\tspotShadowMap: {\n\t\t\tvalue: []\n\t\t},\n\t\tspotShadowMatrix: {\n\t\t\tvalue: []\n\t\t},\n\t\tpointLights: {\n\t\t\tvalue: [],\n\t\t\tproperties: {\n\t\t\t\tcolor: {},\n\t\t\t\tposition: {},\n\t\t\t\tdecay: {},\n\t\t\t\tdistance: {}\n\t\t\t}\n\t\t},\n\t\tpointLightShadows: {\n\t\t\tvalue: [],\n\t\t\tproperties: {\n\t\t\t\tshadowBias: {},\n\t\t\t\tshadowNormalBias: {},\n\t\t\t\tshadowRadius: {},\n\t\t\t\tshadowMapSize: {},\n\t\t\t\tshadowCameraNear: {},\n\t\t\t\tshadowCameraFar: {}\n\t\t\t}\n\t\t},\n\t\tpointShadowMap: {\n\t\t\tvalue: []\n\t\t},\n\t\tpointShadowMatrix: {\n\t\t\tvalue: []\n\t\t},\n\t\themisphereLights: {\n\t\t\tvalue: [],\n\t\t\tproperties: {\n\t\t\t\tdirection: {},\n\t\t\t\tskyColor: {},\n\t\t\t\tgroundColor: {}\n\t\t\t}\n\t\t},\n\t\t// TODO (abelnation): RectAreaLight BRDF data needs to be moved from example to main src\n\t\trectAreaLights: {\n\t\t\tvalue: [],\n\t\t\tproperties: {\n\t\t\t\tcolor: {},\n\t\t\t\tposition: {},\n\t\t\t\twidth: {},\n\t\t\t\theight: {}\n\t\t\t}\n\t\t},\n\t\tltc_1: {\n\t\t\tvalue: null\n\t\t},\n\t\tltc_2: {\n\t\t\tvalue: null\n\t\t}\n\t},\n\tpoints: {\n\t\tdiffuse: {\n\t\t\tvalue: new Color(0xffffff)\n\t\t},\n\t\topacity: {\n\t\t\tvalue: 1.0\n\t\t},\n\t\tsize: {\n\t\t\tvalue: 1.0\n\t\t},\n\t\tscale: {\n\t\t\tvalue: 1.0\n\t\t},\n\t\tmap: {\n\t\t\tvalue: null\n\t\t},\n\t\talphaMap: {\n\t\t\tvalue: null\n\t\t},\n\t\talphaTest: {\n\t\t\tvalue: 0\n\t\t},\n\t\tuvTransform: {\n\t\t\tvalue: new Matrix3()\n\t\t}\n\t},\n\tsprite: {\n\t\tdiffuse: {\n\t\t\tvalue: new Color(0xffffff)\n\t\t},\n\t\topacity: {\n\t\t\tvalue: 1.0\n\t\t},\n\t\tcenter: {\n\t\t\tvalue: new Vector2(0.5, 0.5)\n\t\t},\n\t\trotation: {\n\t\t\tvalue: 0.0\n\t\t},\n\t\tmap: {\n\t\t\tvalue: null\n\t\t},\n\t\talphaMap: {\n\t\t\tvalue: null\n\t\t},\n\t\talphaTest: {\n\t\t\tvalue: 0\n\t\t},\n\t\tuvTransform: {\n\t\t\tvalue: new Matrix3()\n\t\t}\n\t}\n};\n\nconst ShaderLib = {\n\tbasic: {\n\t\tuniforms: mergeUniforms([UniformsLib.common, UniformsLib.specularmap, UniformsLib.envmap, UniformsLib.aomap, UniformsLib.lightmap, UniformsLib.fog]),\n\t\tvertexShader: ShaderChunk.meshbasic_vert,\n\t\tfragmentShader: ShaderChunk.meshbasic_frag\n\t},\n\tlambert: {\n\t\tuniforms: mergeUniforms([UniformsLib.common, UniformsLib.specularmap, UniformsLib.envmap, UniformsLib.aomap, UniformsLib.lightmap, UniformsLib.emissivemap, UniformsLib.fog, UniformsLib.lights, {\n\t\t\temissive: {\n\t\t\t\tvalue: new Color(0x000000)\n\t\t\t}\n\t\t}]),\n\t\tvertexShader: ShaderChunk.meshlambert_vert,\n\t\tfragmentShader: ShaderChunk.meshlambert_frag\n\t},\n\tphong: {\n\t\tuniforms: mergeUniforms([UniformsLib.common, UniformsLib.specularmap, UniformsLib.envmap, UniformsLib.aomap, UniformsLib.lightmap, UniformsLib.emissivemap, UniformsLib.bumpmap, UniformsLib.normalmap, UniformsLib.displacementmap, UniformsLib.fog, UniformsLib.lights, {\n\t\t\temissive: {\n\t\t\t\tvalue: new Color(0x000000)\n\t\t\t},\n\t\t\tspecular: {\n\t\t\t\tvalue: new Color(0x111111)\n\t\t\t},\n\t\t\tshininess: {\n\t\t\t\tvalue: 30\n\t\t\t}\n\t\t}]),\n\t\tvertexShader: ShaderChunk.meshphong_vert,\n\t\tfragmentShader: ShaderChunk.meshphong_frag\n\t},\n\tstandard: {\n\t\tuniforms: mergeUniforms([UniformsLib.common, UniformsLib.envmap, UniformsLib.aomap, UniformsLib.lightmap, UniformsLib.emissivemap, UniformsLib.bumpmap, UniformsLib.normalmap, UniformsLib.displacementmap, UniformsLib.roughnessmap, UniformsLib.metalnessmap, UniformsLib.fog, UniformsLib.lights, {\n\t\t\temissive: {\n\t\t\t\tvalue: new Color(0x000000)\n\t\t\t},\n\t\t\troughness: {\n\t\t\t\tvalue: 1.0\n\t\t\t},\n\t\t\tmetalness: {\n\t\t\t\tvalue: 0.0\n\t\t\t},\n\t\t\tenvMapIntensity: {\n\t\t\t\tvalue: 1\n\t\t\t} // temporary\n\n\t\t}]),\n\t\tvertexShader: ShaderChunk.meshphysical_vert,\n\t\tfragmentShader: ShaderChunk.meshphysical_frag\n\t},\n\ttoon: {\n\t\tuniforms: mergeUniforms([UniformsLib.common, UniformsLib.aomap, UniformsLib.lightmap, UniformsLib.emissivemap, UniformsLib.bumpmap, UniformsLib.normalmap, UniformsLib.displacementmap, UniformsLib.gradientmap, UniformsLib.fog, UniformsLib.lights, {\n\t\t\temissive: {\n\t\t\t\tvalue: new Color(0x000000)\n\t\t\t}\n\t\t}]),\n\t\tvertexShader: ShaderChunk.meshtoon_vert,\n\t\tfragmentShader: ShaderChunk.meshtoon_frag\n\t},\n\tmatcap: {\n\t\tuniforms: mergeUniforms([UniformsLib.common, UniformsLib.bumpmap, UniformsLib.normalmap, UniformsLib.displacementmap, UniformsLib.fog, {\n\t\t\tmatcap: {\n\t\t\t\tvalue: null\n\t\t\t}\n\t\t}]),\n\t\tvertexShader: ShaderChunk.meshmatcap_vert,\n\t\tfragmentShader: ShaderChunk.meshmatcap_frag\n\t},\n\tpoints: {\n\t\tuniforms: mergeUniforms([UniformsLib.points, UniformsLib.fog]),\n\t\tvertexShader: ShaderChunk.points_vert,\n\t\tfragmentShader: ShaderChunk.points_frag\n\t},\n\tdashed: {\n\t\tuniforms: mergeUniforms([UniformsLib.common, UniformsLib.fog, {\n\t\t\tscale: {\n\t\t\t\tvalue: 1\n\t\t\t},\n\t\t\tdashSize: {\n\t\t\t\tvalue: 1\n\t\t\t},\n\t\t\ttotalSize: {\n\t\t\t\tvalue: 2\n\t\t\t}\n\t\t}]),\n\t\tvertexShader: ShaderChunk.linedashed_vert,\n\t\tfragmentShader: ShaderChunk.linedashed_frag\n\t},\n\tdepth: {\n\t\tuniforms: mergeUniforms([UniformsLib.common, UniformsLib.displacementmap]),\n\t\tvertexShader: ShaderChunk.depth_vert,\n\t\tfragmentShader: ShaderChunk.depth_frag\n\t},\n\tnormal: {\n\t\tuniforms: mergeUniforms([UniformsLib.common, UniformsLib.bumpmap, UniformsLib.normalmap, UniformsLib.displacementmap, {\n\t\t\topacity: {\n\t\t\t\tvalue: 1.0\n\t\t\t}\n\t\t}]),\n\t\tvertexShader: ShaderChunk.meshnormal_vert,\n\t\tfragmentShader: ShaderChunk.meshnormal_frag\n\t},\n\tsprite: {\n\t\tuniforms: mergeUniforms([UniformsLib.sprite, UniformsLib.fog]),\n\t\tvertexShader: ShaderChunk.sprite_vert,\n\t\tfragmentShader: ShaderChunk.sprite_frag\n\t},\n\tbackground: {\n\t\tuniforms: {\n\t\t\tuvTransform: {\n\t\t\t\tvalue: new Matrix3()\n\t\t\t},\n\t\t\tt2D: {\n\t\t\t\tvalue: null\n\t\t\t}\n\t\t},\n\t\tvertexShader: ShaderChunk.background_vert,\n\t\tfragmentShader: ShaderChunk.background_frag\n\t},\n\n\t/* -------------------------------------------------------------------------\n\t//\tCube map shader\n\t ------------------------------------------------------------------------- */\n\tcube: {\n\t\tuniforms: mergeUniforms([UniformsLib.envmap, {\n\t\t\topacity: {\n\t\t\t\tvalue: 1.0\n\t\t\t}\n\t\t}]),\n\t\tvertexShader: ShaderChunk.cube_vert,\n\t\tfragmentShader: ShaderChunk.cube_frag\n\t},\n\tequirect: {\n\t\tuniforms: {\n\t\t\ttEquirect: {\n\t\t\t\tvalue: null\n\t\t\t}\n\t\t},\n\t\tvertexShader: ShaderChunk.equirect_vert,\n\t\tfragmentShader: ShaderChunk.equirect_frag\n\t},\n\tdistanceRGBA: {\n\t\tuniforms: mergeUniforms([UniformsLib.common, UniformsLib.displacementmap, {\n\t\t\treferencePosition: {\n\t\t\t\tvalue: new Vector3()\n\t\t\t},\n\t\t\tnearDistance: {\n\t\t\t\tvalue: 1\n\t\t\t},\n\t\t\tfarDistance: {\n\t\t\t\tvalue: 1000\n\t\t\t}\n\t\t}]),\n\t\tvertexShader: ShaderChunk.distanceRGBA_vert,\n\t\tfragmentShader: ShaderChunk.distanceRGBA_frag\n\t},\n\tshadow: {\n\t\tuniforms: mergeUniforms([UniformsLib.lights, UniformsLib.fog, {\n\t\t\tcolor: {\n\t\t\t\tvalue: new Color(0x00000)\n\t\t\t},\n\t\t\topacity: {\n\t\t\t\tvalue: 1.0\n\t\t\t}\n\t\t}]),\n\t\tvertexShader: ShaderChunk.shadow_vert,\n\t\tfragmentShader: ShaderChunk.shadow_frag\n\t}\n};\nShaderLib.physical = {\n\tuniforms: mergeUniforms([ShaderLib.standard.uniforms, {\n\t\tclearcoat: {\n\t\t\tvalue: 0\n\t\t},\n\t\tclearcoatMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tclearcoatRoughness: {\n\t\t\tvalue: 0\n\t\t},\n\t\tclearcoatRoughnessMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tclearcoatNormalScale: {\n\t\t\tvalue: new Vector2(1, 1)\n\t\t},\n\t\tclearcoatNormalMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tiridescence: {\n\t\t\tvalue: 0\n\t\t},\n\t\tiridescenceMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tiridescenceIOR: {\n\t\t\tvalue: 1.3\n\t\t},\n\t\tiridescenceThicknessMinimum: {\n\t\t\tvalue: 100\n\t\t},\n\t\tiridescenceThicknessMaximum: {\n\t\t\tvalue: 400\n\t\t},\n\t\tiridescenceThicknessMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tsheen: {\n\t\t\tvalue: 0\n\t\t},\n\t\tsheenColor: {\n\t\t\tvalue: new Color(0x000000)\n\t\t},\n\t\tsheenColorMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tsheenRoughness: {\n\t\t\tvalue: 1\n\t\t},\n\t\tsheenRoughnessMap: {\n\t\t\tvalue: null\n\t\t},\n\t\ttransmission: {\n\t\t\tvalue: 0\n\t\t},\n\t\ttransmissionMap: {\n\t\t\tvalue: null\n\t\t},\n\t\ttransmissionSamplerSize: {\n\t\t\tvalue: new Vector2()\n\t\t},\n\t\ttransmissionSamplerMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tthickness: {\n\t\t\tvalue: 0\n\t\t},\n\t\tthicknessMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tattenuationDistance: {\n\t\t\tvalue: 0\n\t\t},\n\t\tattenuationColor: {\n\t\t\tvalue: new Color(0x000000)\n\t\t},\n\t\tspecularIntensity: {\n\t\t\tvalue: 1\n\t\t},\n\t\tspecularIntensityMap: {\n\t\t\tvalue: null\n\t\t},\n\t\tspecularColor: {\n\t\t\tvalue: new Color(1, 1, 1)\n\t\t},\n\t\tspecularColorMap: {\n\t\t\tvalue: null\n\t\t}\n\t}]),\n\tvertexShader: ShaderChunk.meshphysical_vert,\n\tfragmentShader: ShaderChunk.meshphysical_frag\n};\n\nfunction WebGLBackground(renderer, cubemaps, state, objects, alpha, premultipliedAlpha) {\n\tconst clearColor = new Color(0x000000);\n\tlet clearAlpha = alpha === true ? 0 : 1;\n\tlet planeMesh;\n\tlet boxMesh;\n\tlet currentBackground = null;\n\tlet currentBackgroundVersion = 0;\n\tlet currentTonemapping = null;\n\n\tfunction render(renderList, scene) {\n\t\tlet forceClear = false;\n\t\tlet background = scene.isScene === true ? scene.background : null;\n\n\t\tif (background && background.isTexture) {\n\t\t\tbackground = cubemaps.get(background);\n\t\t} // Ignore background in AR\n\t\t// TODO: Reconsider this.\n\n\n\t\tconst xr = renderer.xr;\n\t\tconst session = xr.getSession && xr.getSession();\n\n\t\tif (session && session.environmentBlendMode === 'additive') {\n\t\t\tbackground = null;\n\t\t}\n\n\t\tif (background === null) {\n\t\t\tsetClear(clearColor, clearAlpha);\n\t\t} else if (background && background.isColor) {\n\t\t\tsetClear(background, 1);\n\t\t\tforceClear = true;\n\t\t}\n\n\t\tif (renderer.autoClear || forceClear) {\n\t\t\trenderer.clear(renderer.autoClearColor, renderer.autoClearDepth, renderer.autoClearStencil);\n\t\t}\n\n\t\tif (background && (background.isCubeTexture || background.mapping === CubeUVReflectionMapping)) {\n\t\t\tif (boxMesh === undefined) {\n\t\t\t\tboxMesh = new Mesh(new BoxGeometry(1, 1, 1), new ShaderMaterial({\n\t\t\t\t\tname: 'BackgroundCubeMaterial',\n\t\t\t\t\tuniforms: cloneUniforms(ShaderLib.cube.uniforms),\n\t\t\t\t\tvertexShader: ShaderLib.cube.vertexShader,\n\t\t\t\t\tfragmentShader: ShaderLib.cube.fragmentShader,\n\t\t\t\t\tside: BackSide,\n\t\t\t\t\tdepthTest: false,\n\t\t\t\t\tdepthWrite: false,\n\t\t\t\t\tfog: false\n\t\t\t\t}));\n\t\t\t\tboxMesh.geometry.deleteAttribute('normal');\n\t\t\t\tboxMesh.geometry.deleteAttribute('uv');\n\n\t\t\t\tboxMesh.onBeforeRender = function (renderer, scene, camera) {\n\t\t\t\t\tthis.matrixWorld.copyPosition(camera.matrixWorld);\n\t\t\t\t}; // enable code injection for non-built-in material\n\n\n\t\t\t\tObject.defineProperty(boxMesh.material, 'envMap', {\n\t\t\t\t\tget: function () {\n\t\t\t\t\t\treturn this.uniforms.envMap.value;\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tobjects.update(boxMesh);\n\t\t\t}\n\n\t\t\tboxMesh.material.uniforms.envMap.value = background;\n\t\t\tboxMesh.material.uniforms.flipEnvMap.value = background.isCubeTexture && background.isRenderTargetTexture === false ? -1 : 1;\n\n\t\t\tif (currentBackground !== background || currentBackgroundVersion !== background.version || currentTonemapping !== renderer.toneMapping) {\n\t\t\t\tboxMesh.material.needsUpdate = true;\n\t\t\t\tcurrentBackground = background;\n\t\t\t\tcurrentBackgroundVersion = background.version;\n\t\t\t\tcurrentTonemapping = renderer.toneMapping;\n\t\t\t}\n\n\t\t\tboxMesh.layers.enableAll(); // push to the pre-sorted opaque render list\n\n\t\t\trenderList.unshift(boxMesh, boxMesh.geometry, boxMesh.material, 0, 0, null);\n\t\t} else if (background && background.isTexture) {\n\t\t\tif (planeMesh === undefined) {\n\t\t\t\tplaneMesh = new Mesh(new PlaneGeometry(2, 2), new ShaderMaterial({\n\t\t\t\t\tname: 'BackgroundMaterial',\n\t\t\t\t\tuniforms: cloneUniforms(ShaderLib.background.uniforms),\n\t\t\t\t\tvertexShader: ShaderLib.background.vertexShader,\n\t\t\t\t\tfragmentShader: ShaderLib.background.fragmentShader,\n\t\t\t\t\tside: FrontSide,\n\t\t\t\t\tdepthTest: false,\n\t\t\t\t\tdepthWrite: false,\n\t\t\t\t\tfog: false\n\t\t\t\t}));\n\t\t\t\tplaneMesh.geometry.deleteAttribute('normal'); // enable code injection for non-built-in material\n\n\t\t\t\tObject.defineProperty(planeMesh.material, 'map', {\n\t\t\t\t\tget: function () {\n\t\t\t\t\t\treturn this.uniforms.t2D.value;\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tobjects.update(planeMesh);\n\t\t\t}\n\n\t\t\tplaneMesh.material.uniforms.t2D.value = background;\n\n\t\t\tif (background.matrixAutoUpdate === true) {\n\t\t\t\tbackground.updateMatrix();\n\t\t\t}\n\n\t\t\tplaneMesh.material.uniforms.uvTransform.value.copy(background.matrix);\n\n\t\t\tif (currentBackground !== background || currentBackgroundVersion !== background.version || currentTonemapping !== renderer.toneMapping) {\n\t\t\t\tplaneMesh.material.needsUpdate = true;\n\t\t\t\tcurrentBackground = background;\n\t\t\t\tcurrentBackgroundVersion = background.version;\n\t\t\t\tcurrentTonemapping = renderer.toneMapping;\n\t\t\t}\n\n\t\t\tplaneMesh.layers.enableAll(); // push to the pre-sorted opaque render list\n\n\t\t\trenderList.unshift(planeMesh, planeMesh.geometry, planeMesh.material, 0, 0, null);\n\t\t}\n\t}\n\n\tfunction setClear(color, alpha) {\n\t\tstate.buffers.color.setClear(color.r, color.g, color.b, alpha, premultipliedAlpha);\n\t}\n\n\treturn {\n\t\tgetClearColor: function () {\n\t\t\treturn clearColor;\n\t\t},\n\t\tsetClearColor: function (color, alpha = 1) {\n\t\t\tclearColor.set(color);\n\t\t\tclearAlpha = alpha;\n\t\t\tsetClear(clearColor, clearAlpha);\n\t\t},\n\t\tgetClearAlpha: function () {\n\t\t\treturn clearAlpha;\n\t\t},\n\t\tsetClearAlpha: function (alpha) {\n\t\t\tclearAlpha = alpha;\n\t\t\tsetClear(clearColor, clearAlpha);\n\t\t},\n\t\trender: render\n\t};\n}\n\nfunction WebGLBindingStates(gl, extensions, attributes, capabilities) {\n\tconst maxVertexAttributes = gl.getParameter(gl.MAX_VERTEX_ATTRIBS);\n\tconst extension = capabilities.isWebGL2 ? null : extensions.get('OES_vertex_array_object');\n\tconst vaoAvailable = capabilities.isWebGL2 || extension !== null;\n\tconst bindingStates = {};\n\tconst defaultState = createBindingState(null);\n\tlet currentState = defaultState;\n\tlet forceUpdate = false;\n\n\tfunction setup(object, material, program, geometry, index) {\n\t\tlet updateBuffers = false;\n\n\t\tif (vaoAvailable) {\n\t\t\tconst state = getBindingState(geometry, program, material);\n\n\t\t\tif (currentState !== state) {\n\t\t\t\tcurrentState = state;\n\t\t\t\tbindVertexArrayObject(currentState.object);\n\t\t\t}\n\n\t\t\tupdateBuffers = needsUpdate(object, geometry, program, index);\n\t\t\tif (updateBuffers) saveCache(object, geometry, program, index);\n\t\t} else {\n\t\t\tconst wireframe = material.wireframe === true;\n\n\t\t\tif (currentState.geometry !== geometry.id || currentState.program !== program.id || currentState.wireframe !== wireframe) {\n\t\t\t\tcurrentState.geometry = geometry.id;\n\t\t\t\tcurrentState.program = program.id;\n\t\t\t\tcurrentState.wireframe = wireframe;\n\t\t\t\tupdateBuffers = true;\n\t\t\t}\n\t\t}\n\n\t\tif (index !== null) {\n\t\t\tattributes.update(index, gl.ELEMENT_ARRAY_BUFFER);\n\t\t}\n\n\t\tif (updateBuffers || forceUpdate) {\n\t\t\tforceUpdate = false;\n\t\t\tsetupVertexAttributes(object, material, program, geometry);\n\n\t\t\tif (index !== null) {\n\t\t\t\tgl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, attributes.get(index).buffer);\n\t\t\t}\n\t\t}\n\t}\n\n\tfunction createVertexArrayObject() {\n\t\tif (capabilities.isWebGL2) return gl.createVertexArray();\n\t\treturn extension.createVertexArrayOES();\n\t}\n\n\tfunction bindVertexArrayObject(vao) {\n\t\tif (capabilities.isWebGL2) return gl.bindVertexArray(vao);\n\t\treturn extension.bindVertexArrayOES(vao);\n\t}\n\n\tfunction deleteVertexArrayObject(vao) {\n\t\tif (capabilities.isWebGL2) return gl.deleteVertexArray(vao);\n\t\treturn extension.deleteVertexArrayOES(vao);\n\t}\n\n\tfunction getBindingState(geometry, program, material) {\n\t\tconst wireframe = material.wireframe === true;\n\t\tlet programMap = bindingStates[geometry.id];\n\n\t\tif (programMap === undefined) {\n\t\t\tprogramMap = {};\n\t\t\tbindingStates[geometry.id] = programMap;\n\t\t}\n\n\t\tlet stateMap = programMap[program.id];\n\n\t\tif (stateMap === undefined) {\n\t\t\tstateMap = {};\n\t\t\tprogramMap[program.id] = stateMap;\n\t\t}\n\n\t\tlet state = stateMap[wireframe];\n\n\t\tif (state === undefined) {\n\t\t\tstate = createBindingState(createVertexArrayObject());\n\t\t\tstateMap[wireframe] = state;\n\t\t}\n\n\t\treturn state;\n\t}\n\n\tfunction createBindingState(vao) {\n\t\tconst newAttributes = [];\n\t\tconst enabledAttributes = [];\n\t\tconst attributeDivisors = [];\n\n\t\tfor (let i = 0; i < maxVertexAttributes; i++) {\n\t\t\tnewAttributes[i] = 0;\n\t\t\tenabledAttributes[i] = 0;\n\t\t\tattributeDivisors[i] = 0;\n\t\t}\n\n\t\treturn {\n\t\t\t// for backward compatibility on non-VAO support browser\n\t\t\tgeometry: null,\n\t\t\tprogram: null,\n\t\t\twireframe: false,\n\t\t\tnewAttributes: newAttributes,\n\t\t\tenabledAttributes: enabledAttributes,\n\t\t\tattributeDivisors: attributeDivisors,\n\t\t\tobject: vao,\n\t\t\tattributes: {},\n\t\t\tindex: null\n\t\t};\n\t}\n\n\tfunction needsUpdate(object, geometry, program, index) {\n\t\tconst cachedAttributes = currentState.attributes;\n\t\tconst geometryAttributes = geometry.attributes;\n\t\tlet attributesNum = 0;\n\t\tconst programAttributes = program.getAttributes();\n\n\t\tfor (const name in programAttributes) {\n\t\t\tconst programAttribute = programAttributes[name];\n\n\t\t\tif (programAttribute.location >= 0) {\n\t\t\t\tconst cachedAttribute = cachedAttributes[name];\n\t\t\t\tlet geometryAttribute = geometryAttributes[name];\n\n\t\t\t\tif (geometryAttribute === undefined) {\n\t\t\t\t\tif (name === 'instanceMatrix' && object.instanceMatrix) geometryAttribute = object.instanceMatrix;\n\t\t\t\t\tif (name === 'instanceColor' && object.instanceColor) geometryAttribute = object.instanceColor;\n\t\t\t\t}\n\n\t\t\t\tif (cachedAttribute === undefined) return true;\n\t\t\t\tif (cachedAttribute.attribute !== geometryAttribute) return true;\n\t\t\t\tif (geometryAttribute && cachedAttribute.data !== geometryAttribute.data) return true;\n\t\t\t\tattributesNum++;\n\t\t\t}\n\t\t}\n\n\t\tif (currentState.attributesNum !== attributesNum) return true;\n\t\tif (currentState.index !== index) return true;\n\t\treturn false;\n\t}\n\n\tfunction saveCache(object, geometry, program, index) {\n\t\tconst cache = {};\n\t\tconst attributes = geometry.attributes;\n\t\tlet attributesNum = 0;\n\t\tconst programAttributes = program.getAttributes();\n\n\t\tfor (const name in programAttributes) {\n\t\t\tconst programAttribute = programAttributes[name];\n\n\t\t\tif (programAttribute.location >= 0) {\n\t\t\t\tlet attribute = attributes[name];\n\n\t\t\t\tif (attribute === undefined) {\n\t\t\t\t\tif (name === 'instanceMatrix' && object.instanceMatrix) attribute = object.instanceMatrix;\n\t\t\t\t\tif (name === 'instanceColor' && object.instanceColor) attribute = object.instanceColor;\n\t\t\t\t}\n\n\t\t\t\tconst data = {};\n\t\t\t\tdata.attribute = attribute;\n\n\t\t\t\tif (attribute && attribute.data) {\n\t\t\t\t\tdata.data = attribute.data;\n\t\t\t\t}\n\n\t\t\t\tcache[name] = data;\n\t\t\t\tattributesNum++;\n\t\t\t}\n\t\t}\n\n\t\tcurrentState.attributes = cache;\n\t\tcurrentState.attributesNum = attributesNum;\n\t\tcurrentState.index = index;\n\t}\n\n\tfunction initAttributes() {\n\t\tconst newAttributes = currentState.newAttributes;\n\n\t\tfor (let i = 0, il = newAttributes.length; i < il; i++) {\n\t\t\tnewAttributes[i] = 0;\n\t\t}\n\t}\n\n\tfunction enableAttribute(attribute) {\n\t\tenableAttributeAndDivisor(attribute, 0);\n\t}\n\n\tfunction enableAttributeAndDivisor(attribute, meshPerAttribute) {\n\t\tconst newAttributes = currentState.newAttributes;\n\t\tconst enabledAttributes = currentState.enabledAttributes;\n\t\tconst attributeDivisors = currentState.attributeDivisors;\n\t\tnewAttributes[attribute] = 1;\n\n\t\tif (enabledAttributes[attribute] === 0) {\n\t\t\tgl.enableVertexAttribArray(attribute);\n\t\t\tenabledAttributes[attribute] = 1;\n\t\t}\n\n\t\tif (attributeDivisors[attribute] !== meshPerAttribute) {\n\t\t\tconst extension = capabilities.isWebGL2 ? gl : extensions.get('ANGLE_instanced_arrays');\n\t\t\textension[capabilities.isWebGL2 ? 'vertexAttribDivisor' : 'vertexAttribDivisorANGLE'](attribute, meshPerAttribute);\n\t\t\tattributeDivisors[attribute] = meshPerAttribute;\n\t\t}\n\t}\n\n\tfunction disableUnusedAttributes() {\n\t\tconst newAttributes = currentState.newAttributes;\n\t\tconst enabledAttributes = currentState.enabledAttributes;\n\n\t\tfor (let i = 0, il = enabledAttributes.length; i < il; i++) {\n\t\t\tif (enabledAttributes[i] !== newAttributes[i]) {\n\t\t\t\tgl.disableVertexAttribArray(i);\n\t\t\t\tenabledAttributes[i] = 0;\n\t\t\t}\n\t\t}\n\t}\n\n\tfunction vertexAttribPointer(index, size, type, normalized, stride, offset) {\n\t\tif (capabilities.isWebGL2 === true && (type === gl.INT || type === gl.UNSIGNED_INT)) {\n\t\t\tgl.vertexAttribIPointer(index, size, type, stride, offset);\n\t\t} else {\n\t\t\tgl.vertexAttribPointer(index, size, type, normalized, stride, offset);\n\t\t}\n\t}\n\n\tfunction setupVertexAttributes(object, material, program, geometry) {\n\t\tif (capabilities.isWebGL2 === false && (object.isInstancedMesh || geometry.isInstancedBufferGeometry)) {\n\t\t\tif (extensions.get('ANGLE_instanced_arrays') === null) return;\n\t\t}\n\n\t\tinitAttributes();\n\t\tconst geometryAttributes = geometry.attributes;\n\t\tconst programAttributes = program.getAttributes();\n\t\tconst materialDefaultAttributeValues = material.defaultAttributeValues;\n\n\t\tfor (const name in programAttributes) {\n\t\t\tconst programAttribute = programAttributes[name];\n\n\t\t\tif (programAttribute.location >= 0) {\n\t\t\t\tlet geometryAttribute = geometryAttributes[name];\n\n\t\t\t\tif (geometryAttribute === undefined) {\n\t\t\t\t\tif (name === 'instanceMatrix' && object.instanceMatrix) geometryAttribute = object.instanceMatrix;\n\t\t\t\t\tif (name === 'instanceColor' && object.instanceColor) geometryAttribute = object.instanceColor;\n\t\t\t\t}\n\n\t\t\t\tif (geometryAttribute !== undefined) {\n\t\t\t\t\tconst normalized = geometryAttribute.normalized;\n\t\t\t\t\tconst size = geometryAttribute.itemSize;\n\t\t\t\t\tconst attribute = attributes.get(geometryAttribute); // TODO Attribute may not be available on context restore\n\n\t\t\t\t\tif (attribute === undefined) continue;\n\t\t\t\t\tconst buffer = attribute.buffer;\n\t\t\t\t\tconst type = attribute.type;\n\t\t\t\t\tconst bytesPerElement = attribute.bytesPerElement;\n\n\t\t\t\t\tif (geometryAttribute.isInterleavedBufferAttribute) {\n\t\t\t\t\t\tconst data = geometryAttribute.data;\n\t\t\t\t\t\tconst stride = data.stride;\n\t\t\t\t\t\tconst offset = geometryAttribute.offset;\n\n\t\t\t\t\t\tif (data.isInstancedInterleavedBuffer) {\n\t\t\t\t\t\t\tfor (let i = 0; i < programAttribute.locationSize; i++) {\n\t\t\t\t\t\t\t\tenableAttributeAndDivisor(programAttribute.location + i, data.meshPerAttribute);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (object.isInstancedMesh !== true && geometry._maxInstanceCount === undefined) {\n\t\t\t\t\t\t\t\tgeometry._maxInstanceCount = data.meshPerAttribute * data.count;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tfor (let i = 0; i < programAttribute.locationSize; i++) {\n\t\t\t\t\t\t\t\tenableAttribute(programAttribute.location + i);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tgl.bindBuffer(gl.ARRAY_BUFFER, buffer);\n\n\t\t\t\t\t\tfor (let i = 0; i < programAttribute.locationSize; i++) {\n\t\t\t\t\t\t\tvertexAttribPointer(programAttribute.location + i, size / programAttribute.locationSize, type, normalized, stride * bytesPerElement, (offset + size / programAttribute.locationSize * i) * bytesPerElement);\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tif (geometryAttribute.isInstancedBufferAttribute) {\n\t\t\t\t\t\t\tfor (let i = 0; i < programAttribute.locationSize; i++) {\n\t\t\t\t\t\t\t\tenableAttributeAndDivisor(programAttribute.location + i, geometryAttribute.meshPerAttribute);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (object.isInstancedMesh !== true && geometry._maxInstanceCount === undefined) {\n\t\t\t\t\t\t\t\tgeometry._maxInstanceCount = geometryAttribute.meshPerAttribute * geometryAttribute.count;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tfor (let i = 0; i < programAttribute.locationSize; i++) {\n\t\t\t\t\t\t\t\tenableAttribute(programAttribute.location + i);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tgl.bindBuffer(gl.ARRAY_BUFFER, buffer);\n\n\t\t\t\t\t\tfor (let i = 0; i < programAttribute.locationSize; i++) {\n\t\t\t\t\t\t\tvertexAttribPointer(programAttribute.location + i, size / programAttribute.locationSize, type, normalized, size * bytesPerElement, size / programAttribute.locationSize * i * bytesPerElement);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} else if (materialDefaultAttributeValues !== undefined) {\n\t\t\t\t\tconst value = materialDefaultAttributeValues[name];\n\n\t\t\t\t\tif (value !== undefined) {\n\t\t\t\t\t\tswitch (value.length) {\n\t\t\t\t\t\t\tcase 2:\n\t\t\t\t\t\t\t\tgl.vertexAttrib2fv(programAttribute.location, value);\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase 3:\n\t\t\t\t\t\t\t\tgl.vertexAttrib3fv(programAttribute.location, value);\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase 4:\n\t\t\t\t\t\t\t\tgl.vertexAttrib4fv(programAttribute.location, value);\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\tgl.vertexAttrib1fv(programAttribute.location, value);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tdisableUnusedAttributes();\n\t}\n\n\tfunction dispose() {\n\t\treset();\n\n\t\tfor (const geometryId in bindingStates) {\n\t\t\tconst programMap = bindingStates[geometryId];\n\n\t\t\tfor (const programId in programMap) {\n\t\t\t\tconst stateMap = programMap[programId];\n\n\t\t\t\tfor (const wireframe in stateMap) {\n\t\t\t\t\tdeleteVertexArrayObject(stateMap[wireframe].object);\n\t\t\t\t\tdelete stateMap[wireframe];\n\t\t\t\t}\n\n\t\t\t\tdelete programMap[programId];\n\t\t\t}\n\n\t\t\tdelete bindingStates[geometryId];\n\t\t}\n\t}\n\n\tfunction releaseStatesOfGeometry(geometry) {\n\t\tif (bindingStates[geometry.id] === undefined) return;\n\t\tconst programMap = bindingStates[geometry.id];\n\n\t\tfor (const programId in programMap) {\n\t\t\tconst stateMap = programMap[programId];\n\n\t\t\tfor (const wireframe in stateMap) {\n\t\t\t\tdeleteVertexArrayObject(stateMap[wireframe].object);\n\t\t\t\tdelete stateMap[wireframe];\n\t\t\t}\n\n\t\t\tdelete programMap[programId];\n\t\t}\n\n\t\tdelete bindingStates[geometry.id];\n\t}\n\n\tfunction releaseStatesOfProgram(program) {\n\t\tfor (const geometryId in bindingStates) {\n\t\t\tconst programMap = bindingStates[geometryId];\n\t\t\tif (programMap[program.id] === undefined) continue;\n\t\t\tconst stateMap = programMap[program.id];\n\n\t\t\tfor (const wireframe in stateMap) {\n\t\t\t\tdeleteVertexArrayObject(stateMap[wireframe].object);\n\t\t\t\tdelete stateMap[wireframe];\n\t\t\t}\n\n\t\t\tdelete programMap[program.id];\n\t\t}\n\t}\n\n\tfunction reset() {\n\t\tresetDefaultState();\n\t\tforceUpdate = true;\n\t\tif (currentState === defaultState) return;\n\t\tcurrentState = defaultState;\n\t\tbindVertexArrayObject(currentState.object);\n\t} // for backward-compatibility\n\n\n\tfunction resetDefaultState() {\n\t\tdefaultState.geometry = null;\n\t\tdefaultState.program = null;\n\t\tdefaultState.wireframe = false;\n\t}\n\n\treturn {\n\t\tsetup: setup,\n\t\treset: reset,\n\t\tresetDefaultState: resetDefaultState,\n\t\tdispose: dispose,\n\t\treleaseStatesOfGeometry: releaseStatesOfGeometry,\n\t\treleaseStatesOfProgram: releaseStatesOfProgram,\n\t\tinitAttributes: initAttributes,\n\t\tenableAttribute: enableAttribute,\n\t\tdisableUnusedAttributes: disableUnusedAttributes\n\t};\n}\n\nfunction WebGLBufferRenderer(gl, extensions, info, capabilities) {\n\tconst isWebGL2 = capabilities.isWebGL2;\n\tlet mode;\n\n\tfunction setMode(value) {\n\t\tmode = value;\n\t}\n\n\tfunction render(start, count) {\n\t\tgl.drawArrays(mode, start, count);\n\t\tinfo.update(count, mode, 1);\n\t}\n\n\tfunction renderInstances(start, count, primcount) {\n\t\tif (primcount === 0) return;\n\t\tlet extension, methodName;\n\n\t\tif (isWebGL2) {\n\t\t\textension = gl;\n\t\t\tmethodName = 'drawArraysInstanced';\n\t\t} else {\n\t\t\textension = extensions.get('ANGLE_instanced_arrays');\n\t\t\tmethodName = 'drawArraysInstancedANGLE';\n\n\t\t\tif (extension === null) {\n\t\t\t\tconsole.error('THREE.WebGLBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.');\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\textension[methodName](mode, start, count, primcount);\n\t\tinfo.update(count, mode, primcount);\n\t} //\n\n\n\tthis.setMode = setMode;\n\tthis.render = render;\n\tthis.renderInstances = renderInstances;\n}\n\nfunction WebGLCapabilities(gl, extensions, parameters) {\n\tlet maxAnisotropy;\n\n\tfunction getMaxAnisotropy() {\n\t\tif (maxAnisotropy !== undefined) return maxAnisotropy;\n\n\t\tif (extensions.has('EXT_texture_filter_anisotropic') === true) {\n\t\t\tconst extension = extensions.get('EXT_texture_filter_anisotropic');\n\t\t\tmaxAnisotropy = gl.getParameter(extension.MAX_TEXTURE_MAX_ANISOTROPY_EXT);\n\t\t} else {\n\t\t\tmaxAnisotropy = 0;\n\t\t}\n\n\t\treturn maxAnisotropy;\n\t}\n\n\tfunction getMaxPrecision(precision) {\n\t\tif (precision === 'highp') {\n\t\t\tif (gl.getShaderPrecisionFormat(gl.VERTEX_SHADER, gl.HIGH_FLOAT).precision > 0 && gl.getShaderPrecisionFormat(gl.FRAGMENT_SHADER, gl.HIGH_FLOAT).precision > 0) {\n\t\t\t\treturn 'highp';\n\t\t\t}\n\n\t\t\tprecision = 'mediump';\n\t\t}\n\n\t\tif (precision === 'mediump') {\n\t\t\tif (gl.getShaderPrecisionFormat(gl.VERTEX_SHADER, gl.MEDIUM_FLOAT).precision > 0 && gl.getShaderPrecisionFormat(gl.FRAGMENT_SHADER, gl.MEDIUM_FLOAT).precision > 0) {\n\t\t\t\treturn 'mediump';\n\t\t\t}\n\t\t}\n\n\t\treturn 'lowp';\n\t}\n\n\tconst isWebGL2 = typeof WebGL2RenderingContext !== 'undefined' && gl instanceof WebGL2RenderingContext || typeof WebGL2ComputeRenderingContext !== 'undefined' && gl instanceof WebGL2ComputeRenderingContext;\n\tlet precision = parameters.precision !== undefined ? parameters.precision : 'highp';\n\tconst maxPrecision = getMaxPrecision(precision);\n\n\tif (maxPrecision !== precision) {\n\t\tconsole.warn('THREE.WebGLRenderer:', precision, 'not supported, using', maxPrecision, 'instead.');\n\t\tprecision = maxPrecision;\n\t}\n\n\tconst drawBuffers = isWebGL2 || extensions.has('WEBGL_draw_buffers');\n\tconst logarithmicDepthBuffer = parameters.logarithmicDepthBuffer === true;\n\tconst maxTextures = gl.getParameter(gl.MAX_TEXTURE_IMAGE_UNITS);\n\tconst maxVertexTextures = gl.getParameter(gl.MAX_VERTEX_TEXTURE_IMAGE_UNITS);\n\tconst maxTextureSize = gl.getParameter(gl.MAX_TEXTURE_SIZE);\n\tconst maxCubemapSize = gl.getParameter(gl.MAX_CUBE_MAP_TEXTURE_SIZE);\n\tconst maxAttributes = gl.getParameter(gl.MAX_VERTEX_ATTRIBS);\n\tconst maxVertexUniforms = gl.getParameter(gl.MAX_VERTEX_UNIFORM_VECTORS);\n\tconst maxVaryings = gl.getParameter(gl.MAX_VARYING_VECTORS);\n\tconst maxFragmentUniforms = gl.getParameter(gl.MAX_FRAGMENT_UNIFORM_VECTORS);\n\tconst vertexTextures = maxVertexTextures > 0;\n\tconst floatFragmentTextures = isWebGL2 || extensions.has('OES_texture_float');\n\tconst floatVertexTextures = vertexTextures && floatFragmentTextures;\n\tconst maxSamples = isWebGL2 ? gl.getParameter(gl.MAX_SAMPLES) : 0;\n\treturn {\n\t\tisWebGL2: isWebGL2,\n\t\tdrawBuffers: drawBuffers,\n\t\tgetMaxAnisotropy: getMaxAnisotropy,\n\t\tgetMaxPrecision: getMaxPrecision,\n\t\tprecision: precision,\n\t\tlogarithmicDepthBuffer: logarithmicDepthBuffer,\n\t\tmaxTextures: maxTextures,\n\t\tmaxVertexTextures: maxVertexTextures,\n\t\tmaxTextureSize: maxTextureSize,\n\t\tmaxCubemapSize: maxCubemapSize,\n\t\tmaxAttributes: maxAttributes,\n\t\tmaxVertexUniforms: maxVertexUniforms,\n\t\tmaxVaryings: maxVaryings,\n\t\tmaxFragmentUniforms: maxFragmentUniforms,\n\t\tvertexTextures: vertexTextures,\n\t\tfloatFragmentTextures: floatFragmentTextures,\n\t\tfloatVertexTextures: floatVertexTextures,\n\t\tmaxSamples: maxSamples\n\t};\n}\n\nfunction WebGLClipping(properties) {\n\tconst scope = this;\n\tlet globalState = null,\n\t\t\tnumGlobalPlanes = 0,\n\t\t\tlocalClippingEnabled = false,\n\t\t\trenderingShadows = false;\n\tconst plane = new Plane(),\n\t\t\t\tviewNormalMatrix = new Matrix3(),\n\t\t\t\tuniform = {\n\t\tvalue: null,\n\t\tneedsUpdate: false\n\t};\n\tthis.uniform = uniform;\n\tthis.numPlanes = 0;\n\tthis.numIntersection = 0;\n\n\tthis.init = function (planes, enableLocalClipping, camera) {\n\t\tconst enabled = planes.length !== 0 || enableLocalClipping || // enable state of previous frame - the clipping code has to\n\t\t// run another frame in order to reset the state:\n\t\tnumGlobalPlanes !== 0 || localClippingEnabled;\n\t\tlocalClippingEnabled = enableLocalClipping;\n\t\tglobalState = projectPlanes(planes, camera, 0);\n\t\tnumGlobalPlanes = planes.length;\n\t\treturn enabled;\n\t};\n\n\tthis.beginShadows = function () {\n\t\trenderingShadows = true;\n\t\tprojectPlanes(null);\n\t};\n\n\tthis.endShadows = function () {\n\t\trenderingShadows = false;\n\t\tresetGlobalState();\n\t};\n\n\tthis.setState = function (material, camera, useCache) {\n\t\tconst planes = material.clippingPlanes,\n\t\t\t\t\tclipIntersection = material.clipIntersection,\n\t\t\t\t\tclipShadows = material.clipShadows;\n\t\tconst materialProperties = properties.get(material);\n\n\t\tif (!localClippingEnabled || planes === null || planes.length === 0 || renderingShadows && !clipShadows) {\n\t\t\t// there's no local clipping\n\t\t\tif (renderingShadows) {\n\t\t\t\t// there's no global clipping\n\t\t\t\tprojectPlanes(null);\n\t\t\t} else {\n\t\t\t\tresetGlobalState();\n\t\t\t}\n\t\t} else {\n\t\t\tconst nGlobal = renderingShadows ? 0 : numGlobalPlanes,\n\t\t\t\t\t\tlGlobal = nGlobal * 4;\n\t\t\tlet dstArray = materialProperties.clippingState || null;\n\t\t\tuniform.value = dstArray; // ensure unique state\n\n\t\t\tdstArray = projectPlanes(planes, camera, lGlobal, useCache);\n\n\t\t\tfor (let i = 0; i !== lGlobal; ++i) {\n\t\t\t\tdstArray[i] = globalState[i];\n\t\t\t}\n\n\t\t\tmaterialProperties.clippingState = dstArray;\n\t\t\tthis.numIntersection = clipIntersection ? this.numPlanes : 0;\n\t\t\tthis.numPlanes += nGlobal;\n\t\t}\n\t};\n\n\tfunction resetGlobalState() {\n\t\tif (uniform.value !== globalState) {\n\t\t\tuniform.value = globalState;\n\t\t\tuniform.needsUpdate = numGlobalPlanes > 0;\n\t\t}\n\n\t\tscope.numPlanes = numGlobalPlanes;\n\t\tscope.numIntersection = 0;\n\t}\n\n\tfunction projectPlanes(planes, camera, dstOffset, skipTransform) {\n\t\tconst nPlanes = planes !== null ? planes.length : 0;\n\t\tlet dstArray = null;\n\n\t\tif (nPlanes !== 0) {\n\t\t\tdstArray = uniform.value;\n\n\t\t\tif (skipTransform !== true || dstArray === null) {\n\t\t\t\tconst flatSize = dstOffset + nPlanes * 4,\n\t\t\t\t\t\t\tviewMatrix = camera.matrixWorldInverse;\n\t\t\t\tviewNormalMatrix.getNormalMatrix(viewMatrix);\n\n\t\t\t\tif (dstArray === null || dstArray.length < flatSize) {\n\t\t\t\t\tdstArray = new Float32Array(flatSize);\n\t\t\t\t}\n\n\t\t\t\tfor (let i = 0, i4 = dstOffset; i !== nPlanes; ++i, i4 += 4) {\n\t\t\t\t\tplane.copy(planes[i]).applyMatrix4(viewMatrix, viewNormalMatrix);\n\t\t\t\t\tplane.normal.toArray(dstArray, i4);\n\t\t\t\t\tdstArray[i4 + 3] = plane.constant;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tuniform.value = dstArray;\n\t\t\tuniform.needsUpdate = true;\n\t\t}\n\n\t\tscope.numPlanes = nPlanes;\n\t\tscope.numIntersection = 0;\n\t\treturn dstArray;\n\t}\n}\n\nfunction WebGLCubeMaps(renderer) {\n\tlet cubemaps = new WeakMap();\n\n\tfunction mapTextureMapping(texture, mapping) {\n\t\tif (mapping === EquirectangularReflectionMapping) {\n\t\t\ttexture.mapping = CubeReflectionMapping;\n\t\t} else if (mapping === EquirectangularRefractionMapping) {\n\t\t\ttexture.mapping = CubeRefractionMapping;\n\t\t}\n\n\t\treturn texture;\n\t}\n\n\tfunction get(texture) {\n\t\tif (texture && texture.isTexture && texture.isRenderTargetTexture === false) {\n\t\t\tconst mapping = texture.mapping;\n\n\t\t\tif (mapping === EquirectangularReflectionMapping || mapping === EquirectangularRefractionMapping) {\n\t\t\t\tif (cubemaps.has(texture)) {\n\t\t\t\t\tconst cubemap = cubemaps.get(texture).texture;\n\t\t\t\t\treturn mapTextureMapping(cubemap, texture.mapping);\n\t\t\t\t} else {\n\t\t\t\t\tconst image = texture.image;\n\n\t\t\t\t\tif (image && image.height > 0) {\n\t\t\t\t\t\tconst renderTarget = new WebGLCubeRenderTarget(image.height / 2);\n\t\t\t\t\t\trenderTarget.fromEquirectangularTexture(renderer, texture);\n\t\t\t\t\t\tcubemaps.set(texture, renderTarget);\n\t\t\t\t\t\ttexture.addEventListener('dispose', onTextureDispose);\n\t\t\t\t\t\treturn mapTextureMapping(renderTarget.texture, texture.mapping);\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// image not yet ready. try the conversion next frame\n\t\t\t\t\t\treturn null;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn texture;\n\t}\n\n\tfunction onTextureDispose(event) {\n\t\tconst texture = event.target;\n\t\ttexture.removeEventListener('dispose', onTextureDispose);\n\t\tconst cubemap = cubemaps.get(texture);\n\n\t\tif (cubemap !== undefined) {\n\t\t\tcubemaps.delete(texture);\n\t\t\tcubemap.dispose();\n\t\t}\n\t}\n\n\tfunction dispose() {\n\t\tcubemaps = new WeakMap();\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tdispose: dispose\n\t};\n}\n\nclass OrthographicCamera extends Camera {\n\tconstructor(left = -1, right = 1, top = 1, bottom = -1, near = 0.1, far = 2000) {\n\t\tsuper();\n\t\tthis.isOrthographicCamera = true;\n\t\tthis.type = 'OrthographicCamera';\n\t\tthis.zoom = 1;\n\t\tthis.view = null;\n\t\tthis.left = left;\n\t\tthis.right = right;\n\t\tthis.top = top;\n\t\tthis.bottom = bottom;\n\t\tthis.near = near;\n\t\tthis.far = far;\n\t\tthis.updateProjectionMatrix();\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tthis.left = source.left;\n\t\tthis.right = source.right;\n\t\tthis.top = source.top;\n\t\tthis.bottom = source.bottom;\n\t\tthis.near = source.near;\n\t\tthis.far = source.far;\n\t\tthis.zoom = source.zoom;\n\t\tthis.view = source.view === null ? null : Object.assign({}, source.view);\n\t\treturn this;\n\t}\n\n\tsetViewOffset(fullWidth, fullHeight, x, y, width, height) {\n\t\tif (this.view === null) {\n\t\t\tthis.view = {\n\t\t\t\tenabled: true,\n\t\t\t\tfullWidth: 1,\n\t\t\t\tfullHeight: 1,\n\t\t\t\toffsetX: 0,\n\t\t\t\toffsetY: 0,\n\t\t\t\twidth: 1,\n\t\t\t\theight: 1\n\t\t\t};\n\t\t}\n\n\t\tthis.view.enabled = true;\n\t\tthis.view.fullWidth = fullWidth;\n\t\tthis.view.fullHeight = fullHeight;\n\t\tthis.view.offsetX = x;\n\t\tthis.view.offsetY = y;\n\t\tthis.view.width = width;\n\t\tthis.view.height = height;\n\t\tthis.updateProjectionMatrix();\n\t}\n\n\tclearViewOffset() {\n\t\tif (this.view !== null) {\n\t\t\tthis.view.enabled = false;\n\t\t}\n\n\t\tthis.updateProjectionMatrix();\n\t}\n\n\tupdateProjectionMatrix() {\n\t\tconst dx = (this.right - this.left) / (2 * this.zoom);\n\t\tconst dy = (this.top - this.bottom) / (2 * this.zoom);\n\t\tconst cx = (this.right + this.left) / 2;\n\t\tconst cy = (this.top + this.bottom) / 2;\n\t\tlet left = cx - dx;\n\t\tlet right = cx + dx;\n\t\tlet top = cy + dy;\n\t\tlet bottom = cy - dy;\n\n\t\tif (this.view !== null && this.view.enabled) {\n\t\t\tconst scaleW = (this.right - this.left) / this.view.fullWidth / this.zoom;\n\t\t\tconst scaleH = (this.top - this.bottom) / this.view.fullHeight / this.zoom;\n\t\t\tleft += scaleW * this.view.offsetX;\n\t\t\tright = left + scaleW * this.view.width;\n\t\t\ttop -= scaleH * this.view.offsetY;\n\t\t\tbottom = top - scaleH * this.view.height;\n\t\t}\n\n\t\tthis.projectionMatrix.makeOrthographic(left, right, top, bottom, this.near, this.far);\n\t\tthis.projectionMatrixInverse.copy(this.projectionMatrix).invert();\n\t}\n\n\ttoJSON(meta) {\n\t\tconst data = super.toJSON(meta);\n\t\tdata.object.zoom = this.zoom;\n\t\tdata.object.left = this.left;\n\t\tdata.object.right = this.right;\n\t\tdata.object.top = this.top;\n\t\tdata.object.bottom = this.bottom;\n\t\tdata.object.near = this.near;\n\t\tdata.object.far = this.far;\n\t\tif (this.view !== null) data.object.view = Object.assign({}, this.view);\n\t\treturn data;\n\t}\n\n}\n\nconst LOD_MIN = 4; // The standard deviations (radians) associated with the extra mips. These are\n// chosen to approximate a Trowbridge-Reitz distribution function times the\n// geometric shadowing function. These sigma values squared must match the\n// variance #defines in cube_uv_reflection_fragment.glsl.js.\n\nconst EXTRA_LOD_SIGMA = [0.125, 0.215, 0.35, 0.446, 0.526, 0.582]; // The maximum length of the blur for loop. Smaller sigmas will use fewer\n// samples and exit early, but not recompile the shader.\n\nconst MAX_SAMPLES = 20;\n\nconst _flatCamera = /*@__PURE__*/new OrthographicCamera();\n\nconst _clearColor = /*@__PURE__*/new Color();\n\nlet _oldTarget = null; // Golden Ratio\n\nconst PHI = (1 + Math.sqrt(5)) / 2;\nconst INV_PHI = 1 / PHI; // Vertices of a dodecahedron (except the opposites, which represent the\n// same axis), used as axis directions evenly spread on a sphere.\n\nconst _axisDirections = [/*@__PURE__*/new Vector3(1, 1, 1), /*@__PURE__*/new Vector3(-1, 1, 1), /*@__PURE__*/new Vector3(1, 1, -1), /*@__PURE__*/new Vector3(-1, 1, -1), /*@__PURE__*/new Vector3(0, PHI, INV_PHI), /*@__PURE__*/new Vector3(0, PHI, -INV_PHI), /*@__PURE__*/new Vector3(INV_PHI, 0, PHI), /*@__PURE__*/new Vector3(-INV_PHI, 0, PHI), /*@__PURE__*/new Vector3(PHI, INV_PHI, 0), /*@__PURE__*/new Vector3(-PHI, INV_PHI, 0)];\n/**\n * This class generates a Prefiltered, Mipmapped Radiance Environment Map\n * (PMREM) from a cubeMap environment texture. This allows different levels of\n * blur to be quickly accessed based on material roughness. It is packed into a\n * special CubeUV format that allows us to perform custom interpolation so that\n * we can support nonlinear formats such as RGBE. Unlike a traditional mipmap\n * chain, it only goes down to the LOD_MIN level (above), and then creates extra\n * even more filtered 'mips' at the same LOD_MIN resolution, associated with\n * higher roughness levels. In this way we maintain resolution to smoothly\n * interpolate diffuse lighting while limiting sampling computation.\n *\n * Paper: Fast, Accurate Image-Based Lighting\n * https://drive.google.com/file/d/15y8r_UpKlU9SvV4ILb0C3qCPecS8pvLz/view\n*/\n\nclass PMREMGenerator {\n\tconstructor(renderer) {\n\t\tthis._renderer = renderer;\n\t\tthis._pingPongRenderTarget = null;\n\t\tthis._lodMax = 0;\n\t\tthis._cubeSize = 0;\n\t\tthis._lodPlanes = [];\n\t\tthis._sizeLods = [];\n\t\tthis._sigmas = [];\n\t\tthis._blurMaterial = null;\n\t\tthis._cubemapMaterial = null;\n\t\tthis._equirectMaterial = null;\n\n\t\tthis._compileMaterial(this._blurMaterial);\n\t}\n\t/**\n\t * Generates a PMREM from a supplied Scene, which can be faster than using an\n\t * image if networking bandwidth is low. Optional sigma specifies a blur radius\n\t * in radians to be applied to the scene before PMREM generation. Optional near\n\t * and far planes ensure the scene is rendered in its entirety (the cubeCamera\n\t * is placed at the origin).\n\t */\n\n\n\tfromScene(scene, sigma = 0, near = 0.1, far = 100) {\n\t\t_oldTarget = this._renderer.getRenderTarget();\n\n\t\tthis._setSize(256);\n\n\t\tconst cubeUVRenderTarget = this._allocateTargets();\n\n\t\tcubeUVRenderTarget.depthBuffer = true;\n\n\t\tthis._sceneToCubeUV(scene, near, far, cubeUVRenderTarget);\n\n\t\tif (sigma > 0) {\n\t\t\tthis._blur(cubeUVRenderTarget, 0, 0, sigma);\n\t\t}\n\n\t\tthis._applyPMREM(cubeUVRenderTarget);\n\n\t\tthis._cleanup(cubeUVRenderTarget);\n\n\t\treturn cubeUVRenderTarget;\n\t}\n\t/**\n\t * Generates a PMREM from an equirectangular texture, which can be either LDR\n\t * or HDR. The ideal input image size is 1k (1024 x 512),\n\t * as this matches best with the 256 x 256 cubemap output.\n\t */\n\n\n\tfromEquirectangular(equirectangular, renderTarget = null) {\n\t\treturn this._fromTexture(equirectangular, renderTarget);\n\t}\n\t/**\n\t * Generates a PMREM from an cubemap texture, which can be either LDR\n\t * or HDR. The ideal input cube size is 256 x 256,\n\t * as this matches best with the 256 x 256 cubemap output.\n\t */\n\n\n\tfromCubemap(cubemap, renderTarget = null) {\n\t\treturn this._fromTexture(cubemap, renderTarget);\n\t}\n\t/**\n\t * Pre-compiles the cubemap shader. You can get faster start-up by invoking this method during\n\t * your texture's network fetch for increased concurrency.\n\t */\n\n\n\tcompileCubemapShader() {\n\t\tif (this._cubemapMaterial === null) {\n\t\t\tthis._cubemapMaterial = _getCubemapMaterial();\n\n\t\t\tthis._compileMaterial(this._cubemapMaterial);\n\t\t}\n\t}\n\t/**\n\t * Pre-compiles the equirectangular shader. You can get faster start-up by invoking this method during\n\t * your texture's network fetch for increased concurrency.\n\t */\n\n\n\tcompileEquirectangularShader() {\n\t\tif (this._equirectMaterial === null) {\n\t\t\tthis._equirectMaterial = _getEquirectMaterial();\n\n\t\t\tthis._compileMaterial(this._equirectMaterial);\n\t\t}\n\t}\n\t/**\n\t * Disposes of the PMREMGenerator's internal memory. Note that PMREMGenerator is a static class,\n\t * so you should not need more than one PMREMGenerator object. If you do, calling dispose() on\n\t * one of them will cause any others to also become unusable.\n\t */\n\n\n\tdispose() {\n\t\tthis._dispose();\n\n\t\tif (this._cubemapMaterial !== null) this._cubemapMaterial.dispose();\n\t\tif (this._equirectMaterial !== null) this._equirectMaterial.dispose();\n\t} // private interface\n\n\n\t_setSize(cubeSize) {\n\t\tthis._lodMax = Math.floor(Math.log2(cubeSize));\n\t\tthis._cubeSize = Math.pow(2, this._lodMax);\n\t}\n\n\t_dispose() {\n\t\tif (this._blurMaterial !== null) this._blurMaterial.dispose();\n\t\tif (this._pingPongRenderTarget !== null) this._pingPongRenderTarget.dispose();\n\n\t\tfor (let i = 0; i < this._lodPlanes.length; i++) {\n\t\t\tthis._lodPlanes[i].dispose();\n\t\t}\n\t}\n\n\t_cleanup(outputTarget) {\n\t\tthis._renderer.setRenderTarget(_oldTarget);\n\n\t\toutputTarget.scissorTest = false;\n\n\t\t_setViewport(outputTarget, 0, 0, outputTarget.width, outputTarget.height);\n\t}\n\n\t_fromTexture(texture, renderTarget) {\n\t\tif (texture.mapping === CubeReflectionMapping || texture.mapping === CubeRefractionMapping) {\n\t\t\tthis._setSize(texture.image.length === 0 ? 16 : texture.image[0].width || texture.image[0].image.width);\n\t\t} else {\n\t\t\t// Equirectangular\n\t\t\tthis._setSize(texture.image.width / 4);\n\t\t}\n\n\t\t_oldTarget = this._renderer.getRenderTarget();\n\n\t\tconst cubeUVRenderTarget = renderTarget || this._allocateTargets();\n\n\t\tthis._textureToCubeUV(texture, cubeUVRenderTarget);\n\n\t\tthis._applyPMREM(cubeUVRenderTarget);\n\n\t\tthis._cleanup(cubeUVRenderTarget);\n\n\t\treturn cubeUVRenderTarget;\n\t}\n\n\t_allocateTargets() {\n\t\tconst width = 3 * Math.max(this._cubeSize, 16 * 7);\n\t\tconst height = 4 * this._cubeSize;\n\t\tconst params = {\n\t\t\tmagFilter: LinearFilter,\n\t\t\tminFilter: LinearFilter,\n\t\t\tgenerateMipmaps: false,\n\t\t\ttype: HalfFloatType,\n\t\t\tformat: RGBAFormat,\n\t\t\tencoding: LinearEncoding,\n\t\t\tdepthBuffer: false\n\t\t};\n\n\t\tconst cubeUVRenderTarget = _createRenderTarget(width, height, params);\n\n\t\tif (this._pingPongRenderTarget === null || this._pingPongRenderTarget.width !== width) {\n\t\t\tif (this._pingPongRenderTarget !== null) {\n\t\t\t\tthis._dispose();\n\t\t\t}\n\n\t\t\tthis._pingPongRenderTarget = _createRenderTarget(width, height, params);\n\t\t\tconst {\n\t\t\t\t_lodMax\n\t\t\t} = this;\n\t\t\t({\n\t\t\t\tsizeLods: this._sizeLods,\n\t\t\t\tlodPlanes: this._lodPlanes,\n\t\t\t\tsigmas: this._sigmas\n\t\t\t} = _createPlanes(_lodMax));\n\t\t\tthis._blurMaterial = _getBlurShader(_lodMax, width, height);\n\t\t}\n\n\t\treturn cubeUVRenderTarget;\n\t}\n\n\t_compileMaterial(material) {\n\t\tconst tmpMesh = new Mesh(this._lodPlanes[0], material);\n\n\t\tthis._renderer.compile(tmpMesh, _flatCamera);\n\t}\n\n\t_sceneToCubeUV(scene, near, far, cubeUVRenderTarget) {\n\t\tconst fov = 90;\n\t\tconst aspect = 1;\n\t\tconst cubeCamera = new PerspectiveCamera(fov, aspect, near, far);\n\t\tconst upSign = [1, -1, 1, 1, 1, 1];\n\t\tconst forwardSign = [1, 1, 1, -1, -1, -1];\n\t\tconst renderer = this._renderer;\n\t\tconst originalAutoClear = renderer.autoClear;\n\t\tconst toneMapping = renderer.toneMapping;\n\t\trenderer.getClearColor(_clearColor);\n\t\trenderer.toneMapping = NoToneMapping;\n\t\trenderer.autoClear = false;\n\t\tconst backgroundMaterial = new MeshBasicMaterial({\n\t\t\tname: 'PMREM.Background',\n\t\t\tside: BackSide,\n\t\t\tdepthWrite: false,\n\t\t\tdepthTest: false\n\t\t});\n\t\tconst backgroundBox = new Mesh(new BoxGeometry(), backgroundMaterial);\n\t\tlet useSolidColor = false;\n\t\tconst background = scene.background;\n\n\t\tif (background) {\n\t\t\tif (background.isColor) {\n\t\t\t\tbackgroundMaterial.color.copy(background);\n\t\t\t\tscene.background = null;\n\t\t\t\tuseSolidColor = true;\n\t\t\t}\n\t\t} else {\n\t\t\tbackgroundMaterial.color.copy(_clearColor);\n\t\t\tuseSolidColor = true;\n\t\t}\n\n\t\tfor (let i = 0; i < 6; i++) {\n\t\t\tconst col = i % 3;\n\n\t\t\tif (col === 0) {\n\t\t\t\tcubeCamera.up.set(0, upSign[i], 0);\n\t\t\t\tcubeCamera.lookAt(forwardSign[i], 0, 0);\n\t\t\t} else if (col === 1) {\n\t\t\t\tcubeCamera.up.set(0, 0, upSign[i]);\n\t\t\t\tcubeCamera.lookAt(0, forwardSign[i], 0);\n\t\t\t} else {\n\t\t\t\tcubeCamera.up.set(0, upSign[i], 0);\n\t\t\t\tcubeCamera.lookAt(0, 0, forwardSign[i]);\n\t\t\t}\n\n\t\t\tconst size = this._cubeSize;\n\n\t\t\t_setViewport(cubeUVRenderTarget, col * size, i > 2 ? size : 0, size, size);\n\n\t\t\trenderer.setRenderTarget(cubeUVRenderTarget);\n\n\t\t\tif (useSolidColor) {\n\t\t\t\trenderer.render(backgroundBox, cubeCamera);\n\t\t\t}\n\n\t\t\trenderer.render(scene, cubeCamera);\n\t\t}\n\n\t\tbackgroundBox.geometry.dispose();\n\t\tbackgroundBox.material.dispose();\n\t\trenderer.toneMapping = toneMapping;\n\t\trenderer.autoClear = originalAutoClear;\n\t\tscene.background = background;\n\t}\n\n\t_textureToCubeUV(texture, cubeUVRenderTarget) {\n\t\tconst renderer = this._renderer;\n\t\tconst isCubeTexture = texture.mapping === CubeReflectionMapping || texture.mapping === CubeRefractionMapping;\n\n\t\tif (isCubeTexture) {\n\t\t\tif (this._cubemapMaterial === null) {\n\t\t\t\tthis._cubemapMaterial = _getCubemapMaterial();\n\t\t\t}\n\n\t\t\tthis._cubemapMaterial.uniforms.flipEnvMap.value = texture.isRenderTargetTexture === false ? -1 : 1;\n\t\t} else {\n\t\t\tif (this._equirectMaterial === null) {\n\t\t\t\tthis._equirectMaterial = _getEquirectMaterial();\n\t\t\t}\n\t\t}\n\n\t\tconst material = isCubeTexture ? this._cubemapMaterial : this._equirectMaterial;\n\t\tconst mesh = new Mesh(this._lodPlanes[0], material);\n\t\tconst uniforms = material.uniforms;\n\t\tuniforms['envMap'].value = texture;\n\t\tconst size = this._cubeSize;\n\n\t\t_setViewport(cubeUVRenderTarget, 0, 0, 3 * size, 2 * size);\n\n\t\trenderer.setRenderTarget(cubeUVRenderTarget);\n\t\trenderer.render(mesh, _flatCamera);\n\t}\n\n\t_applyPMREM(cubeUVRenderTarget) {\n\t\tconst renderer = this._renderer;\n\t\tconst autoClear = renderer.autoClear;\n\t\trenderer.autoClear = false;\n\n\t\tfor (let i = 1; i < this._lodPlanes.length; i++) {\n\t\t\tconst sigma = Math.sqrt(this._sigmas[i] * this._sigmas[i] - this._sigmas[i - 1] * this._sigmas[i - 1]);\n\t\t\tconst poleAxis = _axisDirections[(i - 1) % _axisDirections.length];\n\n\t\t\tthis._blur(cubeUVRenderTarget, i - 1, i, sigma, poleAxis);\n\t\t}\n\n\t\trenderer.autoClear = autoClear;\n\t}\n\t/**\n\t * This is a two-pass Gaussian blur for a cubemap. Normally this is done\n\t * vertically and horizontally, but this breaks down on a cube. Here we apply\n\t * the blur latitudinally (around the poles), and then longitudinally (towards\n\t * the poles) to approximate the orthogonally-separable blur. It is least\n\t * accurate at the poles, but still does a decent job.\n\t */\n\n\n\t_blur(cubeUVRenderTarget, lodIn, lodOut, sigma, poleAxis) {\n\t\tconst pingPongRenderTarget = this._pingPongRenderTarget;\n\n\t\tthis._halfBlur(cubeUVRenderTarget, pingPongRenderTarget, lodIn, lodOut, sigma, 'latitudinal', poleAxis);\n\n\t\tthis._halfBlur(pingPongRenderTarget, cubeUVRenderTarget, lodOut, lodOut, sigma, 'longitudinal', poleAxis);\n\t}\n\n\t_halfBlur(targetIn, targetOut, lodIn, lodOut, sigmaRadians, direction, poleAxis) {\n\t\tconst renderer = this._renderer;\n\t\tconst blurMaterial = this._blurMaterial;\n\n\t\tif (direction !== 'latitudinal' && direction !== 'longitudinal') {\n\t\t\tconsole.error('blur direction must be either latitudinal or longitudinal!');\n\t\t} // Number of standard deviations at which to cut off the discrete approximation.\n\n\n\t\tconst STANDARD_DEVIATIONS = 3;\n\t\tconst blurMesh = new Mesh(this._lodPlanes[lodOut], blurMaterial);\n\t\tconst blurUniforms = blurMaterial.uniforms;\n\t\tconst pixels = this._sizeLods[lodIn] - 1;\n\t\tconst radiansPerPixel = isFinite(sigmaRadians) ? Math.PI / (2 * pixels) : 2 * Math.PI / (2 * MAX_SAMPLES - 1);\n\t\tconst sigmaPixels = sigmaRadians / radiansPerPixel;\n\t\tconst samples = isFinite(sigmaRadians) ? 1 + Math.floor(STANDARD_DEVIATIONS * sigmaPixels) : MAX_SAMPLES;\n\n\t\tif (samples > MAX_SAMPLES) {\n\t\t\tconsole.warn(`sigmaRadians, ${sigmaRadians}, is too large and will clip, as it requested ${samples} samples when the maximum is set to ${MAX_SAMPLES}`);\n\t\t}\n\n\t\tconst weights = [];\n\t\tlet sum = 0;\n\n\t\tfor (let i = 0; i < MAX_SAMPLES; ++i) {\n\t\t\tconst x = i / sigmaPixels;\n\t\t\tconst weight = Math.exp(-x * x / 2);\n\t\t\tweights.push(weight);\n\n\t\t\tif (i === 0) {\n\t\t\t\tsum += weight;\n\t\t\t} else if (i < samples) {\n\t\t\t\tsum += 2 * weight;\n\t\t\t}\n\t\t}\n\n\t\tfor (let i = 0; i < weights.length; i++) {\n\t\t\tweights[i] = weights[i] / sum;\n\t\t}\n\n\t\tblurUniforms['envMap'].value = targetIn.texture;\n\t\tblurUniforms['samples'].value = samples;\n\t\tblurUniforms['weights'].value = weights;\n\t\tblurUniforms['latitudinal'].value = direction === 'latitudinal';\n\n\t\tif (poleAxis) {\n\t\t\tblurUniforms['poleAxis'].value = poleAxis;\n\t\t}\n\n\t\tconst {\n\t\t\t_lodMax\n\t\t} = this;\n\t\tblurUniforms['dTheta'].value = radiansPerPixel;\n\t\tblurUniforms['mipInt'].value = _lodMax - lodIn;\n\t\tconst outputSize = this._sizeLods[lodOut];\n\t\tconst x = 3 * outputSize * (lodOut > _lodMax - LOD_MIN ? lodOut - _lodMax + LOD_MIN : 0);\n\t\tconst y = 4 * (this._cubeSize - outputSize);\n\n\t\t_setViewport(targetOut, x, y, 3 * outputSize, 2 * outputSize);\n\n\t\trenderer.setRenderTarget(targetOut);\n\t\trenderer.render(blurMesh, _flatCamera);\n\t}\n\n}\n\nfunction _createPlanes(lodMax) {\n\tconst lodPlanes = [];\n\tconst sizeLods = [];\n\tconst sigmas = [];\n\tlet lod = lodMax;\n\tconst totalLods = lodMax - LOD_MIN + 1 + EXTRA_LOD_SIGMA.length;\n\n\tfor (let i = 0; i < totalLods; i++) {\n\t\tconst sizeLod = Math.pow(2, lod);\n\t\tsizeLods.push(sizeLod);\n\t\tlet sigma = 1.0 / sizeLod;\n\n\t\tif (i > lodMax - LOD_MIN) {\n\t\t\tsigma = EXTRA_LOD_SIGMA[i - lodMax + LOD_MIN - 1];\n\t\t} else if (i === 0) {\n\t\t\tsigma = 0;\n\t\t}\n\n\t\tsigmas.push(sigma);\n\t\tconst texelSize = 1.0 / (sizeLod - 2);\n\t\tconst min = -texelSize;\n\t\tconst max = 1 + texelSize;\n\t\tconst uv1 = [min, min, max, min, max, max, min, min, max, max, min, max];\n\t\tconst cubeFaces = 6;\n\t\tconst vertices = 6;\n\t\tconst positionSize = 3;\n\t\tconst uvSize = 2;\n\t\tconst faceIndexSize = 1;\n\t\tconst position = new Float32Array(positionSize * vertices * cubeFaces);\n\t\tconst uv = new Float32Array(uvSize * vertices * cubeFaces);\n\t\tconst faceIndex = new Float32Array(faceIndexSize * vertices * cubeFaces);\n\n\t\tfor (let face = 0; face < cubeFaces; face++) {\n\t\t\tconst x = face % 3 * 2 / 3 - 1;\n\t\t\tconst y = face > 2 ? 0 : -1;\n\t\t\tconst coordinates = [x, y, 0, x + 2 / 3, y, 0, x + 2 / 3, y + 1, 0, x, y, 0, x + 2 / 3, y + 1, 0, x, y + 1, 0];\n\t\t\tposition.set(coordinates, positionSize * vertices * face);\n\t\t\tuv.set(uv1, uvSize * vertices * face);\n\t\t\tconst fill = [face, face, face, face, face, face];\n\t\t\tfaceIndex.set(fill, faceIndexSize * vertices * face);\n\t\t}\n\n\t\tconst planes = new BufferGeometry();\n\t\tplanes.setAttribute('position', new BufferAttribute(position, positionSize));\n\t\tplanes.setAttribute('uv', new BufferAttribute(uv, uvSize));\n\t\tplanes.setAttribute('faceIndex', new BufferAttribute(faceIndex, faceIndexSize));\n\t\tlodPlanes.push(planes);\n\n\t\tif (lod > LOD_MIN) {\n\t\t\tlod--;\n\t\t}\n\t}\n\n\treturn {\n\t\tlodPlanes,\n\t\tsizeLods,\n\t\tsigmas\n\t};\n}\n\nfunction _createRenderTarget(width, height, params) {\n\tconst cubeUVRenderTarget = new WebGLRenderTarget(width, height, params);\n\tcubeUVRenderTarget.texture.mapping = CubeUVReflectionMapping;\n\tcubeUVRenderTarget.texture.name = 'PMREM.cubeUv';\n\tcubeUVRenderTarget.scissorTest = true;\n\treturn cubeUVRenderTarget;\n}\n\nfunction _setViewport(target, x, y, width, height) {\n\ttarget.viewport.set(x, y, width, height);\n\ttarget.scissor.set(x, y, width, height);\n}\n\nfunction _getBlurShader(lodMax, width, height) {\n\tconst weights = new Float32Array(MAX_SAMPLES);\n\tconst poleAxis = new Vector3(0, 1, 0);\n\tconst shaderMaterial = new ShaderMaterial({\n\t\tname: 'SphericalGaussianBlur',\n\t\tdefines: {\n\t\t\t'n': MAX_SAMPLES,\n\t\t\t'CUBEUV_TEXEL_WIDTH': 1.0 / width,\n\t\t\t'CUBEUV_TEXEL_HEIGHT': 1.0 / height,\n\t\t\t'CUBEUV_MAX_MIP': `${lodMax}.0`\n\t\t},\n\t\tuniforms: {\n\t\t\t'envMap': {\n\t\t\t\tvalue: null\n\t\t\t},\n\t\t\t'samples': {\n\t\t\t\tvalue: 1\n\t\t\t},\n\t\t\t'weights': {\n\t\t\t\tvalue: weights\n\t\t\t},\n\t\t\t'latitudinal': {\n\t\t\t\tvalue: false\n\t\t\t},\n\t\t\t'dTheta': {\n\t\t\t\tvalue: 0\n\t\t\t},\n\t\t\t'mipInt': {\n\t\t\t\tvalue: 0\n\t\t\t},\n\t\t\t'poleAxis': {\n\t\t\t\tvalue: poleAxis\n\t\t\t}\n\t\t},\n\t\tvertexShader: _getCommonVertexShader(),\n\t\tfragmentShader:\n\t\t/* glsl */\n\t\t`\n\n\t\t\tprecision mediump float;\n\t\t\tprecision mediump int;\n\n\t\t\tvarying vec3 vOutputDirection;\n\n\t\t\tuniform sampler2D envMap;\n\t\t\tuniform int samples;\n\t\t\tuniform float weights[ n ];\n\t\t\tuniform bool latitudinal;\n\t\t\tuniform float dTheta;\n\t\t\tuniform float mipInt;\n\t\t\tuniform vec3 poleAxis;\n\n\t\t\t#define ENVMAP_TYPE_CUBE_UV\n\t\t\t#include \n\n\t\t\tvec3 getSample( float theta, vec3 axis ) {\n\n\t\t\t\tfloat cosTheta = cos( theta );\n\t\t\t\t// Rodrigues' axis-angle rotation\n\t\t\t\tvec3 sampleDirection = vOutputDirection * cosTheta\n\t\t\t\t\t+ cross( axis, vOutputDirection ) * sin( theta )\n\t\t\t\t\t+ axis * dot( axis, vOutputDirection ) * ( 1.0 - cosTheta );\n\n\t\t\t\treturn bilinearCubeUV( envMap, sampleDirection, mipInt );\n\n\t\t\t}\n\n\t\t\tvoid main() {\n\n\t\t\t\tvec3 axis = latitudinal ? poleAxis : cross( poleAxis, vOutputDirection );\n\n\t\t\t\tif ( all( equal( axis, vec3( 0.0 ) ) ) ) {\n\n\t\t\t\t\taxis = vec3( vOutputDirection.z, 0.0, - vOutputDirection.x );\n\n\t\t\t\t}\n\n\t\t\t\taxis = normalize( axis );\n\n\t\t\t\tgl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 );\n\t\t\t\tgl_FragColor.rgb += weights[ 0 ] * getSample( 0.0, axis );\n\n\t\t\t\tfor ( int i = 1; i < n; i++ ) {\n\n\t\t\t\t\tif ( i >= samples ) {\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tfloat theta = dTheta * float( i );\n\t\t\t\t\tgl_FragColor.rgb += weights[ i ] * getSample( -1.0 * theta, axis );\n\t\t\t\t\tgl_FragColor.rgb += weights[ i ] * getSample( theta, axis );\n\n\t\t\t\t}\n\n\t\t\t}\n\t\t`,\n\t\tblending: NoBlending,\n\t\tdepthTest: false,\n\t\tdepthWrite: false\n\t});\n\treturn shaderMaterial;\n}\n\nfunction _getEquirectMaterial() {\n\treturn new ShaderMaterial({\n\t\tname: 'EquirectangularToCubeUV',\n\t\tuniforms: {\n\t\t\t'envMap': {\n\t\t\t\tvalue: null\n\t\t\t}\n\t\t},\n\t\tvertexShader: _getCommonVertexShader(),\n\t\tfragmentShader:\n\t\t/* glsl */\n\t\t`\n\n\t\t\tprecision mediump float;\n\t\t\tprecision mediump int;\n\n\t\t\tvarying vec3 vOutputDirection;\n\n\t\t\tuniform sampler2D envMap;\n\n\t\t\t#include \n\n\t\t\tvoid main() {\n\n\t\t\t\tvec3 outputDirection = normalize( vOutputDirection );\n\t\t\t\tvec2 uv = equirectUv( outputDirection );\n\n\t\t\t\tgl_FragColor = vec4( texture2D ( envMap, uv ).rgb, 1.0 );\n\n\t\t\t}\n\t\t`,\n\t\tblending: NoBlending,\n\t\tdepthTest: false,\n\t\tdepthWrite: false\n\t});\n}\n\nfunction _getCubemapMaterial() {\n\treturn new ShaderMaterial({\n\t\tname: 'CubemapToCubeUV',\n\t\tuniforms: {\n\t\t\t'envMap': {\n\t\t\t\tvalue: null\n\t\t\t},\n\t\t\t'flipEnvMap': {\n\t\t\t\tvalue: -1\n\t\t\t}\n\t\t},\n\t\tvertexShader: _getCommonVertexShader(),\n\t\tfragmentShader:\n\t\t/* glsl */\n\t\t`\n\n\t\t\tprecision mediump float;\n\t\t\tprecision mediump int;\n\n\t\t\tuniform float flipEnvMap;\n\n\t\t\tvarying vec3 vOutputDirection;\n\n\t\t\tuniform samplerCube envMap;\n\n\t\t\tvoid main() {\n\n\t\t\t\tgl_FragColor = textureCube( envMap, vec3( flipEnvMap * vOutputDirection.x, vOutputDirection.yz ) );\n\n\t\t\t}\n\t\t`,\n\t\tblending: NoBlending,\n\t\tdepthTest: false,\n\t\tdepthWrite: false\n\t});\n}\n\nfunction _getCommonVertexShader() {\n\treturn (\n\t\t/* glsl */\n\t\t`\n\n\t\tprecision mediump float;\n\t\tprecision mediump int;\n\n\t\tattribute float faceIndex;\n\n\t\tvarying vec3 vOutputDirection;\n\n\t\t// RH coordinate system; PMREM face-indexing convention\n\t\tvec3 getDirection( vec2 uv, float face ) {\n\n\t\t\tuv = 2.0 * uv - 1.0;\n\n\t\t\tvec3 direction = vec3( uv, 1.0 );\n\n\t\t\tif ( face == 0.0 ) {\n\n\t\t\t\tdirection = direction.zyx; // ( 1, v, u ) pos x\n\n\t\t\t} else if ( face == 1.0 ) {\n\n\t\t\t\tdirection = direction.xzy;\n\t\t\t\tdirection.xz *= -1.0; // ( -u, 1, -v ) pos y\n\n\t\t\t} else if ( face == 2.0 ) {\n\n\t\t\t\tdirection.x *= -1.0; // ( -u, v, 1 ) pos z\n\n\t\t\t} else if ( face == 3.0 ) {\n\n\t\t\t\tdirection = direction.zyx;\n\t\t\t\tdirection.xz *= -1.0; // ( -1, v, -u ) neg x\n\n\t\t\t} else if ( face == 4.0 ) {\n\n\t\t\t\tdirection = direction.xzy;\n\t\t\t\tdirection.xy *= -1.0; // ( -u, -1, v ) neg y\n\n\t\t\t} else if ( face == 5.0 ) {\n\n\t\t\t\tdirection.z *= -1.0; // ( u, v, -1 ) neg z\n\n\t\t\t}\n\n\t\t\treturn direction;\n\n\t\t}\n\n\t\tvoid main() {\n\n\t\t\tvOutputDirection = getDirection( uv, faceIndex );\n\t\t\tgl_Position = vec4( position, 1.0 );\n\n\t\t}\n\t`\n\t);\n}\n\nfunction WebGLCubeUVMaps(renderer) {\n\tlet cubeUVmaps = new WeakMap();\n\tlet pmremGenerator = null;\n\n\tfunction get(texture) {\n\t\tif (texture && texture.isTexture) {\n\t\t\tconst mapping = texture.mapping;\n\t\t\tconst isEquirectMap = mapping === EquirectangularReflectionMapping || mapping === EquirectangularRefractionMapping;\n\t\t\tconst isCubeMap = mapping === CubeReflectionMapping || mapping === CubeRefractionMapping; // equirect/cube map to cubeUV conversion\n\n\t\t\tif (isEquirectMap || isCubeMap) {\n\t\t\t\tif (texture.isRenderTargetTexture && texture.needsPMREMUpdate === true) {\n\t\t\t\t\ttexture.needsPMREMUpdate = false;\n\t\t\t\t\tlet renderTarget = cubeUVmaps.get(texture);\n\t\t\t\t\tif (pmremGenerator === null) pmremGenerator = new PMREMGenerator(renderer);\n\t\t\t\t\trenderTarget = isEquirectMap ? pmremGenerator.fromEquirectangular(texture, renderTarget) : pmremGenerator.fromCubemap(texture, renderTarget);\n\t\t\t\t\tcubeUVmaps.set(texture, renderTarget);\n\t\t\t\t\treturn renderTarget.texture;\n\t\t\t\t} else {\n\t\t\t\t\tif (cubeUVmaps.has(texture)) {\n\t\t\t\t\t\treturn cubeUVmaps.get(texture).texture;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tconst image = texture.image;\n\n\t\t\t\t\t\tif (isEquirectMap && image && image.height > 0 || isCubeMap && image && isCubeTextureComplete(image)) {\n\t\t\t\t\t\t\tif (pmremGenerator === null) pmremGenerator = new PMREMGenerator(renderer);\n\t\t\t\t\t\t\tconst renderTarget = isEquirectMap ? pmremGenerator.fromEquirectangular(texture) : pmremGenerator.fromCubemap(texture);\n\t\t\t\t\t\t\tcubeUVmaps.set(texture, renderTarget);\n\t\t\t\t\t\t\ttexture.addEventListener('dispose', onTextureDispose);\n\t\t\t\t\t\t\treturn renderTarget.texture;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// image not yet ready. try the conversion next frame\n\t\t\t\t\t\t\treturn null;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn texture;\n\t}\n\n\tfunction isCubeTextureComplete(image) {\n\t\tlet count = 0;\n\t\tconst length = 6;\n\n\t\tfor (let i = 0; i < length; i++) {\n\t\t\tif (image[i] !== undefined) count++;\n\t\t}\n\n\t\treturn count === length;\n\t}\n\n\tfunction onTextureDispose(event) {\n\t\tconst texture = event.target;\n\t\ttexture.removeEventListener('dispose', onTextureDispose);\n\t\tconst cubemapUV = cubeUVmaps.get(texture);\n\n\t\tif (cubemapUV !== undefined) {\n\t\t\tcubeUVmaps.delete(texture);\n\t\t\tcubemapUV.dispose();\n\t\t}\n\t}\n\n\tfunction dispose() {\n\t\tcubeUVmaps = new WeakMap();\n\n\t\tif (pmremGenerator !== null) {\n\t\t\tpmremGenerator.dispose();\n\t\t\tpmremGenerator = null;\n\t\t}\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tdispose: dispose\n\t};\n}\n\nfunction WebGLExtensions(gl) {\n\tconst extensions = {};\n\n\tfunction getExtension(name) {\n\t\tif (extensions[name] !== undefined) {\n\t\t\treturn extensions[name];\n\t\t}\n\n\t\tlet extension;\n\n\t\tswitch (name) {\n\t\t\tcase 'WEBGL_depth_texture':\n\t\t\t\textension = gl.getExtension('WEBGL_depth_texture') || gl.getExtension('MOZ_WEBGL_depth_texture') || gl.getExtension('WEBKIT_WEBGL_depth_texture');\n\t\t\t\tbreak;\n\n\t\t\tcase 'EXT_texture_filter_anisotropic':\n\t\t\t\textension = gl.getExtension('EXT_texture_filter_anisotropic') || gl.getExtension('MOZ_EXT_texture_filter_anisotropic') || gl.getExtension('WEBKIT_EXT_texture_filter_anisotropic');\n\t\t\t\tbreak;\n\n\t\t\tcase 'WEBGL_compressed_texture_s3tc':\n\t\t\t\textension = gl.getExtension('WEBGL_compressed_texture_s3tc') || gl.getExtension('MOZ_WEBGL_compressed_texture_s3tc') || gl.getExtension('WEBKIT_WEBGL_compressed_texture_s3tc');\n\t\t\t\tbreak;\n\n\t\t\tcase 'WEBGL_compressed_texture_pvrtc':\n\t\t\t\textension = gl.getExtension('WEBGL_compressed_texture_pvrtc') || gl.getExtension('WEBKIT_WEBGL_compressed_texture_pvrtc');\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\textension = gl.getExtension(name);\n\t\t}\n\n\t\textensions[name] = extension;\n\t\treturn extension;\n\t}\n\n\treturn {\n\t\thas: function (name) {\n\t\t\treturn getExtension(name) !== null;\n\t\t},\n\t\tinit: function (capabilities) {\n\t\t\tif (capabilities.isWebGL2) {\n\t\t\t\tgetExtension('EXT_color_buffer_float');\n\t\t\t} else {\n\t\t\t\tgetExtension('WEBGL_depth_texture');\n\t\t\t\tgetExtension('OES_texture_float');\n\t\t\t\tgetExtension('OES_texture_half_float');\n\t\t\t\tgetExtension('OES_texture_half_float_linear');\n\t\t\t\tgetExtension('OES_standard_derivatives');\n\t\t\t\tgetExtension('OES_element_index_uint');\n\t\t\t\tgetExtension('OES_vertex_array_object');\n\t\t\t\tgetExtension('ANGLE_instanced_arrays');\n\t\t\t}\n\n\t\t\tgetExtension('OES_texture_float_linear');\n\t\t\tgetExtension('EXT_color_buffer_half_float');\n\t\t\tgetExtension('WEBGL_multisampled_render_to_texture');\n\t\t},\n\t\tget: function (name) {\n\t\t\tconst extension = getExtension(name);\n\n\t\t\tif (extension === null) {\n\t\t\t\tconsole.warn('THREE.WebGLRenderer: ' + name + ' extension not supported.');\n\t\t\t}\n\n\t\t\treturn extension;\n\t\t}\n\t};\n}\n\nfunction WebGLGeometries(gl, attributes, info, bindingStates) {\n\tconst geometries = {};\n\tconst wireframeAttributes = new WeakMap();\n\n\tfunction onGeometryDispose(event) {\n\t\tconst geometry = event.target;\n\n\t\tif (geometry.index !== null) {\n\t\t\tattributes.remove(geometry.index);\n\t\t}\n\n\t\tfor (const name in geometry.attributes) {\n\t\t\tattributes.remove(geometry.attributes[name]);\n\t\t}\n\n\t\tgeometry.removeEventListener('dispose', onGeometryDispose);\n\t\tdelete geometries[geometry.id];\n\t\tconst attribute = wireframeAttributes.get(geometry);\n\n\t\tif (attribute) {\n\t\t\tattributes.remove(attribute);\n\t\t\twireframeAttributes.delete(geometry);\n\t\t}\n\n\t\tbindingStates.releaseStatesOfGeometry(geometry);\n\n\t\tif (geometry.isInstancedBufferGeometry === true) {\n\t\t\tdelete geometry._maxInstanceCount;\n\t\t} //\n\n\n\t\tinfo.memory.geometries--;\n\t}\n\n\tfunction get(object, geometry) {\n\t\tif (geometries[geometry.id] === true) return geometry;\n\t\tgeometry.addEventListener('dispose', onGeometryDispose);\n\t\tgeometries[geometry.id] = true;\n\t\tinfo.memory.geometries++;\n\t\treturn geometry;\n\t}\n\n\tfunction update(geometry) {\n\t\tconst geometryAttributes = geometry.attributes; // Updating index buffer in VAO now. See WebGLBindingStates.\n\n\t\tfor (const name in geometryAttributes) {\n\t\t\tattributes.update(geometryAttributes[name], gl.ARRAY_BUFFER);\n\t\t} // morph targets\n\n\n\t\tconst morphAttributes = geometry.morphAttributes;\n\n\t\tfor (const name in morphAttributes) {\n\t\t\tconst array = morphAttributes[name];\n\n\t\t\tfor (let i = 0, l = array.length; i < l; i++) {\n\t\t\t\tattributes.update(array[i], gl.ARRAY_BUFFER);\n\t\t\t}\n\t\t}\n\t}\n\n\tfunction updateWireframeAttribute(geometry) {\n\t\tconst indices = [];\n\t\tconst geometryIndex = geometry.index;\n\t\tconst geometryPosition = geometry.attributes.position;\n\t\tlet version = 0;\n\n\t\tif (geometryIndex !== null) {\n\t\t\tconst array = geometryIndex.array;\n\t\t\tversion = geometryIndex.version;\n\n\t\t\tfor (let i = 0, l = array.length; i < l; i += 3) {\n\t\t\t\tconst a = array[i + 0];\n\t\t\t\tconst b = array[i + 1];\n\t\t\t\tconst c = array[i + 2];\n\t\t\t\tindices.push(a, b, b, c, c, a);\n\t\t\t}\n\t\t} else {\n\t\t\tconst array = geometryPosition.array;\n\t\t\tversion = geometryPosition.version;\n\n\t\t\tfor (let i = 0, l = array.length / 3 - 1; i < l; i += 3) {\n\t\t\t\tconst a = i + 0;\n\t\t\t\tconst b = i + 1;\n\t\t\t\tconst c = i + 2;\n\t\t\t\tindices.push(a, b, b, c, c, a);\n\t\t\t}\n\t\t}\n\n\t\tconst attribute = new (arrayNeedsUint32(indices) ? Uint32BufferAttribute : Uint16BufferAttribute)(indices, 1);\n\t\tattribute.version = version; // Updating index buffer in VAO now. See WebGLBindingStates\n\t\t//\n\n\t\tconst previousAttribute = wireframeAttributes.get(geometry);\n\t\tif (previousAttribute) attributes.remove(previousAttribute); //\n\n\t\twireframeAttributes.set(geometry, attribute);\n\t}\n\n\tfunction getWireframeAttribute(geometry) {\n\t\tconst currentAttribute = wireframeAttributes.get(geometry);\n\n\t\tif (currentAttribute) {\n\t\t\tconst geometryIndex = geometry.index;\n\n\t\t\tif (geometryIndex !== null) {\n\t\t\t\t// if the attribute is obsolete, create a new one\n\t\t\t\tif (currentAttribute.version < geometryIndex.version) {\n\t\t\t\t\tupdateWireframeAttribute(geometry);\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tupdateWireframeAttribute(geometry);\n\t\t}\n\n\t\treturn wireframeAttributes.get(geometry);\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tupdate: update,\n\t\tgetWireframeAttribute: getWireframeAttribute\n\t};\n}\n\nfunction WebGLIndexedBufferRenderer(gl, extensions, info, capabilities) {\n\tconst isWebGL2 = capabilities.isWebGL2;\n\tlet mode;\n\n\tfunction setMode(value) {\n\t\tmode = value;\n\t}\n\n\tlet type, bytesPerElement;\n\n\tfunction setIndex(value) {\n\t\ttype = value.type;\n\t\tbytesPerElement = value.bytesPerElement;\n\t}\n\n\tfunction render(start, count) {\n\t\tgl.drawElements(mode, count, type, start * bytesPerElement);\n\t\tinfo.update(count, mode, 1);\n\t}\n\n\tfunction renderInstances(start, count, primcount) {\n\t\tif (primcount === 0) return;\n\t\tlet extension, methodName;\n\n\t\tif (isWebGL2) {\n\t\t\textension = gl;\n\t\t\tmethodName = 'drawElementsInstanced';\n\t\t} else {\n\t\t\textension = extensions.get('ANGLE_instanced_arrays');\n\t\t\tmethodName = 'drawElementsInstancedANGLE';\n\n\t\t\tif (extension === null) {\n\t\t\t\tconsole.error('THREE.WebGLIndexedBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.');\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\textension[methodName](mode, count, type, start * bytesPerElement, primcount);\n\t\tinfo.update(count, mode, primcount);\n\t} //\n\n\n\tthis.setMode = setMode;\n\tthis.setIndex = setIndex;\n\tthis.render = render;\n\tthis.renderInstances = renderInstances;\n}\n\nfunction WebGLInfo(gl) {\n\tconst memory = {\n\t\tgeometries: 0,\n\t\ttextures: 0\n\t};\n\tconst render = {\n\t\tframe: 0,\n\t\tcalls: 0,\n\t\ttriangles: 0,\n\t\tpoints: 0,\n\t\tlines: 0\n\t};\n\n\tfunction update(count, mode, instanceCount) {\n\t\trender.calls++;\n\n\t\tswitch (mode) {\n\t\t\tcase gl.TRIANGLES:\n\t\t\t\trender.triangles += instanceCount * (count / 3);\n\t\t\t\tbreak;\n\n\t\t\tcase gl.LINES:\n\t\t\t\trender.lines += instanceCount * (count / 2);\n\t\t\t\tbreak;\n\n\t\t\tcase gl.LINE_STRIP:\n\t\t\t\trender.lines += instanceCount * (count - 1);\n\t\t\t\tbreak;\n\n\t\t\tcase gl.LINE_LOOP:\n\t\t\t\trender.lines += instanceCount * count;\n\t\t\t\tbreak;\n\n\t\t\tcase gl.POINTS:\n\t\t\t\trender.points += instanceCount * count;\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tconsole.error('THREE.WebGLInfo: Unknown draw mode:', mode);\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\tfunction reset() {\n\t\trender.frame++;\n\t\trender.calls = 0;\n\t\trender.triangles = 0;\n\t\trender.points = 0;\n\t\trender.lines = 0;\n\t}\n\n\treturn {\n\t\tmemory: memory,\n\t\trender: render,\n\t\tprograms: null,\n\t\tautoReset: true,\n\t\treset: reset,\n\t\tupdate: update\n\t};\n}\n\nfunction numericalSort(a, b) {\n\treturn a[0] - b[0];\n}\n\nfunction absNumericalSort(a, b) {\n\treturn Math.abs(b[1]) - Math.abs(a[1]);\n}\n\nfunction denormalize(morph, attribute) {\n\tlet denominator = 1;\n\tconst array = attribute.isInterleavedBufferAttribute ? attribute.data.array : attribute.array;\n\tif (array instanceof Int8Array) denominator = 127;else if (array instanceof Int16Array) denominator = 32767;else if (array instanceof Int32Array) denominator = 2147483647;else console.error('THREE.WebGLMorphtargets: Unsupported morph attribute data type: ', array);\n\tmorph.divideScalar(denominator);\n}\n\nfunction WebGLMorphtargets(gl, capabilities, textures) {\n\tconst influencesList = {};\n\tconst morphInfluences = new Float32Array(8);\n\tconst morphTextures = new WeakMap();\n\tconst morph = new Vector4();\n\tconst workInfluences = [];\n\n\tfor (let i = 0; i < 8; i++) {\n\t\tworkInfluences[i] = [i, 0];\n\t}\n\n\tfunction update(object, geometry, material, program) {\n\t\tconst objectInfluences = object.morphTargetInfluences;\n\n\t\tif (capabilities.isWebGL2 === true) {\n\t\t\t// instead of using attributes, the WebGL 2 code path encodes morph targets\n\t\t\t// into an array of data textures. Each layer represents a single morph target.\n\t\t\tconst morphAttribute = geometry.morphAttributes.position || geometry.morphAttributes.normal || geometry.morphAttributes.color;\n\t\t\tconst morphTargetsCount = morphAttribute !== undefined ? morphAttribute.length : 0;\n\t\t\tlet entry = morphTextures.get(geometry);\n\n\t\t\tif (entry === undefined || entry.count !== morphTargetsCount) {\n\t\t\t\tif (entry !== undefined) entry.texture.dispose();\n\t\t\t\tconst hasMorphPosition = geometry.morphAttributes.position !== undefined;\n\t\t\t\tconst hasMorphNormals = geometry.morphAttributes.normal !== undefined;\n\t\t\t\tconst hasMorphColors = geometry.morphAttributes.color !== undefined;\n\t\t\t\tconst morphTargets = geometry.morphAttributes.position || [];\n\t\t\t\tconst morphNormals = geometry.morphAttributes.normal || [];\n\t\t\t\tconst morphColors = geometry.morphAttributes.color || [];\n\t\t\t\tlet vertexDataCount = 0;\n\t\t\t\tif (hasMorphPosition === true) vertexDataCount = 1;\n\t\t\t\tif (hasMorphNormals === true) vertexDataCount = 2;\n\t\t\t\tif (hasMorphColors === true) vertexDataCount = 3;\n\t\t\t\tlet width = geometry.attributes.position.count * vertexDataCount;\n\t\t\t\tlet height = 1;\n\n\t\t\t\tif (width > capabilities.maxTextureSize) {\n\t\t\t\t\theight = Math.ceil(width / capabilities.maxTextureSize);\n\t\t\t\t\twidth = capabilities.maxTextureSize;\n\t\t\t\t}\n\n\t\t\t\tconst buffer = new Float32Array(width * height * 4 * morphTargetsCount);\n\t\t\t\tconst texture = new DataArrayTexture(buffer, width, height, morphTargetsCount);\n\t\t\t\ttexture.type = FloatType;\n\t\t\t\ttexture.needsUpdate = true; // fill buffer\n\n\t\t\t\tconst vertexDataStride = vertexDataCount * 4;\n\n\t\t\t\tfor (let i = 0; i < morphTargetsCount; i++) {\n\t\t\t\t\tconst morphTarget = morphTargets[i];\n\t\t\t\t\tconst morphNormal = morphNormals[i];\n\t\t\t\t\tconst morphColor = morphColors[i];\n\t\t\t\t\tconst offset = width * height * 4 * i;\n\n\t\t\t\t\tfor (let j = 0; j < morphTarget.count; j++) {\n\t\t\t\t\t\tconst stride = j * vertexDataStride;\n\n\t\t\t\t\t\tif (hasMorphPosition === true) {\n\t\t\t\t\t\t\tmorph.fromBufferAttribute(morphTarget, j);\n\t\t\t\t\t\t\tif (morphTarget.normalized === true) denormalize(morph, morphTarget);\n\t\t\t\t\t\t\tbuffer[offset + stride + 0] = morph.x;\n\t\t\t\t\t\t\tbuffer[offset + stride + 1] = morph.y;\n\t\t\t\t\t\t\tbuffer[offset + stride + 2] = morph.z;\n\t\t\t\t\t\t\tbuffer[offset + stride + 3] = 0;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (hasMorphNormals === true) {\n\t\t\t\t\t\t\tmorph.fromBufferAttribute(morphNormal, j);\n\t\t\t\t\t\t\tif (morphNormal.normalized === true) denormalize(morph, morphNormal);\n\t\t\t\t\t\t\tbuffer[offset + stride + 4] = morph.x;\n\t\t\t\t\t\t\tbuffer[offset + stride + 5] = morph.y;\n\t\t\t\t\t\t\tbuffer[offset + stride + 6] = morph.z;\n\t\t\t\t\t\t\tbuffer[offset + stride + 7] = 0;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (hasMorphColors === true) {\n\t\t\t\t\t\t\tmorph.fromBufferAttribute(morphColor, j);\n\t\t\t\t\t\t\tif (morphColor.normalized === true) denormalize(morph, morphColor);\n\t\t\t\t\t\t\tbuffer[offset + stride + 8] = morph.x;\n\t\t\t\t\t\t\tbuffer[offset + stride + 9] = morph.y;\n\t\t\t\t\t\t\tbuffer[offset + stride + 10] = morph.z;\n\t\t\t\t\t\t\tbuffer[offset + stride + 11] = morphColor.itemSize === 4 ? morph.w : 1;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tentry = {\n\t\t\t\t\tcount: morphTargetsCount,\n\t\t\t\t\ttexture: texture,\n\t\t\t\t\tsize: new Vector2(width, height)\n\t\t\t\t};\n\t\t\t\tmorphTextures.set(geometry, entry);\n\n\t\t\t\tfunction disposeTexture() {\n\t\t\t\t\ttexture.dispose();\n\t\t\t\t\tmorphTextures.delete(geometry);\n\t\t\t\t\tgeometry.removeEventListener('dispose', disposeTexture);\n\t\t\t\t}\n\n\t\t\t\tgeometry.addEventListener('dispose', disposeTexture);\n\t\t\t} //\n\n\n\t\t\tlet morphInfluencesSum = 0;\n\n\t\t\tfor (let i = 0; i < objectInfluences.length; i++) {\n\t\t\t\tmorphInfluencesSum += objectInfluences[i];\n\t\t\t}\n\n\t\t\tconst morphBaseInfluence = geometry.morphTargetsRelative ? 1 : 1 - morphInfluencesSum;\n\t\t\tprogram.getUniforms().setValue(gl, 'morphTargetBaseInfluence', morphBaseInfluence);\n\t\t\tprogram.getUniforms().setValue(gl, 'morphTargetInfluences', objectInfluences);\n\t\t\tprogram.getUniforms().setValue(gl, 'morphTargetsTexture', entry.texture, textures);\n\t\t\tprogram.getUniforms().setValue(gl, 'morphTargetsTextureSize', entry.size);\n\t\t} else {\n\t\t\t// When object doesn't have morph target influences defined, we treat it as a 0-length array\n\t\t\t// This is important to make sure we set up morphTargetBaseInfluence / morphTargetInfluences\n\t\t\tconst length = objectInfluences === undefined ? 0 : objectInfluences.length;\n\t\t\tlet influences = influencesList[geometry.id];\n\n\t\t\tif (influences === undefined || influences.length !== length) {\n\t\t\t\t// initialise list\n\t\t\t\tinfluences = [];\n\n\t\t\t\tfor (let i = 0; i < length; i++) {\n\t\t\t\t\tinfluences[i] = [i, 0];\n\t\t\t\t}\n\n\t\t\t\tinfluencesList[geometry.id] = influences;\n\t\t\t} // Collect influences\n\n\n\t\t\tfor (let i = 0; i < length; i++) {\n\t\t\t\tconst influence = influences[i];\n\t\t\t\tinfluence[0] = i;\n\t\t\t\tinfluence[1] = objectInfluences[i];\n\t\t\t}\n\n\t\t\tinfluences.sort(absNumericalSort);\n\n\t\t\tfor (let i = 0; i < 8; i++) {\n\t\t\t\tif (i < length && influences[i][1]) {\n\t\t\t\t\tworkInfluences[i][0] = influences[i][0];\n\t\t\t\t\tworkInfluences[i][1] = influences[i][1];\n\t\t\t\t} else {\n\t\t\t\t\tworkInfluences[i][0] = Number.MAX_SAFE_INTEGER;\n\t\t\t\t\tworkInfluences[i][1] = 0;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tworkInfluences.sort(numericalSort);\n\t\t\tconst morphTargets = geometry.morphAttributes.position;\n\t\t\tconst morphNormals = geometry.morphAttributes.normal;\n\t\t\tlet morphInfluencesSum = 0;\n\n\t\t\tfor (let i = 0; i < 8; i++) {\n\t\t\t\tconst influence = workInfluences[i];\n\t\t\t\tconst index = influence[0];\n\t\t\t\tconst value = influence[1];\n\n\t\t\t\tif (index !== Number.MAX_SAFE_INTEGER && value) {\n\t\t\t\t\tif (morphTargets && geometry.getAttribute('morphTarget' + i) !== morphTargets[index]) {\n\t\t\t\t\t\tgeometry.setAttribute('morphTarget' + i, morphTargets[index]);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (morphNormals && geometry.getAttribute('morphNormal' + i) !== morphNormals[index]) {\n\t\t\t\t\t\tgeometry.setAttribute('morphNormal' + i, morphNormals[index]);\n\t\t\t\t\t}\n\n\t\t\t\t\tmorphInfluences[i] = value;\n\t\t\t\t\tmorphInfluencesSum += value;\n\t\t\t\t} else {\n\t\t\t\t\tif (morphTargets && geometry.hasAttribute('morphTarget' + i) === true) {\n\t\t\t\t\t\tgeometry.deleteAttribute('morphTarget' + i);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (morphNormals && geometry.hasAttribute('morphNormal' + i) === true) {\n\t\t\t\t\t\tgeometry.deleteAttribute('morphNormal' + i);\n\t\t\t\t\t}\n\n\t\t\t\t\tmorphInfluences[i] = 0;\n\t\t\t\t}\n\t\t\t} // GLSL shader uses formula baseinfluence * base + sum(target * influence)\n\t\t\t// This allows us to switch between absolute morphs and relative morphs without changing shader code\n\t\t\t// When baseinfluence = 1 - sum(influence), the above is equivalent to sum((target - base) * influence)\n\n\n\t\t\tconst morphBaseInfluence = geometry.morphTargetsRelative ? 1 : 1 - morphInfluencesSum;\n\t\t\tprogram.getUniforms().setValue(gl, 'morphTargetBaseInfluence', morphBaseInfluence);\n\t\t\tprogram.getUniforms().setValue(gl, 'morphTargetInfluences', morphInfluences);\n\t\t}\n\t}\n\n\treturn {\n\t\tupdate: update\n\t};\n}\n\nfunction WebGLObjects(gl, geometries, attributes, info) {\n\tlet updateMap = new WeakMap();\n\n\tfunction update(object) {\n\t\tconst frame = info.render.frame;\n\t\tconst geometry = object.geometry;\n\t\tconst buffergeometry = geometries.get(object, geometry); // Update once per frame\n\n\t\tif (updateMap.get(buffergeometry) !== frame) {\n\t\t\tgeometries.update(buffergeometry);\n\t\t\tupdateMap.set(buffergeometry, frame);\n\t\t}\n\n\t\tif (object.isInstancedMesh) {\n\t\t\tif (object.hasEventListener('dispose', onInstancedMeshDispose) === false) {\n\t\t\t\tobject.addEventListener('dispose', onInstancedMeshDispose);\n\t\t\t}\n\n\t\t\tattributes.update(object.instanceMatrix, gl.ARRAY_BUFFER);\n\n\t\t\tif (object.instanceColor !== null) {\n\t\t\t\tattributes.update(object.instanceColor, gl.ARRAY_BUFFER);\n\t\t\t}\n\t\t}\n\n\t\treturn buffergeometry;\n\t}\n\n\tfunction dispose() {\n\t\tupdateMap = new WeakMap();\n\t}\n\n\tfunction onInstancedMeshDispose(event) {\n\t\tconst instancedMesh = event.target;\n\t\tinstancedMesh.removeEventListener('dispose', onInstancedMeshDispose);\n\t\tattributes.remove(instancedMesh.instanceMatrix);\n\t\tif (instancedMesh.instanceColor !== null) attributes.remove(instancedMesh.instanceColor);\n\t}\n\n\treturn {\n\t\tupdate: update,\n\t\tdispose: dispose\n\t};\n}\n\n/**\n * Uniforms of a program.\n * Those form a tree structure with a special top-level container for the root,\n * which you get by calling 'new WebGLUniforms( gl, program )'.\n *\n *\n * Properties of inner nodes including the top-level container:\n *\n * .seq - array of nested uniforms\n * .map - nested uniforms by name\n *\n *\n * Methods of all nodes except the top-level container:\n *\n * .setValue( gl, value, [textures] )\n *\n * \t\tuploads a uniform value(s)\n *\t\tthe 'textures' parameter is needed for sampler uniforms\n *\n *\n * Static methods of the top-level container (textures factorizations):\n *\n * .upload( gl, seq, values, textures )\n *\n * \t\tsets uniforms in 'seq' to 'values[id].value'\n *\n * .seqWithValue( seq, values ) : filteredSeq\n *\n * \t\tfilters 'seq' entries with corresponding entry in values\n *\n *\n * Methods of the top-level container (textures factorizations):\n *\n * .setValue( gl, name, value, textures )\n *\n * \t\tsets uniform with\tname 'name' to 'value'\n *\n * .setOptional( gl, obj, prop )\n *\n * \t\tlike .set for an optional property of the object\n *\n */\nconst emptyTexture = new Texture();\nconst emptyArrayTexture = new DataArrayTexture();\nconst empty3dTexture = new Data3DTexture();\nconst emptyCubeTexture = new CubeTexture(); // --- Utilities ---\n// Array Caches (provide typed arrays for temporary by size)\n\nconst arrayCacheF32 = [];\nconst arrayCacheI32 = []; // Float32Array caches used for uploading Matrix uniforms\n\nconst mat4array = new Float32Array(16);\nconst mat3array = new Float32Array(9);\nconst mat2array = new Float32Array(4); // Flattening for arrays of vectors and matrices\n\nfunction flatten(array, nBlocks, blockSize) {\n\tconst firstElem = array[0];\n\tif (firstElem <= 0 || firstElem > 0) return array; // unoptimized: ! isNaN( firstElem )\n\t// see http://jacksondunstan.com/articles/983\n\n\tconst n = nBlocks * blockSize;\n\tlet r = arrayCacheF32[n];\n\n\tif (r === undefined) {\n\t\tr = new Float32Array(n);\n\t\tarrayCacheF32[n] = r;\n\t}\n\n\tif (nBlocks !== 0) {\n\t\tfirstElem.toArray(r, 0);\n\n\t\tfor (let i = 1, offset = 0; i !== nBlocks; ++i) {\n\t\t\toffset += blockSize;\n\t\t\tarray[i].toArray(r, offset);\n\t\t}\n\t}\n\n\treturn r;\n}\n\nfunction arraysEqual(a, b) {\n\tif (a.length !== b.length) return false;\n\n\tfor (let i = 0, l = a.length; i < l; i++) {\n\t\tif (a[i] !== b[i]) return false;\n\t}\n\n\treturn true;\n}\n\nfunction copyArray(a, b) {\n\tfor (let i = 0, l = b.length; i < l; i++) {\n\t\ta[i] = b[i];\n\t}\n} // Texture unit allocation\n\n\nfunction allocTexUnits(textures, n) {\n\tlet r = arrayCacheI32[n];\n\n\tif (r === undefined) {\n\t\tr = new Int32Array(n);\n\t\tarrayCacheI32[n] = r;\n\t}\n\n\tfor (let i = 0; i !== n; ++i) {\n\t\tr[i] = textures.allocateTextureUnit();\n\t}\n\n\treturn r;\n} // --- Setters ---\n// Note: Defining these methods externally, because they come in a bunch\n// and this way their names minify.\n// Single scalar\n\n\nfunction setValueV1f(gl, v) {\n\tconst cache = this.cache;\n\tif (cache[0] === v) return;\n\tgl.uniform1f(this.addr, v);\n\tcache[0] = v;\n} // Single float vector (from flat array or THREE.VectorN)\n\n\nfunction setValueV2f(gl, v) {\n\tconst cache = this.cache;\n\n\tif (v.x !== undefined) {\n\t\tif (cache[0] !== v.x || cache[1] !== v.y) {\n\t\t\tgl.uniform2f(this.addr, v.x, v.y);\n\t\t\tcache[0] = v.x;\n\t\t\tcache[1] = v.y;\n\t\t}\n\t} else {\n\t\tif (arraysEqual(cache, v)) return;\n\t\tgl.uniform2fv(this.addr, v);\n\t\tcopyArray(cache, v);\n\t}\n}\n\nfunction setValueV3f(gl, v) {\n\tconst cache = this.cache;\n\n\tif (v.x !== undefined) {\n\t\tif (cache[0] !== v.x || cache[1] !== v.y || cache[2] !== v.z) {\n\t\t\tgl.uniform3f(this.addr, v.x, v.y, v.z);\n\t\t\tcache[0] = v.x;\n\t\t\tcache[1] = v.y;\n\t\t\tcache[2] = v.z;\n\t\t}\n\t} else if (v.r !== undefined) {\n\t\tif (cache[0] !== v.r || cache[1] !== v.g || cache[2] !== v.b) {\n\t\t\tgl.uniform3f(this.addr, v.r, v.g, v.b);\n\t\t\tcache[0] = v.r;\n\t\t\tcache[1] = v.g;\n\t\t\tcache[2] = v.b;\n\t\t}\n\t} else {\n\t\tif (arraysEqual(cache, v)) return;\n\t\tgl.uniform3fv(this.addr, v);\n\t\tcopyArray(cache, v);\n\t}\n}\n\nfunction setValueV4f(gl, v) {\n\tconst cache = this.cache;\n\n\tif (v.x !== undefined) {\n\t\tif (cache[0] !== v.x || cache[1] !== v.y || cache[2] !== v.z || cache[3] !== v.w) {\n\t\t\tgl.uniform4f(this.addr, v.x, v.y, v.z, v.w);\n\t\t\tcache[0] = v.x;\n\t\t\tcache[1] = v.y;\n\t\t\tcache[2] = v.z;\n\t\t\tcache[3] = v.w;\n\t\t}\n\t} else {\n\t\tif (arraysEqual(cache, v)) return;\n\t\tgl.uniform4fv(this.addr, v);\n\t\tcopyArray(cache, v);\n\t}\n} // Single matrix (from flat array or THREE.MatrixN)\n\n\nfunction setValueM2(gl, v) {\n\tconst cache = this.cache;\n\tconst elements = v.elements;\n\n\tif (elements === undefined) {\n\t\tif (arraysEqual(cache, v)) return;\n\t\tgl.uniformMatrix2fv(this.addr, false, v);\n\t\tcopyArray(cache, v);\n\t} else {\n\t\tif (arraysEqual(cache, elements)) return;\n\t\tmat2array.set(elements);\n\t\tgl.uniformMatrix2fv(this.addr, false, mat2array);\n\t\tcopyArray(cache, elements);\n\t}\n}\n\nfunction setValueM3(gl, v) {\n\tconst cache = this.cache;\n\tconst elements = v.elements;\n\n\tif (elements === undefined) {\n\t\tif (arraysEqual(cache, v)) return;\n\t\tgl.uniformMatrix3fv(this.addr, false, v);\n\t\tcopyArray(cache, v);\n\t} else {\n\t\tif (arraysEqual(cache, elements)) return;\n\t\tmat3array.set(elements);\n\t\tgl.uniformMatrix3fv(this.addr, false, mat3array);\n\t\tcopyArray(cache, elements);\n\t}\n}\n\nfunction setValueM4(gl, v) {\n\tconst cache = this.cache;\n\tconst elements = v.elements;\n\n\tif (elements === undefined) {\n\t\tif (arraysEqual(cache, v)) return;\n\t\tgl.uniformMatrix4fv(this.addr, false, v);\n\t\tcopyArray(cache, v);\n\t} else {\n\t\tif (arraysEqual(cache, elements)) return;\n\t\tmat4array.set(elements);\n\t\tgl.uniformMatrix4fv(this.addr, false, mat4array);\n\t\tcopyArray(cache, elements);\n\t}\n} // Single integer / boolean\n\n\nfunction setValueV1i(gl, v) {\n\tconst cache = this.cache;\n\tif (cache[0] === v) return;\n\tgl.uniform1i(this.addr, v);\n\tcache[0] = v;\n} // Single integer / boolean vector (from flat array)\n\n\nfunction setValueV2i(gl, v) {\n\tconst cache = this.cache;\n\tif (arraysEqual(cache, v)) return;\n\tgl.uniform2iv(this.addr, v);\n\tcopyArray(cache, v);\n}\n\nfunction setValueV3i(gl, v) {\n\tconst cache = this.cache;\n\tif (arraysEqual(cache, v)) return;\n\tgl.uniform3iv(this.addr, v);\n\tcopyArray(cache, v);\n}\n\nfunction setValueV4i(gl, v) {\n\tconst cache = this.cache;\n\tif (arraysEqual(cache, v)) return;\n\tgl.uniform4iv(this.addr, v);\n\tcopyArray(cache, v);\n} // Single unsigned integer\n\n\nfunction setValueV1ui(gl, v) {\n\tconst cache = this.cache;\n\tif (cache[0] === v) return;\n\tgl.uniform1ui(this.addr, v);\n\tcache[0] = v;\n} // Single unsigned integer vector (from flat array)\n\n\nfunction setValueV2ui(gl, v) {\n\tconst cache = this.cache;\n\tif (arraysEqual(cache, v)) return;\n\tgl.uniform2uiv(this.addr, v);\n\tcopyArray(cache, v);\n}\n\nfunction setValueV3ui(gl, v) {\n\tconst cache = this.cache;\n\tif (arraysEqual(cache, v)) return;\n\tgl.uniform3uiv(this.addr, v);\n\tcopyArray(cache, v);\n}\n\nfunction setValueV4ui(gl, v) {\n\tconst cache = this.cache;\n\tif (arraysEqual(cache, v)) return;\n\tgl.uniform4uiv(this.addr, v);\n\tcopyArray(cache, v);\n} // Single texture (2D / Cube)\n\n\nfunction setValueT1(gl, v, textures) {\n\tconst cache = this.cache;\n\tconst unit = textures.allocateTextureUnit();\n\n\tif (cache[0] !== unit) {\n\t\tgl.uniform1i(this.addr, unit);\n\t\tcache[0] = unit;\n\t}\n\n\ttextures.setTexture2D(v || emptyTexture, unit);\n}\n\nfunction setValueT3D1(gl, v, textures) {\n\tconst cache = this.cache;\n\tconst unit = textures.allocateTextureUnit();\n\n\tif (cache[0] !== unit) {\n\t\tgl.uniform1i(this.addr, unit);\n\t\tcache[0] = unit;\n\t}\n\n\ttextures.setTexture3D(v || empty3dTexture, unit);\n}\n\nfunction setValueT6(gl, v, textures) {\n\tconst cache = this.cache;\n\tconst unit = textures.allocateTextureUnit();\n\n\tif (cache[0] !== unit) {\n\t\tgl.uniform1i(this.addr, unit);\n\t\tcache[0] = unit;\n\t}\n\n\ttextures.setTextureCube(v || emptyCubeTexture, unit);\n}\n\nfunction setValueT2DArray1(gl, v, textures) {\n\tconst cache = this.cache;\n\tconst unit = textures.allocateTextureUnit();\n\n\tif (cache[0] !== unit) {\n\t\tgl.uniform1i(this.addr, unit);\n\t\tcache[0] = unit;\n\t}\n\n\ttextures.setTexture2DArray(v || emptyArrayTexture, unit);\n} // Helper to pick the right setter for the singular case\n\n\nfunction getSingularSetter(type) {\n\tswitch (type) {\n\t\tcase 0x1406:\n\t\t\treturn setValueV1f;\n\t\t// FLOAT\n\n\t\tcase 0x8b50:\n\t\t\treturn setValueV2f;\n\t\t// _VEC2\n\n\t\tcase 0x8b51:\n\t\t\treturn setValueV3f;\n\t\t// _VEC3\n\n\t\tcase 0x8b52:\n\t\t\treturn setValueV4f;\n\t\t// _VEC4\n\n\t\tcase 0x8b5a:\n\t\t\treturn setValueM2;\n\t\t// _MAT2\n\n\t\tcase 0x8b5b:\n\t\t\treturn setValueM3;\n\t\t// _MAT3\n\n\t\tcase 0x8b5c:\n\t\t\treturn setValueM4;\n\t\t// _MAT4\n\n\t\tcase 0x1404:\n\t\tcase 0x8b56:\n\t\t\treturn setValueV1i;\n\t\t// INT, BOOL\n\n\t\tcase 0x8b53:\n\t\tcase 0x8b57:\n\t\t\treturn setValueV2i;\n\t\t// _VEC2\n\n\t\tcase 0x8b54:\n\t\tcase 0x8b58:\n\t\t\treturn setValueV3i;\n\t\t// _VEC3\n\n\t\tcase 0x8b55:\n\t\tcase 0x8b59:\n\t\t\treturn setValueV4i;\n\t\t// _VEC4\n\n\t\tcase 0x1405:\n\t\t\treturn setValueV1ui;\n\t\t// UINT\n\n\t\tcase 0x8dc6:\n\t\t\treturn setValueV2ui;\n\t\t// _VEC2\n\n\t\tcase 0x8dc7:\n\t\t\treturn setValueV3ui;\n\t\t// _VEC3\n\n\t\tcase 0x8dc8:\n\t\t\treturn setValueV4ui;\n\t\t// _VEC4\n\n\t\tcase 0x8b5e: // SAMPLER_2D\n\n\t\tcase 0x8d66: // SAMPLER_EXTERNAL_OES\n\n\t\tcase 0x8dca: // INT_SAMPLER_2D\n\n\t\tcase 0x8dd2: // UNSIGNED_INT_SAMPLER_2D\n\n\t\tcase 0x8b62:\n\t\t\t// SAMPLER_2D_SHADOW\n\t\t\treturn setValueT1;\n\n\t\tcase 0x8b5f: // SAMPLER_3D\n\n\t\tcase 0x8dcb: // INT_SAMPLER_3D\n\n\t\tcase 0x8dd3:\n\t\t\t// UNSIGNED_INT_SAMPLER_3D\n\t\t\treturn setValueT3D1;\n\n\t\tcase 0x8b60: // SAMPLER_CUBE\n\n\t\tcase 0x8dcc: // INT_SAMPLER_CUBE\n\n\t\tcase 0x8dd4: // UNSIGNED_INT_SAMPLER_CUBE\n\n\t\tcase 0x8dc5:\n\t\t\t// SAMPLER_CUBE_SHADOW\n\t\t\treturn setValueT6;\n\n\t\tcase 0x8dc1: // SAMPLER_2D_ARRAY\n\n\t\tcase 0x8dcf: // INT_SAMPLER_2D_ARRAY\n\n\t\tcase 0x8dd7: // UNSIGNED_INT_SAMPLER_2D_ARRAY\n\n\t\tcase 0x8dc4:\n\t\t\t// SAMPLER_2D_ARRAY_SHADOW\n\t\t\treturn setValueT2DArray1;\n\t}\n} // Array of scalars\n\n\nfunction setValueV1fArray(gl, v) {\n\tgl.uniform1fv(this.addr, v);\n} // Array of vectors (from flat array or array of THREE.VectorN)\n\n\nfunction setValueV2fArray(gl, v) {\n\tconst data = flatten(v, this.size, 2);\n\tgl.uniform2fv(this.addr, data);\n}\n\nfunction setValueV3fArray(gl, v) {\n\tconst data = flatten(v, this.size, 3);\n\tgl.uniform3fv(this.addr, data);\n}\n\nfunction setValueV4fArray(gl, v) {\n\tconst data = flatten(v, this.size, 4);\n\tgl.uniform4fv(this.addr, data);\n} // Array of matrices (from flat array or array of THREE.MatrixN)\n\n\nfunction setValueM2Array(gl, v) {\n\tconst data = flatten(v, this.size, 4);\n\tgl.uniformMatrix2fv(this.addr, false, data);\n}\n\nfunction setValueM3Array(gl, v) {\n\tconst data = flatten(v, this.size, 9);\n\tgl.uniformMatrix3fv(this.addr, false, data);\n}\n\nfunction setValueM4Array(gl, v) {\n\tconst data = flatten(v, this.size, 16);\n\tgl.uniformMatrix4fv(this.addr, false, data);\n} // Array of integer / boolean\n\n\nfunction setValueV1iArray(gl, v) {\n\tgl.uniform1iv(this.addr, v);\n} // Array of integer / boolean vectors (from flat array)\n\n\nfunction setValueV2iArray(gl, v) {\n\tgl.uniform2iv(this.addr, v);\n}\n\nfunction setValueV3iArray(gl, v) {\n\tgl.uniform3iv(this.addr, v);\n}\n\nfunction setValueV4iArray(gl, v) {\n\tgl.uniform4iv(this.addr, v);\n} // Array of unsigned integer\n\n\nfunction setValueV1uiArray(gl, v) {\n\tgl.uniform1uiv(this.addr, v);\n} // Array of unsigned integer vectors (from flat array)\n\n\nfunction setValueV2uiArray(gl, v) {\n\tgl.uniform2uiv(this.addr, v);\n}\n\nfunction setValueV3uiArray(gl, v) {\n\tgl.uniform3uiv(this.addr, v);\n}\n\nfunction setValueV4uiArray(gl, v) {\n\tgl.uniform4uiv(this.addr, v);\n} // Array of textures (2D / 3D / Cube / 2DArray)\n\n\nfunction setValueT1Array(gl, v, textures) {\n\tconst n = v.length;\n\tconst units = allocTexUnits(textures, n);\n\tgl.uniform1iv(this.addr, units);\n\n\tfor (let i = 0; i !== n; ++i) {\n\t\ttextures.setTexture2D(v[i] || emptyTexture, units[i]);\n\t}\n}\n\nfunction setValueT3DArray(gl, v, textures) {\n\tconst n = v.length;\n\tconst units = allocTexUnits(textures, n);\n\tgl.uniform1iv(this.addr, units);\n\n\tfor (let i = 0; i !== n; ++i) {\n\t\ttextures.setTexture3D(v[i] || empty3dTexture, units[i]);\n\t}\n}\n\nfunction setValueT6Array(gl, v, textures) {\n\tconst n = v.length;\n\tconst units = allocTexUnits(textures, n);\n\tgl.uniform1iv(this.addr, units);\n\n\tfor (let i = 0; i !== n; ++i) {\n\t\ttextures.setTextureCube(v[i] || emptyCubeTexture, units[i]);\n\t}\n}\n\nfunction setValueT2DArrayArray(gl, v, textures) {\n\tconst n = v.length;\n\tconst units = allocTexUnits(textures, n);\n\tgl.uniform1iv(this.addr, units);\n\n\tfor (let i = 0; i !== n; ++i) {\n\t\ttextures.setTexture2DArray(v[i] || emptyArrayTexture, units[i]);\n\t}\n} // Helper to pick the right setter for a pure (bottom-level) array\n\n\nfunction getPureArraySetter(type) {\n\tswitch (type) {\n\t\tcase 0x1406:\n\t\t\treturn setValueV1fArray;\n\t\t// FLOAT\n\n\t\tcase 0x8b50:\n\t\t\treturn setValueV2fArray;\n\t\t// _VEC2\n\n\t\tcase 0x8b51:\n\t\t\treturn setValueV3fArray;\n\t\t// _VEC3\n\n\t\tcase 0x8b52:\n\t\t\treturn setValueV4fArray;\n\t\t// _VEC4\n\n\t\tcase 0x8b5a:\n\t\t\treturn setValueM2Array;\n\t\t// _MAT2\n\n\t\tcase 0x8b5b:\n\t\t\treturn setValueM3Array;\n\t\t// _MAT3\n\n\t\tcase 0x8b5c:\n\t\t\treturn setValueM4Array;\n\t\t// _MAT4\n\n\t\tcase 0x1404:\n\t\tcase 0x8b56:\n\t\t\treturn setValueV1iArray;\n\t\t// INT, BOOL\n\n\t\tcase 0x8b53:\n\t\tcase 0x8b57:\n\t\t\treturn setValueV2iArray;\n\t\t// _VEC2\n\n\t\tcase 0x8b54:\n\t\tcase 0x8b58:\n\t\t\treturn setValueV3iArray;\n\t\t// _VEC3\n\n\t\tcase 0x8b55:\n\t\tcase 0x8b59:\n\t\t\treturn setValueV4iArray;\n\t\t// _VEC4\n\n\t\tcase 0x1405:\n\t\t\treturn setValueV1uiArray;\n\t\t// UINT\n\n\t\tcase 0x8dc6:\n\t\t\treturn setValueV2uiArray;\n\t\t// _VEC2\n\n\t\tcase 0x8dc7:\n\t\t\treturn setValueV3uiArray;\n\t\t// _VEC3\n\n\t\tcase 0x8dc8:\n\t\t\treturn setValueV4uiArray;\n\t\t// _VEC4\n\n\t\tcase 0x8b5e: // SAMPLER_2D\n\n\t\tcase 0x8d66: // SAMPLER_EXTERNAL_OES\n\n\t\tcase 0x8dca: // INT_SAMPLER_2D\n\n\t\tcase 0x8dd2: // UNSIGNED_INT_SAMPLER_2D\n\n\t\tcase 0x8b62:\n\t\t\t// SAMPLER_2D_SHADOW\n\t\t\treturn setValueT1Array;\n\n\t\tcase 0x8b5f: // SAMPLER_3D\n\n\t\tcase 0x8dcb: // INT_SAMPLER_3D\n\n\t\tcase 0x8dd3:\n\t\t\t// UNSIGNED_INT_SAMPLER_3D\n\t\t\treturn setValueT3DArray;\n\n\t\tcase 0x8b60: // SAMPLER_CUBE\n\n\t\tcase 0x8dcc: // INT_SAMPLER_CUBE\n\n\t\tcase 0x8dd4: // UNSIGNED_INT_SAMPLER_CUBE\n\n\t\tcase 0x8dc5:\n\t\t\t// SAMPLER_CUBE_SHADOW\n\t\t\treturn setValueT6Array;\n\n\t\tcase 0x8dc1: // SAMPLER_2D_ARRAY\n\n\t\tcase 0x8dcf: // INT_SAMPLER_2D_ARRAY\n\n\t\tcase 0x8dd7: // UNSIGNED_INT_SAMPLER_2D_ARRAY\n\n\t\tcase 0x8dc4:\n\t\t\t// SAMPLER_2D_ARRAY_SHADOW\n\t\t\treturn setValueT2DArrayArray;\n\t}\n} // --- Uniform Classes ---\n\n\nclass SingleUniform {\n\tconstructor(id, activeInfo, addr) {\n\t\tthis.id = id;\n\t\tthis.addr = addr;\n\t\tthis.cache = [];\n\t\tthis.setValue = getSingularSetter(activeInfo.type); // this.path = activeInfo.name; // DEBUG\n\t}\n\n}\n\nclass PureArrayUniform {\n\tconstructor(id, activeInfo, addr) {\n\t\tthis.id = id;\n\t\tthis.addr = addr;\n\t\tthis.cache = [];\n\t\tthis.size = activeInfo.size;\n\t\tthis.setValue = getPureArraySetter(activeInfo.type); // this.path = activeInfo.name; // DEBUG\n\t}\n\n}\n\nclass StructuredUniform {\n\tconstructor(id) {\n\t\tthis.id = id;\n\t\tthis.seq = [];\n\t\tthis.map = {};\n\t}\n\n\tsetValue(gl, value, textures) {\n\t\tconst seq = this.seq;\n\n\t\tfor (let i = 0, n = seq.length; i !== n; ++i) {\n\t\t\tconst u = seq[i];\n\t\t\tu.setValue(gl, value[u.id], textures);\n\t\t}\n\t}\n\n} // --- Top-level ---\n// Parser - builds up the property tree from the path strings\n\n\nconst RePathPart = /(\\w+)(\\])?(\\[|\\.)?/g; // extracts\n// \t- the identifier (member name or array index)\n//\t- followed by an optional right bracket (found when array index)\n//\t- followed by an optional left bracket or dot (type of subscript)\n//\n// Note: These portions can be read in a non-overlapping fashion and\n// allow straightforward parsing of the hierarchy that WebGL encodes\n// in the uniform names.\n\nfunction addUniform(container, uniformObject) {\n\tcontainer.seq.push(uniformObject);\n\tcontainer.map[uniformObject.id] = uniformObject;\n}\n\nfunction parseUniform(activeInfo, addr, container) {\n\tconst path = activeInfo.name,\n\t\t\t\tpathLength = path.length; // reset RegExp object, because of the early exit of a previous run\n\n\tRePathPart.lastIndex = 0;\n\n\twhile (true) {\n\t\tconst match = RePathPart.exec(path),\n\t\t\t\t\tmatchEnd = RePathPart.lastIndex;\n\t\tlet id = match[1];\n\t\tconst idIsIndex = match[2] === ']',\n\t\t\t\t\tsubscript = match[3];\n\t\tif (idIsIndex) id = id | 0; // convert to integer\n\n\t\tif (subscript === undefined || subscript === '[' && matchEnd + 2 === pathLength) {\n\t\t\t// bare name or \"pure\" bottom-level array \"[0]\" suffix\n\t\t\taddUniform(container, subscript === undefined ? new SingleUniform(id, activeInfo, addr) : new PureArrayUniform(id, activeInfo, addr));\n\t\t\tbreak;\n\t\t} else {\n\t\t\t// step into inner node / create it in case it doesn't exist\n\t\t\tconst map = container.map;\n\t\t\tlet next = map[id];\n\n\t\t\tif (next === undefined) {\n\t\t\t\tnext = new StructuredUniform(id);\n\t\t\t\taddUniform(container, next);\n\t\t\t}\n\n\t\t\tcontainer = next;\n\t\t}\n\t}\n} // Root Container\n\n\nclass WebGLUniforms {\n\tconstructor(gl, program) {\n\t\tthis.seq = [];\n\t\tthis.map = {};\n\t\tconst n = gl.getProgramParameter(program, gl.ACTIVE_UNIFORMS);\n\n\t\tfor (let i = 0; i < n; ++i) {\n\t\t\tconst info = gl.getActiveUniform(program, i),\n\t\t\t\t\t\taddr = gl.getUniformLocation(program, info.name);\n\t\t\tparseUniform(info, addr, this);\n\t\t}\n\t}\n\n\tsetValue(gl, name, value, textures) {\n\t\tconst u = this.map[name];\n\t\tif (u !== undefined) u.setValue(gl, value, textures);\n\t}\n\n\tsetOptional(gl, object, name) {\n\t\tconst v = object[name];\n\t\tif (v !== undefined) this.setValue(gl, name, v);\n\t}\n\n\tstatic upload(gl, seq, values, textures) {\n\t\tfor (let i = 0, n = seq.length; i !== n; ++i) {\n\t\t\tconst u = seq[i],\n\t\t\t\t\t\tv = values[u.id];\n\n\t\t\tif (v.needsUpdate !== false) {\n\t\t\t\t// note: always updating when .needsUpdate is undefined\n\t\t\t\tu.setValue(gl, v.value, textures);\n\t\t\t}\n\t\t}\n\t}\n\n\tstatic seqWithValue(seq, values) {\n\t\tconst r = [];\n\n\t\tfor (let i = 0, n = seq.length; i !== n; ++i) {\n\t\t\tconst u = seq[i];\n\t\t\tif (u.id in values) r.push(u);\n\t\t}\n\n\t\treturn r;\n\t}\n\n}\n\nfunction WebGLShader(gl, type, string) {\n\tconst shader = gl.createShader(type);\n\tgl.shaderSource(shader, string);\n\tgl.compileShader(shader);\n\treturn shader;\n}\n\nlet programIdCount = 0;\n\nfunction handleSource(string, errorLine) {\n\tconst lines = string.split('\\n');\n\tconst lines2 = [];\n\tconst from = Math.max(errorLine - 6, 0);\n\tconst to = Math.min(errorLine + 6, lines.length);\n\n\tfor (let i = from; i < to; i++) {\n\t\tconst line = i + 1;\n\t\tlines2.push(`${line === errorLine ? '>' : ' '} ${line}: ${lines[i]}`);\n\t}\n\n\treturn lines2.join('\\n');\n}\n\nfunction getEncodingComponents(encoding) {\n\tswitch (encoding) {\n\t\tcase LinearEncoding:\n\t\t\treturn ['Linear', '( value )'];\n\n\t\tcase sRGBEncoding:\n\t\t\treturn ['sRGB', '( value )'];\n\n\t\tdefault:\n\t\t\tconsole.warn('THREE.WebGLProgram: Unsupported encoding:', encoding);\n\t\t\treturn ['Linear', '( value )'];\n\t}\n}\n\nfunction getShaderErrors(gl, shader, type) {\n\tconst status = gl.getShaderParameter(shader, gl.COMPILE_STATUS);\n\tconst errors = gl.getShaderInfoLog(shader).trim();\n\tif (status && errors === '') return '';\n\tconst errorMatches = /ERROR: 0:(\\d+)/.exec(errors);\n\n\tif (errorMatches) {\n\t\t// --enable-privileged-webgl-extension\n\t\t// console.log( '**' + type + '**', gl.getExtension( 'WEBGL_debug_shaders' ).getTranslatedShaderSource( shader ) );\n\t\tconst errorLine = parseInt(errorMatches[1]);\n\t\treturn type.toUpperCase() + '\\n\\n' + errors + '\\n\\n' + handleSource(gl.getShaderSource(shader), errorLine);\n\t} else {\n\t\treturn errors;\n\t}\n}\n\nfunction getTexelEncodingFunction(functionName, encoding) {\n\tconst components = getEncodingComponents(encoding);\n\treturn 'vec4 ' + functionName + '( vec4 value ) { return LinearTo' + components[0] + components[1] + '; }';\n}\n\nfunction getToneMappingFunction(functionName, toneMapping) {\n\tlet toneMappingName;\n\n\tswitch (toneMapping) {\n\t\tcase LinearToneMapping:\n\t\t\ttoneMappingName = 'Linear';\n\t\t\tbreak;\n\n\t\tcase ReinhardToneMapping:\n\t\t\ttoneMappingName = 'Reinhard';\n\t\t\tbreak;\n\n\t\tcase CineonToneMapping:\n\t\t\ttoneMappingName = 'OptimizedCineon';\n\t\t\tbreak;\n\n\t\tcase ACESFilmicToneMapping:\n\t\t\ttoneMappingName = 'ACESFilmic';\n\t\t\tbreak;\n\n\t\tcase CustomToneMapping:\n\t\t\ttoneMappingName = 'Custom';\n\t\t\tbreak;\n\n\t\tdefault:\n\t\t\tconsole.warn('THREE.WebGLProgram: Unsupported toneMapping:', toneMapping);\n\t\t\ttoneMappingName = 'Linear';\n\t}\n\n\treturn 'vec3 ' + functionName + '( vec3 color ) { return ' + toneMappingName + 'ToneMapping( color ); }';\n}\n\nfunction generateExtensions(parameters) {\n\tconst chunks = [parameters.extensionDerivatives || !!parameters.envMapCubeUVHeight || parameters.bumpMap || parameters.tangentSpaceNormalMap || parameters.clearcoatNormalMap || parameters.flatShading || parameters.shaderID === 'physical' ? '#extension GL_OES_standard_derivatives : enable' : '', (parameters.extensionFragDepth || parameters.logarithmicDepthBuffer) && parameters.rendererExtensionFragDepth ? '#extension GL_EXT_frag_depth : enable' : '', parameters.extensionDrawBuffers && parameters.rendererExtensionDrawBuffers ? '#extension GL_EXT_draw_buffers : require' : '', (parameters.extensionShaderTextureLOD || parameters.envMap || parameters.transmission) && parameters.rendererExtensionShaderTextureLod ? '#extension GL_EXT_shader_texture_lod : enable' : ''];\n\treturn chunks.filter(filterEmptyLine).join('\\n');\n}\n\nfunction generateDefines(defines) {\n\tconst chunks = [];\n\n\tfor (const name in defines) {\n\t\tconst value = defines[name];\n\t\tif (value === false) continue;\n\t\tchunks.push('#define ' + name + ' ' + value);\n\t}\n\n\treturn chunks.join('\\n');\n}\n\nfunction fetchAttributeLocations(gl, program) {\n\tconst attributes = {};\n\tconst n = gl.getProgramParameter(program, gl.ACTIVE_ATTRIBUTES);\n\n\tfor (let i = 0; i < n; i++) {\n\t\tconst info = gl.getActiveAttrib(program, i);\n\t\tconst name = info.name;\n\t\tlet locationSize = 1;\n\t\tif (info.type === gl.FLOAT_MAT2) locationSize = 2;\n\t\tif (info.type === gl.FLOAT_MAT3) locationSize = 3;\n\t\tif (info.type === gl.FLOAT_MAT4) locationSize = 4; // console.log( 'THREE.WebGLProgram: ACTIVE VERTEX ATTRIBUTE:', name, i );\n\n\t\tattributes[name] = {\n\t\t\ttype: info.type,\n\t\t\tlocation: gl.getAttribLocation(program, name),\n\t\t\tlocationSize: locationSize\n\t\t};\n\t}\n\n\treturn attributes;\n}\n\nfunction filterEmptyLine(string) {\n\treturn string !== '';\n}\n\nfunction replaceLightNums(string, parameters) {\n\treturn string.replace(/NUM_DIR_LIGHTS/g, parameters.numDirLights).replace(/NUM_SPOT_LIGHTS/g, parameters.numSpotLights).replace(/NUM_RECT_AREA_LIGHTS/g, parameters.numRectAreaLights).replace(/NUM_POINT_LIGHTS/g, parameters.numPointLights).replace(/NUM_HEMI_LIGHTS/g, parameters.numHemiLights).replace(/NUM_DIR_LIGHT_SHADOWS/g, parameters.numDirLightShadows).replace(/NUM_SPOT_LIGHT_SHADOWS/g, parameters.numSpotLightShadows).replace(/NUM_POINT_LIGHT_SHADOWS/g, parameters.numPointLightShadows);\n}\n\nfunction replaceClippingPlaneNums(string, parameters) {\n\treturn string.replace(/NUM_CLIPPING_PLANES/g, parameters.numClippingPlanes).replace(/UNION_CLIPPING_PLANES/g, parameters.numClippingPlanes - parameters.numClipIntersection);\n} // Resolve Includes\n\n\nconst includePattern = /^[ \\t]*#include +<([\\w\\d./]+)>/gm;\n\nfunction resolveIncludes(string) {\n\treturn string.replace(includePattern, includeReplacer);\n}\n\nfunction includeReplacer(match, include) {\n\tconst string = ShaderChunk[include];\n\n\tif (string === undefined) {\n\t\tthrow new Error('Can not resolve #include <' + include + '>');\n\t}\n\n\treturn resolveIncludes(string);\n} // Unroll Loops\n\n\nconst deprecatedUnrollLoopPattern = /#pragma unroll_loop[\\s]+?for \\( int i \\= (\\d+)\\; i < (\\d+)\\; i \\+\\+ \\) \\{([\\s\\S]+?)(?=\\})\\}/g;\nconst unrollLoopPattern = /#pragma unroll_loop_start\\s+for\\s*\\(\\s*int\\s+i\\s*=\\s*(\\d+)\\s*;\\s*i\\s*<\\s*(\\d+)\\s*;\\s*i\\s*\\+\\+\\s*\\)\\s*{([\\s\\S]+?)}\\s+#pragma unroll_loop_end/g;\n\nfunction unrollLoops(string) {\n\treturn string.replace(unrollLoopPattern, loopReplacer).replace(deprecatedUnrollLoopPattern, deprecatedLoopReplacer);\n}\n\nfunction deprecatedLoopReplacer(match, start, end, snippet) {\n\tconsole.warn('WebGLProgram: #pragma unroll_loop shader syntax is deprecated. Please use #pragma unroll_loop_start syntax instead.');\n\treturn loopReplacer(match, start, end, snippet);\n}\n\nfunction loopReplacer(match, start, end, snippet) {\n\tlet string = '';\n\n\tfor (let i = parseInt(start); i < parseInt(end); i++) {\n\t\tstring += snippet.replace(/\\[\\s*i\\s*\\]/g, '[ ' + i + ' ]').replace(/UNROLLED_LOOP_INDEX/g, i);\n\t}\n\n\treturn string;\n} //\n\n\nfunction generatePrecision(parameters) {\n\tlet precisionstring = 'precision ' + parameters.precision + ' float;\\nprecision ' + parameters.precision + ' int;';\n\n\tif (parameters.precision === 'highp') {\n\t\tprecisionstring += '\\n#define HIGH_PRECISION';\n\t} else if (parameters.precision === 'mediump') {\n\t\tprecisionstring += '\\n#define MEDIUM_PRECISION';\n\t} else if (parameters.precision === 'lowp') {\n\t\tprecisionstring += '\\n#define LOW_PRECISION';\n\t}\n\n\treturn precisionstring;\n}\n\nfunction generateShadowMapTypeDefine(parameters) {\n\tlet shadowMapTypeDefine = 'SHADOWMAP_TYPE_BASIC';\n\n\tif (parameters.shadowMapType === PCFShadowMap) {\n\t\tshadowMapTypeDefine = 'SHADOWMAP_TYPE_PCF';\n\t} else if (parameters.shadowMapType === PCFSoftShadowMap) {\n\t\tshadowMapTypeDefine = 'SHADOWMAP_TYPE_PCF_SOFT';\n\t} else if (parameters.shadowMapType === VSMShadowMap) {\n\t\tshadowMapTypeDefine = 'SHADOWMAP_TYPE_VSM';\n\t}\n\n\treturn shadowMapTypeDefine;\n}\n\nfunction generateEnvMapTypeDefine(parameters) {\n\tlet envMapTypeDefine = 'ENVMAP_TYPE_CUBE';\n\n\tif (parameters.envMap) {\n\t\tswitch (parameters.envMapMode) {\n\t\t\tcase CubeReflectionMapping:\n\t\t\tcase CubeRefractionMapping:\n\t\t\t\tenvMapTypeDefine = 'ENVMAP_TYPE_CUBE';\n\t\t\t\tbreak;\n\n\t\t\tcase CubeUVReflectionMapping:\n\t\t\t\tenvMapTypeDefine = 'ENVMAP_TYPE_CUBE_UV';\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\treturn envMapTypeDefine;\n}\n\nfunction generateEnvMapModeDefine(parameters) {\n\tlet envMapModeDefine = 'ENVMAP_MODE_REFLECTION';\n\n\tif (parameters.envMap) {\n\t\tswitch (parameters.envMapMode) {\n\t\t\tcase CubeRefractionMapping:\n\t\t\t\tenvMapModeDefine = 'ENVMAP_MODE_REFRACTION';\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\treturn envMapModeDefine;\n}\n\nfunction generateEnvMapBlendingDefine(parameters) {\n\tlet envMapBlendingDefine = 'ENVMAP_BLENDING_NONE';\n\n\tif (parameters.envMap) {\n\t\tswitch (parameters.combine) {\n\t\t\tcase MultiplyOperation:\n\t\t\t\tenvMapBlendingDefine = 'ENVMAP_BLENDING_MULTIPLY';\n\t\t\t\tbreak;\n\n\t\t\tcase MixOperation:\n\t\t\t\tenvMapBlendingDefine = 'ENVMAP_BLENDING_MIX';\n\t\t\t\tbreak;\n\n\t\t\tcase AddOperation:\n\t\t\t\tenvMapBlendingDefine = 'ENVMAP_BLENDING_ADD';\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\treturn envMapBlendingDefine;\n}\n\nfunction generateCubeUVSize(parameters) {\n\tconst imageHeight = parameters.envMapCubeUVHeight;\n\tif (imageHeight === null) return null;\n\tconst maxMip = Math.log2(imageHeight) - 2;\n\tconst texelHeight = 1.0 / imageHeight;\n\tconst texelWidth = 1.0 / (3 * Math.max(Math.pow(2, maxMip), 7 * 16));\n\treturn {\n\t\ttexelWidth,\n\t\ttexelHeight,\n\t\tmaxMip\n\t};\n}\n\nfunction WebGLProgram(renderer, cacheKey, parameters, bindingStates) {\n\t// TODO Send this event to Three.js DevTools\n\t// console.log( 'WebGLProgram', cacheKey );\n\tconst gl = renderer.getContext();\n\tconst defines = parameters.defines;\n\tlet vertexShader = parameters.vertexShader;\n\tlet fragmentShader = parameters.fragmentShader;\n\tconst shadowMapTypeDefine = generateShadowMapTypeDefine(parameters);\n\tconst envMapTypeDefine = generateEnvMapTypeDefine(parameters);\n\tconst envMapModeDefine = generateEnvMapModeDefine(parameters);\n\tconst envMapBlendingDefine = generateEnvMapBlendingDefine(parameters);\n\tconst envMapCubeUVSize = generateCubeUVSize(parameters);\n\tconst customExtensions = parameters.isWebGL2 ? '' : generateExtensions(parameters);\n\tconst customDefines = generateDefines(defines);\n\tconst program = gl.createProgram();\n\tlet prefixVertex, prefixFragment;\n\tlet versionString = parameters.glslVersion ? '#version ' + parameters.glslVersion + '\\n' : '';\n\n\tif (parameters.isRawShaderMaterial) {\n\t\tprefixVertex = [customDefines].filter(filterEmptyLine).join('\\n');\n\n\t\tif (prefixVertex.length > 0) {\n\t\t\tprefixVertex += '\\n';\n\t\t}\n\n\t\tprefixFragment = [customExtensions, customDefines].filter(filterEmptyLine).join('\\n');\n\n\t\tif (prefixFragment.length > 0) {\n\t\t\tprefixFragment += '\\n';\n\t\t}\n\t} else {\n\t\tprefixVertex = [generatePrecision(parameters), '#define SHADER_NAME ' + parameters.shaderName, customDefines, parameters.instancing ? '#define USE_INSTANCING' : '', parameters.instancingColor ? '#define USE_INSTANCING_COLOR' : '', parameters.supportsVertexTextures ? '#define VERTEX_TEXTURES' : '', parameters.useFog && parameters.fog ? '#define USE_FOG' : '', parameters.useFog && parameters.fogExp2 ? '#define FOG_EXP2' : '', parameters.map ? '#define USE_MAP' : '', parameters.envMap ? '#define USE_ENVMAP' : '', parameters.envMap ? '#define ' + envMapModeDefine : '', parameters.lightMap ? '#define USE_LIGHTMAP' : '', parameters.aoMap ? '#define USE_AOMAP' : '', parameters.emissiveMap ? '#define USE_EMISSIVEMAP' : '', parameters.bumpMap ? '#define USE_BUMPMAP' : '', parameters.normalMap ? '#define USE_NORMALMAP' : '', parameters.normalMap && parameters.objectSpaceNormalMap ? '#define OBJECTSPACE_NORMALMAP' : '', parameters.normalMap && parameters.tangentSpaceNormalMap ? '#define TANGENTSPACE_NORMALMAP' : '', parameters.clearcoatMap ? '#define USE_CLEARCOATMAP' : '', parameters.clearcoatRoughnessMap ? '#define USE_CLEARCOAT_ROUGHNESSMAP' : '', parameters.clearcoatNormalMap ? '#define USE_CLEARCOAT_NORMALMAP' : '', parameters.iridescenceMap ? '#define USE_IRIDESCENCEMAP' : '', parameters.iridescenceThicknessMap ? '#define USE_IRIDESCENCE_THICKNESSMAP' : '', parameters.displacementMap && parameters.supportsVertexTextures ? '#define USE_DISPLACEMENTMAP' : '', parameters.specularMap ? '#define USE_SPECULARMAP' : '', parameters.specularIntensityMap ? '#define USE_SPECULARINTENSITYMAP' : '', parameters.specularColorMap ? '#define USE_SPECULARCOLORMAP' : '', parameters.roughnessMap ? '#define USE_ROUGHNESSMAP' : '', parameters.metalnessMap ? '#define USE_METALNESSMAP' : '', parameters.alphaMap ? '#define USE_ALPHAMAP' : '', parameters.transmission ? '#define USE_TRANSMISSION' : '', parameters.transmissionMap ? '#define USE_TRANSMISSIONMAP' : '', parameters.thicknessMap ? '#define USE_THICKNESSMAP' : '', parameters.sheenColorMap ? '#define USE_SHEENCOLORMAP' : '', parameters.sheenRoughnessMap ? '#define USE_SHEENROUGHNESSMAP' : '', parameters.vertexTangents ? '#define USE_TANGENT' : '', parameters.vertexColors ? '#define USE_COLOR' : '', parameters.vertexAlphas ? '#define USE_COLOR_ALPHA' : '', parameters.vertexUvs ? '#define USE_UV' : '', parameters.uvsVertexOnly ? '#define UVS_VERTEX_ONLY' : '', parameters.flatShading ? '#define FLAT_SHADED' : '', parameters.skinning ? '#define USE_SKINNING' : '', parameters.morphTargets ? '#define USE_MORPHTARGETS' : '', parameters.morphNormals && parameters.flatShading === false ? '#define USE_MORPHNORMALS' : '', parameters.morphColors && parameters.isWebGL2 ? '#define USE_MORPHCOLORS' : '', parameters.morphTargetsCount > 0 && parameters.isWebGL2 ? '#define MORPHTARGETS_TEXTURE' : '', parameters.morphTargetsCount > 0 && parameters.isWebGL2 ? '#define MORPHTARGETS_TEXTURE_STRIDE ' + parameters.morphTextureStride : '', parameters.morphTargetsCount > 0 && parameters.isWebGL2 ? '#define MORPHTARGETS_COUNT ' + parameters.morphTargetsCount : '', parameters.doubleSided ? '#define DOUBLE_SIDED' : '', parameters.flipSided ? '#define FLIP_SIDED' : '', parameters.shadowMapEnabled ? '#define USE_SHADOWMAP' : '', parameters.shadowMapEnabled ? '#define ' + shadowMapTypeDefine : '', parameters.sizeAttenuation ? '#define USE_SIZEATTENUATION' : '', parameters.logarithmicDepthBuffer ? '#define USE_LOGDEPTHBUF' : '', parameters.logarithmicDepthBuffer && parameters.rendererExtensionFragDepth ? '#define USE_LOGDEPTHBUF_EXT' : '', 'uniform mat4 modelMatrix;', 'uniform mat4 modelViewMatrix;', 'uniform mat4 projectionMatrix;', 'uniform mat4 viewMatrix;', 'uniform mat3 normalMatrix;', 'uniform vec3 cameraPosition;', 'uniform bool isOrthographic;', '#ifdef USE_INSTANCING', '\tattribute mat4 instanceMatrix;', '#endif', '#ifdef USE_INSTANCING_COLOR', '\tattribute vec3 instanceColor;', '#endif', 'attribute vec3 position;', 'attribute vec3 normal;', 'attribute vec2 uv;', '#ifdef USE_TANGENT', '\tattribute vec4 tangent;', '#endif', '#if defined( USE_COLOR_ALPHA )', '\tattribute vec4 color;', '#elif defined( USE_COLOR )', '\tattribute vec3 color;', '#endif', '#if ( defined( USE_MORPHTARGETS ) && ! defined( MORPHTARGETS_TEXTURE ) )', '\tattribute vec3 morphTarget0;', '\tattribute vec3 morphTarget1;', '\tattribute vec3 morphTarget2;', '\tattribute vec3 morphTarget3;', '\t#ifdef USE_MORPHNORMALS', '\t\tattribute vec3 morphNormal0;', '\t\tattribute vec3 morphNormal1;', '\t\tattribute vec3 morphNormal2;', '\t\tattribute vec3 morphNormal3;', '\t#else', '\t\tattribute vec3 morphTarget4;', '\t\tattribute vec3 morphTarget5;', '\t\tattribute vec3 morphTarget6;', '\t\tattribute vec3 morphTarget7;', '\t#endif', '#endif', '#ifdef USE_SKINNING', '\tattribute vec4 skinIndex;', '\tattribute vec4 skinWeight;', '#endif', '\\n'].filter(filterEmptyLine).join('\\n');\n\t\tprefixFragment = [customExtensions, generatePrecision(parameters), '#define SHADER_NAME ' + parameters.shaderName, customDefines, parameters.useFog && parameters.fog ? '#define USE_FOG' : '', parameters.useFog && parameters.fogExp2 ? '#define FOG_EXP2' : '', parameters.map ? '#define USE_MAP' : '', parameters.matcap ? '#define USE_MATCAP' : '', parameters.envMap ? '#define USE_ENVMAP' : '', parameters.envMap ? '#define ' + envMapTypeDefine : '', parameters.envMap ? '#define ' + envMapModeDefine : '', parameters.envMap ? '#define ' + envMapBlendingDefine : '', envMapCubeUVSize ? '#define CUBEUV_TEXEL_WIDTH ' + envMapCubeUVSize.texelWidth : '', envMapCubeUVSize ? '#define CUBEUV_TEXEL_HEIGHT ' + envMapCubeUVSize.texelHeight : '', envMapCubeUVSize ? '#define CUBEUV_MAX_MIP ' + envMapCubeUVSize.maxMip + '.0' : '', parameters.lightMap ? '#define USE_LIGHTMAP' : '', parameters.aoMap ? '#define USE_AOMAP' : '', parameters.emissiveMap ? '#define USE_EMISSIVEMAP' : '', parameters.bumpMap ? '#define USE_BUMPMAP' : '', parameters.normalMap ? '#define USE_NORMALMAP' : '', parameters.normalMap && parameters.objectSpaceNormalMap ? '#define OBJECTSPACE_NORMALMAP' : '', parameters.normalMap && parameters.tangentSpaceNormalMap ? '#define TANGENTSPACE_NORMALMAP' : '', parameters.clearcoat ? '#define USE_CLEARCOAT' : '', parameters.clearcoatMap ? '#define USE_CLEARCOATMAP' : '', parameters.clearcoatRoughnessMap ? '#define USE_CLEARCOAT_ROUGHNESSMAP' : '', parameters.clearcoatNormalMap ? '#define USE_CLEARCOAT_NORMALMAP' : '', parameters.iridescence ? '#define USE_IRIDESCENCE' : '', parameters.iridescenceMap ? '#define USE_IRIDESCENCEMAP' : '', parameters.iridescenceThicknessMap ? '#define USE_IRIDESCENCE_THICKNESSMAP' : '', parameters.specularMap ? '#define USE_SPECULARMAP' : '', parameters.specularIntensityMap ? '#define USE_SPECULARINTENSITYMAP' : '', parameters.specularColorMap ? '#define USE_SPECULARCOLORMAP' : '', parameters.roughnessMap ? '#define USE_ROUGHNESSMAP' : '', parameters.metalnessMap ? '#define USE_METALNESSMAP' : '', parameters.alphaMap ? '#define USE_ALPHAMAP' : '', parameters.alphaTest ? '#define USE_ALPHATEST' : '', parameters.sheen ? '#define USE_SHEEN' : '', parameters.sheenColorMap ? '#define USE_SHEENCOLORMAP' : '', parameters.sheenRoughnessMap ? '#define USE_SHEENROUGHNESSMAP' : '', parameters.transmission ? '#define USE_TRANSMISSION' : '', parameters.transmissionMap ? '#define USE_TRANSMISSIONMAP' : '', parameters.thicknessMap ? '#define USE_THICKNESSMAP' : '', parameters.decodeVideoTexture ? '#define DECODE_VIDEO_TEXTURE' : '', parameters.vertexTangents ? '#define USE_TANGENT' : '', parameters.vertexColors || parameters.instancingColor ? '#define USE_COLOR' : '', parameters.vertexAlphas ? '#define USE_COLOR_ALPHA' : '', parameters.vertexUvs ? '#define USE_UV' : '', parameters.uvsVertexOnly ? '#define UVS_VERTEX_ONLY' : '', parameters.gradientMap ? '#define USE_GRADIENTMAP' : '', parameters.flatShading ? '#define FLAT_SHADED' : '', parameters.doubleSided ? '#define DOUBLE_SIDED' : '', parameters.flipSided ? '#define FLIP_SIDED' : '', parameters.shadowMapEnabled ? '#define USE_SHADOWMAP' : '', parameters.shadowMapEnabled ? '#define ' + shadowMapTypeDefine : '', parameters.premultipliedAlpha ? '#define PREMULTIPLIED_ALPHA' : '', parameters.physicallyCorrectLights ? '#define PHYSICALLY_CORRECT_LIGHTS' : '', parameters.logarithmicDepthBuffer ? '#define USE_LOGDEPTHBUF' : '', parameters.logarithmicDepthBuffer && parameters.rendererExtensionFragDepth ? '#define USE_LOGDEPTHBUF_EXT' : '', 'uniform mat4 viewMatrix;', 'uniform vec3 cameraPosition;', 'uniform bool isOrthographic;', parameters.toneMapping !== NoToneMapping ? '#define TONE_MAPPING' : '', parameters.toneMapping !== NoToneMapping ? ShaderChunk['tonemapping_pars_fragment'] : '', // this code is required here because it is used by the toneMapping() function defined below\n\t\tparameters.toneMapping !== NoToneMapping ? getToneMappingFunction('toneMapping', parameters.toneMapping) : '', parameters.dithering ? '#define DITHERING' : '', parameters.opaque ? '#define OPAQUE' : '', ShaderChunk['encodings_pars_fragment'], // this code is required here because it is used by the various encoding/decoding function defined below\n\t\tgetTexelEncodingFunction('linearToOutputTexel', parameters.outputEncoding), parameters.useDepthPacking ? '#define DEPTH_PACKING ' + parameters.depthPacking : '', '\\n'].filter(filterEmptyLine).join('\\n');\n\t}\n\n\tvertexShader = resolveIncludes(vertexShader);\n\tvertexShader = replaceLightNums(vertexShader, parameters);\n\tvertexShader = replaceClippingPlaneNums(vertexShader, parameters);\n\tfragmentShader = resolveIncludes(fragmentShader);\n\tfragmentShader = replaceLightNums(fragmentShader, parameters);\n\tfragmentShader = replaceClippingPlaneNums(fragmentShader, parameters);\n\tvertexShader = unrollLoops(vertexShader);\n\tfragmentShader = unrollLoops(fragmentShader);\n\n\tif (parameters.isWebGL2 && parameters.isRawShaderMaterial !== true) {\n\t\t// GLSL 3.0 conversion for built-in materials and ShaderMaterial\n\t\tversionString = '#version 300 es\\n';\n\t\tprefixVertex = ['precision mediump sampler2DArray;', '#define attribute in', '#define varying out', '#define texture2D texture'].join('\\n') + '\\n' + prefixVertex;\n\t\tprefixFragment = ['#define varying in', parameters.glslVersion === GLSL3 ? '' : 'layout(location = 0) out highp vec4 pc_fragColor;', parameters.glslVersion === GLSL3 ? '' : '#define gl_FragColor pc_fragColor', '#define gl_FragDepthEXT gl_FragDepth', '#define texture2D texture', '#define textureCube texture', '#define texture2DProj textureProj', '#define texture2DLodEXT textureLod', '#define texture2DProjLodEXT textureProjLod', '#define textureCubeLodEXT textureLod', '#define texture2DGradEXT textureGrad', '#define texture2DProjGradEXT textureProjGrad', '#define textureCubeGradEXT textureGrad'].join('\\n') + '\\n' + prefixFragment;\n\t}\n\n\tconst vertexGlsl = versionString + prefixVertex + vertexShader;\n\tconst fragmentGlsl = versionString + prefixFragment + fragmentShader; // console.log( '*VERTEX*', vertexGlsl );\n\t// console.log( '*FRAGMENT*', fragmentGlsl );\n\n\tconst glVertexShader = WebGLShader(gl, gl.VERTEX_SHADER, vertexGlsl);\n\tconst glFragmentShader = WebGLShader(gl, gl.FRAGMENT_SHADER, fragmentGlsl);\n\tgl.attachShader(program, glVertexShader);\n\tgl.attachShader(program, glFragmentShader); // Force a particular attribute to index 0.\n\n\tif (parameters.index0AttributeName !== undefined) {\n\t\tgl.bindAttribLocation(program, 0, parameters.index0AttributeName);\n\t} else if (parameters.morphTargets === true) {\n\t\t// programs with morphTargets displace position out of attribute 0\n\t\tgl.bindAttribLocation(program, 0, 'position');\n\t}\n\n\tgl.linkProgram(program); // check for link errors\n\n\tif (renderer.debug.checkShaderErrors) {\n\t\tconst programLog = gl.getProgramInfoLog(program).trim();\n\t\tconst vertexLog = gl.getShaderInfoLog(glVertexShader).trim();\n\t\tconst fragmentLog = gl.getShaderInfoLog(glFragmentShader).trim();\n\t\tlet runnable = true;\n\t\tlet haveDiagnostics = true;\n\n\t\tif (gl.getProgramParameter(program, gl.LINK_STATUS) === false) {\n\t\t\trunnable = false;\n\t\t\tconst vertexErrors = getShaderErrors(gl, glVertexShader, 'vertex');\n\t\t\tconst fragmentErrors = getShaderErrors(gl, glFragmentShader, 'fragment');\n\t\t\tconsole.error('THREE.WebGLProgram: Shader Error ' + gl.getError() + ' - ' + 'VALIDATE_STATUS ' + gl.getProgramParameter(program, gl.VALIDATE_STATUS) + '\\n\\n' + 'Program Info Log: ' + programLog + '\\n' + vertexErrors + '\\n' + fragmentErrors);\n\t\t} else if (programLog !== '') {\n\t\t\tconsole.warn('THREE.WebGLProgram: Program Info Log:', programLog);\n\t\t} else if (vertexLog === '' || fragmentLog === '') {\n\t\t\thaveDiagnostics = false;\n\t\t}\n\n\t\tif (haveDiagnostics) {\n\t\t\tthis.diagnostics = {\n\t\t\t\trunnable: runnable,\n\t\t\t\tprogramLog: programLog,\n\t\t\t\tvertexShader: {\n\t\t\t\t\tlog: vertexLog,\n\t\t\t\t\tprefix: prefixVertex\n\t\t\t\t},\n\t\t\t\tfragmentShader: {\n\t\t\t\t\tlog: fragmentLog,\n\t\t\t\t\tprefix: prefixFragment\n\t\t\t\t}\n\t\t\t};\n\t\t}\n\t} // Clean up\n\t// Crashes in iOS9 and iOS10. #18402\n\t// gl.detachShader( program, glVertexShader );\n\t// gl.detachShader( program, glFragmentShader );\n\n\n\tgl.deleteShader(glVertexShader);\n\tgl.deleteShader(glFragmentShader); // set up caching for uniform locations\n\n\tlet cachedUniforms;\n\n\tthis.getUniforms = function () {\n\t\tif (cachedUniforms === undefined) {\n\t\t\tcachedUniforms = new WebGLUniforms(gl, program);\n\t\t}\n\n\t\treturn cachedUniforms;\n\t}; // set up caching for attribute locations\n\n\n\tlet cachedAttributes;\n\n\tthis.getAttributes = function () {\n\t\tif (cachedAttributes === undefined) {\n\t\t\tcachedAttributes = fetchAttributeLocations(gl, program);\n\t\t}\n\n\t\treturn cachedAttributes;\n\t}; // free resource\n\n\n\tthis.destroy = function () {\n\t\tbindingStates.releaseStatesOfProgram(this);\n\t\tgl.deleteProgram(program);\n\t\tthis.program = undefined;\n\t}; //\n\n\n\tthis.name = parameters.shaderName;\n\tthis.id = programIdCount++;\n\tthis.cacheKey = cacheKey;\n\tthis.usedTimes = 1;\n\tthis.program = program;\n\tthis.vertexShader = glVertexShader;\n\tthis.fragmentShader = glFragmentShader;\n\treturn this;\n}\n\nlet _id = 0;\n\nclass WebGLShaderCache {\n\tconstructor() {\n\t\tthis.shaderCache = new Map();\n\t\tthis.materialCache = new Map();\n\t}\n\n\tupdate(material) {\n\t\tconst vertexShader = material.vertexShader;\n\t\tconst fragmentShader = material.fragmentShader;\n\n\t\tconst vertexShaderStage = this._getShaderStage(vertexShader);\n\n\t\tconst fragmentShaderStage = this._getShaderStage(fragmentShader);\n\n\t\tconst materialShaders = this._getShaderCacheForMaterial(material);\n\n\t\tif (materialShaders.has(vertexShaderStage) === false) {\n\t\t\tmaterialShaders.add(vertexShaderStage);\n\t\t\tvertexShaderStage.usedTimes++;\n\t\t}\n\n\t\tif (materialShaders.has(fragmentShaderStage) === false) {\n\t\t\tmaterialShaders.add(fragmentShaderStage);\n\t\t\tfragmentShaderStage.usedTimes++;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tremove(material) {\n\t\tconst materialShaders = this.materialCache.get(material);\n\n\t\tfor (const shaderStage of materialShaders) {\n\t\t\tshaderStage.usedTimes--;\n\t\t\tif (shaderStage.usedTimes === 0) this.shaderCache.delete(shaderStage.code);\n\t\t}\n\n\t\tthis.materialCache.delete(material);\n\t\treturn this;\n\t}\n\n\tgetVertexShaderID(material) {\n\t\treturn this._getShaderStage(material.vertexShader).id;\n\t}\n\n\tgetFragmentShaderID(material) {\n\t\treturn this._getShaderStage(material.fragmentShader).id;\n\t}\n\n\tdispose() {\n\t\tthis.shaderCache.clear();\n\t\tthis.materialCache.clear();\n\t}\n\n\t_getShaderCacheForMaterial(material) {\n\t\tconst cache = this.materialCache;\n\n\t\tif (cache.has(material) === false) {\n\t\t\tcache.set(material, new Set());\n\t\t}\n\n\t\treturn cache.get(material);\n\t}\n\n\t_getShaderStage(code) {\n\t\tconst cache = this.shaderCache;\n\n\t\tif (cache.has(code) === false) {\n\t\t\tconst stage = new WebGLShaderStage(code);\n\t\t\tcache.set(code, stage);\n\t\t}\n\n\t\treturn cache.get(code);\n\t}\n\n}\n\nclass WebGLShaderStage {\n\tconstructor(code) {\n\t\tthis.id = _id++;\n\t\tthis.code = code;\n\t\tthis.usedTimes = 0;\n\t}\n\n}\n\nfunction WebGLPrograms(renderer, cubemaps, cubeuvmaps, extensions, capabilities, bindingStates, clipping) {\n\tconst _programLayers = new Layers();\n\n\tconst _customShaders = new WebGLShaderCache();\n\n\tconst programs = [];\n\tconst isWebGL2 = capabilities.isWebGL2;\n\tconst logarithmicDepthBuffer = capabilities.logarithmicDepthBuffer;\n\tconst vertexTextures = capabilities.vertexTextures;\n\tlet precision = capabilities.precision;\n\tconst shaderIDs = {\n\t\tMeshDepthMaterial: 'depth',\n\t\tMeshDistanceMaterial: 'distanceRGBA',\n\t\tMeshNormalMaterial: 'normal',\n\t\tMeshBasicMaterial: 'basic',\n\t\tMeshLambertMaterial: 'lambert',\n\t\tMeshPhongMaterial: 'phong',\n\t\tMeshToonMaterial: 'toon',\n\t\tMeshStandardMaterial: 'physical',\n\t\tMeshPhysicalMaterial: 'physical',\n\t\tMeshMatcapMaterial: 'matcap',\n\t\tLineBasicMaterial: 'basic',\n\t\tLineDashedMaterial: 'dashed',\n\t\tPointsMaterial: 'points',\n\t\tShadowMaterial: 'shadow',\n\t\tSpriteMaterial: 'sprite'\n\t};\n\n\tfunction getParameters(material, lights, shadows, scene, object) {\n\t\tconst fog = scene.fog;\n\t\tconst geometry = object.geometry;\n\t\tconst environment = material.isMeshStandardMaterial ? scene.environment : null;\n\t\tconst envMap = (material.isMeshStandardMaterial ? cubeuvmaps : cubemaps).get(material.envMap || environment);\n\t\tconst envMapCubeUVHeight = !!envMap && envMap.mapping === CubeUVReflectionMapping ? envMap.image.height : null;\n\t\tconst shaderID = shaderIDs[material.type]; // heuristics to create shader parameters according to lights in the scene\n\t\t// (not to blow over maxLights budget)\n\n\t\tif (material.precision !== null) {\n\t\t\tprecision = capabilities.getMaxPrecision(material.precision);\n\n\t\t\tif (precision !== material.precision) {\n\t\t\t\tconsole.warn('THREE.WebGLProgram.getParameters:', material.precision, 'not supported, using', precision, 'instead.');\n\t\t\t}\n\t\t} //\n\n\n\t\tconst morphAttribute = geometry.morphAttributes.position || geometry.morphAttributes.normal || geometry.morphAttributes.color;\n\t\tconst morphTargetsCount = morphAttribute !== undefined ? morphAttribute.length : 0;\n\t\tlet morphTextureStride = 0;\n\t\tif (geometry.morphAttributes.position !== undefined) morphTextureStride = 1;\n\t\tif (geometry.morphAttributes.normal !== undefined) morphTextureStride = 2;\n\t\tif (geometry.morphAttributes.color !== undefined) morphTextureStride = 3; //\n\n\t\tlet vertexShader, fragmentShader;\n\t\tlet customVertexShaderID, customFragmentShaderID;\n\n\t\tif (shaderID) {\n\t\t\tconst shader = ShaderLib[shaderID];\n\t\t\tvertexShader = shader.vertexShader;\n\t\t\tfragmentShader = shader.fragmentShader;\n\t\t} else {\n\t\t\tvertexShader = material.vertexShader;\n\t\t\tfragmentShader = material.fragmentShader;\n\n\t\t\t_customShaders.update(material);\n\n\t\t\tcustomVertexShaderID = _customShaders.getVertexShaderID(material);\n\t\t\tcustomFragmentShaderID = _customShaders.getFragmentShaderID(material);\n\t\t}\n\n\t\tconst currentRenderTarget = renderer.getRenderTarget();\n\t\tconst useAlphaTest = material.alphaTest > 0;\n\t\tconst useClearcoat = material.clearcoat > 0;\n\t\tconst useIridescence = material.iridescence > 0;\n\t\tconst parameters = {\n\t\t\tisWebGL2: isWebGL2,\n\t\t\tshaderID: shaderID,\n\t\t\tshaderName: material.type,\n\t\t\tvertexShader: vertexShader,\n\t\t\tfragmentShader: fragmentShader,\n\t\t\tdefines: material.defines,\n\t\t\tcustomVertexShaderID: customVertexShaderID,\n\t\t\tcustomFragmentShaderID: customFragmentShaderID,\n\t\t\tisRawShaderMaterial: material.isRawShaderMaterial === true,\n\t\t\tglslVersion: material.glslVersion,\n\t\t\tprecision: precision,\n\t\t\tinstancing: object.isInstancedMesh === true,\n\t\t\tinstancingColor: object.isInstancedMesh === true && object.instanceColor !== null,\n\t\t\tsupportsVertexTextures: vertexTextures,\n\t\t\toutputEncoding: currentRenderTarget === null ? renderer.outputEncoding : currentRenderTarget.isXRRenderTarget === true ? currentRenderTarget.texture.encoding : LinearEncoding,\n\t\t\tmap: !!material.map,\n\t\t\tmatcap: !!material.matcap,\n\t\t\tenvMap: !!envMap,\n\t\t\tenvMapMode: envMap && envMap.mapping,\n\t\t\tenvMapCubeUVHeight: envMapCubeUVHeight,\n\t\t\tlightMap: !!material.lightMap,\n\t\t\taoMap: !!material.aoMap,\n\t\t\temissiveMap: !!material.emissiveMap,\n\t\t\tbumpMap: !!material.bumpMap,\n\t\t\tnormalMap: !!material.normalMap,\n\t\t\tobjectSpaceNormalMap: material.normalMapType === ObjectSpaceNormalMap,\n\t\t\ttangentSpaceNormalMap: material.normalMapType === TangentSpaceNormalMap,\n\t\t\tdecodeVideoTexture: !!material.map && material.map.isVideoTexture === true && material.map.encoding === sRGBEncoding,\n\t\t\tclearcoat: useClearcoat,\n\t\t\tclearcoatMap: useClearcoat && !!material.clearcoatMap,\n\t\t\tclearcoatRoughnessMap: useClearcoat && !!material.clearcoatRoughnessMap,\n\t\t\tclearcoatNormalMap: useClearcoat && !!material.clearcoatNormalMap,\n\t\t\tiridescence: useIridescence,\n\t\t\tiridescenceMap: useIridescence && !!material.iridescenceMap,\n\t\t\tiridescenceThicknessMap: useIridescence && !!material.iridescenceThicknessMap,\n\t\t\tdisplacementMap: !!material.displacementMap,\n\t\t\troughnessMap: !!material.roughnessMap,\n\t\t\tmetalnessMap: !!material.metalnessMap,\n\t\t\tspecularMap: !!material.specularMap,\n\t\t\tspecularIntensityMap: !!material.specularIntensityMap,\n\t\t\tspecularColorMap: !!material.specularColorMap,\n\t\t\topaque: material.transparent === false && material.blending === NormalBlending,\n\t\t\talphaMap: !!material.alphaMap,\n\t\t\talphaTest: useAlphaTest,\n\t\t\tgradientMap: !!material.gradientMap,\n\t\t\tsheen: material.sheen > 0,\n\t\t\tsheenColorMap: !!material.sheenColorMap,\n\t\t\tsheenRoughnessMap: !!material.sheenRoughnessMap,\n\t\t\ttransmission: material.transmission > 0,\n\t\t\ttransmissionMap: !!material.transmissionMap,\n\t\t\tthicknessMap: !!material.thicknessMap,\n\t\t\tcombine: material.combine,\n\t\t\tvertexTangents: !!material.normalMap && !!geometry.attributes.tangent,\n\t\t\tvertexColors: material.vertexColors,\n\t\t\tvertexAlphas: material.vertexColors === true && !!geometry.attributes.color && geometry.attributes.color.itemSize === 4,\n\t\t\tvertexUvs: !!material.map || !!material.bumpMap || !!material.normalMap || !!material.specularMap || !!material.alphaMap || !!material.emissiveMap || !!material.roughnessMap || !!material.metalnessMap || !!material.clearcoatMap || !!material.clearcoatRoughnessMap || !!material.clearcoatNormalMap || !!material.iridescenceMap || !!material.iridescenceThicknessMap || !!material.displacementMap || !!material.transmissionMap || !!material.thicknessMap || !!material.specularIntensityMap || !!material.specularColorMap || !!material.sheenColorMap || !!material.sheenRoughnessMap,\n\t\t\tuvsVertexOnly: !(!!material.map || !!material.bumpMap || !!material.normalMap || !!material.specularMap || !!material.alphaMap || !!material.emissiveMap || !!material.roughnessMap || !!material.metalnessMap || !!material.clearcoatNormalMap || !!material.iridescenceMap || !!material.iridescenceThicknessMap || material.transmission > 0 || !!material.transmissionMap || !!material.thicknessMap || !!material.specularIntensityMap || !!material.specularColorMap || material.sheen > 0 || !!material.sheenColorMap || !!material.sheenRoughnessMap) && !!material.displacementMap,\n\t\t\tfog: !!fog,\n\t\t\tuseFog: material.fog === true,\n\t\t\tfogExp2: fog && fog.isFogExp2,\n\t\t\tflatShading: !!material.flatShading,\n\t\t\tsizeAttenuation: material.sizeAttenuation,\n\t\t\tlogarithmicDepthBuffer: logarithmicDepthBuffer,\n\t\t\tskinning: object.isSkinnedMesh === true,\n\t\t\tmorphTargets: geometry.morphAttributes.position !== undefined,\n\t\t\tmorphNormals: geometry.morphAttributes.normal !== undefined,\n\t\t\tmorphColors: geometry.morphAttributes.color !== undefined,\n\t\t\tmorphTargetsCount: morphTargetsCount,\n\t\t\tmorphTextureStride: morphTextureStride,\n\t\t\tnumDirLights: lights.directional.length,\n\t\t\tnumPointLights: lights.point.length,\n\t\t\tnumSpotLights: lights.spot.length,\n\t\t\tnumRectAreaLights: lights.rectArea.length,\n\t\t\tnumHemiLights: lights.hemi.length,\n\t\t\tnumDirLightShadows: lights.directionalShadowMap.length,\n\t\t\tnumPointLightShadows: lights.pointShadowMap.length,\n\t\t\tnumSpotLightShadows: lights.spotShadowMap.length,\n\t\t\tnumClippingPlanes: clipping.numPlanes,\n\t\t\tnumClipIntersection: clipping.numIntersection,\n\t\t\tdithering: material.dithering,\n\t\t\tshadowMapEnabled: renderer.shadowMap.enabled && shadows.length > 0,\n\t\t\tshadowMapType: renderer.shadowMap.type,\n\t\t\ttoneMapping: material.toneMapped ? renderer.toneMapping : NoToneMapping,\n\t\t\tphysicallyCorrectLights: renderer.physicallyCorrectLights,\n\t\t\tpremultipliedAlpha: material.premultipliedAlpha,\n\t\t\tdoubleSided: material.side === DoubleSide,\n\t\t\tflipSided: material.side === BackSide,\n\t\t\tuseDepthPacking: !!material.depthPacking,\n\t\t\tdepthPacking: material.depthPacking || 0,\n\t\t\tindex0AttributeName: material.index0AttributeName,\n\t\t\textensionDerivatives: material.extensions && material.extensions.derivatives,\n\t\t\textensionFragDepth: material.extensions && material.extensions.fragDepth,\n\t\t\textensionDrawBuffers: material.extensions && material.extensions.drawBuffers,\n\t\t\textensionShaderTextureLOD: material.extensions && material.extensions.shaderTextureLOD,\n\t\t\trendererExtensionFragDepth: isWebGL2 || extensions.has('EXT_frag_depth'),\n\t\t\trendererExtensionDrawBuffers: isWebGL2 || extensions.has('WEBGL_draw_buffers'),\n\t\t\trendererExtensionShaderTextureLod: isWebGL2 || extensions.has('EXT_shader_texture_lod'),\n\t\t\tcustomProgramCacheKey: material.customProgramCacheKey()\n\t\t};\n\t\treturn parameters;\n\t}\n\n\tfunction getProgramCacheKey(parameters) {\n\t\tconst array = [];\n\n\t\tif (parameters.shaderID) {\n\t\t\tarray.push(parameters.shaderID);\n\t\t} else {\n\t\t\tarray.push(parameters.customVertexShaderID);\n\t\t\tarray.push(parameters.customFragmentShaderID);\n\t\t}\n\n\t\tif (parameters.defines !== undefined) {\n\t\t\tfor (const name in parameters.defines) {\n\t\t\t\tarray.push(name);\n\t\t\t\tarray.push(parameters.defines[name]);\n\t\t\t}\n\t\t}\n\n\t\tif (parameters.isRawShaderMaterial === false) {\n\t\t\tgetProgramCacheKeyParameters(array, parameters);\n\t\t\tgetProgramCacheKeyBooleans(array, parameters);\n\t\t\tarray.push(renderer.outputEncoding);\n\t\t}\n\n\t\tarray.push(parameters.customProgramCacheKey);\n\t\treturn array.join();\n\t}\n\n\tfunction getProgramCacheKeyParameters(array, parameters) {\n\t\tarray.push(parameters.precision);\n\t\tarray.push(parameters.outputEncoding);\n\t\tarray.push(parameters.envMapMode);\n\t\tarray.push(parameters.envMapCubeUVHeight);\n\t\tarray.push(parameters.combine);\n\t\tarray.push(parameters.vertexUvs);\n\t\tarray.push(parameters.fogExp2);\n\t\tarray.push(parameters.sizeAttenuation);\n\t\tarray.push(parameters.morphTargetsCount);\n\t\tarray.push(parameters.morphAttributeCount);\n\t\tarray.push(parameters.numDirLights);\n\t\tarray.push(parameters.numPointLights);\n\t\tarray.push(parameters.numSpotLights);\n\t\tarray.push(parameters.numHemiLights);\n\t\tarray.push(parameters.numRectAreaLights);\n\t\tarray.push(parameters.numDirLightShadows);\n\t\tarray.push(parameters.numPointLightShadows);\n\t\tarray.push(parameters.numSpotLightShadows);\n\t\tarray.push(parameters.shadowMapType);\n\t\tarray.push(parameters.toneMapping);\n\t\tarray.push(parameters.numClippingPlanes);\n\t\tarray.push(parameters.numClipIntersection);\n\t\tarray.push(parameters.depthPacking);\n\t}\n\n\tfunction getProgramCacheKeyBooleans(array, parameters) {\n\t\t_programLayers.disableAll();\n\n\t\tif (parameters.isWebGL2) _programLayers.enable(0);\n\t\tif (parameters.supportsVertexTextures) _programLayers.enable(1);\n\t\tif (parameters.instancing) _programLayers.enable(2);\n\t\tif (parameters.instancingColor) _programLayers.enable(3);\n\t\tif (parameters.map) _programLayers.enable(4);\n\t\tif (parameters.matcap) _programLayers.enable(5);\n\t\tif (parameters.envMap) _programLayers.enable(6);\n\t\tif (parameters.lightMap) _programLayers.enable(7);\n\t\tif (parameters.aoMap) _programLayers.enable(8);\n\t\tif (parameters.emissiveMap) _programLayers.enable(9);\n\t\tif (parameters.bumpMap) _programLayers.enable(10);\n\t\tif (parameters.normalMap) _programLayers.enable(11);\n\t\tif (parameters.objectSpaceNormalMap) _programLayers.enable(12);\n\t\tif (parameters.tangentSpaceNormalMap) _programLayers.enable(13);\n\t\tif (parameters.clearcoat) _programLayers.enable(14);\n\t\tif (parameters.clearcoatMap) _programLayers.enable(15);\n\t\tif (parameters.clearcoatRoughnessMap) _programLayers.enable(16);\n\t\tif (parameters.clearcoatNormalMap) _programLayers.enable(17);\n\t\tif (parameters.iridescence) _programLayers.enable(18);\n\t\tif (parameters.iridescenceMap) _programLayers.enable(19);\n\t\tif (parameters.iridescenceThicknessMap) _programLayers.enable(20);\n\t\tif (parameters.displacementMap) _programLayers.enable(21);\n\t\tif (parameters.specularMap) _programLayers.enable(22);\n\t\tif (parameters.roughnessMap) _programLayers.enable(23);\n\t\tif (parameters.metalnessMap) _programLayers.enable(24);\n\t\tif (parameters.gradientMap) _programLayers.enable(25);\n\t\tif (parameters.alphaMap) _programLayers.enable(26);\n\t\tif (parameters.alphaTest) _programLayers.enable(27);\n\t\tif (parameters.vertexColors) _programLayers.enable(28);\n\t\tif (parameters.vertexAlphas) _programLayers.enable(29);\n\t\tif (parameters.vertexUvs) _programLayers.enable(30);\n\t\tif (parameters.vertexTangents) _programLayers.enable(31);\n\t\tif (parameters.uvsVertexOnly) _programLayers.enable(32);\n\t\tif (parameters.fog) _programLayers.enable(33);\n\t\tarray.push(_programLayers.mask);\n\n\t\t_programLayers.disableAll();\n\n\t\tif (parameters.useFog) _programLayers.enable(0);\n\t\tif (parameters.flatShading) _programLayers.enable(1);\n\t\tif (parameters.logarithmicDepthBuffer) _programLayers.enable(2);\n\t\tif (parameters.skinning) _programLayers.enable(3);\n\t\tif (parameters.morphTargets) _programLayers.enable(4);\n\t\tif (parameters.morphNormals) _programLayers.enable(5);\n\t\tif (parameters.morphColors) _programLayers.enable(6);\n\t\tif (parameters.premultipliedAlpha) _programLayers.enable(7);\n\t\tif (parameters.shadowMapEnabled) _programLayers.enable(8);\n\t\tif (parameters.physicallyCorrectLights) _programLayers.enable(9);\n\t\tif (parameters.doubleSided) _programLayers.enable(10);\n\t\tif (parameters.flipSided) _programLayers.enable(11);\n\t\tif (parameters.useDepthPacking) _programLayers.enable(12);\n\t\tif (parameters.dithering) _programLayers.enable(13);\n\t\tif (parameters.specularIntensityMap) _programLayers.enable(14);\n\t\tif (parameters.specularColorMap) _programLayers.enable(15);\n\t\tif (parameters.transmission) _programLayers.enable(16);\n\t\tif (parameters.transmissionMap) _programLayers.enable(17);\n\t\tif (parameters.thicknessMap) _programLayers.enable(18);\n\t\tif (parameters.sheen) _programLayers.enable(19);\n\t\tif (parameters.sheenColorMap) _programLayers.enable(20);\n\t\tif (parameters.sheenRoughnessMap) _programLayers.enable(21);\n\t\tif (parameters.decodeVideoTexture) _programLayers.enable(22);\n\t\tif (parameters.opaque) _programLayers.enable(23);\n\t\tarray.push(_programLayers.mask);\n\t}\n\n\tfunction getUniforms(material) {\n\t\tconst shaderID = shaderIDs[material.type];\n\t\tlet uniforms;\n\n\t\tif (shaderID) {\n\t\t\tconst shader = ShaderLib[shaderID];\n\t\t\tuniforms = UniformsUtils.clone(shader.uniforms);\n\t\t} else {\n\t\t\tuniforms = material.uniforms;\n\t\t}\n\n\t\treturn uniforms;\n\t}\n\n\tfunction acquireProgram(parameters, cacheKey) {\n\t\tlet program; // Check if code has been already compiled\n\n\t\tfor (let p = 0, pl = programs.length; p < pl; p++) {\n\t\t\tconst preexistingProgram = programs[p];\n\n\t\t\tif (preexistingProgram.cacheKey === cacheKey) {\n\t\t\t\tprogram = preexistingProgram;\n\t\t\t\t++program.usedTimes;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tif (program === undefined) {\n\t\t\tprogram = new WebGLProgram(renderer, cacheKey, parameters, bindingStates);\n\t\t\tprograms.push(program);\n\t\t}\n\n\t\treturn program;\n\t}\n\n\tfunction releaseProgram(program) {\n\t\tif (--program.usedTimes === 0) {\n\t\t\t// Remove from unordered set\n\t\t\tconst i = programs.indexOf(program);\n\t\t\tprograms[i] = programs[programs.length - 1];\n\t\t\tprograms.pop(); // Free WebGL resources\n\n\t\t\tprogram.destroy();\n\t\t}\n\t}\n\n\tfunction releaseShaderCache(material) {\n\t\t_customShaders.remove(material);\n\t}\n\n\tfunction dispose() {\n\t\t_customShaders.dispose();\n\t}\n\n\treturn {\n\t\tgetParameters: getParameters,\n\t\tgetProgramCacheKey: getProgramCacheKey,\n\t\tgetUniforms: getUniforms,\n\t\tacquireProgram: acquireProgram,\n\t\treleaseProgram: releaseProgram,\n\t\treleaseShaderCache: releaseShaderCache,\n\t\t// Exposed for resource monitoring & error feedback via renderer.info:\n\t\tprograms: programs,\n\t\tdispose: dispose\n\t};\n}\n\nfunction WebGLProperties() {\n\tlet properties = new WeakMap();\n\n\tfunction get(object) {\n\t\tlet map = properties.get(object);\n\n\t\tif (map === undefined) {\n\t\t\tmap = {};\n\t\t\tproperties.set(object, map);\n\t\t}\n\n\t\treturn map;\n\t}\n\n\tfunction remove(object) {\n\t\tproperties.delete(object);\n\t}\n\n\tfunction update(object, key, value) {\n\t\tproperties.get(object)[key] = value;\n\t}\n\n\tfunction dispose() {\n\t\tproperties = new WeakMap();\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tremove: remove,\n\t\tupdate: update,\n\t\tdispose: dispose\n\t};\n}\n\nfunction painterSortStable(a, b) {\n\tif (a.groupOrder !== b.groupOrder) {\n\t\treturn a.groupOrder - b.groupOrder;\n\t} else if (a.renderOrder !== b.renderOrder) {\n\t\treturn a.renderOrder - b.renderOrder;\n\t} else if (a.material.id !== b.material.id) {\n\t\treturn a.material.id - b.material.id;\n\t} else if (a.z !== b.z) {\n\t\treturn a.z - b.z;\n\t} else {\n\t\treturn a.id - b.id;\n\t}\n}\n\nfunction reversePainterSortStable(a, b) {\n\tif (a.groupOrder !== b.groupOrder) {\n\t\treturn a.groupOrder - b.groupOrder;\n\t} else if (a.renderOrder !== b.renderOrder) {\n\t\treturn a.renderOrder - b.renderOrder;\n\t} else if (a.z !== b.z) {\n\t\treturn b.z - a.z;\n\t} else {\n\t\treturn a.id - b.id;\n\t}\n}\n\nfunction WebGLRenderList() {\n\tconst renderItems = [];\n\tlet renderItemsIndex = 0;\n\tconst opaque = [];\n\tconst transmissive = [];\n\tconst transparent = [];\n\n\tfunction init() {\n\t\trenderItemsIndex = 0;\n\t\topaque.length = 0;\n\t\ttransmissive.length = 0;\n\t\ttransparent.length = 0;\n\t}\n\n\tfunction getNextRenderItem(object, geometry, material, groupOrder, z, group) {\n\t\tlet renderItem = renderItems[renderItemsIndex];\n\n\t\tif (renderItem === undefined) {\n\t\t\trenderItem = {\n\t\t\t\tid: object.id,\n\t\t\t\tobject: object,\n\t\t\t\tgeometry: geometry,\n\t\t\t\tmaterial: material,\n\t\t\t\tgroupOrder: groupOrder,\n\t\t\t\trenderOrder: object.renderOrder,\n\t\t\t\tz: z,\n\t\t\t\tgroup: group\n\t\t\t};\n\t\t\trenderItems[renderItemsIndex] = renderItem;\n\t\t} else {\n\t\t\trenderItem.id = object.id;\n\t\t\trenderItem.object = object;\n\t\t\trenderItem.geometry = geometry;\n\t\t\trenderItem.material = material;\n\t\t\trenderItem.groupOrder = groupOrder;\n\t\t\trenderItem.renderOrder = object.renderOrder;\n\t\t\trenderItem.z = z;\n\t\t\trenderItem.group = group;\n\t\t}\n\n\t\trenderItemsIndex++;\n\t\treturn renderItem;\n\t}\n\n\tfunction push(object, geometry, material, groupOrder, z, group) {\n\t\tconst renderItem = getNextRenderItem(object, geometry, material, groupOrder, z, group);\n\n\t\tif (material.transmission > 0.0) {\n\t\t\ttransmissive.push(renderItem);\n\t\t} else if (material.transparent === true) {\n\t\t\ttransparent.push(renderItem);\n\t\t} else {\n\t\t\topaque.push(renderItem);\n\t\t}\n\t}\n\n\tfunction unshift(object, geometry, material, groupOrder, z, group) {\n\t\tconst renderItem = getNextRenderItem(object, geometry, material, groupOrder, z, group);\n\n\t\tif (material.transmission > 0.0) {\n\t\t\ttransmissive.unshift(renderItem);\n\t\t} else if (material.transparent === true) {\n\t\t\ttransparent.unshift(renderItem);\n\t\t} else {\n\t\t\topaque.unshift(renderItem);\n\t\t}\n\t}\n\n\tfunction sort(customOpaqueSort, customTransparentSort) {\n\t\tif (opaque.length > 1) opaque.sort(customOpaqueSort || painterSortStable);\n\t\tif (transmissive.length > 1) transmissive.sort(customTransparentSort || reversePainterSortStable);\n\t\tif (transparent.length > 1) transparent.sort(customTransparentSort || reversePainterSortStable);\n\t}\n\n\tfunction finish() {\n\t\t// Clear references from inactive renderItems in the list\n\t\tfor (let i = renderItemsIndex, il = renderItems.length; i < il; i++) {\n\t\t\tconst renderItem = renderItems[i];\n\t\t\tif (renderItem.id === null) break;\n\t\t\trenderItem.id = null;\n\t\t\trenderItem.object = null;\n\t\t\trenderItem.geometry = null;\n\t\t\trenderItem.material = null;\n\t\t\trenderItem.group = null;\n\t\t}\n\t}\n\n\treturn {\n\t\topaque: opaque,\n\t\ttransmissive: transmissive,\n\t\ttransparent: transparent,\n\t\tinit: init,\n\t\tpush: push,\n\t\tunshift: unshift,\n\t\tfinish: finish,\n\t\tsort: sort\n\t};\n}\n\nfunction WebGLRenderLists() {\n\tlet lists = new WeakMap();\n\n\tfunction get(scene, renderCallDepth) {\n\t\tlet list;\n\n\t\tif (lists.has(scene) === false) {\n\t\t\tlist = new WebGLRenderList();\n\t\t\tlists.set(scene, [list]);\n\t\t} else {\n\t\t\tif (renderCallDepth >= lists.get(scene).length) {\n\t\t\t\tlist = new WebGLRenderList();\n\t\t\t\tlists.get(scene).push(list);\n\t\t\t} else {\n\t\t\t\tlist = lists.get(scene)[renderCallDepth];\n\t\t\t}\n\t\t}\n\n\t\treturn list;\n\t}\n\n\tfunction dispose() {\n\t\tlists = new WeakMap();\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tdispose: dispose\n\t};\n}\n\nfunction UniformsCache() {\n\tconst lights = {};\n\treturn {\n\t\tget: function (light) {\n\t\t\tif (lights[light.id] !== undefined) {\n\t\t\t\treturn lights[light.id];\n\t\t\t}\n\n\t\t\tlet uniforms;\n\n\t\t\tswitch (light.type) {\n\t\t\t\tcase 'DirectionalLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tdirection: new Vector3(),\n\t\t\t\t\t\tcolor: new Color()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'SpotLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tposition: new Vector3(),\n\t\t\t\t\t\tdirection: new Vector3(),\n\t\t\t\t\t\tcolor: new Color(),\n\t\t\t\t\t\tdistance: 0,\n\t\t\t\t\t\tconeCos: 0,\n\t\t\t\t\t\tpenumbraCos: 0,\n\t\t\t\t\t\tdecay: 0\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'PointLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tposition: new Vector3(),\n\t\t\t\t\t\tcolor: new Color(),\n\t\t\t\t\t\tdistance: 0,\n\t\t\t\t\t\tdecay: 0\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'HemisphereLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tdirection: new Vector3(),\n\t\t\t\t\t\tskyColor: new Color(),\n\t\t\t\t\t\tgroundColor: new Color()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'RectAreaLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tcolor: new Color(),\n\t\t\t\t\t\tposition: new Vector3(),\n\t\t\t\t\t\thalfWidth: new Vector3(),\n\t\t\t\t\t\thalfHeight: new Vector3()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tlights[light.id] = uniforms;\n\t\t\treturn uniforms;\n\t\t}\n\t};\n}\n\nfunction ShadowUniformsCache() {\n\tconst lights = {};\n\treturn {\n\t\tget: function (light) {\n\t\t\tif (lights[light.id] !== undefined) {\n\t\t\t\treturn lights[light.id];\n\t\t\t}\n\n\t\t\tlet uniforms;\n\n\t\t\tswitch (light.type) {\n\t\t\t\tcase 'DirectionalLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tshadowBias: 0,\n\t\t\t\t\t\tshadowNormalBias: 0,\n\t\t\t\t\t\tshadowRadius: 1,\n\t\t\t\t\t\tshadowMapSize: new Vector2()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'SpotLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tshadowBias: 0,\n\t\t\t\t\t\tshadowNormalBias: 0,\n\t\t\t\t\t\tshadowRadius: 1,\n\t\t\t\t\t\tshadowMapSize: new Vector2()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'PointLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tshadowBias: 0,\n\t\t\t\t\t\tshadowNormalBias: 0,\n\t\t\t\t\t\tshadowRadius: 1,\n\t\t\t\t\t\tshadowMapSize: new Vector2(),\n\t\t\t\t\t\tshadowCameraNear: 1,\n\t\t\t\t\t\tshadowCameraFar: 1000\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\t\t\t\t// TODO (abelnation): set RectAreaLight shadow uniforms\n\t\t\t}\n\n\t\t\tlights[light.id] = uniforms;\n\t\t\treturn uniforms;\n\t\t}\n\t};\n}\n\nlet nextVersion = 0;\n\nfunction shadowCastingLightsFirst(lightA, lightB) {\n\treturn (lightB.castShadow ? 1 : 0) - (lightA.castShadow ? 1 : 0);\n}\n\nfunction WebGLLights(extensions, capabilities) {\n\tconst cache = new UniformsCache();\n\tconst shadowCache = ShadowUniformsCache();\n\tconst state = {\n\t\tversion: 0,\n\t\thash: {\n\t\t\tdirectionalLength: -1,\n\t\t\tpointLength: -1,\n\t\t\tspotLength: -1,\n\t\t\trectAreaLength: -1,\n\t\t\themiLength: -1,\n\t\t\tnumDirectionalShadows: -1,\n\t\t\tnumPointShadows: -1,\n\t\t\tnumSpotShadows: -1\n\t\t},\n\t\tambient: [0, 0, 0],\n\t\tprobe: [],\n\t\tdirectional: [],\n\t\tdirectionalShadow: [],\n\t\tdirectionalShadowMap: [],\n\t\tdirectionalShadowMatrix: [],\n\t\tspot: [],\n\t\tspotShadow: [],\n\t\tspotShadowMap: [],\n\t\tspotShadowMatrix: [],\n\t\trectArea: [],\n\t\trectAreaLTC1: null,\n\t\trectAreaLTC2: null,\n\t\tpoint: [],\n\t\tpointShadow: [],\n\t\tpointShadowMap: [],\n\t\tpointShadowMatrix: [],\n\t\themi: []\n\t};\n\n\tfor (let i = 0; i < 9; i++) state.probe.push(new Vector3());\n\n\tconst vector3 = new Vector3();\n\tconst matrix4 = new Matrix4();\n\tconst matrix42 = new Matrix4();\n\n\tfunction setup(lights, physicallyCorrectLights) {\n\t\tlet r = 0,\n\t\t\t\tg = 0,\n\t\t\t\tb = 0;\n\n\t\tfor (let i = 0; i < 9; i++) state.probe[i].set(0, 0, 0);\n\n\t\tlet directionalLength = 0;\n\t\tlet pointLength = 0;\n\t\tlet spotLength = 0;\n\t\tlet rectAreaLength = 0;\n\t\tlet hemiLength = 0;\n\t\tlet numDirectionalShadows = 0;\n\t\tlet numPointShadows = 0;\n\t\tlet numSpotShadows = 0;\n\t\tlights.sort(shadowCastingLightsFirst); // artist-friendly light intensity scaling factor\n\n\t\tconst scaleFactor = physicallyCorrectLights !== true ? Math.PI : 1;\n\n\t\tfor (let i = 0, l = lights.length; i < l; i++) {\n\t\t\tconst light = lights[i];\n\t\t\tconst color = light.color;\n\t\t\tconst intensity = light.intensity;\n\t\t\tconst distance = light.distance;\n\t\t\tconst shadowMap = light.shadow && light.shadow.map ? light.shadow.map.texture : null;\n\n\t\t\tif (light.isAmbientLight) {\n\t\t\t\tr += color.r * intensity * scaleFactor;\n\t\t\t\tg += color.g * intensity * scaleFactor;\n\t\t\t\tb += color.b * intensity * scaleFactor;\n\t\t\t} else if (light.isLightProbe) {\n\t\t\t\tfor (let j = 0; j < 9; j++) {\n\t\t\t\t\tstate.probe[j].addScaledVector(light.sh.coefficients[j], intensity);\n\t\t\t\t}\n\t\t\t} else if (light.isDirectionalLight) {\n\t\t\t\tconst uniforms = cache.get(light);\n\t\t\t\tuniforms.color.copy(light.color).multiplyScalar(light.intensity * scaleFactor);\n\n\t\t\t\tif (light.castShadow) {\n\t\t\t\t\tconst shadow = light.shadow;\n\t\t\t\t\tconst shadowUniforms = shadowCache.get(light);\n\t\t\t\t\tshadowUniforms.shadowBias = shadow.bias;\n\t\t\t\t\tshadowUniforms.shadowNormalBias = shadow.normalBias;\n\t\t\t\t\tshadowUniforms.shadowRadius = shadow.radius;\n\t\t\t\t\tshadowUniforms.shadowMapSize = shadow.mapSize;\n\t\t\t\t\tstate.directionalShadow[directionalLength] = shadowUniforms;\n\t\t\t\t\tstate.directionalShadowMap[directionalLength] = shadowMap;\n\t\t\t\t\tstate.directionalShadowMatrix[directionalLength] = light.shadow.matrix;\n\t\t\t\t\tnumDirectionalShadows++;\n\t\t\t\t}\n\n\t\t\t\tstate.directional[directionalLength] = uniforms;\n\t\t\t\tdirectionalLength++;\n\t\t\t} else if (light.isSpotLight) {\n\t\t\t\tconst uniforms = cache.get(light);\n\t\t\t\tuniforms.position.setFromMatrixPosition(light.matrixWorld);\n\t\t\t\tuniforms.color.copy(color).multiplyScalar(intensity * scaleFactor);\n\t\t\t\tuniforms.distance = distance;\n\t\t\t\tuniforms.coneCos = Math.cos(light.angle);\n\t\t\t\tuniforms.penumbraCos = Math.cos(light.angle * (1 - light.penumbra));\n\t\t\t\tuniforms.decay = light.decay;\n\n\t\t\t\tif (light.castShadow) {\n\t\t\t\t\tconst shadow = light.shadow;\n\t\t\t\t\tconst shadowUniforms = shadowCache.get(light);\n\t\t\t\t\tshadowUniforms.shadowBias = shadow.bias;\n\t\t\t\t\tshadowUniforms.shadowNormalBias = shadow.normalBias;\n\t\t\t\t\tshadowUniforms.shadowRadius = shadow.radius;\n\t\t\t\t\tshadowUniforms.shadowMapSize = shadow.mapSize;\n\t\t\t\t\tstate.spotShadow[spotLength] = shadowUniforms;\n\t\t\t\t\tstate.spotShadowMap[spotLength] = shadowMap;\n\t\t\t\t\tstate.spotShadowMatrix[spotLength] = light.shadow.matrix;\n\t\t\t\t\tnumSpotShadows++;\n\t\t\t\t}\n\n\t\t\t\tstate.spot[spotLength] = uniforms;\n\t\t\t\tspotLength++;\n\t\t\t} else if (light.isRectAreaLight) {\n\t\t\t\tconst uniforms = cache.get(light); // (a) intensity is the total visible light emitted\n\t\t\t\t//uniforms.color.copy( color ).multiplyScalar( intensity / ( light.width * light.height * Math.PI ) );\n\t\t\t\t// (b) intensity is the brightness of the light\n\n\t\t\t\tuniforms.color.copy(color).multiplyScalar(intensity);\n\t\t\t\tuniforms.halfWidth.set(light.width * 0.5, 0.0, 0.0);\n\t\t\t\tuniforms.halfHeight.set(0.0, light.height * 0.5, 0.0);\n\t\t\t\tstate.rectArea[rectAreaLength] = uniforms;\n\t\t\t\trectAreaLength++;\n\t\t\t} else if (light.isPointLight) {\n\t\t\t\tconst uniforms = cache.get(light);\n\t\t\t\tuniforms.color.copy(light.color).multiplyScalar(light.intensity * scaleFactor);\n\t\t\t\tuniforms.distance = light.distance;\n\t\t\t\tuniforms.decay = light.decay;\n\n\t\t\t\tif (light.castShadow) {\n\t\t\t\t\tconst shadow = light.shadow;\n\t\t\t\t\tconst shadowUniforms = shadowCache.get(light);\n\t\t\t\t\tshadowUniforms.shadowBias = shadow.bias;\n\t\t\t\t\tshadowUniforms.shadowNormalBias = shadow.normalBias;\n\t\t\t\t\tshadowUniforms.shadowRadius = shadow.radius;\n\t\t\t\t\tshadowUniforms.shadowMapSize = shadow.mapSize;\n\t\t\t\t\tshadowUniforms.shadowCameraNear = shadow.camera.near;\n\t\t\t\t\tshadowUniforms.shadowCameraFar = shadow.camera.far;\n\t\t\t\t\tstate.pointShadow[pointLength] = shadowUniforms;\n\t\t\t\t\tstate.pointShadowMap[pointLength] = shadowMap;\n\t\t\t\t\tstate.pointShadowMatrix[pointLength] = light.shadow.matrix;\n\t\t\t\t\tnumPointShadows++;\n\t\t\t\t}\n\n\t\t\t\tstate.point[pointLength] = uniforms;\n\t\t\t\tpointLength++;\n\t\t\t} else if (light.isHemisphereLight) {\n\t\t\t\tconst uniforms = cache.get(light);\n\t\t\t\tuniforms.skyColor.copy(light.color).multiplyScalar(intensity * scaleFactor);\n\t\t\t\tuniforms.groundColor.copy(light.groundColor).multiplyScalar(intensity * scaleFactor);\n\t\t\t\tstate.hemi[hemiLength] = uniforms;\n\t\t\t\themiLength++;\n\t\t\t}\n\t\t}\n\n\t\tif (rectAreaLength > 0) {\n\t\t\tif (capabilities.isWebGL2) {\n\t\t\t\t// WebGL 2\n\t\t\t\tstate.rectAreaLTC1 = UniformsLib.LTC_FLOAT_1;\n\t\t\t\tstate.rectAreaLTC2 = UniformsLib.LTC_FLOAT_2;\n\t\t\t} else {\n\t\t\t\t// WebGL 1\n\t\t\t\tif (extensions.has('OES_texture_float_linear') === true) {\n\t\t\t\t\tstate.rectAreaLTC1 = UniformsLib.LTC_FLOAT_1;\n\t\t\t\t\tstate.rectAreaLTC2 = UniformsLib.LTC_FLOAT_2;\n\t\t\t\t} else if (extensions.has('OES_texture_half_float_linear') === true) {\n\t\t\t\t\tstate.rectAreaLTC1 = UniformsLib.LTC_HALF_1;\n\t\t\t\t\tstate.rectAreaLTC2 = UniformsLib.LTC_HALF_2;\n\t\t\t\t} else {\n\t\t\t\t\tconsole.error('THREE.WebGLRenderer: Unable to use RectAreaLight. Missing WebGL extensions.');\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tstate.ambient[0] = r;\n\t\tstate.ambient[1] = g;\n\t\tstate.ambient[2] = b;\n\t\tconst hash = state.hash;\n\n\t\tif (hash.directionalLength !== directionalLength || hash.pointLength !== pointLength || hash.spotLength !== spotLength || hash.rectAreaLength !== rectAreaLength || hash.hemiLength !== hemiLength || hash.numDirectionalShadows !== numDirectionalShadows || hash.numPointShadows !== numPointShadows || hash.numSpotShadows !== numSpotShadows) {\n\t\t\tstate.directional.length = directionalLength;\n\t\t\tstate.spot.length = spotLength;\n\t\t\tstate.rectArea.length = rectAreaLength;\n\t\t\tstate.point.length = pointLength;\n\t\t\tstate.hemi.length = hemiLength;\n\t\t\tstate.directionalShadow.length = numDirectionalShadows;\n\t\t\tstate.directionalShadowMap.length = numDirectionalShadows;\n\t\t\tstate.pointShadow.length = numPointShadows;\n\t\t\tstate.pointShadowMap.length = numPointShadows;\n\t\t\tstate.spotShadow.length = numSpotShadows;\n\t\t\tstate.spotShadowMap.length = numSpotShadows;\n\t\t\tstate.directionalShadowMatrix.length = numDirectionalShadows;\n\t\t\tstate.pointShadowMatrix.length = numPointShadows;\n\t\t\tstate.spotShadowMatrix.length = numSpotShadows;\n\t\t\thash.directionalLength = directionalLength;\n\t\t\thash.pointLength = pointLength;\n\t\t\thash.spotLength = spotLength;\n\t\t\thash.rectAreaLength = rectAreaLength;\n\t\t\thash.hemiLength = hemiLength;\n\t\t\thash.numDirectionalShadows = numDirectionalShadows;\n\t\t\thash.numPointShadows = numPointShadows;\n\t\t\thash.numSpotShadows = numSpotShadows;\n\t\t\tstate.version = nextVersion++;\n\t\t}\n\t}\n\n\tfunction setupView(lights, camera) {\n\t\tlet directionalLength = 0;\n\t\tlet pointLength = 0;\n\t\tlet spotLength = 0;\n\t\tlet rectAreaLength = 0;\n\t\tlet hemiLength = 0;\n\t\tconst viewMatrix = camera.matrixWorldInverse;\n\n\t\tfor (let i = 0, l = lights.length; i < l; i++) {\n\t\t\tconst light = lights[i];\n\n\t\t\tif (light.isDirectionalLight) {\n\t\t\t\tconst uniforms = state.directional[directionalLength];\n\t\t\t\tuniforms.direction.setFromMatrixPosition(light.matrixWorld);\n\t\t\t\tvector3.setFromMatrixPosition(light.target.matrixWorld);\n\t\t\t\tuniforms.direction.sub(vector3);\n\t\t\t\tuniforms.direction.transformDirection(viewMatrix);\n\t\t\t\tdirectionalLength++;\n\t\t\t} else if (light.isSpotLight) {\n\t\t\t\tconst uniforms = state.spot[spotLength];\n\t\t\t\tuniforms.position.setFromMatrixPosition(light.matrixWorld);\n\t\t\t\tuniforms.position.applyMatrix4(viewMatrix);\n\t\t\t\tuniforms.direction.setFromMatrixPosition(light.matrixWorld);\n\t\t\t\tvector3.setFromMatrixPosition(light.target.matrixWorld);\n\t\t\t\tuniforms.direction.sub(vector3);\n\t\t\t\tuniforms.direction.transformDirection(viewMatrix);\n\t\t\t\tspotLength++;\n\t\t\t} else if (light.isRectAreaLight) {\n\t\t\t\tconst uniforms = state.rectArea[rectAreaLength];\n\t\t\t\tuniforms.position.setFromMatrixPosition(light.matrixWorld);\n\t\t\t\tuniforms.position.applyMatrix4(viewMatrix); // extract local rotation of light to derive width/height half vectors\n\n\t\t\t\tmatrix42.identity();\n\t\t\t\tmatrix4.copy(light.matrixWorld);\n\t\t\t\tmatrix4.premultiply(viewMatrix);\n\t\t\t\tmatrix42.extractRotation(matrix4);\n\t\t\t\tuniforms.halfWidth.set(light.width * 0.5, 0.0, 0.0);\n\t\t\t\tuniforms.halfHeight.set(0.0, light.height * 0.5, 0.0);\n\t\t\t\tuniforms.halfWidth.applyMatrix4(matrix42);\n\t\t\t\tuniforms.halfHeight.applyMatrix4(matrix42);\n\t\t\t\trectAreaLength++;\n\t\t\t} else if (light.isPointLight) {\n\t\t\t\tconst uniforms = state.point[pointLength];\n\t\t\t\tuniforms.position.setFromMatrixPosition(light.matrixWorld);\n\t\t\t\tuniforms.position.applyMatrix4(viewMatrix);\n\t\t\t\tpointLength++;\n\t\t\t} else if (light.isHemisphereLight) {\n\t\t\t\tconst uniforms = state.hemi[hemiLength];\n\t\t\t\tuniforms.direction.setFromMatrixPosition(light.matrixWorld);\n\t\t\t\tuniforms.direction.transformDirection(viewMatrix);\n\t\t\t\themiLength++;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn {\n\t\tsetup: setup,\n\t\tsetupView: setupView,\n\t\tstate: state\n\t};\n}\n\nfunction WebGLRenderState(extensions, capabilities) {\n\tconst lights = new WebGLLights(extensions, capabilities);\n\tconst lightsArray = [];\n\tconst shadowsArray = [];\n\n\tfunction init() {\n\t\tlightsArray.length = 0;\n\t\tshadowsArray.length = 0;\n\t}\n\n\tfunction pushLight(light) {\n\t\tlightsArray.push(light);\n\t}\n\n\tfunction pushShadow(shadowLight) {\n\t\tshadowsArray.push(shadowLight);\n\t}\n\n\tfunction setupLights(physicallyCorrectLights) {\n\t\tlights.setup(lightsArray, physicallyCorrectLights);\n\t}\n\n\tfunction setupLightsView(camera) {\n\t\tlights.setupView(lightsArray, camera);\n\t}\n\n\tconst state = {\n\t\tlightsArray: lightsArray,\n\t\tshadowsArray: shadowsArray,\n\t\tlights: lights\n\t};\n\treturn {\n\t\tinit: init,\n\t\tstate: state,\n\t\tsetupLights: setupLights,\n\t\tsetupLightsView: setupLightsView,\n\t\tpushLight: pushLight,\n\t\tpushShadow: pushShadow\n\t};\n}\n\nfunction WebGLRenderStates(extensions, capabilities) {\n\tlet renderStates = new WeakMap();\n\n\tfunction get(scene, renderCallDepth = 0) {\n\t\tlet renderState;\n\n\t\tif (renderStates.has(scene) === false) {\n\t\t\trenderState = new WebGLRenderState(extensions, capabilities);\n\t\t\trenderStates.set(scene, [renderState]);\n\t\t} else {\n\t\t\tif (renderCallDepth >= renderStates.get(scene).length) {\n\t\t\t\trenderState = new WebGLRenderState(extensions, capabilities);\n\t\t\t\trenderStates.get(scene).push(renderState);\n\t\t\t} else {\n\t\t\t\trenderState = renderStates.get(scene)[renderCallDepth];\n\t\t\t}\n\t\t}\n\n\t\treturn renderState;\n\t}\n\n\tfunction dispose() {\n\t\trenderStates = new WeakMap();\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tdispose: dispose\n\t};\n}\n\nclass MeshDepthMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isMeshDepthMaterial = true;\n\t\tthis.type = 'MeshDepthMaterial';\n\t\tthis.depthPacking = BasicDepthPacking;\n\t\tthis.map = null;\n\t\tthis.alphaMap = null;\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.depthPacking = source.depthPacking;\n\t\tthis.map = source.map;\n\t\tthis.alphaMap = source.alphaMap;\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\treturn this;\n\t}\n\n}\n\nclass MeshDistanceMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isMeshDistanceMaterial = true;\n\t\tthis.type = 'MeshDistanceMaterial';\n\t\tthis.referencePosition = new Vector3();\n\t\tthis.nearDistance = 1;\n\t\tthis.farDistance = 1000;\n\t\tthis.map = null;\n\t\tthis.alphaMap = null;\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.referencePosition.copy(source.referencePosition);\n\t\tthis.nearDistance = source.nearDistance;\n\t\tthis.farDistance = source.farDistance;\n\t\tthis.map = source.map;\n\t\tthis.alphaMap = source.alphaMap;\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\t\treturn this;\n\t}\n\n}\n\nconst vertex = \"void main() {\\n\\tgl_Position = vec4( position, 1.0 );\\n}\";\nconst fragment = \"uniform sampler2D shadow_pass;\\nuniform vec2 resolution;\\nuniform float radius;\\n#include \\nvoid main() {\\n\\tconst float samples = float( VSM_SAMPLES );\\n\\tfloat mean = 0.0;\\n\\tfloat squared_mean = 0.0;\\n\\tfloat uvStride = samples <= 1.0 ? 0.0 : 2.0 / ( samples - 1.0 );\\n\\tfloat uvStart = samples <= 1.0 ? 0.0 : - 1.0;\\n\\tfor ( float i = 0.0; i < samples; i ++ ) {\\n\\t\\tfloat uvOffset = uvStart + i * uvStride;\\n\\t\\t#ifdef HORIZONTAL_PASS\\n\\t\\t\\tvec2 distribution = unpackRGBATo2Half( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( uvOffset, 0.0 ) * radius ) / resolution ) );\\n\\t\\t\\tmean += distribution.x;\\n\\t\\t\\tsquared_mean += distribution.y * distribution.y + distribution.x * distribution.x;\\n\\t\\t#else\\n\\t\\t\\tfloat depth = unpackRGBAToDepth( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( 0.0, uvOffset ) * radius ) / resolution ) );\\n\\t\\t\\tmean += depth;\\n\\t\\t\\tsquared_mean += depth * depth;\\n\\t\\t#endif\\n\\t}\\n\\tmean = mean / samples;\\n\\tsquared_mean = squared_mean / samples;\\n\\tfloat std_dev = sqrt( squared_mean - mean * mean );\\n\\tgl_FragColor = pack2HalfToRGBA( vec2( mean, std_dev ) );\\n}\";\n\nfunction WebGLShadowMap(_renderer, _objects, _capabilities) {\n\tlet _frustum = new Frustum();\n\n\tconst _shadowMapSize = new Vector2(),\n\t\t\t\t_viewportSize = new Vector2(),\n\t\t\t\t_viewport = new Vector4(),\n\t\t\t\t_depthMaterial = new MeshDepthMaterial({\n\t\tdepthPacking: RGBADepthPacking\n\t}),\n\t\t\t\t_distanceMaterial = new MeshDistanceMaterial(),\n\t\t\t\t_materialCache = {},\n\t\t\t\t_maxTextureSize = _capabilities.maxTextureSize;\n\n\tconst shadowSide = {\n\t\t0: BackSide,\n\t\t1: FrontSide,\n\t\t2: DoubleSide\n\t};\n\tconst shadowMaterialVertical = new ShaderMaterial({\n\t\tdefines: {\n\t\t\tVSM_SAMPLES: 8\n\t\t},\n\t\tuniforms: {\n\t\t\tshadow_pass: {\n\t\t\t\tvalue: null\n\t\t\t},\n\t\t\tresolution: {\n\t\t\t\tvalue: new Vector2()\n\t\t\t},\n\t\t\tradius: {\n\t\t\t\tvalue: 4.0\n\t\t\t}\n\t\t},\n\t\tvertexShader: vertex,\n\t\tfragmentShader: fragment\n\t});\n\tconst shadowMaterialHorizontal = shadowMaterialVertical.clone();\n\tshadowMaterialHorizontal.defines.HORIZONTAL_PASS = 1;\n\tconst fullScreenTri = new BufferGeometry();\n\tfullScreenTri.setAttribute('position', new BufferAttribute(new Float32Array([-1, -1, 0.5, 3, -1, 0.5, -1, 3, 0.5]), 3));\n\tconst fullScreenMesh = new Mesh(fullScreenTri, shadowMaterialVertical);\n\tconst scope = this;\n\tthis.enabled = false;\n\tthis.autoUpdate = true;\n\tthis.needsUpdate = false;\n\tthis.type = PCFShadowMap;\n\n\tthis.render = function (lights, scene, camera) {\n\t\tif (scope.enabled === false) return;\n\t\tif (scope.autoUpdate === false && scope.needsUpdate === false) return;\n\t\tif (lights.length === 0) return;\n\n\t\tconst currentRenderTarget = _renderer.getRenderTarget();\n\n\t\tconst activeCubeFace = _renderer.getActiveCubeFace();\n\n\t\tconst activeMipmapLevel = _renderer.getActiveMipmapLevel();\n\n\t\tconst _state = _renderer.state; // Set GL state for depth map.\n\n\t\t_state.setBlending(NoBlending);\n\n\t\t_state.buffers.color.setClear(1, 1, 1, 1);\n\n\t\t_state.buffers.depth.setTest(true);\n\n\t\t_state.setScissorTest(false); // render depth map\n\n\n\t\tfor (let i = 0, il = lights.length; i < il; i++) {\n\t\t\tconst light = lights[i];\n\t\t\tconst shadow = light.shadow;\n\n\t\t\tif (shadow === undefined) {\n\t\t\t\tconsole.warn('THREE.WebGLShadowMap:', light, 'has no shadow.');\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (shadow.autoUpdate === false && shadow.needsUpdate === false) continue;\n\n\t\t\t_shadowMapSize.copy(shadow.mapSize);\n\n\t\t\tconst shadowFrameExtents = shadow.getFrameExtents();\n\n\t\t\t_shadowMapSize.multiply(shadowFrameExtents);\n\n\t\t\t_viewportSize.copy(shadow.mapSize);\n\n\t\t\tif (_shadowMapSize.x > _maxTextureSize || _shadowMapSize.y > _maxTextureSize) {\n\t\t\t\tif (_shadowMapSize.x > _maxTextureSize) {\n\t\t\t\t\t_viewportSize.x = Math.floor(_maxTextureSize / shadowFrameExtents.x);\n\t\t\t\t\t_shadowMapSize.x = _viewportSize.x * shadowFrameExtents.x;\n\t\t\t\t\tshadow.mapSize.x = _viewportSize.x;\n\t\t\t\t}\n\n\t\t\t\tif (_shadowMapSize.y > _maxTextureSize) {\n\t\t\t\t\t_viewportSize.y = Math.floor(_maxTextureSize / shadowFrameExtents.y);\n\t\t\t\t\t_shadowMapSize.y = _viewportSize.y * shadowFrameExtents.y;\n\t\t\t\t\tshadow.mapSize.y = _viewportSize.y;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (shadow.map === null && !shadow.isPointLightShadow && this.type === VSMShadowMap) {\n\t\t\t\tshadow.map = new WebGLRenderTarget(_shadowMapSize.x, _shadowMapSize.y);\n\t\t\t\tshadow.map.texture.name = light.name + '.shadowMap';\n\t\t\t\tshadow.mapPass = new WebGLRenderTarget(_shadowMapSize.x, _shadowMapSize.y);\n\t\t\t\tshadow.camera.updateProjectionMatrix();\n\t\t\t}\n\n\t\t\tif (shadow.map === null) {\n\t\t\t\tconst pars = {\n\t\t\t\t\tminFilter: NearestFilter,\n\t\t\t\t\tmagFilter: NearestFilter,\n\t\t\t\t\tformat: RGBAFormat\n\t\t\t\t};\n\t\t\t\tshadow.map = new WebGLRenderTarget(_shadowMapSize.x, _shadowMapSize.y, pars);\n\t\t\t\tshadow.map.texture.name = light.name + '.shadowMap';\n\t\t\t\tshadow.camera.updateProjectionMatrix();\n\t\t\t}\n\n\t\t\t_renderer.setRenderTarget(shadow.map);\n\n\t\t\t_renderer.clear();\n\n\t\t\tconst viewportCount = shadow.getViewportCount();\n\n\t\t\tfor (let vp = 0; vp < viewportCount; vp++) {\n\t\t\t\tconst viewport = shadow.getViewport(vp);\n\n\t\t\t\t_viewport.set(_viewportSize.x * viewport.x, _viewportSize.y * viewport.y, _viewportSize.x * viewport.z, _viewportSize.y * viewport.w);\n\n\t\t\t\t_state.viewport(_viewport);\n\n\t\t\t\tshadow.updateMatrices(light, vp);\n\t\t\t\t_frustum = shadow.getFrustum();\n\t\t\t\trenderObject(scene, camera, shadow.camera, light, this.type);\n\t\t\t} // do blur pass for VSM\n\n\n\t\t\tif (!shadow.isPointLightShadow && this.type === VSMShadowMap) {\n\t\t\t\tVSMPass(shadow, camera);\n\t\t\t}\n\n\t\t\tshadow.needsUpdate = false;\n\t\t}\n\n\t\tscope.needsUpdate = false;\n\n\t\t_renderer.setRenderTarget(currentRenderTarget, activeCubeFace, activeMipmapLevel);\n\t};\n\n\tfunction VSMPass(shadow, camera) {\n\t\tconst geometry = _objects.update(fullScreenMesh);\n\n\t\tif (shadowMaterialVertical.defines.VSM_SAMPLES !== shadow.blurSamples) {\n\t\t\tshadowMaterialVertical.defines.VSM_SAMPLES = shadow.blurSamples;\n\t\t\tshadowMaterialHorizontal.defines.VSM_SAMPLES = shadow.blurSamples;\n\t\t\tshadowMaterialVertical.needsUpdate = true;\n\t\t\tshadowMaterialHorizontal.needsUpdate = true;\n\t\t} // vertical pass\n\n\n\t\tshadowMaterialVertical.uniforms.shadow_pass.value = shadow.map.texture;\n\t\tshadowMaterialVertical.uniforms.resolution.value = shadow.mapSize;\n\t\tshadowMaterialVertical.uniforms.radius.value = shadow.radius;\n\n\t\t_renderer.setRenderTarget(shadow.mapPass);\n\n\t\t_renderer.clear();\n\n\t\t_renderer.renderBufferDirect(camera, null, geometry, shadowMaterialVertical, fullScreenMesh, null); // horizontal pass\n\n\n\t\tshadowMaterialHorizontal.uniforms.shadow_pass.value = shadow.mapPass.texture;\n\t\tshadowMaterialHorizontal.uniforms.resolution.value = shadow.mapSize;\n\t\tshadowMaterialHorizontal.uniforms.radius.value = shadow.radius;\n\n\t\t_renderer.setRenderTarget(shadow.map);\n\n\t\t_renderer.clear();\n\n\t\t_renderer.renderBufferDirect(camera, null, geometry, shadowMaterialHorizontal, fullScreenMesh, null);\n\t}\n\n\tfunction getDepthMaterial(object, material, light, shadowCameraNear, shadowCameraFar, type) {\n\t\tlet result = null;\n\t\tconst customMaterial = light.isPointLight === true ? object.customDistanceMaterial : object.customDepthMaterial;\n\n\t\tif (customMaterial !== undefined) {\n\t\t\tresult = customMaterial;\n\t\t} else {\n\t\t\tresult = light.isPointLight === true ? _distanceMaterial : _depthMaterial;\n\t\t}\n\n\t\tif (_renderer.localClippingEnabled && material.clipShadows === true && material.clippingPlanes.length !== 0 || material.displacementMap && material.displacementScale !== 0 || material.alphaMap && material.alphaTest > 0) {\n\t\t\t// in this case we need a unique material instance reflecting the\n\t\t\t// appropriate state\n\t\t\tconst keyA = result.uuid,\n\t\t\t\t\t\tkeyB = material.uuid;\n\t\t\tlet materialsForVariant = _materialCache[keyA];\n\n\t\t\tif (materialsForVariant === undefined) {\n\t\t\t\tmaterialsForVariant = {};\n\t\t\t\t_materialCache[keyA] = materialsForVariant;\n\t\t\t}\n\n\t\t\tlet cachedMaterial = materialsForVariant[keyB];\n\n\t\t\tif (cachedMaterial === undefined) {\n\t\t\t\tcachedMaterial = result.clone();\n\t\t\t\tmaterialsForVariant[keyB] = cachedMaterial;\n\t\t\t}\n\n\t\t\tresult = cachedMaterial;\n\t\t}\n\n\t\tresult.visible = material.visible;\n\t\tresult.wireframe = material.wireframe;\n\n\t\tif (type === VSMShadowMap) {\n\t\t\tresult.side = material.shadowSide !== null ? material.shadowSide : material.side;\n\t\t} else {\n\t\t\tresult.side = material.shadowSide !== null ? material.shadowSide : shadowSide[material.side];\n\t\t}\n\n\t\tresult.alphaMap = material.alphaMap;\n\t\tresult.alphaTest = material.alphaTest;\n\t\tresult.clipShadows = material.clipShadows;\n\t\tresult.clippingPlanes = material.clippingPlanes;\n\t\tresult.clipIntersection = material.clipIntersection;\n\t\tresult.displacementMap = material.displacementMap;\n\t\tresult.displacementScale = material.displacementScale;\n\t\tresult.displacementBias = material.displacementBias;\n\t\tresult.wireframeLinewidth = material.wireframeLinewidth;\n\t\tresult.linewidth = material.linewidth;\n\n\t\tif (light.isPointLight === true && result.isMeshDistanceMaterial === true) {\n\t\t\tresult.referencePosition.setFromMatrixPosition(light.matrixWorld);\n\t\t\tresult.nearDistance = shadowCameraNear;\n\t\t\tresult.farDistance = shadowCameraFar;\n\t\t}\n\n\t\treturn result;\n\t}\n\n\tfunction renderObject(object, camera, shadowCamera, light, type) {\n\t\tif (object.visible === false) return;\n\t\tconst visible = object.layers.test(camera.layers);\n\n\t\tif (visible && (object.isMesh || object.isLine || object.isPoints)) {\n\t\t\tif ((object.castShadow || object.receiveShadow && type === VSMShadowMap) && (!object.frustumCulled || _frustum.intersectsObject(object))) {\n\t\t\t\tobject.modelViewMatrix.multiplyMatrices(shadowCamera.matrixWorldInverse, object.matrixWorld);\n\n\t\t\t\tconst geometry = _objects.update(object);\n\n\t\t\t\tconst material = object.material;\n\n\t\t\t\tif (Array.isArray(material)) {\n\t\t\t\t\tconst groups = geometry.groups;\n\n\t\t\t\t\tfor (let k = 0, kl = groups.length; k < kl; k++) {\n\t\t\t\t\t\tconst group = groups[k];\n\t\t\t\t\t\tconst groupMaterial = material[group.materialIndex];\n\n\t\t\t\t\t\tif (groupMaterial && groupMaterial.visible) {\n\t\t\t\t\t\t\tconst depthMaterial = getDepthMaterial(object, groupMaterial, light, shadowCamera.near, shadowCamera.far, type);\n\n\t\t\t\t\t\t\t_renderer.renderBufferDirect(shadowCamera, null, geometry, depthMaterial, object, group);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} else if (material.visible) {\n\t\t\t\t\tconst depthMaterial = getDepthMaterial(object, material, light, shadowCamera.near, shadowCamera.far, type);\n\n\t\t\t\t\t_renderer.renderBufferDirect(shadowCamera, null, geometry, depthMaterial, object, null);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst children = object.children;\n\n\t\tfor (let i = 0, l = children.length; i < l; i++) {\n\t\t\trenderObject(children[i], camera, shadowCamera, light, type);\n\t\t}\n\t}\n}\n\nfunction WebGLState(gl, extensions, capabilities) {\n\tconst isWebGL2 = capabilities.isWebGL2;\n\n\tfunction ColorBuffer() {\n\t\tlet locked = false;\n\t\tconst color = new Vector4();\n\t\tlet currentColorMask = null;\n\t\tconst currentColorClear = new Vector4(0, 0, 0, 0);\n\t\treturn {\n\t\t\tsetMask: function (colorMask) {\n\t\t\t\tif (currentColorMask !== colorMask && !locked) {\n\t\t\t\t\tgl.colorMask(colorMask, colorMask, colorMask, colorMask);\n\t\t\t\t\tcurrentColorMask = colorMask;\n\t\t\t\t}\n\t\t\t},\n\t\t\tsetLocked: function (lock) {\n\t\t\t\tlocked = lock;\n\t\t\t},\n\t\t\tsetClear: function (r, g, b, a, premultipliedAlpha) {\n\t\t\t\tif (premultipliedAlpha === true) {\n\t\t\t\t\tr *= a;\n\t\t\t\t\tg *= a;\n\t\t\t\t\tb *= a;\n\t\t\t\t}\n\n\t\t\t\tcolor.set(r, g, b, a);\n\n\t\t\t\tif (currentColorClear.equals(color) === false) {\n\t\t\t\t\tgl.clearColor(r, g, b, a);\n\t\t\t\t\tcurrentColorClear.copy(color);\n\t\t\t\t}\n\t\t\t},\n\t\t\treset: function () {\n\t\t\t\tlocked = false;\n\t\t\t\tcurrentColorMask = null;\n\t\t\t\tcurrentColorClear.set(-1, 0, 0, 0); // set to invalid state\n\t\t\t}\n\t\t};\n\t}\n\n\tfunction DepthBuffer() {\n\t\tlet locked = false;\n\t\tlet currentDepthMask = null;\n\t\tlet currentDepthFunc = null;\n\t\tlet currentDepthClear = null;\n\t\treturn {\n\t\t\tsetTest: function (depthTest) {\n\t\t\t\tif (depthTest) {\n\t\t\t\t\tenable(gl.DEPTH_TEST);\n\t\t\t\t} else {\n\t\t\t\t\tdisable(gl.DEPTH_TEST);\n\t\t\t\t}\n\t\t\t},\n\t\t\tsetMask: function (depthMask) {\n\t\t\t\tif (currentDepthMask !== depthMask && !locked) {\n\t\t\t\t\tgl.depthMask(depthMask);\n\t\t\t\t\tcurrentDepthMask = depthMask;\n\t\t\t\t}\n\t\t\t},\n\t\t\tsetFunc: function (depthFunc) {\n\t\t\t\tif (currentDepthFunc !== depthFunc) {\n\t\t\t\t\tif (depthFunc) {\n\t\t\t\t\t\tswitch (depthFunc) {\n\t\t\t\t\t\t\tcase NeverDepth:\n\t\t\t\t\t\t\t\tgl.depthFunc(gl.NEVER);\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase AlwaysDepth:\n\t\t\t\t\t\t\t\tgl.depthFunc(gl.ALWAYS);\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase LessDepth:\n\t\t\t\t\t\t\t\tgl.depthFunc(gl.LESS);\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase LessEqualDepth:\n\t\t\t\t\t\t\t\tgl.depthFunc(gl.LEQUAL);\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase EqualDepth:\n\t\t\t\t\t\t\t\tgl.depthFunc(gl.EQUAL);\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase GreaterEqualDepth:\n\t\t\t\t\t\t\t\tgl.depthFunc(gl.GEQUAL);\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase GreaterDepth:\n\t\t\t\t\t\t\t\tgl.depthFunc(gl.GREATER);\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase NotEqualDepth:\n\t\t\t\t\t\t\t\tgl.depthFunc(gl.NOTEQUAL);\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\tgl.depthFunc(gl.LEQUAL);\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tgl.depthFunc(gl.LEQUAL);\n\t\t\t\t\t}\n\n\t\t\t\t\tcurrentDepthFunc = depthFunc;\n\t\t\t\t}\n\t\t\t},\n\t\t\tsetLocked: function (lock) {\n\t\t\t\tlocked = lock;\n\t\t\t},\n\t\t\tsetClear: function (depth) {\n\t\t\t\tif (currentDepthClear !== depth) {\n\t\t\t\t\tgl.clearDepth(depth);\n\t\t\t\t\tcurrentDepthClear = depth;\n\t\t\t\t}\n\t\t\t},\n\t\t\treset: function () {\n\t\t\t\tlocked = false;\n\t\t\t\tcurrentDepthMask = null;\n\t\t\t\tcurrentDepthFunc = null;\n\t\t\t\tcurrentDepthClear = null;\n\t\t\t}\n\t\t};\n\t}\n\n\tfunction StencilBuffer() {\n\t\tlet locked = false;\n\t\tlet currentStencilMask = null;\n\t\tlet currentStencilFunc = null;\n\t\tlet currentStencilRef = null;\n\t\tlet currentStencilFuncMask = null;\n\t\tlet currentStencilFail = null;\n\t\tlet currentStencilZFail = null;\n\t\tlet currentStencilZPass = null;\n\t\tlet currentStencilClear = null;\n\t\treturn {\n\t\t\tsetTest: function (stencilTest) {\n\t\t\t\tif (!locked) {\n\t\t\t\t\tif (stencilTest) {\n\t\t\t\t\t\tenable(gl.STENCIL_TEST);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdisable(gl.STENCIL_TEST);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\tsetMask: function (stencilMask) {\n\t\t\t\tif (currentStencilMask !== stencilMask && !locked) {\n\t\t\t\t\tgl.stencilMask(stencilMask);\n\t\t\t\t\tcurrentStencilMask = stencilMask;\n\t\t\t\t}\n\t\t\t},\n\t\t\tsetFunc: function (stencilFunc, stencilRef, stencilMask) {\n\t\t\t\tif (currentStencilFunc !== stencilFunc || currentStencilRef !== stencilRef || currentStencilFuncMask !== stencilMask) {\n\t\t\t\t\tgl.stencilFunc(stencilFunc, stencilRef, stencilMask);\n\t\t\t\t\tcurrentStencilFunc = stencilFunc;\n\t\t\t\t\tcurrentStencilRef = stencilRef;\n\t\t\t\t\tcurrentStencilFuncMask = stencilMask;\n\t\t\t\t}\n\t\t\t},\n\t\t\tsetOp: function (stencilFail, stencilZFail, stencilZPass) {\n\t\t\t\tif (currentStencilFail !== stencilFail || currentStencilZFail !== stencilZFail || currentStencilZPass !== stencilZPass) {\n\t\t\t\t\tgl.stencilOp(stencilFail, stencilZFail, stencilZPass);\n\t\t\t\t\tcurrentStencilFail = stencilFail;\n\t\t\t\t\tcurrentStencilZFail = stencilZFail;\n\t\t\t\t\tcurrentStencilZPass = stencilZPass;\n\t\t\t\t}\n\t\t\t},\n\t\t\tsetLocked: function (lock) {\n\t\t\t\tlocked = lock;\n\t\t\t},\n\t\t\tsetClear: function (stencil) {\n\t\t\t\tif (currentStencilClear !== stencil) {\n\t\t\t\t\tgl.clearStencil(stencil);\n\t\t\t\t\tcurrentStencilClear = stencil;\n\t\t\t\t}\n\t\t\t},\n\t\t\treset: function () {\n\t\t\t\tlocked = false;\n\t\t\t\tcurrentStencilMask = null;\n\t\t\t\tcurrentStencilFunc = null;\n\t\t\t\tcurrentStencilRef = null;\n\t\t\t\tcurrentStencilFuncMask = null;\n\t\t\t\tcurrentStencilFail = null;\n\t\t\t\tcurrentStencilZFail = null;\n\t\t\t\tcurrentStencilZPass = null;\n\t\t\t\tcurrentStencilClear = null;\n\t\t\t}\n\t\t};\n\t} //\n\n\n\tconst colorBuffer = new ColorBuffer();\n\tconst depthBuffer = new DepthBuffer();\n\tconst stencilBuffer = new StencilBuffer();\n\tlet enabledCapabilities = {};\n\tlet currentBoundFramebuffers = {};\n\tlet currentDrawbuffers = new WeakMap();\n\tlet defaultDrawbuffers = [];\n\tlet currentProgram = null;\n\tlet currentBlendingEnabled = false;\n\tlet currentBlending = null;\n\tlet currentBlendEquation = null;\n\tlet currentBlendSrc = null;\n\tlet currentBlendDst = null;\n\tlet currentBlendEquationAlpha = null;\n\tlet currentBlendSrcAlpha = null;\n\tlet currentBlendDstAlpha = null;\n\tlet currentPremultipledAlpha = false;\n\tlet currentFlipSided = null;\n\tlet currentCullFace = null;\n\tlet currentLineWidth = null;\n\tlet currentPolygonOffsetFactor = null;\n\tlet currentPolygonOffsetUnits = null;\n\tconst maxTextures = gl.getParameter(gl.MAX_COMBINED_TEXTURE_IMAGE_UNITS);\n\tlet lineWidthAvailable = false;\n\tlet version = 0;\n\tconst glVersion = gl.getParameter(gl.VERSION);\n\n\tif (glVersion.indexOf('WebGL') !== -1) {\n\t\tversion = parseFloat(/^WebGL (\\d)/.exec(glVersion)[1]);\n\t\tlineWidthAvailable = version >= 1.0;\n\t} else if (glVersion.indexOf('OpenGL ES') !== -1) {\n\t\tversion = parseFloat(/^OpenGL ES (\\d)/.exec(glVersion)[1]);\n\t\tlineWidthAvailable = version >= 2.0;\n\t}\n\n\tlet currentTextureSlot = null;\n\tlet currentBoundTextures = {};\n\tconst scissorParam = gl.getParameter(gl.SCISSOR_BOX);\n\tconst viewportParam = gl.getParameter(gl.VIEWPORT);\n\tconst currentScissor = new Vector4().fromArray(scissorParam);\n\tconst currentViewport = new Vector4().fromArray(viewportParam);\n\n\tfunction createTexture(type, target, count) {\n\t\tconst data = new Uint8Array(4); // 4 is required to match default unpack alignment of 4.\n\n\t\tconst texture = gl.createTexture();\n\t\tgl.bindTexture(type, texture);\n\t\tgl.texParameteri(type, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n\t\tgl.texParameteri(type, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n\n\t\tfor (let i = 0; i < count; i++) {\n\t\t\tgl.texImage2D(target + i, 0, gl.RGBA, 1, 1, 0, gl.RGBA, gl.UNSIGNED_BYTE, data);\n\t\t}\n\n\t\treturn texture;\n\t}\n\n\tconst emptyTextures = {};\n\temptyTextures[gl.TEXTURE_2D] = createTexture(gl.TEXTURE_2D, gl.TEXTURE_2D, 1);\n\temptyTextures[gl.TEXTURE_CUBE_MAP] = createTexture(gl.TEXTURE_CUBE_MAP, gl.TEXTURE_CUBE_MAP_POSITIVE_X, 6); // init\n\n\tcolorBuffer.setClear(0, 0, 0, 1);\n\tdepthBuffer.setClear(1);\n\tstencilBuffer.setClear(0);\n\tenable(gl.DEPTH_TEST);\n\tdepthBuffer.setFunc(LessEqualDepth);\n\tsetFlipSided(false);\n\tsetCullFace(CullFaceBack);\n\tenable(gl.CULL_FACE);\n\tsetBlending(NoBlending); //\n\n\tfunction enable(id) {\n\t\tif (enabledCapabilities[id] !== true) {\n\t\t\tgl.enable(id);\n\t\t\tenabledCapabilities[id] = true;\n\t\t}\n\t}\n\n\tfunction disable(id) {\n\t\tif (enabledCapabilities[id] !== false) {\n\t\t\tgl.disable(id);\n\t\t\tenabledCapabilities[id] = false;\n\t\t}\n\t}\n\n\tfunction bindFramebuffer(target, framebuffer) {\n\t\tif (currentBoundFramebuffers[target] !== framebuffer) {\n\t\t\tgl.bindFramebuffer(target, framebuffer);\n\t\t\tcurrentBoundFramebuffers[target] = framebuffer;\n\n\t\t\tif (isWebGL2) {\n\t\t\t\t// gl.DRAW_FRAMEBUFFER is equivalent to gl.FRAMEBUFFER\n\t\t\t\tif (target === gl.DRAW_FRAMEBUFFER) {\n\t\t\t\t\tcurrentBoundFramebuffers[gl.FRAMEBUFFER] = framebuffer;\n\t\t\t\t}\n\n\t\t\t\tif (target === gl.FRAMEBUFFER) {\n\t\t\t\t\tcurrentBoundFramebuffers[gl.DRAW_FRAMEBUFFER] = framebuffer;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\tfunction drawBuffers(renderTarget, framebuffer) {\n\t\tlet drawBuffers = defaultDrawbuffers;\n\t\tlet needsUpdate = false;\n\n\t\tif (renderTarget) {\n\t\t\tdrawBuffers = currentDrawbuffers.get(framebuffer);\n\n\t\t\tif (drawBuffers === undefined) {\n\t\t\t\tdrawBuffers = [];\n\t\t\t\tcurrentDrawbuffers.set(framebuffer, drawBuffers);\n\t\t\t}\n\n\t\t\tif (renderTarget.isWebGLMultipleRenderTargets) {\n\t\t\t\tconst textures = renderTarget.texture;\n\n\t\t\t\tif (drawBuffers.length !== textures.length || drawBuffers[0] !== gl.COLOR_ATTACHMENT0) {\n\t\t\t\t\tfor (let i = 0, il = textures.length; i < il; i++) {\n\t\t\t\t\t\tdrawBuffers[i] = gl.COLOR_ATTACHMENT0 + i;\n\t\t\t\t\t}\n\n\t\t\t\t\tdrawBuffers.length = textures.length;\n\t\t\t\t\tneedsUpdate = true;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (drawBuffers[0] !== gl.COLOR_ATTACHMENT0) {\n\t\t\t\t\tdrawBuffers[0] = gl.COLOR_ATTACHMENT0;\n\t\t\t\t\tneedsUpdate = true;\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tif (drawBuffers[0] !== gl.BACK) {\n\t\t\t\tdrawBuffers[0] = gl.BACK;\n\t\t\t\tneedsUpdate = true;\n\t\t\t}\n\t\t}\n\n\t\tif (needsUpdate) {\n\t\t\tif (capabilities.isWebGL2) {\n\t\t\t\tgl.drawBuffers(drawBuffers);\n\t\t\t} else {\n\t\t\t\textensions.get('WEBGL_draw_buffers').drawBuffersWEBGL(drawBuffers);\n\t\t\t}\n\t\t}\n\t}\n\n\tfunction useProgram(program) {\n\t\tif (currentProgram !== program) {\n\t\t\tgl.useProgram(program);\n\t\t\tcurrentProgram = program;\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\tconst equationToGL = {\n\t\t[AddEquation]: gl.FUNC_ADD,\n\t\t[SubtractEquation]: gl.FUNC_SUBTRACT,\n\t\t[ReverseSubtractEquation]: gl.FUNC_REVERSE_SUBTRACT\n\t};\n\n\tif (isWebGL2) {\n\t\tequationToGL[MinEquation] = gl.MIN;\n\t\tequationToGL[MaxEquation] = gl.MAX;\n\t} else {\n\t\tconst extension = extensions.get('EXT_blend_minmax');\n\n\t\tif (extension !== null) {\n\t\t\tequationToGL[MinEquation] = extension.MIN_EXT;\n\t\t\tequationToGL[MaxEquation] = extension.MAX_EXT;\n\t\t}\n\t}\n\n\tconst factorToGL = {\n\t\t[ZeroFactor]: gl.ZERO,\n\t\t[OneFactor]: gl.ONE,\n\t\t[SrcColorFactor]: gl.SRC_COLOR,\n\t\t[SrcAlphaFactor]: gl.SRC_ALPHA,\n\t\t[SrcAlphaSaturateFactor]: gl.SRC_ALPHA_SATURATE,\n\t\t[DstColorFactor]: gl.DST_COLOR,\n\t\t[DstAlphaFactor]: gl.DST_ALPHA,\n\t\t[OneMinusSrcColorFactor]: gl.ONE_MINUS_SRC_COLOR,\n\t\t[OneMinusSrcAlphaFactor]: gl.ONE_MINUS_SRC_ALPHA,\n\t\t[OneMinusDstColorFactor]: gl.ONE_MINUS_DST_COLOR,\n\t\t[OneMinusDstAlphaFactor]: gl.ONE_MINUS_DST_ALPHA\n\t};\n\n\tfunction setBlending(blending, blendEquation, blendSrc, blendDst, blendEquationAlpha, blendSrcAlpha, blendDstAlpha, premultipliedAlpha) {\n\t\tif (blending === NoBlending) {\n\t\t\tif (currentBlendingEnabled === true) {\n\t\t\t\tdisable(gl.BLEND);\n\t\t\t\tcurrentBlendingEnabled = false;\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\tif (currentBlendingEnabled === false) {\n\t\t\tenable(gl.BLEND);\n\t\t\tcurrentBlendingEnabled = true;\n\t\t}\n\n\t\tif (blending !== CustomBlending) {\n\t\t\tif (blending !== currentBlending || premultipliedAlpha !== currentPremultipledAlpha) {\n\t\t\t\tif (currentBlendEquation !== AddEquation || currentBlendEquationAlpha !== AddEquation) {\n\t\t\t\t\tgl.blendEquation(gl.FUNC_ADD);\n\t\t\t\t\tcurrentBlendEquation = AddEquation;\n\t\t\t\t\tcurrentBlendEquationAlpha = AddEquation;\n\t\t\t\t}\n\n\t\t\t\tif (premultipliedAlpha) {\n\t\t\t\t\tswitch (blending) {\n\t\t\t\t\t\tcase NormalBlending:\n\t\t\t\t\t\t\tgl.blendFuncSeparate(gl.ONE, gl.ONE_MINUS_SRC_ALPHA, gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase AdditiveBlending:\n\t\t\t\t\t\t\tgl.blendFunc(gl.ONE, gl.ONE);\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase SubtractiveBlending:\n\t\t\t\t\t\t\tgl.blendFuncSeparate(gl.ZERO, gl.ONE_MINUS_SRC_COLOR, gl.ZERO, gl.ONE);\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase MultiplyBlending:\n\t\t\t\t\t\t\tgl.blendFuncSeparate(gl.ZERO, gl.SRC_COLOR, gl.ZERO, gl.SRC_ALPHA);\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tconsole.error('THREE.WebGLState: Invalid blending: ', blending);\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tswitch (blending) {\n\t\t\t\t\t\tcase NormalBlending:\n\t\t\t\t\t\t\tgl.blendFuncSeparate(gl.SRC_ALPHA, gl.ONE_MINUS_SRC_ALPHA, gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase AdditiveBlending:\n\t\t\t\t\t\t\tgl.blendFunc(gl.SRC_ALPHA, gl.ONE);\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase SubtractiveBlending:\n\t\t\t\t\t\t\tgl.blendFuncSeparate(gl.ZERO, gl.ONE_MINUS_SRC_COLOR, gl.ZERO, gl.ONE);\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase MultiplyBlending:\n\t\t\t\t\t\t\tgl.blendFunc(gl.ZERO, gl.SRC_COLOR);\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tconsole.error('THREE.WebGLState: Invalid blending: ', blending);\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tcurrentBlendSrc = null;\n\t\t\t\tcurrentBlendDst = null;\n\t\t\t\tcurrentBlendSrcAlpha = null;\n\t\t\t\tcurrentBlendDstAlpha = null;\n\t\t\t\tcurrentBlending = blending;\n\t\t\t\tcurrentPremultipledAlpha = premultipliedAlpha;\n\t\t\t}\n\n\t\t\treturn;\n\t\t} // custom blending\n\n\n\t\tblendEquationAlpha = blendEquationAlpha || blendEquation;\n\t\tblendSrcAlpha = blendSrcAlpha || blendSrc;\n\t\tblendDstAlpha = blendDstAlpha || blendDst;\n\n\t\tif (blendEquation !== currentBlendEquation || blendEquationAlpha !== currentBlendEquationAlpha) {\n\t\t\tgl.blendEquationSeparate(equationToGL[blendEquation], equationToGL[blendEquationAlpha]);\n\t\t\tcurrentBlendEquation = blendEquation;\n\t\t\tcurrentBlendEquationAlpha = blendEquationAlpha;\n\t\t}\n\n\t\tif (blendSrc !== currentBlendSrc || blendDst !== currentBlendDst || blendSrcAlpha !== currentBlendSrcAlpha || blendDstAlpha !== currentBlendDstAlpha) {\n\t\t\tgl.blendFuncSeparate(factorToGL[blendSrc], factorToGL[blendDst], factorToGL[blendSrcAlpha], factorToGL[blendDstAlpha]);\n\t\t\tcurrentBlendSrc = blendSrc;\n\t\t\tcurrentBlendDst = blendDst;\n\t\t\tcurrentBlendSrcAlpha = blendSrcAlpha;\n\t\t\tcurrentBlendDstAlpha = blendDstAlpha;\n\t\t}\n\n\t\tcurrentBlending = blending;\n\t\tcurrentPremultipledAlpha = null;\n\t}\n\n\tfunction setMaterial(material, frontFaceCW) {\n\t\tmaterial.side === DoubleSide ? disable(gl.CULL_FACE) : enable(gl.CULL_FACE);\n\t\tlet flipSided = material.side === BackSide;\n\t\tif (frontFaceCW) flipSided = !flipSided;\n\t\tsetFlipSided(flipSided);\n\t\tmaterial.blending === NormalBlending && material.transparent === false ? setBlending(NoBlending) : setBlending(material.blending, material.blendEquation, material.blendSrc, material.blendDst, material.blendEquationAlpha, material.blendSrcAlpha, material.blendDstAlpha, material.premultipliedAlpha);\n\t\tdepthBuffer.setFunc(material.depthFunc);\n\t\tdepthBuffer.setTest(material.depthTest);\n\t\tdepthBuffer.setMask(material.depthWrite);\n\t\tcolorBuffer.setMask(material.colorWrite);\n\t\tconst stencilWrite = material.stencilWrite;\n\t\tstencilBuffer.setTest(stencilWrite);\n\n\t\tif (stencilWrite) {\n\t\t\tstencilBuffer.setMask(material.stencilWriteMask);\n\t\t\tstencilBuffer.setFunc(material.stencilFunc, material.stencilRef, material.stencilFuncMask);\n\t\t\tstencilBuffer.setOp(material.stencilFail, material.stencilZFail, material.stencilZPass);\n\t\t}\n\n\t\tsetPolygonOffset(material.polygonOffset, material.polygonOffsetFactor, material.polygonOffsetUnits);\n\t\tmaterial.alphaToCoverage === true ? enable(gl.SAMPLE_ALPHA_TO_COVERAGE) : disable(gl.SAMPLE_ALPHA_TO_COVERAGE);\n\t} //\n\n\n\tfunction setFlipSided(flipSided) {\n\t\tif (currentFlipSided !== flipSided) {\n\t\t\tif (flipSided) {\n\t\t\t\tgl.frontFace(gl.CW);\n\t\t\t} else {\n\t\t\t\tgl.frontFace(gl.CCW);\n\t\t\t}\n\n\t\t\tcurrentFlipSided = flipSided;\n\t\t}\n\t}\n\n\tfunction setCullFace(cullFace) {\n\t\tif (cullFace !== CullFaceNone) {\n\t\t\tenable(gl.CULL_FACE);\n\n\t\t\tif (cullFace !== currentCullFace) {\n\t\t\t\tif (cullFace === CullFaceBack) {\n\t\t\t\t\tgl.cullFace(gl.BACK);\n\t\t\t\t} else if (cullFace === CullFaceFront) {\n\t\t\t\t\tgl.cullFace(gl.FRONT);\n\t\t\t\t} else {\n\t\t\t\t\tgl.cullFace(gl.FRONT_AND_BACK);\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tdisable(gl.CULL_FACE);\n\t\t}\n\n\t\tcurrentCullFace = cullFace;\n\t}\n\n\tfunction setLineWidth(width) {\n\t\tif (width !== currentLineWidth) {\n\t\t\tif (lineWidthAvailable) gl.lineWidth(width);\n\t\t\tcurrentLineWidth = width;\n\t\t}\n\t}\n\n\tfunction setPolygonOffset(polygonOffset, factor, units) {\n\t\tif (polygonOffset) {\n\t\t\tenable(gl.POLYGON_OFFSET_FILL);\n\n\t\t\tif (currentPolygonOffsetFactor !== factor || currentPolygonOffsetUnits !== units) {\n\t\t\t\tgl.polygonOffset(factor, units);\n\t\t\t\tcurrentPolygonOffsetFactor = factor;\n\t\t\t\tcurrentPolygonOffsetUnits = units;\n\t\t\t}\n\t\t} else {\n\t\t\tdisable(gl.POLYGON_OFFSET_FILL);\n\t\t}\n\t}\n\n\tfunction setScissorTest(scissorTest) {\n\t\tif (scissorTest) {\n\t\t\tenable(gl.SCISSOR_TEST);\n\t\t} else {\n\t\t\tdisable(gl.SCISSOR_TEST);\n\t\t}\n\t} // texture\n\n\n\tfunction activeTexture(webglSlot) {\n\t\tif (webglSlot === undefined) webglSlot = gl.TEXTURE0 + maxTextures - 1;\n\n\t\tif (currentTextureSlot !== webglSlot) {\n\t\t\tgl.activeTexture(webglSlot);\n\t\t\tcurrentTextureSlot = webglSlot;\n\t\t}\n\t}\n\n\tfunction bindTexture(webglType, webglTexture) {\n\t\tif (currentTextureSlot === null) {\n\t\t\tactiveTexture();\n\t\t}\n\n\t\tlet boundTexture = currentBoundTextures[currentTextureSlot];\n\n\t\tif (boundTexture === undefined) {\n\t\t\tboundTexture = {\n\t\t\t\ttype: undefined,\n\t\t\t\ttexture: undefined\n\t\t\t};\n\t\t\tcurrentBoundTextures[currentTextureSlot] = boundTexture;\n\t\t}\n\n\t\tif (boundTexture.type !== webglType || boundTexture.texture !== webglTexture) {\n\t\t\tgl.bindTexture(webglType, webglTexture || emptyTextures[webglType]);\n\t\t\tboundTexture.type = webglType;\n\t\t\tboundTexture.texture = webglTexture;\n\t\t}\n\t}\n\n\tfunction unbindTexture() {\n\t\tconst boundTexture = currentBoundTextures[currentTextureSlot];\n\n\t\tif (boundTexture !== undefined && boundTexture.type !== undefined) {\n\t\t\tgl.bindTexture(boundTexture.type, null);\n\t\t\tboundTexture.type = undefined;\n\t\t\tboundTexture.texture = undefined;\n\t\t}\n\t}\n\n\tfunction compressedTexImage2D() {\n\t\ttry {\n\t\t\tgl.compressedTexImage2D.apply(gl, arguments);\n\t\t} catch (error) {\n\t\t\tconsole.error('THREE.WebGLState:', error);\n\t\t}\n\t}\n\n\tfunction texSubImage2D() {\n\t\ttry {\n\t\t\tgl.texSubImage2D.apply(gl, arguments);\n\t\t} catch (error) {\n\t\t\tconsole.error('THREE.WebGLState:', error);\n\t\t}\n\t}\n\n\tfunction texSubImage3D() {\n\t\ttry {\n\t\t\tgl.texSubImage3D.apply(gl, arguments);\n\t\t} catch (error) {\n\t\t\tconsole.error('THREE.WebGLState:', error);\n\t\t}\n\t}\n\n\tfunction compressedTexSubImage2D() {\n\t\ttry {\n\t\t\tgl.compressedTexSubImage2D.apply(gl, arguments);\n\t\t} catch (error) {\n\t\t\tconsole.error('THREE.WebGLState:', error);\n\t\t}\n\t}\n\n\tfunction texStorage2D() {\n\t\ttry {\n\t\t\tgl.texStorage2D.apply(gl, arguments);\n\t\t} catch (error) {\n\t\t\tconsole.error('THREE.WebGLState:', error);\n\t\t}\n\t}\n\n\tfunction texStorage3D() {\n\t\ttry {\n\t\t\tgl.texStorage3D.apply(gl, arguments);\n\t\t} catch (error) {\n\t\t\tconsole.error('THREE.WebGLState:', error);\n\t\t}\n\t}\n\n\tfunction texImage2D() {\n\t\ttry {\n\t\t\tgl.texImage2D.apply(gl, arguments);\n\t\t} catch (error) {\n\t\t\tconsole.error('THREE.WebGLState:', error);\n\t\t}\n\t}\n\n\tfunction texImage3D() {\n\t\ttry {\n\t\t\tgl.texImage3D.apply(gl, arguments);\n\t\t} catch (error) {\n\t\t\tconsole.error('THREE.WebGLState:', error);\n\t\t}\n\t} //\n\n\n\tfunction scissor(scissor) {\n\t\tif (currentScissor.equals(scissor) === false) {\n\t\t\tgl.scissor(scissor.x, scissor.y, scissor.z, scissor.w);\n\t\t\tcurrentScissor.copy(scissor);\n\t\t}\n\t}\n\n\tfunction viewport(viewport) {\n\t\tif (currentViewport.equals(viewport) === false) {\n\t\t\tgl.viewport(viewport.x, viewport.y, viewport.z, viewport.w);\n\t\t\tcurrentViewport.copy(viewport);\n\t\t}\n\t} //\n\n\n\tfunction reset() {\n\t\t// reset state\n\t\tgl.disable(gl.BLEND);\n\t\tgl.disable(gl.CULL_FACE);\n\t\tgl.disable(gl.DEPTH_TEST);\n\t\tgl.disable(gl.POLYGON_OFFSET_FILL);\n\t\tgl.disable(gl.SCISSOR_TEST);\n\t\tgl.disable(gl.STENCIL_TEST);\n\t\tgl.disable(gl.SAMPLE_ALPHA_TO_COVERAGE);\n\t\tgl.blendEquation(gl.FUNC_ADD);\n\t\tgl.blendFunc(gl.ONE, gl.ZERO);\n\t\tgl.blendFuncSeparate(gl.ONE, gl.ZERO, gl.ONE, gl.ZERO);\n\t\tgl.colorMask(true, true, true, true);\n\t\tgl.clearColor(0, 0, 0, 0);\n\t\tgl.depthMask(true);\n\t\tgl.depthFunc(gl.LESS);\n\t\tgl.clearDepth(1);\n\t\tgl.stencilMask(0xffffffff);\n\t\tgl.stencilFunc(gl.ALWAYS, 0, 0xffffffff);\n\t\tgl.stencilOp(gl.KEEP, gl.KEEP, gl.KEEP);\n\t\tgl.clearStencil(0);\n\t\tgl.cullFace(gl.BACK);\n\t\tgl.frontFace(gl.CCW);\n\t\tgl.polygonOffset(0, 0);\n\t\tgl.activeTexture(gl.TEXTURE0);\n\t\tgl.bindFramebuffer(gl.FRAMEBUFFER, null);\n\n\t\tif (isWebGL2 === true) {\n\t\t\tgl.bindFramebuffer(gl.DRAW_FRAMEBUFFER, null);\n\t\t\tgl.bindFramebuffer(gl.READ_FRAMEBUFFER, null);\n\t\t}\n\n\t\tgl.useProgram(null);\n\t\tgl.lineWidth(1);\n\t\tgl.scissor(0, 0, gl.canvas.width, gl.canvas.height);\n\t\tgl.viewport(0, 0, gl.canvas.width, gl.canvas.height); // reset internals\n\n\t\tenabledCapabilities = {};\n\t\tcurrentTextureSlot = null;\n\t\tcurrentBoundTextures = {};\n\t\tcurrentBoundFramebuffers = {};\n\t\tcurrentDrawbuffers = new WeakMap();\n\t\tdefaultDrawbuffers = [];\n\t\tcurrentProgram = null;\n\t\tcurrentBlendingEnabled = false;\n\t\tcurrentBlending = null;\n\t\tcurrentBlendEquation = null;\n\t\tcurrentBlendSrc = null;\n\t\tcurrentBlendDst = null;\n\t\tcurrentBlendEquationAlpha = null;\n\t\tcurrentBlendSrcAlpha = null;\n\t\tcurrentBlendDstAlpha = null;\n\t\tcurrentPremultipledAlpha = false;\n\t\tcurrentFlipSided = null;\n\t\tcurrentCullFace = null;\n\t\tcurrentLineWidth = null;\n\t\tcurrentPolygonOffsetFactor = null;\n\t\tcurrentPolygonOffsetUnits = null;\n\t\tcurrentScissor.set(0, 0, gl.canvas.width, gl.canvas.height);\n\t\tcurrentViewport.set(0, 0, gl.canvas.width, gl.canvas.height);\n\t\tcolorBuffer.reset();\n\t\tdepthBuffer.reset();\n\t\tstencilBuffer.reset();\n\t}\n\n\treturn {\n\t\tbuffers: {\n\t\t\tcolor: colorBuffer,\n\t\t\tdepth: depthBuffer,\n\t\t\tstencil: stencilBuffer\n\t\t},\n\t\tenable: enable,\n\t\tdisable: disable,\n\t\tbindFramebuffer: bindFramebuffer,\n\t\tdrawBuffers: drawBuffers,\n\t\tuseProgram: useProgram,\n\t\tsetBlending: setBlending,\n\t\tsetMaterial: setMaterial,\n\t\tsetFlipSided: setFlipSided,\n\t\tsetCullFace: setCullFace,\n\t\tsetLineWidth: setLineWidth,\n\t\tsetPolygonOffset: setPolygonOffset,\n\t\tsetScissorTest: setScissorTest,\n\t\tactiveTexture: activeTexture,\n\t\tbindTexture: bindTexture,\n\t\tunbindTexture: unbindTexture,\n\t\tcompressedTexImage2D: compressedTexImage2D,\n\t\ttexImage2D: texImage2D,\n\t\ttexImage3D: texImage3D,\n\t\ttexStorage2D: texStorage2D,\n\t\ttexStorage3D: texStorage3D,\n\t\ttexSubImage2D: texSubImage2D,\n\t\ttexSubImage3D: texSubImage3D,\n\t\tcompressedTexSubImage2D: compressedTexSubImage2D,\n\t\tscissor: scissor,\n\t\tviewport: viewport,\n\t\treset: reset\n\t};\n}\n\nfunction WebGLTextures(_gl, extensions, state, properties, capabilities, utils, info) {\n\tconst isWebGL2 = capabilities.isWebGL2;\n\tconst maxTextures = capabilities.maxTextures;\n\tconst maxCubemapSize = capabilities.maxCubemapSize;\n\tconst maxTextureSize = capabilities.maxTextureSize;\n\tconst maxSamples = capabilities.maxSamples;\n\tconst multisampledRTTExt = extensions.has('WEBGL_multisampled_render_to_texture') ? extensions.get('WEBGL_multisampled_render_to_texture') : null;\n\tconst supportsInvalidateFramebuffer = /OculusBrowser/g.test(navigator.userAgent);\n\n\tconst _videoTextures = new WeakMap();\n\n\tlet _canvas;\n\n\tconst _sources = new WeakMap(); // maps WebglTexture objects to instances of Source\n\t// cordova iOS (as of 5.0) still uses UIWebView, which provides OffscreenCanvas,\n\t// also OffscreenCanvas.getContext(\"webgl\"), but not OffscreenCanvas.getContext(\"2d\")!\n\t// Some implementations may only implement OffscreenCanvas partially (e.g. lacking 2d).\n\n\n\tlet useOffscreenCanvas = false;\n\n\ttry {\n\t\tuseOffscreenCanvas = typeof OffscreenCanvas !== 'undefined' // eslint-disable-next-line compat/compat\n\t\t&& new OffscreenCanvas(1, 1).getContext('2d') !== null;\n\t} catch (err) {// Ignore any errors\n\t}\n\n\tfunction createCanvas(width, height) {\n\t\t// Use OffscreenCanvas when available. Specially needed in web workers\n\t\treturn useOffscreenCanvas ? // eslint-disable-next-line compat/compat\n\t\tnew OffscreenCanvas(width, height) : createElementNS('canvas');\n\t}\n\n\tfunction resizeImage(image, needsPowerOfTwo, needsNewCanvas, maxSize) {\n\t\tlet scale = 1; // handle case if texture exceeds max size\n\n\t\tif (image.width > maxSize || image.height > maxSize) {\n\t\t\tscale = maxSize / Math.max(image.width, image.height);\n\t\t} // only perform resize if necessary\n\n\n\t\tif (scale < 1 || needsPowerOfTwo === true) {\n\t\t\t// only perform resize for certain image types\n\t\t\tif (typeof HTMLImageElement !== 'undefined' && image instanceof HTMLImageElement || typeof HTMLCanvasElement !== 'undefined' && image instanceof HTMLCanvasElement || typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {\n\t\t\t\tconst floor = needsPowerOfTwo ? floorPowerOfTwo : Math.floor;\n\t\t\t\tconst width = floor(scale * image.width);\n\t\t\t\tconst height = floor(scale * image.height);\n\t\t\t\tif (_canvas === undefined) _canvas = createCanvas(width, height); // cube textures can't reuse the same canvas\n\n\t\t\t\tconst canvas = needsNewCanvas ? createCanvas(width, height) : _canvas;\n\t\t\t\tcanvas.width = width;\n\t\t\t\tcanvas.height = height;\n\t\t\t\tconst context = canvas.getContext('2d');\n\t\t\t\tcontext.drawImage(image, 0, 0, width, height);\n\t\t\t\tconsole.warn('THREE.WebGLRenderer: Texture has been resized from (' + image.width + 'x' + image.height + ') to (' + width + 'x' + height + ').');\n\t\t\t\treturn canvas;\n\t\t\t} else {\n\t\t\t\tif ('data' in image) {\n\t\t\t\t\tconsole.warn('THREE.WebGLRenderer: Image in DataTexture is too big (' + image.width + 'x' + image.height + ').');\n\t\t\t\t}\n\n\t\t\t\treturn image;\n\t\t\t}\n\t\t}\n\n\t\treturn image;\n\t}\n\n\tfunction isPowerOfTwo$1(image) {\n\t\treturn isPowerOfTwo(image.width) && isPowerOfTwo(image.height);\n\t}\n\n\tfunction textureNeedsPowerOfTwo(texture) {\n\t\tif (isWebGL2) return false;\n\t\treturn texture.wrapS !== ClampToEdgeWrapping || texture.wrapT !== ClampToEdgeWrapping || texture.minFilter !== NearestFilter && texture.minFilter !== LinearFilter;\n\t}\n\n\tfunction textureNeedsGenerateMipmaps(texture, supportsMips) {\n\t\treturn texture.generateMipmaps && supportsMips && texture.minFilter !== NearestFilter && texture.minFilter !== LinearFilter;\n\t}\n\n\tfunction generateMipmap(target) {\n\t\t_gl.generateMipmap(target);\n\t}\n\n\tfunction getInternalFormat(internalFormatName, glFormat, glType, encoding, isVideoTexture = false) {\n\t\tif (isWebGL2 === false) return glFormat;\n\n\t\tif (internalFormatName !== null) {\n\t\t\tif (_gl[internalFormatName] !== undefined) return _gl[internalFormatName];\n\t\t\tconsole.warn('THREE.WebGLRenderer: Attempt to use non-existing WebGL internal format \\'' + internalFormatName + '\\'');\n\t\t}\n\n\t\tlet internalFormat = glFormat;\n\n\t\tif (glFormat === _gl.RED) {\n\t\t\tif (glType === _gl.FLOAT) internalFormat = _gl.R32F;\n\t\t\tif (glType === _gl.HALF_FLOAT) internalFormat = _gl.R16F;\n\t\t\tif (glType === _gl.UNSIGNED_BYTE) internalFormat = _gl.R8;\n\t\t}\n\n\t\tif (glFormat === _gl.RG) {\n\t\t\tif (glType === _gl.FLOAT) internalFormat = _gl.RG32F;\n\t\t\tif (glType === _gl.HALF_FLOAT) internalFormat = _gl.RG16F;\n\t\t\tif (glType === _gl.UNSIGNED_BYTE) internalFormat = _gl.RG8;\n\t\t}\n\n\t\tif (glFormat === _gl.RGBA) {\n\t\t\tif (glType === _gl.FLOAT) internalFormat = _gl.RGBA32F;\n\t\t\tif (glType === _gl.HALF_FLOAT) internalFormat = _gl.RGBA16F;\n\t\t\tif (glType === _gl.UNSIGNED_BYTE) internalFormat = encoding === sRGBEncoding && isVideoTexture === false ? _gl.SRGB8_ALPHA8 : _gl.RGBA8;\n\t\t\tif (glType === _gl.UNSIGNED_SHORT_4_4_4_4) internalFormat = _gl.RGBA4;\n\t\t\tif (glType === _gl.UNSIGNED_SHORT_5_5_5_1) internalFormat = _gl.RGB5_A1;\n\t\t}\n\n\t\tif (internalFormat === _gl.R16F || internalFormat === _gl.R32F || internalFormat === _gl.RG16F || internalFormat === _gl.RG32F || internalFormat === _gl.RGBA16F || internalFormat === _gl.RGBA32F) {\n\t\t\textensions.get('EXT_color_buffer_float');\n\t\t}\n\n\t\treturn internalFormat;\n\t}\n\n\tfunction getMipLevels(texture, image, supportsMips) {\n\t\tif (textureNeedsGenerateMipmaps(texture, supportsMips) === true || texture.isFramebufferTexture && texture.minFilter !== NearestFilter && texture.minFilter !== LinearFilter) {\n\t\t\treturn Math.log2(Math.max(image.width, image.height)) + 1;\n\t\t} else if (texture.mipmaps !== undefined && texture.mipmaps.length > 0) {\n\t\t\t// user-defined mipmaps\n\t\t\treturn texture.mipmaps.length;\n\t\t} else if (texture.isCompressedTexture && Array.isArray(texture.image)) {\n\t\t\treturn image.mipmaps.length;\n\t\t} else {\n\t\t\t// texture without mipmaps (only base level)\n\t\t\treturn 1;\n\t\t}\n\t} // Fallback filters for non-power-of-2 textures\n\n\n\tfunction filterFallback(f) {\n\t\tif (f === NearestFilter || f === NearestMipmapNearestFilter || f === NearestMipmapLinearFilter) {\n\t\t\treturn _gl.NEAREST;\n\t\t}\n\n\t\treturn _gl.LINEAR;\n\t} //\n\n\n\tfunction onTextureDispose(event) {\n\t\tconst texture = event.target;\n\t\ttexture.removeEventListener('dispose', onTextureDispose);\n\t\tdeallocateTexture(texture);\n\n\t\tif (texture.isVideoTexture) {\n\t\t\t_videoTextures.delete(texture);\n\t\t}\n\t}\n\n\tfunction onRenderTargetDispose(event) {\n\t\tconst renderTarget = event.target;\n\t\trenderTarget.removeEventListener('dispose', onRenderTargetDispose);\n\t\tdeallocateRenderTarget(renderTarget);\n\t} //\n\n\n\tfunction deallocateTexture(texture) {\n\t\tconst textureProperties = properties.get(texture);\n\t\tif (textureProperties.__webglInit === undefined) return; // check if it's necessary to remove the WebGLTexture object\n\n\t\tconst source = texture.source;\n\n\t\tconst webglTextures = _sources.get(source);\n\n\t\tif (webglTextures) {\n\t\t\tconst webglTexture = webglTextures[textureProperties.__cacheKey];\n\t\t\twebglTexture.usedTimes--; // the WebGLTexture object is not used anymore, remove it\n\n\t\t\tif (webglTexture.usedTimes === 0) {\n\t\t\t\tdeleteTexture(texture);\n\t\t\t} // remove the weak map entry if no WebGLTexture uses the source anymore\n\n\n\t\t\tif (Object.keys(webglTextures).length === 0) {\n\t\t\t\t_sources.delete(source);\n\t\t\t}\n\t\t}\n\n\t\tproperties.remove(texture);\n\t}\n\n\tfunction deleteTexture(texture) {\n\t\tconst textureProperties = properties.get(texture);\n\n\t\t_gl.deleteTexture(textureProperties.__webglTexture);\n\n\t\tconst source = texture.source;\n\n\t\tconst webglTextures = _sources.get(source);\n\n\t\tdelete webglTextures[textureProperties.__cacheKey];\n\t\tinfo.memory.textures--;\n\t}\n\n\tfunction deallocateRenderTarget(renderTarget) {\n\t\tconst texture = renderTarget.texture;\n\t\tconst renderTargetProperties = properties.get(renderTarget);\n\t\tconst textureProperties = properties.get(texture);\n\n\t\tif (textureProperties.__webglTexture !== undefined) {\n\t\t\t_gl.deleteTexture(textureProperties.__webglTexture);\n\n\t\t\tinfo.memory.textures--;\n\t\t}\n\n\t\tif (renderTarget.depthTexture) {\n\t\t\trenderTarget.depthTexture.dispose();\n\t\t}\n\n\t\tif (renderTarget.isWebGLCubeRenderTarget) {\n\t\t\tfor (let i = 0; i < 6; i++) {\n\t\t\t\t_gl.deleteFramebuffer(renderTargetProperties.__webglFramebuffer[i]);\n\n\t\t\t\tif (renderTargetProperties.__webglDepthbuffer) _gl.deleteRenderbuffer(renderTargetProperties.__webglDepthbuffer[i]);\n\t\t\t}\n\t\t} else {\n\t\t\t_gl.deleteFramebuffer(renderTargetProperties.__webglFramebuffer);\n\n\t\t\tif (renderTargetProperties.__webglDepthbuffer) _gl.deleteRenderbuffer(renderTargetProperties.__webglDepthbuffer);\n\t\t\tif (renderTargetProperties.__webglMultisampledFramebuffer) _gl.deleteFramebuffer(renderTargetProperties.__webglMultisampledFramebuffer);\n\n\t\t\tif (renderTargetProperties.__webglColorRenderbuffer) {\n\t\t\t\tfor (let i = 0; i < renderTargetProperties.__webglColorRenderbuffer.length; i++) {\n\t\t\t\t\tif (renderTargetProperties.__webglColorRenderbuffer[i]) _gl.deleteRenderbuffer(renderTargetProperties.__webglColorRenderbuffer[i]);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (renderTargetProperties.__webglDepthRenderbuffer) _gl.deleteRenderbuffer(renderTargetProperties.__webglDepthRenderbuffer);\n\t\t}\n\n\t\tif (renderTarget.isWebGLMultipleRenderTargets) {\n\t\t\tfor (let i = 0, il = texture.length; i < il; i++) {\n\t\t\t\tconst attachmentProperties = properties.get(texture[i]);\n\n\t\t\t\tif (attachmentProperties.__webglTexture) {\n\t\t\t\t\t_gl.deleteTexture(attachmentProperties.__webglTexture);\n\n\t\t\t\t\tinfo.memory.textures--;\n\t\t\t\t}\n\n\t\t\t\tproperties.remove(texture[i]);\n\t\t\t}\n\t\t}\n\n\t\tproperties.remove(texture);\n\t\tproperties.remove(renderTarget);\n\t} //\n\n\n\tlet textureUnits = 0;\n\n\tfunction resetTextureUnits() {\n\t\ttextureUnits = 0;\n\t}\n\n\tfunction allocateTextureUnit() {\n\t\tconst textureUnit = textureUnits;\n\n\t\tif (textureUnit >= maxTextures) {\n\t\t\tconsole.warn('THREE.WebGLTextures: Trying to use ' + textureUnit + ' texture units while this GPU supports only ' + maxTextures);\n\t\t}\n\n\t\ttextureUnits += 1;\n\t\treturn textureUnit;\n\t}\n\n\tfunction getTextureCacheKey(texture) {\n\t\tconst array = [];\n\t\tarray.push(texture.wrapS);\n\t\tarray.push(texture.wrapT);\n\t\tarray.push(texture.magFilter);\n\t\tarray.push(texture.minFilter);\n\t\tarray.push(texture.anisotropy);\n\t\tarray.push(texture.internalFormat);\n\t\tarray.push(texture.format);\n\t\tarray.push(texture.type);\n\t\tarray.push(texture.generateMipmaps);\n\t\tarray.push(texture.premultiplyAlpha);\n\t\tarray.push(texture.flipY);\n\t\tarray.push(texture.unpackAlignment);\n\t\tarray.push(texture.encoding);\n\t\treturn array.join();\n\t} //\n\n\n\tfunction setTexture2D(texture, slot) {\n\t\tconst textureProperties = properties.get(texture);\n\t\tif (texture.isVideoTexture) updateVideoTexture(texture);\n\n\t\tif (texture.isRenderTargetTexture === false && texture.version > 0 && textureProperties.__version !== texture.version) {\n\t\t\tconst image = texture.image;\n\n\t\t\tif (image === null) {\n\t\t\t\tconsole.warn('THREE.WebGLRenderer: Texture marked for update but no image data found.');\n\t\t\t} else if (image.complete === false) {\n\t\t\t\tconsole.warn('THREE.WebGLRenderer: Texture marked for update but image is incomplete');\n\t\t\t} else {\n\t\t\t\tuploadTexture(textureProperties, texture, slot);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\tstate.activeTexture(_gl.TEXTURE0 + slot);\n\t\tstate.bindTexture(_gl.TEXTURE_2D, textureProperties.__webglTexture);\n\t}\n\n\tfunction setTexture2DArray(texture, slot) {\n\t\tconst textureProperties = properties.get(texture);\n\n\t\tif (texture.version > 0 && textureProperties.__version !== texture.version) {\n\t\t\tuploadTexture(textureProperties, texture, slot);\n\t\t\treturn;\n\t\t}\n\n\t\tstate.activeTexture(_gl.TEXTURE0 + slot);\n\t\tstate.bindTexture(_gl.TEXTURE_2D_ARRAY, textureProperties.__webglTexture);\n\t}\n\n\tfunction setTexture3D(texture, slot) {\n\t\tconst textureProperties = properties.get(texture);\n\n\t\tif (texture.version > 0 && textureProperties.__version !== texture.version) {\n\t\t\tuploadTexture(textureProperties, texture, slot);\n\t\t\treturn;\n\t\t}\n\n\t\tstate.activeTexture(_gl.TEXTURE0 + slot);\n\t\tstate.bindTexture(_gl.TEXTURE_3D, textureProperties.__webglTexture);\n\t}\n\n\tfunction setTextureCube(texture, slot) {\n\t\tconst textureProperties = properties.get(texture);\n\n\t\tif (texture.version > 0 && textureProperties.__version !== texture.version) {\n\t\t\tuploadCubeTexture(textureProperties, texture, slot);\n\t\t\treturn;\n\t\t}\n\n\t\tstate.activeTexture(_gl.TEXTURE0 + slot);\n\t\tstate.bindTexture(_gl.TEXTURE_CUBE_MAP, textureProperties.__webglTexture);\n\t}\n\n\tconst wrappingToGL = {\n\t\t[RepeatWrapping]: _gl.REPEAT,\n\t\t[ClampToEdgeWrapping]: _gl.CLAMP_TO_EDGE,\n\t\t[MirroredRepeatWrapping]: _gl.MIRRORED_REPEAT\n\t};\n\tconst filterToGL = {\n\t\t[NearestFilter]: _gl.NEAREST,\n\t\t[NearestMipmapNearestFilter]: _gl.NEAREST_MIPMAP_NEAREST,\n\t\t[NearestMipmapLinearFilter]: _gl.NEAREST_MIPMAP_LINEAR,\n\t\t[LinearFilter]: _gl.LINEAR,\n\t\t[LinearMipmapNearestFilter]: _gl.LINEAR_MIPMAP_NEAREST,\n\t\t[LinearMipmapLinearFilter]: _gl.LINEAR_MIPMAP_LINEAR\n\t};\n\n\tfunction setTextureParameters(textureType, texture, supportsMips) {\n\t\tif (supportsMips) {\n\t\t\t_gl.texParameteri(textureType, _gl.TEXTURE_WRAP_S, wrappingToGL[texture.wrapS]);\n\n\t\t\t_gl.texParameteri(textureType, _gl.TEXTURE_WRAP_T, wrappingToGL[texture.wrapT]);\n\n\t\t\tif (textureType === _gl.TEXTURE_3D || textureType === _gl.TEXTURE_2D_ARRAY) {\n\t\t\t\t_gl.texParameteri(textureType, _gl.TEXTURE_WRAP_R, wrappingToGL[texture.wrapR]);\n\t\t\t}\n\n\t\t\t_gl.texParameteri(textureType, _gl.TEXTURE_MAG_FILTER, filterToGL[texture.magFilter]);\n\n\t\t\t_gl.texParameteri(textureType, _gl.TEXTURE_MIN_FILTER, filterToGL[texture.minFilter]);\n\t\t} else {\n\t\t\t_gl.texParameteri(textureType, _gl.TEXTURE_WRAP_S, _gl.CLAMP_TO_EDGE);\n\n\t\t\t_gl.texParameteri(textureType, _gl.TEXTURE_WRAP_T, _gl.CLAMP_TO_EDGE);\n\n\t\t\tif (textureType === _gl.TEXTURE_3D || textureType === _gl.TEXTURE_2D_ARRAY) {\n\t\t\t\t_gl.texParameteri(textureType, _gl.TEXTURE_WRAP_R, _gl.CLAMP_TO_EDGE);\n\t\t\t}\n\n\t\t\tif (texture.wrapS !== ClampToEdgeWrapping || texture.wrapT !== ClampToEdgeWrapping) {\n\t\t\t\tconsole.warn('THREE.WebGLRenderer: Texture is not power of two. Texture.wrapS and Texture.wrapT should be set to THREE.ClampToEdgeWrapping.');\n\t\t\t}\n\n\t\t\t_gl.texParameteri(textureType, _gl.TEXTURE_MAG_FILTER, filterFallback(texture.magFilter));\n\n\t\t\t_gl.texParameteri(textureType, _gl.TEXTURE_MIN_FILTER, filterFallback(texture.minFilter));\n\n\t\t\tif (texture.minFilter !== NearestFilter && texture.minFilter !== LinearFilter) {\n\t\t\t\tconsole.warn('THREE.WebGLRenderer: Texture is not power of two. Texture.minFilter should be set to THREE.NearestFilter or THREE.LinearFilter.');\n\t\t\t}\n\t\t}\n\n\t\tif (extensions.has('EXT_texture_filter_anisotropic') === true) {\n\t\t\tconst extension = extensions.get('EXT_texture_filter_anisotropic');\n\t\t\tif (texture.type === FloatType && extensions.has('OES_texture_float_linear') === false) return; // verify extension for WebGL 1 and WebGL 2\n\n\t\t\tif (isWebGL2 === false && texture.type === HalfFloatType && extensions.has('OES_texture_half_float_linear') === false) return; // verify extension for WebGL 1 only\n\n\t\t\tif (texture.anisotropy > 1 || properties.get(texture).__currentAnisotropy) {\n\t\t\t\t_gl.texParameterf(textureType, extension.TEXTURE_MAX_ANISOTROPY_EXT, Math.min(texture.anisotropy, capabilities.getMaxAnisotropy()));\n\n\t\t\t\tproperties.get(texture).__currentAnisotropy = texture.anisotropy;\n\t\t\t}\n\t\t}\n\t}\n\n\tfunction initTexture(textureProperties, texture) {\n\t\tlet forceUpload = false;\n\n\t\tif (textureProperties.__webglInit === undefined) {\n\t\t\ttextureProperties.__webglInit = true;\n\t\t\ttexture.addEventListener('dispose', onTextureDispose);\n\t\t} // create Source <-> WebGLTextures mapping if necessary\n\n\n\t\tconst source = texture.source;\n\n\t\tlet webglTextures = _sources.get(source);\n\n\t\tif (webglTextures === undefined) {\n\t\t\twebglTextures = {};\n\n\t\t\t_sources.set(source, webglTextures);\n\t\t} // check if there is already a WebGLTexture object for the given texture parameters\n\n\n\t\tconst textureCacheKey = getTextureCacheKey(texture);\n\n\t\tif (textureCacheKey !== textureProperties.__cacheKey) {\n\t\t\t// if not, create a new instance of WebGLTexture\n\t\t\tif (webglTextures[textureCacheKey] === undefined) {\n\t\t\t\t// create new entry\n\t\t\t\twebglTextures[textureCacheKey] = {\n\t\t\t\t\ttexture: _gl.createTexture(),\n\t\t\t\t\tusedTimes: 0\n\t\t\t\t};\n\t\t\t\tinfo.memory.textures++; // when a new instance of WebGLTexture was created, a texture upload is required\n\t\t\t\t// even if the image contents are identical\n\n\t\t\t\tforceUpload = true;\n\t\t\t}\n\n\t\t\twebglTextures[textureCacheKey].usedTimes++; // every time the texture cache key changes, it's necessary to check if an instance of\n\t\t\t// WebGLTexture can be deleted in order to avoid a memory leak.\n\n\t\t\tconst webglTexture = webglTextures[textureProperties.__cacheKey];\n\n\t\t\tif (webglTexture !== undefined) {\n\t\t\t\twebglTextures[textureProperties.__cacheKey].usedTimes--;\n\n\t\t\t\tif (webglTexture.usedTimes === 0) {\n\t\t\t\t\tdeleteTexture(texture);\n\t\t\t\t}\n\t\t\t} // store references to cache key and WebGLTexture object\n\n\n\t\t\ttextureProperties.__cacheKey = textureCacheKey;\n\t\t\ttextureProperties.__webglTexture = webglTextures[textureCacheKey].texture;\n\t\t}\n\n\t\treturn forceUpload;\n\t}\n\n\tfunction uploadTexture(textureProperties, texture, slot) {\n\t\tlet textureType = _gl.TEXTURE_2D;\n\t\tif (texture.isDataArrayTexture) textureType = _gl.TEXTURE_2D_ARRAY;\n\t\tif (texture.isData3DTexture) textureType = _gl.TEXTURE_3D;\n\t\tconst forceUpload = initTexture(textureProperties, texture);\n\t\tconst source = texture.source;\n\t\tstate.activeTexture(_gl.TEXTURE0 + slot);\n\t\tstate.bindTexture(textureType, textureProperties.__webglTexture);\n\n\t\tif (source.version !== source.__currentVersion || forceUpload === true) {\n\t\t\t_gl.pixelStorei(_gl.UNPACK_FLIP_Y_WEBGL, texture.flipY);\n\n\t\t\t_gl.pixelStorei(_gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, texture.premultiplyAlpha);\n\n\t\t\t_gl.pixelStorei(_gl.UNPACK_ALIGNMENT, texture.unpackAlignment);\n\n\t\t\t_gl.pixelStorei(_gl.UNPACK_COLORSPACE_CONVERSION_WEBGL, _gl.NONE);\n\n\t\t\tconst needsPowerOfTwo = textureNeedsPowerOfTwo(texture) && isPowerOfTwo$1(texture.image) === false;\n\t\t\tlet image = resizeImage(texture.image, needsPowerOfTwo, false, maxTextureSize);\n\t\t\timage = verifyColorSpace(texture, image);\n\t\t\tconst supportsMips = isPowerOfTwo$1(image) || isWebGL2,\n\t\t\t\t\t\tglFormat = utils.convert(texture.format, texture.encoding);\n\t\t\tlet glType = utils.convert(texture.type),\n\t\t\t\t\tglInternalFormat = getInternalFormat(texture.internalFormat, glFormat, glType, texture.encoding, texture.isVideoTexture);\n\t\t\tsetTextureParameters(textureType, texture, supportsMips);\n\t\t\tlet mipmap;\n\t\t\tconst mipmaps = texture.mipmaps;\n\t\t\tconst useTexStorage = isWebGL2 && texture.isVideoTexture !== true;\n\t\t\tconst allocateMemory = source.__currentVersion === undefined || forceUpload === true;\n\t\t\tconst levels = getMipLevels(texture, image, supportsMips);\n\n\t\t\tif (texture.isDepthTexture) {\n\t\t\t\t// populate depth texture with dummy data\n\t\t\t\tglInternalFormat = _gl.DEPTH_COMPONENT;\n\n\t\t\t\tif (isWebGL2) {\n\t\t\t\t\tif (texture.type === FloatType) {\n\t\t\t\t\t\tglInternalFormat = _gl.DEPTH_COMPONENT32F;\n\t\t\t\t\t} else if (texture.type === UnsignedIntType) {\n\t\t\t\t\t\tglInternalFormat = _gl.DEPTH_COMPONENT24;\n\t\t\t\t\t} else if (texture.type === UnsignedInt248Type) {\n\t\t\t\t\t\tglInternalFormat = _gl.DEPTH24_STENCIL8;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tglInternalFormat = _gl.DEPTH_COMPONENT16; // WebGL2 requires sized internalformat for glTexImage2D\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tif (texture.type === FloatType) {\n\t\t\t\t\t\tconsole.error('WebGLRenderer: Floating point depth texture requires WebGL2.');\n\t\t\t\t\t}\n\t\t\t\t} // validation checks for WebGL 1\n\n\n\t\t\t\tif (texture.format === DepthFormat && glInternalFormat === _gl.DEPTH_COMPONENT) {\n\t\t\t\t\t// The error INVALID_OPERATION is generated by texImage2D if format and internalformat are\n\t\t\t\t\t// DEPTH_COMPONENT and type is not UNSIGNED_SHORT or UNSIGNED_INT\n\t\t\t\t\t// (https://www.khronos.org/registry/webgl/extensions/WEBGL_depth_texture/)\n\t\t\t\t\tif (texture.type !== UnsignedShortType && texture.type !== UnsignedIntType) {\n\t\t\t\t\t\tconsole.warn('THREE.WebGLRenderer: Use UnsignedShortType or UnsignedIntType for DepthFormat DepthTexture.');\n\t\t\t\t\t\ttexture.type = UnsignedIntType;\n\t\t\t\t\t\tglType = utils.convert(texture.type);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (texture.format === DepthStencilFormat && glInternalFormat === _gl.DEPTH_COMPONENT) {\n\t\t\t\t\t// Depth stencil textures need the DEPTH_STENCIL internal format\n\t\t\t\t\t// (https://www.khronos.org/registry/webgl/extensions/WEBGL_depth_texture/)\n\t\t\t\t\tglInternalFormat = _gl.DEPTH_STENCIL; // The error INVALID_OPERATION is generated by texImage2D if format and internalformat are\n\t\t\t\t\t// DEPTH_STENCIL and type is not UNSIGNED_INT_24_8_WEBGL.\n\t\t\t\t\t// (https://www.khronos.org/registry/webgl/extensions/WEBGL_depth_texture/)\n\n\t\t\t\t\tif (texture.type !== UnsignedInt248Type) {\n\t\t\t\t\t\tconsole.warn('THREE.WebGLRenderer: Use UnsignedInt248Type for DepthStencilFormat DepthTexture.');\n\t\t\t\t\t\ttexture.type = UnsignedInt248Type;\n\t\t\t\t\t\tglType = utils.convert(texture.type);\n\t\t\t\t\t}\n\t\t\t\t} //\n\n\n\t\t\t\tif (allocateMemory) {\n\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\tstate.texStorage2D(_gl.TEXTURE_2D, 1, glInternalFormat, image.width, image.height);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tstate.texImage2D(_gl.TEXTURE_2D, 0, glInternalFormat, image.width, image.height, 0, glFormat, glType, null);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (texture.isDataTexture) {\n\t\t\t\t// use manually created mipmaps if available\n\t\t\t\t// if there are no manual mipmaps\n\t\t\t\t// set 0 level mipmap and then use GL to generate other mipmap levels\n\t\t\t\tif (mipmaps.length > 0 && supportsMips) {\n\t\t\t\t\tif (useTexStorage && allocateMemory) {\n\t\t\t\t\t\tstate.texStorage2D(_gl.TEXTURE_2D, levels, glInternalFormat, mipmaps[0].width, mipmaps[0].height);\n\t\t\t\t\t}\n\n\t\t\t\t\tfor (let i = 0, il = mipmaps.length; i < il; i++) {\n\t\t\t\t\t\tmipmap = mipmaps[i];\n\n\t\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\t\tstate.texSubImage2D(_gl.TEXTURE_2D, i, 0, 0, mipmap.width, mipmap.height, glFormat, glType, mipmap.data);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tstate.texImage2D(_gl.TEXTURE_2D, i, glInternalFormat, mipmap.width, mipmap.height, 0, glFormat, glType, mipmap.data);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\ttexture.generateMipmaps = false;\n\t\t\t\t} else {\n\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\tif (allocateMemory) {\n\t\t\t\t\t\t\tstate.texStorage2D(_gl.TEXTURE_2D, levels, glInternalFormat, image.width, image.height);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tstate.texSubImage2D(_gl.TEXTURE_2D, 0, 0, 0, image.width, image.height, glFormat, glType, image.data);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tstate.texImage2D(_gl.TEXTURE_2D, 0, glInternalFormat, image.width, image.height, 0, glFormat, glType, image.data);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (texture.isCompressedTexture) {\n\t\t\t\tif (useTexStorage && allocateMemory) {\n\t\t\t\t\tstate.texStorage2D(_gl.TEXTURE_2D, levels, glInternalFormat, mipmaps[0].width, mipmaps[0].height);\n\t\t\t\t}\n\n\t\t\t\tfor (let i = 0, il = mipmaps.length; i < il; i++) {\n\t\t\t\t\tmipmap = mipmaps[i];\n\n\t\t\t\t\tif (texture.format !== RGBAFormat) {\n\t\t\t\t\t\tif (glFormat !== null) {\n\t\t\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\t\t\tstate.compressedTexSubImage2D(_gl.TEXTURE_2D, i, 0, 0, mipmap.width, mipmap.height, glFormat, mipmap.data);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tstate.compressedTexImage2D(_gl.TEXTURE_2D, i, glInternalFormat, mipmap.width, mipmap.height, 0, mipmap.data);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tconsole.warn('THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .uploadTexture()');\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\t\tstate.texSubImage2D(_gl.TEXTURE_2D, i, 0, 0, mipmap.width, mipmap.height, glFormat, glType, mipmap.data);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tstate.texImage2D(_gl.TEXTURE_2D, i, glInternalFormat, mipmap.width, mipmap.height, 0, glFormat, glType, mipmap.data);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (texture.isDataArrayTexture) {\n\t\t\t\tif (useTexStorage) {\n\t\t\t\t\tif (allocateMemory) {\n\t\t\t\t\t\tstate.texStorage3D(_gl.TEXTURE_2D_ARRAY, levels, glInternalFormat, image.width, image.height, image.depth);\n\t\t\t\t\t}\n\n\t\t\t\t\tstate.texSubImage3D(_gl.TEXTURE_2D_ARRAY, 0, 0, 0, 0, image.width, image.height, image.depth, glFormat, glType, image.data);\n\t\t\t\t} else {\n\t\t\t\t\tstate.texImage3D(_gl.TEXTURE_2D_ARRAY, 0, glInternalFormat, image.width, image.height, image.depth, 0, glFormat, glType, image.data);\n\t\t\t\t}\n\t\t\t} else if (texture.isData3DTexture) {\n\t\t\t\tif (useTexStorage) {\n\t\t\t\t\tif (allocateMemory) {\n\t\t\t\t\t\tstate.texStorage3D(_gl.TEXTURE_3D, levels, glInternalFormat, image.width, image.height, image.depth);\n\t\t\t\t\t}\n\n\t\t\t\t\tstate.texSubImage3D(_gl.TEXTURE_3D, 0, 0, 0, 0, image.width, image.height, image.depth, glFormat, glType, image.data);\n\t\t\t\t} else {\n\t\t\t\t\tstate.texImage3D(_gl.TEXTURE_3D, 0, glInternalFormat, image.width, image.height, image.depth, 0, glFormat, glType, image.data);\n\t\t\t\t}\n\t\t\t} else if (texture.isFramebufferTexture) {\n\t\t\t\tif (allocateMemory) {\n\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\tstate.texStorage2D(_gl.TEXTURE_2D, levels, glInternalFormat, image.width, image.height);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tlet width = image.width,\n\t\t\t\t\t\t\t\theight = image.height;\n\n\t\t\t\t\t\tfor (let i = 0; i < levels; i++) {\n\t\t\t\t\t\t\tstate.texImage2D(_gl.TEXTURE_2D, i, glInternalFormat, width, height, 0, glFormat, glType, null);\n\t\t\t\t\t\t\twidth >>= 1;\n\t\t\t\t\t\t\theight >>= 1;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// regular Texture (image, video, canvas)\n\t\t\t\t// use manually created mipmaps if available\n\t\t\t\t// if there are no manual mipmaps\n\t\t\t\t// set 0 level mipmap and then use GL to generate other mipmap levels\n\t\t\t\tif (mipmaps.length > 0 && supportsMips) {\n\t\t\t\t\tif (useTexStorage && allocateMemory) {\n\t\t\t\t\t\tstate.texStorage2D(_gl.TEXTURE_2D, levels, glInternalFormat, mipmaps[0].width, mipmaps[0].height);\n\t\t\t\t\t}\n\n\t\t\t\t\tfor (let i = 0, il = mipmaps.length; i < il; i++) {\n\t\t\t\t\t\tmipmap = mipmaps[i];\n\n\t\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\t\tstate.texSubImage2D(_gl.TEXTURE_2D, i, 0, 0, glFormat, glType, mipmap);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tstate.texImage2D(_gl.TEXTURE_2D, i, glInternalFormat, glFormat, glType, mipmap);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\ttexture.generateMipmaps = false;\n\t\t\t\t} else {\n\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\tif (allocateMemory) {\n\t\t\t\t\t\t\tstate.texStorage2D(_gl.TEXTURE_2D, levels, glInternalFormat, image.width, image.height);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tstate.texSubImage2D(_gl.TEXTURE_2D, 0, 0, 0, glFormat, glType, image);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tstate.texImage2D(_gl.TEXTURE_2D, 0, glInternalFormat, glFormat, glType, image);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (textureNeedsGenerateMipmaps(texture, supportsMips)) {\n\t\t\t\tgenerateMipmap(textureType);\n\t\t\t}\n\n\t\t\tsource.__currentVersion = source.version;\n\t\t\tif (texture.onUpdate) texture.onUpdate(texture);\n\t\t}\n\n\t\ttextureProperties.__version = texture.version;\n\t}\n\n\tfunction uploadCubeTexture(textureProperties, texture, slot) {\n\t\tif (texture.image.length !== 6) return;\n\t\tconst forceUpload = initTexture(textureProperties, texture);\n\t\tconst source = texture.source;\n\t\tstate.activeTexture(_gl.TEXTURE0 + slot);\n\t\tstate.bindTexture(_gl.TEXTURE_CUBE_MAP, textureProperties.__webglTexture);\n\n\t\tif (source.version !== source.__currentVersion || forceUpload === true) {\n\t\t\t_gl.pixelStorei(_gl.UNPACK_FLIP_Y_WEBGL, texture.flipY);\n\n\t\t\t_gl.pixelStorei(_gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, texture.premultiplyAlpha);\n\n\t\t\t_gl.pixelStorei(_gl.UNPACK_ALIGNMENT, texture.unpackAlignment);\n\n\t\t\t_gl.pixelStorei(_gl.UNPACK_COLORSPACE_CONVERSION_WEBGL, _gl.NONE);\n\n\t\t\tconst isCompressed = texture.isCompressedTexture || texture.image[0].isCompressedTexture;\n\t\t\tconst isDataTexture = texture.image[0] && texture.image[0].isDataTexture;\n\t\t\tconst cubeImage = [];\n\n\t\t\tfor (let i = 0; i < 6; i++) {\n\t\t\t\tif (!isCompressed && !isDataTexture) {\n\t\t\t\t\tcubeImage[i] = resizeImage(texture.image[i], false, true, maxCubemapSize);\n\t\t\t\t} else {\n\t\t\t\t\tcubeImage[i] = isDataTexture ? texture.image[i].image : texture.image[i];\n\t\t\t\t}\n\n\t\t\t\tcubeImage[i] = verifyColorSpace(texture, cubeImage[i]);\n\t\t\t}\n\n\t\t\tconst image = cubeImage[0],\n\t\t\t\t\t\tsupportsMips = isPowerOfTwo$1(image) || isWebGL2,\n\t\t\t\t\t\tglFormat = utils.convert(texture.format, texture.encoding),\n\t\t\t\t\t\tglType = utils.convert(texture.type),\n\t\t\t\t\t\tglInternalFormat = getInternalFormat(texture.internalFormat, glFormat, glType, texture.encoding);\n\t\t\tconst useTexStorage = isWebGL2 && texture.isVideoTexture !== true;\n\t\t\tconst allocateMemory = source.__currentVersion === undefined || forceUpload === true;\n\t\t\tlet levels = getMipLevels(texture, image, supportsMips);\n\t\t\tsetTextureParameters(_gl.TEXTURE_CUBE_MAP, texture, supportsMips);\n\t\t\tlet mipmaps;\n\n\t\t\tif (isCompressed) {\n\t\t\t\tif (useTexStorage && allocateMemory) {\n\t\t\t\t\tstate.texStorage2D(_gl.TEXTURE_CUBE_MAP, levels, glInternalFormat, image.width, image.height);\n\t\t\t\t}\n\n\t\t\t\tfor (let i = 0; i < 6; i++) {\n\t\t\t\t\tmipmaps = cubeImage[i].mipmaps;\n\n\t\t\t\t\tfor (let j = 0; j < mipmaps.length; j++) {\n\t\t\t\t\t\tconst mipmap = mipmaps[j];\n\n\t\t\t\t\t\tif (texture.format !== RGBAFormat) {\n\t\t\t\t\t\t\tif (glFormat !== null) {\n\t\t\t\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\t\t\t\tstate.compressedTexSubImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, j, 0, 0, mipmap.width, mipmap.height, glFormat, mipmap.data);\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tstate.compressedTexImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, j, glInternalFormat, mipmap.width, mipmap.height, 0, mipmap.data);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tconsole.warn('THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .setTextureCube()');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\t\t\tstate.texSubImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, j, 0, 0, mipmap.width, mipmap.height, glFormat, glType, mipmap.data);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tstate.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, j, glInternalFormat, mipmap.width, mipmap.height, 0, glFormat, glType, mipmap.data);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tmipmaps = texture.mipmaps;\n\n\t\t\t\tif (useTexStorage && allocateMemory) {\n\t\t\t\t\t// TODO: Uniformly handle mipmap definitions\n\t\t\t\t\t// Normal textures and compressed cube textures define base level + mips with their mipmap array\n\t\t\t\t\t// Uncompressed cube textures use their mipmap array only for mips (no base level)\n\t\t\t\t\tif (mipmaps.length > 0) levels++;\n\t\t\t\t\tstate.texStorage2D(_gl.TEXTURE_CUBE_MAP, levels, glInternalFormat, cubeImage[0].width, cubeImage[0].height);\n\t\t\t\t}\n\n\t\t\t\tfor (let i = 0; i < 6; i++) {\n\t\t\t\t\tif (isDataTexture) {\n\t\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\t\tstate.texSubImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, 0, 0, 0, cubeImage[i].width, cubeImage[i].height, glFormat, glType, cubeImage[i].data);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tstate.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, 0, glInternalFormat, cubeImage[i].width, cubeImage[i].height, 0, glFormat, glType, cubeImage[i].data);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tfor (let j = 0; j < mipmaps.length; j++) {\n\t\t\t\t\t\t\tconst mipmap = mipmaps[j];\n\t\t\t\t\t\t\tconst mipmapImage = mipmap.image[i].image;\n\n\t\t\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\t\t\tstate.texSubImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, j + 1, 0, 0, mipmapImage.width, mipmapImage.height, glFormat, glType, mipmapImage.data);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tstate.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, j + 1, glInternalFormat, mipmapImage.width, mipmapImage.height, 0, glFormat, glType, mipmapImage.data);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\t\tstate.texSubImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, 0, 0, 0, glFormat, glType, cubeImage[i]);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tstate.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, 0, glInternalFormat, glFormat, glType, cubeImage[i]);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tfor (let j = 0; j < mipmaps.length; j++) {\n\t\t\t\t\t\t\tconst mipmap = mipmaps[j];\n\n\t\t\t\t\t\t\tif (useTexStorage) {\n\t\t\t\t\t\t\t\tstate.texSubImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, j + 1, 0, 0, glFormat, glType, mipmap.image[i]);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tstate.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, j + 1, glInternalFormat, glFormat, glType, mipmap.image[i]);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (textureNeedsGenerateMipmaps(texture, supportsMips)) {\n\t\t\t\t// We assume images for cube map have the same size.\n\t\t\t\tgenerateMipmap(_gl.TEXTURE_CUBE_MAP);\n\t\t\t}\n\n\t\t\tsource.__currentVersion = source.version;\n\t\t\tif (texture.onUpdate) texture.onUpdate(texture);\n\t\t}\n\n\t\ttextureProperties.__version = texture.version;\n\t} // Render targets\n\t// Setup storage for target texture and bind it to correct framebuffer\n\n\n\tfunction setupFrameBufferTexture(framebuffer, renderTarget, texture, attachment, textureTarget) {\n\t\tconst glFormat = utils.convert(texture.format, texture.encoding);\n\t\tconst glType = utils.convert(texture.type);\n\t\tconst glInternalFormat = getInternalFormat(texture.internalFormat, glFormat, glType, texture.encoding);\n\t\tconst renderTargetProperties = properties.get(renderTarget);\n\n\t\tif (!renderTargetProperties.__hasExternalTextures) {\n\t\t\tif (textureTarget === _gl.TEXTURE_3D || textureTarget === _gl.TEXTURE_2D_ARRAY) {\n\t\t\t\tstate.texImage3D(textureTarget, 0, glInternalFormat, renderTarget.width, renderTarget.height, renderTarget.depth, 0, glFormat, glType, null);\n\t\t\t} else {\n\t\t\t\tstate.texImage2D(textureTarget, 0, glInternalFormat, renderTarget.width, renderTarget.height, 0, glFormat, glType, null);\n\t\t\t}\n\t\t}\n\n\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, framebuffer);\n\n\t\tif (useMultisampledRTT(renderTarget)) {\n\t\t\tmultisampledRTTExt.framebufferTexture2DMultisampleEXT(_gl.FRAMEBUFFER, attachment, textureTarget, properties.get(texture).__webglTexture, 0, getRenderTargetSamples(renderTarget));\n\t\t} else {\n\t\t\t_gl.framebufferTexture2D(_gl.FRAMEBUFFER, attachment, textureTarget, properties.get(texture).__webglTexture, 0);\n\t\t}\n\n\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, null);\n\t} // Setup storage for internal depth/stencil buffers and bind to correct framebuffer\n\n\n\tfunction setupRenderBufferStorage(renderbuffer, renderTarget, isMultisample) {\n\t\t_gl.bindRenderbuffer(_gl.RENDERBUFFER, renderbuffer);\n\n\t\tif (renderTarget.depthBuffer && !renderTarget.stencilBuffer) {\n\t\t\tlet glInternalFormat = _gl.DEPTH_COMPONENT16;\n\n\t\t\tif (isMultisample || useMultisampledRTT(renderTarget)) {\n\t\t\t\tconst depthTexture = renderTarget.depthTexture;\n\n\t\t\t\tif (depthTexture && depthTexture.isDepthTexture) {\n\t\t\t\t\tif (depthTexture.type === FloatType) {\n\t\t\t\t\t\tglInternalFormat = _gl.DEPTH_COMPONENT32F;\n\t\t\t\t\t} else if (depthTexture.type === UnsignedIntType) {\n\t\t\t\t\t\tglInternalFormat = _gl.DEPTH_COMPONENT24;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst samples = getRenderTargetSamples(renderTarget);\n\n\t\t\t\tif (useMultisampledRTT(renderTarget)) {\n\t\t\t\t\tmultisampledRTTExt.renderbufferStorageMultisampleEXT(_gl.RENDERBUFFER, samples, glInternalFormat, renderTarget.width, renderTarget.height);\n\t\t\t\t} else {\n\t\t\t\t\t_gl.renderbufferStorageMultisample(_gl.RENDERBUFFER, samples, glInternalFormat, renderTarget.width, renderTarget.height);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t_gl.renderbufferStorage(_gl.RENDERBUFFER, glInternalFormat, renderTarget.width, renderTarget.height);\n\t\t\t}\n\n\t\t\t_gl.framebufferRenderbuffer(_gl.FRAMEBUFFER, _gl.DEPTH_ATTACHMENT, _gl.RENDERBUFFER, renderbuffer);\n\t\t} else if (renderTarget.depthBuffer && renderTarget.stencilBuffer) {\n\t\t\tconst samples = getRenderTargetSamples(renderTarget);\n\n\t\t\tif (isMultisample && useMultisampledRTT(renderTarget) === false) {\n\t\t\t\t_gl.renderbufferStorageMultisample(_gl.RENDERBUFFER, samples, _gl.DEPTH24_STENCIL8, renderTarget.width, renderTarget.height);\n\t\t\t} else if (useMultisampledRTT(renderTarget)) {\n\t\t\t\tmultisampledRTTExt.renderbufferStorageMultisampleEXT(_gl.RENDERBUFFER, samples, _gl.DEPTH24_STENCIL8, renderTarget.width, renderTarget.height);\n\t\t\t} else {\n\t\t\t\t_gl.renderbufferStorage(_gl.RENDERBUFFER, _gl.DEPTH_STENCIL, renderTarget.width, renderTarget.height);\n\t\t\t}\n\n\t\t\t_gl.framebufferRenderbuffer(_gl.FRAMEBUFFER, _gl.DEPTH_STENCIL_ATTACHMENT, _gl.RENDERBUFFER, renderbuffer);\n\t\t} else {\n\t\t\tconst textures = renderTarget.isWebGLMultipleRenderTargets === true ? renderTarget.texture : [renderTarget.texture];\n\n\t\t\tfor (let i = 0; i < textures.length; i++) {\n\t\t\t\tconst texture = textures[i];\n\t\t\t\tconst glFormat = utils.convert(texture.format, texture.encoding);\n\t\t\t\tconst glType = utils.convert(texture.type);\n\t\t\t\tconst glInternalFormat = getInternalFormat(texture.internalFormat, glFormat, glType, texture.encoding);\n\t\t\t\tconst samples = getRenderTargetSamples(renderTarget);\n\n\t\t\t\tif (isMultisample && useMultisampledRTT(renderTarget) === false) {\n\t\t\t\t\t_gl.renderbufferStorageMultisample(_gl.RENDERBUFFER, samples, glInternalFormat, renderTarget.width, renderTarget.height);\n\t\t\t\t} else if (useMultisampledRTT(renderTarget)) {\n\t\t\t\t\tmultisampledRTTExt.renderbufferStorageMultisampleEXT(_gl.RENDERBUFFER, samples, glInternalFormat, renderTarget.width, renderTarget.height);\n\t\t\t\t} else {\n\t\t\t\t\t_gl.renderbufferStorage(_gl.RENDERBUFFER, glInternalFormat, renderTarget.width, renderTarget.height);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t_gl.bindRenderbuffer(_gl.RENDERBUFFER, null);\n\t} // Setup resources for a Depth Texture for a FBO (needs an extension)\n\n\n\tfunction setupDepthTexture(framebuffer, renderTarget) {\n\t\tconst isCube = renderTarget && renderTarget.isWebGLCubeRenderTarget;\n\t\tif (isCube) throw new Error('Depth Texture with cube render targets is not supported');\n\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, framebuffer);\n\n\t\tif (!(renderTarget.depthTexture && renderTarget.depthTexture.isDepthTexture)) {\n\t\t\tthrow new Error('renderTarget.depthTexture must be an instance of THREE.DepthTexture');\n\t\t} // upload an empty depth texture with framebuffer size\n\n\n\t\tif (!properties.get(renderTarget.depthTexture).__webglTexture || renderTarget.depthTexture.image.width !== renderTarget.width || renderTarget.depthTexture.image.height !== renderTarget.height) {\n\t\t\trenderTarget.depthTexture.image.width = renderTarget.width;\n\t\t\trenderTarget.depthTexture.image.height = renderTarget.height;\n\t\t\trenderTarget.depthTexture.needsUpdate = true;\n\t\t}\n\n\t\tsetTexture2D(renderTarget.depthTexture, 0);\n\n\t\tconst webglDepthTexture = properties.get(renderTarget.depthTexture).__webglTexture;\n\n\t\tconst samples = getRenderTargetSamples(renderTarget);\n\n\t\tif (renderTarget.depthTexture.format === DepthFormat) {\n\t\t\tif (useMultisampledRTT(renderTarget)) {\n\t\t\t\tmultisampledRTTExt.framebufferTexture2DMultisampleEXT(_gl.FRAMEBUFFER, _gl.DEPTH_ATTACHMENT, _gl.TEXTURE_2D, webglDepthTexture, 0, samples);\n\t\t\t} else {\n\t\t\t\t_gl.framebufferTexture2D(_gl.FRAMEBUFFER, _gl.DEPTH_ATTACHMENT, _gl.TEXTURE_2D, webglDepthTexture, 0);\n\t\t\t}\n\t\t} else if (renderTarget.depthTexture.format === DepthStencilFormat) {\n\t\t\tif (useMultisampledRTT(renderTarget)) {\n\t\t\t\tmultisampledRTTExt.framebufferTexture2DMultisampleEXT(_gl.FRAMEBUFFER, _gl.DEPTH_STENCIL_ATTACHMENT, _gl.TEXTURE_2D, webglDepthTexture, 0, samples);\n\t\t\t} else {\n\t\t\t\t_gl.framebufferTexture2D(_gl.FRAMEBUFFER, _gl.DEPTH_STENCIL_ATTACHMENT, _gl.TEXTURE_2D, webglDepthTexture, 0);\n\t\t\t}\n\t\t} else {\n\t\t\tthrow new Error('Unknown depthTexture format');\n\t\t}\n\t} // Setup GL resources for a non-texture depth buffer\n\n\n\tfunction setupDepthRenderbuffer(renderTarget) {\n\t\tconst renderTargetProperties = properties.get(renderTarget);\n\t\tconst isCube = renderTarget.isWebGLCubeRenderTarget === true;\n\n\t\tif (renderTarget.depthTexture && !renderTargetProperties.__autoAllocateDepthBuffer) {\n\t\t\tif (isCube) throw new Error('target.depthTexture not supported in Cube render targets');\n\t\t\tsetupDepthTexture(renderTargetProperties.__webglFramebuffer, renderTarget);\n\t\t} else {\n\t\t\tif (isCube) {\n\t\t\t\trenderTargetProperties.__webglDepthbuffer = [];\n\n\t\t\t\tfor (let i = 0; i < 6; i++) {\n\t\t\t\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, renderTargetProperties.__webglFramebuffer[i]);\n\t\t\t\t\trenderTargetProperties.__webglDepthbuffer[i] = _gl.createRenderbuffer();\n\t\t\t\t\tsetupRenderBufferStorage(renderTargetProperties.__webglDepthbuffer[i], renderTarget, false);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, renderTargetProperties.__webglFramebuffer);\n\t\t\t\trenderTargetProperties.__webglDepthbuffer = _gl.createRenderbuffer();\n\t\t\t\tsetupRenderBufferStorage(renderTargetProperties.__webglDepthbuffer, renderTarget, false);\n\t\t\t}\n\t\t}\n\n\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, null);\n\t} // rebind framebuffer with external textures\n\n\n\tfunction rebindTextures(renderTarget, colorTexture, depthTexture) {\n\t\tconst renderTargetProperties = properties.get(renderTarget);\n\n\t\tif (colorTexture !== undefined) {\n\t\t\tsetupFrameBufferTexture(renderTargetProperties.__webglFramebuffer, renderTarget, renderTarget.texture, _gl.COLOR_ATTACHMENT0, _gl.TEXTURE_2D);\n\t\t}\n\n\t\tif (depthTexture !== undefined) {\n\t\t\tsetupDepthRenderbuffer(renderTarget);\n\t\t}\n\t} // Set up GL resources for the render target\n\n\n\tfunction setupRenderTarget(renderTarget) {\n\t\tconst texture = renderTarget.texture;\n\t\tconst renderTargetProperties = properties.get(renderTarget);\n\t\tconst textureProperties = properties.get(texture);\n\t\trenderTarget.addEventListener('dispose', onRenderTargetDispose);\n\n\t\tif (renderTarget.isWebGLMultipleRenderTargets !== true) {\n\t\t\tif (textureProperties.__webglTexture === undefined) {\n\t\t\t\ttextureProperties.__webglTexture = _gl.createTexture();\n\t\t\t}\n\n\t\t\ttextureProperties.__version = texture.version;\n\t\t\tinfo.memory.textures++;\n\t\t}\n\n\t\tconst isCube = renderTarget.isWebGLCubeRenderTarget === true;\n\t\tconst isMultipleRenderTargets = renderTarget.isWebGLMultipleRenderTargets === true;\n\t\tconst supportsMips = isPowerOfTwo$1(renderTarget) || isWebGL2; // Setup framebuffer\n\n\t\tif (isCube) {\n\t\t\trenderTargetProperties.__webglFramebuffer = [];\n\n\t\t\tfor (let i = 0; i < 6; i++) {\n\t\t\t\trenderTargetProperties.__webglFramebuffer[i] = _gl.createFramebuffer();\n\t\t\t}\n\t\t} else {\n\t\t\trenderTargetProperties.__webglFramebuffer = _gl.createFramebuffer();\n\n\t\t\tif (isMultipleRenderTargets) {\n\t\t\t\tif (capabilities.drawBuffers) {\n\t\t\t\t\tconst textures = renderTarget.texture;\n\n\t\t\t\t\tfor (let i = 0, il = textures.length; i < il; i++) {\n\t\t\t\t\t\tconst attachmentProperties = properties.get(textures[i]);\n\n\t\t\t\t\t\tif (attachmentProperties.__webglTexture === undefined) {\n\t\t\t\t\t\t\tattachmentProperties.__webglTexture = _gl.createTexture();\n\t\t\t\t\t\t\tinfo.memory.textures++;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tconsole.warn('THREE.WebGLRenderer: WebGLMultipleRenderTargets can only be used with WebGL2 or WEBGL_draw_buffers extension.');\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (isWebGL2 && renderTarget.samples > 0 && useMultisampledRTT(renderTarget) === false) {\n\t\t\t\tconst textures = isMultipleRenderTargets ? texture : [texture];\n\t\t\t\trenderTargetProperties.__webglMultisampledFramebuffer = _gl.createFramebuffer();\n\t\t\t\trenderTargetProperties.__webglColorRenderbuffer = [];\n\t\t\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, renderTargetProperties.__webglMultisampledFramebuffer);\n\n\t\t\t\tfor (let i = 0; i < textures.length; i++) {\n\t\t\t\t\tconst texture = textures[i];\n\t\t\t\t\trenderTargetProperties.__webglColorRenderbuffer[i] = _gl.createRenderbuffer();\n\n\t\t\t\t\t_gl.bindRenderbuffer(_gl.RENDERBUFFER, renderTargetProperties.__webglColorRenderbuffer[i]);\n\n\t\t\t\t\tconst glFormat = utils.convert(texture.format, texture.encoding);\n\t\t\t\t\tconst glType = utils.convert(texture.type);\n\t\t\t\t\tconst glInternalFormat = getInternalFormat(texture.internalFormat, glFormat, glType, texture.encoding);\n\t\t\t\t\tconst samples = getRenderTargetSamples(renderTarget);\n\n\t\t\t\t\t_gl.renderbufferStorageMultisample(_gl.RENDERBUFFER, samples, glInternalFormat, renderTarget.width, renderTarget.height);\n\n\t\t\t\t\t_gl.framebufferRenderbuffer(_gl.FRAMEBUFFER, _gl.COLOR_ATTACHMENT0 + i, _gl.RENDERBUFFER, renderTargetProperties.__webglColorRenderbuffer[i]);\n\t\t\t\t}\n\n\t\t\t\t_gl.bindRenderbuffer(_gl.RENDERBUFFER, null);\n\n\t\t\t\tif (renderTarget.depthBuffer) {\n\t\t\t\t\trenderTargetProperties.__webglDepthRenderbuffer = _gl.createRenderbuffer();\n\t\t\t\t\tsetupRenderBufferStorage(renderTargetProperties.__webglDepthRenderbuffer, renderTarget, true);\n\t\t\t\t}\n\n\t\t\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, null);\n\t\t\t}\n\t\t} // Setup color buffer\n\n\n\t\tif (isCube) {\n\t\t\tstate.bindTexture(_gl.TEXTURE_CUBE_MAP, textureProperties.__webglTexture);\n\t\t\tsetTextureParameters(_gl.TEXTURE_CUBE_MAP, texture, supportsMips);\n\n\t\t\tfor (let i = 0; i < 6; i++) {\n\t\t\t\tsetupFrameBufferTexture(renderTargetProperties.__webglFramebuffer[i], renderTarget, texture, _gl.COLOR_ATTACHMENT0, _gl.TEXTURE_CUBE_MAP_POSITIVE_X + i);\n\t\t\t}\n\n\t\t\tif (textureNeedsGenerateMipmaps(texture, supportsMips)) {\n\t\t\t\tgenerateMipmap(_gl.TEXTURE_CUBE_MAP);\n\t\t\t}\n\n\t\t\tstate.unbindTexture();\n\t\t} else if (isMultipleRenderTargets) {\n\t\t\tconst textures = renderTarget.texture;\n\n\t\t\tfor (let i = 0, il = textures.length; i < il; i++) {\n\t\t\t\tconst attachment = textures[i];\n\t\t\t\tconst attachmentProperties = properties.get(attachment);\n\t\t\t\tstate.bindTexture(_gl.TEXTURE_2D, attachmentProperties.__webglTexture);\n\t\t\t\tsetTextureParameters(_gl.TEXTURE_2D, attachment, supportsMips);\n\t\t\t\tsetupFrameBufferTexture(renderTargetProperties.__webglFramebuffer, renderTarget, attachment, _gl.COLOR_ATTACHMENT0 + i, _gl.TEXTURE_2D);\n\n\t\t\t\tif (textureNeedsGenerateMipmaps(attachment, supportsMips)) {\n\t\t\t\t\tgenerateMipmap(_gl.TEXTURE_2D);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tstate.unbindTexture();\n\t\t} else {\n\t\t\tlet glTextureType = _gl.TEXTURE_2D;\n\n\t\t\tif (renderTarget.isWebGL3DRenderTarget || renderTarget.isWebGLArrayRenderTarget) {\n\t\t\t\tif (isWebGL2) {\n\t\t\t\t\tglTextureType = renderTarget.isWebGL3DRenderTarget ? _gl.TEXTURE_3D : _gl.TEXTURE_2D_ARRAY;\n\t\t\t\t} else {\n\t\t\t\t\tconsole.error('THREE.WebGLTextures: THREE.Data3DTexture and THREE.DataArrayTexture only supported with WebGL2.');\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tstate.bindTexture(glTextureType, textureProperties.__webglTexture);\n\t\t\tsetTextureParameters(glTextureType, texture, supportsMips);\n\t\t\tsetupFrameBufferTexture(renderTargetProperties.__webglFramebuffer, renderTarget, texture, _gl.COLOR_ATTACHMENT0, glTextureType);\n\n\t\t\tif (textureNeedsGenerateMipmaps(texture, supportsMips)) {\n\t\t\t\tgenerateMipmap(glTextureType);\n\t\t\t}\n\n\t\t\tstate.unbindTexture();\n\t\t} // Setup depth and stencil buffers\n\n\n\t\tif (renderTarget.depthBuffer) {\n\t\t\tsetupDepthRenderbuffer(renderTarget);\n\t\t}\n\t}\n\n\tfunction updateRenderTargetMipmap(renderTarget) {\n\t\tconst supportsMips = isPowerOfTwo$1(renderTarget) || isWebGL2;\n\t\tconst textures = renderTarget.isWebGLMultipleRenderTargets === true ? renderTarget.texture : [renderTarget.texture];\n\n\t\tfor (let i = 0, il = textures.length; i < il; i++) {\n\t\t\tconst texture = textures[i];\n\n\t\t\tif (textureNeedsGenerateMipmaps(texture, supportsMips)) {\n\t\t\t\tconst target = renderTarget.isWebGLCubeRenderTarget ? _gl.TEXTURE_CUBE_MAP : _gl.TEXTURE_2D;\n\n\t\t\t\tconst webglTexture = properties.get(texture).__webglTexture;\n\n\t\t\t\tstate.bindTexture(target, webglTexture);\n\t\t\t\tgenerateMipmap(target);\n\t\t\t\tstate.unbindTexture();\n\t\t\t}\n\t\t}\n\t}\n\n\tfunction updateMultisampleRenderTarget(renderTarget) {\n\t\tif (isWebGL2 && renderTarget.samples > 0 && useMultisampledRTT(renderTarget) === false) {\n\t\t\tconst textures = renderTarget.isWebGLMultipleRenderTargets ? renderTarget.texture : [renderTarget.texture];\n\t\t\tconst width = renderTarget.width;\n\t\t\tconst height = renderTarget.height;\n\t\t\tlet mask = _gl.COLOR_BUFFER_BIT;\n\t\t\tconst invalidationArray = [];\n\t\t\tconst depthStyle = renderTarget.stencilBuffer ? _gl.DEPTH_STENCIL_ATTACHMENT : _gl.DEPTH_ATTACHMENT;\n\t\t\tconst renderTargetProperties = properties.get(renderTarget);\n\t\t\tconst isMultipleRenderTargets = renderTarget.isWebGLMultipleRenderTargets === true; // If MRT we need to remove FBO attachments\n\n\t\t\tif (isMultipleRenderTargets) {\n\t\t\t\tfor (let i = 0; i < textures.length; i++) {\n\t\t\t\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, renderTargetProperties.__webglMultisampledFramebuffer);\n\n\t\t\t\t\t_gl.framebufferRenderbuffer(_gl.FRAMEBUFFER, _gl.COLOR_ATTACHMENT0 + i, _gl.RENDERBUFFER, null);\n\n\t\t\t\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, renderTargetProperties.__webglFramebuffer);\n\n\t\t\t\t\t_gl.framebufferTexture2D(_gl.DRAW_FRAMEBUFFER, _gl.COLOR_ATTACHMENT0 + i, _gl.TEXTURE_2D, null, 0);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tstate.bindFramebuffer(_gl.READ_FRAMEBUFFER, renderTargetProperties.__webglMultisampledFramebuffer);\n\t\t\tstate.bindFramebuffer(_gl.DRAW_FRAMEBUFFER, renderTargetProperties.__webglFramebuffer);\n\n\t\t\tfor (let i = 0; i < textures.length; i++) {\n\t\t\t\tinvalidationArray.push(_gl.COLOR_ATTACHMENT0 + i);\n\n\t\t\t\tif (renderTarget.depthBuffer) {\n\t\t\t\t\tinvalidationArray.push(depthStyle);\n\t\t\t\t}\n\n\t\t\t\tconst ignoreDepthValues = renderTargetProperties.__ignoreDepthValues !== undefined ? renderTargetProperties.__ignoreDepthValues : false;\n\n\t\t\t\tif (ignoreDepthValues === false) {\n\t\t\t\t\tif (renderTarget.depthBuffer) mask |= _gl.DEPTH_BUFFER_BIT;\n\t\t\t\t\tif (renderTarget.stencilBuffer) mask |= _gl.STENCIL_BUFFER_BIT;\n\t\t\t\t}\n\n\t\t\t\tif (isMultipleRenderTargets) {\n\t\t\t\t\t_gl.framebufferRenderbuffer(_gl.READ_FRAMEBUFFER, _gl.COLOR_ATTACHMENT0, _gl.RENDERBUFFER, renderTargetProperties.__webglColorRenderbuffer[i]);\n\t\t\t\t}\n\n\t\t\t\tif (ignoreDepthValues === true) {\n\t\t\t\t\t_gl.invalidateFramebuffer(_gl.READ_FRAMEBUFFER, [depthStyle]);\n\n\t\t\t\t\t_gl.invalidateFramebuffer(_gl.DRAW_FRAMEBUFFER, [depthStyle]);\n\t\t\t\t}\n\n\t\t\t\tif (isMultipleRenderTargets) {\n\t\t\t\t\tconst webglTexture = properties.get(textures[i]).__webglTexture;\n\n\t\t\t\t\t_gl.framebufferTexture2D(_gl.DRAW_FRAMEBUFFER, _gl.COLOR_ATTACHMENT0, _gl.TEXTURE_2D, webglTexture, 0);\n\t\t\t\t}\n\n\t\t\t\t_gl.blitFramebuffer(0, 0, width, height, 0, 0, width, height, mask, _gl.NEAREST);\n\n\t\t\t\tif (supportsInvalidateFramebuffer) {\n\t\t\t\t\t_gl.invalidateFramebuffer(_gl.READ_FRAMEBUFFER, invalidationArray);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tstate.bindFramebuffer(_gl.READ_FRAMEBUFFER, null);\n\t\t\tstate.bindFramebuffer(_gl.DRAW_FRAMEBUFFER, null); // If MRT since pre-blit we removed the FBO we need to reconstruct the attachments\n\n\t\t\tif (isMultipleRenderTargets) {\n\t\t\t\tfor (let i = 0; i < textures.length; i++) {\n\t\t\t\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, renderTargetProperties.__webglMultisampledFramebuffer);\n\n\t\t\t\t\t_gl.framebufferRenderbuffer(_gl.FRAMEBUFFER, _gl.COLOR_ATTACHMENT0 + i, _gl.RENDERBUFFER, renderTargetProperties.__webglColorRenderbuffer[i]);\n\n\t\t\t\t\tconst webglTexture = properties.get(textures[i]).__webglTexture;\n\n\t\t\t\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, renderTargetProperties.__webglFramebuffer);\n\n\t\t\t\t\t_gl.framebufferTexture2D(_gl.DRAW_FRAMEBUFFER, _gl.COLOR_ATTACHMENT0 + i, _gl.TEXTURE_2D, webglTexture, 0);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tstate.bindFramebuffer(_gl.DRAW_FRAMEBUFFER, renderTargetProperties.__webglMultisampledFramebuffer);\n\t\t}\n\t}\n\n\tfunction getRenderTargetSamples(renderTarget) {\n\t\treturn Math.min(maxSamples, renderTarget.samples);\n\t}\n\n\tfunction useMultisampledRTT(renderTarget) {\n\t\tconst renderTargetProperties = properties.get(renderTarget);\n\t\treturn isWebGL2 && renderTarget.samples > 0 && extensions.has('WEBGL_multisampled_render_to_texture') === true && renderTargetProperties.__useRenderToTexture !== false;\n\t}\n\n\tfunction updateVideoTexture(texture) {\n\t\tconst frame = info.render.frame; // Check the last frame we updated the VideoTexture\n\n\t\tif (_videoTextures.get(texture) !== frame) {\n\t\t\t_videoTextures.set(texture, frame);\n\n\t\t\ttexture.update();\n\t\t}\n\t}\n\n\tfunction verifyColorSpace(texture, image) {\n\t\tconst encoding = texture.encoding;\n\t\tconst format = texture.format;\n\t\tconst type = texture.type;\n\t\tif (texture.isCompressedTexture === true || texture.isVideoTexture === true || texture.format === _SRGBAFormat) return image;\n\n\t\tif (encoding !== LinearEncoding) {\n\t\t\t// sRGB\n\t\t\tif (encoding === sRGBEncoding) {\n\t\t\t\tif (isWebGL2 === false) {\n\t\t\t\t\t// in WebGL 1, try to use EXT_sRGB extension and unsized formats\n\t\t\t\t\tif (extensions.has('EXT_sRGB') === true && format === RGBAFormat) {\n\t\t\t\t\t\ttexture.format = _SRGBAFormat; // it's not possible to generate mips in WebGL 1 with this extension\n\n\t\t\t\t\t\ttexture.minFilter = LinearFilter;\n\t\t\t\t\t\ttexture.generateMipmaps = false;\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// slow fallback (CPU decode)\n\t\t\t\t\t\timage = ImageUtils.sRGBToLinear(image);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// in WebGL 2 uncompressed textures can only be sRGB encoded if they have the RGBA8 format\n\t\t\t\t\tif (format !== RGBAFormat || type !== UnsignedByteType) {\n\t\t\t\t\t\tconsole.warn('THREE.WebGLTextures: sRGB encoded textures have to use RGBAFormat and UnsignedByteType.');\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tconsole.error('THREE.WebGLTextures: Unsupported texture encoding:', encoding);\n\t\t\t}\n\t\t}\n\n\t\treturn image;\n\t} //\n\n\n\tthis.allocateTextureUnit = allocateTextureUnit;\n\tthis.resetTextureUnits = resetTextureUnits;\n\tthis.setTexture2D = setTexture2D;\n\tthis.setTexture2DArray = setTexture2DArray;\n\tthis.setTexture3D = setTexture3D;\n\tthis.setTextureCube = setTextureCube;\n\tthis.rebindTextures = rebindTextures;\n\tthis.setupRenderTarget = setupRenderTarget;\n\tthis.updateRenderTargetMipmap = updateRenderTargetMipmap;\n\tthis.updateMultisampleRenderTarget = updateMultisampleRenderTarget;\n\tthis.setupDepthRenderbuffer = setupDepthRenderbuffer;\n\tthis.setupFrameBufferTexture = setupFrameBufferTexture;\n\tthis.useMultisampledRTT = useMultisampledRTT;\n}\n\nfunction WebGLUtils(gl, extensions, capabilities) {\n\tconst isWebGL2 = capabilities.isWebGL2;\n\n\tfunction convert(p, encoding = null) {\n\t\tlet extension;\n\t\tif (p === UnsignedByteType) return gl.UNSIGNED_BYTE;\n\t\tif (p === UnsignedShort4444Type) return gl.UNSIGNED_SHORT_4_4_4_4;\n\t\tif (p === UnsignedShort5551Type) return gl.UNSIGNED_SHORT_5_5_5_1;\n\t\tif (p === ByteType) return gl.BYTE;\n\t\tif (p === ShortType) return gl.SHORT;\n\t\tif (p === UnsignedShortType) return gl.UNSIGNED_SHORT;\n\t\tif (p === IntType) return gl.INT;\n\t\tif (p === UnsignedIntType) return gl.UNSIGNED_INT;\n\t\tif (p === FloatType) return gl.FLOAT;\n\n\t\tif (p === HalfFloatType) {\n\t\t\tif (isWebGL2) return gl.HALF_FLOAT;\n\t\t\textension = extensions.get('OES_texture_half_float');\n\n\t\t\tif (extension !== null) {\n\t\t\t\treturn extension.HALF_FLOAT_OES;\n\t\t\t} else {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t}\n\n\t\tif (p === AlphaFormat) return gl.ALPHA;\n\t\tif (p === RGBAFormat) return gl.RGBA;\n\t\tif (p === LuminanceFormat) return gl.LUMINANCE;\n\t\tif (p === LuminanceAlphaFormat) return gl.LUMINANCE_ALPHA;\n\t\tif (p === DepthFormat) return gl.DEPTH_COMPONENT;\n\t\tif (p === DepthStencilFormat) return gl.DEPTH_STENCIL;\n\t\tif (p === RedFormat) return gl.RED;\n\n\t\tif (p === RGBFormat) {\n\t\t\tconsole.warn('THREE.WebGLRenderer: THREE.RGBFormat has been removed. Use THREE.RGBAFormat instead. https://github.com/mrdoob/three.js/pull/23228');\n\t\t\treturn gl.RGBA;\n\t\t} // WebGL 1 sRGB fallback\n\n\n\t\tif (p === _SRGBAFormat) {\n\t\t\textension = extensions.get('EXT_sRGB');\n\n\t\t\tif (extension !== null) {\n\t\t\t\treturn extension.SRGB_ALPHA_EXT;\n\t\t\t} else {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t} // WebGL2 formats.\n\n\n\t\tif (p === RedIntegerFormat) return gl.RED_INTEGER;\n\t\tif (p === RGFormat) return gl.RG;\n\t\tif (p === RGIntegerFormat) return gl.RG_INTEGER;\n\t\tif (p === RGBAIntegerFormat) return gl.RGBA_INTEGER; // S3TC\n\n\t\tif (p === RGB_S3TC_DXT1_Format || p === RGBA_S3TC_DXT1_Format || p === RGBA_S3TC_DXT3_Format || p === RGBA_S3TC_DXT5_Format) {\n\t\t\tif (encoding === sRGBEncoding) {\n\t\t\t\textension = extensions.get('WEBGL_compressed_texture_s3tc_srgb');\n\n\t\t\t\tif (extension !== null) {\n\t\t\t\t\tif (p === RGB_S3TC_DXT1_Format) return extension.COMPRESSED_SRGB_S3TC_DXT1_EXT;\n\t\t\t\t\tif (p === RGBA_S3TC_DXT1_Format) return extension.COMPRESSED_SRGB_ALPHA_S3TC_DXT1_EXT;\n\t\t\t\t\tif (p === RGBA_S3TC_DXT3_Format) return extension.COMPRESSED_SRGB_ALPHA_S3TC_DXT3_EXT;\n\t\t\t\t\tif (p === RGBA_S3TC_DXT5_Format) return extension.COMPRESSED_SRGB_ALPHA_S3TC_DXT5_EXT;\n\t\t\t\t} else {\n\t\t\t\t\treturn null;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\textension = extensions.get('WEBGL_compressed_texture_s3tc');\n\n\t\t\t\tif (extension !== null) {\n\t\t\t\t\tif (p === RGB_S3TC_DXT1_Format) return extension.COMPRESSED_RGB_S3TC_DXT1_EXT;\n\t\t\t\t\tif (p === RGBA_S3TC_DXT1_Format) return extension.COMPRESSED_RGBA_S3TC_DXT1_EXT;\n\t\t\t\t\tif (p === RGBA_S3TC_DXT3_Format) return extension.COMPRESSED_RGBA_S3TC_DXT3_EXT;\n\t\t\t\t\tif (p === RGBA_S3TC_DXT5_Format) return extension.COMPRESSED_RGBA_S3TC_DXT5_EXT;\n\t\t\t\t} else {\n\t\t\t\t\treturn null;\n\t\t\t\t}\n\t\t\t}\n\t\t} // PVRTC\n\n\n\t\tif (p === RGB_PVRTC_4BPPV1_Format || p === RGB_PVRTC_2BPPV1_Format || p === RGBA_PVRTC_4BPPV1_Format || p === RGBA_PVRTC_2BPPV1_Format) {\n\t\t\textension = extensions.get('WEBGL_compressed_texture_pvrtc');\n\n\t\t\tif (extension !== null) {\n\t\t\t\tif (p === RGB_PVRTC_4BPPV1_Format) return extension.COMPRESSED_RGB_PVRTC_4BPPV1_IMG;\n\t\t\t\tif (p === RGB_PVRTC_2BPPV1_Format) return extension.COMPRESSED_RGB_PVRTC_2BPPV1_IMG;\n\t\t\t\tif (p === RGBA_PVRTC_4BPPV1_Format) return extension.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG;\n\t\t\t\tif (p === RGBA_PVRTC_2BPPV1_Format) return extension.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG;\n\t\t\t} else {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t} // ETC1\n\n\n\t\tif (p === RGB_ETC1_Format) {\n\t\t\textension = extensions.get('WEBGL_compressed_texture_etc1');\n\n\t\t\tif (extension !== null) {\n\t\t\t\treturn extension.COMPRESSED_RGB_ETC1_WEBGL;\n\t\t\t} else {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t} // ETC2\n\n\n\t\tif (p === RGB_ETC2_Format || p === RGBA_ETC2_EAC_Format) {\n\t\t\textension = extensions.get('WEBGL_compressed_texture_etc');\n\n\t\t\tif (extension !== null) {\n\t\t\t\tif (p === RGB_ETC2_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ETC2 : extension.COMPRESSED_RGB8_ETC2;\n\t\t\t\tif (p === RGBA_ETC2_EAC_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ETC2_EAC : extension.COMPRESSED_RGBA8_ETC2_EAC;\n\t\t\t} else {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t} // ASTC\n\n\n\t\tif (p === RGBA_ASTC_4x4_Format || p === RGBA_ASTC_5x4_Format || p === RGBA_ASTC_5x5_Format || p === RGBA_ASTC_6x5_Format || p === RGBA_ASTC_6x6_Format || p === RGBA_ASTC_8x5_Format || p === RGBA_ASTC_8x6_Format || p === RGBA_ASTC_8x8_Format || p === RGBA_ASTC_10x5_Format || p === RGBA_ASTC_10x6_Format || p === RGBA_ASTC_10x8_Format || p === RGBA_ASTC_10x10_Format || p === RGBA_ASTC_12x10_Format || p === RGBA_ASTC_12x12_Format) {\n\t\t\textension = extensions.get('WEBGL_compressed_texture_astc');\n\n\t\t\tif (extension !== null) {\n\t\t\t\tif (p === RGBA_ASTC_4x4_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_4x4_KHR : extension.COMPRESSED_RGBA_ASTC_4x4_KHR;\n\t\t\t\tif (p === RGBA_ASTC_5x4_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_5x4_KHR : extension.COMPRESSED_RGBA_ASTC_5x4_KHR;\n\t\t\t\tif (p === RGBA_ASTC_5x5_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_5x5_KHR : extension.COMPRESSED_RGBA_ASTC_5x5_KHR;\n\t\t\t\tif (p === RGBA_ASTC_6x5_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_6x5_KHR : extension.COMPRESSED_RGBA_ASTC_6x5_KHR;\n\t\t\t\tif (p === RGBA_ASTC_6x6_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_6x6_KHR : extension.COMPRESSED_RGBA_ASTC_6x6_KHR;\n\t\t\t\tif (p === RGBA_ASTC_8x5_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_8x5_KHR : extension.COMPRESSED_RGBA_ASTC_8x5_KHR;\n\t\t\t\tif (p === RGBA_ASTC_8x6_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_8x6_KHR : extension.COMPRESSED_RGBA_ASTC_8x6_KHR;\n\t\t\t\tif (p === RGBA_ASTC_8x8_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_8x8_KHR : extension.COMPRESSED_RGBA_ASTC_8x8_KHR;\n\t\t\t\tif (p === RGBA_ASTC_10x5_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_10x5_KHR : extension.COMPRESSED_RGBA_ASTC_10x5_KHR;\n\t\t\t\tif (p === RGBA_ASTC_10x6_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_10x6_KHR : extension.COMPRESSED_RGBA_ASTC_10x6_KHR;\n\t\t\t\tif (p === RGBA_ASTC_10x8_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_10x8_KHR : extension.COMPRESSED_RGBA_ASTC_10x8_KHR;\n\t\t\t\tif (p === RGBA_ASTC_10x10_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_10x10_KHR : extension.COMPRESSED_RGBA_ASTC_10x10_KHR;\n\t\t\t\tif (p === RGBA_ASTC_12x10_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_12x10_KHR : extension.COMPRESSED_RGBA_ASTC_12x10_KHR;\n\t\t\t\tif (p === RGBA_ASTC_12x12_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_12x12_KHR : extension.COMPRESSED_RGBA_ASTC_12x12_KHR;\n\t\t\t} else {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t} // BPTC\n\n\n\t\tif (p === RGBA_BPTC_Format) {\n\t\t\textension = extensions.get('EXT_texture_compression_bptc');\n\n\t\t\tif (extension !== null) {\n\t\t\t\tif (p === RGBA_BPTC_Format) return encoding === sRGBEncoding ? extension.COMPRESSED_SRGB_ALPHA_BPTC_UNORM_EXT : extension.COMPRESSED_RGBA_BPTC_UNORM_EXT;\n\t\t\t} else {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t} //\n\n\n\t\tif (p === UnsignedInt248Type) {\n\t\t\tif (isWebGL2) return gl.UNSIGNED_INT_24_8;\n\t\t\textension = extensions.get('WEBGL_depth_texture');\n\n\t\t\tif (extension !== null) {\n\t\t\t\treturn extension.UNSIGNED_INT_24_8_WEBGL;\n\t\t\t} else {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t} // if \"p\" can't be resolved, assume the user defines a WebGL constant as a string (fallback/workaround for packed RGB formats)\n\n\n\t\treturn gl[p] !== undefined ? gl[p] : null;\n\t}\n\n\treturn {\n\t\tconvert: convert\n\t};\n}\n\nclass ArrayCamera extends PerspectiveCamera {\n\tconstructor(array = []) {\n\t\tsuper();\n\t\tthis.isArrayCamera = true;\n\t\tthis.cameras = array;\n\t}\n\n}\n\nclass Group extends Object3D {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.isGroup = true;\n\t\tthis.type = 'Group';\n\t}\n\n}\n\nconst _moveEvent = {\n\ttype: 'move'\n};\n\nclass WebXRController {\n\tconstructor() {\n\t\tthis._targetRay = null;\n\t\tthis._grip = null;\n\t\tthis._hand = null;\n\t}\n\n\tgetHandSpace() {\n\t\tif (this._hand === null) {\n\t\t\tthis._hand = new Group();\n\t\t\tthis._hand.matrixAutoUpdate = false;\n\t\t\tthis._hand.visible = false;\n\t\t\tthis._hand.joints = {};\n\t\t\tthis._hand.inputState = {\n\t\t\t\tpinching: false\n\t\t\t};\n\t\t}\n\n\t\treturn this._hand;\n\t}\n\n\tgetTargetRaySpace() {\n\t\tif (this._targetRay === null) {\n\t\t\tthis._targetRay = new Group();\n\t\t\tthis._targetRay.matrixAutoUpdate = false;\n\t\t\tthis._targetRay.visible = false;\n\t\t\tthis._targetRay.hasLinearVelocity = false;\n\t\t\tthis._targetRay.linearVelocity = new Vector3();\n\t\t\tthis._targetRay.hasAngularVelocity = false;\n\t\t\tthis._targetRay.angularVelocity = new Vector3();\n\t\t}\n\n\t\treturn this._targetRay;\n\t}\n\n\tgetGripSpace() {\n\t\tif (this._grip === null) {\n\t\t\tthis._grip = new Group();\n\t\t\tthis._grip.matrixAutoUpdate = false;\n\t\t\tthis._grip.visible = false;\n\t\t\tthis._grip.hasLinearVelocity = false;\n\t\t\tthis._grip.linearVelocity = new Vector3();\n\t\t\tthis._grip.hasAngularVelocity = false;\n\t\t\tthis._grip.angularVelocity = new Vector3();\n\t\t}\n\n\t\treturn this._grip;\n\t}\n\n\tdispatchEvent(event) {\n\t\tif (this._targetRay !== null) {\n\t\t\tthis._targetRay.dispatchEvent(event);\n\t\t}\n\n\t\tif (this._grip !== null) {\n\t\t\tthis._grip.dispatchEvent(event);\n\t\t}\n\n\t\tif (this._hand !== null) {\n\t\t\tthis._hand.dispatchEvent(event);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tdisconnect(inputSource) {\n\t\tthis.dispatchEvent({\n\t\t\ttype: 'disconnected',\n\t\t\tdata: inputSource\n\t\t});\n\n\t\tif (this._targetRay !== null) {\n\t\t\tthis._targetRay.visible = false;\n\t\t}\n\n\t\tif (this._grip !== null) {\n\t\t\tthis._grip.visible = false;\n\t\t}\n\n\t\tif (this._hand !== null) {\n\t\t\tthis._hand.visible = false;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tupdate(inputSource, frame, referenceSpace) {\n\t\tlet inputPose = null;\n\t\tlet gripPose = null;\n\t\tlet handPose = null;\n\t\tconst targetRay = this._targetRay;\n\t\tconst grip = this._grip;\n\t\tconst hand = this._hand;\n\n\t\tif (inputSource && frame.session.visibilityState !== 'visible-blurred') {\n\t\t\tif (targetRay !== null) {\n\t\t\t\tinputPose = frame.getPose(inputSource.targetRaySpace, referenceSpace);\n\n\t\t\t\tif (inputPose !== null) {\n\t\t\t\t\ttargetRay.matrix.fromArray(inputPose.transform.matrix);\n\t\t\t\t\ttargetRay.matrix.decompose(targetRay.position, targetRay.rotation, targetRay.scale);\n\n\t\t\t\t\tif (inputPose.linearVelocity) {\n\t\t\t\t\t\ttargetRay.hasLinearVelocity = true;\n\t\t\t\t\t\ttargetRay.linearVelocity.copy(inputPose.linearVelocity);\n\t\t\t\t\t} else {\n\t\t\t\t\t\ttargetRay.hasLinearVelocity = false;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (inputPose.angularVelocity) {\n\t\t\t\t\t\ttargetRay.hasAngularVelocity = true;\n\t\t\t\t\t\ttargetRay.angularVelocity.copy(inputPose.angularVelocity);\n\t\t\t\t\t} else {\n\t\t\t\t\t\ttargetRay.hasAngularVelocity = false;\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.dispatchEvent(_moveEvent);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (hand && inputSource.hand) {\n\t\t\t\thandPose = true;\n\n\t\t\t\tfor (const inputjoint of inputSource.hand.values()) {\n\t\t\t\t\t// Update the joints groups with the XRJoint poses\n\t\t\t\t\tconst jointPose = frame.getJointPose(inputjoint, referenceSpace);\n\n\t\t\t\t\tif (hand.joints[inputjoint.jointName] === undefined) {\n\t\t\t\t\t\t// The transform of this joint will be updated with the joint pose on each frame\n\t\t\t\t\t\tconst joint = new Group();\n\t\t\t\t\t\tjoint.matrixAutoUpdate = false;\n\t\t\t\t\t\tjoint.visible = false;\n\t\t\t\t\t\thand.joints[inputjoint.jointName] = joint; // ??\n\n\t\t\t\t\t\thand.add(joint);\n\t\t\t\t\t}\n\n\t\t\t\t\tconst joint = hand.joints[inputjoint.jointName];\n\n\t\t\t\t\tif (jointPose !== null) {\n\t\t\t\t\t\tjoint.matrix.fromArray(jointPose.transform.matrix);\n\t\t\t\t\t\tjoint.matrix.decompose(joint.position, joint.rotation, joint.scale);\n\t\t\t\t\t\tjoint.jointRadius = jointPose.radius;\n\t\t\t\t\t}\n\n\t\t\t\t\tjoint.visible = jointPose !== null;\n\t\t\t\t} // Custom events\n\t\t\t\t// Check pinchz\n\n\n\t\t\t\tconst indexTip = hand.joints['index-finger-tip'];\n\t\t\t\tconst thumbTip = hand.joints['thumb-tip'];\n\t\t\t\tconst distance = indexTip.position.distanceTo(thumbTip.position);\n\t\t\t\tconst distanceToPinch = 0.02;\n\t\t\t\tconst threshold = 0.005;\n\n\t\t\t\tif (hand.inputState.pinching && distance > distanceToPinch + threshold) {\n\t\t\t\t\thand.inputState.pinching = false;\n\t\t\t\t\tthis.dispatchEvent({\n\t\t\t\t\t\ttype: 'pinchend',\n\t\t\t\t\t\thandedness: inputSource.handedness,\n\t\t\t\t\t\ttarget: this\n\t\t\t\t\t});\n\t\t\t\t} else if (!hand.inputState.pinching && distance <= distanceToPinch - threshold) {\n\t\t\t\t\thand.inputState.pinching = true;\n\t\t\t\t\tthis.dispatchEvent({\n\t\t\t\t\t\ttype: 'pinchstart',\n\t\t\t\t\t\thandedness: inputSource.handedness,\n\t\t\t\t\t\ttarget: this\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (grip !== null && inputSource.gripSpace) {\n\t\t\t\t\tgripPose = frame.getPose(inputSource.gripSpace, referenceSpace);\n\n\t\t\t\t\tif (gripPose !== null) {\n\t\t\t\t\t\tgrip.matrix.fromArray(gripPose.transform.matrix);\n\t\t\t\t\t\tgrip.matrix.decompose(grip.position, grip.rotation, grip.scale);\n\n\t\t\t\t\t\tif (gripPose.linearVelocity) {\n\t\t\t\t\t\t\tgrip.hasLinearVelocity = true;\n\t\t\t\t\t\t\tgrip.linearVelocity.copy(gripPose.linearVelocity);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tgrip.hasLinearVelocity = false;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (gripPose.angularVelocity) {\n\t\t\t\t\t\t\tgrip.hasAngularVelocity = true;\n\t\t\t\t\t\t\tgrip.angularVelocity.copy(gripPose.angularVelocity);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tgrip.hasAngularVelocity = false;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (targetRay !== null) {\n\t\t\ttargetRay.visible = inputPose !== null;\n\t\t}\n\n\t\tif (grip !== null) {\n\t\t\tgrip.visible = gripPose !== null;\n\t\t}\n\n\t\tif (hand !== null) {\n\t\t\thand.visible = handPose !== null;\n\t\t}\n\n\t\treturn this;\n\t}\n\n}\n\nclass DepthTexture extends Texture {\n\tconstructor(width, height, type, mapping, wrapS, wrapT, magFilter, minFilter, anisotropy, format) {\n\t\tformat = format !== undefined ? format : DepthFormat;\n\n\t\tif (format !== DepthFormat && format !== DepthStencilFormat) {\n\t\t\tthrow new Error('DepthTexture format must be either THREE.DepthFormat or THREE.DepthStencilFormat');\n\t\t}\n\n\t\tif (type === undefined && format === DepthFormat) type = UnsignedIntType;\n\t\tif (type === undefined && format === DepthStencilFormat) type = UnsignedInt248Type;\n\t\tsuper(null, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy);\n\t\tthis.isDepthTexture = true;\n\t\tthis.image = {\n\t\t\twidth: width,\n\t\t\theight: height\n\t\t};\n\t\tthis.magFilter = magFilter !== undefined ? magFilter : NearestFilter;\n\t\tthis.minFilter = minFilter !== undefined ? minFilter : NearestFilter;\n\t\tthis.flipY = false;\n\t\tthis.generateMipmaps = false;\n\t}\n\n}\n\nclass WebXRManager extends EventDispatcher {\n\tconstructor(renderer, gl) {\n\t\tsuper();\n\t\tconst scope = this;\n\t\tlet session = null;\n\t\tlet framebufferScaleFactor = 1.0;\n\t\tlet referenceSpace = null;\n\t\tlet referenceSpaceType = 'local-floor';\n\t\tlet customReferenceSpace = null;\n\t\tlet pose = null;\n\t\tlet glBinding = null;\n\t\tlet glProjLayer = null;\n\t\tlet glBaseLayer = null;\n\t\tlet xrFrame = null;\n\t\tconst attributes = gl.getContextAttributes();\n\t\tlet initialRenderTarget = null;\n\t\tlet newRenderTarget = null;\n\t\tconst controllers = [];\n\t\tconst inputSourcesMap = new Map(); //\n\n\t\tconst cameraL = new PerspectiveCamera();\n\t\tcameraL.layers.enable(1);\n\t\tcameraL.viewport = new Vector4();\n\t\tconst cameraR = new PerspectiveCamera();\n\t\tcameraR.layers.enable(2);\n\t\tcameraR.viewport = new Vector4();\n\t\tconst cameras = [cameraL, cameraR];\n\t\tconst cameraVR = new ArrayCamera();\n\t\tcameraVR.layers.enable(1);\n\t\tcameraVR.layers.enable(2);\n\t\tlet _currentDepthNear = null;\n\t\tlet _currentDepthFar = null; //\n\n\t\tthis.cameraAutoUpdate = true;\n\t\tthis.enabled = false;\n\t\tthis.isPresenting = false;\n\n\t\tthis.getController = function (index) {\n\t\t\tlet controller = controllers[index];\n\n\t\t\tif (controller === undefined) {\n\t\t\t\tcontroller = new WebXRController();\n\t\t\t\tcontrollers[index] = controller;\n\t\t\t}\n\n\t\t\treturn controller.getTargetRaySpace();\n\t\t};\n\n\t\tthis.getControllerGrip = function (index) {\n\t\t\tlet controller = controllers[index];\n\n\t\t\tif (controller === undefined) {\n\t\t\t\tcontroller = new WebXRController();\n\t\t\t\tcontrollers[index] = controller;\n\t\t\t}\n\n\t\t\treturn controller.getGripSpace();\n\t\t};\n\n\t\tthis.getHand = function (index) {\n\t\t\tlet controller = controllers[index];\n\n\t\t\tif (controller === undefined) {\n\t\t\t\tcontroller = new WebXRController();\n\t\t\t\tcontrollers[index] = controller;\n\t\t\t}\n\n\t\t\treturn controller.getHandSpace();\n\t\t}; //\n\n\n\t\tfunction onSessionEvent(event) {\n\t\t\tconst controller = inputSourcesMap.get(event.inputSource);\n\n\t\t\tif (controller !== undefined) {\n\t\t\t\tcontroller.dispatchEvent({\n\t\t\t\t\ttype: event.type,\n\t\t\t\t\tdata: event.inputSource\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tfunction onSessionEnd() {\n\t\t\tsession.removeEventListener('select', onSessionEvent);\n\t\t\tsession.removeEventListener('selectstart', onSessionEvent);\n\t\t\tsession.removeEventListener('selectend', onSessionEvent);\n\t\t\tsession.removeEventListener('squeeze', onSessionEvent);\n\t\t\tsession.removeEventListener('squeezestart', onSessionEvent);\n\t\t\tsession.removeEventListener('squeezeend', onSessionEvent);\n\t\t\tsession.removeEventListener('end', onSessionEnd);\n\t\t\tsession.removeEventListener('inputsourceschange', onInputSourcesChange);\n\t\t\tinputSourcesMap.forEach(function (controller, inputSource) {\n\t\t\t\tif (controller !== undefined) {\n\t\t\t\t\tcontroller.disconnect(inputSource);\n\t\t\t\t}\n\t\t\t});\n\t\t\tinputSourcesMap.clear();\n\t\t\t_currentDepthNear = null;\n\t\t\t_currentDepthFar = null; // restore framebuffer/rendering state\n\n\t\t\trenderer.setRenderTarget(initialRenderTarget);\n\t\t\tglBaseLayer = null;\n\t\t\tglProjLayer = null;\n\t\t\tglBinding = null;\n\t\t\tsession = null;\n\t\t\tnewRenderTarget = null; //\n\n\t\t\tanimation.stop();\n\t\t\tscope.isPresenting = false;\n\t\t\tscope.dispatchEvent({\n\t\t\t\ttype: 'sessionend'\n\t\t\t});\n\t\t}\n\n\t\tthis.setFramebufferScaleFactor = function (value) {\n\t\t\tframebufferScaleFactor = value;\n\n\t\t\tif (scope.isPresenting === true) {\n\t\t\t\tconsole.warn('THREE.WebXRManager: Cannot change framebuffer scale while presenting.');\n\t\t\t}\n\t\t};\n\n\t\tthis.setReferenceSpaceType = function (value) {\n\t\t\treferenceSpaceType = value;\n\n\t\t\tif (scope.isPresenting === true) {\n\t\t\t\tconsole.warn('THREE.WebXRManager: Cannot change reference space type while presenting.');\n\t\t\t}\n\t\t};\n\n\t\tthis.getReferenceSpace = function () {\n\t\t\treturn customReferenceSpace || referenceSpace;\n\t\t};\n\n\t\tthis.setReferenceSpace = function (space) {\n\t\t\tcustomReferenceSpace = space;\n\t\t};\n\n\t\tthis.getBaseLayer = function () {\n\t\t\treturn glProjLayer !== null ? glProjLayer : glBaseLayer;\n\t\t};\n\n\t\tthis.getBinding = function () {\n\t\t\treturn glBinding;\n\t\t};\n\n\t\tthis.getFrame = function () {\n\t\t\treturn xrFrame;\n\t\t};\n\n\t\tthis.getSession = function () {\n\t\t\treturn session;\n\t\t};\n\n\t\tthis.setSession = async function (value) {\n\t\t\tsession = value;\n\n\t\t\tif (session !== null) {\n\t\t\t\tinitialRenderTarget = renderer.getRenderTarget();\n\t\t\t\tsession.addEventListener('select', onSessionEvent);\n\t\t\t\tsession.addEventListener('selectstart', onSessionEvent);\n\t\t\t\tsession.addEventListener('selectend', onSessionEvent);\n\t\t\t\tsession.addEventListener('squeeze', onSessionEvent);\n\t\t\t\tsession.addEventListener('squeezestart', onSessionEvent);\n\t\t\t\tsession.addEventListener('squeezeend', onSessionEvent);\n\t\t\t\tsession.addEventListener('end', onSessionEnd);\n\t\t\t\tsession.addEventListener('inputsourceschange', onInputSourcesChange);\n\n\t\t\t\tif (attributes.xrCompatible !== true) {\n\t\t\t\t\tawait gl.makeXRCompatible();\n\t\t\t\t}\n\n\t\t\t\tif (session.renderState.layers === undefined || renderer.capabilities.isWebGL2 === false) {\n\t\t\t\t\tconst layerInit = {\n\t\t\t\t\t\tantialias: session.renderState.layers === undefined ? attributes.antialias : true,\n\t\t\t\t\t\talpha: attributes.alpha,\n\t\t\t\t\t\tdepth: attributes.depth,\n\t\t\t\t\t\tstencil: attributes.stencil,\n\t\t\t\t\t\tframebufferScaleFactor: framebufferScaleFactor\n\t\t\t\t\t};\n\t\t\t\t\tglBaseLayer = new XRWebGLLayer(session, gl, layerInit);\n\t\t\t\t\tsession.updateRenderState({\n\t\t\t\t\t\tbaseLayer: glBaseLayer\n\t\t\t\t\t});\n\t\t\t\t\tnewRenderTarget = new WebGLRenderTarget(glBaseLayer.framebufferWidth, glBaseLayer.framebufferHeight, {\n\t\t\t\t\t\tformat: RGBAFormat,\n\t\t\t\t\t\ttype: UnsignedByteType,\n\t\t\t\t\t\tencoding: renderer.outputEncoding\n\t\t\t\t\t});\n\t\t\t\t} else {\n\t\t\t\t\tlet depthFormat = null;\n\t\t\t\t\tlet depthType = null;\n\t\t\t\t\tlet glDepthFormat = null;\n\n\t\t\t\t\tif (attributes.depth) {\n\t\t\t\t\t\tglDepthFormat = attributes.stencil ? gl.DEPTH24_STENCIL8 : gl.DEPTH_COMPONENT24;\n\t\t\t\t\t\tdepthFormat = attributes.stencil ? DepthStencilFormat : DepthFormat;\n\t\t\t\t\t\tdepthType = attributes.stencil ? UnsignedInt248Type : UnsignedIntType;\n\t\t\t\t\t}\n\n\t\t\t\t\tconst projectionlayerInit = {\n\t\t\t\t\t\tcolorFormat: renderer.outputEncoding === sRGBEncoding ? gl.SRGB8_ALPHA8 : gl.RGBA8,\n\t\t\t\t\t\tdepthFormat: glDepthFormat,\n\t\t\t\t\t\tscaleFactor: framebufferScaleFactor\n\t\t\t\t\t};\n\t\t\t\t\tglBinding = new XRWebGLBinding(session, gl);\n\t\t\t\t\tglProjLayer = glBinding.createProjectionLayer(projectionlayerInit);\n\t\t\t\t\tsession.updateRenderState({\n\t\t\t\t\t\tlayers: [glProjLayer]\n\t\t\t\t\t});\n\t\t\t\t\tnewRenderTarget = new WebGLRenderTarget(glProjLayer.textureWidth, glProjLayer.textureHeight, {\n\t\t\t\t\t\tformat: RGBAFormat,\n\t\t\t\t\t\ttype: UnsignedByteType,\n\t\t\t\t\t\tdepthTexture: new DepthTexture(glProjLayer.textureWidth, glProjLayer.textureHeight, depthType, undefined, undefined, undefined, undefined, undefined, undefined, depthFormat),\n\t\t\t\t\t\tstencilBuffer: attributes.stencil,\n\t\t\t\t\t\tencoding: renderer.outputEncoding,\n\t\t\t\t\t\tsamples: attributes.antialias ? 4 : 0\n\t\t\t\t\t});\n\t\t\t\t\tconst renderTargetProperties = renderer.properties.get(newRenderTarget);\n\t\t\t\t\trenderTargetProperties.__ignoreDepthValues = glProjLayer.ignoreDepthValues;\n\t\t\t\t}\n\n\t\t\t\tnewRenderTarget.isXRRenderTarget = true; // TODO Remove this when possible, see #23278\n\t\t\t\t// Set foveation to maximum.\n\n\t\t\t\tthis.setFoveation(1.0);\n\t\t\t\tcustomReferenceSpace = null;\n\t\t\t\treferenceSpace = await session.requestReferenceSpace(referenceSpaceType);\n\t\t\t\tanimation.setContext(session);\n\t\t\t\tanimation.start();\n\t\t\t\tscope.isPresenting = true;\n\t\t\t\tscope.dispatchEvent({\n\t\t\t\t\ttype: 'sessionstart'\n\t\t\t\t});\n\t\t\t}\n\t\t};\n\n\t\tfunction onInputSourcesChange(event) {\n\t\t\tconst inputSources = session.inputSources; // Assign controllers to available inputSources\n\n\t\t\tfor (let i = 0; i < inputSources.length; i++) {\n\t\t\t\tconst index = inputSources[i].handedness === 'right' ? 1 : 0;\n\t\t\t\tinputSourcesMap.set(inputSources[i], controllers[index]);\n\t\t\t} // Notify disconnected\n\n\n\t\t\tfor (let i = 0; i < event.removed.length; i++) {\n\t\t\t\tconst inputSource = event.removed[i];\n\t\t\t\tconst controller = inputSourcesMap.get(inputSource);\n\n\t\t\t\tif (controller) {\n\t\t\t\t\tcontroller.dispatchEvent({\n\t\t\t\t\t\ttype: 'disconnected',\n\t\t\t\t\t\tdata: inputSource\n\t\t\t\t\t});\n\t\t\t\t\tinputSourcesMap.delete(inputSource);\n\t\t\t\t}\n\t\t\t} // Notify connected\n\n\n\t\t\tfor (let i = 0; i < event.added.length; i++) {\n\t\t\t\tconst inputSource = event.added[i];\n\t\t\t\tconst controller = inputSourcesMap.get(inputSource);\n\n\t\t\t\tif (controller) {\n\t\t\t\t\tcontroller.dispatchEvent({\n\t\t\t\t\t\ttype: 'connected',\n\t\t\t\t\t\tdata: inputSource\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t} //\n\n\n\t\tconst cameraLPos = new Vector3();\n\t\tconst cameraRPos = new Vector3();\n\t\t/**\n\t\t * Assumes 2 cameras that are parallel and share an X-axis, and that\n\t\t * the cameras' projection and world matrices have already been set.\n\t\t * And that near and far planes are identical for both cameras.\n\t\t * Visualization of this technique: https://computergraphics.stackexchange.com/a/4765\n\t\t */\n\n\t\tfunction setProjectionFromUnion(camera, cameraL, cameraR) {\n\t\t\tcameraLPos.setFromMatrixPosition(cameraL.matrixWorld);\n\t\t\tcameraRPos.setFromMatrixPosition(cameraR.matrixWorld);\n\t\t\tconst ipd = cameraLPos.distanceTo(cameraRPos);\n\t\t\tconst projL = cameraL.projectionMatrix.elements;\n\t\t\tconst projR = cameraR.projectionMatrix.elements; // VR systems will have identical far and near planes, and\n\t\t\t// most likely identical top and bottom frustum extents.\n\t\t\t// Use the left camera for these values.\n\n\t\t\tconst near = projL[14] / (projL[10] - 1);\n\t\t\tconst far = projL[14] / (projL[10] + 1);\n\t\t\tconst topFov = (projL[9] + 1) / projL[5];\n\t\t\tconst bottomFov = (projL[9] - 1) / projL[5];\n\t\t\tconst leftFov = (projL[8] - 1) / projL[0];\n\t\t\tconst rightFov = (projR[8] + 1) / projR[0];\n\t\t\tconst left = near * leftFov;\n\t\t\tconst right = near * rightFov; // Calculate the new camera's position offset from the\n\t\t\t// left camera. xOffset should be roughly half `ipd`.\n\n\t\t\tconst zOffset = ipd / (-leftFov + rightFov);\n\t\t\tconst xOffset = zOffset * -leftFov; // TODO: Better way to apply this offset?\n\n\t\t\tcameraL.matrixWorld.decompose(camera.position, camera.quaternion, camera.scale);\n\t\t\tcamera.translateX(xOffset);\n\t\t\tcamera.translateZ(zOffset);\n\t\t\tcamera.matrixWorld.compose(camera.position, camera.quaternion, camera.scale);\n\t\t\tcamera.matrixWorldInverse.copy(camera.matrixWorld).invert(); // Find the union of the frustum values of the cameras and scale\n\t\t\t// the values so that the near plane's position does not change in world space,\n\t\t\t// although must now be relative to the new union camera.\n\n\t\t\tconst near2 = near + zOffset;\n\t\t\tconst far2 = far + zOffset;\n\t\t\tconst left2 = left - xOffset;\n\t\t\tconst right2 = right + (ipd - xOffset);\n\t\t\tconst top2 = topFov * far / far2 * near2;\n\t\t\tconst bottom2 = bottomFov * far / far2 * near2;\n\t\t\tcamera.projectionMatrix.makePerspective(left2, right2, top2, bottom2, near2, far2);\n\t\t}\n\n\t\tfunction updateCamera(camera, parent) {\n\t\t\tif (parent === null) {\n\t\t\t\tcamera.matrixWorld.copy(camera.matrix);\n\t\t\t} else {\n\t\t\t\tcamera.matrixWorld.multiplyMatrices(parent.matrixWorld, camera.matrix);\n\t\t\t}\n\n\t\t\tcamera.matrixWorldInverse.copy(camera.matrixWorld).invert();\n\t\t}\n\n\t\tthis.updateCamera = function (camera) {\n\t\t\tif (session === null) return;\n\t\t\tcameraVR.near = cameraR.near = cameraL.near = camera.near;\n\t\t\tcameraVR.far = cameraR.far = cameraL.far = camera.far;\n\n\t\t\tif (_currentDepthNear !== cameraVR.near || _currentDepthFar !== cameraVR.far) {\n\t\t\t\t// Note that the new renderState won't apply until the next frame. See #18320\n\t\t\t\tsession.updateRenderState({\n\t\t\t\t\tdepthNear: cameraVR.near,\n\t\t\t\t\tdepthFar: cameraVR.far\n\t\t\t\t});\n\t\t\t\t_currentDepthNear = cameraVR.near;\n\t\t\t\t_currentDepthFar = cameraVR.far;\n\t\t\t}\n\n\t\t\tconst parent = camera.parent;\n\t\t\tconst cameras = cameraVR.cameras;\n\t\t\tupdateCamera(cameraVR, parent);\n\n\t\t\tfor (let i = 0; i < cameras.length; i++) {\n\t\t\t\tupdateCamera(cameras[i], parent);\n\t\t\t}\n\n\t\t\tcameraVR.matrixWorld.decompose(cameraVR.position, cameraVR.quaternion, cameraVR.scale); // update user camera and its children\n\n\t\t\tcamera.position.copy(cameraVR.position);\n\t\t\tcamera.quaternion.copy(cameraVR.quaternion);\n\t\t\tcamera.scale.copy(cameraVR.scale);\n\t\t\tcamera.matrix.copy(cameraVR.matrix);\n\t\t\tcamera.matrixWorld.copy(cameraVR.matrixWorld);\n\t\t\tconst children = camera.children;\n\n\t\t\tfor (let i = 0, l = children.length; i < l; i++) {\n\t\t\t\tchildren[i].updateMatrixWorld(true);\n\t\t\t} // update projection matrix for proper view frustum culling\n\n\n\t\t\tif (cameras.length === 2) {\n\t\t\t\tsetProjectionFromUnion(cameraVR, cameraL, cameraR);\n\t\t\t} else {\n\t\t\t\t// assume single camera setup (AR)\n\t\t\t\tcameraVR.projectionMatrix.copy(cameraL.projectionMatrix);\n\t\t\t}\n\t\t};\n\n\t\tthis.getCamera = function () {\n\t\t\treturn cameraVR;\n\t\t};\n\n\t\tthis.getFoveation = function () {\n\t\t\tif (glProjLayer !== null) {\n\t\t\t\treturn glProjLayer.fixedFoveation;\n\t\t\t}\n\n\t\t\tif (glBaseLayer !== null) {\n\t\t\t\treturn glBaseLayer.fixedFoveation;\n\t\t\t}\n\n\t\t\treturn undefined;\n\t\t};\n\n\t\tthis.setFoveation = function (foveation) {\n\t\t\t// 0 = no foveation = full resolution\n\t\t\t// 1 = maximum foveation = the edges render at lower resolution\n\t\t\tif (glProjLayer !== null) {\n\t\t\t\tglProjLayer.fixedFoveation = foveation;\n\t\t\t}\n\n\t\t\tif (glBaseLayer !== null && glBaseLayer.fixedFoveation !== undefined) {\n\t\t\t\tglBaseLayer.fixedFoveation = foveation;\n\t\t\t}\n\t\t}; // Animation Loop\n\n\n\t\tlet onAnimationFrameCallback = null;\n\n\t\tfunction onAnimationFrame(time, frame) {\n\t\t\tpose = frame.getViewerPose(customReferenceSpace || referenceSpace);\n\t\t\txrFrame = frame;\n\n\t\t\tif (pose !== null) {\n\t\t\t\tconst views = pose.views;\n\n\t\t\t\tif (glBaseLayer !== null) {\n\t\t\t\t\trenderer.setRenderTargetFramebuffer(newRenderTarget, glBaseLayer.framebuffer);\n\t\t\t\t\trenderer.setRenderTarget(newRenderTarget);\n\t\t\t\t}\n\n\t\t\t\tlet cameraVRNeedsUpdate = false; // check if it's necessary to rebuild cameraVR's camera list\n\n\t\t\t\tif (views.length !== cameraVR.cameras.length) {\n\t\t\t\t\tcameraVR.cameras.length = 0;\n\t\t\t\t\tcameraVRNeedsUpdate = true;\n\t\t\t\t}\n\n\t\t\t\tfor (let i = 0; i < views.length; i++) {\n\t\t\t\t\tconst view = views[i];\n\t\t\t\t\tlet viewport = null;\n\n\t\t\t\t\tif (glBaseLayer !== null) {\n\t\t\t\t\t\tviewport = glBaseLayer.getViewport(view);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tconst glSubImage = glBinding.getViewSubImage(glProjLayer, view);\n\t\t\t\t\t\tviewport = glSubImage.viewport; // For side-by-side projection, we only produce a single texture for both eyes.\n\n\t\t\t\t\t\tif (i === 0) {\n\t\t\t\t\t\t\trenderer.setRenderTargetTextures(newRenderTarget, glSubImage.colorTexture, glProjLayer.ignoreDepthValues ? undefined : glSubImage.depthStencilTexture);\n\t\t\t\t\t\t\trenderer.setRenderTarget(newRenderTarget);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tlet camera = cameras[i];\n\n\t\t\t\t\tif (camera === undefined) {\n\t\t\t\t\t\tcamera = new PerspectiveCamera();\n\t\t\t\t\t\tcamera.layers.enable(i);\n\t\t\t\t\t\tcamera.viewport = new Vector4();\n\t\t\t\t\t\tcameras[i] = camera;\n\t\t\t\t\t}\n\n\t\t\t\t\tcamera.matrix.fromArray(view.transform.matrix);\n\t\t\t\t\tcamera.projectionMatrix.fromArray(view.projectionMatrix);\n\t\t\t\t\tcamera.viewport.set(viewport.x, viewport.y, viewport.width, viewport.height);\n\n\t\t\t\t\tif (i === 0) {\n\t\t\t\t\t\tcameraVR.matrix.copy(camera.matrix);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (cameraVRNeedsUpdate === true) {\n\t\t\t\t\t\tcameraVR.cameras.push(camera);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} //\n\n\n\t\t\tconst inputSources = session.inputSources;\n\n\t\t\tfor (let i = 0; i < controllers.length; i++) {\n\t\t\t\tconst inputSource = inputSources[i];\n\t\t\t\tconst controller = inputSourcesMap.get(inputSource);\n\n\t\t\t\tif (controller !== undefined) {\n\t\t\t\t\tcontroller.update(inputSource, frame, customReferenceSpace || referenceSpace);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (onAnimationFrameCallback) onAnimationFrameCallback(time, frame);\n\t\t\txrFrame = null;\n\t\t}\n\n\t\tconst animation = new WebGLAnimation();\n\t\tanimation.setAnimationLoop(onAnimationFrame);\n\n\t\tthis.setAnimationLoop = function (callback) {\n\t\t\tonAnimationFrameCallback = callback;\n\t\t};\n\n\t\tthis.dispose = function () {};\n\t}\n\n}\n\nfunction WebGLMaterials(renderer, properties) {\n\tfunction refreshFogUniforms(uniforms, fog) {\n\t\tuniforms.fogColor.value.copy(fog.color);\n\n\t\tif (fog.isFog) {\n\t\t\tuniforms.fogNear.value = fog.near;\n\t\t\tuniforms.fogFar.value = fog.far;\n\t\t} else if (fog.isFogExp2) {\n\t\t\tuniforms.fogDensity.value = fog.density;\n\t\t}\n\t}\n\n\tfunction refreshMaterialUniforms(uniforms, material, pixelRatio, height, transmissionRenderTarget) {\n\t\tif (material.isMeshBasicMaterial) {\n\t\t\trefreshUniformsCommon(uniforms, material);\n\t\t} else if (material.isMeshLambertMaterial) {\n\t\t\trefreshUniformsCommon(uniforms, material);\n\t\t} else if (material.isMeshToonMaterial) {\n\t\t\trefreshUniformsCommon(uniforms, material);\n\t\t\trefreshUniformsToon(uniforms, material);\n\t\t} else if (material.isMeshPhongMaterial) {\n\t\t\trefreshUniformsCommon(uniforms, material);\n\t\t\trefreshUniformsPhong(uniforms, material);\n\t\t} else if (material.isMeshStandardMaterial) {\n\t\t\trefreshUniformsCommon(uniforms, material);\n\t\t\trefreshUniformsStandard(uniforms, material);\n\n\t\t\tif (material.isMeshPhysicalMaterial) {\n\t\t\t\trefreshUniformsPhysical(uniforms, material, transmissionRenderTarget);\n\t\t\t}\n\t\t} else if (material.isMeshMatcapMaterial) {\n\t\t\trefreshUniformsCommon(uniforms, material);\n\t\t\trefreshUniformsMatcap(uniforms, material);\n\t\t} else if (material.isMeshDepthMaterial) {\n\t\t\trefreshUniformsCommon(uniforms, material);\n\t\t} else if (material.isMeshDistanceMaterial) {\n\t\t\trefreshUniformsCommon(uniforms, material);\n\t\t\trefreshUniformsDistance(uniforms, material);\n\t\t} else if (material.isMeshNormalMaterial) {\n\t\t\trefreshUniformsCommon(uniforms, material);\n\t\t} else if (material.isLineBasicMaterial) {\n\t\t\trefreshUniformsLine(uniforms, material);\n\n\t\t\tif (material.isLineDashedMaterial) {\n\t\t\t\trefreshUniformsDash(uniforms, material);\n\t\t\t}\n\t\t} else if (material.isPointsMaterial) {\n\t\t\trefreshUniformsPoints(uniforms, material, pixelRatio, height);\n\t\t} else if (material.isSpriteMaterial) {\n\t\t\trefreshUniformsSprites(uniforms, material);\n\t\t} else if (material.isShadowMaterial) {\n\t\t\tuniforms.color.value.copy(material.color);\n\t\t\tuniforms.opacity.value = material.opacity;\n\t\t} else if (material.isShaderMaterial) {\n\t\t\tmaterial.uniformsNeedUpdate = false; // #15581\n\t\t}\n\t}\n\n\tfunction refreshUniformsCommon(uniforms, material) {\n\t\tuniforms.opacity.value = material.opacity;\n\n\t\tif (material.color) {\n\t\t\tuniforms.diffuse.value.copy(material.color);\n\t\t}\n\n\t\tif (material.emissive) {\n\t\t\tuniforms.emissive.value.copy(material.emissive).multiplyScalar(material.emissiveIntensity);\n\t\t}\n\n\t\tif (material.map) {\n\t\t\tuniforms.map.value = material.map;\n\t\t}\n\n\t\tif (material.alphaMap) {\n\t\t\tuniforms.alphaMap.value = material.alphaMap;\n\t\t}\n\n\t\tif (material.bumpMap) {\n\t\t\tuniforms.bumpMap.value = material.bumpMap;\n\t\t\tuniforms.bumpScale.value = material.bumpScale;\n\t\t\tif (material.side === BackSide) uniforms.bumpScale.value *= -1;\n\t\t}\n\n\t\tif (material.displacementMap) {\n\t\t\tuniforms.displacementMap.value = material.displacementMap;\n\t\t\tuniforms.displacementScale.value = material.displacementScale;\n\t\t\tuniforms.displacementBias.value = material.displacementBias;\n\t\t}\n\n\t\tif (material.emissiveMap) {\n\t\t\tuniforms.emissiveMap.value = material.emissiveMap;\n\t\t}\n\n\t\tif (material.normalMap) {\n\t\t\tuniforms.normalMap.value = material.normalMap;\n\t\t\tuniforms.normalScale.value.copy(material.normalScale);\n\t\t\tif (material.side === BackSide) uniforms.normalScale.value.negate();\n\t\t}\n\n\t\tif (material.specularMap) {\n\t\t\tuniforms.specularMap.value = material.specularMap;\n\t\t}\n\n\t\tif (material.alphaTest > 0) {\n\t\t\tuniforms.alphaTest.value = material.alphaTest;\n\t\t}\n\n\t\tconst envMap = properties.get(material).envMap;\n\n\t\tif (envMap) {\n\t\t\tuniforms.envMap.value = envMap;\n\t\t\tuniforms.flipEnvMap.value = envMap.isCubeTexture && envMap.isRenderTargetTexture === false ? -1 : 1;\n\t\t\tuniforms.reflectivity.value = material.reflectivity;\n\t\t\tuniforms.ior.value = material.ior;\n\t\t\tuniforms.refractionRatio.value = material.refractionRatio;\n\t\t}\n\n\t\tif (material.lightMap) {\n\t\t\tuniforms.lightMap.value = material.lightMap; // artist-friendly light intensity scaling factor\n\n\t\t\tconst scaleFactor = renderer.physicallyCorrectLights !== true ? Math.PI : 1;\n\t\t\tuniforms.lightMapIntensity.value = material.lightMapIntensity * scaleFactor;\n\t\t}\n\n\t\tif (material.aoMap) {\n\t\t\tuniforms.aoMap.value = material.aoMap;\n\t\t\tuniforms.aoMapIntensity.value = material.aoMapIntensity;\n\t\t} // uv repeat and offset setting priorities\n\t\t// 1. color map\n\t\t// 2. specular map\n\t\t// 3. displacementMap map\n\t\t// 4. normal map\n\t\t// 5. bump map\n\t\t// 6. roughnessMap map\n\t\t// 7. metalnessMap map\n\t\t// 8. alphaMap map\n\t\t// 9. emissiveMap map\n\t\t// 10. clearcoat map\n\t\t// 11. clearcoat normal map\n\t\t// 12. clearcoat roughnessMap map\n\t\t// 13. iridescence map\n\t\t// 14. iridescence thickness map\n\t\t// 15. specular intensity map\n\t\t// 16. specular tint map\n\t\t// 17. transmission map\n\t\t// 18. thickness map\n\n\n\t\tlet uvScaleMap;\n\n\t\tif (material.map) {\n\t\t\tuvScaleMap = material.map;\n\t\t} else if (material.specularMap) {\n\t\t\tuvScaleMap = material.specularMap;\n\t\t} else if (material.displacementMap) {\n\t\t\tuvScaleMap = material.displacementMap;\n\t\t} else if (material.normalMap) {\n\t\t\tuvScaleMap = material.normalMap;\n\t\t} else if (material.bumpMap) {\n\t\t\tuvScaleMap = material.bumpMap;\n\t\t} else if (material.roughnessMap) {\n\t\t\tuvScaleMap = material.roughnessMap;\n\t\t} else if (material.metalnessMap) {\n\t\t\tuvScaleMap = material.metalnessMap;\n\t\t} else if (material.alphaMap) {\n\t\t\tuvScaleMap = material.alphaMap;\n\t\t} else if (material.emissiveMap) {\n\t\t\tuvScaleMap = material.emissiveMap;\n\t\t} else if (material.clearcoatMap) {\n\t\t\tuvScaleMap = material.clearcoatMap;\n\t\t} else if (material.clearcoatNormalMap) {\n\t\t\tuvScaleMap = material.clearcoatNormalMap;\n\t\t} else if (material.clearcoatRoughnessMap) {\n\t\t\tuvScaleMap = material.clearcoatRoughnessMap;\n\t\t} else if (material.iridescenceMap) {\n\t\t\tuvScaleMap = material.iridescenceMap;\n\t\t} else if (material.iridescenceThicknessMap) {\n\t\t\tuvScaleMap = material.iridescenceThicknessMap;\n\t\t} else if (material.specularIntensityMap) {\n\t\t\tuvScaleMap = material.specularIntensityMap;\n\t\t} else if (material.specularColorMap) {\n\t\t\tuvScaleMap = material.specularColorMap;\n\t\t} else if (material.transmissionMap) {\n\t\t\tuvScaleMap = material.transmissionMap;\n\t\t} else if (material.thicknessMap) {\n\t\t\tuvScaleMap = material.thicknessMap;\n\t\t} else if (material.sheenColorMap) {\n\t\t\tuvScaleMap = material.sheenColorMap;\n\t\t} else if (material.sheenRoughnessMap) {\n\t\t\tuvScaleMap = material.sheenRoughnessMap;\n\t\t}\n\n\t\tif (uvScaleMap !== undefined) {\n\t\t\t// backwards compatibility\n\t\t\tif (uvScaleMap.isWebGLRenderTarget) {\n\t\t\t\tuvScaleMap = uvScaleMap.texture;\n\t\t\t}\n\n\t\t\tif (uvScaleMap.matrixAutoUpdate === true) {\n\t\t\t\tuvScaleMap.updateMatrix();\n\t\t\t}\n\n\t\t\tuniforms.uvTransform.value.copy(uvScaleMap.matrix);\n\t\t} // uv repeat and offset setting priorities for uv2\n\t\t// 1. ao map\n\t\t// 2. light map\n\n\n\t\tlet uv2ScaleMap;\n\n\t\tif (material.aoMap) {\n\t\t\tuv2ScaleMap = material.aoMap;\n\t\t} else if (material.lightMap) {\n\t\t\tuv2ScaleMap = material.lightMap;\n\t\t}\n\n\t\tif (uv2ScaleMap !== undefined) {\n\t\t\t// backwards compatibility\n\t\t\tif (uv2ScaleMap.isWebGLRenderTarget) {\n\t\t\t\tuv2ScaleMap = uv2ScaleMap.texture;\n\t\t\t}\n\n\t\t\tif (uv2ScaleMap.matrixAutoUpdate === true) {\n\t\t\t\tuv2ScaleMap.updateMatrix();\n\t\t\t}\n\n\t\t\tuniforms.uv2Transform.value.copy(uv2ScaleMap.matrix);\n\t\t}\n\t}\n\n\tfunction refreshUniformsLine(uniforms, material) {\n\t\tuniforms.diffuse.value.copy(material.color);\n\t\tuniforms.opacity.value = material.opacity;\n\t}\n\n\tfunction refreshUniformsDash(uniforms, material) {\n\t\tuniforms.dashSize.value = material.dashSize;\n\t\tuniforms.totalSize.value = material.dashSize + material.gapSize;\n\t\tuniforms.scale.value = material.scale;\n\t}\n\n\tfunction refreshUniformsPoints(uniforms, material, pixelRatio, height) {\n\t\tuniforms.diffuse.value.copy(material.color);\n\t\tuniforms.opacity.value = material.opacity;\n\t\tuniforms.size.value = material.size * pixelRatio;\n\t\tuniforms.scale.value = height * 0.5;\n\n\t\tif (material.map) {\n\t\t\tuniforms.map.value = material.map;\n\t\t}\n\n\t\tif (material.alphaMap) {\n\t\t\tuniforms.alphaMap.value = material.alphaMap;\n\t\t}\n\n\t\tif (material.alphaTest > 0) {\n\t\t\tuniforms.alphaTest.value = material.alphaTest;\n\t\t} // uv repeat and offset setting priorities\n\t\t// 1. color map\n\t\t// 2. alpha map\n\n\n\t\tlet uvScaleMap;\n\n\t\tif (material.map) {\n\t\t\tuvScaleMap = material.map;\n\t\t} else if (material.alphaMap) {\n\t\t\tuvScaleMap = material.alphaMap;\n\t\t}\n\n\t\tif (uvScaleMap !== undefined) {\n\t\t\tif (uvScaleMap.matrixAutoUpdate === true) {\n\t\t\t\tuvScaleMap.updateMatrix();\n\t\t\t}\n\n\t\t\tuniforms.uvTransform.value.copy(uvScaleMap.matrix);\n\t\t}\n\t}\n\n\tfunction refreshUniformsSprites(uniforms, material) {\n\t\tuniforms.diffuse.value.copy(material.color);\n\t\tuniforms.opacity.value = material.opacity;\n\t\tuniforms.rotation.value = material.rotation;\n\n\t\tif (material.map) {\n\t\t\tuniforms.map.value = material.map;\n\t\t}\n\n\t\tif (material.alphaMap) {\n\t\t\tuniforms.alphaMap.value = material.alphaMap;\n\t\t}\n\n\t\tif (material.alphaTest > 0) {\n\t\t\tuniforms.alphaTest.value = material.alphaTest;\n\t\t} // uv repeat and offset setting priorities\n\t\t// 1. color map\n\t\t// 2. alpha map\n\n\n\t\tlet uvScaleMap;\n\n\t\tif (material.map) {\n\t\t\tuvScaleMap = material.map;\n\t\t} else if (material.alphaMap) {\n\t\t\tuvScaleMap = material.alphaMap;\n\t\t}\n\n\t\tif (uvScaleMap !== undefined) {\n\t\t\tif (uvScaleMap.matrixAutoUpdate === true) {\n\t\t\t\tuvScaleMap.updateMatrix();\n\t\t\t}\n\n\t\t\tuniforms.uvTransform.value.copy(uvScaleMap.matrix);\n\t\t}\n\t}\n\n\tfunction refreshUniformsPhong(uniforms, material) {\n\t\tuniforms.specular.value.copy(material.specular);\n\t\tuniforms.shininess.value = Math.max(material.shininess, 1e-4); // to prevent pow( 0.0, 0.0 )\n\t}\n\n\tfunction refreshUniformsToon(uniforms, material) {\n\t\tif (material.gradientMap) {\n\t\t\tuniforms.gradientMap.value = material.gradientMap;\n\t\t}\n\t}\n\n\tfunction refreshUniformsStandard(uniforms, material) {\n\t\tuniforms.roughness.value = material.roughness;\n\t\tuniforms.metalness.value = material.metalness;\n\n\t\tif (material.roughnessMap) {\n\t\t\tuniforms.roughnessMap.value = material.roughnessMap;\n\t\t}\n\n\t\tif (material.metalnessMap) {\n\t\t\tuniforms.metalnessMap.value = material.metalnessMap;\n\t\t}\n\n\t\tconst envMap = properties.get(material).envMap;\n\n\t\tif (envMap) {\n\t\t\t//uniforms.envMap.value = material.envMap; // part of uniforms common\n\t\t\tuniforms.envMapIntensity.value = material.envMapIntensity;\n\t\t}\n\t}\n\n\tfunction refreshUniformsPhysical(uniforms, material, transmissionRenderTarget) {\n\t\tuniforms.ior.value = material.ior; // also part of uniforms common\n\n\t\tif (material.sheen > 0) {\n\t\t\tuniforms.sheenColor.value.copy(material.sheenColor).multiplyScalar(material.sheen);\n\t\t\tuniforms.sheenRoughness.value = material.sheenRoughness;\n\n\t\t\tif (material.sheenColorMap) {\n\t\t\t\tuniforms.sheenColorMap.value = material.sheenColorMap;\n\t\t\t}\n\n\t\t\tif (material.sheenRoughnessMap) {\n\t\t\t\tuniforms.sheenRoughnessMap.value = material.sheenRoughnessMap;\n\t\t\t}\n\t\t}\n\n\t\tif (material.clearcoat > 0) {\n\t\t\tuniforms.clearcoat.value = material.clearcoat;\n\t\t\tuniforms.clearcoatRoughness.value = material.clearcoatRoughness;\n\n\t\t\tif (material.clearcoatMap) {\n\t\t\t\tuniforms.clearcoatMap.value = material.clearcoatMap;\n\t\t\t}\n\n\t\t\tif (material.clearcoatRoughnessMap) {\n\t\t\t\tuniforms.clearcoatRoughnessMap.value = material.clearcoatRoughnessMap;\n\t\t\t}\n\n\t\t\tif (material.clearcoatNormalMap) {\n\t\t\t\tuniforms.clearcoatNormalScale.value.copy(material.clearcoatNormalScale);\n\t\t\t\tuniforms.clearcoatNormalMap.value = material.clearcoatNormalMap;\n\n\t\t\t\tif (material.side === BackSide) {\n\t\t\t\t\tuniforms.clearcoatNormalScale.value.negate();\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (material.iridescence > 0) {\n\t\t\tuniforms.iridescence.value = material.iridescence;\n\t\t\tuniforms.iridescenceIOR.value = material.iridescenceIOR;\n\t\t\tuniforms.iridescenceThicknessMinimum.value = material.iridescenceThicknessRange[0];\n\t\t\tuniforms.iridescenceThicknessMaximum.value = material.iridescenceThicknessRange[1];\n\n\t\t\tif (material.iridescenceMap) {\n\t\t\t\tuniforms.iridescenceMap.value = material.iridescenceMap;\n\t\t\t}\n\n\t\t\tif (material.iridescenceThicknessMap) {\n\t\t\t\tuniforms.iridescenceThicknessMap.value = material.iridescenceThicknessMap;\n\t\t\t}\n\t\t}\n\n\t\tif (material.transmission > 0) {\n\t\t\tuniforms.transmission.value = material.transmission;\n\t\t\tuniforms.transmissionSamplerMap.value = transmissionRenderTarget.texture;\n\t\t\tuniforms.transmissionSamplerSize.value.set(transmissionRenderTarget.width, transmissionRenderTarget.height);\n\n\t\t\tif (material.transmissionMap) {\n\t\t\t\tuniforms.transmissionMap.value = material.transmissionMap;\n\t\t\t}\n\n\t\t\tuniforms.thickness.value = material.thickness;\n\n\t\t\tif (material.thicknessMap) {\n\t\t\t\tuniforms.thicknessMap.value = material.thicknessMap;\n\t\t\t}\n\n\t\t\tuniforms.attenuationDistance.value = material.attenuationDistance;\n\t\t\tuniforms.attenuationColor.value.copy(material.attenuationColor);\n\t\t}\n\n\t\tuniforms.specularIntensity.value = material.specularIntensity;\n\t\tuniforms.specularColor.value.copy(material.specularColor);\n\n\t\tif (material.specularIntensityMap) {\n\t\t\tuniforms.specularIntensityMap.value = material.specularIntensityMap;\n\t\t}\n\n\t\tif (material.specularColorMap) {\n\t\t\tuniforms.specularColorMap.value = material.specularColorMap;\n\t\t}\n\t}\n\n\tfunction refreshUniformsMatcap(uniforms, material) {\n\t\tif (material.matcap) {\n\t\t\tuniforms.matcap.value = material.matcap;\n\t\t}\n\t}\n\n\tfunction refreshUniformsDistance(uniforms, material) {\n\t\tuniforms.referencePosition.value.copy(material.referencePosition);\n\t\tuniforms.nearDistance.value = material.nearDistance;\n\t\tuniforms.farDistance.value = material.farDistance;\n\t}\n\n\treturn {\n\t\trefreshFogUniforms: refreshFogUniforms,\n\t\trefreshMaterialUniforms: refreshMaterialUniforms\n\t};\n}\n\nfunction createCanvasElement() {\n\tconst canvas = createElementNS('canvas');\n\tcanvas.style.display = 'block';\n\treturn canvas;\n}\n\nfunction WebGLRenderer(parameters = {}) {\n\tthis.isWebGLRenderer = true;\n\n\tconst _canvas = parameters.canvas !== undefined ? parameters.canvas : createCanvasElement(),\n\t\t\t\t_context = parameters.context !== undefined ? parameters.context : null,\n\t\t\t\t_depth = parameters.depth !== undefined ? parameters.depth : true,\n\t\t\t\t_stencil = parameters.stencil !== undefined ? parameters.stencil : true,\n\t\t\t\t_antialias = parameters.antialias !== undefined ? parameters.antialias : false,\n\t\t\t\t_premultipliedAlpha = parameters.premultipliedAlpha !== undefined ? parameters.premultipliedAlpha : true,\n\t\t\t\t_preserveDrawingBuffer = parameters.preserveDrawingBuffer !== undefined ? parameters.preserveDrawingBuffer : false,\n\t\t\t\t_powerPreference = parameters.powerPreference !== undefined ? parameters.powerPreference : 'default',\n\t\t\t\t_failIfMajorPerformanceCaveat = parameters.failIfMajorPerformanceCaveat !== undefined ? parameters.failIfMajorPerformanceCaveat : false;\n\n\tlet _alpha;\n\n\tif (_context !== null) {\n\t\t_alpha = _context.getContextAttributes().alpha;\n\t} else {\n\t\t_alpha = parameters.alpha !== undefined ? parameters.alpha : false;\n\t}\n\n\tlet currentRenderList = null;\n\tlet currentRenderState = null; // render() can be called from within a callback triggered by another render.\n\t// We track this so that the nested render call gets its list and state isolated from the parent render call.\n\n\tconst renderListStack = [];\n\tconst renderStateStack = []; // public properties\n\n\tthis.domElement = _canvas; // Debug configuration container\n\n\tthis.debug = {\n\t\t/**\n\t\t * Enables error checking and reporting when shader programs are being compiled\n\t\t * @type {boolean}\n\t\t */\n\t\tcheckShaderErrors: true\n\t}; // clearing\n\n\tthis.autoClear = true;\n\tthis.autoClearColor = true;\n\tthis.autoClearDepth = true;\n\tthis.autoClearStencil = true; // scene graph\n\n\tthis.sortObjects = true; // user-defined clipping\n\n\tthis.clippingPlanes = [];\n\tthis.localClippingEnabled = false; // physically based shading\n\n\tthis.outputEncoding = LinearEncoding; // physical lights\n\n\tthis.physicallyCorrectLights = false; // tone mapping\n\n\tthis.toneMapping = NoToneMapping;\n\tthis.toneMappingExposure = 1.0; //\n\n\tObject.defineProperties(this, {\n\t\t// @deprecated since r136, 0e21088102b4de7e0a0a33140620b7a3424b9e6d\n\t\tgammaFactor: {\n\t\t\tget: function () {\n\t\t\t\tconsole.warn('THREE.WebGLRenderer: .gammaFactor has been removed.');\n\t\t\t\treturn 2;\n\t\t\t},\n\t\t\tset: function () {\n\t\t\t\tconsole.warn('THREE.WebGLRenderer: .gammaFactor has been removed.');\n\t\t\t}\n\t\t}\n\t}); // internal properties\n\n\tconst _this = this;\n\n\tlet _isContextLost = false; // internal state cache\n\n\tlet _currentActiveCubeFace = 0;\n\tlet _currentActiveMipmapLevel = 0;\n\tlet _currentRenderTarget = null;\n\n\tlet _currentMaterialId = -1;\n\n\tlet _currentCamera = null;\n\n\tconst _currentViewport = new Vector4();\n\n\tconst _currentScissor = new Vector4();\n\n\tlet _currentScissorTest = null; //\n\n\tlet _width = _canvas.width;\n\tlet _height = _canvas.height;\n\tlet _pixelRatio = 1;\n\tlet _opaqueSort = null;\n\tlet _transparentSort = null;\n\n\tconst _viewport = new Vector4(0, 0, _width, _height);\n\n\tconst _scissor = new Vector4(0, 0, _width, _height);\n\n\tlet _scissorTest = false; // frustum\n\n\tconst _frustum = new Frustum(); // clipping\n\n\n\tlet _clippingEnabled = false;\n\tlet _localClippingEnabled = false; // transmission\n\n\tlet _transmissionRenderTarget = null; // camera matrices cache\n\n\tconst _projScreenMatrix = new Matrix4();\n\n\tconst _vector2 = new Vector2();\n\n\tconst _vector3 = new Vector3();\n\n\tconst _emptyScene = {\n\t\tbackground: null,\n\t\tfog: null,\n\t\tenvironment: null,\n\t\toverrideMaterial: null,\n\t\tisScene: true\n\t};\n\n\tfunction getTargetPixelRatio() {\n\t\treturn _currentRenderTarget === null ? _pixelRatio : 1;\n\t} // initialize\n\n\n\tlet _gl = _context;\n\n\tfunction getContext(contextNames, contextAttributes) {\n\t\tfor (let i = 0; i < contextNames.length; i++) {\n\t\t\tconst contextName = contextNames[i];\n\n\t\t\tconst context = _canvas.getContext(contextName, contextAttributes);\n\n\t\t\tif (context !== null) return context;\n\t\t}\n\n\t\treturn null;\n\t}\n\n\ttry {\n\t\tconst contextAttributes = {\n\t\t\talpha: true,\n\t\t\tdepth: _depth,\n\t\t\tstencil: _stencil,\n\t\t\tantialias: _antialias,\n\t\t\tpremultipliedAlpha: _premultipliedAlpha,\n\t\t\tpreserveDrawingBuffer: _preserveDrawingBuffer,\n\t\t\tpowerPreference: _powerPreference,\n\t\t\tfailIfMajorPerformanceCaveat: _failIfMajorPerformanceCaveat\n\t\t}; // OffscreenCanvas does not have setAttribute, see #22811\n\n\t\tif ('setAttribute' in _canvas) _canvas.setAttribute('data-engine', `three.js r${REVISION}`); // event listeners must be registered before WebGL context is created, see #12753\n\n\t\t_canvas.addEventListener('webglcontextlost', onContextLost, false);\n\n\t\t_canvas.addEventListener('webglcontextrestored', onContextRestore, false);\n\n\t\t_canvas.addEventListener('webglcontextcreationerror', onContextCreationError, false);\n\n\t\tif (_gl === null) {\n\t\t\tconst contextNames = ['webgl2', 'webgl', 'experimental-webgl'];\n\n\t\t\tif (_this.isWebGL1Renderer === true) {\n\t\t\t\tcontextNames.shift();\n\t\t\t}\n\n\t\t\t_gl = getContext(contextNames, contextAttributes);\n\n\t\t\tif (_gl === null) {\n\t\t\t\tif (getContext(contextNames)) {\n\t\t\t\t\tthrow new Error('Error creating WebGL context with your selected attributes.');\n\t\t\t\t} else {\n\t\t\t\t\tthrow new Error('Error creating WebGL context.');\n\t\t\t\t}\n\t\t\t}\n\t\t} // Some experimental-webgl implementations do not have getShaderPrecisionFormat\n\n\n\t\tif (_gl.getShaderPrecisionFormat === undefined) {\n\t\t\t_gl.getShaderPrecisionFormat = function () {\n\t\t\t\treturn {\n\t\t\t\t\t'rangeMin': 1,\n\t\t\t\t\t'rangeMax': 1,\n\t\t\t\t\t'precision': 1\n\t\t\t\t};\n\t\t\t};\n\t\t}\n\t} catch (error) {\n\t\tconsole.error('THREE.WebGLRenderer: ' + error.message);\n\t\tthrow error;\n\t}\n\n\tlet extensions, capabilities, state, info;\n\tlet properties, textures, cubemaps, cubeuvmaps, attributes, geometries, objects;\n\tlet programCache, materials, renderLists, renderStates, clipping, shadowMap;\n\tlet background, morphtargets, bufferRenderer, indexedBufferRenderer;\n\tlet utils, bindingStates;\n\n\tfunction initGLContext() {\n\t\textensions = new WebGLExtensions(_gl);\n\t\tcapabilities = new WebGLCapabilities(_gl, extensions, parameters);\n\t\textensions.init(capabilities);\n\t\tutils = new WebGLUtils(_gl, extensions, capabilities);\n\t\tstate = new WebGLState(_gl, extensions, capabilities);\n\t\tinfo = new WebGLInfo(_gl);\n\t\tproperties = new WebGLProperties();\n\t\ttextures = new WebGLTextures(_gl, extensions, state, properties, capabilities, utils, info);\n\t\tcubemaps = new WebGLCubeMaps(_this);\n\t\tcubeuvmaps = new WebGLCubeUVMaps(_this);\n\t\tattributes = new WebGLAttributes(_gl, capabilities);\n\t\tbindingStates = new WebGLBindingStates(_gl, extensions, attributes, capabilities);\n\t\tgeometries = new WebGLGeometries(_gl, attributes, info, bindingStates);\n\t\tobjects = new WebGLObjects(_gl, geometries, attributes, info);\n\t\tmorphtargets = new WebGLMorphtargets(_gl, capabilities, textures);\n\t\tclipping = new WebGLClipping(properties);\n\t\tprogramCache = new WebGLPrograms(_this, cubemaps, cubeuvmaps, extensions, capabilities, bindingStates, clipping);\n\t\tmaterials = new WebGLMaterials(_this, properties);\n\t\trenderLists = new WebGLRenderLists();\n\t\trenderStates = new WebGLRenderStates(extensions, capabilities);\n\t\tbackground = new WebGLBackground(_this, cubemaps, state, objects, _alpha, _premultipliedAlpha);\n\t\tshadowMap = new WebGLShadowMap(_this, objects, capabilities);\n\t\tbufferRenderer = new WebGLBufferRenderer(_gl, extensions, info, capabilities);\n\t\tindexedBufferRenderer = new WebGLIndexedBufferRenderer(_gl, extensions, info, capabilities);\n\t\tinfo.programs = programCache.programs;\n\t\t_this.capabilities = capabilities;\n\t\t_this.extensions = extensions;\n\t\t_this.properties = properties;\n\t\t_this.renderLists = renderLists;\n\t\t_this.shadowMap = shadowMap;\n\t\t_this.state = state;\n\t\t_this.info = info;\n\t}\n\n\tinitGLContext(); // xr\n\n\tconst xr = new WebXRManager(_this, _gl);\n\tthis.xr = xr; // API\n\n\tthis.getContext = function () {\n\t\treturn _gl;\n\t};\n\n\tthis.getContextAttributes = function () {\n\t\treturn _gl.getContextAttributes();\n\t};\n\n\tthis.forceContextLoss = function () {\n\t\tconst extension = extensions.get('WEBGL_lose_context');\n\t\tif (extension) extension.loseContext();\n\t};\n\n\tthis.forceContextRestore = function () {\n\t\tconst extension = extensions.get('WEBGL_lose_context');\n\t\tif (extension) extension.restoreContext();\n\t};\n\n\tthis.getPixelRatio = function () {\n\t\treturn _pixelRatio;\n\t};\n\n\tthis.setPixelRatio = function (value) {\n\t\tif (value === undefined) return;\n\t\t_pixelRatio = value;\n\t\tthis.setSize(_width, _height, false);\n\t};\n\n\tthis.getSize = function (target) {\n\t\treturn target.set(_width, _height);\n\t};\n\n\tthis.setSize = function (width, height, updateStyle) {\n\t\tif (xr.isPresenting) {\n\t\t\tconsole.warn('THREE.WebGLRenderer: Can\\'t change size while VR device is presenting.');\n\t\t\treturn;\n\t\t}\n\n\t\t_width = width;\n\t\t_height = height;\n\t\t_canvas.width = Math.floor(width * _pixelRatio);\n\t\t_canvas.height = Math.floor(height * _pixelRatio);\n\n\t\tif (updateStyle !== false) {\n\t\t\t_canvas.style.width = width + 'px';\n\t\t\t_canvas.style.height = height + 'px';\n\t\t}\n\n\t\tthis.setViewport(0, 0, width, height);\n\t};\n\n\tthis.getDrawingBufferSize = function (target) {\n\t\treturn target.set(_width * _pixelRatio, _height * _pixelRatio).floor();\n\t};\n\n\tthis.setDrawingBufferSize = function (width, height, pixelRatio) {\n\t\t_width = width;\n\t\t_height = height;\n\t\t_pixelRatio = pixelRatio;\n\t\t_canvas.width = Math.floor(width * pixelRatio);\n\t\t_canvas.height = Math.floor(height * pixelRatio);\n\t\tthis.setViewport(0, 0, width, height);\n\t};\n\n\tthis.getCurrentViewport = function (target) {\n\t\treturn target.copy(_currentViewport);\n\t};\n\n\tthis.getViewport = function (target) {\n\t\treturn target.copy(_viewport);\n\t};\n\n\tthis.setViewport = function (x, y, width, height) {\n\t\tif (x.isVector4) {\n\t\t\t_viewport.set(x.x, x.y, x.z, x.w);\n\t\t} else {\n\t\t\t_viewport.set(x, y, width, height);\n\t\t}\n\n\t\tstate.viewport(_currentViewport.copy(_viewport).multiplyScalar(_pixelRatio).floor());\n\t};\n\n\tthis.getScissor = function (target) {\n\t\treturn target.copy(_scissor);\n\t};\n\n\tthis.setScissor = function (x, y, width, height) {\n\t\tif (x.isVector4) {\n\t\t\t_scissor.set(x.x, x.y, x.z, x.w);\n\t\t} else {\n\t\t\t_scissor.set(x, y, width, height);\n\t\t}\n\n\t\tstate.scissor(_currentScissor.copy(_scissor).multiplyScalar(_pixelRatio).floor());\n\t};\n\n\tthis.getScissorTest = function () {\n\t\treturn _scissorTest;\n\t};\n\n\tthis.setScissorTest = function (boolean) {\n\t\tstate.setScissorTest(_scissorTest = boolean);\n\t};\n\n\tthis.setOpaqueSort = function (method) {\n\t\t_opaqueSort = method;\n\t};\n\n\tthis.setTransparentSort = function (method) {\n\t\t_transparentSort = method;\n\t}; // Clearing\n\n\n\tthis.getClearColor = function (target) {\n\t\treturn target.copy(background.getClearColor());\n\t};\n\n\tthis.setClearColor = function () {\n\t\tbackground.setClearColor.apply(background, arguments);\n\t};\n\n\tthis.getClearAlpha = function () {\n\t\treturn background.getClearAlpha();\n\t};\n\n\tthis.setClearAlpha = function () {\n\t\tbackground.setClearAlpha.apply(background, arguments);\n\t};\n\n\tthis.clear = function (color = true, depth = true, stencil = true) {\n\t\tlet bits = 0;\n\t\tif (color) bits |= _gl.COLOR_BUFFER_BIT;\n\t\tif (depth) bits |= _gl.DEPTH_BUFFER_BIT;\n\t\tif (stencil) bits |= _gl.STENCIL_BUFFER_BIT;\n\n\t\t_gl.clear(bits);\n\t};\n\n\tthis.clearColor = function () {\n\t\tthis.clear(true, false, false);\n\t};\n\n\tthis.clearDepth = function () {\n\t\tthis.clear(false, true, false);\n\t};\n\n\tthis.clearStencil = function () {\n\t\tthis.clear(false, false, true);\n\t}; //\n\n\n\tthis.dispose = function () {\n\t\t_canvas.removeEventListener('webglcontextlost', onContextLost, false);\n\n\t\t_canvas.removeEventListener('webglcontextrestored', onContextRestore, false);\n\n\t\t_canvas.removeEventListener('webglcontextcreationerror', onContextCreationError, false);\n\n\t\trenderLists.dispose();\n\t\trenderStates.dispose();\n\t\tproperties.dispose();\n\t\tcubemaps.dispose();\n\t\tcubeuvmaps.dispose();\n\t\tobjects.dispose();\n\t\tbindingStates.dispose();\n\t\tprogramCache.dispose();\n\t\txr.dispose();\n\t\txr.removeEventListener('sessionstart', onXRSessionStart);\n\t\txr.removeEventListener('sessionend', onXRSessionEnd);\n\n\t\tif (_transmissionRenderTarget) {\n\t\t\t_transmissionRenderTarget.dispose();\n\n\t\t\t_transmissionRenderTarget = null;\n\t\t}\n\n\t\tanimation.stop();\n\t}; // Events\n\n\n\tfunction onContextLost(event) {\n\t\tevent.preventDefault();\n\t\tconsole.log('THREE.WebGLRenderer: Context Lost.');\n\t\t_isContextLost = true;\n\t}\n\n\tfunction\n\t\t/* event */\n\tonContextRestore() {\n\t\tconsole.log('THREE.WebGLRenderer: Context Restored.');\n\t\t_isContextLost = false;\n\t\tconst infoAutoReset = info.autoReset;\n\t\tconst shadowMapEnabled = shadowMap.enabled;\n\t\tconst shadowMapAutoUpdate = shadowMap.autoUpdate;\n\t\tconst shadowMapNeedsUpdate = shadowMap.needsUpdate;\n\t\tconst shadowMapType = shadowMap.type;\n\t\tinitGLContext();\n\t\tinfo.autoReset = infoAutoReset;\n\t\tshadowMap.enabled = shadowMapEnabled;\n\t\tshadowMap.autoUpdate = shadowMapAutoUpdate;\n\t\tshadowMap.needsUpdate = shadowMapNeedsUpdate;\n\t\tshadowMap.type = shadowMapType;\n\t}\n\n\tfunction onContextCreationError(event) {\n\t\tconsole.error('THREE.WebGLRenderer: A WebGL context could not be created. Reason: ', event.statusMessage);\n\t}\n\n\tfunction onMaterialDispose(event) {\n\t\tconst material = event.target;\n\t\tmaterial.removeEventListener('dispose', onMaterialDispose);\n\t\tdeallocateMaterial(material);\n\t} // Buffer deallocation\n\n\n\tfunction deallocateMaterial(material) {\n\t\treleaseMaterialProgramReferences(material);\n\t\tproperties.remove(material);\n\t}\n\n\tfunction releaseMaterialProgramReferences(material) {\n\t\tconst programs = properties.get(material).programs;\n\n\t\tif (programs !== undefined) {\n\t\t\tprograms.forEach(function (program) {\n\t\t\t\tprogramCache.releaseProgram(program);\n\t\t\t});\n\n\t\t\tif (material.isShaderMaterial) {\n\t\t\t\tprogramCache.releaseShaderCache(material);\n\t\t\t}\n\t\t}\n\t} // Buffer rendering\n\n\n\tthis.renderBufferDirect = function (camera, scene, geometry, material, object, group) {\n\t\tif (scene === null) scene = _emptyScene; // renderBufferDirect second parameter used to be fog (could be null)\n\n\t\tconst frontFaceCW = object.isMesh && object.matrixWorld.determinant() < 0;\n\t\tconst program = setProgram(camera, scene, geometry, material, object);\n\t\tstate.setMaterial(material, frontFaceCW); //\n\n\t\tlet index = geometry.index;\n\t\tconst position = geometry.attributes.position; //\n\n\t\tif (index === null) {\n\t\t\tif (position === undefined || position.count === 0) return;\n\t\t} else if (index.count === 0) {\n\t\t\treturn;\n\t\t} //\n\n\n\t\tlet rangeFactor = 1;\n\n\t\tif (material.wireframe === true) {\n\t\t\tindex = geometries.getWireframeAttribute(geometry);\n\t\t\trangeFactor = 2;\n\t\t}\n\n\t\tbindingStates.setup(object, material, program, geometry, index);\n\t\tlet attribute;\n\t\tlet renderer = bufferRenderer;\n\n\t\tif (index !== null) {\n\t\t\tattribute = attributes.get(index);\n\t\t\trenderer = indexedBufferRenderer;\n\t\t\trenderer.setIndex(attribute);\n\t\t} //\n\n\n\t\tconst dataCount = index !== null ? index.count : position.count;\n\t\tconst rangeStart = geometry.drawRange.start * rangeFactor;\n\t\tconst rangeCount = geometry.drawRange.count * rangeFactor;\n\t\tconst groupStart = group !== null ? group.start * rangeFactor : 0;\n\t\tconst groupCount = group !== null ? group.count * rangeFactor : Infinity;\n\t\tconst drawStart = Math.max(rangeStart, groupStart);\n\t\tconst drawEnd = Math.min(dataCount, rangeStart + rangeCount, groupStart + groupCount) - 1;\n\t\tconst drawCount = Math.max(0, drawEnd - drawStart + 1);\n\t\tif (drawCount === 0) return; //\n\n\t\tif (object.isMesh) {\n\t\t\tif (material.wireframe === true) {\n\t\t\t\tstate.setLineWidth(material.wireframeLinewidth * getTargetPixelRatio());\n\t\t\t\trenderer.setMode(_gl.LINES);\n\t\t\t} else {\n\t\t\t\trenderer.setMode(_gl.TRIANGLES);\n\t\t\t}\n\t\t} else if (object.isLine) {\n\t\t\tlet lineWidth = material.linewidth;\n\t\t\tif (lineWidth === undefined) lineWidth = 1; // Not using Line*Material\n\n\t\t\tstate.setLineWidth(lineWidth * getTargetPixelRatio());\n\n\t\t\tif (object.isLineSegments) {\n\t\t\t\trenderer.setMode(_gl.LINES);\n\t\t\t} else if (object.isLineLoop) {\n\t\t\t\trenderer.setMode(_gl.LINE_LOOP);\n\t\t\t} else {\n\t\t\t\trenderer.setMode(_gl.LINE_STRIP);\n\t\t\t}\n\t\t} else if (object.isPoints) {\n\t\t\trenderer.setMode(_gl.POINTS);\n\t\t} else if (object.isSprite) {\n\t\t\trenderer.setMode(_gl.TRIANGLES);\n\t\t}\n\n\t\tif (object.isInstancedMesh) {\n\t\t\trenderer.renderInstances(drawStart, drawCount, object.count);\n\t\t} else if (geometry.isInstancedBufferGeometry) {\n\t\t\tconst instanceCount = Math.min(geometry.instanceCount, geometry._maxInstanceCount);\n\t\t\trenderer.renderInstances(drawStart, drawCount, instanceCount);\n\t\t} else {\n\t\t\trenderer.render(drawStart, drawCount);\n\t\t}\n\t}; // Compile\n\n\n\tthis.compile = function (scene, camera) {\n\t\tcurrentRenderState = renderStates.get(scene);\n\t\tcurrentRenderState.init();\n\t\trenderStateStack.push(currentRenderState);\n\t\tscene.traverseVisible(function (object) {\n\t\t\tif (object.isLight && object.layers.test(camera.layers)) {\n\t\t\t\tcurrentRenderState.pushLight(object);\n\n\t\t\t\tif (object.castShadow) {\n\t\t\t\t\tcurrentRenderState.pushShadow(object);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\tcurrentRenderState.setupLights(_this.physicallyCorrectLights);\n\t\tscene.traverse(function (object) {\n\t\t\tconst material = object.material;\n\n\t\t\tif (material) {\n\t\t\t\tif (Array.isArray(material)) {\n\t\t\t\t\tfor (let i = 0; i < material.length; i++) {\n\t\t\t\t\t\tconst material2 = material[i];\n\t\t\t\t\t\tgetProgram(material2, scene, object);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tgetProgram(material, scene, object);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\trenderStateStack.pop();\n\t\tcurrentRenderState = null;\n\t}; // Animation Loop\n\n\n\tlet onAnimationFrameCallback = null;\n\n\tfunction onAnimationFrame(time) {\n\t\tif (onAnimationFrameCallback) onAnimationFrameCallback(time);\n\t}\n\n\tfunction onXRSessionStart() {\n\t\tanimation.stop();\n\t}\n\n\tfunction onXRSessionEnd() {\n\t\tanimation.start();\n\t}\n\n\tconst animation = new WebGLAnimation();\n\tanimation.setAnimationLoop(onAnimationFrame);\n\tif (typeof self !== 'undefined') animation.setContext(self);\n\n\tthis.setAnimationLoop = function (callback) {\n\t\tonAnimationFrameCallback = callback;\n\t\txr.setAnimationLoop(callback);\n\t\tcallback === null ? animation.stop() : animation.start();\n\t};\n\n\txr.addEventListener('sessionstart', onXRSessionStart);\n\txr.addEventListener('sessionend', onXRSessionEnd); // Rendering\n\n\tthis.render = function (scene, camera) {\n\t\tif (camera !== undefined && camera.isCamera !== true) {\n\t\t\tconsole.error('THREE.WebGLRenderer.render: camera is not an instance of THREE.Camera.');\n\t\t\treturn;\n\t\t}\n\n\t\tif (_isContextLost === true) return; // update scene graph\n\n\t\tif (scene.autoUpdate === true) scene.updateMatrixWorld(); // update camera matrices and frustum\n\n\t\tif (camera.parent === null) camera.updateMatrixWorld();\n\n\t\tif (xr.enabled === true && xr.isPresenting === true) {\n\t\t\tif (xr.cameraAutoUpdate === true) xr.updateCamera(camera);\n\t\t\tcamera = xr.getCamera(); // use XR camera for rendering\n\t\t} //\n\n\n\t\tif (scene.isScene === true) scene.onBeforeRender(_this, scene, camera, _currentRenderTarget);\n\t\tcurrentRenderState = renderStates.get(scene, renderStateStack.length);\n\t\tcurrentRenderState.init();\n\t\trenderStateStack.push(currentRenderState);\n\n\t\t_projScreenMatrix.multiplyMatrices(camera.projectionMatrix, camera.matrixWorldInverse);\n\n\t\t_frustum.setFromProjectionMatrix(_projScreenMatrix);\n\n\t\t_localClippingEnabled = this.localClippingEnabled;\n\t\t_clippingEnabled = clipping.init(this.clippingPlanes, _localClippingEnabled, camera);\n\t\tcurrentRenderList = renderLists.get(scene, renderListStack.length);\n\t\tcurrentRenderList.init();\n\t\trenderListStack.push(currentRenderList);\n\t\tprojectObject(scene, camera, 0, _this.sortObjects);\n\t\tcurrentRenderList.finish();\n\n\t\tif (_this.sortObjects === true) {\n\t\t\tcurrentRenderList.sort(_opaqueSort, _transparentSort);\n\t\t} //\n\n\n\t\tif (_clippingEnabled === true) clipping.beginShadows();\n\t\tconst shadowsArray = currentRenderState.state.shadowsArray;\n\t\tshadowMap.render(shadowsArray, scene, camera);\n\t\tif (_clippingEnabled === true) clipping.endShadows(); //\n\n\t\tif (this.info.autoReset === true) this.info.reset(); //\n\n\t\tbackground.render(currentRenderList, scene); // render scene\n\n\t\tcurrentRenderState.setupLights(_this.physicallyCorrectLights);\n\n\t\tif (camera.isArrayCamera) {\n\t\t\tconst cameras = camera.cameras;\n\n\t\t\tfor (let i = 0, l = cameras.length; i < l; i++) {\n\t\t\t\tconst camera2 = cameras[i];\n\t\t\t\trenderScene(currentRenderList, scene, camera2, camera2.viewport);\n\t\t\t}\n\t\t} else {\n\t\t\trenderScene(currentRenderList, scene, camera);\n\t\t} //\n\n\n\t\tif (_currentRenderTarget !== null) {\n\t\t\t// resolve multisample renderbuffers to a single-sample texture if necessary\n\t\t\ttextures.updateMultisampleRenderTarget(_currentRenderTarget); // Generate mipmap if we're using any kind of mipmap filtering\n\n\t\t\ttextures.updateRenderTargetMipmap(_currentRenderTarget);\n\t\t} //\n\n\n\t\tif (scene.isScene === true) scene.onAfterRender(_this, scene, camera); // _gl.finish();\n\n\t\tbindingStates.resetDefaultState();\n\t\t_currentMaterialId = -1;\n\t\t_currentCamera = null;\n\t\trenderStateStack.pop();\n\n\t\tif (renderStateStack.length > 0) {\n\t\t\tcurrentRenderState = renderStateStack[renderStateStack.length - 1];\n\t\t} else {\n\t\t\tcurrentRenderState = null;\n\t\t}\n\n\t\trenderListStack.pop();\n\n\t\tif (renderListStack.length > 0) {\n\t\t\tcurrentRenderList = renderListStack[renderListStack.length - 1];\n\t\t} else {\n\t\t\tcurrentRenderList = null;\n\t\t}\n\t};\n\n\tfunction projectObject(object, camera, groupOrder, sortObjects) {\n\t\tif (object.visible === false) return;\n\t\tconst visible = object.layers.test(camera.layers);\n\n\t\tif (visible) {\n\t\t\tif (object.isGroup) {\n\t\t\t\tgroupOrder = object.renderOrder;\n\t\t\t} else if (object.isLOD) {\n\t\t\t\tif (object.autoUpdate === true) object.update(camera);\n\t\t\t} else if (object.isLight) {\n\t\t\t\tcurrentRenderState.pushLight(object);\n\n\t\t\t\tif (object.castShadow) {\n\t\t\t\t\tcurrentRenderState.pushShadow(object);\n\t\t\t\t}\n\t\t\t} else if (object.isSprite) {\n\t\t\t\tif (!object.frustumCulled || _frustum.intersectsSprite(object)) {\n\t\t\t\t\tif (sortObjects) {\n\t\t\t\t\t\t_vector3.setFromMatrixPosition(object.matrixWorld).applyMatrix4(_projScreenMatrix);\n\t\t\t\t\t}\n\n\t\t\t\t\tconst geometry = objects.update(object);\n\t\t\t\t\tconst material = object.material;\n\n\t\t\t\t\tif (material.visible) {\n\t\t\t\t\t\tcurrentRenderList.push(object, geometry, material, groupOrder, _vector3.z, null);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (object.isMesh || object.isLine || object.isPoints) {\n\t\t\t\tif (object.isSkinnedMesh) {\n\t\t\t\t\t// update skeleton only once in a frame\n\t\t\t\t\tif (object.skeleton.frame !== info.render.frame) {\n\t\t\t\t\t\tobject.skeleton.update();\n\t\t\t\t\t\tobject.skeleton.frame = info.render.frame;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (!object.frustumCulled || _frustum.intersectsObject(object)) {\n\t\t\t\t\tif (sortObjects) {\n\t\t\t\t\t\t_vector3.setFromMatrixPosition(object.matrixWorld).applyMatrix4(_projScreenMatrix);\n\t\t\t\t\t}\n\n\t\t\t\t\tconst geometry = objects.update(object);\n\t\t\t\t\tconst material = object.material;\n\n\t\t\t\t\tif (Array.isArray(material)) {\n\t\t\t\t\t\tconst groups = geometry.groups;\n\n\t\t\t\t\t\tfor (let i = 0, l = groups.length; i < l; i++) {\n\t\t\t\t\t\t\tconst group = groups[i];\n\t\t\t\t\t\t\tconst groupMaterial = material[group.materialIndex];\n\n\t\t\t\t\t\t\tif (groupMaterial && groupMaterial.visible) {\n\t\t\t\t\t\t\t\tcurrentRenderList.push(object, geometry, groupMaterial, groupOrder, _vector3.z, group);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t} else if (material.visible) {\n\t\t\t\t\t\tcurrentRenderList.push(object, geometry, material, groupOrder, _vector3.z, null);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst children = object.children;\n\n\t\tfor (let i = 0, l = children.length; i < l; i++) {\n\t\t\tprojectObject(children[i], camera, groupOrder, sortObjects);\n\t\t}\n\t}\n\n\tfunction renderScene(currentRenderList, scene, camera, viewport) {\n\t\tconst opaqueObjects = currentRenderList.opaque;\n\t\tconst transmissiveObjects = currentRenderList.transmissive;\n\t\tconst transparentObjects = currentRenderList.transparent;\n\t\tcurrentRenderState.setupLightsView(camera);\n\t\tif (transmissiveObjects.length > 0) renderTransmissionPass(opaqueObjects, scene, camera);\n\t\tif (viewport) state.viewport(_currentViewport.copy(viewport));\n\t\tif (opaqueObjects.length > 0) renderObjects(opaqueObjects, scene, camera);\n\t\tif (transmissiveObjects.length > 0) renderObjects(transmissiveObjects, scene, camera);\n\t\tif (transparentObjects.length > 0) renderObjects(transparentObjects, scene, camera); // Ensure depth buffer writing is enabled so it can be cleared on next render\n\n\t\tstate.buffers.depth.setTest(true);\n\t\tstate.buffers.depth.setMask(true);\n\t\tstate.buffers.color.setMask(true);\n\t\tstate.setPolygonOffset(false);\n\t}\n\n\tfunction renderTransmissionPass(opaqueObjects, scene, camera) {\n\t\tconst isWebGL2 = capabilities.isWebGL2;\n\n\t\tif (_transmissionRenderTarget === null) {\n\t\t\t_transmissionRenderTarget = new WebGLRenderTarget(1, 1, {\n\t\t\t\tgenerateMipmaps: true,\n\t\t\t\ttype: extensions.has('EXT_color_buffer_half_float') ? HalfFloatType : UnsignedByteType,\n\t\t\t\tminFilter: LinearMipmapLinearFilter,\n\t\t\t\tsamples: isWebGL2 && _antialias === true ? 4 : 0\n\t\t\t});\n\t\t}\n\n\t\t_this.getDrawingBufferSize(_vector2);\n\n\t\tif (isWebGL2) {\n\t\t\t_transmissionRenderTarget.setSize(_vector2.x, _vector2.y);\n\t\t} else {\n\t\t\t_transmissionRenderTarget.setSize(floorPowerOfTwo(_vector2.x), floorPowerOfTwo(_vector2.y));\n\t\t} //\n\n\n\t\tconst currentRenderTarget = _this.getRenderTarget();\n\n\t\t_this.setRenderTarget(_transmissionRenderTarget);\n\n\t\t_this.clear(); // Turn off the features which can affect the frag color for opaque objects pass.\n\t\t// Otherwise they are applied twice in opaque objects pass and transmission objects pass.\n\n\n\t\tconst currentToneMapping = _this.toneMapping;\n\t\t_this.toneMapping = NoToneMapping;\n\t\trenderObjects(opaqueObjects, scene, camera);\n\t\t_this.toneMapping = currentToneMapping;\n\t\ttextures.updateMultisampleRenderTarget(_transmissionRenderTarget);\n\t\ttextures.updateRenderTargetMipmap(_transmissionRenderTarget);\n\n\t\t_this.setRenderTarget(currentRenderTarget);\n\t}\n\n\tfunction renderObjects(renderList, scene, camera) {\n\t\tconst overrideMaterial = scene.isScene === true ? scene.overrideMaterial : null;\n\n\t\tfor (let i = 0, l = renderList.length; i < l; i++) {\n\t\t\tconst renderItem = renderList[i];\n\t\t\tconst object = renderItem.object;\n\t\t\tconst geometry = renderItem.geometry;\n\t\t\tconst material = overrideMaterial === null ? renderItem.material : overrideMaterial;\n\t\t\tconst group = renderItem.group;\n\n\t\t\tif (object.layers.test(camera.layers)) {\n\t\t\t\trenderObject(object, scene, camera, geometry, material, group);\n\t\t\t}\n\t\t}\n\t}\n\n\tfunction renderObject(object, scene, camera, geometry, material, group) {\n\t\tobject.onBeforeRender(_this, scene, camera, geometry, material, group);\n\t\tobject.modelViewMatrix.multiplyMatrices(camera.matrixWorldInverse, object.matrixWorld);\n\t\tobject.normalMatrix.getNormalMatrix(object.modelViewMatrix);\n\t\tmaterial.onBeforeRender(_this, scene, camera, geometry, object, group);\n\n\t\tif (material.transparent === true && material.side === DoubleSide) {\n\t\t\tmaterial.side = BackSide;\n\t\t\tmaterial.needsUpdate = true;\n\n\t\t\t_this.renderBufferDirect(camera, scene, geometry, material, object, group);\n\n\t\t\tmaterial.side = FrontSide;\n\t\t\tmaterial.needsUpdate = true;\n\n\t\t\t_this.renderBufferDirect(camera, scene, geometry, material, object, group);\n\n\t\t\tmaterial.side = DoubleSide;\n\t\t} else {\n\t\t\t_this.renderBufferDirect(camera, scene, geometry, material, object, group);\n\t\t}\n\n\t\tobject.onAfterRender(_this, scene, camera, geometry, material, group);\n\t}\n\n\tfunction getProgram(material, scene, object) {\n\t\tif (scene.isScene !== true) scene = _emptyScene; // scene could be a Mesh, Line, Points, ...\n\n\t\tconst materialProperties = properties.get(material);\n\t\tconst lights = currentRenderState.state.lights;\n\t\tconst shadowsArray = currentRenderState.state.shadowsArray;\n\t\tconst lightsStateVersion = lights.state.version;\n\t\tconst parameters = programCache.getParameters(material, lights.state, shadowsArray, scene, object);\n\t\tconst programCacheKey = programCache.getProgramCacheKey(parameters);\n\t\tlet programs = materialProperties.programs; // always update environment and fog - changing these trigger an getProgram call, but it's possible that the program doesn't change\n\n\t\tmaterialProperties.environment = material.isMeshStandardMaterial ? scene.environment : null;\n\t\tmaterialProperties.fog = scene.fog;\n\t\tmaterialProperties.envMap = (material.isMeshStandardMaterial ? cubeuvmaps : cubemaps).get(material.envMap || materialProperties.environment);\n\n\t\tif (programs === undefined) {\n\t\t\t// new material\n\t\t\tmaterial.addEventListener('dispose', onMaterialDispose);\n\t\t\tprograms = new Map();\n\t\t\tmaterialProperties.programs = programs;\n\t\t}\n\n\t\tlet program = programs.get(programCacheKey);\n\n\t\tif (program !== undefined) {\n\t\t\t// early out if program and light state is identical\n\t\t\tif (materialProperties.currentProgram === program && materialProperties.lightsStateVersion === lightsStateVersion) {\n\t\t\t\tupdateCommonMaterialProperties(material, parameters);\n\t\t\t\treturn program;\n\t\t\t}\n\t\t} else {\n\t\t\tparameters.uniforms = programCache.getUniforms(material);\n\t\t\tmaterial.onBuild(object, parameters, _this);\n\t\t\tmaterial.onBeforeCompile(parameters, _this);\n\t\t\tprogram = programCache.acquireProgram(parameters, programCacheKey);\n\t\t\tprograms.set(programCacheKey, program);\n\t\t\tmaterialProperties.uniforms = parameters.uniforms;\n\t\t}\n\n\t\tconst uniforms = materialProperties.uniforms;\n\n\t\tif (!material.isShaderMaterial && !material.isRawShaderMaterial || material.clipping === true) {\n\t\t\tuniforms.clippingPlanes = clipping.uniform;\n\t\t}\n\n\t\tupdateCommonMaterialProperties(material, parameters); // store the light setup it was created for\n\n\t\tmaterialProperties.needsLights = materialNeedsLights(material);\n\t\tmaterialProperties.lightsStateVersion = lightsStateVersion;\n\n\t\tif (materialProperties.needsLights) {\n\t\t\t// wire up the material to this renderer's lighting state\n\t\t\tuniforms.ambientLightColor.value = lights.state.ambient;\n\t\t\tuniforms.lightProbe.value = lights.state.probe;\n\t\t\tuniforms.directionalLights.value = lights.state.directional;\n\t\t\tuniforms.directionalLightShadows.value = lights.state.directionalShadow;\n\t\t\tuniforms.spotLights.value = lights.state.spot;\n\t\t\tuniforms.spotLightShadows.value = lights.state.spotShadow;\n\t\t\tuniforms.rectAreaLights.value = lights.state.rectArea;\n\t\t\tuniforms.ltc_1.value = lights.state.rectAreaLTC1;\n\t\t\tuniforms.ltc_2.value = lights.state.rectAreaLTC2;\n\t\t\tuniforms.pointLights.value = lights.state.point;\n\t\t\tuniforms.pointLightShadows.value = lights.state.pointShadow;\n\t\t\tuniforms.hemisphereLights.value = lights.state.hemi;\n\t\t\tuniforms.directionalShadowMap.value = lights.state.directionalShadowMap;\n\t\t\tuniforms.directionalShadowMatrix.value = lights.state.directionalShadowMatrix;\n\t\t\tuniforms.spotShadowMap.value = lights.state.spotShadowMap;\n\t\t\tuniforms.spotShadowMatrix.value = lights.state.spotShadowMatrix;\n\t\t\tuniforms.pointShadowMap.value = lights.state.pointShadowMap;\n\t\t\tuniforms.pointShadowMatrix.value = lights.state.pointShadowMatrix; // TODO (abelnation): add area lights shadow info to uniforms\n\t\t}\n\n\t\tconst progUniforms = program.getUniforms();\n\t\tconst uniformsList = WebGLUniforms.seqWithValue(progUniforms.seq, uniforms);\n\t\tmaterialProperties.currentProgram = program;\n\t\tmaterialProperties.uniformsList = uniformsList;\n\t\treturn program;\n\t}\n\n\tfunction updateCommonMaterialProperties(material, parameters) {\n\t\tconst materialProperties = properties.get(material);\n\t\tmaterialProperties.outputEncoding = parameters.outputEncoding;\n\t\tmaterialProperties.instancing = parameters.instancing;\n\t\tmaterialProperties.skinning = parameters.skinning;\n\t\tmaterialProperties.morphTargets = parameters.morphTargets;\n\t\tmaterialProperties.morphNormals = parameters.morphNormals;\n\t\tmaterialProperties.morphColors = parameters.morphColors;\n\t\tmaterialProperties.morphTargetsCount = parameters.morphTargetsCount;\n\t\tmaterialProperties.numClippingPlanes = parameters.numClippingPlanes;\n\t\tmaterialProperties.numIntersection = parameters.numClipIntersection;\n\t\tmaterialProperties.vertexAlphas = parameters.vertexAlphas;\n\t\tmaterialProperties.vertexTangents = parameters.vertexTangents;\n\t\tmaterialProperties.toneMapping = parameters.toneMapping;\n\t}\n\n\tfunction setProgram(camera, scene, geometry, material, object) {\n\t\tif (scene.isScene !== true) scene = _emptyScene; // scene could be a Mesh, Line, Points, ...\n\n\t\ttextures.resetTextureUnits();\n\t\tconst fog = scene.fog;\n\t\tconst environment = material.isMeshStandardMaterial ? scene.environment : null;\n\t\tconst encoding = _currentRenderTarget === null ? _this.outputEncoding : _currentRenderTarget.isXRRenderTarget === true ? _currentRenderTarget.texture.encoding : LinearEncoding;\n\t\tconst envMap = (material.isMeshStandardMaterial ? cubeuvmaps : cubemaps).get(material.envMap || environment);\n\t\tconst vertexAlphas = material.vertexColors === true && !!geometry.attributes.color && geometry.attributes.color.itemSize === 4;\n\t\tconst vertexTangents = !!material.normalMap && !!geometry.attributes.tangent;\n\t\tconst morphTargets = !!geometry.morphAttributes.position;\n\t\tconst morphNormals = !!geometry.morphAttributes.normal;\n\t\tconst morphColors = !!geometry.morphAttributes.color;\n\t\tconst toneMapping = material.toneMapped ? _this.toneMapping : NoToneMapping;\n\t\tconst morphAttribute = geometry.morphAttributes.position || geometry.morphAttributes.normal || geometry.morphAttributes.color;\n\t\tconst morphTargetsCount = morphAttribute !== undefined ? morphAttribute.length : 0;\n\t\tconst materialProperties = properties.get(material);\n\t\tconst lights = currentRenderState.state.lights;\n\n\t\tif (_clippingEnabled === true) {\n\t\t\tif (_localClippingEnabled === true || camera !== _currentCamera) {\n\t\t\t\tconst useCache = camera === _currentCamera && material.id === _currentMaterialId; // we might want to call this function with some ClippingGroup\n\t\t\t\t// object instead of the material, once it becomes feasible\n\t\t\t\t// (#8465, #8379)\n\n\t\t\t\tclipping.setState(material, camera, useCache);\n\t\t\t}\n\t\t} //\n\n\n\t\tlet needsProgramChange = false;\n\n\t\tif (material.version === materialProperties.__version) {\n\t\t\tif (materialProperties.needsLights && materialProperties.lightsStateVersion !== lights.state.version) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (materialProperties.outputEncoding !== encoding) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (object.isInstancedMesh && materialProperties.instancing === false) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (!object.isInstancedMesh && materialProperties.instancing === true) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (object.isSkinnedMesh && materialProperties.skinning === false) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (!object.isSkinnedMesh && materialProperties.skinning === true) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (materialProperties.envMap !== envMap) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (material.fog === true && materialProperties.fog !== fog) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (materialProperties.numClippingPlanes !== undefined && (materialProperties.numClippingPlanes !== clipping.numPlanes || materialProperties.numIntersection !== clipping.numIntersection)) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (materialProperties.vertexAlphas !== vertexAlphas) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (materialProperties.vertexTangents !== vertexTangents) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (materialProperties.morphTargets !== morphTargets) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (materialProperties.morphNormals !== morphNormals) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (materialProperties.morphColors !== morphColors) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (materialProperties.toneMapping !== toneMapping) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t} else if (capabilities.isWebGL2 === true && materialProperties.morphTargetsCount !== morphTargetsCount) {\n\t\t\t\tneedsProgramChange = true;\n\t\t\t}\n\t\t} else {\n\t\t\tneedsProgramChange = true;\n\t\t\tmaterialProperties.__version = material.version;\n\t\t} //\n\n\n\t\tlet program = materialProperties.currentProgram;\n\n\t\tif (needsProgramChange === true) {\n\t\t\tprogram = getProgram(material, scene, object);\n\t\t}\n\n\t\tlet refreshProgram = false;\n\t\tlet refreshMaterial = false;\n\t\tlet refreshLights = false;\n\t\tconst p_uniforms = program.getUniforms(),\n\t\t\t\t\tm_uniforms = materialProperties.uniforms;\n\n\t\tif (state.useProgram(program.program)) {\n\t\t\trefreshProgram = true;\n\t\t\trefreshMaterial = true;\n\t\t\trefreshLights = true;\n\t\t}\n\n\t\tif (material.id !== _currentMaterialId) {\n\t\t\t_currentMaterialId = material.id;\n\t\t\trefreshMaterial = true;\n\t\t}\n\n\t\tif (refreshProgram || _currentCamera !== camera) {\n\t\t\tp_uniforms.setValue(_gl, 'projectionMatrix', camera.projectionMatrix);\n\n\t\t\tif (capabilities.logarithmicDepthBuffer) {\n\t\t\t\tp_uniforms.setValue(_gl, 'logDepthBufFC', 2.0 / (Math.log(camera.far + 1.0) / Math.LN2));\n\t\t\t}\n\n\t\t\tif (_currentCamera !== camera) {\n\t\t\t\t_currentCamera = camera; // lighting uniforms depend on the camera so enforce an update\n\t\t\t\t// now, in case this material supports lights - or later, when\n\t\t\t\t// the next material that does gets activated:\n\n\t\t\t\trefreshMaterial = true; // set to true on material change\n\n\t\t\t\trefreshLights = true; // remains set until update done\n\t\t\t} // load material specific uniforms\n\t\t\t// (shader material also gets them for the sake of genericity)\n\n\n\t\t\tif (material.isShaderMaterial || material.isMeshPhongMaterial || material.isMeshToonMaterial || material.isMeshStandardMaterial || material.envMap) {\n\t\t\t\tconst uCamPos = p_uniforms.map.cameraPosition;\n\n\t\t\t\tif (uCamPos !== undefined) {\n\t\t\t\t\tuCamPos.setValue(_gl, _vector3.setFromMatrixPosition(camera.matrixWorld));\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (material.isMeshPhongMaterial || material.isMeshToonMaterial || material.isMeshLambertMaterial || material.isMeshBasicMaterial || material.isMeshStandardMaterial || material.isShaderMaterial) {\n\t\t\t\tp_uniforms.setValue(_gl, 'isOrthographic', camera.isOrthographicCamera === true);\n\t\t\t}\n\n\t\t\tif (material.isMeshPhongMaterial || material.isMeshToonMaterial || material.isMeshLambertMaterial || material.isMeshBasicMaterial || material.isMeshStandardMaterial || material.isShaderMaterial || material.isShadowMaterial || object.isSkinnedMesh) {\n\t\t\t\tp_uniforms.setValue(_gl, 'viewMatrix', camera.matrixWorldInverse);\n\t\t\t}\n\t\t} // skinning and morph target uniforms must be set even if material didn't change\n\t\t// auto-setting of texture unit for bone and morph texture must go before other textures\n\t\t// otherwise textures used for skinning and morphing can take over texture units reserved for other material textures\n\n\n\t\tif (object.isSkinnedMesh) {\n\t\t\tp_uniforms.setOptional(_gl, object, 'bindMatrix');\n\t\t\tp_uniforms.setOptional(_gl, object, 'bindMatrixInverse');\n\t\t\tconst skeleton = object.skeleton;\n\n\t\t\tif (skeleton) {\n\t\t\t\tif (capabilities.floatVertexTextures) {\n\t\t\t\t\tif (skeleton.boneTexture === null) skeleton.computeBoneTexture();\n\t\t\t\t\tp_uniforms.setValue(_gl, 'boneTexture', skeleton.boneTexture, textures);\n\t\t\t\t\tp_uniforms.setValue(_gl, 'boneTextureSize', skeleton.boneTextureSize);\n\t\t\t\t} else {\n\t\t\t\t\tconsole.warn('THREE.WebGLRenderer: SkinnedMesh can only be used with WebGL 2. With WebGL 1 OES_texture_float and vertex textures support is required.');\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst morphAttributes = geometry.morphAttributes;\n\n\t\tif (morphAttributes.position !== undefined || morphAttributes.normal !== undefined || morphAttributes.color !== undefined && capabilities.isWebGL2 === true) {\n\t\t\tmorphtargets.update(object, geometry, material, program);\n\t\t}\n\n\t\tif (refreshMaterial || materialProperties.receiveShadow !== object.receiveShadow) {\n\t\t\tmaterialProperties.receiveShadow = object.receiveShadow;\n\t\t\tp_uniforms.setValue(_gl, 'receiveShadow', object.receiveShadow);\n\t\t}\n\n\t\tif (refreshMaterial) {\n\t\t\tp_uniforms.setValue(_gl, 'toneMappingExposure', _this.toneMappingExposure);\n\n\t\t\tif (materialProperties.needsLights) {\n\t\t\t\t// the current material requires lighting info\n\t\t\t\t// note: all lighting uniforms are always set correctly\n\t\t\t\t// they simply reference the renderer's state for their\n\t\t\t\t// values\n\t\t\t\t//\n\t\t\t\t// use the current material's .needsUpdate flags to set\n\t\t\t\t// the GL state when required\n\t\t\t\tmarkUniformsLightsNeedsUpdate(m_uniforms, refreshLights);\n\t\t\t} // refresh uniforms common to several materials\n\n\n\t\t\tif (fog && material.fog === true) {\n\t\t\t\tmaterials.refreshFogUniforms(m_uniforms, fog);\n\t\t\t}\n\n\t\t\tmaterials.refreshMaterialUniforms(m_uniforms, material, _pixelRatio, _height, _transmissionRenderTarget);\n\t\t\tWebGLUniforms.upload(_gl, materialProperties.uniformsList, m_uniforms, textures);\n\t\t}\n\n\t\tif (material.isShaderMaterial && material.uniformsNeedUpdate === true) {\n\t\t\tWebGLUniforms.upload(_gl, materialProperties.uniformsList, m_uniforms, textures);\n\t\t\tmaterial.uniformsNeedUpdate = false;\n\t\t}\n\n\t\tif (material.isSpriteMaterial) {\n\t\t\tp_uniforms.setValue(_gl, 'center', object.center);\n\t\t} // common matrices\n\n\n\t\tp_uniforms.setValue(_gl, 'modelViewMatrix', object.modelViewMatrix);\n\t\tp_uniforms.setValue(_gl, 'normalMatrix', object.normalMatrix);\n\t\tp_uniforms.setValue(_gl, 'modelMatrix', object.matrixWorld);\n\t\treturn program;\n\t} // If uniforms are marked as clean, they don't need to be loaded to the GPU.\n\n\n\tfunction markUniformsLightsNeedsUpdate(uniforms, value) {\n\t\tuniforms.ambientLightColor.needsUpdate = value;\n\t\tuniforms.lightProbe.needsUpdate = value;\n\t\tuniforms.directionalLights.needsUpdate = value;\n\t\tuniforms.directionalLightShadows.needsUpdate = value;\n\t\tuniforms.pointLights.needsUpdate = value;\n\t\tuniforms.pointLightShadows.needsUpdate = value;\n\t\tuniforms.spotLights.needsUpdate = value;\n\t\tuniforms.spotLightShadows.needsUpdate = value;\n\t\tuniforms.rectAreaLights.needsUpdate = value;\n\t\tuniforms.hemisphereLights.needsUpdate = value;\n\t}\n\n\tfunction materialNeedsLights(material) {\n\t\treturn material.isMeshLambertMaterial || material.isMeshToonMaterial || material.isMeshPhongMaterial || material.isMeshStandardMaterial || material.isShadowMaterial || material.isShaderMaterial && material.lights === true;\n\t}\n\n\tthis.getActiveCubeFace = function () {\n\t\treturn _currentActiveCubeFace;\n\t};\n\n\tthis.getActiveMipmapLevel = function () {\n\t\treturn _currentActiveMipmapLevel;\n\t};\n\n\tthis.getRenderTarget = function () {\n\t\treturn _currentRenderTarget;\n\t};\n\n\tthis.setRenderTargetTextures = function (renderTarget, colorTexture, depthTexture) {\n\t\tproperties.get(renderTarget.texture).__webglTexture = colorTexture;\n\t\tproperties.get(renderTarget.depthTexture).__webglTexture = depthTexture;\n\t\tconst renderTargetProperties = properties.get(renderTarget);\n\t\trenderTargetProperties.__hasExternalTextures = true;\n\n\t\tif (renderTargetProperties.__hasExternalTextures) {\n\t\t\trenderTargetProperties.__autoAllocateDepthBuffer = depthTexture === undefined;\n\n\t\t\tif (!renderTargetProperties.__autoAllocateDepthBuffer) {\n\t\t\t\t// The multisample_render_to_texture extension doesn't work properly if there\n\t\t\t\t// are midframe flushes and an external depth buffer. Disable use of the extension.\n\t\t\t\tif (extensions.has('WEBGL_multisampled_render_to_texture') === true) {\n\t\t\t\t\tconsole.warn('THREE.WebGLRenderer: Render-to-texture extension was disabled because an external texture was provided');\n\t\t\t\t\trenderTargetProperties.__useRenderToTexture = false;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n\n\tthis.setRenderTargetFramebuffer = function (renderTarget, defaultFramebuffer) {\n\t\tconst renderTargetProperties = properties.get(renderTarget);\n\t\trenderTargetProperties.__webglFramebuffer = defaultFramebuffer;\n\t\trenderTargetProperties.__useDefaultFramebuffer = defaultFramebuffer === undefined;\n\t};\n\n\tthis.setRenderTarget = function (renderTarget, activeCubeFace = 0, activeMipmapLevel = 0) {\n\t\t_currentRenderTarget = renderTarget;\n\t\t_currentActiveCubeFace = activeCubeFace;\n\t\t_currentActiveMipmapLevel = activeMipmapLevel;\n\t\tlet useDefaultFramebuffer = true;\n\n\t\tif (renderTarget) {\n\t\t\tconst renderTargetProperties = properties.get(renderTarget);\n\n\t\t\tif (renderTargetProperties.__useDefaultFramebuffer !== undefined) {\n\t\t\t\t// We need to make sure to rebind the framebuffer.\n\t\t\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, null);\n\t\t\t\tuseDefaultFramebuffer = false;\n\t\t\t} else if (renderTargetProperties.__webglFramebuffer === undefined) {\n\t\t\t\ttextures.setupRenderTarget(renderTarget);\n\t\t\t} else if (renderTargetProperties.__hasExternalTextures) {\n\t\t\t\t// Color and depth texture must be rebound in order for the swapchain to update.\n\t\t\t\ttextures.rebindTextures(renderTarget, properties.get(renderTarget.texture).__webglTexture, properties.get(renderTarget.depthTexture).__webglTexture);\n\t\t\t}\n\t\t}\n\n\t\tlet framebuffer = null;\n\t\tlet isCube = false;\n\t\tlet isRenderTarget3D = false;\n\n\t\tif (renderTarget) {\n\t\t\tconst texture = renderTarget.texture;\n\n\t\t\tif (texture.isData3DTexture || texture.isDataArrayTexture) {\n\t\t\t\tisRenderTarget3D = true;\n\t\t\t}\n\n\t\t\tconst __webglFramebuffer = properties.get(renderTarget).__webglFramebuffer;\n\n\t\t\tif (renderTarget.isWebGLCubeRenderTarget) {\n\t\t\t\tframebuffer = __webglFramebuffer[activeCubeFace];\n\t\t\t\tisCube = true;\n\t\t\t} else if (capabilities.isWebGL2 && renderTarget.samples > 0 && textures.useMultisampledRTT(renderTarget) === false) {\n\t\t\t\tframebuffer = properties.get(renderTarget).__webglMultisampledFramebuffer;\n\t\t\t} else {\n\t\t\t\tframebuffer = __webglFramebuffer;\n\t\t\t}\n\n\t\t\t_currentViewport.copy(renderTarget.viewport);\n\n\t\t\t_currentScissor.copy(renderTarget.scissor);\n\n\t\t\t_currentScissorTest = renderTarget.scissorTest;\n\t\t} else {\n\t\t\t_currentViewport.copy(_viewport).multiplyScalar(_pixelRatio).floor();\n\n\t\t\t_currentScissor.copy(_scissor).multiplyScalar(_pixelRatio).floor();\n\n\t\t\t_currentScissorTest = _scissorTest;\n\t\t}\n\n\t\tconst framebufferBound = state.bindFramebuffer(_gl.FRAMEBUFFER, framebuffer);\n\n\t\tif (framebufferBound && capabilities.drawBuffers && useDefaultFramebuffer) {\n\t\t\tstate.drawBuffers(renderTarget, framebuffer);\n\t\t}\n\n\t\tstate.viewport(_currentViewport);\n\t\tstate.scissor(_currentScissor);\n\t\tstate.setScissorTest(_currentScissorTest);\n\n\t\tif (isCube) {\n\t\t\tconst textureProperties = properties.get(renderTarget.texture);\n\n\t\t\t_gl.framebufferTexture2D(_gl.FRAMEBUFFER, _gl.COLOR_ATTACHMENT0, _gl.TEXTURE_CUBE_MAP_POSITIVE_X + activeCubeFace, textureProperties.__webglTexture, activeMipmapLevel);\n\t\t} else if (isRenderTarget3D) {\n\t\t\tconst textureProperties = properties.get(renderTarget.texture);\n\t\t\tconst layer = activeCubeFace || 0;\n\n\t\t\t_gl.framebufferTextureLayer(_gl.FRAMEBUFFER, _gl.COLOR_ATTACHMENT0, textureProperties.__webglTexture, activeMipmapLevel || 0, layer);\n\t\t}\n\n\t\t_currentMaterialId = -1; // reset current material to ensure correct uniform bindings\n\t};\n\n\tthis.readRenderTargetPixels = function (renderTarget, x, y, width, height, buffer, activeCubeFaceIndex) {\n\t\tif (!(renderTarget && renderTarget.isWebGLRenderTarget)) {\n\t\t\tconsole.error('THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not THREE.WebGLRenderTarget.');\n\t\t\treturn;\n\t\t}\n\n\t\tlet framebuffer = properties.get(renderTarget).__webglFramebuffer;\n\n\t\tif (renderTarget.isWebGLCubeRenderTarget && activeCubeFaceIndex !== undefined) {\n\t\t\tframebuffer = framebuffer[activeCubeFaceIndex];\n\t\t}\n\n\t\tif (framebuffer) {\n\t\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, framebuffer);\n\n\t\t\ttry {\n\t\t\t\tconst texture = renderTarget.texture;\n\t\t\t\tconst textureFormat = texture.format;\n\t\t\t\tconst textureType = texture.type;\n\n\t\t\t\tif (textureFormat !== RGBAFormat && utils.convert(textureFormat) !== _gl.getParameter(_gl.IMPLEMENTATION_COLOR_READ_FORMAT)) {\n\t\t\t\t\tconsole.error('THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in RGBA or implementation defined format.');\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst halfFloatSupportedByExt = textureType === HalfFloatType && (extensions.has('EXT_color_buffer_half_float') || capabilities.isWebGL2 && extensions.has('EXT_color_buffer_float'));\n\n\t\t\t\tif (textureType !== UnsignedByteType && utils.convert(textureType) !== _gl.getParameter(_gl.IMPLEMENTATION_COLOR_READ_TYPE) && // Edge and Chrome Mac < 52 (#9513)\n\t\t\t\t!(textureType === FloatType && (capabilities.isWebGL2 || extensions.has('OES_texture_float') || extensions.has('WEBGL_color_buffer_float'))) && // Chrome Mac >= 52 and Firefox\n\t\t\t\t!halfFloatSupportedByExt) {\n\t\t\t\t\tconsole.error('THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in UnsignedByteType or implementation defined type.');\n\t\t\t\t\treturn;\n\t\t\t\t} // the following if statement ensures valid read requests (no out-of-bounds pixels, see #8604)\n\n\n\t\t\t\tif (x >= 0 && x <= renderTarget.width - width && y >= 0 && y <= renderTarget.height - height) {\n\t\t\t\t\t_gl.readPixels(x, y, width, height, utils.convert(textureFormat), utils.convert(textureType), buffer);\n\t\t\t\t}\n\t\t\t} finally {\n\t\t\t\t// restore framebuffer of current render target if necessary\n\t\t\t\tconst framebuffer = _currentRenderTarget !== null ? properties.get(_currentRenderTarget).__webglFramebuffer : null;\n\t\t\t\tstate.bindFramebuffer(_gl.FRAMEBUFFER, framebuffer);\n\t\t\t}\n\t\t}\n\t};\n\n\tthis.copyFramebufferToTexture = function (position, texture, level = 0) {\n\t\tconst levelScale = Math.pow(2, -level);\n\t\tconst width = Math.floor(texture.image.width * levelScale);\n\t\tconst height = Math.floor(texture.image.height * levelScale);\n\t\ttextures.setTexture2D(texture, 0);\n\n\t\t_gl.copyTexSubImage2D(_gl.TEXTURE_2D, level, 0, 0, position.x, position.y, width, height);\n\n\t\tstate.unbindTexture();\n\t};\n\n\tthis.copyTextureToTexture = function (position, srcTexture, dstTexture, level = 0) {\n\t\tconst width = srcTexture.image.width;\n\t\tconst height = srcTexture.image.height;\n\t\tconst glFormat = utils.convert(dstTexture.format);\n\t\tconst glType = utils.convert(dstTexture.type);\n\t\ttextures.setTexture2D(dstTexture, 0); // As another texture upload may have changed pixelStorei\n\t\t// parameters, make sure they are correct for the dstTexture\n\n\t\t_gl.pixelStorei(_gl.UNPACK_FLIP_Y_WEBGL, dstTexture.flipY);\n\n\t\t_gl.pixelStorei(_gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, dstTexture.premultiplyAlpha);\n\n\t\t_gl.pixelStorei(_gl.UNPACK_ALIGNMENT, dstTexture.unpackAlignment);\n\n\t\tif (srcTexture.isDataTexture) {\n\t\t\t_gl.texSubImage2D(_gl.TEXTURE_2D, level, position.x, position.y, width, height, glFormat, glType, srcTexture.image.data);\n\t\t} else {\n\t\t\tif (srcTexture.isCompressedTexture) {\n\t\t\t\t_gl.compressedTexSubImage2D(_gl.TEXTURE_2D, level, position.x, position.y, srcTexture.mipmaps[0].width, srcTexture.mipmaps[0].height, glFormat, srcTexture.mipmaps[0].data);\n\t\t\t} else {\n\t\t\t\t_gl.texSubImage2D(_gl.TEXTURE_2D, level, position.x, position.y, glFormat, glType, srcTexture.image);\n\t\t\t}\n\t\t} // Generate mipmaps only when copying level 0\n\n\n\t\tif (level === 0 && dstTexture.generateMipmaps) _gl.generateMipmap(_gl.TEXTURE_2D);\n\t\tstate.unbindTexture();\n\t};\n\n\tthis.copyTextureToTexture3D = function (sourceBox, position, srcTexture, dstTexture, level = 0) {\n\t\tif (_this.isWebGL1Renderer) {\n\t\t\tconsole.warn('THREE.WebGLRenderer.copyTextureToTexture3D: can only be used with WebGL2.');\n\t\t\treturn;\n\t\t}\n\n\t\tconst width = sourceBox.max.x - sourceBox.min.x + 1;\n\t\tconst height = sourceBox.max.y - sourceBox.min.y + 1;\n\t\tconst depth = sourceBox.max.z - sourceBox.min.z + 1;\n\t\tconst glFormat = utils.convert(dstTexture.format);\n\t\tconst glType = utils.convert(dstTexture.type);\n\t\tlet glTarget;\n\n\t\tif (dstTexture.isData3DTexture) {\n\t\t\ttextures.setTexture3D(dstTexture, 0);\n\t\t\tglTarget = _gl.TEXTURE_3D;\n\t\t} else if (dstTexture.isDataArrayTexture) {\n\t\t\ttextures.setTexture2DArray(dstTexture, 0);\n\t\t\tglTarget = _gl.TEXTURE_2D_ARRAY;\n\t\t} else {\n\t\t\tconsole.warn('THREE.WebGLRenderer.copyTextureToTexture3D: only supports THREE.DataTexture3D and THREE.DataTexture2DArray.');\n\t\t\treturn;\n\t\t}\n\n\t\t_gl.pixelStorei(_gl.UNPACK_FLIP_Y_WEBGL, dstTexture.flipY);\n\n\t\t_gl.pixelStorei(_gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, dstTexture.premultiplyAlpha);\n\n\t\t_gl.pixelStorei(_gl.UNPACK_ALIGNMENT, dstTexture.unpackAlignment);\n\n\t\tconst unpackRowLen = _gl.getParameter(_gl.UNPACK_ROW_LENGTH);\n\n\t\tconst unpackImageHeight = _gl.getParameter(_gl.UNPACK_IMAGE_HEIGHT);\n\n\t\tconst unpackSkipPixels = _gl.getParameter(_gl.UNPACK_SKIP_PIXELS);\n\n\t\tconst unpackSkipRows = _gl.getParameter(_gl.UNPACK_SKIP_ROWS);\n\n\t\tconst unpackSkipImages = _gl.getParameter(_gl.UNPACK_SKIP_IMAGES);\n\n\t\tconst image = srcTexture.isCompressedTexture ? srcTexture.mipmaps[0] : srcTexture.image;\n\n\t\t_gl.pixelStorei(_gl.UNPACK_ROW_LENGTH, image.width);\n\n\t\t_gl.pixelStorei(_gl.UNPACK_IMAGE_HEIGHT, image.height);\n\n\t\t_gl.pixelStorei(_gl.UNPACK_SKIP_PIXELS, sourceBox.min.x);\n\n\t\t_gl.pixelStorei(_gl.UNPACK_SKIP_ROWS, sourceBox.min.y);\n\n\t\t_gl.pixelStorei(_gl.UNPACK_SKIP_IMAGES, sourceBox.min.z);\n\n\t\tif (srcTexture.isDataTexture || srcTexture.isData3DTexture) {\n\t\t\t_gl.texSubImage3D(glTarget, level, position.x, position.y, position.z, width, height, depth, glFormat, glType, image.data);\n\t\t} else {\n\t\t\tif (srcTexture.isCompressedTexture) {\n\t\t\t\tconsole.warn('THREE.WebGLRenderer.copyTextureToTexture3D: untested support for compressed srcTexture.');\n\n\t\t\t\t_gl.compressedTexSubImage3D(glTarget, level, position.x, position.y, position.z, width, height, depth, glFormat, image.data);\n\t\t\t} else {\n\t\t\t\t_gl.texSubImage3D(glTarget, level, position.x, position.y, position.z, width, height, depth, glFormat, glType, image);\n\t\t\t}\n\t\t}\n\n\t\t_gl.pixelStorei(_gl.UNPACK_ROW_LENGTH, unpackRowLen);\n\n\t\t_gl.pixelStorei(_gl.UNPACK_IMAGE_HEIGHT, unpackImageHeight);\n\n\t\t_gl.pixelStorei(_gl.UNPACK_SKIP_PIXELS, unpackSkipPixels);\n\n\t\t_gl.pixelStorei(_gl.UNPACK_SKIP_ROWS, unpackSkipRows);\n\n\t\t_gl.pixelStorei(_gl.UNPACK_SKIP_IMAGES, unpackSkipImages); // Generate mipmaps only when copying level 0\n\n\n\t\tif (level === 0 && dstTexture.generateMipmaps) _gl.generateMipmap(glTarget);\n\t\tstate.unbindTexture();\n\t};\n\n\tthis.initTexture = function (texture) {\n\t\ttextures.setTexture2D(texture, 0);\n\t\tstate.unbindTexture();\n\t};\n\n\tthis.resetState = function () {\n\t\t_currentActiveCubeFace = 0;\n\t\t_currentActiveMipmapLevel = 0;\n\t\t_currentRenderTarget = null;\n\t\tstate.reset();\n\t\tbindingStates.reset();\n\t};\n\n\tif (typeof __THREE_DEVTOOLS__ !== 'undefined') {\n\t\t__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent('observe', {\n\t\t\tdetail: this\n\t\t}));\n\t}\n}\n\nclass WebGL1Renderer extends WebGLRenderer {}\n\nWebGL1Renderer.prototype.isWebGL1Renderer = true;\n\nclass FogExp2 {\n\tconstructor(color, density = 0.00025) {\n\t\tthis.isFogExp2 = true;\n\t\tthis.name = '';\n\t\tthis.color = new Color(color);\n\t\tthis.density = density;\n\t}\n\n\tclone() {\n\t\treturn new FogExp2(this.color, this.density);\n\t}\n\n\ttoJSON() {\n\t\treturn {\n\t\t\ttype: 'FogExp2',\n\t\t\tcolor: this.color.getHex(),\n\t\t\tdensity: this.density\n\t\t};\n\t}\n\n}\n\nclass Fog {\n\tconstructor(color, near = 1, far = 1000) {\n\t\tthis.isFog = true;\n\t\tthis.name = '';\n\t\tthis.color = new Color(color);\n\t\tthis.near = near;\n\t\tthis.far = far;\n\t}\n\n\tclone() {\n\t\treturn new Fog(this.color, this.near, this.far);\n\t}\n\n\ttoJSON() {\n\t\treturn {\n\t\t\ttype: 'Fog',\n\t\t\tcolor: this.color.getHex(),\n\t\t\tnear: this.near,\n\t\t\tfar: this.far\n\t\t};\n\t}\n\n}\n\nclass Scene extends Object3D {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.isScene = true;\n\t\tthis.type = 'Scene';\n\t\tthis.background = null;\n\t\tthis.environment = null;\n\t\tthis.fog = null;\n\t\tthis.overrideMaterial = null;\n\t\tthis.autoUpdate = true; // checked by the renderer\n\n\t\tif (typeof __THREE_DEVTOOLS__ !== 'undefined') {\n\t\t\t__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent('observe', {\n\t\t\t\tdetail: this\n\t\t\t}));\n\t\t}\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tif (source.background !== null) this.background = source.background.clone();\n\t\tif (source.environment !== null) this.environment = source.environment.clone();\n\t\tif (source.fog !== null) this.fog = source.fog.clone();\n\t\tif (source.overrideMaterial !== null) this.overrideMaterial = source.overrideMaterial.clone();\n\t\tthis.autoUpdate = source.autoUpdate;\n\t\tthis.matrixAutoUpdate = source.matrixAutoUpdate;\n\t\treturn this;\n\t}\n\n\ttoJSON(meta) {\n\t\tconst data = super.toJSON(meta);\n\t\tif (this.fog !== null) data.object.fog = this.fog.toJSON();\n\t\treturn data;\n\t}\n\n}\n\nclass InterleavedBuffer {\n\tconstructor(array, stride) {\n\t\tthis.isInterleavedBuffer = true;\n\t\tthis.array = array;\n\t\tthis.stride = stride;\n\t\tthis.count = array !== undefined ? array.length / stride : 0;\n\t\tthis.usage = StaticDrawUsage;\n\t\tthis.updateRange = {\n\t\t\toffset: 0,\n\t\t\tcount: -1\n\t\t};\n\t\tthis.version = 0;\n\t\tthis.uuid = generateUUID();\n\t}\n\n\tonUploadCallback() {}\n\n\tset needsUpdate(value) {\n\t\tif (value === true) this.version++;\n\t}\n\n\tsetUsage(value) {\n\t\tthis.usage = value;\n\t\treturn this;\n\t}\n\n\tcopy(source) {\n\t\tthis.array = new source.array.constructor(source.array);\n\t\tthis.count = source.count;\n\t\tthis.stride = source.stride;\n\t\tthis.usage = source.usage;\n\t\treturn this;\n\t}\n\n\tcopyAt(index1, attribute, index2) {\n\t\tindex1 *= this.stride;\n\t\tindex2 *= attribute.stride;\n\n\t\tfor (let i = 0, l = this.stride; i < l; i++) {\n\t\t\tthis.array[index1 + i] = attribute.array[index2 + i];\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tset(value, offset = 0) {\n\t\tthis.array.set(value, offset);\n\t\treturn this;\n\t}\n\n\tclone(data) {\n\t\tif (data.arrayBuffers === undefined) {\n\t\t\tdata.arrayBuffers = {};\n\t\t}\n\n\t\tif (this.array.buffer._uuid === undefined) {\n\t\t\tthis.array.buffer._uuid = generateUUID();\n\t\t}\n\n\t\tif (data.arrayBuffers[this.array.buffer._uuid] === undefined) {\n\t\t\tdata.arrayBuffers[this.array.buffer._uuid] = this.array.slice(0).buffer;\n\t\t}\n\n\t\tconst array = new this.array.constructor(data.arrayBuffers[this.array.buffer._uuid]);\n\t\tconst ib = new this.constructor(array, this.stride);\n\t\tib.setUsage(this.usage);\n\t\treturn ib;\n\t}\n\n\tonUpload(callback) {\n\t\tthis.onUploadCallback = callback;\n\t\treturn this;\n\t}\n\n\ttoJSON(data) {\n\t\tif (data.arrayBuffers === undefined) {\n\t\t\tdata.arrayBuffers = {};\n\t\t} // generate UUID for array buffer if necessary\n\n\n\t\tif (this.array.buffer._uuid === undefined) {\n\t\t\tthis.array.buffer._uuid = generateUUID();\n\t\t}\n\n\t\tif (data.arrayBuffers[this.array.buffer._uuid] === undefined) {\n\t\t\tdata.arrayBuffers[this.array.buffer._uuid] = Array.prototype.slice.call(new Uint32Array(this.array.buffer));\n\t\t} //\n\n\n\t\treturn {\n\t\t\tuuid: this.uuid,\n\t\t\tbuffer: this.array.buffer._uuid,\n\t\t\ttype: this.array.constructor.name,\n\t\t\tstride: this.stride\n\t\t};\n\t}\n\n}\n\nconst _vector$6 = /*@__PURE__*/new Vector3();\n\nclass InterleavedBufferAttribute {\n\tconstructor(interleavedBuffer, itemSize, offset, normalized = false) {\n\t\tthis.isInterleavedBufferAttribute = true;\n\t\tthis.name = '';\n\t\tthis.data = interleavedBuffer;\n\t\tthis.itemSize = itemSize;\n\t\tthis.offset = offset;\n\t\tthis.normalized = normalized === true;\n\t}\n\n\tget count() {\n\t\treturn this.data.count;\n\t}\n\n\tget array() {\n\t\treturn this.data.array;\n\t}\n\n\tset needsUpdate(value) {\n\t\tthis.data.needsUpdate = value;\n\t}\n\n\tapplyMatrix4(m) {\n\t\tfor (let i = 0, l = this.data.count; i < l; i++) {\n\t\t\t_vector$6.fromBufferAttribute(this, i);\n\n\t\t\t_vector$6.applyMatrix4(m);\n\n\t\t\tthis.setXYZ(i, _vector$6.x, _vector$6.y, _vector$6.z);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tapplyNormalMatrix(m) {\n\t\tfor (let i = 0, l = this.count; i < l; i++) {\n\t\t\t_vector$6.fromBufferAttribute(this, i);\n\n\t\t\t_vector$6.applyNormalMatrix(m);\n\n\t\t\tthis.setXYZ(i, _vector$6.x, _vector$6.y, _vector$6.z);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\ttransformDirection(m) {\n\t\tfor (let i = 0, l = this.count; i < l; i++) {\n\t\t\t_vector$6.fromBufferAttribute(this, i);\n\n\t\t\t_vector$6.transformDirection(m);\n\n\t\t\tthis.setXYZ(i, _vector$6.x, _vector$6.y, _vector$6.z);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tsetX(index, x) {\n\t\tthis.data.array[index * this.data.stride + this.offset] = x;\n\t\treturn this;\n\t}\n\n\tsetY(index, y) {\n\t\tthis.data.array[index * this.data.stride + this.offset + 1] = y;\n\t\treturn this;\n\t}\n\n\tsetZ(index, z) {\n\t\tthis.data.array[index * this.data.stride + this.offset + 2] = z;\n\t\treturn this;\n\t}\n\n\tsetW(index, w) {\n\t\tthis.data.array[index * this.data.stride + this.offset + 3] = w;\n\t\treturn this;\n\t}\n\n\tgetX(index) {\n\t\treturn this.data.array[index * this.data.stride + this.offset];\n\t}\n\n\tgetY(index) {\n\t\treturn this.data.array[index * this.data.stride + this.offset + 1];\n\t}\n\n\tgetZ(index) {\n\t\treturn this.data.array[index * this.data.stride + this.offset + 2];\n\t}\n\n\tgetW(index) {\n\t\treturn this.data.array[index * this.data.stride + this.offset + 3];\n\t}\n\n\tsetXY(index, x, y) {\n\t\tindex = index * this.data.stride + this.offset;\n\t\tthis.data.array[index + 0] = x;\n\t\tthis.data.array[index + 1] = y;\n\t\treturn this;\n\t}\n\n\tsetXYZ(index, x, y, z) {\n\t\tindex = index * this.data.stride + this.offset;\n\t\tthis.data.array[index + 0] = x;\n\t\tthis.data.array[index + 1] = y;\n\t\tthis.data.array[index + 2] = z;\n\t\treturn this;\n\t}\n\n\tsetXYZW(index, x, y, z, w) {\n\t\tindex = index * this.data.stride + this.offset;\n\t\tthis.data.array[index + 0] = x;\n\t\tthis.data.array[index + 1] = y;\n\t\tthis.data.array[index + 2] = z;\n\t\tthis.data.array[index + 3] = w;\n\t\treturn this;\n\t}\n\n\tclone(data) {\n\t\tif (data === undefined) {\n\t\t\tconsole.log('THREE.InterleavedBufferAttribute.clone(): Cloning an interlaved buffer attribute will deinterleave buffer data.');\n\t\t\tconst array = [];\n\n\t\t\tfor (let i = 0; i < this.count; i++) {\n\t\t\t\tconst index = i * this.data.stride + this.offset;\n\n\t\t\t\tfor (let j = 0; j < this.itemSize; j++) {\n\t\t\t\t\tarray.push(this.data.array[index + j]);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn new BufferAttribute(new this.array.constructor(array), this.itemSize, this.normalized);\n\t\t} else {\n\t\t\tif (data.interleavedBuffers === undefined) {\n\t\t\t\tdata.interleavedBuffers = {};\n\t\t\t}\n\n\t\t\tif (data.interleavedBuffers[this.data.uuid] === undefined) {\n\t\t\t\tdata.interleavedBuffers[this.data.uuid] = this.data.clone(data);\n\t\t\t}\n\n\t\t\treturn new InterleavedBufferAttribute(data.interleavedBuffers[this.data.uuid], this.itemSize, this.offset, this.normalized);\n\t\t}\n\t}\n\n\ttoJSON(data) {\n\t\tif (data === undefined) {\n\t\t\tconsole.log('THREE.InterleavedBufferAttribute.toJSON(): Serializing an interlaved buffer attribute will deinterleave buffer data.');\n\t\t\tconst array = [];\n\n\t\t\tfor (let i = 0; i < this.count; i++) {\n\t\t\t\tconst index = i * this.data.stride + this.offset;\n\n\t\t\t\tfor (let j = 0; j < this.itemSize; j++) {\n\t\t\t\t\tarray.push(this.data.array[index + j]);\n\t\t\t\t}\n\t\t\t} // deinterleave data and save it as an ordinary buffer attribute for now\n\n\n\t\t\treturn {\n\t\t\t\titemSize: this.itemSize,\n\t\t\t\ttype: this.array.constructor.name,\n\t\t\t\tarray: array,\n\t\t\t\tnormalized: this.normalized\n\t\t\t};\n\t\t} else {\n\t\t\t// save as true interlaved attribtue\n\t\t\tif (data.interleavedBuffers === undefined) {\n\t\t\t\tdata.interleavedBuffers = {};\n\t\t\t}\n\n\t\t\tif (data.interleavedBuffers[this.data.uuid] === undefined) {\n\t\t\t\tdata.interleavedBuffers[this.data.uuid] = this.data.toJSON(data);\n\t\t\t}\n\n\t\t\treturn {\n\t\t\t\tisInterleavedBufferAttribute: true,\n\t\t\t\titemSize: this.itemSize,\n\t\t\t\tdata: this.data.uuid,\n\t\t\t\toffset: this.offset,\n\t\t\t\tnormalized: this.normalized\n\t\t\t};\n\t\t}\n\t}\n\n}\n\nclass SpriteMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isSpriteMaterial = true;\n\t\tthis.type = 'SpriteMaterial';\n\t\tthis.color = new Color(0xffffff);\n\t\tthis.map = null;\n\t\tthis.alphaMap = null;\n\t\tthis.rotation = 0;\n\t\tthis.sizeAttenuation = true;\n\t\tthis.transparent = true;\n\t\tthis.fog = true;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.color.copy(source.color);\n\t\tthis.map = source.map;\n\t\tthis.alphaMap = source.alphaMap;\n\t\tthis.rotation = source.rotation;\n\t\tthis.sizeAttenuation = source.sizeAttenuation;\n\t\tthis.fog = source.fog;\n\t\treturn this;\n\t}\n\n}\n\nlet _geometry;\n\nconst _intersectPoint = /*@__PURE__*/new Vector3();\n\nconst _worldScale = /*@__PURE__*/new Vector3();\n\nconst _mvPosition = /*@__PURE__*/new Vector3();\n\nconst _alignedPosition = /*@__PURE__*/new Vector2();\n\nconst _rotatedPosition = /*@__PURE__*/new Vector2();\n\nconst _viewWorldMatrix = /*@__PURE__*/new Matrix4();\n\nconst _vA = /*@__PURE__*/new Vector3();\n\nconst _vB = /*@__PURE__*/new Vector3();\n\nconst _vC = /*@__PURE__*/new Vector3();\n\nconst _uvA = /*@__PURE__*/new Vector2();\n\nconst _uvB = /*@__PURE__*/new Vector2();\n\nconst _uvC = /*@__PURE__*/new Vector2();\n\nclass Sprite extends Object3D {\n\tconstructor(material) {\n\t\tsuper();\n\t\tthis.isSprite = true;\n\t\tthis.type = 'Sprite';\n\n\t\tif (_geometry === undefined) {\n\t\t\t_geometry = new BufferGeometry();\n\t\t\tconst float32Array = new Float32Array([-0.5, -0.5, 0, 0, 0, 0.5, -0.5, 0, 1, 0, 0.5, 0.5, 0, 1, 1, -0.5, 0.5, 0, 0, 1]);\n\t\t\tconst interleavedBuffer = new InterleavedBuffer(float32Array, 5);\n\n\t\t\t_geometry.setIndex([0, 1, 2, 0, 2, 3]);\n\n\t\t\t_geometry.setAttribute('position', new InterleavedBufferAttribute(interleavedBuffer, 3, 0, false));\n\n\t\t\t_geometry.setAttribute('uv', new InterleavedBufferAttribute(interleavedBuffer, 2, 3, false));\n\t\t}\n\n\t\tthis.geometry = _geometry;\n\t\tthis.material = material !== undefined ? material : new SpriteMaterial();\n\t\tthis.center = new Vector2(0.5, 0.5);\n\t}\n\n\traycast(raycaster, intersects) {\n\t\tif (raycaster.camera === null) {\n\t\t\tconsole.error('THREE.Sprite: \"Raycaster.camera\" needs to be set in order to raycast against sprites.');\n\t\t}\n\n\t\t_worldScale.setFromMatrixScale(this.matrixWorld);\n\n\t\t_viewWorldMatrix.copy(raycaster.camera.matrixWorld);\n\n\t\tthis.modelViewMatrix.multiplyMatrices(raycaster.camera.matrixWorldInverse, this.matrixWorld);\n\n\t\t_mvPosition.setFromMatrixPosition(this.modelViewMatrix);\n\n\t\tif (raycaster.camera.isPerspectiveCamera && this.material.sizeAttenuation === false) {\n\t\t\t_worldScale.multiplyScalar(-_mvPosition.z);\n\t\t}\n\n\t\tconst rotation = this.material.rotation;\n\t\tlet sin, cos;\n\n\t\tif (rotation !== 0) {\n\t\t\tcos = Math.cos(rotation);\n\t\t\tsin = Math.sin(rotation);\n\t\t}\n\n\t\tconst center = this.center;\n\t\ttransformVertex(_vA.set(-0.5, -0.5, 0), _mvPosition, center, _worldScale, sin, cos);\n\t\ttransformVertex(_vB.set(0.5, -0.5, 0), _mvPosition, center, _worldScale, sin, cos);\n\t\ttransformVertex(_vC.set(0.5, 0.5, 0), _mvPosition, center, _worldScale, sin, cos);\n\n\t\t_uvA.set(0, 0);\n\n\t\t_uvB.set(1, 0);\n\n\t\t_uvC.set(1, 1); // check first triangle\n\n\n\t\tlet intersect = raycaster.ray.intersectTriangle(_vA, _vB, _vC, false, _intersectPoint);\n\n\t\tif (intersect === null) {\n\t\t\t// check second triangle\n\t\t\ttransformVertex(_vB.set(-0.5, 0.5, 0), _mvPosition, center, _worldScale, sin, cos);\n\n\t\t\t_uvB.set(0, 1);\n\n\t\t\tintersect = raycaster.ray.intersectTriangle(_vA, _vC, _vB, false, _intersectPoint);\n\n\t\t\tif (intersect === null) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\tconst distance = raycaster.ray.origin.distanceTo(_intersectPoint);\n\t\tif (distance < raycaster.near || distance > raycaster.far) return;\n\t\tintersects.push({\n\t\t\tdistance: distance,\n\t\t\tpoint: _intersectPoint.clone(),\n\t\t\tuv: Triangle.getUV(_intersectPoint, _vA, _vB, _vC, _uvA, _uvB, _uvC, new Vector2()),\n\t\t\tface: null,\n\t\t\tobject: this\n\t\t});\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tif (source.center !== undefined) this.center.copy(source.center);\n\t\tthis.material = source.material;\n\t\treturn this;\n\t}\n\n}\n\nfunction transformVertex(vertexPosition, mvPosition, center, scale, sin, cos) {\n\t// compute position in camera space\n\t_alignedPosition.subVectors(vertexPosition, center).addScalar(0.5).multiply(scale); // to check if rotation is not zero\n\n\n\tif (sin !== undefined) {\n\t\t_rotatedPosition.x = cos * _alignedPosition.x - sin * _alignedPosition.y;\n\t\t_rotatedPosition.y = sin * _alignedPosition.x + cos * _alignedPosition.y;\n\t} else {\n\t\t_rotatedPosition.copy(_alignedPosition);\n\t}\n\n\tvertexPosition.copy(mvPosition);\n\tvertexPosition.x += _rotatedPosition.x;\n\tvertexPosition.y += _rotatedPosition.y; // transform to world space\n\n\tvertexPosition.applyMatrix4(_viewWorldMatrix);\n}\n\nconst _v1$2 = /*@__PURE__*/new Vector3();\n\nconst _v2$1 = /*@__PURE__*/new Vector3();\n\nclass LOD extends Object3D {\n\tconstructor() {\n\t\tsuper();\n\t\tthis._currentLevel = 0;\n\t\tthis.type = 'LOD';\n\t\tObject.defineProperties(this, {\n\t\t\tlevels: {\n\t\t\t\tenumerable: true,\n\t\t\t\tvalue: []\n\t\t\t},\n\t\t\tisLOD: {\n\t\t\t\tvalue: true\n\t\t\t}\n\t\t});\n\t\tthis.autoUpdate = true;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source, false);\n\t\tconst levels = source.levels;\n\n\t\tfor (let i = 0, l = levels.length; i < l; i++) {\n\t\t\tconst level = levels[i];\n\t\t\tthis.addLevel(level.object.clone(), level.distance);\n\t\t}\n\n\t\tthis.autoUpdate = source.autoUpdate;\n\t\treturn this;\n\t}\n\n\taddLevel(object, distance = 0) {\n\t\tdistance = Math.abs(distance);\n\t\tconst levels = this.levels;\n\t\tlet l;\n\n\t\tfor (l = 0; l < levels.length; l++) {\n\t\t\tif (distance < levels[l].distance) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tlevels.splice(l, 0, {\n\t\t\tdistance: distance,\n\t\t\tobject: object\n\t\t});\n\t\tthis.add(object);\n\t\treturn this;\n\t}\n\n\tgetCurrentLevel() {\n\t\treturn this._currentLevel;\n\t}\n\n\tgetObjectForDistance(distance) {\n\t\tconst levels = this.levels;\n\n\t\tif (levels.length > 0) {\n\t\t\tlet i, l;\n\n\t\t\tfor (i = 1, l = levels.length; i < l; i++) {\n\t\t\t\tif (distance < levels[i].distance) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn levels[i - 1].object;\n\t\t}\n\n\t\treturn null;\n\t}\n\n\traycast(raycaster, intersects) {\n\t\tconst levels = this.levels;\n\n\t\tif (levels.length > 0) {\n\t\t\t_v1$2.setFromMatrixPosition(this.matrixWorld);\n\n\t\t\tconst distance = raycaster.ray.origin.distanceTo(_v1$2);\n\t\t\tthis.getObjectForDistance(distance).raycast(raycaster, intersects);\n\t\t}\n\t}\n\n\tupdate(camera) {\n\t\tconst levels = this.levels;\n\n\t\tif (levels.length > 1) {\n\t\t\t_v1$2.setFromMatrixPosition(camera.matrixWorld);\n\n\t\t\t_v2$1.setFromMatrixPosition(this.matrixWorld);\n\n\t\t\tconst distance = _v1$2.distanceTo(_v2$1) / camera.zoom;\n\t\t\tlevels[0].object.visible = true;\n\t\t\tlet i, l;\n\n\t\t\tfor (i = 1, l = levels.length; i < l; i++) {\n\t\t\t\tif (distance >= levels[i].distance) {\n\t\t\t\t\tlevels[i - 1].object.visible = false;\n\t\t\t\t\tlevels[i].object.visible = true;\n\t\t\t\t} else {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis._currentLevel = i - 1;\n\n\t\t\tfor (; i < l; i++) {\n\t\t\t\tlevels[i].object.visible = false;\n\t\t\t}\n\t\t}\n\t}\n\n\ttoJSON(meta) {\n\t\tconst data = super.toJSON(meta);\n\t\tif (this.autoUpdate === false) data.object.autoUpdate = false;\n\t\tdata.object.levels = [];\n\t\tconst levels = this.levels;\n\n\t\tfor (let i = 0, l = levels.length; i < l; i++) {\n\t\t\tconst level = levels[i];\n\t\t\tdata.object.levels.push({\n\t\t\t\tobject: level.object.uuid,\n\t\t\t\tdistance: level.distance\n\t\t\t});\n\t\t}\n\n\t\treturn data;\n\t}\n\n}\n\nconst _basePosition = /*@__PURE__*/new Vector3();\n\nconst _skinIndex = /*@__PURE__*/new Vector4();\n\nconst _skinWeight = /*@__PURE__*/new Vector4();\n\nconst _vector$5 = /*@__PURE__*/new Vector3();\n\nconst _matrix = /*@__PURE__*/new Matrix4();\n\nclass SkinnedMesh extends Mesh {\n\tconstructor(geometry, material) {\n\t\tsuper(geometry, material);\n\t\tthis.isSkinnedMesh = true;\n\t\tthis.type = 'SkinnedMesh';\n\t\tthis.bindMode = 'attached';\n\t\tthis.bindMatrix = new Matrix4();\n\t\tthis.bindMatrixInverse = new Matrix4();\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tthis.bindMode = source.bindMode;\n\t\tthis.bindMatrix.copy(source.bindMatrix);\n\t\tthis.bindMatrixInverse.copy(source.bindMatrixInverse);\n\t\tthis.skeleton = source.skeleton;\n\t\treturn this;\n\t}\n\n\tbind(skeleton, bindMatrix) {\n\t\tthis.skeleton = skeleton;\n\n\t\tif (bindMatrix === undefined) {\n\t\t\tthis.updateMatrixWorld(true);\n\t\t\tthis.skeleton.calculateInverses();\n\t\t\tbindMatrix = this.matrixWorld;\n\t\t}\n\n\t\tthis.bindMatrix.copy(bindMatrix);\n\t\tthis.bindMatrixInverse.copy(bindMatrix).invert();\n\t}\n\n\tpose() {\n\t\tthis.skeleton.pose();\n\t}\n\n\tnormalizeSkinWeights() {\n\t\tconst vector = new Vector4();\n\t\tconst skinWeight = this.geometry.attributes.skinWeight;\n\n\t\tfor (let i = 0, l = skinWeight.count; i < l; i++) {\n\t\t\tvector.fromBufferAttribute(skinWeight, i);\n\t\t\tconst scale = 1.0 / vector.manhattanLength();\n\n\t\t\tif (scale !== Infinity) {\n\t\t\t\tvector.multiplyScalar(scale);\n\t\t\t} else {\n\t\t\t\tvector.set(1, 0, 0, 0); // do something reasonable\n\t\t\t}\n\n\t\t\tskinWeight.setXYZW(i, vector.x, vector.y, vector.z, vector.w);\n\t\t}\n\t}\n\n\tupdateMatrixWorld(force) {\n\t\tsuper.updateMatrixWorld(force);\n\n\t\tif (this.bindMode === 'attached') {\n\t\t\tthis.bindMatrixInverse.copy(this.matrixWorld).invert();\n\t\t} else if (this.bindMode === 'detached') {\n\t\t\tthis.bindMatrixInverse.copy(this.bindMatrix).invert();\n\t\t} else {\n\t\t\tconsole.warn('THREE.SkinnedMesh: Unrecognized bindMode: ' + this.bindMode);\n\t\t}\n\t}\n\n\tboneTransform(index, target) {\n\t\tconst skeleton = this.skeleton;\n\t\tconst geometry = this.geometry;\n\n\t\t_skinIndex.fromBufferAttribute(geometry.attributes.skinIndex, index);\n\n\t\t_skinWeight.fromBufferAttribute(geometry.attributes.skinWeight, index);\n\n\t\t_basePosition.copy(target).applyMatrix4(this.bindMatrix);\n\n\t\ttarget.set(0, 0, 0);\n\n\t\tfor (let i = 0; i < 4; i++) {\n\t\t\tconst weight = _skinWeight.getComponent(i);\n\n\t\t\tif (weight !== 0) {\n\t\t\t\tconst boneIndex = _skinIndex.getComponent(i);\n\n\t\t\t\t_matrix.multiplyMatrices(skeleton.bones[boneIndex].matrixWorld, skeleton.boneInverses[boneIndex]);\n\n\t\t\t\ttarget.addScaledVector(_vector$5.copy(_basePosition).applyMatrix4(_matrix), weight);\n\t\t\t}\n\t\t}\n\n\t\treturn target.applyMatrix4(this.bindMatrixInverse);\n\t}\n\n}\n\nclass Bone extends Object3D {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.isBone = true;\n\t\tthis.type = 'Bone';\n\t}\n\n}\n\nclass DataTexture extends Texture {\n\tconstructor(data = null, width = 1, height = 1, format, type, mapping, wrapS, wrapT, magFilter = NearestFilter, minFilter = NearestFilter, anisotropy, encoding) {\n\t\tsuper(null, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding);\n\t\tthis.isDataTexture = true;\n\t\tthis.image = {\n\t\t\tdata: data,\n\t\t\twidth: width,\n\t\t\theight: height\n\t\t};\n\t\tthis.generateMipmaps = false;\n\t\tthis.flipY = false;\n\t\tthis.unpackAlignment = 1;\n\t}\n\n}\n\nconst _offsetMatrix = /*@__PURE__*/new Matrix4();\n\nconst _identityMatrix = /*@__PURE__*/new Matrix4();\n\nclass Skeleton {\n\tconstructor(bones = [], boneInverses = []) {\n\t\tthis.uuid = generateUUID();\n\t\tthis.bones = bones.slice(0);\n\t\tthis.boneInverses = boneInverses;\n\t\tthis.boneMatrices = null;\n\t\tthis.boneTexture = null;\n\t\tthis.boneTextureSize = 0;\n\t\tthis.frame = -1;\n\t\tthis.init();\n\t}\n\n\tinit() {\n\t\tconst bones = this.bones;\n\t\tconst boneInverses = this.boneInverses;\n\t\tthis.boneMatrices = new Float32Array(bones.length * 16); // calculate inverse bone matrices if necessary\n\n\t\tif (boneInverses.length === 0) {\n\t\t\tthis.calculateInverses();\n\t\t} else {\n\t\t\t// handle special case\n\t\t\tif (bones.length !== boneInverses.length) {\n\t\t\t\tconsole.warn('THREE.Skeleton: Number of inverse bone matrices does not match amount of bones.');\n\t\t\t\tthis.boneInverses = [];\n\n\t\t\t\tfor (let i = 0, il = this.bones.length; i < il; i++) {\n\t\t\t\t\tthis.boneInverses.push(new Matrix4());\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tcalculateInverses() {\n\t\tthis.boneInverses.length = 0;\n\n\t\tfor (let i = 0, il = this.bones.length; i < il; i++) {\n\t\t\tconst inverse = new Matrix4();\n\n\t\t\tif (this.bones[i]) {\n\t\t\t\tinverse.copy(this.bones[i].matrixWorld).invert();\n\t\t\t}\n\n\t\t\tthis.boneInverses.push(inverse);\n\t\t}\n\t}\n\n\tpose() {\n\t\t// recover the bind-time world matrices\n\t\tfor (let i = 0, il = this.bones.length; i < il; i++) {\n\t\t\tconst bone = this.bones[i];\n\n\t\t\tif (bone) {\n\t\t\t\tbone.matrixWorld.copy(this.boneInverses[i]).invert();\n\t\t\t}\n\t\t} // compute the local matrices, positions, rotations and scales\n\n\n\t\tfor (let i = 0, il = this.bones.length; i < il; i++) {\n\t\t\tconst bone = this.bones[i];\n\n\t\t\tif (bone) {\n\t\t\t\tif (bone.parent && bone.parent.isBone) {\n\t\t\t\t\tbone.matrix.copy(bone.parent.matrixWorld).invert();\n\t\t\t\t\tbone.matrix.multiply(bone.matrixWorld);\n\t\t\t\t} else {\n\t\t\t\t\tbone.matrix.copy(bone.matrixWorld);\n\t\t\t\t}\n\n\t\t\t\tbone.matrix.decompose(bone.position, bone.quaternion, bone.scale);\n\t\t\t}\n\t\t}\n\t}\n\n\tupdate() {\n\t\tconst bones = this.bones;\n\t\tconst boneInverses = this.boneInverses;\n\t\tconst boneMatrices = this.boneMatrices;\n\t\tconst boneTexture = this.boneTexture; // flatten bone matrices to array\n\n\t\tfor (let i = 0, il = bones.length; i < il; i++) {\n\t\t\t// compute the offset between the current and the original transform\n\t\t\tconst matrix = bones[i] ? bones[i].matrixWorld : _identityMatrix;\n\n\t\t\t_offsetMatrix.multiplyMatrices(matrix, boneInverses[i]);\n\n\t\t\t_offsetMatrix.toArray(boneMatrices, i * 16);\n\t\t}\n\n\t\tif (boneTexture !== null) {\n\t\t\tboneTexture.needsUpdate = true;\n\t\t}\n\t}\n\n\tclone() {\n\t\treturn new Skeleton(this.bones, this.boneInverses);\n\t}\n\n\tcomputeBoneTexture() {\n\t\t// layout (1 matrix = 4 pixels)\n\t\t//\t\t\tRGBA RGBA RGBA RGBA (=> column1, column2, column3, column4)\n\t\t//\twith\t8x8\tpixel texture max\t 16 bones * 4 pixels =\t(8 * 8)\n\t\t//\t\t\t 16x16 pixel texture max\t 64 bones * 4 pixels = (16 * 16)\n\t\t//\t\t\t 32x32 pixel texture max\t256 bones * 4 pixels = (32 * 32)\n\t\t//\t\t\t 64x64 pixel texture max 1024 bones * 4 pixels = (64 * 64)\n\t\tlet size = Math.sqrt(this.bones.length * 4); // 4 pixels needed for 1 matrix\n\n\t\tsize = ceilPowerOfTwo(size);\n\t\tsize = Math.max(size, 4);\n\t\tconst boneMatrices = new Float32Array(size * size * 4); // 4 floats per RGBA pixel\n\n\t\tboneMatrices.set(this.boneMatrices); // copy current values\n\n\t\tconst boneTexture = new DataTexture(boneMatrices, size, size, RGBAFormat, FloatType);\n\t\tboneTexture.needsUpdate = true;\n\t\tthis.boneMatrices = boneMatrices;\n\t\tthis.boneTexture = boneTexture;\n\t\tthis.boneTextureSize = size;\n\t\treturn this;\n\t}\n\n\tgetBoneByName(name) {\n\t\tfor (let i = 0, il = this.bones.length; i < il; i++) {\n\t\t\tconst bone = this.bones[i];\n\n\t\t\tif (bone.name === name) {\n\t\t\t\treturn bone;\n\t\t\t}\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\tdispose() {\n\t\tif (this.boneTexture !== null) {\n\t\t\tthis.boneTexture.dispose();\n\t\t\tthis.boneTexture = null;\n\t\t}\n\t}\n\n\tfromJSON(json, bones) {\n\t\tthis.uuid = json.uuid;\n\n\t\tfor (let i = 0, l = json.bones.length; i < l; i++) {\n\t\t\tconst uuid = json.bones[i];\n\t\t\tlet bone = bones[uuid];\n\n\t\t\tif (bone === undefined) {\n\t\t\t\tconsole.warn('THREE.Skeleton: No bone found with UUID:', uuid);\n\t\t\t\tbone = new Bone();\n\t\t\t}\n\n\t\t\tthis.bones.push(bone);\n\t\t\tthis.boneInverses.push(new Matrix4().fromArray(json.boneInverses[i]));\n\t\t}\n\n\t\tthis.init();\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Skeleton',\n\t\t\t\tgenerator: 'Skeleton.toJSON'\n\t\t\t},\n\t\t\tbones: [],\n\t\t\tboneInverses: []\n\t\t};\n\t\tdata.uuid = this.uuid;\n\t\tconst bones = this.bones;\n\t\tconst boneInverses = this.boneInverses;\n\n\t\tfor (let i = 0, l = bones.length; i < l; i++) {\n\t\t\tconst bone = bones[i];\n\t\t\tdata.bones.push(bone.uuid);\n\t\t\tconst boneInverse = boneInverses[i];\n\t\t\tdata.boneInverses.push(boneInverse.toArray());\n\t\t}\n\n\t\treturn data;\n\t}\n\n}\n\nclass InstancedBufferAttribute extends BufferAttribute {\n\tconstructor(array, itemSize, normalized, meshPerAttribute = 1) {\n\t\tif (typeof normalized === 'number') {\n\t\t\tmeshPerAttribute = normalized;\n\t\t\tnormalized = false;\n\t\t\tconsole.error('THREE.InstancedBufferAttribute: The constructor now expects normalized as the third argument.');\n\t\t}\n\n\t\tsuper(array, itemSize, normalized);\n\t\tthis.isInstancedBufferAttribute = true;\n\t\tthis.meshPerAttribute = meshPerAttribute;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.meshPerAttribute = source.meshPerAttribute;\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.meshPerAttribute = this.meshPerAttribute;\n\t\tdata.isInstancedBufferAttribute = true;\n\t\treturn data;\n\t}\n\n}\n\nconst _instanceLocalMatrix = /*@__PURE__*/new Matrix4();\n\nconst _instanceWorldMatrix = /*@__PURE__*/new Matrix4();\n\nconst _instanceIntersects = [];\n\nconst _mesh = /*@__PURE__*/new Mesh();\n\nclass InstancedMesh extends Mesh {\n\tconstructor(geometry, material, count) {\n\t\tsuper(geometry, material);\n\t\tthis.isInstancedMesh = true;\n\t\tthis.instanceMatrix = new InstancedBufferAttribute(new Float32Array(count * 16), 16);\n\t\tthis.instanceColor = null;\n\t\tthis.count = count;\n\t\tthis.frustumCulled = false;\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tthis.instanceMatrix.copy(source.instanceMatrix);\n\t\tif (source.instanceColor !== null) this.instanceColor = source.instanceColor.clone();\n\t\tthis.count = source.count;\n\t\treturn this;\n\t}\n\n\tgetColorAt(index, color) {\n\t\tcolor.fromArray(this.instanceColor.array, index * 3);\n\t}\n\n\tgetMatrixAt(index, matrix) {\n\t\tmatrix.fromArray(this.instanceMatrix.array, index * 16);\n\t}\n\n\traycast(raycaster, intersects) {\n\t\tconst matrixWorld = this.matrixWorld;\n\t\tconst raycastTimes = this.count;\n\t\t_mesh.geometry = this.geometry;\n\t\t_mesh.material = this.material;\n\t\tif (_mesh.material === undefined) return;\n\n\t\tfor (let instanceId = 0; instanceId < raycastTimes; instanceId++) {\n\t\t\t// calculate the world matrix for each instance\n\t\t\tthis.getMatrixAt(instanceId, _instanceLocalMatrix);\n\n\t\t\t_instanceWorldMatrix.multiplyMatrices(matrixWorld, _instanceLocalMatrix); // the mesh represents this single instance\n\n\n\t\t\t_mesh.matrixWorld = _instanceWorldMatrix;\n\n\t\t\t_mesh.raycast(raycaster, _instanceIntersects); // process the result of raycast\n\n\n\t\t\tfor (let i = 0, l = _instanceIntersects.length; i < l; i++) {\n\t\t\t\tconst intersect = _instanceIntersects[i];\n\t\t\t\tintersect.instanceId = instanceId;\n\t\t\t\tintersect.object = this;\n\t\t\t\tintersects.push(intersect);\n\t\t\t}\n\n\t\t\t_instanceIntersects.length = 0;\n\t\t}\n\t}\n\n\tsetColorAt(index, color) {\n\t\tif (this.instanceColor === null) {\n\t\t\tthis.instanceColor = new InstancedBufferAttribute(new Float32Array(this.instanceMatrix.count * 3), 3);\n\t\t}\n\n\t\tcolor.toArray(this.instanceColor.array, index * 3);\n\t}\n\n\tsetMatrixAt(index, matrix) {\n\t\tmatrix.toArray(this.instanceMatrix.array, index * 16);\n\t}\n\n\tupdateMorphTargets() {}\n\n\tdispose() {\n\t\tthis.dispatchEvent({\n\t\t\ttype: 'dispose'\n\t\t});\n\t}\n\n}\n\nclass LineBasicMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isLineBasicMaterial = true;\n\t\tthis.type = 'LineBasicMaterial';\n\t\tthis.color = new Color(0xffffff);\n\t\tthis.linewidth = 1;\n\t\tthis.linecap = 'round';\n\t\tthis.linejoin = 'round';\n\t\tthis.fog = true;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.color.copy(source.color);\n\t\tthis.linewidth = source.linewidth;\n\t\tthis.linecap = source.linecap;\n\t\tthis.linejoin = source.linejoin;\n\t\tthis.fog = source.fog;\n\t\treturn this;\n\t}\n\n}\n\nconst _start$1 = /*@__PURE__*/new Vector3();\n\nconst _end$1 = /*@__PURE__*/new Vector3();\n\nconst _inverseMatrix$1 = /*@__PURE__*/new Matrix4();\n\nconst _ray$1 = /*@__PURE__*/new Ray();\n\nconst _sphere$1 = /*@__PURE__*/new Sphere();\n\nclass Line extends Object3D {\n\tconstructor(geometry = new BufferGeometry(), material = new LineBasicMaterial()) {\n\t\tsuper();\n\t\tthis.isLine = true;\n\t\tthis.type = 'Line';\n\t\tthis.geometry = geometry;\n\t\tthis.material = material;\n\t\tthis.updateMorphTargets();\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tthis.material = source.material;\n\t\tthis.geometry = source.geometry;\n\t\treturn this;\n\t}\n\n\tcomputeLineDistances() {\n\t\tconst geometry = this.geometry; // we assume non-indexed geometry\n\n\t\tif (geometry.index === null) {\n\t\t\tconst positionAttribute = geometry.attributes.position;\n\t\t\tconst lineDistances = [0];\n\n\t\t\tfor (let i = 1, l = positionAttribute.count; i < l; i++) {\n\t\t\t\t_start$1.fromBufferAttribute(positionAttribute, i - 1);\n\n\t\t\t\t_end$1.fromBufferAttribute(positionAttribute, i);\n\n\t\t\t\tlineDistances[i] = lineDistances[i - 1];\n\t\t\t\tlineDistances[i] += _start$1.distanceTo(_end$1);\n\t\t\t}\n\n\t\t\tgeometry.setAttribute('lineDistance', new Float32BufferAttribute(lineDistances, 1));\n\t\t} else {\n\t\t\tconsole.warn('THREE.Line.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.');\n\t\t}\n\n\t\treturn this;\n\t}\n\n\traycast(raycaster, intersects) {\n\t\tconst geometry = this.geometry;\n\t\tconst matrixWorld = this.matrixWorld;\n\t\tconst threshold = raycaster.params.Line.threshold;\n\t\tconst drawRange = geometry.drawRange; // Checking boundingSphere distance to ray\n\n\t\tif (geometry.boundingSphere === null) geometry.computeBoundingSphere();\n\n\t\t_sphere$1.copy(geometry.boundingSphere);\n\n\t\t_sphere$1.applyMatrix4(matrixWorld);\n\n\t\t_sphere$1.radius += threshold;\n\t\tif (raycaster.ray.intersectsSphere(_sphere$1) === false) return; //\n\n\t\t_inverseMatrix$1.copy(matrixWorld).invert();\n\n\t\t_ray$1.copy(raycaster.ray).applyMatrix4(_inverseMatrix$1);\n\n\t\tconst localThreshold = threshold / ((this.scale.x + this.scale.y + this.scale.z) / 3);\n\t\tconst localThresholdSq = localThreshold * localThreshold;\n\t\tconst vStart = new Vector3();\n\t\tconst vEnd = new Vector3();\n\t\tconst interSegment = new Vector3();\n\t\tconst interRay = new Vector3();\n\t\tconst step = this.isLineSegments ? 2 : 1;\n\t\tconst index = geometry.index;\n\t\tconst attributes = geometry.attributes;\n\t\tconst positionAttribute = attributes.position;\n\n\t\tif (index !== null) {\n\t\t\tconst start = Math.max(0, drawRange.start);\n\t\t\tconst end = Math.min(index.count, drawRange.start + drawRange.count);\n\n\t\t\tfor (let i = start, l = end - 1; i < l; i += step) {\n\t\t\t\tconst a = index.getX(i);\n\t\t\t\tconst b = index.getX(i + 1);\n\t\t\t\tvStart.fromBufferAttribute(positionAttribute, a);\n\t\t\t\tvEnd.fromBufferAttribute(positionAttribute, b);\n\n\t\t\t\tconst distSq = _ray$1.distanceSqToSegment(vStart, vEnd, interRay, interSegment);\n\n\t\t\t\tif (distSq > localThresholdSq) continue;\n\t\t\t\tinterRay.applyMatrix4(this.matrixWorld); //Move back to world space for distance calculation\n\n\t\t\t\tconst distance = raycaster.ray.origin.distanceTo(interRay);\n\t\t\t\tif (distance < raycaster.near || distance > raycaster.far) continue;\n\t\t\t\tintersects.push({\n\t\t\t\t\tdistance: distance,\n\t\t\t\t\t// What do we want? intersection point on the ray or on the segment??\n\t\t\t\t\t// point: raycaster.ray.at( distance ),\n\t\t\t\t\tpoint: interSegment.clone().applyMatrix4(this.matrixWorld),\n\t\t\t\t\tindex: i,\n\t\t\t\t\tface: null,\n\t\t\t\t\tfaceIndex: null,\n\t\t\t\t\tobject: this\n\t\t\t\t});\n\t\t\t}\n\t\t} else {\n\t\t\tconst start = Math.max(0, drawRange.start);\n\t\t\tconst end = Math.min(positionAttribute.count, drawRange.start + drawRange.count);\n\n\t\t\tfor (let i = start, l = end - 1; i < l; i += step) {\n\t\t\t\tvStart.fromBufferAttribute(positionAttribute, i);\n\t\t\t\tvEnd.fromBufferAttribute(positionAttribute, i + 1);\n\n\t\t\t\tconst distSq = _ray$1.distanceSqToSegment(vStart, vEnd, interRay, interSegment);\n\n\t\t\t\tif (distSq > localThresholdSq) continue;\n\t\t\t\tinterRay.applyMatrix4(this.matrixWorld); //Move back to world space for distance calculation\n\n\t\t\t\tconst distance = raycaster.ray.origin.distanceTo(interRay);\n\t\t\t\tif (distance < raycaster.near || distance > raycaster.far) continue;\n\t\t\t\tintersects.push({\n\t\t\t\t\tdistance: distance,\n\t\t\t\t\t// What do we want? intersection point on the ray or on the segment??\n\t\t\t\t\t// point: raycaster.ray.at( distance ),\n\t\t\t\t\tpoint: interSegment.clone().applyMatrix4(this.matrixWorld),\n\t\t\t\t\tindex: i,\n\t\t\t\t\tface: null,\n\t\t\t\t\tfaceIndex: null,\n\t\t\t\t\tobject: this\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}\n\n\tupdateMorphTargets() {\n\t\tconst geometry = this.geometry;\n\t\tconst morphAttributes = geometry.morphAttributes;\n\t\tconst keys = Object.keys(morphAttributes);\n\n\t\tif (keys.length > 0) {\n\t\t\tconst morphAttribute = morphAttributes[keys[0]];\n\n\t\t\tif (morphAttribute !== undefined) {\n\t\t\t\tthis.morphTargetInfluences = [];\n\t\t\t\tthis.morphTargetDictionary = {};\n\n\t\t\t\tfor (let m = 0, ml = morphAttribute.length; m < ml; m++) {\n\t\t\t\t\tconst name = morphAttribute[m].name || String(m);\n\t\t\t\t\tthis.morphTargetInfluences.push(0);\n\t\t\t\t\tthis.morphTargetDictionary[name] = m;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n}\n\nconst _start = /*@__PURE__*/new Vector3();\n\nconst _end = /*@__PURE__*/new Vector3();\n\nclass LineSegments extends Line {\n\tconstructor(geometry, material) {\n\t\tsuper(geometry, material);\n\t\tthis.isLineSegments = true;\n\t\tthis.type = 'LineSegments';\n\t}\n\n\tcomputeLineDistances() {\n\t\tconst geometry = this.geometry; // we assume non-indexed geometry\n\n\t\tif (geometry.index === null) {\n\t\t\tconst positionAttribute = geometry.attributes.position;\n\t\t\tconst lineDistances = [];\n\n\t\t\tfor (let i = 0, l = positionAttribute.count; i < l; i += 2) {\n\t\t\t\t_start.fromBufferAttribute(positionAttribute, i);\n\n\t\t\t\t_end.fromBufferAttribute(positionAttribute, i + 1);\n\n\t\t\t\tlineDistances[i] = i === 0 ? 0 : lineDistances[i - 1];\n\t\t\t\tlineDistances[i + 1] = lineDistances[i] + _start.distanceTo(_end);\n\t\t\t}\n\n\t\t\tgeometry.setAttribute('lineDistance', new Float32BufferAttribute(lineDistances, 1));\n\t\t} else {\n\t\t\tconsole.warn('THREE.LineSegments.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.');\n\t\t}\n\n\t\treturn this;\n\t}\n\n}\n\nclass LineLoop extends Line {\n\tconstructor(geometry, material) {\n\t\tsuper(geometry, material);\n\t\tthis.isLineLoop = true;\n\t\tthis.type = 'LineLoop';\n\t}\n\n}\n\nclass PointsMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isPointsMaterial = true;\n\t\tthis.type = 'PointsMaterial';\n\t\tthis.color = new Color(0xffffff);\n\t\tthis.map = null;\n\t\tthis.alphaMap = null;\n\t\tthis.size = 1;\n\t\tthis.sizeAttenuation = true;\n\t\tthis.fog = true;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.color.copy(source.color);\n\t\tthis.map = source.map;\n\t\tthis.alphaMap = source.alphaMap;\n\t\tthis.size = source.size;\n\t\tthis.sizeAttenuation = source.sizeAttenuation;\n\t\tthis.fog = source.fog;\n\t\treturn this;\n\t}\n\n}\n\nconst _inverseMatrix = /*@__PURE__*/new Matrix4();\n\nconst _ray = /*@__PURE__*/new Ray();\n\nconst _sphere = /*@__PURE__*/new Sphere();\n\nconst _position$2 = /*@__PURE__*/new Vector3();\n\nclass Points extends Object3D {\n\tconstructor(geometry = new BufferGeometry(), material = new PointsMaterial()) {\n\t\tsuper();\n\t\tthis.isPoints = true;\n\t\tthis.type = 'Points';\n\t\tthis.geometry = geometry;\n\t\tthis.material = material;\n\t\tthis.updateMorphTargets();\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tthis.material = source.material;\n\t\tthis.geometry = source.geometry;\n\t\treturn this;\n\t}\n\n\traycast(raycaster, intersects) {\n\t\tconst geometry = this.geometry;\n\t\tconst matrixWorld = this.matrixWorld;\n\t\tconst threshold = raycaster.params.Points.threshold;\n\t\tconst drawRange = geometry.drawRange; // Checking boundingSphere distance to ray\n\n\t\tif (geometry.boundingSphere === null) geometry.computeBoundingSphere();\n\n\t\t_sphere.copy(geometry.boundingSphere);\n\n\t\t_sphere.applyMatrix4(matrixWorld);\n\n\t\t_sphere.radius += threshold;\n\t\tif (raycaster.ray.intersectsSphere(_sphere) === false) return; //\n\n\t\t_inverseMatrix.copy(matrixWorld).invert();\n\n\t\t_ray.copy(raycaster.ray).applyMatrix4(_inverseMatrix);\n\n\t\tconst localThreshold = threshold / ((this.scale.x + this.scale.y + this.scale.z) / 3);\n\t\tconst localThresholdSq = localThreshold * localThreshold;\n\t\tconst index = geometry.index;\n\t\tconst attributes = geometry.attributes;\n\t\tconst positionAttribute = attributes.position;\n\n\t\tif (index !== null) {\n\t\t\tconst start = Math.max(0, drawRange.start);\n\t\t\tconst end = Math.min(index.count, drawRange.start + drawRange.count);\n\n\t\t\tfor (let i = start, il = end; i < il; i++) {\n\t\t\t\tconst a = index.getX(i);\n\n\t\t\t\t_position$2.fromBufferAttribute(positionAttribute, a);\n\n\t\t\t\ttestPoint(_position$2, a, localThresholdSq, matrixWorld, raycaster, intersects, this);\n\t\t\t}\n\t\t} else {\n\t\t\tconst start = Math.max(0, drawRange.start);\n\t\t\tconst end = Math.min(positionAttribute.count, drawRange.start + drawRange.count);\n\n\t\t\tfor (let i = start, l = end; i < l; i++) {\n\t\t\t\t_position$2.fromBufferAttribute(positionAttribute, i);\n\n\t\t\t\ttestPoint(_position$2, i, localThresholdSq, matrixWorld, raycaster, intersects, this);\n\t\t\t}\n\t\t}\n\t}\n\n\tupdateMorphTargets() {\n\t\tconst geometry = this.geometry;\n\t\tconst morphAttributes = geometry.morphAttributes;\n\t\tconst keys = Object.keys(morphAttributes);\n\n\t\tif (keys.length > 0) {\n\t\t\tconst morphAttribute = morphAttributes[keys[0]];\n\n\t\t\tif (morphAttribute !== undefined) {\n\t\t\t\tthis.morphTargetInfluences = [];\n\t\t\t\tthis.morphTargetDictionary = {};\n\n\t\t\t\tfor (let m = 0, ml = morphAttribute.length; m < ml; m++) {\n\t\t\t\t\tconst name = morphAttribute[m].name || String(m);\n\t\t\t\t\tthis.morphTargetInfluences.push(0);\n\t\t\t\t\tthis.morphTargetDictionary[name] = m;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n}\n\nfunction testPoint(point, index, localThresholdSq, matrixWorld, raycaster, intersects, object) {\n\tconst rayPointDistanceSq = _ray.distanceSqToPoint(point);\n\n\tif (rayPointDistanceSq < localThresholdSq) {\n\t\tconst intersectPoint = new Vector3();\n\n\t\t_ray.closestPointToPoint(point, intersectPoint);\n\n\t\tintersectPoint.applyMatrix4(matrixWorld);\n\t\tconst distance = raycaster.ray.origin.distanceTo(intersectPoint);\n\t\tif (distance < raycaster.near || distance > raycaster.far) return;\n\t\tintersects.push({\n\t\t\tdistance: distance,\n\t\t\tdistanceToRay: Math.sqrt(rayPointDistanceSq),\n\t\t\tpoint: intersectPoint,\n\t\t\tindex: index,\n\t\t\tface: null,\n\t\t\tobject: object\n\t\t});\n\t}\n}\n\nclass VideoTexture extends Texture {\n\tconstructor(video, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy) {\n\t\tsuper(video, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy);\n\t\tthis.isVideoTexture = true;\n\t\tthis.minFilter = minFilter !== undefined ? minFilter : LinearFilter;\n\t\tthis.magFilter = magFilter !== undefined ? magFilter : LinearFilter;\n\t\tthis.generateMipmaps = false;\n\t\tconst scope = this;\n\n\t\tfunction updateVideo() {\n\t\t\tscope.needsUpdate = true;\n\t\t\tvideo.requestVideoFrameCallback(updateVideo);\n\t\t}\n\n\t\tif ('requestVideoFrameCallback' in video) {\n\t\t\tvideo.requestVideoFrameCallback(updateVideo);\n\t\t}\n\t}\n\n\tclone() {\n\t\treturn new this.constructor(this.image).copy(this);\n\t}\n\n\tupdate() {\n\t\tconst video = this.image;\n\t\tconst hasVideoFrameCallback = ('requestVideoFrameCallback' in video);\n\n\t\tif (hasVideoFrameCallback === false && video.readyState >= video.HAVE_CURRENT_DATA) {\n\t\t\tthis.needsUpdate = true;\n\t\t}\n\t}\n\n}\n\nclass FramebufferTexture extends Texture {\n\tconstructor(width, height, format) {\n\t\tsuper({\n\t\t\twidth,\n\t\t\theight\n\t\t});\n\t\tthis.isFramebufferTexture = true;\n\t\tthis.format = format;\n\t\tthis.magFilter = NearestFilter;\n\t\tthis.minFilter = NearestFilter;\n\t\tthis.generateMipmaps = false;\n\t\tthis.needsUpdate = true;\n\t}\n\n}\n\nclass CompressedTexture extends Texture {\n\tconstructor(mipmaps, width, height, format, type, mapping, wrapS, wrapT, magFilter, minFilter, anisotropy, encoding) {\n\t\tsuper(null, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding);\n\t\tthis.isCompressedTexture = true;\n\t\tthis.image = {\n\t\t\twidth: width,\n\t\t\theight: height\n\t\t};\n\t\tthis.mipmaps = mipmaps; // no flipping for cube textures\n\t\t// (also flipping doesn't work for compressed textures )\n\n\t\tthis.flipY = false; // can't generate mipmaps for compressed textures\n\t\t// mips must be embedded in DDS files\n\n\t\tthis.generateMipmaps = false;\n\t}\n\n}\n\nclass CanvasTexture extends Texture {\n\tconstructor(canvas, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy) {\n\t\tsuper(canvas, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy);\n\t\tthis.isCanvasTexture = true;\n\t\tthis.needsUpdate = true;\n\t}\n\n}\n\n/**\n * Extensible curve object.\n *\n * Some common of curve methods:\n * .getPoint( t, optionalTarget ), .getTangent( t, optionalTarget )\n * .getPointAt( u, optionalTarget ), .getTangentAt( u, optionalTarget )\n * .getPoints(), .getSpacedPoints()\n * .getLength()\n * .updateArcLengths()\n *\n * This following curves inherit from THREE.Curve:\n *\n * -- 2D curves --\n * THREE.ArcCurve\n * THREE.CubicBezierCurve\n * THREE.EllipseCurve\n * THREE.LineCurve\n * THREE.QuadraticBezierCurve\n * THREE.SplineCurve\n *\n * -- 3D curves --\n * THREE.CatmullRomCurve3\n * THREE.CubicBezierCurve3\n * THREE.LineCurve3\n * THREE.QuadraticBezierCurve3\n *\n * A series of curves can be represented as a THREE.CurvePath.\n *\n **/\n\nclass Curve {\n\tconstructor() {\n\t\tthis.type = 'Curve';\n\t\tthis.arcLengthDivisions = 200;\n\t} // Virtual base class method to overwrite and implement in subclasses\n\t//\t- t [0 .. 1]\n\n\n\tgetPoint() {\n\t\tconsole.warn('THREE.Curve: .getPoint() not implemented.');\n\t\treturn null;\n\t} // Get point at relative position in curve according to arc length\n\t// - u [0 .. 1]\n\n\n\tgetPointAt(u, optionalTarget) {\n\t\tconst t = this.getUtoTmapping(u);\n\t\treturn this.getPoint(t, optionalTarget);\n\t} // Get sequence of points using getPoint( t )\n\n\n\tgetPoints(divisions = 5) {\n\t\tconst points = [];\n\n\t\tfor (let d = 0; d <= divisions; d++) {\n\t\t\tpoints.push(this.getPoint(d / divisions));\n\t\t}\n\n\t\treturn points;\n\t} // Get sequence of points using getPointAt( u )\n\n\n\tgetSpacedPoints(divisions = 5) {\n\t\tconst points = [];\n\n\t\tfor (let d = 0; d <= divisions; d++) {\n\t\t\tpoints.push(this.getPointAt(d / divisions));\n\t\t}\n\n\t\treturn points;\n\t} // Get total curve arc length\n\n\n\tgetLength() {\n\t\tconst lengths = this.getLengths();\n\t\treturn lengths[lengths.length - 1];\n\t} // Get list of cumulative segment lengths\n\n\n\tgetLengths(divisions = this.arcLengthDivisions) {\n\t\tif (this.cacheArcLengths && this.cacheArcLengths.length === divisions + 1 && !this.needsUpdate) {\n\t\t\treturn this.cacheArcLengths;\n\t\t}\n\n\t\tthis.needsUpdate = false;\n\t\tconst cache = [];\n\t\tlet current,\n\t\t\t\tlast = this.getPoint(0);\n\t\tlet sum = 0;\n\t\tcache.push(0);\n\n\t\tfor (let p = 1; p <= divisions; p++) {\n\t\t\tcurrent = this.getPoint(p / divisions);\n\t\t\tsum += current.distanceTo(last);\n\t\t\tcache.push(sum);\n\t\t\tlast = current;\n\t\t}\n\n\t\tthis.cacheArcLengths = cache;\n\t\treturn cache; // { sums: cache, sum: sum }; Sum is in the last element.\n\t}\n\n\tupdateArcLengths() {\n\t\tthis.needsUpdate = true;\n\t\tthis.getLengths();\n\t} // Given u ( 0 .. 1 ), get a t to find p. This gives you points which are equidistant\n\n\n\tgetUtoTmapping(u, distance) {\n\t\tconst arcLengths = this.getLengths();\n\t\tlet i = 0;\n\t\tconst il = arcLengths.length;\n\t\tlet targetArcLength; // The targeted u distance value to get\n\n\t\tif (distance) {\n\t\t\ttargetArcLength = distance;\n\t\t} else {\n\t\t\ttargetArcLength = u * arcLengths[il - 1];\n\t\t} // binary search for the index with largest value smaller than target u distance\n\n\n\t\tlet low = 0,\n\t\t\t\thigh = il - 1,\n\t\t\t\tcomparison;\n\n\t\twhile (low <= high) {\n\t\t\ti = Math.floor(low + (high - low) / 2); // less likely to overflow, though probably not issue here, JS doesn't really have integers, all numbers are floats\n\n\t\t\tcomparison = arcLengths[i] - targetArcLength;\n\n\t\t\tif (comparison < 0) {\n\t\t\t\tlow = i + 1;\n\t\t\t} else if (comparison > 0) {\n\t\t\t\thigh = i - 1;\n\t\t\t} else {\n\t\t\t\thigh = i;\n\t\t\t\tbreak; // DONE\n\t\t\t}\n\t\t}\n\n\t\ti = high;\n\n\t\tif (arcLengths[i] === targetArcLength) {\n\t\t\treturn i / (il - 1);\n\t\t} // we could get finer grain at lengths, or use simple interpolation between two points\n\n\n\t\tconst lengthBefore = arcLengths[i];\n\t\tconst lengthAfter = arcLengths[i + 1];\n\t\tconst segmentLength = lengthAfter - lengthBefore; // determine where we are between the 'before' and 'after' points\n\n\t\tconst segmentFraction = (targetArcLength - lengthBefore) / segmentLength; // add that fractional amount to t\n\n\t\tconst t = (i + segmentFraction) / (il - 1);\n\t\treturn t;\n\t} // Returns a unit vector tangent at t\n\t// In case any sub curve does not implement its tangent derivation,\n\t// 2 points a small delta apart will be used to find its gradient\n\t// which seems to give a reasonable approximation\n\n\n\tgetTangent(t, optionalTarget) {\n\t\tconst delta = 0.0001;\n\t\tlet t1 = t - delta;\n\t\tlet t2 = t + delta; // Capping in case of danger\n\n\t\tif (t1 < 0) t1 = 0;\n\t\tif (t2 > 1) t2 = 1;\n\t\tconst pt1 = this.getPoint(t1);\n\t\tconst pt2 = this.getPoint(t2);\n\t\tconst tangent = optionalTarget || (pt1.isVector2 ? new Vector2() : new Vector3());\n\t\ttangent.copy(pt2).sub(pt1).normalize();\n\t\treturn tangent;\n\t}\n\n\tgetTangentAt(u, optionalTarget) {\n\t\tconst t = this.getUtoTmapping(u);\n\t\treturn this.getTangent(t, optionalTarget);\n\t}\n\n\tcomputeFrenetFrames(segments, closed) {\n\t\t// see http://www.cs.indiana.edu/pub/techreports/TR425.pdf\n\t\tconst normal = new Vector3();\n\t\tconst tangents = [];\n\t\tconst normals = [];\n\t\tconst binormals = [];\n\t\tconst vec = new Vector3();\n\t\tconst mat = new Matrix4(); // compute the tangent vectors for each segment on the curve\n\n\t\tfor (let i = 0; i <= segments; i++) {\n\t\t\tconst u = i / segments;\n\t\t\ttangents[i] = this.getTangentAt(u, new Vector3());\n\t\t} // select an initial normal vector perpendicular to the first tangent vector,\n\t\t// and in the direction of the minimum tangent xyz component\n\n\n\t\tnormals[0] = new Vector3();\n\t\tbinormals[0] = new Vector3();\n\t\tlet min = Number.MAX_VALUE;\n\t\tconst tx = Math.abs(tangents[0].x);\n\t\tconst ty = Math.abs(tangents[0].y);\n\t\tconst tz = Math.abs(tangents[0].z);\n\n\t\tif (tx <= min) {\n\t\t\tmin = tx;\n\t\t\tnormal.set(1, 0, 0);\n\t\t}\n\n\t\tif (ty <= min) {\n\t\t\tmin = ty;\n\t\t\tnormal.set(0, 1, 0);\n\t\t}\n\n\t\tif (tz <= min) {\n\t\t\tnormal.set(0, 0, 1);\n\t\t}\n\n\t\tvec.crossVectors(tangents[0], normal).normalize();\n\t\tnormals[0].crossVectors(tangents[0], vec);\n\t\tbinormals[0].crossVectors(tangents[0], normals[0]); // compute the slowly-varying normal and binormal vectors for each segment on the curve\n\n\t\tfor (let i = 1; i <= segments; i++) {\n\t\t\tnormals[i] = normals[i - 1].clone();\n\t\t\tbinormals[i] = binormals[i - 1].clone();\n\t\t\tvec.crossVectors(tangents[i - 1], tangents[i]);\n\n\t\t\tif (vec.length() > Number.EPSILON) {\n\t\t\t\tvec.normalize();\n\t\t\t\tconst theta = Math.acos(clamp(tangents[i - 1].dot(tangents[i]), -1, 1)); // clamp for floating pt errors\n\n\t\t\t\tnormals[i].applyMatrix4(mat.makeRotationAxis(vec, theta));\n\t\t\t}\n\n\t\t\tbinormals[i].crossVectors(tangents[i], normals[i]);\n\t\t} // if the curve is closed, postprocess the vectors so the first and last normal vectors are the same\n\n\n\t\tif (closed === true) {\n\t\t\tlet theta = Math.acos(clamp(normals[0].dot(normals[segments]), -1, 1));\n\t\t\ttheta /= segments;\n\n\t\t\tif (tangents[0].dot(vec.crossVectors(normals[0], normals[segments])) > 0) {\n\t\t\t\ttheta = -theta;\n\t\t\t}\n\n\t\t\tfor (let i = 1; i <= segments; i++) {\n\t\t\t\t// twist a little...\n\t\t\t\tnormals[i].applyMatrix4(mat.makeRotationAxis(tangents[i], theta * i));\n\t\t\t\tbinormals[i].crossVectors(tangents[i], normals[i]);\n\t\t\t}\n\t\t}\n\n\t\treturn {\n\t\t\ttangents: tangents,\n\t\t\tnormals: normals,\n\t\t\tbinormals: binormals\n\t\t};\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n\tcopy(source) {\n\t\tthis.arcLengthDivisions = source.arcLengthDivisions;\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Curve',\n\t\t\t\tgenerator: 'Curve.toJSON'\n\t\t\t}\n\t\t};\n\t\tdata.arcLengthDivisions = this.arcLengthDivisions;\n\t\tdata.type = this.type;\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tthis.arcLengthDivisions = json.arcLengthDivisions;\n\t\treturn this;\n\t}\n\n}\n\nclass EllipseCurve extends Curve {\n\tconstructor(aX = 0, aY = 0, xRadius = 1, yRadius = 1, aStartAngle = 0, aEndAngle = Math.PI * 2, aClockwise = false, aRotation = 0) {\n\t\tsuper();\n\t\tthis.isEllipseCurve = true;\n\t\tthis.type = 'EllipseCurve';\n\t\tthis.aX = aX;\n\t\tthis.aY = aY;\n\t\tthis.xRadius = xRadius;\n\t\tthis.yRadius = yRadius;\n\t\tthis.aStartAngle = aStartAngle;\n\t\tthis.aEndAngle = aEndAngle;\n\t\tthis.aClockwise = aClockwise;\n\t\tthis.aRotation = aRotation;\n\t}\n\n\tgetPoint(t, optionalTarget) {\n\t\tconst point = optionalTarget || new Vector2();\n\t\tconst twoPi = Math.PI * 2;\n\t\tlet deltaAngle = this.aEndAngle - this.aStartAngle;\n\t\tconst samePoints = Math.abs(deltaAngle) < Number.EPSILON; // ensures that deltaAngle is 0 .. 2 PI\n\n\t\twhile (deltaAngle < 0) deltaAngle += twoPi;\n\n\t\twhile (deltaAngle > twoPi) deltaAngle -= twoPi;\n\n\t\tif (deltaAngle < Number.EPSILON) {\n\t\t\tif (samePoints) {\n\t\t\t\tdeltaAngle = 0;\n\t\t\t} else {\n\t\t\t\tdeltaAngle = twoPi;\n\t\t\t}\n\t\t}\n\n\t\tif (this.aClockwise === true && !samePoints) {\n\t\t\tif (deltaAngle === twoPi) {\n\t\t\t\tdeltaAngle = -twoPi;\n\t\t\t} else {\n\t\t\t\tdeltaAngle = deltaAngle - twoPi;\n\t\t\t}\n\t\t}\n\n\t\tconst angle = this.aStartAngle + t * deltaAngle;\n\t\tlet x = this.aX + this.xRadius * Math.cos(angle);\n\t\tlet y = this.aY + this.yRadius * Math.sin(angle);\n\n\t\tif (this.aRotation !== 0) {\n\t\t\tconst cos = Math.cos(this.aRotation);\n\t\t\tconst sin = Math.sin(this.aRotation);\n\t\t\tconst tx = x - this.aX;\n\t\t\tconst ty = y - this.aY; // Rotate the point about the center of the ellipse.\n\n\t\t\tx = tx * cos - ty * sin + this.aX;\n\t\t\ty = tx * sin + ty * cos + this.aY;\n\t\t}\n\n\t\treturn point.set(x, y);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.aX = source.aX;\n\t\tthis.aY = source.aY;\n\t\tthis.xRadius = source.xRadius;\n\t\tthis.yRadius = source.yRadius;\n\t\tthis.aStartAngle = source.aStartAngle;\n\t\tthis.aEndAngle = source.aEndAngle;\n\t\tthis.aClockwise = source.aClockwise;\n\t\tthis.aRotation = source.aRotation;\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.aX = this.aX;\n\t\tdata.aY = this.aY;\n\t\tdata.xRadius = this.xRadius;\n\t\tdata.yRadius = this.yRadius;\n\t\tdata.aStartAngle = this.aStartAngle;\n\t\tdata.aEndAngle = this.aEndAngle;\n\t\tdata.aClockwise = this.aClockwise;\n\t\tdata.aRotation = this.aRotation;\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tsuper.fromJSON(json);\n\t\tthis.aX = json.aX;\n\t\tthis.aY = json.aY;\n\t\tthis.xRadius = json.xRadius;\n\t\tthis.yRadius = json.yRadius;\n\t\tthis.aStartAngle = json.aStartAngle;\n\t\tthis.aEndAngle = json.aEndAngle;\n\t\tthis.aClockwise = json.aClockwise;\n\t\tthis.aRotation = json.aRotation;\n\t\treturn this;\n\t}\n\n}\n\nclass ArcCurve extends EllipseCurve {\n\tconstructor(aX, aY, aRadius, aStartAngle, aEndAngle, aClockwise) {\n\t\tsuper(aX, aY, aRadius, aRadius, aStartAngle, aEndAngle, aClockwise);\n\t\tthis.isArcCurve = true;\n\t\tthis.type = 'ArcCurve';\n\t}\n\n}\n\n/**\n * Centripetal CatmullRom Curve - which is useful for avoiding\n * cusps and self-intersections in non-uniform catmull rom curves.\n * http://www.cemyuksel.com/research/catmullrom_param/catmullrom.pdf\n *\n * curve.type accepts centripetal(default), chordal and catmullrom\n * curve.tension is used for catmullrom which defaults to 0.5\n */\n\n/*\nBased on an optimized c++ solution in\n - http://stackoverflow.com/questions/9489736/catmull-rom-curve-with-no-cusps-and-no-self-intersections/\n - http://ideone.com/NoEbVM\n\nThis CubicPoly class could be used for reusing some variables and calculations,\nbut for three.js curve use, it could be possible inlined and flatten into a single function call\nwhich can be placed in CurveUtils.\n*/\n\nfunction CubicPoly() {\n\tlet c0 = 0,\n\t\t\tc1 = 0,\n\t\t\tc2 = 0,\n\t\t\tc3 = 0;\n\t/*\n\t * Compute coefficients for a cubic polynomial\n\t *\t p(s) = c0 + c1*s + c2*s^2 + c3*s^3\n\t * such that\n\t *\t p(0) = x0, p(1) = x1\n\t *\tand\n\t *\t p'(0) = t0, p'(1) = t1.\n\t */\n\n\tfunction init(x0, x1, t0, t1) {\n\t\tc0 = x0;\n\t\tc1 = t0;\n\t\tc2 = -3 * x0 + 3 * x1 - 2 * t0 - t1;\n\t\tc3 = 2 * x0 - 2 * x1 + t0 + t1;\n\t}\n\n\treturn {\n\t\tinitCatmullRom: function (x0, x1, x2, x3, tension) {\n\t\t\tinit(x1, x2, tension * (x2 - x0), tension * (x3 - x1));\n\t\t},\n\t\tinitNonuniformCatmullRom: function (x0, x1, x2, x3, dt0, dt1, dt2) {\n\t\t\t// compute tangents when parameterized in [t1,t2]\n\t\t\tlet t1 = (x1 - x0) / dt0 - (x2 - x0) / (dt0 + dt1) + (x2 - x1) / dt1;\n\t\t\tlet t2 = (x2 - x1) / dt1 - (x3 - x1) / (dt1 + dt2) + (x3 - x2) / dt2; // rescale tangents for parametrization in [0,1]\n\n\t\t\tt1 *= dt1;\n\t\t\tt2 *= dt1;\n\t\t\tinit(x1, x2, t1, t2);\n\t\t},\n\t\tcalc: function (t) {\n\t\t\tconst t2 = t * t;\n\t\t\tconst t3 = t2 * t;\n\t\t\treturn c0 + c1 * t + c2 * t2 + c3 * t3;\n\t\t}\n\t};\n} //\n\n\nconst tmp = new Vector3();\nconst px = new CubicPoly(),\n\t\t\tpy = new CubicPoly(),\n\t\t\tpz = new CubicPoly();\n\nclass CatmullRomCurve3 extends Curve {\n\tconstructor(points = [], closed = false, curveType = 'centripetal', tension = 0.5) {\n\t\tsuper();\n\t\tthis.isCatmullRomCurve3 = true;\n\t\tthis.type = 'CatmullRomCurve3';\n\t\tthis.points = points;\n\t\tthis.closed = closed;\n\t\tthis.curveType = curveType;\n\t\tthis.tension = tension;\n\t}\n\n\tgetPoint(t, optionalTarget = new Vector3()) {\n\t\tconst point = optionalTarget;\n\t\tconst points = this.points;\n\t\tconst l = points.length;\n\t\tconst p = (l - (this.closed ? 0 : 1)) * t;\n\t\tlet intPoint = Math.floor(p);\n\t\tlet weight = p - intPoint;\n\n\t\tif (this.closed) {\n\t\t\tintPoint += intPoint > 0 ? 0 : (Math.floor(Math.abs(intPoint) / l) + 1) * l;\n\t\t} else if (weight === 0 && intPoint === l - 1) {\n\t\t\tintPoint = l - 2;\n\t\t\tweight = 1;\n\t\t}\n\n\t\tlet p0, p3; // 4 points (p1 & p2 defined below)\n\n\t\tif (this.closed || intPoint > 0) {\n\t\t\tp0 = points[(intPoint - 1) % l];\n\t\t} else {\n\t\t\t// extrapolate first point\n\t\t\ttmp.subVectors(points[0], points[1]).add(points[0]);\n\t\t\tp0 = tmp;\n\t\t}\n\n\t\tconst p1 = points[intPoint % l];\n\t\tconst p2 = points[(intPoint + 1) % l];\n\n\t\tif (this.closed || intPoint + 2 < l) {\n\t\t\tp3 = points[(intPoint + 2) % l];\n\t\t} else {\n\t\t\t// extrapolate last point\n\t\t\ttmp.subVectors(points[l - 1], points[l - 2]).add(points[l - 1]);\n\t\t\tp3 = tmp;\n\t\t}\n\n\t\tif (this.curveType === 'centripetal' || this.curveType === 'chordal') {\n\t\t\t// init Centripetal / Chordal Catmull-Rom\n\t\t\tconst pow = this.curveType === 'chordal' ? 0.5 : 0.25;\n\t\t\tlet dt0 = Math.pow(p0.distanceToSquared(p1), pow);\n\t\t\tlet dt1 = Math.pow(p1.distanceToSquared(p2), pow);\n\t\t\tlet dt2 = Math.pow(p2.distanceToSquared(p3), pow); // safety check for repeated points\n\n\t\t\tif (dt1 < 1e-4) dt1 = 1.0;\n\t\t\tif (dt0 < 1e-4) dt0 = dt1;\n\t\t\tif (dt2 < 1e-4) dt2 = dt1;\n\t\t\tpx.initNonuniformCatmullRom(p0.x, p1.x, p2.x, p3.x, dt0, dt1, dt2);\n\t\t\tpy.initNonuniformCatmullRom(p0.y, p1.y, p2.y, p3.y, dt0, dt1, dt2);\n\t\t\tpz.initNonuniformCatmullRom(p0.z, p1.z, p2.z, p3.z, dt0, dt1, dt2);\n\t\t} else if (this.curveType === 'catmullrom') {\n\t\t\tpx.initCatmullRom(p0.x, p1.x, p2.x, p3.x, this.tension);\n\t\t\tpy.initCatmullRom(p0.y, p1.y, p2.y, p3.y, this.tension);\n\t\t\tpz.initCatmullRom(p0.z, p1.z, p2.z, p3.z, this.tension);\n\t\t}\n\n\t\tpoint.set(px.calc(weight), py.calc(weight), pz.calc(weight));\n\t\treturn point;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.points = [];\n\n\t\tfor (let i = 0, l = source.points.length; i < l; i++) {\n\t\t\tconst point = source.points[i];\n\t\t\tthis.points.push(point.clone());\n\t\t}\n\n\t\tthis.closed = source.closed;\n\t\tthis.curveType = source.curveType;\n\t\tthis.tension = source.tension;\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.points = [];\n\n\t\tfor (let i = 0, l = this.points.length; i < l; i++) {\n\t\t\tconst point = this.points[i];\n\t\t\tdata.points.push(point.toArray());\n\t\t}\n\n\t\tdata.closed = this.closed;\n\t\tdata.curveType = this.curveType;\n\t\tdata.tension = this.tension;\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tsuper.fromJSON(json);\n\t\tthis.points = [];\n\n\t\tfor (let i = 0, l = json.points.length; i < l; i++) {\n\t\t\tconst point = json.points[i];\n\t\t\tthis.points.push(new Vector3().fromArray(point));\n\t\t}\n\n\t\tthis.closed = json.closed;\n\t\tthis.curveType = json.curveType;\n\t\tthis.tension = json.tension;\n\t\treturn this;\n\t}\n\n}\n\n/**\n * Bezier Curves formulas obtained from\n * https://en.wikipedia.org/wiki/B%C3%A9zier_curve\n */\nfunction CatmullRom(t, p0, p1, p2, p3) {\n\tconst v0 = (p2 - p0) * 0.5;\n\tconst v1 = (p3 - p1) * 0.5;\n\tconst t2 = t * t;\n\tconst t3 = t * t2;\n\treturn (2 * p1 - 2 * p2 + v0 + v1) * t3 + (-3 * p1 + 3 * p2 - 2 * v0 - v1) * t2 + v0 * t + p1;\n} //\n\n\nfunction QuadraticBezierP0(t, p) {\n\tconst k = 1 - t;\n\treturn k * k * p;\n}\n\nfunction QuadraticBezierP1(t, p) {\n\treturn 2 * (1 - t) * t * p;\n}\n\nfunction QuadraticBezierP2(t, p) {\n\treturn t * t * p;\n}\n\nfunction QuadraticBezier(t, p0, p1, p2) {\n\treturn QuadraticBezierP0(t, p0) + QuadraticBezierP1(t, p1) + QuadraticBezierP2(t, p2);\n} //\n\n\nfunction CubicBezierP0(t, p) {\n\tconst k = 1 - t;\n\treturn k * k * k * p;\n}\n\nfunction CubicBezierP1(t, p) {\n\tconst k = 1 - t;\n\treturn 3 * k * k * t * p;\n}\n\nfunction CubicBezierP2(t, p) {\n\treturn 3 * (1 - t) * t * t * p;\n}\n\nfunction CubicBezierP3(t, p) {\n\treturn t * t * t * p;\n}\n\nfunction CubicBezier(t, p0, p1, p2, p3) {\n\treturn CubicBezierP0(t, p0) + CubicBezierP1(t, p1) + CubicBezierP2(t, p2) + CubicBezierP3(t, p3);\n}\n\nclass CubicBezierCurve extends Curve {\n\tconstructor(v0 = new Vector2(), v1 = new Vector2(), v2 = new Vector2(), v3 = new Vector2()) {\n\t\tsuper();\n\t\tthis.isCubicBezierCurve = true;\n\t\tthis.type = 'CubicBezierCurve';\n\t\tthis.v0 = v0;\n\t\tthis.v1 = v1;\n\t\tthis.v2 = v2;\n\t\tthis.v3 = v3;\n\t}\n\n\tgetPoint(t, optionalTarget = new Vector2()) {\n\t\tconst point = optionalTarget;\n\t\tconst v0 = this.v0,\n\t\t\t\t\tv1 = this.v1,\n\t\t\t\t\tv2 = this.v2,\n\t\t\t\t\tv3 = this.v3;\n\t\tpoint.set(CubicBezier(t, v0.x, v1.x, v2.x, v3.x), CubicBezier(t, v0.y, v1.y, v2.y, v3.y));\n\t\treturn point;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.v0.copy(source.v0);\n\t\tthis.v1.copy(source.v1);\n\t\tthis.v2.copy(source.v2);\n\t\tthis.v3.copy(source.v3);\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.v0 = this.v0.toArray();\n\t\tdata.v1 = this.v1.toArray();\n\t\tdata.v2 = this.v2.toArray();\n\t\tdata.v3 = this.v3.toArray();\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tsuper.fromJSON(json);\n\t\tthis.v0.fromArray(json.v0);\n\t\tthis.v1.fromArray(json.v1);\n\t\tthis.v2.fromArray(json.v2);\n\t\tthis.v3.fromArray(json.v3);\n\t\treturn this;\n\t}\n\n}\n\nclass CubicBezierCurve3 extends Curve {\n\tconstructor(v0 = new Vector3(), v1 = new Vector3(), v2 = new Vector3(), v3 = new Vector3()) {\n\t\tsuper();\n\t\tthis.isCubicBezierCurve3 = true;\n\t\tthis.type = 'CubicBezierCurve3';\n\t\tthis.v0 = v0;\n\t\tthis.v1 = v1;\n\t\tthis.v2 = v2;\n\t\tthis.v3 = v3;\n\t}\n\n\tgetPoint(t, optionalTarget = new Vector3()) {\n\t\tconst point = optionalTarget;\n\t\tconst v0 = this.v0,\n\t\t\t\t\tv1 = this.v1,\n\t\t\t\t\tv2 = this.v2,\n\t\t\t\t\tv3 = this.v3;\n\t\tpoint.set(CubicBezier(t, v0.x, v1.x, v2.x, v3.x), CubicBezier(t, v0.y, v1.y, v2.y, v3.y), CubicBezier(t, v0.z, v1.z, v2.z, v3.z));\n\t\treturn point;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.v0.copy(source.v0);\n\t\tthis.v1.copy(source.v1);\n\t\tthis.v2.copy(source.v2);\n\t\tthis.v3.copy(source.v3);\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.v0 = this.v0.toArray();\n\t\tdata.v1 = this.v1.toArray();\n\t\tdata.v2 = this.v2.toArray();\n\t\tdata.v3 = this.v3.toArray();\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tsuper.fromJSON(json);\n\t\tthis.v0.fromArray(json.v0);\n\t\tthis.v1.fromArray(json.v1);\n\t\tthis.v2.fromArray(json.v2);\n\t\tthis.v3.fromArray(json.v3);\n\t\treturn this;\n\t}\n\n}\n\nclass LineCurve extends Curve {\n\tconstructor(v1 = new Vector2(), v2 = new Vector2()) {\n\t\tsuper();\n\t\tthis.isLineCurve = true;\n\t\tthis.type = 'LineCurve';\n\t\tthis.v1 = v1;\n\t\tthis.v2 = v2;\n\t}\n\n\tgetPoint(t, optionalTarget = new Vector2()) {\n\t\tconst point = optionalTarget;\n\n\t\tif (t === 1) {\n\t\t\tpoint.copy(this.v2);\n\t\t} else {\n\t\t\tpoint.copy(this.v2).sub(this.v1);\n\t\t\tpoint.multiplyScalar(t).add(this.v1);\n\t\t}\n\n\t\treturn point;\n\t} // Line curve is linear, so we can overwrite default getPointAt\n\n\n\tgetPointAt(u, optionalTarget) {\n\t\treturn this.getPoint(u, optionalTarget);\n\t}\n\n\tgetTangent(t, optionalTarget) {\n\t\tconst tangent = optionalTarget || new Vector2();\n\t\ttangent.copy(this.v2).sub(this.v1).normalize();\n\t\treturn tangent;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.v1.copy(source.v1);\n\t\tthis.v2.copy(source.v2);\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.v1 = this.v1.toArray();\n\t\tdata.v2 = this.v2.toArray();\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tsuper.fromJSON(json);\n\t\tthis.v1.fromArray(json.v1);\n\t\tthis.v2.fromArray(json.v2);\n\t\treturn this;\n\t}\n\n}\n\nclass LineCurve3 extends Curve {\n\tconstructor(v1 = new Vector3(), v2 = new Vector3()) {\n\t\tsuper();\n\t\tthis.isLineCurve3 = true;\n\t\tthis.type = 'LineCurve3';\n\t\tthis.v1 = v1;\n\t\tthis.v2 = v2;\n\t}\n\n\tgetPoint(t, optionalTarget = new Vector3()) {\n\t\tconst point = optionalTarget;\n\n\t\tif (t === 1) {\n\t\t\tpoint.copy(this.v2);\n\t\t} else {\n\t\t\tpoint.copy(this.v2).sub(this.v1);\n\t\t\tpoint.multiplyScalar(t).add(this.v1);\n\t\t}\n\n\t\treturn point;\n\t} // Line curve is linear, so we can overwrite default getPointAt\n\n\n\tgetPointAt(u, optionalTarget) {\n\t\treturn this.getPoint(u, optionalTarget);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.v1.copy(source.v1);\n\t\tthis.v2.copy(source.v2);\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.v1 = this.v1.toArray();\n\t\tdata.v2 = this.v2.toArray();\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tsuper.fromJSON(json);\n\t\tthis.v1.fromArray(json.v1);\n\t\tthis.v2.fromArray(json.v2);\n\t\treturn this;\n\t}\n\n}\n\nclass QuadraticBezierCurve extends Curve {\n\tconstructor(v0 = new Vector2(), v1 = new Vector2(), v2 = new Vector2()) {\n\t\tsuper();\n\t\tthis.isQuadraticBezierCurve = true;\n\t\tthis.type = 'QuadraticBezierCurve';\n\t\tthis.v0 = v0;\n\t\tthis.v1 = v1;\n\t\tthis.v2 = v2;\n\t}\n\n\tgetPoint(t, optionalTarget = new Vector2()) {\n\t\tconst point = optionalTarget;\n\t\tconst v0 = this.v0,\n\t\t\t\t\tv1 = this.v1,\n\t\t\t\t\tv2 = this.v2;\n\t\tpoint.set(QuadraticBezier(t, v0.x, v1.x, v2.x), QuadraticBezier(t, v0.y, v1.y, v2.y));\n\t\treturn point;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.v0.copy(source.v0);\n\t\tthis.v1.copy(source.v1);\n\t\tthis.v2.copy(source.v2);\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.v0 = this.v0.toArray();\n\t\tdata.v1 = this.v1.toArray();\n\t\tdata.v2 = this.v2.toArray();\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tsuper.fromJSON(json);\n\t\tthis.v0.fromArray(json.v0);\n\t\tthis.v1.fromArray(json.v1);\n\t\tthis.v2.fromArray(json.v2);\n\t\treturn this;\n\t}\n\n}\n\nclass QuadraticBezierCurve3 extends Curve {\n\tconstructor(v0 = new Vector3(), v1 = new Vector3(), v2 = new Vector3()) {\n\t\tsuper();\n\t\tthis.isQuadraticBezierCurve3 = true;\n\t\tthis.type = 'QuadraticBezierCurve3';\n\t\tthis.v0 = v0;\n\t\tthis.v1 = v1;\n\t\tthis.v2 = v2;\n\t}\n\n\tgetPoint(t, optionalTarget = new Vector3()) {\n\t\tconst point = optionalTarget;\n\t\tconst v0 = this.v0,\n\t\t\t\t\tv1 = this.v1,\n\t\t\t\t\tv2 = this.v2;\n\t\tpoint.set(QuadraticBezier(t, v0.x, v1.x, v2.x), QuadraticBezier(t, v0.y, v1.y, v2.y), QuadraticBezier(t, v0.z, v1.z, v2.z));\n\t\treturn point;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.v0.copy(source.v0);\n\t\tthis.v1.copy(source.v1);\n\t\tthis.v2.copy(source.v2);\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.v0 = this.v0.toArray();\n\t\tdata.v1 = this.v1.toArray();\n\t\tdata.v2 = this.v2.toArray();\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tsuper.fromJSON(json);\n\t\tthis.v0.fromArray(json.v0);\n\t\tthis.v1.fromArray(json.v1);\n\t\tthis.v2.fromArray(json.v2);\n\t\treturn this;\n\t}\n\n}\n\nclass SplineCurve extends Curve {\n\tconstructor(points = []) {\n\t\tsuper();\n\t\tthis.isSplineCurve = true;\n\t\tthis.type = 'SplineCurve';\n\t\tthis.points = points;\n\t}\n\n\tgetPoint(t, optionalTarget = new Vector2()) {\n\t\tconst point = optionalTarget;\n\t\tconst points = this.points;\n\t\tconst p = (points.length - 1) * t;\n\t\tconst intPoint = Math.floor(p);\n\t\tconst weight = p - intPoint;\n\t\tconst p0 = points[intPoint === 0 ? intPoint : intPoint - 1];\n\t\tconst p1 = points[intPoint];\n\t\tconst p2 = points[intPoint > points.length - 2 ? points.length - 1 : intPoint + 1];\n\t\tconst p3 = points[intPoint > points.length - 3 ? points.length - 1 : intPoint + 2];\n\t\tpoint.set(CatmullRom(weight, p0.x, p1.x, p2.x, p3.x), CatmullRom(weight, p0.y, p1.y, p2.y, p3.y));\n\t\treturn point;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.points = [];\n\n\t\tfor (let i = 0, l = source.points.length; i < l; i++) {\n\t\t\tconst point = source.points[i];\n\t\t\tthis.points.push(point.clone());\n\t\t}\n\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.points = [];\n\n\t\tfor (let i = 0, l = this.points.length; i < l; i++) {\n\t\t\tconst point = this.points[i];\n\t\t\tdata.points.push(point.toArray());\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tsuper.fromJSON(json);\n\t\tthis.points = [];\n\n\t\tfor (let i = 0, l = json.points.length; i < l; i++) {\n\t\t\tconst point = json.points[i];\n\t\t\tthis.points.push(new Vector2().fromArray(point));\n\t\t}\n\n\t\treturn this;\n\t}\n\n}\n\nvar Curves = /*#__PURE__*/Object.freeze({\n\t__proto__: null,\n\tArcCurve: ArcCurve,\n\tCatmullRomCurve3: CatmullRomCurve3,\n\tCubicBezierCurve: CubicBezierCurve,\n\tCubicBezierCurve3: CubicBezierCurve3,\n\tEllipseCurve: EllipseCurve,\n\tLineCurve: LineCurve,\n\tLineCurve3: LineCurve3,\n\tQuadraticBezierCurve: QuadraticBezierCurve,\n\tQuadraticBezierCurve3: QuadraticBezierCurve3,\n\tSplineCurve: SplineCurve\n});\n\n/**************************************************************\n *\tCurved Path - a curve path is simply a array of connected\n *\tcurves, but retains the api of a curve\n **************************************************************/\n\nclass CurvePath extends Curve {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.type = 'CurvePath';\n\t\tthis.curves = [];\n\t\tthis.autoClose = false; // Automatically closes the path\n\t}\n\n\tadd(curve) {\n\t\tthis.curves.push(curve);\n\t}\n\n\tclosePath() {\n\t\t// Add a line curve if start and end of lines are not connected\n\t\tconst startPoint = this.curves[0].getPoint(0);\n\t\tconst endPoint = this.curves[this.curves.length - 1].getPoint(1);\n\n\t\tif (!startPoint.equals(endPoint)) {\n\t\t\tthis.curves.push(new LineCurve(endPoint, startPoint));\n\t\t}\n\t} // To get accurate point with reference to\n\t// entire path distance at time t,\n\t// following has to be done:\n\t// 1. Length of each sub path have to be known\n\t// 2. Locate and identify type of curve\n\t// 3. Get t for the curve\n\t// 4. Return curve.getPointAt(t')\n\n\n\tgetPoint(t, optionalTarget) {\n\t\tconst d = t * this.getLength();\n\t\tconst curveLengths = this.getCurveLengths();\n\t\tlet i = 0; // To think about boundaries points.\n\n\t\twhile (i < curveLengths.length) {\n\t\t\tif (curveLengths[i] >= d) {\n\t\t\t\tconst diff = curveLengths[i] - d;\n\t\t\t\tconst curve = this.curves[i];\n\t\t\t\tconst segmentLength = curve.getLength();\n\t\t\t\tconst u = segmentLength === 0 ? 0 : 1 - diff / segmentLength;\n\t\t\t\treturn curve.getPointAt(u, optionalTarget);\n\t\t\t}\n\n\t\t\ti++;\n\t\t}\n\n\t\treturn null; // loop where sum != 0, sum > d , sum+1 1 && !points[points.length - 1].equals(points[0])) {\n\t\t\tpoints.push(points[0]);\n\t\t}\n\n\t\treturn points;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.curves = [];\n\n\t\tfor (let i = 0, l = source.curves.length; i < l; i++) {\n\t\t\tconst curve = source.curves[i];\n\t\t\tthis.curves.push(curve.clone());\n\t\t}\n\n\t\tthis.autoClose = source.autoClose;\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.autoClose = this.autoClose;\n\t\tdata.curves = [];\n\n\t\tfor (let i = 0, l = this.curves.length; i < l; i++) {\n\t\t\tconst curve = this.curves[i];\n\t\t\tdata.curves.push(curve.toJSON());\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tsuper.fromJSON(json);\n\t\tthis.autoClose = json.autoClose;\n\t\tthis.curves = [];\n\n\t\tfor (let i = 0, l = json.curves.length; i < l; i++) {\n\t\t\tconst curve = json.curves[i];\n\t\t\tthis.curves.push(new Curves[curve.type]().fromJSON(curve));\n\t\t}\n\n\t\treturn this;\n\t}\n\n}\n\nclass Path extends CurvePath {\n\tconstructor(points) {\n\t\tsuper();\n\t\tthis.type = 'Path';\n\t\tthis.currentPoint = new Vector2();\n\n\t\tif (points) {\n\t\t\tthis.setFromPoints(points);\n\t\t}\n\t}\n\n\tsetFromPoints(points) {\n\t\tthis.moveTo(points[0].x, points[0].y);\n\n\t\tfor (let i = 1, l = points.length; i < l; i++) {\n\t\t\tthis.lineTo(points[i].x, points[i].y);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tmoveTo(x, y) {\n\t\tthis.currentPoint.set(x, y); // TODO consider referencing vectors instead of copying?\n\n\t\treturn this;\n\t}\n\n\tlineTo(x, y) {\n\t\tconst curve = new LineCurve(this.currentPoint.clone(), new Vector2(x, y));\n\t\tthis.curves.push(curve);\n\t\tthis.currentPoint.set(x, y);\n\t\treturn this;\n\t}\n\n\tquadraticCurveTo(aCPx, aCPy, aX, aY) {\n\t\tconst curve = new QuadraticBezierCurve(this.currentPoint.clone(), new Vector2(aCPx, aCPy), new Vector2(aX, aY));\n\t\tthis.curves.push(curve);\n\t\tthis.currentPoint.set(aX, aY);\n\t\treturn this;\n\t}\n\n\tbezierCurveTo(aCP1x, aCP1y, aCP2x, aCP2y, aX, aY) {\n\t\tconst curve = new CubicBezierCurve(this.currentPoint.clone(), new Vector2(aCP1x, aCP1y), new Vector2(aCP2x, aCP2y), new Vector2(aX, aY));\n\t\tthis.curves.push(curve);\n\t\tthis.currentPoint.set(aX, aY);\n\t\treturn this;\n\t}\n\n\tsplineThru(pts\n\t/*Array of Vector*/\n\t) {\n\t\tconst npts = [this.currentPoint.clone()].concat(pts);\n\t\tconst curve = new SplineCurve(npts);\n\t\tthis.curves.push(curve);\n\t\tthis.currentPoint.copy(pts[pts.length - 1]);\n\t\treturn this;\n\t}\n\n\tarc(aX, aY, aRadius, aStartAngle, aEndAngle, aClockwise) {\n\t\tconst x0 = this.currentPoint.x;\n\t\tconst y0 = this.currentPoint.y;\n\t\tthis.absarc(aX + x0, aY + y0, aRadius, aStartAngle, aEndAngle, aClockwise);\n\t\treturn this;\n\t}\n\n\tabsarc(aX, aY, aRadius, aStartAngle, aEndAngle, aClockwise) {\n\t\tthis.absellipse(aX, aY, aRadius, aRadius, aStartAngle, aEndAngle, aClockwise);\n\t\treturn this;\n\t}\n\n\tellipse(aX, aY, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation) {\n\t\tconst x0 = this.currentPoint.x;\n\t\tconst y0 = this.currentPoint.y;\n\t\tthis.absellipse(aX + x0, aY + y0, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation);\n\t\treturn this;\n\t}\n\n\tabsellipse(aX, aY, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation) {\n\t\tconst curve = new EllipseCurve(aX, aY, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation);\n\n\t\tif (this.curves.length > 0) {\n\t\t\t// if a previous curve is present, attempt to join\n\t\t\tconst firstPoint = curve.getPoint(0);\n\n\t\t\tif (!firstPoint.equals(this.currentPoint)) {\n\t\t\t\tthis.lineTo(firstPoint.x, firstPoint.y);\n\t\t\t}\n\t\t}\n\n\t\tthis.curves.push(curve);\n\t\tconst lastPoint = curve.getPoint(1);\n\t\tthis.currentPoint.copy(lastPoint);\n\t\treturn this;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.currentPoint.copy(source.currentPoint);\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.currentPoint = this.currentPoint.toArray();\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tsuper.fromJSON(json);\n\t\tthis.currentPoint.fromArray(json.currentPoint);\n\t\treturn this;\n\t}\n\n}\n\nclass LatheGeometry extends BufferGeometry {\n\tconstructor(points = [new Vector2(0, 0.5), new Vector2(0.5, 0), new Vector2(0, -0.5)], segments = 12, phiStart = 0, phiLength = Math.PI * 2) {\n\t\tsuper();\n\t\tthis.type = 'LatheGeometry';\n\t\tthis.parameters = {\n\t\t\tpoints: points,\n\t\t\tsegments: segments,\n\t\t\tphiStart: phiStart,\n\t\t\tphiLength: phiLength\n\t\t};\n\t\tsegments = Math.floor(segments); // clamp phiLength so it's in range of [ 0, 2PI ]\n\n\t\tphiLength = clamp(phiLength, 0, Math.PI * 2); // buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst uvs = [];\n\t\tconst initNormals = [];\n\t\tconst normals = []; // helper variables\n\n\t\tconst inverseSegments = 1.0 / segments;\n\t\tconst vertex = new Vector3();\n\t\tconst uv = new Vector2();\n\t\tconst normal = new Vector3();\n\t\tconst curNormal = new Vector3();\n\t\tconst prevNormal = new Vector3();\n\t\tlet dx = 0;\n\t\tlet dy = 0; // pre-compute normals for initial \"meridian\"\n\n\t\tfor (let j = 0; j <= points.length - 1; j++) {\n\t\t\tswitch (j) {\n\t\t\t\tcase 0:\n\t\t\t\t\t// special handling for 1st vertex on path\n\t\t\t\t\tdx = points[j + 1].x - points[j].x;\n\t\t\t\t\tdy = points[j + 1].y - points[j].y;\n\t\t\t\t\tnormal.x = dy * 1.0;\n\t\t\t\t\tnormal.y = -dx;\n\t\t\t\t\tnormal.z = dy * 0.0;\n\t\t\t\t\tprevNormal.copy(normal);\n\t\t\t\t\tnormal.normalize();\n\t\t\t\t\tinitNormals.push(normal.x, normal.y, normal.z);\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase points.length - 1:\n\t\t\t\t\t// special handling for last Vertex on path\n\t\t\t\t\tinitNormals.push(prevNormal.x, prevNormal.y, prevNormal.z);\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\n\t\t\t\t\t// default handling for all vertices in between\n\t\t\t\t\tdx = points[j + 1].x - points[j].x;\n\t\t\t\t\tdy = points[j + 1].y - points[j].y;\n\t\t\t\t\tnormal.x = dy * 1.0;\n\t\t\t\t\tnormal.y = -dx;\n\t\t\t\t\tnormal.z = dy * 0.0;\n\t\t\t\t\tcurNormal.copy(normal);\n\t\t\t\t\tnormal.x += prevNormal.x;\n\t\t\t\t\tnormal.y += prevNormal.y;\n\t\t\t\t\tnormal.z += prevNormal.z;\n\t\t\t\t\tnormal.normalize();\n\t\t\t\t\tinitNormals.push(normal.x, normal.y, normal.z);\n\t\t\t\t\tprevNormal.copy(curNormal);\n\t\t\t}\n\t\t} // generate vertices, uvs and normals\n\n\n\t\tfor (let i = 0; i <= segments; i++) {\n\t\t\tconst phi = phiStart + i * inverseSegments * phiLength;\n\t\t\tconst sin = Math.sin(phi);\n\t\t\tconst cos = Math.cos(phi);\n\n\t\t\tfor (let j = 0; j <= points.length - 1; j++) {\n\t\t\t\t// vertex\n\t\t\t\tvertex.x = points[j].x * sin;\n\t\t\t\tvertex.y = points[j].y;\n\t\t\t\tvertex.z = points[j].x * cos;\n\t\t\t\tvertices.push(vertex.x, vertex.y, vertex.z); // uv\n\n\t\t\t\tuv.x = i / segments;\n\t\t\t\tuv.y = j / (points.length - 1);\n\t\t\t\tuvs.push(uv.x, uv.y); // normal\n\n\t\t\t\tconst x = initNormals[3 * j + 0] * sin;\n\t\t\t\tconst y = initNormals[3 * j + 1];\n\t\t\t\tconst z = initNormals[3 * j + 0] * cos;\n\t\t\t\tnormals.push(x, y, z);\n\t\t\t}\n\t\t} // indices\n\n\n\t\tfor (let i = 0; i < segments; i++) {\n\t\t\tfor (let j = 0; j < points.length - 1; j++) {\n\t\t\t\tconst base = j + i * points.length;\n\t\t\t\tconst a = base;\n\t\t\t\tconst b = base + points.length;\n\t\t\t\tconst c = base + points.length + 1;\n\t\t\t\tconst d = base + 1; // faces\n\n\t\t\t\tindices.push(a, b, d);\n\t\t\t\tindices.push(c, d, b);\n\t\t\t}\n\t\t} // build geometry\n\n\n\t\tthis.setIndex(indices);\n\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvs, 2));\n\t\tthis.setAttribute('normal', new Float32BufferAttribute(normals, 3));\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new LatheGeometry(data.points, data.segments, data.phiStart, data.phiLength);\n\t}\n\n}\n\nclass CapsuleGeometry extends LatheGeometry {\n\tconstructor(radius = 1, length = 1, capSegments = 4, radialSegments = 8) {\n\t\tconst path = new Path();\n\t\tpath.absarc(0, -length / 2, radius, Math.PI * 1.5, 0);\n\t\tpath.absarc(0, length / 2, radius, 0, Math.PI * 0.5);\n\t\tsuper(path.getPoints(capSegments), radialSegments);\n\t\tthis.type = 'CapsuleGeometry';\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\theight: length,\n\t\t\tcapSegments: capSegments,\n\t\t\tradialSegments: radialSegments\n\t\t};\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new CapsuleGeometry(data.radius, data.length, data.capSegments, data.radialSegments);\n\t}\n\n}\n\nclass CircleGeometry extends BufferGeometry {\n\tconstructor(radius = 1, segments = 8, thetaStart = 0, thetaLength = Math.PI * 2) {\n\t\tsuper();\n\t\tthis.type = 'CircleGeometry';\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\tsegments: segments,\n\t\t\tthetaStart: thetaStart,\n\t\t\tthetaLength: thetaLength\n\t\t};\n\t\tsegments = Math.max(3, segments); // buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = []; // helper variables\n\n\t\tconst vertex = new Vector3();\n\t\tconst uv = new Vector2(); // center point\n\n\t\tvertices.push(0, 0, 0);\n\t\tnormals.push(0, 0, 1);\n\t\tuvs.push(0.5, 0.5);\n\n\t\tfor (let s = 0, i = 3; s <= segments; s++, i += 3) {\n\t\t\tconst segment = thetaStart + s / segments * thetaLength; // vertex\n\n\t\t\tvertex.x = radius * Math.cos(segment);\n\t\t\tvertex.y = radius * Math.sin(segment);\n\t\t\tvertices.push(vertex.x, vertex.y, vertex.z); // normal\n\n\t\t\tnormals.push(0, 0, 1); // uvs\n\n\t\t\tuv.x = (vertices[i] / radius + 1) / 2;\n\t\t\tuv.y = (vertices[i + 1] / radius + 1) / 2;\n\t\t\tuvs.push(uv.x, uv.y);\n\t\t} // indices\n\n\n\t\tfor (let i = 1; i <= segments; i++) {\n\t\t\tindices.push(i, i + 1, 0);\n\t\t} // build geometry\n\n\n\t\tthis.setIndex(indices);\n\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tthis.setAttribute('normal', new Float32BufferAttribute(normals, 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvs, 2));\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new CircleGeometry(data.radius, data.segments, data.thetaStart, data.thetaLength);\n\t}\n\n}\n\nclass CylinderGeometry extends BufferGeometry {\n\tconstructor(radiusTop = 1, radiusBottom = 1, height = 1, radialSegments = 8, heightSegments = 1, openEnded = false, thetaStart = 0, thetaLength = Math.PI * 2) {\n\t\tsuper();\n\t\tthis.type = 'CylinderGeometry';\n\t\tthis.parameters = {\n\t\t\tradiusTop: radiusTop,\n\t\t\tradiusBottom: radiusBottom,\n\t\t\theight: height,\n\t\t\tradialSegments: radialSegments,\n\t\t\theightSegments: heightSegments,\n\t\t\topenEnded: openEnded,\n\t\t\tthetaStart: thetaStart,\n\t\t\tthetaLength: thetaLength\n\t\t};\n\t\tconst scope = this;\n\t\tradialSegments = Math.floor(radialSegments);\n\t\theightSegments = Math.floor(heightSegments); // buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = []; // helper variables\n\n\t\tlet index = 0;\n\t\tconst indexArray = [];\n\t\tconst halfHeight = height / 2;\n\t\tlet groupStart = 0; // generate geometry\n\n\t\tgenerateTorso();\n\n\t\tif (openEnded === false) {\n\t\t\tif (radiusTop > 0) generateCap(true);\n\t\t\tif (radiusBottom > 0) generateCap(false);\n\t\t} // build geometry\n\n\n\t\tthis.setIndex(indices);\n\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tthis.setAttribute('normal', new Float32BufferAttribute(normals, 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvs, 2));\n\n\t\tfunction generateTorso() {\n\t\t\tconst normal = new Vector3();\n\t\t\tconst vertex = new Vector3();\n\t\t\tlet groupCount = 0; // this will be used to calculate the normal\n\n\t\t\tconst slope = (radiusBottom - radiusTop) / height; // generate vertices, normals and uvs\n\n\t\t\tfor (let y = 0; y <= heightSegments; y++) {\n\t\t\t\tconst indexRow = [];\n\t\t\t\tconst v = y / heightSegments; // calculate the radius of the current row\n\n\t\t\t\tconst radius = v * (radiusBottom - radiusTop) + radiusTop;\n\n\t\t\t\tfor (let x = 0; x <= radialSegments; x++) {\n\t\t\t\t\tconst u = x / radialSegments;\n\t\t\t\t\tconst theta = u * thetaLength + thetaStart;\n\t\t\t\t\tconst sinTheta = Math.sin(theta);\n\t\t\t\t\tconst cosTheta = Math.cos(theta); // vertex\n\n\t\t\t\t\tvertex.x = radius * sinTheta;\n\t\t\t\t\tvertex.y = -v * height + halfHeight;\n\t\t\t\t\tvertex.z = radius * cosTheta;\n\t\t\t\t\tvertices.push(vertex.x, vertex.y, vertex.z); // normal\n\n\t\t\t\t\tnormal.set(sinTheta, slope, cosTheta).normalize();\n\t\t\t\t\tnormals.push(normal.x, normal.y, normal.z); // uv\n\n\t\t\t\t\tuvs.push(u, 1 - v); // save index of vertex in respective row\n\n\t\t\t\t\tindexRow.push(index++);\n\t\t\t\t} // now save vertices of the row in our index array\n\n\n\t\t\t\tindexArray.push(indexRow);\n\t\t\t} // generate indices\n\n\n\t\t\tfor (let x = 0; x < radialSegments; x++) {\n\t\t\t\tfor (let y = 0; y < heightSegments; y++) {\n\t\t\t\t\t// we use the index array to access the correct indices\n\t\t\t\t\tconst a = indexArray[y][x];\n\t\t\t\t\tconst b = indexArray[y + 1][x];\n\t\t\t\t\tconst c = indexArray[y + 1][x + 1];\n\t\t\t\t\tconst d = indexArray[y][x + 1]; // faces\n\n\t\t\t\t\tindices.push(a, b, d);\n\t\t\t\t\tindices.push(b, c, d); // update group counter\n\n\t\t\t\t\tgroupCount += 6;\n\t\t\t\t}\n\t\t\t} // add a group to the geometry. this will ensure multi material support\n\n\n\t\t\tscope.addGroup(groupStart, groupCount, 0); // calculate new start value for groups\n\n\t\t\tgroupStart += groupCount;\n\t\t}\n\n\t\tfunction generateCap(top) {\n\t\t\t// save the index of the first center vertex\n\t\t\tconst centerIndexStart = index;\n\t\t\tconst uv = new Vector2();\n\t\t\tconst vertex = new Vector3();\n\t\t\tlet groupCount = 0;\n\t\t\tconst radius = top === true ? radiusTop : radiusBottom;\n\t\t\tconst sign = top === true ? 1 : -1; // first we generate the center vertex data of the cap.\n\t\t\t// because the geometry needs one set of uvs per face,\n\t\t\t// we must generate a center vertex per face/segment\n\n\t\t\tfor (let x = 1; x <= radialSegments; x++) {\n\t\t\t\t// vertex\n\t\t\t\tvertices.push(0, halfHeight * sign, 0); // normal\n\n\t\t\t\tnormals.push(0, sign, 0); // uv\n\n\t\t\t\tuvs.push(0.5, 0.5); // increase index\n\n\t\t\t\tindex++;\n\t\t\t} // save the index of the last center vertex\n\n\n\t\t\tconst centerIndexEnd = index; // now we generate the surrounding vertices, normals and uvs\n\n\t\t\tfor (let x = 0; x <= radialSegments; x++) {\n\t\t\t\tconst u = x / radialSegments;\n\t\t\t\tconst theta = u * thetaLength + thetaStart;\n\t\t\t\tconst cosTheta = Math.cos(theta);\n\t\t\t\tconst sinTheta = Math.sin(theta); // vertex\n\n\t\t\t\tvertex.x = radius * sinTheta;\n\t\t\t\tvertex.y = halfHeight * sign;\n\t\t\t\tvertex.z = radius * cosTheta;\n\t\t\t\tvertices.push(vertex.x, vertex.y, vertex.z); // normal\n\n\t\t\t\tnormals.push(0, sign, 0); // uv\n\n\t\t\t\tuv.x = cosTheta * 0.5 + 0.5;\n\t\t\t\tuv.y = sinTheta * 0.5 * sign + 0.5;\n\t\t\t\tuvs.push(uv.x, uv.y); // increase index\n\n\t\t\t\tindex++;\n\t\t\t} // generate indices\n\n\n\t\t\tfor (let x = 0; x < radialSegments; x++) {\n\t\t\t\tconst c = centerIndexStart + x;\n\t\t\t\tconst i = centerIndexEnd + x;\n\n\t\t\t\tif (top === true) {\n\t\t\t\t\t// face top\n\t\t\t\t\tindices.push(i, i + 1, c);\n\t\t\t\t} else {\n\t\t\t\t\t// face bottom\n\t\t\t\t\tindices.push(i + 1, i, c);\n\t\t\t\t}\n\n\t\t\t\tgroupCount += 3;\n\t\t\t} // add a group to the geometry. this will ensure multi material support\n\n\n\t\t\tscope.addGroup(groupStart, groupCount, top === true ? 1 : 2); // calculate new start value for groups\n\n\t\t\tgroupStart += groupCount;\n\t\t}\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new CylinderGeometry(data.radiusTop, data.radiusBottom, data.height, data.radialSegments, data.heightSegments, data.openEnded, data.thetaStart, data.thetaLength);\n\t}\n\n}\n\nclass ConeGeometry extends CylinderGeometry {\n\tconstructor(radius = 1, height = 1, radialSegments = 8, heightSegments = 1, openEnded = false, thetaStart = 0, thetaLength = Math.PI * 2) {\n\t\tsuper(0, radius, height, radialSegments, heightSegments, openEnded, thetaStart, thetaLength);\n\t\tthis.type = 'ConeGeometry';\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\theight: height,\n\t\t\tradialSegments: radialSegments,\n\t\t\theightSegments: heightSegments,\n\t\t\topenEnded: openEnded,\n\t\t\tthetaStart: thetaStart,\n\t\t\tthetaLength: thetaLength\n\t\t};\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new ConeGeometry(data.radius, data.height, data.radialSegments, data.heightSegments, data.openEnded, data.thetaStart, data.thetaLength);\n\t}\n\n}\n\nclass PolyhedronGeometry extends BufferGeometry {\n\tconstructor(vertices = [], indices = [], radius = 1, detail = 0) {\n\t\tsuper();\n\t\tthis.type = 'PolyhedronGeometry';\n\t\tthis.parameters = {\n\t\t\tvertices: vertices,\n\t\t\tindices: indices,\n\t\t\tradius: radius,\n\t\t\tdetail: detail\n\t\t}; // default buffer data\n\n\t\tconst vertexBuffer = [];\n\t\tconst uvBuffer = []; // the subdivision creates the vertex buffer data\n\n\t\tsubdivide(detail); // all vertices should lie on a conceptual sphere with a given radius\n\n\t\tapplyRadius(radius); // finally, create the uv data\n\n\t\tgenerateUVs(); // build non-indexed geometry\n\n\t\tthis.setAttribute('position', new Float32BufferAttribute(vertexBuffer, 3));\n\t\tthis.setAttribute('normal', new Float32BufferAttribute(vertexBuffer.slice(), 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvBuffer, 2));\n\n\t\tif (detail === 0) {\n\t\t\tthis.computeVertexNormals(); // flat normals\n\t\t} else {\n\t\t\tthis.normalizeNormals(); // smooth normals\n\t\t} // helper functions\n\n\n\t\tfunction subdivide(detail) {\n\t\t\tconst a = new Vector3();\n\t\t\tconst b = new Vector3();\n\t\t\tconst c = new Vector3(); // iterate over all faces and apply a subdivison with the given detail value\n\n\t\t\tfor (let i = 0; i < indices.length; i += 3) {\n\t\t\t\t// get the vertices of the face\n\t\t\t\tgetVertexByIndex(indices[i + 0], a);\n\t\t\t\tgetVertexByIndex(indices[i + 1], b);\n\t\t\t\tgetVertexByIndex(indices[i + 2], c); // perform subdivision\n\n\t\t\t\tsubdivideFace(a, b, c, detail);\n\t\t\t}\n\t\t}\n\n\t\tfunction subdivideFace(a, b, c, detail) {\n\t\t\tconst cols = detail + 1; // we use this multidimensional array as a data structure for creating the subdivision\n\n\t\t\tconst v = []; // construct all of the vertices for this subdivision\n\n\t\t\tfor (let i = 0; i <= cols; i++) {\n\t\t\t\tv[i] = [];\n\t\t\t\tconst aj = a.clone().lerp(c, i / cols);\n\t\t\t\tconst bj = b.clone().lerp(c, i / cols);\n\t\t\t\tconst rows = cols - i;\n\n\t\t\t\tfor (let j = 0; j <= rows; j++) {\n\t\t\t\t\tif (j === 0 && i === cols) {\n\t\t\t\t\t\tv[i][j] = aj;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tv[i][j] = aj.clone().lerp(bj, j / rows);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} // construct all of the faces\n\n\n\t\t\tfor (let i = 0; i < cols; i++) {\n\t\t\t\tfor (let j = 0; j < 2 * (cols - i) - 1; j++) {\n\t\t\t\t\tconst k = Math.floor(j / 2);\n\n\t\t\t\t\tif (j % 2 === 0) {\n\t\t\t\t\t\tpushVertex(v[i][k + 1]);\n\t\t\t\t\t\tpushVertex(v[i + 1][k]);\n\t\t\t\t\t\tpushVertex(v[i][k]);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tpushVertex(v[i][k + 1]);\n\t\t\t\t\t\tpushVertex(v[i + 1][k + 1]);\n\t\t\t\t\t\tpushVertex(v[i + 1][k]);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tfunction applyRadius(radius) {\n\t\t\tconst vertex = new Vector3(); // iterate over the entire buffer and apply the radius to each vertex\n\n\t\t\tfor (let i = 0; i < vertexBuffer.length; i += 3) {\n\t\t\t\tvertex.x = vertexBuffer[i + 0];\n\t\t\t\tvertex.y = vertexBuffer[i + 1];\n\t\t\t\tvertex.z = vertexBuffer[i + 2];\n\t\t\t\tvertex.normalize().multiplyScalar(radius);\n\t\t\t\tvertexBuffer[i + 0] = vertex.x;\n\t\t\t\tvertexBuffer[i + 1] = vertex.y;\n\t\t\t\tvertexBuffer[i + 2] = vertex.z;\n\t\t\t}\n\t\t}\n\n\t\tfunction generateUVs() {\n\t\t\tconst vertex = new Vector3();\n\n\t\t\tfor (let i = 0; i < vertexBuffer.length; i += 3) {\n\t\t\t\tvertex.x = vertexBuffer[i + 0];\n\t\t\t\tvertex.y = vertexBuffer[i + 1];\n\t\t\t\tvertex.z = vertexBuffer[i + 2];\n\t\t\t\tconst u = azimuth(vertex) / 2 / Math.PI + 0.5;\n\t\t\t\tconst v = inclination(vertex) / Math.PI + 0.5;\n\t\t\t\tuvBuffer.push(u, 1 - v);\n\t\t\t}\n\n\t\t\tcorrectUVs();\n\t\t\tcorrectSeam();\n\t\t}\n\n\t\tfunction correctSeam() {\n\t\t\t// handle case when face straddles the seam, see #3269\n\t\t\tfor (let i = 0; i < uvBuffer.length; i += 6) {\n\t\t\t\t// uv data of a single face\n\t\t\t\tconst x0 = uvBuffer[i + 0];\n\t\t\t\tconst x1 = uvBuffer[i + 2];\n\t\t\t\tconst x2 = uvBuffer[i + 4];\n\t\t\t\tconst max = Math.max(x0, x1, x2);\n\t\t\t\tconst min = Math.min(x0, x1, x2); // 0.9 is somewhat arbitrary\n\n\t\t\t\tif (max > 0.9 && min < 0.1) {\n\t\t\t\t\tif (x0 < 0.2) uvBuffer[i + 0] += 1;\n\t\t\t\t\tif (x1 < 0.2) uvBuffer[i + 2] += 1;\n\t\t\t\t\tif (x2 < 0.2) uvBuffer[i + 4] += 1;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tfunction pushVertex(vertex) {\n\t\t\tvertexBuffer.push(vertex.x, vertex.y, vertex.z);\n\t\t}\n\n\t\tfunction getVertexByIndex(index, vertex) {\n\t\t\tconst stride = index * 3;\n\t\t\tvertex.x = vertices[stride + 0];\n\t\t\tvertex.y = vertices[stride + 1];\n\t\t\tvertex.z = vertices[stride + 2];\n\t\t}\n\n\t\tfunction correctUVs() {\n\t\t\tconst a = new Vector3();\n\t\t\tconst b = new Vector3();\n\t\t\tconst c = new Vector3();\n\t\t\tconst centroid = new Vector3();\n\t\t\tconst uvA = new Vector2();\n\t\t\tconst uvB = new Vector2();\n\t\t\tconst uvC = new Vector2();\n\n\t\t\tfor (let i = 0, j = 0; i < vertexBuffer.length; i += 9, j += 6) {\n\t\t\t\ta.set(vertexBuffer[i + 0], vertexBuffer[i + 1], vertexBuffer[i + 2]);\n\t\t\t\tb.set(vertexBuffer[i + 3], vertexBuffer[i + 4], vertexBuffer[i + 5]);\n\t\t\t\tc.set(vertexBuffer[i + 6], vertexBuffer[i + 7], vertexBuffer[i + 8]);\n\t\t\t\tuvA.set(uvBuffer[j + 0], uvBuffer[j + 1]);\n\t\t\t\tuvB.set(uvBuffer[j + 2], uvBuffer[j + 3]);\n\t\t\t\tuvC.set(uvBuffer[j + 4], uvBuffer[j + 5]);\n\t\t\t\tcentroid.copy(a).add(b).add(c).divideScalar(3);\n\t\t\t\tconst azi = azimuth(centroid);\n\t\t\t\tcorrectUV(uvA, j + 0, a, azi);\n\t\t\t\tcorrectUV(uvB, j + 2, b, azi);\n\t\t\t\tcorrectUV(uvC, j + 4, c, azi);\n\t\t\t}\n\t\t}\n\n\t\tfunction correctUV(uv, stride, vector, azimuth) {\n\t\t\tif (azimuth < 0 && uv.x === 1) {\n\t\t\t\tuvBuffer[stride] = uv.x - 1;\n\t\t\t}\n\n\t\t\tif (vector.x === 0 && vector.z === 0) {\n\t\t\t\tuvBuffer[stride] = azimuth / 2 / Math.PI + 0.5;\n\t\t\t}\n\t\t} // Angle around the Y axis, counter-clockwise when looking from above.\n\n\n\t\tfunction azimuth(vector) {\n\t\t\treturn Math.atan2(vector.z, -vector.x);\n\t\t} // Angle above the XZ plane.\n\n\n\t\tfunction inclination(vector) {\n\t\t\treturn Math.atan2(-vector.y, Math.sqrt(vector.x * vector.x + vector.z * vector.z));\n\t\t}\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new PolyhedronGeometry(data.vertices, data.indices, data.radius, data.details);\n\t}\n\n}\n\nclass DodecahedronGeometry extends PolyhedronGeometry {\n\tconstructor(radius = 1, detail = 0) {\n\t\tconst t = (1 + Math.sqrt(5)) / 2;\n\t\tconst r = 1 / t;\n\t\tconst vertices = [// (±1, ±1, ±1)\n\t\t-1, -1, -1, -1, -1, 1, -1, 1, -1, -1, 1, 1, 1, -1, -1, 1, -1, 1, 1, 1, -1, 1, 1, 1, // (0, ±1/φ, ±φ)\n\t\t0, -r, -t, 0, -r, t, 0, r, -t, 0, r, t, // (±1/φ, ±φ, 0)\n\t\t-r, -t, 0, -r, t, 0, r, -t, 0, r, t, 0, // (±φ, 0, ±1/φ)\n\t\t-t, 0, -r, t, 0, -r, -t, 0, r, t, 0, r];\n\t\tconst indices = [3, 11, 7, 3, 7, 15, 3, 15, 13, 7, 19, 17, 7, 17, 6, 7, 6, 15, 17, 4, 8, 17, 8, 10, 17, 10, 6, 8, 0, 16, 8, 16, 2, 8, 2, 10, 0, 12, 1, 0, 1, 18, 0, 18, 16, 6, 10, 2, 6, 2, 13, 6, 13, 15, 2, 16, 18, 2, 18, 3, 2, 3, 13, 18, 1, 9, 18, 9, 11, 18, 11, 3, 4, 14, 12, 4, 12, 0, 4, 0, 8, 11, 9, 5, 11, 5, 19, 11, 19, 7, 19, 5, 14, 19, 14, 4, 19, 4, 17, 1, 12, 14, 1, 14, 5, 1, 5, 9];\n\t\tsuper(vertices, indices, radius, detail);\n\t\tthis.type = 'DodecahedronGeometry';\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\tdetail: detail\n\t\t};\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new DodecahedronGeometry(data.radius, data.detail);\n\t}\n\n}\n\nconst _v0 = new Vector3();\n\nconst _v1$1 = new Vector3();\n\nconst _normal = new Vector3();\n\nconst _triangle = new Triangle();\n\nclass EdgesGeometry extends BufferGeometry {\n\tconstructor(geometry = null, thresholdAngle = 1) {\n\t\tsuper();\n\t\tthis.type = 'EdgesGeometry';\n\t\tthis.parameters = {\n\t\t\tgeometry: geometry,\n\t\t\tthresholdAngle: thresholdAngle\n\t\t};\n\n\t\tif (geometry !== null) {\n\t\t\tconst precisionPoints = 4;\n\t\t\tconst precision = Math.pow(10, precisionPoints);\n\t\t\tconst thresholdDot = Math.cos(DEG2RAD * thresholdAngle);\n\t\t\tconst indexAttr = geometry.getIndex();\n\t\t\tconst positionAttr = geometry.getAttribute('position');\n\t\t\tconst indexCount = indexAttr ? indexAttr.count : positionAttr.count;\n\t\t\tconst indexArr = [0, 0, 0];\n\t\t\tconst vertKeys = ['a', 'b', 'c'];\n\t\t\tconst hashes = new Array(3);\n\t\t\tconst edgeData = {};\n\t\t\tconst vertices = [];\n\n\t\t\tfor (let i = 0; i < indexCount; i += 3) {\n\t\t\t\tif (indexAttr) {\n\t\t\t\t\tindexArr[0] = indexAttr.getX(i);\n\t\t\t\t\tindexArr[1] = indexAttr.getX(i + 1);\n\t\t\t\t\tindexArr[2] = indexAttr.getX(i + 2);\n\t\t\t\t} else {\n\t\t\t\t\tindexArr[0] = i;\n\t\t\t\t\tindexArr[1] = i + 1;\n\t\t\t\t\tindexArr[2] = i + 2;\n\t\t\t\t}\n\n\t\t\t\tconst {\n\t\t\t\t\ta,\n\t\t\t\t\tb,\n\t\t\t\t\tc\n\t\t\t\t} = _triangle;\n\t\t\t\ta.fromBufferAttribute(positionAttr, indexArr[0]);\n\t\t\t\tb.fromBufferAttribute(positionAttr, indexArr[1]);\n\t\t\t\tc.fromBufferAttribute(positionAttr, indexArr[2]);\n\n\t\t\t\t_triangle.getNormal(_normal); // create hashes for the edge from the vertices\n\n\n\t\t\t\thashes[0] = `${Math.round(a.x * precision)},${Math.round(a.y * precision)},${Math.round(a.z * precision)}`;\n\t\t\t\thashes[1] = `${Math.round(b.x * precision)},${Math.round(b.y * precision)},${Math.round(b.z * precision)}`;\n\t\t\t\thashes[2] = `${Math.round(c.x * precision)},${Math.round(c.y * precision)},${Math.round(c.z * precision)}`; // skip degenerate triangles\n\n\t\t\t\tif (hashes[0] === hashes[1] || hashes[1] === hashes[2] || hashes[2] === hashes[0]) {\n\t\t\t\t\tcontinue;\n\t\t\t\t} // iterate over every edge\n\n\n\t\t\t\tfor (let j = 0; j < 3; j++) {\n\t\t\t\t\t// get the first and next vertex making up the edge\n\t\t\t\t\tconst jNext = (j + 1) % 3;\n\t\t\t\t\tconst vecHash0 = hashes[j];\n\t\t\t\t\tconst vecHash1 = hashes[jNext];\n\t\t\t\t\tconst v0 = _triangle[vertKeys[j]];\n\t\t\t\t\tconst v1 = _triangle[vertKeys[jNext]];\n\t\t\t\t\tconst hash = `${vecHash0}_${vecHash1}`;\n\t\t\t\t\tconst reverseHash = `${vecHash1}_${vecHash0}`;\n\n\t\t\t\t\tif (reverseHash in edgeData && edgeData[reverseHash]) {\n\t\t\t\t\t\t// if we found a sibling edge add it into the vertex array if\n\t\t\t\t\t\t// it meets the angle threshold and delete the edge from the map.\n\t\t\t\t\t\tif (_normal.dot(edgeData[reverseHash].normal) <= thresholdDot) {\n\t\t\t\t\t\t\tvertices.push(v0.x, v0.y, v0.z);\n\t\t\t\t\t\t\tvertices.push(v1.x, v1.y, v1.z);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tedgeData[reverseHash] = null;\n\t\t\t\t\t} else if (!(hash in edgeData)) {\n\t\t\t\t\t\t// if we've already got an edge here then skip adding a new one\n\t\t\t\t\t\tedgeData[hash] = {\n\t\t\t\t\t\t\tindex0: indexArr[j],\n\t\t\t\t\t\t\tindex1: indexArr[jNext],\n\t\t\t\t\t\t\tnormal: _normal.clone()\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} // iterate over all remaining, unmatched edges and add them to the vertex array\n\n\n\t\t\tfor (const key in edgeData) {\n\t\t\t\tif (edgeData[key]) {\n\t\t\t\t\tconst {\n\t\t\t\t\t\tindex0,\n\t\t\t\t\t\tindex1\n\t\t\t\t\t} = edgeData[key];\n\n\t\t\t\t\t_v0.fromBufferAttribute(positionAttr, index0);\n\n\t\t\t\t\t_v1$1.fromBufferAttribute(positionAttr, index1);\n\n\t\t\t\t\tvertices.push(_v0.x, _v0.y, _v0.z);\n\t\t\t\t\tvertices.push(_v1$1.x, _v1$1.y, _v1$1.z);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\t}\n\t}\n\n}\n\nclass Shape extends Path {\n\tconstructor(points) {\n\t\tsuper(points);\n\t\tthis.uuid = generateUUID();\n\t\tthis.type = 'Shape';\n\t\tthis.holes = [];\n\t}\n\n\tgetPointsHoles(divisions) {\n\t\tconst holesPts = [];\n\n\t\tfor (let i = 0, l = this.holes.length; i < l; i++) {\n\t\t\tholesPts[i] = this.holes[i].getPoints(divisions);\n\t\t}\n\n\t\treturn holesPts;\n\t} // get points of shape and holes (keypoints based on segments parameter)\n\n\n\textractPoints(divisions) {\n\t\treturn {\n\t\t\tshape: this.getPoints(divisions),\n\t\t\tholes: this.getPointsHoles(divisions)\n\t\t};\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.holes = [];\n\n\t\tfor (let i = 0, l = source.holes.length; i < l; i++) {\n\t\t\tconst hole = source.holes[i];\n\t\t\tthis.holes.push(hole.clone());\n\t\t}\n\n\t\treturn this;\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.uuid = this.uuid;\n\t\tdata.holes = [];\n\n\t\tfor (let i = 0, l = this.holes.length; i < l; i++) {\n\t\t\tconst hole = this.holes[i];\n\t\t\tdata.holes.push(hole.toJSON());\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tfromJSON(json) {\n\t\tsuper.fromJSON(json);\n\t\tthis.uuid = json.uuid;\n\t\tthis.holes = [];\n\n\t\tfor (let i = 0, l = json.holes.length; i < l; i++) {\n\t\t\tconst hole = json.holes[i];\n\t\t\tthis.holes.push(new Path().fromJSON(hole));\n\t\t}\n\n\t\treturn this;\n\t}\n\n}\n\n/**\n * Port from https://github.com/mapbox/earcut (v2.2.2)\n */\nconst Earcut = {\n\ttriangulate: function (data, holeIndices, dim = 2) {\n\t\tconst hasHoles = holeIndices && holeIndices.length;\n\t\tconst outerLen = hasHoles ? holeIndices[0] * dim : data.length;\n\t\tlet outerNode = linkedList(data, 0, outerLen, dim, true);\n\t\tconst triangles = [];\n\t\tif (!outerNode || outerNode.next === outerNode.prev) return triangles;\n\t\tlet minX, minY, maxX, maxY, x, y, invSize;\n\t\tif (hasHoles) outerNode = eliminateHoles(data, holeIndices, outerNode, dim); // if the shape is not too simple, we'll use z-order curve hash later; calculate polygon bbox\n\n\t\tif (data.length > 80 * dim) {\n\t\t\tminX = maxX = data[0];\n\t\t\tminY = maxY = data[1];\n\n\t\t\tfor (let i = dim; i < outerLen; i += dim) {\n\t\t\t\tx = data[i];\n\t\t\t\ty = data[i + 1];\n\t\t\t\tif (x < minX) minX = x;\n\t\t\t\tif (y < minY) minY = y;\n\t\t\t\tif (x > maxX) maxX = x;\n\t\t\t\tif (y > maxY) maxY = y;\n\t\t\t} // minX, minY and invSize are later used to transform coords into integers for z-order calculation\n\n\n\t\t\tinvSize = Math.max(maxX - minX, maxY - minY);\n\t\t\tinvSize = invSize !== 0 ? 1 / invSize : 0;\n\t\t}\n\n\t\tearcutLinked(outerNode, triangles, dim, minX, minY, invSize);\n\t\treturn triangles;\n\t}\n}; // create a circular doubly linked list from polygon points in the specified winding order\n\nfunction linkedList(data, start, end, dim, clockwise) {\n\tlet i, last;\n\n\tif (clockwise === signedArea(data, start, end, dim) > 0) {\n\t\tfor (i = start; i < end; i += dim) last = insertNode(i, data[i], data[i + 1], last);\n\t} else {\n\t\tfor (i = end - dim; i >= start; i -= dim) last = insertNode(i, data[i], data[i + 1], last);\n\t}\n\n\tif (last && equals(last, last.next)) {\n\t\tremoveNode(last);\n\t\tlast = last.next;\n\t}\n\n\treturn last;\n} // eliminate colinear or duplicate points\n\n\nfunction filterPoints(start, end) {\n\tif (!start) return start;\n\tif (!end) end = start;\n\tlet p = start,\n\t\t\tagain;\n\n\tdo {\n\t\tagain = false;\n\n\t\tif (!p.steiner && (equals(p, p.next) || area(p.prev, p, p.next) === 0)) {\n\t\t\tremoveNode(p);\n\t\t\tp = end = p.prev;\n\t\t\tif (p === p.next) break;\n\t\t\tagain = true;\n\t\t} else {\n\t\t\tp = p.next;\n\t\t}\n\t} while (again || p !== end);\n\n\treturn end;\n} // main ear slicing loop which triangulates a polygon (given as a linked list)\n\n\nfunction earcutLinked(ear, triangles, dim, minX, minY, invSize, pass) {\n\tif (!ear) return; // interlink polygon nodes in z-order\n\n\tif (!pass && invSize) indexCurve(ear, minX, minY, invSize);\n\tlet stop = ear,\n\t\t\tprev,\n\t\t\tnext; // iterate through ears, slicing them one by one\n\n\twhile (ear.prev !== ear.next) {\n\t\tprev = ear.prev;\n\t\tnext = ear.next;\n\n\t\tif (invSize ? isEarHashed(ear, minX, minY, invSize) : isEar(ear)) {\n\t\t\t// cut off the triangle\n\t\t\ttriangles.push(prev.i / dim);\n\t\t\ttriangles.push(ear.i / dim);\n\t\t\ttriangles.push(next.i / dim);\n\t\t\tremoveNode(ear); // skipping the next vertex leads to less sliver triangles\n\n\t\t\tear = next.next;\n\t\t\tstop = next.next;\n\t\t\tcontinue;\n\t\t}\n\n\t\tear = next; // if we looped through the whole remaining polygon and can't find any more ears\n\n\t\tif (ear === stop) {\n\t\t\t// try filtering points and slicing again\n\t\t\tif (!pass) {\n\t\t\t\tearcutLinked(filterPoints(ear), triangles, dim, minX, minY, invSize, 1); // if this didn't work, try curing all small self-intersections locally\n\t\t\t} else if (pass === 1) {\n\t\t\t\tear = cureLocalIntersections(filterPoints(ear), triangles, dim);\n\t\t\t\tearcutLinked(ear, triangles, dim, minX, minY, invSize, 2); // as a last resort, try splitting the remaining polygon into two\n\t\t\t} else if (pass === 2) {\n\t\t\t\tsplitEarcut(ear, triangles, dim, minX, minY, invSize);\n\t\t\t}\n\n\t\t\tbreak;\n\t\t}\n\t}\n} // check whether a polygon node forms a valid ear with adjacent nodes\n\n\nfunction isEar(ear) {\n\tconst a = ear.prev,\n\t\t\t\tb = ear,\n\t\t\t\tc = ear.next;\n\tif (area(a, b, c) >= 0) return false; // reflex, can't be an ear\n\t// now make sure we don't have other points inside the potential ear\n\n\tlet p = ear.next.next;\n\n\twhile (p !== ear.prev) {\n\t\tif (pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y) && area(p.prev, p, p.next) >= 0) return false;\n\t\tp = p.next;\n\t}\n\n\treturn true;\n}\n\nfunction isEarHashed(ear, minX, minY, invSize) {\n\tconst a = ear.prev,\n\t\t\t\tb = ear,\n\t\t\t\tc = ear.next;\n\tif (area(a, b, c) >= 0) return false; // reflex, can't be an ear\n\t// triangle bbox; min & max are calculated like this for speed\n\n\tconst minTX = a.x < b.x ? a.x < c.x ? a.x : c.x : b.x < c.x ? b.x : c.x,\n\t\t\t\tminTY = a.y < b.y ? a.y < c.y ? a.y : c.y : b.y < c.y ? b.y : c.y,\n\t\t\t\tmaxTX = a.x > b.x ? a.x > c.x ? a.x : c.x : b.x > c.x ? b.x : c.x,\n\t\t\t\tmaxTY = a.y > b.y ? a.y > c.y ? a.y : c.y : b.y > c.y ? b.y : c.y; // z-order range for the current triangle bbox;\n\n\tconst minZ = zOrder(minTX, minTY, minX, minY, invSize),\n\t\t\t\tmaxZ = zOrder(maxTX, maxTY, minX, minY, invSize);\n\tlet p = ear.prevZ,\n\t\t\tn = ear.nextZ; // look for points inside the triangle in both directions\n\n\twhile (p && p.z >= minZ && n && n.z <= maxZ) {\n\t\tif (p !== ear.prev && p !== ear.next && pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y) && area(p.prev, p, p.next) >= 0) return false;\n\t\tp = p.prevZ;\n\t\tif (n !== ear.prev && n !== ear.next && pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, n.x, n.y) && area(n.prev, n, n.next) >= 0) return false;\n\t\tn = n.nextZ;\n\t} // look for remaining points in decreasing z-order\n\n\n\twhile (p && p.z >= minZ) {\n\t\tif (p !== ear.prev && p !== ear.next && pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y) && area(p.prev, p, p.next) >= 0) return false;\n\t\tp = p.prevZ;\n\t} // look for remaining points in increasing z-order\n\n\n\twhile (n && n.z <= maxZ) {\n\t\tif (n !== ear.prev && n !== ear.next && pointInTriangle(a.x, a.y, b.x, b.y, c.x, c.y, n.x, n.y) && area(n.prev, n, n.next) >= 0) return false;\n\t\tn = n.nextZ;\n\t}\n\n\treturn true;\n} // go through all polygon nodes and cure small local self-intersections\n\n\nfunction cureLocalIntersections(start, triangles, dim) {\n\tlet p = start;\n\n\tdo {\n\t\tconst a = p.prev,\n\t\t\t\t\tb = p.next.next;\n\n\t\tif (!equals(a, b) && intersects(a, p, p.next, b) && locallyInside(a, b) && locallyInside(b, a)) {\n\t\t\ttriangles.push(a.i / dim);\n\t\t\ttriangles.push(p.i / dim);\n\t\t\ttriangles.push(b.i / dim); // remove two nodes involved\n\n\t\t\tremoveNode(p);\n\t\t\tremoveNode(p.next);\n\t\t\tp = start = b;\n\t\t}\n\n\t\tp = p.next;\n\t} while (p !== start);\n\n\treturn filterPoints(p);\n} // try splitting polygon into two and triangulate them independently\n\n\nfunction splitEarcut(start, triangles, dim, minX, minY, invSize) {\n\t// look for a valid diagonal that divides the polygon into two\n\tlet a = start;\n\n\tdo {\n\t\tlet b = a.next.next;\n\n\t\twhile (b !== a.prev) {\n\t\t\tif (a.i !== b.i && isValidDiagonal(a, b)) {\n\t\t\t\t// split the polygon in two by the diagonal\n\t\t\t\tlet c = splitPolygon(a, b); // filter colinear points around the cuts\n\n\t\t\t\ta = filterPoints(a, a.next);\n\t\t\t\tc = filterPoints(c, c.next); // run earcut on each half\n\n\t\t\t\tearcutLinked(a, triangles, dim, minX, minY, invSize);\n\t\t\t\tearcutLinked(c, triangles, dim, minX, minY, invSize);\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tb = b.next;\n\t\t}\n\n\t\ta = a.next;\n\t} while (a !== start);\n} // link every hole into the outer loop, producing a single-ring polygon without holes\n\n\nfunction eliminateHoles(data, holeIndices, outerNode, dim) {\n\tconst queue = [];\n\tlet i, len, start, end, list;\n\n\tfor (i = 0, len = holeIndices.length; i < len; i++) {\n\t\tstart = holeIndices[i] * dim;\n\t\tend = i < len - 1 ? holeIndices[i + 1] * dim : data.length;\n\t\tlist = linkedList(data, start, end, dim, false);\n\t\tif (list === list.next) list.steiner = true;\n\t\tqueue.push(getLeftmost(list));\n\t}\n\n\tqueue.sort(compareX); // process holes from left to right\n\n\tfor (i = 0; i < queue.length; i++) {\n\t\teliminateHole(queue[i], outerNode);\n\t\touterNode = filterPoints(outerNode, outerNode.next);\n\t}\n\n\treturn outerNode;\n}\n\nfunction compareX(a, b) {\n\treturn a.x - b.x;\n} // find a bridge between vertices that connects hole with an outer ring and link it\n\n\nfunction eliminateHole(hole, outerNode) {\n\touterNode = findHoleBridge(hole, outerNode);\n\n\tif (outerNode) {\n\t\tconst b = splitPolygon(outerNode, hole); // filter collinear points around the cuts\n\n\t\tfilterPoints(outerNode, outerNode.next);\n\t\tfilterPoints(b, b.next);\n\t}\n} // David Eberly's algorithm for finding a bridge between hole and outer polygon\n\n\nfunction findHoleBridge(hole, outerNode) {\n\tlet p = outerNode;\n\tconst hx = hole.x;\n\tconst hy = hole.y;\n\tlet qx = -Infinity,\n\t\t\tm; // find a segment intersected by a ray from the hole's leftmost point to the left;\n\t// segment's endpoint with lesser x will be potential connection point\n\n\tdo {\n\t\tif (hy <= p.y && hy >= p.next.y && p.next.y !== p.y) {\n\t\t\tconst x = p.x + (hy - p.y) * (p.next.x - p.x) / (p.next.y - p.y);\n\n\t\t\tif (x <= hx && x > qx) {\n\t\t\t\tqx = x;\n\n\t\t\t\tif (x === hx) {\n\t\t\t\t\tif (hy === p.y) return p;\n\t\t\t\t\tif (hy === p.next.y) return p.next;\n\t\t\t\t}\n\n\t\t\t\tm = p.x < p.next.x ? p : p.next;\n\t\t\t}\n\t\t}\n\n\t\tp = p.next;\n\t} while (p !== outerNode);\n\n\tif (!m) return null;\n\tif (hx === qx) return m; // hole touches outer segment; pick leftmost endpoint\n\t// look for points inside the triangle of hole point, segment intersection and endpoint;\n\t// if there are no points found, we have a valid connection;\n\t// otherwise choose the point of the minimum angle with the ray as connection point\n\n\tconst stop = m,\n\t\t\t\tmx = m.x,\n\t\t\t\tmy = m.y;\n\tlet tanMin = Infinity,\n\t\t\ttan;\n\tp = m;\n\n\tdo {\n\t\tif (hx >= p.x && p.x >= mx && hx !== p.x && pointInTriangle(hy < my ? hx : qx, hy, mx, my, hy < my ? qx : hx, hy, p.x, p.y)) {\n\t\t\ttan = Math.abs(hy - p.y) / (hx - p.x); // tangential\n\n\t\t\tif (locallyInside(p, hole) && (tan < tanMin || tan === tanMin && (p.x > m.x || p.x === m.x && sectorContainsSector(m, p)))) {\n\t\t\t\tm = p;\n\t\t\t\ttanMin = tan;\n\t\t\t}\n\t\t}\n\n\t\tp = p.next;\n\t} while (p !== stop);\n\n\treturn m;\n} // whether sector in vertex m contains sector in vertex p in the same coordinates\n\n\nfunction sectorContainsSector(m, p) {\n\treturn area(m.prev, m, p.prev) < 0 && area(p.next, m, m.next) < 0;\n} // interlink polygon nodes in z-order\n\n\nfunction indexCurve(start, minX, minY, invSize) {\n\tlet p = start;\n\n\tdo {\n\t\tif (p.z === null) p.z = zOrder(p.x, p.y, minX, minY, invSize);\n\t\tp.prevZ = p.prev;\n\t\tp.nextZ = p.next;\n\t\tp = p.next;\n\t} while (p !== start);\n\n\tp.prevZ.nextZ = null;\n\tp.prevZ = null;\n\tsortLinked(p);\n} // Simon Tatham's linked list merge sort algorithm\n// http://www.chiark.greenend.org.uk/~sgtatham/algorithms/listsort.html\n\n\nfunction sortLinked(list) {\n\tlet i,\n\t\t\tp,\n\t\t\tq,\n\t\t\te,\n\t\t\ttail,\n\t\t\tnumMerges,\n\t\t\tpSize,\n\t\t\tqSize,\n\t\t\tinSize = 1;\n\n\tdo {\n\t\tp = list;\n\t\tlist = null;\n\t\ttail = null;\n\t\tnumMerges = 0;\n\n\t\twhile (p) {\n\t\t\tnumMerges++;\n\t\t\tq = p;\n\t\t\tpSize = 0;\n\n\t\t\tfor (i = 0; i < inSize; i++) {\n\t\t\t\tpSize++;\n\t\t\t\tq = q.nextZ;\n\t\t\t\tif (!q) break;\n\t\t\t}\n\n\t\t\tqSize = inSize;\n\n\t\t\twhile (pSize > 0 || qSize > 0 && q) {\n\t\t\t\tif (pSize !== 0 && (qSize === 0 || !q || p.z <= q.z)) {\n\t\t\t\t\te = p;\n\t\t\t\t\tp = p.nextZ;\n\t\t\t\t\tpSize--;\n\t\t\t\t} else {\n\t\t\t\t\te = q;\n\t\t\t\t\tq = q.nextZ;\n\t\t\t\t\tqSize--;\n\t\t\t\t}\n\n\t\t\t\tif (tail) tail.nextZ = e;else list = e;\n\t\t\t\te.prevZ = tail;\n\t\t\t\ttail = e;\n\t\t\t}\n\n\t\t\tp = q;\n\t\t}\n\n\t\ttail.nextZ = null;\n\t\tinSize *= 2;\n\t} while (numMerges > 1);\n\n\treturn list;\n} // z-order of a point given coords and inverse of the longer side of data bbox\n\n\nfunction zOrder(x, y, minX, minY, invSize) {\n\t// coords are transformed into non-negative 15-bit integer range\n\tx = 32767 * (x - minX) * invSize;\n\ty = 32767 * (y - minY) * invSize;\n\tx = (x | x << 8) & 0x00FF00FF;\n\tx = (x | x << 4) & 0x0F0F0F0F;\n\tx = (x | x << 2) & 0x33333333;\n\tx = (x | x << 1) & 0x55555555;\n\ty = (y | y << 8) & 0x00FF00FF;\n\ty = (y | y << 4) & 0x0F0F0F0F;\n\ty = (y | y << 2) & 0x33333333;\n\ty = (y | y << 1) & 0x55555555;\n\treturn x | y << 1;\n} // find the leftmost node of a polygon ring\n\n\nfunction getLeftmost(start) {\n\tlet p = start,\n\t\t\tleftmost = start;\n\n\tdo {\n\t\tif (p.x < leftmost.x || p.x === leftmost.x && p.y < leftmost.y) leftmost = p;\n\t\tp = p.next;\n\t} while (p !== start);\n\n\treturn leftmost;\n} // check if a point lies within a convex triangle\n\n\nfunction pointInTriangle(ax, ay, bx, by, cx, cy, px, py) {\n\treturn (cx - px) * (ay - py) - (ax - px) * (cy - py) >= 0 && (ax - px) * (by - py) - (bx - px) * (ay - py) >= 0 && (bx - px) * (cy - py) - (cx - px) * (by - py) >= 0;\n} // check if a diagonal between two polygon nodes is valid (lies in polygon interior)\n\n\nfunction isValidDiagonal(a, b) {\n\treturn a.next.i !== b.i && a.prev.i !== b.i && !intersectsPolygon(a, b) && ( // doesn't intersect other edges\n\tlocallyInside(a, b) && locallyInside(b, a) && middleInside(a, b) && ( // locally visible\n\tarea(a.prev, a, b.prev) || area(a, b.prev, b)) || // does not create opposite-facing sectors\n\tequals(a, b) && area(a.prev, a, a.next) > 0 && area(b.prev, b, b.next) > 0); // special zero-length case\n} // signed area of a triangle\n\n\nfunction area(p, q, r) {\n\treturn (q.y - p.y) * (r.x - q.x) - (q.x - p.x) * (r.y - q.y);\n} // check if two points are equal\n\n\nfunction equals(p1, p2) {\n\treturn p1.x === p2.x && p1.y === p2.y;\n} // check if two segments intersect\n\n\nfunction intersects(p1, q1, p2, q2) {\n\tconst o1 = sign(area(p1, q1, p2));\n\tconst o2 = sign(area(p1, q1, q2));\n\tconst o3 = sign(area(p2, q2, p1));\n\tconst o4 = sign(area(p2, q2, q1));\n\tif (o1 !== o2 && o3 !== o4) return true; // general case\n\n\tif (o1 === 0 && onSegment(p1, p2, q1)) return true; // p1, q1 and p2 are collinear and p2 lies on p1q1\n\n\tif (o2 === 0 && onSegment(p1, q2, q1)) return true; // p1, q1 and q2 are collinear and q2 lies on p1q1\n\n\tif (o3 === 0 && onSegment(p2, p1, q2)) return true; // p2, q2 and p1 are collinear and p1 lies on p2q2\n\n\tif (o4 === 0 && onSegment(p2, q1, q2)) return true; // p2, q2 and q1 are collinear and q1 lies on p2q2\n\n\treturn false;\n} // for collinear points p, q, r, check if point q lies on segment pr\n\n\nfunction onSegment(p, q, r) {\n\treturn q.x <= Math.max(p.x, r.x) && q.x >= Math.min(p.x, r.x) && q.y <= Math.max(p.y, r.y) && q.y >= Math.min(p.y, r.y);\n}\n\nfunction sign(num) {\n\treturn num > 0 ? 1 : num < 0 ? -1 : 0;\n} // check if a polygon diagonal intersects any polygon segments\n\n\nfunction intersectsPolygon(a, b) {\n\tlet p = a;\n\n\tdo {\n\t\tif (p.i !== a.i && p.next.i !== a.i && p.i !== b.i && p.next.i !== b.i && intersects(p, p.next, a, b)) return true;\n\t\tp = p.next;\n\t} while (p !== a);\n\n\treturn false;\n} // check if a polygon diagonal is locally inside the polygon\n\n\nfunction locallyInside(a, b) {\n\treturn area(a.prev, a, a.next) < 0 ? area(a, b, a.next) >= 0 && area(a, a.prev, b) >= 0 : area(a, b, a.prev) < 0 || area(a, a.next, b) < 0;\n} // check if the middle point of a polygon diagonal is inside the polygon\n\n\nfunction middleInside(a, b) {\n\tlet p = a,\n\t\t\tinside = false;\n\tconst px = (a.x + b.x) / 2,\n\t\t\t\tpy = (a.y + b.y) / 2;\n\n\tdo {\n\t\tif (p.y > py !== p.next.y > py && p.next.y !== p.y && px < (p.next.x - p.x) * (py - p.y) / (p.next.y - p.y) + p.x) inside = !inside;\n\t\tp = p.next;\n\t} while (p !== a);\n\n\treturn inside;\n} // link two polygon vertices with a bridge; if the vertices belong to the same ring, it splits polygon into two;\n// if one belongs to the outer ring and another to a hole, it merges it into a single ring\n\n\nfunction splitPolygon(a, b) {\n\tconst a2 = new Node(a.i, a.x, a.y),\n\t\t\t\tb2 = new Node(b.i, b.x, b.y),\n\t\t\t\tan = a.next,\n\t\t\t\tbp = b.prev;\n\ta.next = b;\n\tb.prev = a;\n\ta2.next = an;\n\tan.prev = a2;\n\tb2.next = a2;\n\ta2.prev = b2;\n\tbp.next = b2;\n\tb2.prev = bp;\n\treturn b2;\n} // create a node and optionally link it with previous one (in a circular doubly linked list)\n\n\nfunction insertNode(i, x, y, last) {\n\tconst p = new Node(i, x, y);\n\n\tif (!last) {\n\t\tp.prev = p;\n\t\tp.next = p;\n\t} else {\n\t\tp.next = last.next;\n\t\tp.prev = last;\n\t\tlast.next.prev = p;\n\t\tlast.next = p;\n\t}\n\n\treturn p;\n}\n\nfunction removeNode(p) {\n\tp.next.prev = p.prev;\n\tp.prev.next = p.next;\n\tif (p.prevZ) p.prevZ.nextZ = p.nextZ;\n\tif (p.nextZ) p.nextZ.prevZ = p.prevZ;\n}\n\nfunction Node(i, x, y) {\n\t// vertex index in coordinates array\n\tthis.i = i; // vertex coordinates\n\n\tthis.x = x;\n\tthis.y = y; // previous and next vertex nodes in a polygon ring\n\n\tthis.prev = null;\n\tthis.next = null; // z-order curve value\n\n\tthis.z = null; // previous and next nodes in z-order\n\n\tthis.prevZ = null;\n\tthis.nextZ = null; // indicates whether this is a steiner point\n\n\tthis.steiner = false;\n}\n\nfunction signedArea(data, start, end, dim) {\n\tlet sum = 0;\n\n\tfor (let i = start, j = end - dim; i < end; i += dim) {\n\t\tsum += (data[j] - data[i]) * (data[i + 1] + data[j + 1]);\n\t\tj = i;\n\t}\n\n\treturn sum;\n}\n\nclass ShapeUtils {\n\t// calculate area of the contour polygon\n\tstatic area(contour) {\n\t\tconst n = contour.length;\n\t\tlet a = 0.0;\n\n\t\tfor (let p = n - 1, q = 0; q < n; p = q++) {\n\t\t\ta += contour[p].x * contour[q].y - contour[q].x * contour[p].y;\n\t\t}\n\n\t\treturn a * 0.5;\n\t}\n\n\tstatic isClockWise(pts) {\n\t\treturn ShapeUtils.area(pts) < 0;\n\t}\n\n\tstatic triangulateShape(contour, holes) {\n\t\tconst vertices = []; // flat array of vertices like [ x0,y0, x1,y1, x2,y2, ... ]\n\n\t\tconst holeIndices = []; // array of hole indices\n\n\t\tconst faces = []; // final array of vertex indices like [ [ a,b,d ], [ b,c,d ] ]\n\n\t\tremoveDupEndPts(contour);\n\t\taddContour(vertices, contour); //\n\n\t\tlet holeIndex = contour.length;\n\t\tholes.forEach(removeDupEndPts);\n\n\t\tfor (let i = 0; i < holes.length; i++) {\n\t\t\tholeIndices.push(holeIndex);\n\t\t\tholeIndex += holes[i].length;\n\t\t\taddContour(vertices, holes[i]);\n\t\t} //\n\n\n\t\tconst triangles = Earcut.triangulate(vertices, holeIndices); //\n\n\t\tfor (let i = 0; i < triangles.length; i += 3) {\n\t\t\tfaces.push(triangles.slice(i, i + 3));\n\t\t}\n\n\t\treturn faces;\n\t}\n\n}\n\nfunction removeDupEndPts(points) {\n\tconst l = points.length;\n\n\tif (l > 2 && points[l - 1].equals(points[0])) {\n\t\tpoints.pop();\n\t}\n}\n\nfunction addContour(vertices, contour) {\n\tfor (let i = 0; i < contour.length; i++) {\n\t\tvertices.push(contour[i].x);\n\t\tvertices.push(contour[i].y);\n\t}\n}\n\n/**\n * Creates extruded geometry from a path shape.\n *\n * parameters = {\n *\n *\tcurveSegments: , // number of points on the curves\n *\tsteps: , // number of points for z-side extrusions / used for subdividing segments of extrude spline too\n *\tdepth: , // Depth to extrude the shape\n *\n *\tbevelEnabled: , // turn on bevel\n *\tbevelThickness: , // how deep into the original shape bevel goes\n *\tbevelSize: , // how far from shape outline (including bevelOffset) is bevel\n *\tbevelOffset: , // how far from shape outline does bevel start\n *\tbevelSegments: , // number of bevel layers\n *\n *\textrudePath: // curve to extrude shape along\n *\n *\tUVGenerator: // object that provides UV generator functions\n *\n * }\n */\n\nclass ExtrudeGeometry extends BufferGeometry {\n\tconstructor(shapes = new Shape([new Vector2(0.5, 0.5), new Vector2(-0.5, 0.5), new Vector2(-0.5, -0.5), new Vector2(0.5, -0.5)]), options = {}) {\n\t\tsuper();\n\t\tthis.type = 'ExtrudeGeometry';\n\t\tthis.parameters = {\n\t\t\tshapes: shapes,\n\t\t\toptions: options\n\t\t};\n\t\tshapes = Array.isArray(shapes) ? shapes : [shapes];\n\t\tconst scope = this;\n\t\tconst verticesArray = [];\n\t\tconst uvArray = [];\n\n\t\tfor (let i = 0, l = shapes.length; i < l; i++) {\n\t\t\tconst shape = shapes[i];\n\t\t\taddShape(shape);\n\t\t} // build geometry\n\n\n\t\tthis.setAttribute('position', new Float32BufferAttribute(verticesArray, 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvArray, 2));\n\t\tthis.computeVertexNormals(); // functions\n\n\t\tfunction addShape(shape) {\n\t\t\tconst placeholder = []; // options\n\n\t\t\tconst curveSegments = options.curveSegments !== undefined ? options.curveSegments : 12;\n\t\t\tconst steps = options.steps !== undefined ? options.steps : 1;\n\t\t\tlet depth = options.depth !== undefined ? options.depth : 1;\n\t\t\tlet bevelEnabled = options.bevelEnabled !== undefined ? options.bevelEnabled : true;\n\t\t\tlet bevelThickness = options.bevelThickness !== undefined ? options.bevelThickness : 0.2;\n\t\t\tlet bevelSize = options.bevelSize !== undefined ? options.bevelSize : bevelThickness - 0.1;\n\t\t\tlet bevelOffset = options.bevelOffset !== undefined ? options.bevelOffset : 0;\n\t\t\tlet bevelSegments = options.bevelSegments !== undefined ? options.bevelSegments : 3;\n\t\t\tconst extrudePath = options.extrudePath;\n\t\t\tconst uvgen = options.UVGenerator !== undefined ? options.UVGenerator : WorldUVGenerator; // deprecated options\n\n\t\t\tif (options.amount !== undefined) {\n\t\t\t\tconsole.warn('THREE.ExtrudeBufferGeometry: amount has been renamed to depth.');\n\t\t\t\tdepth = options.amount;\n\t\t\t} //\n\n\n\t\t\tlet extrudePts,\n\t\t\t\t\textrudeByPath = false;\n\t\t\tlet splineTube, binormal, normal, position2;\n\n\t\t\tif (extrudePath) {\n\t\t\t\textrudePts = extrudePath.getSpacedPoints(steps);\n\t\t\t\textrudeByPath = true;\n\t\t\t\tbevelEnabled = false; // bevels not supported for path extrusion\n\t\t\t\t// SETUP TNB variables\n\t\t\t\t// TODO1 - have a .isClosed in spline?\n\n\t\t\t\tsplineTube = extrudePath.computeFrenetFrames(steps, false); // console.log(splineTube, 'splineTube', splineTube.normals.length, 'steps', steps, 'extrudePts', extrudePts.length);\n\n\t\t\t\tbinormal = new Vector3();\n\t\t\t\tnormal = new Vector3();\n\t\t\t\tposition2 = new Vector3();\n\t\t\t} // Safeguards if bevels are not enabled\n\n\n\t\t\tif (!bevelEnabled) {\n\t\t\t\tbevelSegments = 0;\n\t\t\t\tbevelThickness = 0;\n\t\t\t\tbevelSize = 0;\n\t\t\t\tbevelOffset = 0;\n\t\t\t} // Variables initialization\n\n\n\t\t\tconst shapePoints = shape.extractPoints(curveSegments);\n\t\t\tlet vertices = shapePoints.shape;\n\t\t\tconst holes = shapePoints.holes;\n\t\t\tconst reverse = !ShapeUtils.isClockWise(vertices);\n\n\t\t\tif (reverse) {\n\t\t\t\tvertices = vertices.reverse(); // Maybe we should also check if holes are in the opposite direction, just to be safe ...\n\n\t\t\t\tfor (let h = 0, hl = holes.length; h < hl; h++) {\n\t\t\t\t\tconst ahole = holes[h];\n\n\t\t\t\t\tif (ShapeUtils.isClockWise(ahole)) {\n\t\t\t\t\t\tholes[h] = ahole.reverse();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst faces = ShapeUtils.triangulateShape(vertices, holes);\n\t\t\t/* Vertices */\n\n\t\t\tconst contour = vertices; // vertices has all points but contour has only points of circumference\n\n\t\t\tfor (let h = 0, hl = holes.length; h < hl; h++) {\n\t\t\t\tconst ahole = holes[h];\n\t\t\t\tvertices = vertices.concat(ahole);\n\t\t\t}\n\n\t\t\tfunction scalePt2(pt, vec, size) {\n\t\t\t\tif (!vec) console.error('THREE.ExtrudeGeometry: vec does not exist');\n\t\t\t\treturn vec.clone().multiplyScalar(size).add(pt);\n\t\t\t}\n\n\t\t\tconst vlen = vertices.length,\n\t\t\t\t\t\tflen = faces.length; // Find directions for point movement\n\n\t\t\tfunction getBevelVec(inPt, inPrev, inNext) {\n\t\t\t\t// computes for inPt the corresponding point inPt' on a new contour\n\t\t\t\t//\t shifted by 1 unit (length of normalized vector) to the left\n\t\t\t\t// if we walk along contour clockwise, this new contour is outside the old one\n\t\t\t\t//\n\t\t\t\t// inPt' is the intersection of the two lines parallel to the two\n\t\t\t\t//\tadjacent edges of inPt at a distance of 1 unit on the left side.\n\t\t\t\tlet v_trans_x, v_trans_y, shrink_by; // resulting translation vector for inPt\n\t\t\t\t// good reading for geometry algorithms (here: line-line intersection)\n\t\t\t\t// http://geomalgorithms.com/a05-_intersect-1.html\n\n\t\t\t\tconst v_prev_x = inPt.x - inPrev.x,\n\t\t\t\t\t\t\tv_prev_y = inPt.y - inPrev.y;\n\t\t\t\tconst v_next_x = inNext.x - inPt.x,\n\t\t\t\t\t\t\tv_next_y = inNext.y - inPt.y;\n\t\t\t\tconst v_prev_lensq = v_prev_x * v_prev_x + v_prev_y * v_prev_y; // check for collinear edges\n\n\t\t\t\tconst collinear0 = v_prev_x * v_next_y - v_prev_y * v_next_x;\n\n\t\t\t\tif (Math.abs(collinear0) > Number.EPSILON) {\n\t\t\t\t\t// not collinear\n\t\t\t\t\t// length of vectors for normalizing\n\t\t\t\t\tconst v_prev_len = Math.sqrt(v_prev_lensq);\n\t\t\t\t\tconst v_next_len = Math.sqrt(v_next_x * v_next_x + v_next_y * v_next_y); // shift adjacent points by unit vectors to the left\n\n\t\t\t\t\tconst ptPrevShift_x = inPrev.x - v_prev_y / v_prev_len;\n\t\t\t\t\tconst ptPrevShift_y = inPrev.y + v_prev_x / v_prev_len;\n\t\t\t\t\tconst ptNextShift_x = inNext.x - v_next_y / v_next_len;\n\t\t\t\t\tconst ptNextShift_y = inNext.y + v_next_x / v_next_len; // scaling factor for v_prev to intersection point\n\n\t\t\t\t\tconst sf = ((ptNextShift_x - ptPrevShift_x) * v_next_y - (ptNextShift_y - ptPrevShift_y) * v_next_x) / (v_prev_x * v_next_y - v_prev_y * v_next_x); // vector from inPt to intersection point\n\n\t\t\t\t\tv_trans_x = ptPrevShift_x + v_prev_x * sf - inPt.x;\n\t\t\t\t\tv_trans_y = ptPrevShift_y + v_prev_y * sf - inPt.y; // Don't normalize!, otherwise sharp corners become ugly\n\t\t\t\t\t//\tbut prevent crazy spikes\n\n\t\t\t\t\tconst v_trans_lensq = v_trans_x * v_trans_x + v_trans_y * v_trans_y;\n\n\t\t\t\t\tif (v_trans_lensq <= 2) {\n\t\t\t\t\t\treturn new Vector2(v_trans_x, v_trans_y);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tshrink_by = Math.sqrt(v_trans_lensq / 2);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// handle special case of collinear edges\n\t\t\t\t\tlet direction_eq = false; // assumes: opposite\n\n\t\t\t\t\tif (v_prev_x > Number.EPSILON) {\n\t\t\t\t\t\tif (v_next_x > Number.EPSILON) {\n\t\t\t\t\t\t\tdirection_eq = true;\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tif (v_prev_x < -Number.EPSILON) {\n\t\t\t\t\t\t\tif (v_next_x < -Number.EPSILON) {\n\t\t\t\t\t\t\t\tdirection_eq = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tif (Math.sign(v_prev_y) === Math.sign(v_next_y)) {\n\t\t\t\t\t\t\t\tdirection_eq = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (direction_eq) {\n\t\t\t\t\t\t// console.log(\"Warning: lines are a straight sequence\");\n\t\t\t\t\t\tv_trans_x = -v_prev_y;\n\t\t\t\t\t\tv_trans_y = v_prev_x;\n\t\t\t\t\t\tshrink_by = Math.sqrt(v_prev_lensq);\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// console.log(\"Warning: lines are a straight spike\");\n\t\t\t\t\t\tv_trans_x = v_prev_x;\n\t\t\t\t\t\tv_trans_y = v_prev_y;\n\t\t\t\t\t\tshrink_by = Math.sqrt(v_prev_lensq / 2);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn new Vector2(v_trans_x / shrink_by, v_trans_y / shrink_by);\n\t\t\t}\n\n\t\t\tconst contourMovements = [];\n\n\t\t\tfor (let i = 0, il = contour.length, j = il - 1, k = i + 1; i < il; i++, j++, k++) {\n\t\t\t\tif (j === il) j = 0;\n\t\t\t\tif (k === il) k = 0; //\t(j)---(i)---(k)\n\t\t\t\t// console.log('i,j,k', i, j , k)\n\n\t\t\t\tcontourMovements[i] = getBevelVec(contour[i], contour[j], contour[k]);\n\t\t\t}\n\n\t\t\tconst holesMovements = [];\n\t\t\tlet oneHoleMovements,\n\t\t\t\t\tverticesMovements = contourMovements.concat();\n\n\t\t\tfor (let h = 0, hl = holes.length; h < hl; h++) {\n\t\t\t\tconst ahole = holes[h];\n\t\t\t\toneHoleMovements = [];\n\n\t\t\t\tfor (let i = 0, il = ahole.length, j = il - 1, k = i + 1; i < il; i++, j++, k++) {\n\t\t\t\t\tif (j === il) j = 0;\n\t\t\t\t\tif (k === il) k = 0; //\t(j)---(i)---(k)\n\n\t\t\t\t\toneHoleMovements[i] = getBevelVec(ahole[i], ahole[j], ahole[k]);\n\t\t\t\t}\n\n\t\t\t\tholesMovements.push(oneHoleMovements);\n\t\t\t\tverticesMovements = verticesMovements.concat(oneHoleMovements);\n\t\t\t} // Loop bevelSegments, 1 for the front, 1 for the back\n\n\n\t\t\tfor (let b = 0; b < bevelSegments; b++) {\n\t\t\t\t//for ( b = bevelSegments; b > 0; b -- ) {\n\t\t\t\tconst t = b / bevelSegments;\n\t\t\t\tconst z = bevelThickness * Math.cos(t * Math.PI / 2);\n\t\t\t\tconst bs = bevelSize * Math.sin(t * Math.PI / 2) + bevelOffset; // contract shape\n\n\t\t\t\tfor (let i = 0, il = contour.length; i < il; i++) {\n\t\t\t\t\tconst vert = scalePt2(contour[i], contourMovements[i], bs);\n\t\t\t\t\tv(vert.x, vert.y, -z);\n\t\t\t\t} // expand holes\n\n\n\t\t\t\tfor (let h = 0, hl = holes.length; h < hl; h++) {\n\t\t\t\t\tconst ahole = holes[h];\n\t\t\t\t\toneHoleMovements = holesMovements[h];\n\n\t\t\t\t\tfor (let i = 0, il = ahole.length; i < il; i++) {\n\t\t\t\t\t\tconst vert = scalePt2(ahole[i], oneHoleMovements[i], bs);\n\t\t\t\t\t\tv(vert.x, vert.y, -z);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst bs = bevelSize + bevelOffset; // Back facing vertices\n\n\t\t\tfor (let i = 0; i < vlen; i++) {\n\t\t\t\tconst vert = bevelEnabled ? scalePt2(vertices[i], verticesMovements[i], bs) : vertices[i];\n\n\t\t\t\tif (!extrudeByPath) {\n\t\t\t\t\tv(vert.x, vert.y, 0);\n\t\t\t\t} else {\n\t\t\t\t\t// v( vert.x, vert.y + extrudePts[ 0 ].y, extrudePts[ 0 ].x );\n\t\t\t\t\tnormal.copy(splineTube.normals[0]).multiplyScalar(vert.x);\n\t\t\t\t\tbinormal.copy(splineTube.binormals[0]).multiplyScalar(vert.y);\n\t\t\t\t\tposition2.copy(extrudePts[0]).add(normal).add(binormal);\n\t\t\t\t\tv(position2.x, position2.y, position2.z);\n\t\t\t\t}\n\t\t\t} // Add stepped vertices...\n\t\t\t// Including front facing vertices\n\n\n\t\t\tfor (let s = 1; s <= steps; s++) {\n\t\t\t\tfor (let i = 0; i < vlen; i++) {\n\t\t\t\t\tconst vert = bevelEnabled ? scalePt2(vertices[i], verticesMovements[i], bs) : vertices[i];\n\n\t\t\t\t\tif (!extrudeByPath) {\n\t\t\t\t\t\tv(vert.x, vert.y, depth / steps * s);\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// v( vert.x, vert.y + extrudePts[ s - 1 ].y, extrudePts[ s - 1 ].x );\n\t\t\t\t\t\tnormal.copy(splineTube.normals[s]).multiplyScalar(vert.x);\n\t\t\t\t\t\tbinormal.copy(splineTube.binormals[s]).multiplyScalar(vert.y);\n\t\t\t\t\t\tposition2.copy(extrudePts[s]).add(normal).add(binormal);\n\t\t\t\t\t\tv(position2.x, position2.y, position2.z);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} // Add bevel segments planes\n\t\t\t//for ( b = 1; b <= bevelSegments; b ++ ) {\n\n\n\t\t\tfor (let b = bevelSegments - 1; b >= 0; b--) {\n\t\t\t\tconst t = b / bevelSegments;\n\t\t\t\tconst z = bevelThickness * Math.cos(t * Math.PI / 2);\n\t\t\t\tconst bs = bevelSize * Math.sin(t * Math.PI / 2) + bevelOffset; // contract shape\n\n\t\t\t\tfor (let i = 0, il = contour.length; i < il; i++) {\n\t\t\t\t\tconst vert = scalePt2(contour[i], contourMovements[i], bs);\n\t\t\t\t\tv(vert.x, vert.y, depth + z);\n\t\t\t\t} // expand holes\n\n\n\t\t\t\tfor (let h = 0, hl = holes.length; h < hl; h++) {\n\t\t\t\t\tconst ahole = holes[h];\n\t\t\t\t\toneHoleMovements = holesMovements[h];\n\n\t\t\t\t\tfor (let i = 0, il = ahole.length; i < il; i++) {\n\t\t\t\t\t\tconst vert = scalePt2(ahole[i], oneHoleMovements[i], bs);\n\n\t\t\t\t\t\tif (!extrudeByPath) {\n\t\t\t\t\t\t\tv(vert.x, vert.y, depth + z);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tv(vert.x, vert.y + extrudePts[steps - 1].y, extrudePts[steps - 1].x + z);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\t/* Faces */\n\t\t\t// Top and bottom faces\n\n\n\t\t\tbuildLidFaces(); // Sides faces\n\n\t\t\tbuildSideFaces(); /////\tInternal functions\n\n\t\t\tfunction buildLidFaces() {\n\t\t\t\tconst start = verticesArray.length / 3;\n\n\t\t\t\tif (bevelEnabled) {\n\t\t\t\t\tlet layer = 0; // steps + 1\n\n\t\t\t\t\tlet offset = vlen * layer; // Bottom faces\n\n\t\t\t\t\tfor (let i = 0; i < flen; i++) {\n\t\t\t\t\t\tconst face = faces[i];\n\t\t\t\t\t\tf3(face[2] + offset, face[1] + offset, face[0] + offset);\n\t\t\t\t\t}\n\n\t\t\t\t\tlayer = steps + bevelSegments * 2;\n\t\t\t\t\toffset = vlen * layer; // Top faces\n\n\t\t\t\t\tfor (let i = 0; i < flen; i++) {\n\t\t\t\t\t\tconst face = faces[i];\n\t\t\t\t\t\tf3(face[0] + offset, face[1] + offset, face[2] + offset);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// Bottom faces\n\t\t\t\t\tfor (let i = 0; i < flen; i++) {\n\t\t\t\t\t\tconst face = faces[i];\n\t\t\t\t\t\tf3(face[2], face[1], face[0]);\n\t\t\t\t\t} // Top faces\n\n\n\t\t\t\t\tfor (let i = 0; i < flen; i++) {\n\t\t\t\t\t\tconst face = faces[i];\n\t\t\t\t\t\tf3(face[0] + vlen * steps, face[1] + vlen * steps, face[2] + vlen * steps);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tscope.addGroup(start, verticesArray.length / 3 - start, 0);\n\t\t\t} // Create faces for the z-sides of the shape\n\n\n\t\t\tfunction buildSideFaces() {\n\t\t\t\tconst start = verticesArray.length / 3;\n\t\t\t\tlet layeroffset = 0;\n\t\t\t\tsidewalls(contour, layeroffset);\n\t\t\t\tlayeroffset += contour.length;\n\n\t\t\t\tfor (let h = 0, hl = holes.length; h < hl; h++) {\n\t\t\t\t\tconst ahole = holes[h];\n\t\t\t\t\tsidewalls(ahole, layeroffset); //, true\n\n\t\t\t\t\tlayeroffset += ahole.length;\n\t\t\t\t}\n\n\t\t\t\tscope.addGroup(start, verticesArray.length / 3 - start, 1);\n\t\t\t}\n\n\t\t\tfunction sidewalls(contour, layeroffset) {\n\t\t\t\tlet i = contour.length;\n\n\t\t\t\twhile (--i >= 0) {\n\t\t\t\t\tconst j = i;\n\t\t\t\t\tlet k = i - 1;\n\t\t\t\t\tif (k < 0) k = contour.length - 1; //console.log('b', i,j, i-1, k,vertices.length);\n\n\t\t\t\t\tfor (let s = 0, sl = steps + bevelSegments * 2; s < sl; s++) {\n\t\t\t\t\t\tconst slen1 = vlen * s;\n\t\t\t\t\t\tconst slen2 = vlen * (s + 1);\n\t\t\t\t\t\tconst a = layeroffset + j + slen1,\n\t\t\t\t\t\t\t\t\tb = layeroffset + k + slen1,\n\t\t\t\t\t\t\t\t\tc = layeroffset + k + slen2,\n\t\t\t\t\t\t\t\t\td = layeroffset + j + slen2;\n\t\t\t\t\t\tf4(a, b, c, d);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfunction v(x, y, z) {\n\t\t\t\tplaceholder.push(x);\n\t\t\t\tplaceholder.push(y);\n\t\t\t\tplaceholder.push(z);\n\t\t\t}\n\n\t\t\tfunction f3(a, b, c) {\n\t\t\t\taddVertex(a);\n\t\t\t\taddVertex(b);\n\t\t\t\taddVertex(c);\n\t\t\t\tconst nextIndex = verticesArray.length / 3;\n\t\t\t\tconst uvs = uvgen.generateTopUV(scope, verticesArray, nextIndex - 3, nextIndex - 2, nextIndex - 1);\n\t\t\t\taddUV(uvs[0]);\n\t\t\t\taddUV(uvs[1]);\n\t\t\t\taddUV(uvs[2]);\n\t\t\t}\n\n\t\t\tfunction f4(a, b, c, d) {\n\t\t\t\taddVertex(a);\n\t\t\t\taddVertex(b);\n\t\t\t\taddVertex(d);\n\t\t\t\taddVertex(b);\n\t\t\t\taddVertex(c);\n\t\t\t\taddVertex(d);\n\t\t\t\tconst nextIndex = verticesArray.length / 3;\n\t\t\t\tconst uvs = uvgen.generateSideWallUV(scope, verticesArray, nextIndex - 6, nextIndex - 3, nextIndex - 2, nextIndex - 1);\n\t\t\t\taddUV(uvs[0]);\n\t\t\t\taddUV(uvs[1]);\n\t\t\t\taddUV(uvs[3]);\n\t\t\t\taddUV(uvs[1]);\n\t\t\t\taddUV(uvs[2]);\n\t\t\t\taddUV(uvs[3]);\n\t\t\t}\n\n\t\t\tfunction addVertex(index) {\n\t\t\t\tverticesArray.push(placeholder[index * 3 + 0]);\n\t\t\t\tverticesArray.push(placeholder[index * 3 + 1]);\n\t\t\t\tverticesArray.push(placeholder[index * 3 + 2]);\n\t\t\t}\n\n\t\t\tfunction addUV(vector2) {\n\t\t\t\tuvArray.push(vector2.x);\n\t\t\t\tuvArray.push(vector2.y);\n\t\t\t}\n\t\t}\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tconst shapes = this.parameters.shapes;\n\t\tconst options = this.parameters.options;\n\t\treturn toJSON$1(shapes, options, data);\n\t}\n\n\tstatic fromJSON(data, shapes) {\n\t\tconst geometryShapes = [];\n\n\t\tfor (let j = 0, jl = data.shapes.length; j < jl; j++) {\n\t\t\tconst shape = shapes[data.shapes[j]];\n\t\t\tgeometryShapes.push(shape);\n\t\t}\n\n\t\tconst extrudePath = data.options.extrudePath;\n\n\t\tif (extrudePath !== undefined) {\n\t\t\tdata.options.extrudePath = new Curves[extrudePath.type]().fromJSON(extrudePath);\n\t\t}\n\n\t\treturn new ExtrudeGeometry(geometryShapes, data.options);\n\t}\n\n}\n\nconst WorldUVGenerator = {\n\tgenerateTopUV: function (geometry, vertices, indexA, indexB, indexC) {\n\t\tconst a_x = vertices[indexA * 3];\n\t\tconst a_y = vertices[indexA * 3 + 1];\n\t\tconst b_x = vertices[indexB * 3];\n\t\tconst b_y = vertices[indexB * 3 + 1];\n\t\tconst c_x = vertices[indexC * 3];\n\t\tconst c_y = vertices[indexC * 3 + 1];\n\t\treturn [new Vector2(a_x, a_y), new Vector2(b_x, b_y), new Vector2(c_x, c_y)];\n\t},\n\tgenerateSideWallUV: function (geometry, vertices, indexA, indexB, indexC, indexD) {\n\t\tconst a_x = vertices[indexA * 3];\n\t\tconst a_y = vertices[indexA * 3 + 1];\n\t\tconst a_z = vertices[indexA * 3 + 2];\n\t\tconst b_x = vertices[indexB * 3];\n\t\tconst b_y = vertices[indexB * 3 + 1];\n\t\tconst b_z = vertices[indexB * 3 + 2];\n\t\tconst c_x = vertices[indexC * 3];\n\t\tconst c_y = vertices[indexC * 3 + 1];\n\t\tconst c_z = vertices[indexC * 3 + 2];\n\t\tconst d_x = vertices[indexD * 3];\n\t\tconst d_y = vertices[indexD * 3 + 1];\n\t\tconst d_z = vertices[indexD * 3 + 2];\n\n\t\tif (Math.abs(a_y - b_y) < Math.abs(a_x - b_x)) {\n\t\t\treturn [new Vector2(a_x, 1 - a_z), new Vector2(b_x, 1 - b_z), new Vector2(c_x, 1 - c_z), new Vector2(d_x, 1 - d_z)];\n\t\t} else {\n\t\t\treturn [new Vector2(a_y, 1 - a_z), new Vector2(b_y, 1 - b_z), new Vector2(c_y, 1 - c_z), new Vector2(d_y, 1 - d_z)];\n\t\t}\n\t}\n};\n\nfunction toJSON$1(shapes, options, data) {\n\tdata.shapes = [];\n\n\tif (Array.isArray(shapes)) {\n\t\tfor (let i = 0, l = shapes.length; i < l; i++) {\n\t\t\tconst shape = shapes[i];\n\t\t\tdata.shapes.push(shape.uuid);\n\t\t}\n\t} else {\n\t\tdata.shapes.push(shapes.uuid);\n\t}\n\n\tdata.options = Object.assign({}, options);\n\tif (options.extrudePath !== undefined) data.options.extrudePath = options.extrudePath.toJSON();\n\treturn data;\n}\n\nclass IcosahedronGeometry extends PolyhedronGeometry {\n\tconstructor(radius = 1, detail = 0) {\n\t\tconst t = (1 + Math.sqrt(5)) / 2;\n\t\tconst vertices = [-1, t, 0, 1, t, 0, -1, -t, 0, 1, -t, 0, 0, -1, t, 0, 1, t, 0, -1, -t, 0, 1, -t, t, 0, -1, t, 0, 1, -t, 0, -1, -t, 0, 1];\n\t\tconst indices = [0, 11, 5, 0, 5, 1, 0, 1, 7, 0, 7, 10, 0, 10, 11, 1, 5, 9, 5, 11, 4, 11, 10, 2, 10, 7, 6, 7, 1, 8, 3, 9, 4, 3, 4, 2, 3, 2, 6, 3, 6, 8, 3, 8, 9, 4, 9, 5, 2, 4, 11, 6, 2, 10, 8, 6, 7, 9, 8, 1];\n\t\tsuper(vertices, indices, radius, detail);\n\t\tthis.type = 'IcosahedronGeometry';\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\tdetail: detail\n\t\t};\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new IcosahedronGeometry(data.radius, data.detail);\n\t}\n\n}\n\nclass OctahedronGeometry extends PolyhedronGeometry {\n\tconstructor(radius = 1, detail = 0) {\n\t\tconst vertices = [1, 0, 0, -1, 0, 0, 0, 1, 0, 0, -1, 0, 0, 0, 1, 0, 0, -1];\n\t\tconst indices = [0, 2, 4, 0, 4, 3, 0, 3, 5, 0, 5, 2, 1, 2, 5, 1, 5, 3, 1, 3, 4, 1, 4, 2];\n\t\tsuper(vertices, indices, radius, detail);\n\t\tthis.type = 'OctahedronGeometry';\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\tdetail: detail\n\t\t};\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new OctahedronGeometry(data.radius, data.detail);\n\t}\n\n}\n\nclass RingGeometry extends BufferGeometry {\n\tconstructor(innerRadius = 0.5, outerRadius = 1, thetaSegments = 8, phiSegments = 1, thetaStart = 0, thetaLength = Math.PI * 2) {\n\t\tsuper();\n\t\tthis.type = 'RingGeometry';\n\t\tthis.parameters = {\n\t\t\tinnerRadius: innerRadius,\n\t\t\touterRadius: outerRadius,\n\t\t\tthetaSegments: thetaSegments,\n\t\t\tphiSegments: phiSegments,\n\t\t\tthetaStart: thetaStart,\n\t\t\tthetaLength: thetaLength\n\t\t};\n\t\tthetaSegments = Math.max(3, thetaSegments);\n\t\tphiSegments = Math.max(1, phiSegments); // buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = []; // some helper variables\n\n\t\tlet radius = innerRadius;\n\t\tconst radiusStep = (outerRadius - innerRadius) / phiSegments;\n\t\tconst vertex = new Vector3();\n\t\tconst uv = new Vector2(); // generate vertices, normals and uvs\n\n\t\tfor (let j = 0; j <= phiSegments; j++) {\n\t\t\tfor (let i = 0; i <= thetaSegments; i++) {\n\t\t\t\t// values are generate from the inside of the ring to the outside\n\t\t\t\tconst segment = thetaStart + i / thetaSegments * thetaLength; // vertex\n\n\t\t\t\tvertex.x = radius * Math.cos(segment);\n\t\t\t\tvertex.y = radius * Math.sin(segment);\n\t\t\t\tvertices.push(vertex.x, vertex.y, vertex.z); // normal\n\n\t\t\t\tnormals.push(0, 0, 1); // uv\n\n\t\t\t\tuv.x = (vertex.x / outerRadius + 1) / 2;\n\t\t\t\tuv.y = (vertex.y / outerRadius + 1) / 2;\n\t\t\t\tuvs.push(uv.x, uv.y);\n\t\t\t} // increase the radius for next row of vertices\n\n\n\t\t\tradius += radiusStep;\n\t\t} // indices\n\n\n\t\tfor (let j = 0; j < phiSegments; j++) {\n\t\t\tconst thetaSegmentLevel = j * (thetaSegments + 1);\n\n\t\t\tfor (let i = 0; i < thetaSegments; i++) {\n\t\t\t\tconst segment = i + thetaSegmentLevel;\n\t\t\t\tconst a = segment;\n\t\t\t\tconst b = segment + thetaSegments + 1;\n\t\t\t\tconst c = segment + thetaSegments + 2;\n\t\t\t\tconst d = segment + 1; // faces\n\n\t\t\t\tindices.push(a, b, d);\n\t\t\t\tindices.push(b, c, d);\n\t\t\t}\n\t\t} // build geometry\n\n\n\t\tthis.setIndex(indices);\n\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tthis.setAttribute('normal', new Float32BufferAttribute(normals, 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvs, 2));\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new RingGeometry(data.innerRadius, data.outerRadius, data.thetaSegments, data.phiSegments, data.thetaStart, data.thetaLength);\n\t}\n\n}\n\nclass ShapeGeometry extends BufferGeometry {\n\tconstructor(shapes = new Shape([new Vector2(0, 0.5), new Vector2(-0.5, -0.5), new Vector2(0.5, -0.5)]), curveSegments = 12) {\n\t\tsuper();\n\t\tthis.type = 'ShapeGeometry';\n\t\tthis.parameters = {\n\t\t\tshapes: shapes,\n\t\t\tcurveSegments: curveSegments\n\t\t}; // buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = []; // helper variables\n\n\t\tlet groupStart = 0;\n\t\tlet groupCount = 0; // allow single and array values for \"shapes\" parameter\n\n\t\tif (Array.isArray(shapes) === false) {\n\t\t\taddShape(shapes);\n\t\t} else {\n\t\t\tfor (let i = 0; i < shapes.length; i++) {\n\t\t\t\taddShape(shapes[i]);\n\t\t\t\tthis.addGroup(groupStart, groupCount, i); // enables MultiMaterial support\n\n\t\t\t\tgroupStart += groupCount;\n\t\t\t\tgroupCount = 0;\n\t\t\t}\n\t\t} // build geometry\n\n\n\t\tthis.setIndex(indices);\n\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tthis.setAttribute('normal', new Float32BufferAttribute(normals, 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvs, 2)); // helper functions\n\n\t\tfunction addShape(shape) {\n\t\t\tconst indexOffset = vertices.length / 3;\n\t\t\tconst points = shape.extractPoints(curveSegments);\n\t\t\tlet shapeVertices = points.shape;\n\t\t\tconst shapeHoles = points.holes; // check direction of vertices\n\n\t\t\tif (ShapeUtils.isClockWise(shapeVertices) === false) {\n\t\t\t\tshapeVertices = shapeVertices.reverse();\n\t\t\t}\n\n\t\t\tfor (let i = 0, l = shapeHoles.length; i < l; i++) {\n\t\t\t\tconst shapeHole = shapeHoles[i];\n\n\t\t\t\tif (ShapeUtils.isClockWise(shapeHole) === true) {\n\t\t\t\t\tshapeHoles[i] = shapeHole.reverse();\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst faces = ShapeUtils.triangulateShape(shapeVertices, shapeHoles); // join vertices of inner and outer paths to a single array\n\n\t\t\tfor (let i = 0, l = shapeHoles.length; i < l; i++) {\n\t\t\t\tconst shapeHole = shapeHoles[i];\n\t\t\t\tshapeVertices = shapeVertices.concat(shapeHole);\n\t\t\t} // vertices, normals, uvs\n\n\n\t\t\tfor (let i = 0, l = shapeVertices.length; i < l; i++) {\n\t\t\t\tconst vertex = shapeVertices[i];\n\t\t\t\tvertices.push(vertex.x, vertex.y, 0);\n\t\t\t\tnormals.push(0, 0, 1);\n\t\t\t\tuvs.push(vertex.x, vertex.y); // world uvs\n\t\t\t} // incides\n\n\n\t\t\tfor (let i = 0, l = faces.length; i < l; i++) {\n\t\t\t\tconst face = faces[i];\n\t\t\t\tconst a = face[0] + indexOffset;\n\t\t\t\tconst b = face[1] + indexOffset;\n\t\t\t\tconst c = face[2] + indexOffset;\n\t\t\t\tindices.push(a, b, c);\n\t\t\t\tgroupCount += 3;\n\t\t\t}\n\t\t}\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tconst shapes = this.parameters.shapes;\n\t\treturn toJSON(shapes, data);\n\t}\n\n\tstatic fromJSON(data, shapes) {\n\t\tconst geometryShapes = [];\n\n\t\tfor (let j = 0, jl = data.shapes.length; j < jl; j++) {\n\t\t\tconst shape = shapes[data.shapes[j]];\n\t\t\tgeometryShapes.push(shape);\n\t\t}\n\n\t\treturn new ShapeGeometry(geometryShapes, data.curveSegments);\n\t}\n\n}\n\nfunction toJSON(shapes, data) {\n\tdata.shapes = [];\n\n\tif (Array.isArray(shapes)) {\n\t\tfor (let i = 0, l = shapes.length; i < l; i++) {\n\t\t\tconst shape = shapes[i];\n\t\t\tdata.shapes.push(shape.uuid);\n\t\t}\n\t} else {\n\t\tdata.shapes.push(shapes.uuid);\n\t}\n\n\treturn data;\n}\n\nclass SphereGeometry extends BufferGeometry {\n\tconstructor(radius = 1, widthSegments = 32, heightSegments = 16, phiStart = 0, phiLength = Math.PI * 2, thetaStart = 0, thetaLength = Math.PI) {\n\t\tsuper();\n\t\tthis.type = 'SphereGeometry';\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\twidthSegments: widthSegments,\n\t\t\theightSegments: heightSegments,\n\t\t\tphiStart: phiStart,\n\t\t\tphiLength: phiLength,\n\t\t\tthetaStart: thetaStart,\n\t\t\tthetaLength: thetaLength\n\t\t};\n\t\twidthSegments = Math.max(3, Math.floor(widthSegments));\n\t\theightSegments = Math.max(2, Math.floor(heightSegments));\n\t\tconst thetaEnd = Math.min(thetaStart + thetaLength, Math.PI);\n\t\tlet index = 0;\n\t\tconst grid = [];\n\t\tconst vertex = new Vector3();\n\t\tconst normal = new Vector3(); // buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = []; // generate vertices, normals and uvs\n\n\t\tfor (let iy = 0; iy <= heightSegments; iy++) {\n\t\t\tconst verticesRow = [];\n\t\t\tconst v = iy / heightSegments; // special case for the poles\n\n\t\t\tlet uOffset = 0;\n\n\t\t\tif (iy == 0 && thetaStart == 0) {\n\t\t\t\tuOffset = 0.5 / widthSegments;\n\t\t\t} else if (iy == heightSegments && thetaEnd == Math.PI) {\n\t\t\t\tuOffset = -0.5 / widthSegments;\n\t\t\t}\n\n\t\t\tfor (let ix = 0; ix <= widthSegments; ix++) {\n\t\t\t\tconst u = ix / widthSegments; // vertex\n\n\t\t\t\tvertex.x = -radius * Math.cos(phiStart + u * phiLength) * Math.sin(thetaStart + v * thetaLength);\n\t\t\t\tvertex.y = radius * Math.cos(thetaStart + v * thetaLength);\n\t\t\t\tvertex.z = radius * Math.sin(phiStart + u * phiLength) * Math.sin(thetaStart + v * thetaLength);\n\t\t\t\tvertices.push(vertex.x, vertex.y, vertex.z); // normal\n\n\t\t\t\tnormal.copy(vertex).normalize();\n\t\t\t\tnormals.push(normal.x, normal.y, normal.z); // uv\n\n\t\t\t\tuvs.push(u + uOffset, 1 - v);\n\t\t\t\tverticesRow.push(index++);\n\t\t\t}\n\n\t\t\tgrid.push(verticesRow);\n\t\t} // indices\n\n\n\t\tfor (let iy = 0; iy < heightSegments; iy++) {\n\t\t\tfor (let ix = 0; ix < widthSegments; ix++) {\n\t\t\t\tconst a = grid[iy][ix + 1];\n\t\t\t\tconst b = grid[iy][ix];\n\t\t\t\tconst c = grid[iy + 1][ix];\n\t\t\t\tconst d = grid[iy + 1][ix + 1];\n\t\t\t\tif (iy !== 0 || thetaStart > 0) indices.push(a, b, d);\n\t\t\t\tif (iy !== heightSegments - 1 || thetaEnd < Math.PI) indices.push(b, c, d);\n\t\t\t}\n\t\t} // build geometry\n\n\n\t\tthis.setIndex(indices);\n\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tthis.setAttribute('normal', new Float32BufferAttribute(normals, 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvs, 2));\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new SphereGeometry(data.radius, data.widthSegments, data.heightSegments, data.phiStart, data.phiLength, data.thetaStart, data.thetaLength);\n\t}\n\n}\n\nclass TetrahedronGeometry extends PolyhedronGeometry {\n\tconstructor(radius = 1, detail = 0) {\n\t\tconst vertices = [1, 1, 1, -1, -1, 1, -1, 1, -1, 1, -1, -1];\n\t\tconst indices = [2, 1, 0, 0, 3, 2, 1, 3, 0, 2, 3, 1];\n\t\tsuper(vertices, indices, radius, detail);\n\t\tthis.type = 'TetrahedronGeometry';\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\tdetail: detail\n\t\t};\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new TetrahedronGeometry(data.radius, data.detail);\n\t}\n\n}\n\nclass TorusGeometry extends BufferGeometry {\n\tconstructor(radius = 1, tube = 0.4, radialSegments = 8, tubularSegments = 6, arc = Math.PI * 2) {\n\t\tsuper();\n\t\tthis.type = 'TorusGeometry';\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\ttube: tube,\n\t\t\tradialSegments: radialSegments,\n\t\t\ttubularSegments: tubularSegments,\n\t\t\tarc: arc\n\t\t};\n\t\tradialSegments = Math.floor(radialSegments);\n\t\ttubularSegments = Math.floor(tubularSegments); // buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = []; // helper variables\n\n\t\tconst center = new Vector3();\n\t\tconst vertex = new Vector3();\n\t\tconst normal = new Vector3(); // generate vertices, normals and uvs\n\n\t\tfor (let j = 0; j <= radialSegments; j++) {\n\t\t\tfor (let i = 0; i <= tubularSegments; i++) {\n\t\t\t\tconst u = i / tubularSegments * arc;\n\t\t\t\tconst v = j / radialSegments * Math.PI * 2; // vertex\n\n\t\t\t\tvertex.x = (radius + tube * Math.cos(v)) * Math.cos(u);\n\t\t\t\tvertex.y = (radius + tube * Math.cos(v)) * Math.sin(u);\n\t\t\t\tvertex.z = tube * Math.sin(v);\n\t\t\t\tvertices.push(vertex.x, vertex.y, vertex.z); // normal\n\n\t\t\t\tcenter.x = radius * Math.cos(u);\n\t\t\t\tcenter.y = radius * Math.sin(u);\n\t\t\t\tnormal.subVectors(vertex, center).normalize();\n\t\t\t\tnormals.push(normal.x, normal.y, normal.z); // uv\n\n\t\t\t\tuvs.push(i / tubularSegments);\n\t\t\t\tuvs.push(j / radialSegments);\n\t\t\t}\n\t\t} // generate indices\n\n\n\t\tfor (let j = 1; j <= radialSegments; j++) {\n\t\t\tfor (let i = 1; i <= tubularSegments; i++) {\n\t\t\t\t// indices\n\t\t\t\tconst a = (tubularSegments + 1) * j + i - 1;\n\t\t\t\tconst b = (tubularSegments + 1) * (j - 1) + i - 1;\n\t\t\t\tconst c = (tubularSegments + 1) * (j - 1) + i;\n\t\t\t\tconst d = (tubularSegments + 1) * j + i; // faces\n\n\t\t\t\tindices.push(a, b, d);\n\t\t\t\tindices.push(b, c, d);\n\t\t\t}\n\t\t} // build geometry\n\n\n\t\tthis.setIndex(indices);\n\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tthis.setAttribute('normal', new Float32BufferAttribute(normals, 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvs, 2));\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new TorusGeometry(data.radius, data.tube, data.radialSegments, data.tubularSegments, data.arc);\n\t}\n\n}\n\nclass TorusKnotGeometry extends BufferGeometry {\n\tconstructor(radius = 1, tube = 0.4, tubularSegments = 64, radialSegments = 8, p = 2, q = 3) {\n\t\tsuper();\n\t\tthis.type = 'TorusKnotGeometry';\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\ttube: tube,\n\t\t\ttubularSegments: tubularSegments,\n\t\t\tradialSegments: radialSegments,\n\t\t\tp: p,\n\t\t\tq: q\n\t\t};\n\t\ttubularSegments = Math.floor(tubularSegments);\n\t\tradialSegments = Math.floor(radialSegments); // buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = []; // helper variables\n\n\t\tconst vertex = new Vector3();\n\t\tconst normal = new Vector3();\n\t\tconst P1 = new Vector3();\n\t\tconst P2 = new Vector3();\n\t\tconst B = new Vector3();\n\t\tconst T = new Vector3();\n\t\tconst N = new Vector3(); // generate vertices, normals and uvs\n\n\t\tfor (let i = 0; i <= tubularSegments; ++i) {\n\t\t\t// the radian \"u\" is used to calculate the position on the torus curve of the current tubular segment\n\t\t\tconst u = i / tubularSegments * p * Math.PI * 2; // now we calculate two points. P1 is our current position on the curve, P2 is a little farther ahead.\n\t\t\t// these points are used to create a special \"coordinate space\", which is necessary to calculate the correct vertex positions\n\n\t\t\tcalculatePositionOnCurve(u, p, q, radius, P1);\n\t\t\tcalculatePositionOnCurve(u + 0.01, p, q, radius, P2); // calculate orthonormal basis\n\n\t\t\tT.subVectors(P2, P1);\n\t\t\tN.addVectors(P2, P1);\n\t\t\tB.crossVectors(T, N);\n\t\t\tN.crossVectors(B, T); // normalize B, N. T can be ignored, we don't use it\n\n\t\t\tB.normalize();\n\t\t\tN.normalize();\n\n\t\t\tfor (let j = 0; j <= radialSegments; ++j) {\n\t\t\t\t// now calculate the vertices. they are nothing more than an extrusion of the torus curve.\n\t\t\t\t// because we extrude a shape in the xy-plane, there is no need to calculate a z-value.\n\t\t\t\tconst v = j / radialSegments * Math.PI * 2;\n\t\t\t\tconst cx = -tube * Math.cos(v);\n\t\t\t\tconst cy = tube * Math.sin(v); // now calculate the final vertex position.\n\t\t\t\t// first we orient the extrusion with our basis vectors, then we add it to the current position on the curve\n\n\t\t\t\tvertex.x = P1.x + (cx * N.x + cy * B.x);\n\t\t\t\tvertex.y = P1.y + (cx * N.y + cy * B.y);\n\t\t\t\tvertex.z = P1.z + (cx * N.z + cy * B.z);\n\t\t\t\tvertices.push(vertex.x, vertex.y, vertex.z); // normal (P1 is always the center/origin of the extrusion, thus we can use it to calculate the normal)\n\n\t\t\t\tnormal.subVectors(vertex, P1).normalize();\n\t\t\t\tnormals.push(normal.x, normal.y, normal.z); // uv\n\n\t\t\t\tuvs.push(i / tubularSegments);\n\t\t\t\tuvs.push(j / radialSegments);\n\t\t\t}\n\t\t} // generate indices\n\n\n\t\tfor (let j = 1; j <= tubularSegments; j++) {\n\t\t\tfor (let i = 1; i <= radialSegments; i++) {\n\t\t\t\t// indices\n\t\t\t\tconst a = (radialSegments + 1) * (j - 1) + (i - 1);\n\t\t\t\tconst b = (radialSegments + 1) * j + (i - 1);\n\t\t\t\tconst c = (radialSegments + 1) * j + i;\n\t\t\t\tconst d = (radialSegments + 1) * (j - 1) + i; // faces\n\n\t\t\t\tindices.push(a, b, d);\n\t\t\t\tindices.push(b, c, d);\n\t\t\t}\n\t\t} // build geometry\n\n\n\t\tthis.setIndex(indices);\n\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tthis.setAttribute('normal', new Float32BufferAttribute(normals, 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvs, 2)); // this function calculates the current position on the torus curve\n\n\t\tfunction calculatePositionOnCurve(u, p, q, radius, position) {\n\t\t\tconst cu = Math.cos(u);\n\t\t\tconst su = Math.sin(u);\n\t\t\tconst quOverP = q / p * u;\n\t\t\tconst cs = Math.cos(quOverP);\n\t\t\tposition.x = radius * (2 + cs) * 0.5 * cu;\n\t\t\tposition.y = radius * (2 + cs) * su * 0.5;\n\t\t\tposition.z = radius * Math.sin(quOverP) * 0.5;\n\t\t}\n\t}\n\n\tstatic fromJSON(data) {\n\t\treturn new TorusKnotGeometry(data.radius, data.tube, data.tubularSegments, data.radialSegments, data.p, data.q);\n\t}\n\n}\n\nclass TubeGeometry extends BufferGeometry {\n\tconstructor(path = new QuadraticBezierCurve3(new Vector3(-1, -1, 0), new Vector3(-1, 1, 0), new Vector3(1, 1, 0)), tubularSegments = 64, radius = 1, radialSegments = 8, closed = false) {\n\t\tsuper();\n\t\tthis.type = 'TubeGeometry';\n\t\tthis.parameters = {\n\t\t\tpath: path,\n\t\t\ttubularSegments: tubularSegments,\n\t\t\tradius: radius,\n\t\t\tradialSegments: radialSegments,\n\t\t\tclosed: closed\n\t\t};\n\t\tconst frames = path.computeFrenetFrames(tubularSegments, closed); // expose internals\n\n\t\tthis.tangents = frames.tangents;\n\t\tthis.normals = frames.normals;\n\t\tthis.binormals = frames.binormals; // helper variables\n\n\t\tconst vertex = new Vector3();\n\t\tconst normal = new Vector3();\n\t\tconst uv = new Vector2();\n\t\tlet P = new Vector3(); // buffer\n\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\t\tconst indices = []; // create buffer data\n\n\t\tgenerateBufferData(); // build geometry\n\n\t\tthis.setIndex(indices);\n\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tthis.setAttribute('normal', new Float32BufferAttribute(normals, 3));\n\t\tthis.setAttribute('uv', new Float32BufferAttribute(uvs, 2)); // functions\n\n\t\tfunction generateBufferData() {\n\t\t\tfor (let i = 0; i < tubularSegments; i++) {\n\t\t\t\tgenerateSegment(i);\n\t\t\t} // if the geometry is not closed, generate the last row of vertices and normals\n\t\t\t// at the regular position on the given path\n\t\t\t//\n\t\t\t// if the geometry is closed, duplicate the first row of vertices and normals (uvs will differ)\n\n\n\t\t\tgenerateSegment(closed === false ? tubularSegments : 0); // uvs are generated in a separate function.\n\t\t\t// this makes it easy compute correct values for closed geometries\n\n\t\t\tgenerateUVs(); // finally create faces\n\n\t\t\tgenerateIndices();\n\t\t}\n\n\t\tfunction generateSegment(i) {\n\t\t\t// we use getPointAt to sample evenly distributed points from the given path\n\t\t\tP = path.getPointAt(i / tubularSegments, P); // retrieve corresponding normal and binormal\n\n\t\t\tconst N = frames.normals[i];\n\t\t\tconst B = frames.binormals[i]; // generate normals and vertices for the current segment\n\n\t\t\tfor (let j = 0; j <= radialSegments; j++) {\n\t\t\t\tconst v = j / radialSegments * Math.PI * 2;\n\t\t\t\tconst sin = Math.sin(v);\n\t\t\t\tconst cos = -Math.cos(v); // normal\n\n\t\t\t\tnormal.x = cos * N.x + sin * B.x;\n\t\t\t\tnormal.y = cos * N.y + sin * B.y;\n\t\t\t\tnormal.z = cos * N.z + sin * B.z;\n\t\t\t\tnormal.normalize();\n\t\t\t\tnormals.push(normal.x, normal.y, normal.z); // vertex\n\n\t\t\t\tvertex.x = P.x + radius * normal.x;\n\t\t\t\tvertex.y = P.y + radius * normal.y;\n\t\t\t\tvertex.z = P.z + radius * normal.z;\n\t\t\t\tvertices.push(vertex.x, vertex.y, vertex.z);\n\t\t\t}\n\t\t}\n\n\t\tfunction generateIndices() {\n\t\t\tfor (let j = 1; j <= tubularSegments; j++) {\n\t\t\t\tfor (let i = 1; i <= radialSegments; i++) {\n\t\t\t\t\tconst a = (radialSegments + 1) * (j - 1) + (i - 1);\n\t\t\t\t\tconst b = (radialSegments + 1) * j + (i - 1);\n\t\t\t\t\tconst c = (radialSegments + 1) * j + i;\n\t\t\t\t\tconst d = (radialSegments + 1) * (j - 1) + i; // faces\n\n\t\t\t\t\tindices.push(a, b, d);\n\t\t\t\t\tindices.push(b, c, d);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tfunction generateUVs() {\n\t\t\tfor (let i = 0; i <= tubularSegments; i++) {\n\t\t\t\tfor (let j = 0; j <= radialSegments; j++) {\n\t\t\t\t\tuv.x = i / tubularSegments;\n\t\t\t\t\tuv.y = j / radialSegments;\n\t\t\t\t\tuvs.push(uv.x, uv.y);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON();\n\t\tdata.path = this.parameters.path.toJSON();\n\t\treturn data;\n\t}\n\n\tstatic fromJSON(data) {\n\t\t// This only works for built-in curves (e.g. CatmullRomCurve3).\n\t\t// User defined curves or instances of CurvePath will not be deserialized.\n\t\treturn new TubeGeometry(new Curves[data.path.type]().fromJSON(data.path), data.tubularSegments, data.radius, data.radialSegments, data.closed);\n\t}\n\n}\n\nclass WireframeGeometry extends BufferGeometry {\n\tconstructor(geometry = null) {\n\t\tsuper();\n\t\tthis.type = 'WireframeGeometry';\n\t\tthis.parameters = {\n\t\t\tgeometry: geometry\n\t\t};\n\n\t\tif (geometry !== null) {\n\t\t\t// buffer\n\t\t\tconst vertices = [];\n\t\t\tconst edges = new Set(); // helper variables\n\n\t\t\tconst start = new Vector3();\n\t\t\tconst end = new Vector3();\n\n\t\t\tif (geometry.index !== null) {\n\t\t\t\t// indexed BufferGeometry\n\t\t\t\tconst position = geometry.attributes.position;\n\t\t\t\tconst indices = geometry.index;\n\t\t\t\tlet groups = geometry.groups;\n\n\t\t\t\tif (groups.length === 0) {\n\t\t\t\t\tgroups = [{\n\t\t\t\t\t\tstart: 0,\n\t\t\t\t\t\tcount: indices.count,\n\t\t\t\t\t\tmaterialIndex: 0\n\t\t\t\t\t}];\n\t\t\t\t} // create a data structure that contains all edges without duplicates\n\n\n\t\t\t\tfor (let o = 0, ol = groups.length; o < ol; ++o) {\n\t\t\t\t\tconst group = groups[o];\n\t\t\t\t\tconst groupStart = group.start;\n\t\t\t\t\tconst groupCount = group.count;\n\n\t\t\t\t\tfor (let i = groupStart, l = groupStart + groupCount; i < l; i += 3) {\n\t\t\t\t\t\tfor (let j = 0; j < 3; j++) {\n\t\t\t\t\t\t\tconst index1 = indices.getX(i + j);\n\t\t\t\t\t\t\tconst index2 = indices.getX(i + (j + 1) % 3);\n\t\t\t\t\t\t\tstart.fromBufferAttribute(position, index1);\n\t\t\t\t\t\t\tend.fromBufferAttribute(position, index2);\n\n\t\t\t\t\t\t\tif (isUniqueEdge(start, end, edges) === true) {\n\t\t\t\t\t\t\t\tvertices.push(start.x, start.y, start.z);\n\t\t\t\t\t\t\t\tvertices.push(end.x, end.y, end.z);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// non-indexed BufferGeometry\n\t\t\t\tconst position = geometry.attributes.position;\n\n\t\t\t\tfor (let i = 0, l = position.count / 3; i < l; i++) {\n\t\t\t\t\tfor (let j = 0; j < 3; j++) {\n\t\t\t\t\t\t// three edges per triangle, an edge is represented as (index1, index2)\n\t\t\t\t\t\t// e.g. the first triangle has the following edges: (0,1),(1,2),(2,0)\n\t\t\t\t\t\tconst index1 = 3 * i + j;\n\t\t\t\t\t\tconst index2 = 3 * i + (j + 1) % 3;\n\t\t\t\t\t\tstart.fromBufferAttribute(position, index1);\n\t\t\t\t\t\tend.fromBufferAttribute(position, index2);\n\n\t\t\t\t\t\tif (isUniqueEdge(start, end, edges) === true) {\n\t\t\t\t\t\t\tvertices.push(start.x, start.y, start.z);\n\t\t\t\t\t\t\tvertices.push(end.x, end.y, end.z);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} // build geometry\n\n\n\t\t\tthis.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\t}\n\t}\n\n}\n\nfunction isUniqueEdge(start, end, edges) {\n\tconst hash1 = `${start.x},${start.y},${start.z}-${end.x},${end.y},${end.z}`;\n\tconst hash2 = `${end.x},${end.y},${end.z}-${start.x},${start.y},${start.z}`; // coincident edge\n\n\tif (edges.has(hash1) === true || edges.has(hash2) === true) {\n\t\treturn false;\n\t} else {\n\t\tedges.add(hash1);\n\t\tedges.add(hash2);\n\t\treturn true;\n\t}\n}\n\nvar Geometries = /*#__PURE__*/Object.freeze({\n\t__proto__: null,\n\tBoxGeometry: BoxGeometry,\n\tBoxBufferGeometry: BoxGeometry,\n\tCapsuleGeometry: CapsuleGeometry,\n\tCapsuleBufferGeometry: CapsuleGeometry,\n\tCircleGeometry: CircleGeometry,\n\tCircleBufferGeometry: CircleGeometry,\n\tConeGeometry: ConeGeometry,\n\tConeBufferGeometry: ConeGeometry,\n\tCylinderGeometry: CylinderGeometry,\n\tCylinderBufferGeometry: CylinderGeometry,\n\tDodecahedronGeometry: DodecahedronGeometry,\n\tDodecahedronBufferGeometry: DodecahedronGeometry,\n\tEdgesGeometry: EdgesGeometry,\n\tExtrudeGeometry: ExtrudeGeometry,\n\tExtrudeBufferGeometry: ExtrudeGeometry,\n\tIcosahedronGeometry: IcosahedronGeometry,\n\tIcosahedronBufferGeometry: IcosahedronGeometry,\n\tLatheGeometry: LatheGeometry,\n\tLatheBufferGeometry: LatheGeometry,\n\tOctahedronGeometry: OctahedronGeometry,\n\tOctahedronBufferGeometry: OctahedronGeometry,\n\tPlaneGeometry: PlaneGeometry,\n\tPlaneBufferGeometry: PlaneGeometry,\n\tPolyhedronGeometry: PolyhedronGeometry,\n\tPolyhedronBufferGeometry: PolyhedronGeometry,\n\tRingGeometry: RingGeometry,\n\tRingBufferGeometry: RingGeometry,\n\tShapeGeometry: ShapeGeometry,\n\tShapeBufferGeometry: ShapeGeometry,\n\tSphereGeometry: SphereGeometry,\n\tSphereBufferGeometry: SphereGeometry,\n\tTetrahedronGeometry: TetrahedronGeometry,\n\tTetrahedronBufferGeometry: TetrahedronGeometry,\n\tTorusGeometry: TorusGeometry,\n\tTorusBufferGeometry: TorusGeometry,\n\tTorusKnotGeometry: TorusKnotGeometry,\n\tTorusKnotBufferGeometry: TorusKnotGeometry,\n\tTubeGeometry: TubeGeometry,\n\tTubeBufferGeometry: TubeGeometry,\n\tWireframeGeometry: WireframeGeometry\n});\n\nclass ShadowMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isShadowMaterial = true;\n\t\tthis.type = 'ShadowMaterial';\n\t\tthis.color = new Color(0x000000);\n\t\tthis.transparent = true;\n\t\tthis.fog = true;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.color.copy(source.color);\n\t\tthis.fog = source.fog;\n\t\treturn this;\n\t}\n\n}\n\nclass RawShaderMaterial extends ShaderMaterial {\n\tconstructor(parameters) {\n\t\tsuper(parameters);\n\t\tthis.isRawShaderMaterial = true;\n\t\tthis.type = 'RawShaderMaterial';\n\t}\n\n}\n\nclass MeshStandardMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isMeshStandardMaterial = true;\n\t\tthis.defines = {\n\t\t\t'STANDARD': ''\n\t\t};\n\t\tthis.type = 'MeshStandardMaterial';\n\t\tthis.color = new Color(0xffffff); // diffuse\n\n\t\tthis.roughness = 1.0;\n\t\tthis.metalness = 0.0;\n\t\tthis.map = null;\n\t\tthis.lightMap = null;\n\t\tthis.lightMapIntensity = 1.0;\n\t\tthis.aoMap = null;\n\t\tthis.aoMapIntensity = 1.0;\n\t\tthis.emissive = new Color(0x000000);\n\t\tthis.emissiveIntensity = 1.0;\n\t\tthis.emissiveMap = null;\n\t\tthis.bumpMap = null;\n\t\tthis.bumpScale = 1;\n\t\tthis.normalMap = null;\n\t\tthis.normalMapType = TangentSpaceNormalMap;\n\t\tthis.normalScale = new Vector2(1, 1);\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\t\tthis.roughnessMap = null;\n\t\tthis.metalnessMap = null;\n\t\tthis.alphaMap = null;\n\t\tthis.envMap = null;\n\t\tthis.envMapIntensity = 1.0;\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.wireframeLinecap = 'round';\n\t\tthis.wireframeLinejoin = 'round';\n\t\tthis.flatShading = false;\n\t\tthis.fog = true;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.defines = {\n\t\t\t'STANDARD': ''\n\t\t};\n\t\tthis.color.copy(source.color);\n\t\tthis.roughness = source.roughness;\n\t\tthis.metalness = source.metalness;\n\t\tthis.map = source.map;\n\t\tthis.lightMap = source.lightMap;\n\t\tthis.lightMapIntensity = source.lightMapIntensity;\n\t\tthis.aoMap = source.aoMap;\n\t\tthis.aoMapIntensity = source.aoMapIntensity;\n\t\tthis.emissive.copy(source.emissive);\n\t\tthis.emissiveMap = source.emissiveMap;\n\t\tthis.emissiveIntensity = source.emissiveIntensity;\n\t\tthis.bumpMap = source.bumpMap;\n\t\tthis.bumpScale = source.bumpScale;\n\t\tthis.normalMap = source.normalMap;\n\t\tthis.normalMapType = source.normalMapType;\n\t\tthis.normalScale.copy(source.normalScale);\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\t\tthis.roughnessMap = source.roughnessMap;\n\t\tthis.metalnessMap = source.metalnessMap;\n\t\tthis.alphaMap = source.alphaMap;\n\t\tthis.envMap = source.envMap;\n\t\tthis.envMapIntensity = source.envMapIntensity;\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\tthis.wireframeLinecap = source.wireframeLinecap;\n\t\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\t\tthis.flatShading = source.flatShading;\n\t\tthis.fog = source.fog;\n\t\treturn this;\n\t}\n\n}\n\nclass MeshPhysicalMaterial extends MeshStandardMaterial {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isMeshPhysicalMaterial = true;\n\t\tthis.defines = {\n\t\t\t'STANDARD': '',\n\t\t\t'PHYSICAL': ''\n\t\t};\n\t\tthis.type = 'MeshPhysicalMaterial';\n\t\tthis.clearcoatMap = null;\n\t\tthis.clearcoatRoughness = 0.0;\n\t\tthis.clearcoatRoughnessMap = null;\n\t\tthis.clearcoatNormalScale = new Vector2(1, 1);\n\t\tthis.clearcoatNormalMap = null;\n\t\tthis.ior = 1.5;\n\t\tObject.defineProperty(this, 'reflectivity', {\n\t\t\tget: function () {\n\t\t\t\treturn clamp(2.5 * (this.ior - 1) / (this.ior + 1), 0, 1);\n\t\t\t},\n\t\t\tset: function (reflectivity) {\n\t\t\t\tthis.ior = (1 + 0.4 * reflectivity) / (1 - 0.4 * reflectivity);\n\t\t\t}\n\t\t});\n\t\tthis.iridescenceMap = null;\n\t\tthis.iridescenceIOR = 1.3;\n\t\tthis.iridescenceThicknessRange = [100, 400];\n\t\tthis.iridescenceThicknessMap = null;\n\t\tthis.sheenColor = new Color(0x000000);\n\t\tthis.sheenColorMap = null;\n\t\tthis.sheenRoughness = 1.0;\n\t\tthis.sheenRoughnessMap = null;\n\t\tthis.transmissionMap = null;\n\t\tthis.thickness = 0;\n\t\tthis.thicknessMap = null;\n\t\tthis.attenuationDistance = 0.0;\n\t\tthis.attenuationColor = new Color(1, 1, 1);\n\t\tthis.specularIntensity = 1.0;\n\t\tthis.specularIntensityMap = null;\n\t\tthis.specularColor = new Color(1, 1, 1);\n\t\tthis.specularColorMap = null;\n\t\tthis._sheen = 0.0;\n\t\tthis._clearcoat = 0;\n\t\tthis._iridescence = 0;\n\t\tthis._transmission = 0;\n\t\tthis.setValues(parameters);\n\t}\n\n\tget sheen() {\n\t\treturn this._sheen;\n\t}\n\n\tset sheen(value) {\n\t\tif (this._sheen > 0 !== value > 0) {\n\t\t\tthis.version++;\n\t\t}\n\n\t\tthis._sheen = value;\n\t}\n\n\tget clearcoat() {\n\t\treturn this._clearcoat;\n\t}\n\n\tset clearcoat(value) {\n\t\tif (this._clearcoat > 0 !== value > 0) {\n\t\t\tthis.version++;\n\t\t}\n\n\t\tthis._clearcoat = value;\n\t}\n\n\tget iridescence() {\n\t\treturn this._iridescence;\n\t}\n\n\tset iridescence(value) {\n\t\tif (this._iridescence > 0 !== value > 0) {\n\t\t\tthis.version++;\n\t\t}\n\n\t\tthis._iridescence = value;\n\t}\n\n\tget transmission() {\n\t\treturn this._transmission;\n\t}\n\n\tset transmission(value) {\n\t\tif (this._transmission > 0 !== value > 0) {\n\t\t\tthis.version++;\n\t\t}\n\n\t\tthis._transmission = value;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.defines = {\n\t\t\t'STANDARD': '',\n\t\t\t'PHYSICAL': ''\n\t\t};\n\t\tthis.clearcoat = source.clearcoat;\n\t\tthis.clearcoatMap = source.clearcoatMap;\n\t\tthis.clearcoatRoughness = source.clearcoatRoughness;\n\t\tthis.clearcoatRoughnessMap = source.clearcoatRoughnessMap;\n\t\tthis.clearcoatNormalMap = source.clearcoatNormalMap;\n\t\tthis.clearcoatNormalScale.copy(source.clearcoatNormalScale);\n\t\tthis.ior = source.ior;\n\t\tthis.iridescence = source.iridescence;\n\t\tthis.iridescenceMap = source.iridescenceMap;\n\t\tthis.iridescenceIOR = source.iridescenceIOR;\n\t\tthis.iridescenceThicknessRange = [...source.iridescenceThicknessRange];\n\t\tthis.iridescenceThicknessMap = source.iridescenceThicknessMap;\n\t\tthis.sheen = source.sheen;\n\t\tthis.sheenColor.copy(source.sheenColor);\n\t\tthis.sheenColorMap = source.sheenColorMap;\n\t\tthis.sheenRoughness = source.sheenRoughness;\n\t\tthis.sheenRoughnessMap = source.sheenRoughnessMap;\n\t\tthis.transmission = source.transmission;\n\t\tthis.transmissionMap = source.transmissionMap;\n\t\tthis.thickness = source.thickness;\n\t\tthis.thicknessMap = source.thicknessMap;\n\t\tthis.attenuationDistance = source.attenuationDistance;\n\t\tthis.attenuationColor.copy(source.attenuationColor);\n\t\tthis.specularIntensity = source.specularIntensity;\n\t\tthis.specularIntensityMap = source.specularIntensityMap;\n\t\tthis.specularColor.copy(source.specularColor);\n\t\tthis.specularColorMap = source.specularColorMap;\n\t\treturn this;\n\t}\n\n}\n\nclass MeshPhongMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isMeshPhongMaterial = true;\n\t\tthis.type = 'MeshPhongMaterial';\n\t\tthis.color = new Color(0xffffff); // diffuse\n\n\t\tthis.specular = new Color(0x111111);\n\t\tthis.shininess = 30;\n\t\tthis.map = null;\n\t\tthis.lightMap = null;\n\t\tthis.lightMapIntensity = 1.0;\n\t\tthis.aoMap = null;\n\t\tthis.aoMapIntensity = 1.0;\n\t\tthis.emissive = new Color(0x000000);\n\t\tthis.emissiveIntensity = 1.0;\n\t\tthis.emissiveMap = null;\n\t\tthis.bumpMap = null;\n\t\tthis.bumpScale = 1;\n\t\tthis.normalMap = null;\n\t\tthis.normalMapType = TangentSpaceNormalMap;\n\t\tthis.normalScale = new Vector2(1, 1);\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\t\tthis.specularMap = null;\n\t\tthis.alphaMap = null;\n\t\tthis.envMap = null;\n\t\tthis.combine = MultiplyOperation;\n\t\tthis.reflectivity = 1;\n\t\tthis.refractionRatio = 0.98;\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.wireframeLinecap = 'round';\n\t\tthis.wireframeLinejoin = 'round';\n\t\tthis.flatShading = false;\n\t\tthis.fog = true;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.color.copy(source.color);\n\t\tthis.specular.copy(source.specular);\n\t\tthis.shininess = source.shininess;\n\t\tthis.map = source.map;\n\t\tthis.lightMap = source.lightMap;\n\t\tthis.lightMapIntensity = source.lightMapIntensity;\n\t\tthis.aoMap = source.aoMap;\n\t\tthis.aoMapIntensity = source.aoMapIntensity;\n\t\tthis.emissive.copy(source.emissive);\n\t\tthis.emissiveMap = source.emissiveMap;\n\t\tthis.emissiveIntensity = source.emissiveIntensity;\n\t\tthis.bumpMap = source.bumpMap;\n\t\tthis.bumpScale = source.bumpScale;\n\t\tthis.normalMap = source.normalMap;\n\t\tthis.normalMapType = source.normalMapType;\n\t\tthis.normalScale.copy(source.normalScale);\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\t\tthis.specularMap = source.specularMap;\n\t\tthis.alphaMap = source.alphaMap;\n\t\tthis.envMap = source.envMap;\n\t\tthis.combine = source.combine;\n\t\tthis.reflectivity = source.reflectivity;\n\t\tthis.refractionRatio = source.refractionRatio;\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\tthis.wireframeLinecap = source.wireframeLinecap;\n\t\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\t\tthis.flatShading = source.flatShading;\n\t\tthis.fog = source.fog;\n\t\treturn this;\n\t}\n\n}\n\nclass MeshToonMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isMeshToonMaterial = true;\n\t\tthis.defines = {\n\t\t\t'TOON': ''\n\t\t};\n\t\tthis.type = 'MeshToonMaterial';\n\t\tthis.color = new Color(0xffffff);\n\t\tthis.map = null;\n\t\tthis.gradientMap = null;\n\t\tthis.lightMap = null;\n\t\tthis.lightMapIntensity = 1.0;\n\t\tthis.aoMap = null;\n\t\tthis.aoMapIntensity = 1.0;\n\t\tthis.emissive = new Color(0x000000);\n\t\tthis.emissiveIntensity = 1.0;\n\t\tthis.emissiveMap = null;\n\t\tthis.bumpMap = null;\n\t\tthis.bumpScale = 1;\n\t\tthis.normalMap = null;\n\t\tthis.normalMapType = TangentSpaceNormalMap;\n\t\tthis.normalScale = new Vector2(1, 1);\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\t\tthis.alphaMap = null;\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.wireframeLinecap = 'round';\n\t\tthis.wireframeLinejoin = 'round';\n\t\tthis.fog = true;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.color.copy(source.color);\n\t\tthis.map = source.map;\n\t\tthis.gradientMap = source.gradientMap;\n\t\tthis.lightMap = source.lightMap;\n\t\tthis.lightMapIntensity = source.lightMapIntensity;\n\t\tthis.aoMap = source.aoMap;\n\t\tthis.aoMapIntensity = source.aoMapIntensity;\n\t\tthis.emissive.copy(source.emissive);\n\t\tthis.emissiveMap = source.emissiveMap;\n\t\tthis.emissiveIntensity = source.emissiveIntensity;\n\t\tthis.bumpMap = source.bumpMap;\n\t\tthis.bumpScale = source.bumpScale;\n\t\tthis.normalMap = source.normalMap;\n\t\tthis.normalMapType = source.normalMapType;\n\t\tthis.normalScale.copy(source.normalScale);\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\t\tthis.alphaMap = source.alphaMap;\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\tthis.wireframeLinecap = source.wireframeLinecap;\n\t\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\t\tthis.fog = source.fog;\n\t\treturn this;\n\t}\n\n}\n\nclass MeshNormalMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isMeshNormalMaterial = true;\n\t\tthis.type = 'MeshNormalMaterial';\n\t\tthis.bumpMap = null;\n\t\tthis.bumpScale = 1;\n\t\tthis.normalMap = null;\n\t\tthis.normalMapType = TangentSpaceNormalMap;\n\t\tthis.normalScale = new Vector2(1, 1);\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.flatShading = false;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.bumpMap = source.bumpMap;\n\t\tthis.bumpScale = source.bumpScale;\n\t\tthis.normalMap = source.normalMap;\n\t\tthis.normalMapType = source.normalMapType;\n\t\tthis.normalScale.copy(source.normalScale);\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\tthis.flatShading = source.flatShading;\n\t\treturn this;\n\t}\n\n}\n\nclass MeshLambertMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isMeshLambertMaterial = true;\n\t\tthis.type = 'MeshLambertMaterial';\n\t\tthis.color = new Color(0xffffff); // diffuse\n\n\t\tthis.map = null;\n\t\tthis.lightMap = null;\n\t\tthis.lightMapIntensity = 1.0;\n\t\tthis.aoMap = null;\n\t\tthis.aoMapIntensity = 1.0;\n\t\tthis.emissive = new Color(0x000000);\n\t\tthis.emissiveIntensity = 1.0;\n\t\tthis.emissiveMap = null;\n\t\tthis.specularMap = null;\n\t\tthis.alphaMap = null;\n\t\tthis.envMap = null;\n\t\tthis.combine = MultiplyOperation;\n\t\tthis.reflectivity = 1;\n\t\tthis.refractionRatio = 0.98;\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.wireframeLinecap = 'round';\n\t\tthis.wireframeLinejoin = 'round';\n\t\tthis.fog = true;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.color.copy(source.color);\n\t\tthis.map = source.map;\n\t\tthis.lightMap = source.lightMap;\n\t\tthis.lightMapIntensity = source.lightMapIntensity;\n\t\tthis.aoMap = source.aoMap;\n\t\tthis.aoMapIntensity = source.aoMapIntensity;\n\t\tthis.emissive.copy(source.emissive);\n\t\tthis.emissiveMap = source.emissiveMap;\n\t\tthis.emissiveIntensity = source.emissiveIntensity;\n\t\tthis.specularMap = source.specularMap;\n\t\tthis.alphaMap = source.alphaMap;\n\t\tthis.envMap = source.envMap;\n\t\tthis.combine = source.combine;\n\t\tthis.reflectivity = source.reflectivity;\n\t\tthis.refractionRatio = source.refractionRatio;\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\tthis.wireframeLinecap = source.wireframeLinecap;\n\t\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\t\tthis.fog = source.fog;\n\t\treturn this;\n\t}\n\n}\n\nclass MeshMatcapMaterial extends Material {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isMeshMatcapMaterial = true;\n\t\tthis.defines = {\n\t\t\t'MATCAP': ''\n\t\t};\n\t\tthis.type = 'MeshMatcapMaterial';\n\t\tthis.color = new Color(0xffffff); // diffuse\n\n\t\tthis.matcap = null;\n\t\tthis.map = null;\n\t\tthis.bumpMap = null;\n\t\tthis.bumpScale = 1;\n\t\tthis.normalMap = null;\n\t\tthis.normalMapType = TangentSpaceNormalMap;\n\t\tthis.normalScale = new Vector2(1, 1);\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\t\tthis.alphaMap = null;\n\t\tthis.flatShading = false;\n\t\tthis.fog = true;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.defines = {\n\t\t\t'MATCAP': ''\n\t\t};\n\t\tthis.color.copy(source.color);\n\t\tthis.matcap = source.matcap;\n\t\tthis.map = source.map;\n\t\tthis.bumpMap = source.bumpMap;\n\t\tthis.bumpScale = source.bumpScale;\n\t\tthis.normalMap = source.normalMap;\n\t\tthis.normalMapType = source.normalMapType;\n\t\tthis.normalScale.copy(source.normalScale);\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\t\tthis.alphaMap = source.alphaMap;\n\t\tthis.flatShading = source.flatShading;\n\t\tthis.fog = source.fog;\n\t\treturn this;\n\t}\n\n}\n\nclass LineDashedMaterial extends LineBasicMaterial {\n\tconstructor(parameters) {\n\t\tsuper();\n\t\tthis.isLineDashedMaterial = true;\n\t\tthis.type = 'LineDashedMaterial';\n\t\tthis.scale = 1;\n\t\tthis.dashSize = 3;\n\t\tthis.gapSize = 1;\n\t\tthis.setValues(parameters);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.scale = source.scale;\n\t\tthis.dashSize = source.dashSize;\n\t\tthis.gapSize = source.gapSize;\n\t\treturn this;\n\t}\n\n}\n\nconst materialLib = {\n\tShadowMaterial,\n\tSpriteMaterial,\n\tRawShaderMaterial,\n\tShaderMaterial,\n\tPointsMaterial,\n\tMeshPhysicalMaterial,\n\tMeshStandardMaterial,\n\tMeshPhongMaterial,\n\tMeshToonMaterial,\n\tMeshNormalMaterial,\n\tMeshLambertMaterial,\n\tMeshDepthMaterial,\n\tMeshDistanceMaterial,\n\tMeshBasicMaterial,\n\tMeshMatcapMaterial,\n\tLineDashedMaterial,\n\tLineBasicMaterial,\n\tMaterial\n};\n\nMaterial.fromType = function (type) {\n\treturn new materialLib[type]();\n};\n\nconst AnimationUtils = {\n\t// same as Array.prototype.slice, but also works on typed arrays\n\tarraySlice: function (array, from, to) {\n\t\tif (AnimationUtils.isTypedArray(array)) {\n\t\t\t// in ios9 array.subarray(from, undefined) will return empty array\n\t\t\t// but array.subarray(from) or array.subarray(from, len) is correct\n\t\t\treturn new array.constructor(array.subarray(from, to !== undefined ? to : array.length));\n\t\t}\n\n\t\treturn array.slice(from, to);\n\t},\n\t// converts an array to a specific type\n\tconvertArray: function (array, type, forceClone) {\n\t\tif (!array || // let 'undefined' and 'null' pass\n\t\t!forceClone && array.constructor === type) return array;\n\n\t\tif (typeof type.BYTES_PER_ELEMENT === 'number') {\n\t\t\treturn new type(array); // create typed array\n\t\t}\n\n\t\treturn Array.prototype.slice.call(array); // create Array\n\t},\n\tisTypedArray: function (object) {\n\t\treturn ArrayBuffer.isView(object) && !(object instanceof DataView);\n\t},\n\t// returns an array by which times and values can be sorted\n\tgetKeyframeOrder: function (times) {\n\t\tfunction compareTime(i, j) {\n\t\t\treturn times[i] - times[j];\n\t\t}\n\n\t\tconst n = times.length;\n\t\tconst result = new Array(n);\n\n\t\tfor (let i = 0; i !== n; ++i) result[i] = i;\n\n\t\tresult.sort(compareTime);\n\t\treturn result;\n\t},\n\t// uses the array previously returned by 'getKeyframeOrder' to sort data\n\tsortedArray: function (values, stride, order) {\n\t\tconst nValues = values.length;\n\t\tconst result = new values.constructor(nValues);\n\n\t\tfor (let i = 0, dstOffset = 0; dstOffset !== nValues; ++i) {\n\t\t\tconst srcOffset = order[i] * stride;\n\n\t\t\tfor (let j = 0; j !== stride; ++j) {\n\t\t\t\tresult[dstOffset++] = values[srcOffset + j];\n\t\t\t}\n\t\t}\n\n\t\treturn result;\n\t},\n\t// function for parsing AOS keyframe formats\n\tflattenJSON: function (jsonKeys, times, values, valuePropertyName) {\n\t\tlet i = 1,\n\t\t\t\tkey = jsonKeys[0];\n\n\t\twhile (key !== undefined && key[valuePropertyName] === undefined) {\n\t\t\tkey = jsonKeys[i++];\n\t\t}\n\n\t\tif (key === undefined) return; // no data\n\n\t\tlet value = key[valuePropertyName];\n\t\tif (value === undefined) return; // no data\n\n\t\tif (Array.isArray(value)) {\n\t\t\tdo {\n\t\t\t\tvalue = key[valuePropertyName];\n\n\t\t\t\tif (value !== undefined) {\n\t\t\t\t\ttimes.push(key.time);\n\t\t\t\t\tvalues.push.apply(values, value); // push all elements\n\t\t\t\t}\n\n\t\t\t\tkey = jsonKeys[i++];\n\t\t\t} while (key !== undefined);\n\t\t} else if (value.toArray !== undefined) {\n\t\t\t// ...assume THREE.Math-ish\n\t\t\tdo {\n\t\t\t\tvalue = key[valuePropertyName];\n\n\t\t\t\tif (value !== undefined) {\n\t\t\t\t\ttimes.push(key.time);\n\t\t\t\t\tvalue.toArray(values, values.length);\n\t\t\t\t}\n\n\t\t\t\tkey = jsonKeys[i++];\n\t\t\t} while (key !== undefined);\n\t\t} else {\n\t\t\t// otherwise push as-is\n\t\t\tdo {\n\t\t\t\tvalue = key[valuePropertyName];\n\n\t\t\t\tif (value !== undefined) {\n\t\t\t\t\ttimes.push(key.time);\n\t\t\t\t\tvalues.push(value);\n\t\t\t\t}\n\n\t\t\t\tkey = jsonKeys[i++];\n\t\t\t} while (key !== undefined);\n\t\t}\n\t},\n\tsubclip: function (sourceClip, name, startFrame, endFrame, fps = 30) {\n\t\tconst clip = sourceClip.clone();\n\t\tclip.name = name;\n\t\tconst tracks = [];\n\n\t\tfor (let i = 0; i < clip.tracks.length; ++i) {\n\t\t\tconst track = clip.tracks[i];\n\t\t\tconst valueSize = track.getValueSize();\n\t\t\tconst times = [];\n\t\t\tconst values = [];\n\n\t\t\tfor (let j = 0; j < track.times.length; ++j) {\n\t\t\t\tconst frame = track.times[j] * fps;\n\t\t\t\tif (frame < startFrame || frame >= endFrame) continue;\n\t\t\t\ttimes.push(track.times[j]);\n\n\t\t\t\tfor (let k = 0; k < valueSize; ++k) {\n\t\t\t\t\tvalues.push(track.values[j * valueSize + k]);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (times.length === 0) continue;\n\t\t\ttrack.times = AnimationUtils.convertArray(times, track.times.constructor);\n\t\t\ttrack.values = AnimationUtils.convertArray(values, track.values.constructor);\n\t\t\ttracks.push(track);\n\t\t}\n\n\t\tclip.tracks = tracks; // find minimum .times value across all tracks in the trimmed clip\n\n\t\tlet minStartTime = Infinity;\n\n\t\tfor (let i = 0; i < clip.tracks.length; ++i) {\n\t\t\tif (minStartTime > clip.tracks[i].times[0]) {\n\t\t\t\tminStartTime = clip.tracks[i].times[0];\n\t\t\t}\n\t\t} // shift all tracks such that clip begins at t=0\n\n\n\t\tfor (let i = 0; i < clip.tracks.length; ++i) {\n\t\t\tclip.tracks[i].shift(-1 * minStartTime);\n\t\t}\n\n\t\tclip.resetDuration();\n\t\treturn clip;\n\t},\n\tmakeClipAdditive: function (targetClip, referenceFrame = 0, referenceClip = targetClip, fps = 30) {\n\t\tif (fps <= 0) fps = 30;\n\t\tconst numTracks = referenceClip.tracks.length;\n\t\tconst referenceTime = referenceFrame / fps; // Make each track's values relative to the values at the reference frame\n\n\t\tfor (let i = 0; i < numTracks; ++i) {\n\t\t\tconst referenceTrack = referenceClip.tracks[i];\n\t\t\tconst referenceTrackType = referenceTrack.ValueTypeName; // Skip this track if it's non-numeric\n\n\t\t\tif (referenceTrackType === 'bool' || referenceTrackType === 'string') continue; // Find the track in the target clip whose name and type matches the reference track\n\n\t\t\tconst targetTrack = targetClip.tracks.find(function (track) {\n\t\t\t\treturn track.name === referenceTrack.name && track.ValueTypeName === referenceTrackType;\n\t\t\t});\n\t\t\tif (targetTrack === undefined) continue;\n\t\t\tlet referenceOffset = 0;\n\t\t\tconst referenceValueSize = referenceTrack.getValueSize();\n\n\t\t\tif (referenceTrack.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline) {\n\t\t\t\treferenceOffset = referenceValueSize / 3;\n\t\t\t}\n\n\t\t\tlet targetOffset = 0;\n\t\t\tconst targetValueSize = targetTrack.getValueSize();\n\n\t\t\tif (targetTrack.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline) {\n\t\t\t\ttargetOffset = targetValueSize / 3;\n\t\t\t}\n\n\t\t\tconst lastIndex = referenceTrack.times.length - 1;\n\t\t\tlet referenceValue; // Find the value to subtract out of the track\n\n\t\t\tif (referenceTime <= referenceTrack.times[0]) {\n\t\t\t\t// Reference frame is earlier than the first keyframe, so just use the first keyframe\n\t\t\t\tconst startIndex = referenceOffset;\n\t\t\t\tconst endIndex = referenceValueSize - referenceOffset;\n\t\t\t\treferenceValue = AnimationUtils.arraySlice(referenceTrack.values, startIndex, endIndex);\n\t\t\t} else if (referenceTime >= referenceTrack.times[lastIndex]) {\n\t\t\t\t// Reference frame is after the last keyframe, so just use the last keyframe\n\t\t\t\tconst startIndex = lastIndex * referenceValueSize + referenceOffset;\n\t\t\t\tconst endIndex = startIndex + referenceValueSize - referenceOffset;\n\t\t\t\treferenceValue = AnimationUtils.arraySlice(referenceTrack.values, startIndex, endIndex);\n\t\t\t} else {\n\t\t\t\t// Interpolate to the reference value\n\t\t\t\tconst interpolant = referenceTrack.createInterpolant();\n\t\t\t\tconst startIndex = referenceOffset;\n\t\t\t\tconst endIndex = referenceValueSize - referenceOffset;\n\t\t\t\tinterpolant.evaluate(referenceTime);\n\t\t\t\treferenceValue = AnimationUtils.arraySlice(interpolant.resultBuffer, startIndex, endIndex);\n\t\t\t} // Conjugate the quaternion\n\n\n\t\t\tif (referenceTrackType === 'quaternion') {\n\t\t\t\tconst referenceQuat = new Quaternion().fromArray(referenceValue).normalize().conjugate();\n\t\t\t\treferenceQuat.toArray(referenceValue);\n\t\t\t} // Subtract the reference value from all of the track values\n\n\n\t\t\tconst numTimes = targetTrack.times.length;\n\n\t\t\tfor (let j = 0; j < numTimes; ++j) {\n\t\t\t\tconst valueStart = j * targetValueSize + targetOffset;\n\n\t\t\t\tif (referenceTrackType === 'quaternion') {\n\t\t\t\t\t// Multiply the conjugate for quaternion track types\n\t\t\t\t\tQuaternion.multiplyQuaternionsFlat(targetTrack.values, valueStart, referenceValue, 0, targetTrack.values, valueStart);\n\t\t\t\t} else {\n\t\t\t\t\tconst valueEnd = targetValueSize - targetOffset * 2; // Subtract each value for all other numeric track types\n\n\t\t\t\t\tfor (let k = 0; k < valueEnd; ++k) {\n\t\t\t\t\t\ttargetTrack.values[valueStart + k] -= referenceValue[k];\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\ttargetClip.blendMode = AdditiveAnimationBlendMode;\n\t\treturn targetClip;\n\t}\n};\n\n/**\n * Abstract base class of interpolants over parametric samples.\n *\n * The parameter domain is one dimensional, typically the time or a path\n * along a curve defined by the data.\n *\n * The sample values can have any dimensionality and derived classes may\n * apply special interpretations to the data.\n *\n * This class provides the interval seek in a Template Method, deferring\n * the actual interpolation to derived classes.\n *\n * Time complexity is O(1) for linear access crossing at most two points\n * and O(log N) for random access, where N is the number of positions.\n *\n * References:\n *\n * \t\thttp://www.oodesign.com/template-method-pattern.html\n *\n */\nclass Interpolant {\n\tconstructor(parameterPositions, sampleValues, sampleSize, resultBuffer) {\n\t\tthis.parameterPositions = parameterPositions;\n\t\tthis._cachedIndex = 0;\n\t\tthis.resultBuffer = resultBuffer !== undefined ? resultBuffer : new sampleValues.constructor(sampleSize);\n\t\tthis.sampleValues = sampleValues;\n\t\tthis.valueSize = sampleSize;\n\t\tthis.settings = null;\n\t\tthis.DefaultSettings_ = {};\n\t}\n\n\tevaluate(t) {\n\t\tconst pp = this.parameterPositions;\n\t\tlet i1 = this._cachedIndex,\n\t\t\t\tt1 = pp[i1],\n\t\t\t\tt0 = pp[i1 - 1];\n\n\t\tvalidate_interval: {\n\t\t\tseek: {\n\t\t\t\tlet right;\n\n\t\t\t\tlinear_scan: {\n\t\t\t\t\t//- See http://jsperf.com/comparison-to-undefined/3\n\t\t\t\t\t//- slower code:\n\t\t\t\t\t//-\n\t\t\t\t\t//- \t\t\t\tif ( t >= t1 || t1 === undefined ) {\n\t\t\t\t\tforward_scan: if (!(t < t1)) {\n\t\t\t\t\t\tfor (let giveUpAt = i1 + 2;;) {\n\t\t\t\t\t\t\tif (t1 === undefined) {\n\t\t\t\t\t\t\t\tif (t < t0) break forward_scan; // after end\n\n\t\t\t\t\t\t\t\ti1 = pp.length;\n\t\t\t\t\t\t\t\tthis._cachedIndex = i1;\n\t\t\t\t\t\t\t\treturn this.copySampleValue_(i1 - 1);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (i1 === giveUpAt) break; // this loop\n\n\t\t\t\t\t\t\tt0 = t1;\n\t\t\t\t\t\t\tt1 = pp[++i1];\n\n\t\t\t\t\t\t\tif (t < t1) {\n\t\t\t\t\t\t\t\t// we have arrived at the sought interval\n\t\t\t\t\t\t\t\tbreak seek;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} // prepare binary search on the right side of the index\n\n\n\t\t\t\t\t\tright = pp.length;\n\t\t\t\t\t\tbreak linear_scan;\n\t\t\t\t\t} //- slower code:\n\t\t\t\t\t//-\t\t\t\t\tif ( t < t0 || t0 === undefined ) {\n\n\n\t\t\t\t\tif (!(t >= t0)) {\n\t\t\t\t\t\t// looping?\n\t\t\t\t\t\tconst t1global = pp[1];\n\n\t\t\t\t\t\tif (t < t1global) {\n\t\t\t\t\t\t\ti1 = 2; // + 1, using the scan for the details\n\n\t\t\t\t\t\t\tt0 = t1global;\n\t\t\t\t\t\t} // linear reverse scan\n\n\n\t\t\t\t\t\tfor (let giveUpAt = i1 - 2;;) {\n\t\t\t\t\t\t\tif (t0 === undefined) {\n\t\t\t\t\t\t\t\t// before start\n\t\t\t\t\t\t\t\tthis._cachedIndex = 0;\n\t\t\t\t\t\t\t\treturn this.copySampleValue_(0);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (i1 === giveUpAt) break; // this loop\n\n\t\t\t\t\t\t\tt1 = t0;\n\t\t\t\t\t\t\tt0 = pp[--i1 - 1];\n\n\t\t\t\t\t\t\tif (t >= t0) {\n\t\t\t\t\t\t\t\t// we have arrived at the sought interval\n\t\t\t\t\t\t\t\tbreak seek;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} // prepare binary search on the left side of the index\n\n\n\t\t\t\t\t\tright = i1;\n\t\t\t\t\t\ti1 = 0;\n\t\t\t\t\t\tbreak linear_scan;\n\t\t\t\t\t} // the interval is valid\n\n\n\t\t\t\t\tbreak validate_interval;\n\t\t\t\t} // linear scan\n\t\t\t\t// binary search\n\n\n\t\t\t\twhile (i1 < right) {\n\t\t\t\t\tconst mid = i1 + right >>> 1;\n\n\t\t\t\t\tif (t < pp[mid]) {\n\t\t\t\t\t\tright = mid;\n\t\t\t\t\t} else {\n\t\t\t\t\t\ti1 = mid + 1;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tt1 = pp[i1];\n\t\t\t\tt0 = pp[i1 - 1]; // check boundary cases, again\n\n\t\t\t\tif (t0 === undefined) {\n\t\t\t\t\tthis._cachedIndex = 0;\n\t\t\t\t\treturn this.copySampleValue_(0);\n\t\t\t\t}\n\n\t\t\t\tif (t1 === undefined) {\n\t\t\t\t\ti1 = pp.length;\n\t\t\t\t\tthis._cachedIndex = i1;\n\t\t\t\t\treturn this.copySampleValue_(i1 - 1);\n\t\t\t\t}\n\t\t\t} // seek\n\n\n\t\t\tthis._cachedIndex = i1;\n\t\t\tthis.intervalChanged_(i1, t0, t1);\n\t\t} // validate_interval\n\n\n\t\treturn this.interpolate_(i1, t0, t, t1);\n\t}\n\n\tgetSettings_() {\n\t\treturn this.settings || this.DefaultSettings_;\n\t}\n\n\tcopySampleValue_(index) {\n\t\t// copies a sample value to the result buffer\n\t\tconst result = this.resultBuffer,\n\t\t\t\t\tvalues = this.sampleValues,\n\t\t\t\t\tstride = this.valueSize,\n\t\t\t\t\toffset = index * stride;\n\n\t\tfor (let i = 0; i !== stride; ++i) {\n\t\t\tresult[i] = values[offset + i];\n\t\t}\n\n\t\treturn result;\n\t} // Template methods for derived classes:\n\n\n\tinterpolate_() {\n\t\tthrow new Error('call to abstract method'); // implementations shall return this.resultBuffer\n\t}\n\n\tintervalChanged_() {// empty\n\t}\n\n}\n\n/**\n * Fast and simple cubic spline interpolant.\n *\n * It was derived from a Hermitian construction setting the first derivative\n * at each sample position to the linear slope between neighboring positions\n * over their parameter interval.\n */\n\nclass CubicInterpolant extends Interpolant {\n\tconstructor(parameterPositions, sampleValues, sampleSize, resultBuffer) {\n\t\tsuper(parameterPositions, sampleValues, sampleSize, resultBuffer);\n\t\tthis._weightPrev = -0;\n\t\tthis._offsetPrev = -0;\n\t\tthis._weightNext = -0;\n\t\tthis._offsetNext = -0;\n\t\tthis.DefaultSettings_ = {\n\t\t\tendingStart: ZeroCurvatureEnding,\n\t\t\tendingEnd: ZeroCurvatureEnding\n\t\t};\n\t}\n\n\tintervalChanged_(i1, t0, t1) {\n\t\tconst pp = this.parameterPositions;\n\t\tlet iPrev = i1 - 2,\n\t\t\t\tiNext = i1 + 1,\n\t\t\t\ttPrev = pp[iPrev],\n\t\t\t\ttNext = pp[iNext];\n\n\t\tif (tPrev === undefined) {\n\t\t\tswitch (this.getSettings_().endingStart) {\n\t\t\t\tcase ZeroSlopeEnding:\n\t\t\t\t\t// f'(t0) = 0\n\t\t\t\t\tiPrev = i1;\n\t\t\t\t\ttPrev = 2 * t0 - t1;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase WrapAroundEnding:\n\t\t\t\t\t// use the other end of the curve\n\t\t\t\t\tiPrev = pp.length - 2;\n\t\t\t\t\ttPrev = t0 + pp[iPrev] - pp[iPrev + 1];\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\n\t\t\t\t\t// ZeroCurvatureEnding\n\t\t\t\t\t// f''(t0) = 0 a.k.a. Natural Spline\n\t\t\t\t\tiPrev = i1;\n\t\t\t\t\ttPrev = t1;\n\t\t\t}\n\t\t}\n\n\t\tif (tNext === undefined) {\n\t\t\tswitch (this.getSettings_().endingEnd) {\n\t\t\t\tcase ZeroSlopeEnding:\n\t\t\t\t\t// f'(tN) = 0\n\t\t\t\t\tiNext = i1;\n\t\t\t\t\ttNext = 2 * t1 - t0;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase WrapAroundEnding:\n\t\t\t\t\t// use the other end of the curve\n\t\t\t\t\tiNext = 1;\n\t\t\t\t\ttNext = t1 + pp[1] - pp[0];\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\n\t\t\t\t\t// ZeroCurvatureEnding\n\t\t\t\t\t// f''(tN) = 0, a.k.a. Natural Spline\n\t\t\t\t\tiNext = i1 - 1;\n\t\t\t\t\ttNext = t0;\n\t\t\t}\n\t\t}\n\n\t\tconst halfDt = (t1 - t0) * 0.5,\n\t\t\t\t\tstride = this.valueSize;\n\t\tthis._weightPrev = halfDt / (t0 - tPrev);\n\t\tthis._weightNext = halfDt / (tNext - t1);\n\t\tthis._offsetPrev = iPrev * stride;\n\t\tthis._offsetNext = iNext * stride;\n\t}\n\n\tinterpolate_(i1, t0, t, t1) {\n\t\tconst result = this.resultBuffer,\n\t\t\t\t\tvalues = this.sampleValues,\n\t\t\t\t\tstride = this.valueSize,\n\t\t\t\t\to1 = i1 * stride,\n\t\t\t\t\to0 = o1 - stride,\n\t\t\t\t\toP = this._offsetPrev,\n\t\t\t\t\toN = this._offsetNext,\n\t\t\t\t\twP = this._weightPrev,\n\t\t\t\t\twN = this._weightNext,\n\t\t\t\t\tp = (t - t0) / (t1 - t0),\n\t\t\t\t\tpp = p * p,\n\t\t\t\t\tppp = pp * p; // evaluate polynomials\n\n\t\tconst sP = -wP * ppp + 2 * wP * pp - wP * p;\n\t\tconst s0 = (1 + wP) * ppp + (-1.5 - 2 * wP) * pp + (-0.5 + wP) * p + 1;\n\t\tconst s1 = (-1 - wN) * ppp + (1.5 + wN) * pp + 0.5 * p;\n\t\tconst sN = wN * ppp - wN * pp; // combine data linearly\n\n\t\tfor (let i = 0; i !== stride; ++i) {\n\t\t\tresult[i] = sP * values[oP + i] + s0 * values[o0 + i] + s1 * values[o1 + i] + sN * values[oN + i];\n\t\t}\n\n\t\treturn result;\n\t}\n\n}\n\nclass LinearInterpolant extends Interpolant {\n\tconstructor(parameterPositions, sampleValues, sampleSize, resultBuffer) {\n\t\tsuper(parameterPositions, sampleValues, sampleSize, resultBuffer);\n\t}\n\n\tinterpolate_(i1, t0, t, t1) {\n\t\tconst result = this.resultBuffer,\n\t\t\t\t\tvalues = this.sampleValues,\n\t\t\t\t\tstride = this.valueSize,\n\t\t\t\t\toffset1 = i1 * stride,\n\t\t\t\t\toffset0 = offset1 - stride,\n\t\t\t\t\tweight1 = (t - t0) / (t1 - t0),\n\t\t\t\t\tweight0 = 1 - weight1;\n\n\t\tfor (let i = 0; i !== stride; ++i) {\n\t\t\tresult[i] = values[offset0 + i] * weight0 + values[offset1 + i] * weight1;\n\t\t}\n\n\t\treturn result;\n\t}\n\n}\n\n/**\n *\n * Interpolant that evaluates to the sample value at the position preceding\n * the parameter.\n */\n\nclass DiscreteInterpolant extends Interpolant {\n\tconstructor(parameterPositions, sampleValues, sampleSize, resultBuffer) {\n\t\tsuper(parameterPositions, sampleValues, sampleSize, resultBuffer);\n\t}\n\n\tinterpolate_(i1\n\t/*, t0, t, t1 */\n\t) {\n\t\treturn this.copySampleValue_(i1 - 1);\n\t}\n\n}\n\nclass KeyframeTrack {\n\tconstructor(name, times, values, interpolation) {\n\t\tif (name === undefined) throw new Error('THREE.KeyframeTrack: track name is undefined');\n\t\tif (times === undefined || times.length === 0) throw new Error('THREE.KeyframeTrack: no keyframes in track named ' + name);\n\t\tthis.name = name;\n\t\tthis.times = AnimationUtils.convertArray(times, this.TimeBufferType);\n\t\tthis.values = AnimationUtils.convertArray(values, this.ValueBufferType);\n\t\tthis.setInterpolation(interpolation || this.DefaultInterpolation);\n\t} // Serialization (in static context, because of constructor invocation\n\t// and automatic invocation of .toJSON):\n\n\n\tstatic toJSON(track) {\n\t\tconst trackType = track.constructor;\n\t\tlet json; // derived classes can define a static toJSON method\n\n\t\tif (trackType.toJSON !== this.toJSON) {\n\t\t\tjson = trackType.toJSON(track);\n\t\t} else {\n\t\t\t// by default, we assume the data can be serialized as-is\n\t\t\tjson = {\n\t\t\t\t'name': track.name,\n\t\t\t\t'times': AnimationUtils.convertArray(track.times, Array),\n\t\t\t\t'values': AnimationUtils.convertArray(track.values, Array)\n\t\t\t};\n\t\t\tconst interpolation = track.getInterpolation();\n\n\t\t\tif (interpolation !== track.DefaultInterpolation) {\n\t\t\t\tjson.interpolation = interpolation;\n\t\t\t}\n\t\t}\n\n\t\tjson.type = track.ValueTypeName; // mandatory\n\n\t\treturn json;\n\t}\n\n\tInterpolantFactoryMethodDiscrete(result) {\n\t\treturn new DiscreteInterpolant(this.times, this.values, this.getValueSize(), result);\n\t}\n\n\tInterpolantFactoryMethodLinear(result) {\n\t\treturn new LinearInterpolant(this.times, this.values, this.getValueSize(), result);\n\t}\n\n\tInterpolantFactoryMethodSmooth(result) {\n\t\treturn new CubicInterpolant(this.times, this.values, this.getValueSize(), result);\n\t}\n\n\tsetInterpolation(interpolation) {\n\t\tlet factoryMethod;\n\n\t\tswitch (interpolation) {\n\t\t\tcase InterpolateDiscrete:\n\t\t\t\tfactoryMethod = this.InterpolantFactoryMethodDiscrete;\n\t\t\t\tbreak;\n\n\t\t\tcase InterpolateLinear:\n\t\t\t\tfactoryMethod = this.InterpolantFactoryMethodLinear;\n\t\t\t\tbreak;\n\n\t\t\tcase InterpolateSmooth:\n\t\t\t\tfactoryMethod = this.InterpolantFactoryMethodSmooth;\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif (factoryMethod === undefined) {\n\t\t\tconst message = 'unsupported interpolation for ' + this.ValueTypeName + ' keyframe track named ' + this.name;\n\n\t\t\tif (this.createInterpolant === undefined) {\n\t\t\t\t// fall back to default, unless the default itself is messed up\n\t\t\t\tif (interpolation !== this.DefaultInterpolation) {\n\t\t\t\t\tthis.setInterpolation(this.DefaultInterpolation);\n\t\t\t\t} else {\n\t\t\t\t\tthrow new Error(message); // fatal, in this case\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconsole.warn('THREE.KeyframeTrack:', message);\n\t\t\treturn this;\n\t\t}\n\n\t\tthis.createInterpolant = factoryMethod;\n\t\treturn this;\n\t}\n\n\tgetInterpolation() {\n\t\tswitch (this.createInterpolant) {\n\t\t\tcase this.InterpolantFactoryMethodDiscrete:\n\t\t\t\treturn InterpolateDiscrete;\n\n\t\t\tcase this.InterpolantFactoryMethodLinear:\n\t\t\t\treturn InterpolateLinear;\n\n\t\t\tcase this.InterpolantFactoryMethodSmooth:\n\t\t\t\treturn InterpolateSmooth;\n\t\t}\n\t}\n\n\tgetValueSize() {\n\t\treturn this.values.length / this.times.length;\n\t} // move all keyframes either forwards or backwards in time\n\n\n\tshift(timeOffset) {\n\t\tif (timeOffset !== 0.0) {\n\t\t\tconst times = this.times;\n\n\t\t\tfor (let i = 0, n = times.length; i !== n; ++i) {\n\t\t\t\ttimes[i] += timeOffset;\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t} // scale all keyframe times by a factor (useful for frame <-> seconds conversions)\n\n\n\tscale(timeScale) {\n\t\tif (timeScale !== 1.0) {\n\t\t\tconst times = this.times;\n\n\t\t\tfor (let i = 0, n = times.length; i !== n; ++i) {\n\t\t\t\ttimes[i] *= timeScale;\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t} // removes keyframes before and after animation without changing any values within the range [startTime, endTime].\n\t// IMPORTANT: We do not shift around keys to the start of the track time, because for interpolated keys this will change their values\n\n\n\ttrim(startTime, endTime) {\n\t\tconst times = this.times,\n\t\t\t\t\tnKeys = times.length;\n\t\tlet from = 0,\n\t\t\t\tto = nKeys - 1;\n\n\t\twhile (from !== nKeys && times[from] < startTime) {\n\t\t\t++from;\n\t\t}\n\n\t\twhile (to !== -1 && times[to] > endTime) {\n\t\t\t--to;\n\t\t}\n\n\t\t++to; // inclusive -> exclusive bound\n\n\t\tif (from !== 0 || to !== nKeys) {\n\t\t\t// empty tracks are forbidden, so keep at least one keyframe\n\t\t\tif (from >= to) {\n\t\t\t\tto = Math.max(to, 1);\n\t\t\t\tfrom = to - 1;\n\t\t\t}\n\n\t\t\tconst stride = this.getValueSize();\n\t\t\tthis.times = AnimationUtils.arraySlice(times, from, to);\n\t\t\tthis.values = AnimationUtils.arraySlice(this.values, from * stride, to * stride);\n\t\t}\n\n\t\treturn this;\n\t} // ensure we do not get a GarbageInGarbageOut situation, make sure tracks are at least minimally viable\n\n\n\tvalidate() {\n\t\tlet valid = true;\n\t\tconst valueSize = this.getValueSize();\n\n\t\tif (valueSize - Math.floor(valueSize) !== 0) {\n\t\t\tconsole.error('THREE.KeyframeTrack: Invalid value size in track.', this);\n\t\t\tvalid = false;\n\t\t}\n\n\t\tconst times = this.times,\n\t\t\t\t\tvalues = this.values,\n\t\t\t\t\tnKeys = times.length;\n\n\t\tif (nKeys === 0) {\n\t\t\tconsole.error('THREE.KeyframeTrack: Track is empty.', this);\n\t\t\tvalid = false;\n\t\t}\n\n\t\tlet prevTime = null;\n\n\t\tfor (let i = 0; i !== nKeys; i++) {\n\t\t\tconst currTime = times[i];\n\n\t\t\tif (typeof currTime === 'number' && isNaN(currTime)) {\n\t\t\t\tconsole.error('THREE.KeyframeTrack: Time is not a valid number.', this, i, currTime);\n\t\t\t\tvalid = false;\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tif (prevTime !== null && prevTime > currTime) {\n\t\t\t\tconsole.error('THREE.KeyframeTrack: Out of order keys.', this, i, currTime, prevTime);\n\t\t\t\tvalid = false;\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tprevTime = currTime;\n\t\t}\n\n\t\tif (values !== undefined) {\n\t\t\tif (AnimationUtils.isTypedArray(values)) {\n\t\t\t\tfor (let i = 0, n = values.length; i !== n; ++i) {\n\t\t\t\t\tconst value = values[i];\n\n\t\t\t\t\tif (isNaN(value)) {\n\t\t\t\t\t\tconsole.error('THREE.KeyframeTrack: Value is not a valid number.', this, i, value);\n\t\t\t\t\t\tvalid = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn valid;\n\t} // removes equivalent sequential keys as common in morph target sequences\n\t// (0,0,0,0,1,1,1,0,0,0,0,0,0,0) --> (0,0,1,1,0,0)\n\n\n\toptimize() {\n\t\t// times or values may be shared with other tracks, so overwriting is unsafe\n\t\tconst times = AnimationUtils.arraySlice(this.times),\n\t\t\t\t\tvalues = AnimationUtils.arraySlice(this.values),\n\t\t\t\t\tstride = this.getValueSize(),\n\t\t\t\t\tsmoothInterpolation = this.getInterpolation() === InterpolateSmooth,\n\t\t\t\t\tlastIndex = times.length - 1;\n\t\tlet writeIndex = 1;\n\n\t\tfor (let i = 1; i < lastIndex; ++i) {\n\t\t\tlet keep = false;\n\t\t\tconst time = times[i];\n\t\t\tconst timeNext = times[i + 1]; // remove adjacent keyframes scheduled at the same time\n\n\t\t\tif (time !== timeNext && (i !== 1 || time !== times[0])) {\n\t\t\t\tif (!smoothInterpolation) {\n\t\t\t\t\t// remove unnecessary keyframes same as their neighbors\n\t\t\t\t\tconst offset = i * stride,\n\t\t\t\t\t\t\t\toffsetP = offset - stride,\n\t\t\t\t\t\t\t\toffsetN = offset + stride;\n\n\t\t\t\t\tfor (let j = 0; j !== stride; ++j) {\n\t\t\t\t\t\tconst value = values[offset + j];\n\n\t\t\t\t\t\tif (value !== values[offsetP + j] || value !== values[offsetN + j]) {\n\t\t\t\t\t\t\tkeep = true;\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tkeep = true;\n\t\t\t\t}\n\t\t\t} // in-place compaction\n\n\n\t\t\tif (keep) {\n\t\t\t\tif (i !== writeIndex) {\n\t\t\t\t\ttimes[writeIndex] = times[i];\n\t\t\t\t\tconst readOffset = i * stride,\n\t\t\t\t\t\t\t\twriteOffset = writeIndex * stride;\n\n\t\t\t\t\tfor (let j = 0; j !== stride; ++j) {\n\t\t\t\t\t\tvalues[writeOffset + j] = values[readOffset + j];\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t++writeIndex;\n\t\t\t}\n\t\t} // flush last keyframe (compaction looks ahead)\n\n\n\t\tif (lastIndex > 0) {\n\t\t\ttimes[writeIndex] = times[lastIndex];\n\n\t\t\tfor (let readOffset = lastIndex * stride, writeOffset = writeIndex * stride, j = 0; j !== stride; ++j) {\n\t\t\t\tvalues[writeOffset + j] = values[readOffset + j];\n\t\t\t}\n\n\t\t\t++writeIndex;\n\t\t}\n\n\t\tif (writeIndex !== times.length) {\n\t\t\tthis.times = AnimationUtils.arraySlice(times, 0, writeIndex);\n\t\t\tthis.values = AnimationUtils.arraySlice(values, 0, writeIndex * stride);\n\t\t} else {\n\t\t\tthis.times = times;\n\t\t\tthis.values = values;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\tconst times = AnimationUtils.arraySlice(this.times, 0);\n\t\tconst values = AnimationUtils.arraySlice(this.values, 0);\n\t\tconst TypedKeyframeTrack = this.constructor;\n\t\tconst track = new TypedKeyframeTrack(this.name, times, values); // Interpolant argument to constructor is not saved, so copy the factory method directly.\n\n\t\ttrack.createInterpolant = this.createInterpolant;\n\t\treturn track;\n\t}\n\n}\n\nKeyframeTrack.prototype.TimeBufferType = Float32Array;\nKeyframeTrack.prototype.ValueBufferType = Float32Array;\nKeyframeTrack.prototype.DefaultInterpolation = InterpolateLinear;\n\n/**\n * A Track of Boolean keyframe values.\n */\n\nclass BooleanKeyframeTrack extends KeyframeTrack {}\n\nBooleanKeyframeTrack.prototype.ValueTypeName = 'bool';\nBooleanKeyframeTrack.prototype.ValueBufferType = Array;\nBooleanKeyframeTrack.prototype.DefaultInterpolation = InterpolateDiscrete;\nBooleanKeyframeTrack.prototype.InterpolantFactoryMethodLinear = undefined;\nBooleanKeyframeTrack.prototype.InterpolantFactoryMethodSmooth = undefined; // Note: Actually this track could have a optimized / compressed\n\n/**\n * A Track of keyframe values that represent color.\n */\n\nclass ColorKeyframeTrack extends KeyframeTrack {}\n\nColorKeyframeTrack.prototype.ValueTypeName = 'color'; // ValueBufferType is inherited\n\n/**\n * A Track of numeric keyframe values.\n */\n\nclass NumberKeyframeTrack extends KeyframeTrack {}\n\nNumberKeyframeTrack.prototype.ValueTypeName = 'number'; // ValueBufferType is inherited\n\n/**\n * Spherical linear unit quaternion interpolant.\n */\n\nclass QuaternionLinearInterpolant extends Interpolant {\n\tconstructor(parameterPositions, sampleValues, sampleSize, resultBuffer) {\n\t\tsuper(parameterPositions, sampleValues, sampleSize, resultBuffer);\n\t}\n\n\tinterpolate_(i1, t0, t, t1) {\n\t\tconst result = this.resultBuffer,\n\t\t\t\t\tvalues = this.sampleValues,\n\t\t\t\t\tstride = this.valueSize,\n\t\t\t\t\talpha = (t - t0) / (t1 - t0);\n\t\tlet offset = i1 * stride;\n\n\t\tfor (let end = offset + stride; offset !== end; offset += 4) {\n\t\t\tQuaternion.slerpFlat(result, 0, values, offset - stride, values, offset, alpha);\n\t\t}\n\n\t\treturn result;\n\t}\n\n}\n\n/**\n * A Track of quaternion keyframe values.\n */\n\nclass QuaternionKeyframeTrack extends KeyframeTrack {\n\tInterpolantFactoryMethodLinear(result) {\n\t\treturn new QuaternionLinearInterpolant(this.times, this.values, this.getValueSize(), result);\n\t}\n\n}\n\nQuaternionKeyframeTrack.prototype.ValueTypeName = 'quaternion'; // ValueBufferType is inherited\n\nQuaternionKeyframeTrack.prototype.DefaultInterpolation = InterpolateLinear;\nQuaternionKeyframeTrack.prototype.InterpolantFactoryMethodSmooth = undefined;\n\n/**\n * A Track that interpolates Strings\n */\n\nclass StringKeyframeTrack extends KeyframeTrack {}\n\nStringKeyframeTrack.prototype.ValueTypeName = 'string';\nStringKeyframeTrack.prototype.ValueBufferType = Array;\nStringKeyframeTrack.prototype.DefaultInterpolation = InterpolateDiscrete;\nStringKeyframeTrack.prototype.InterpolantFactoryMethodLinear = undefined;\nStringKeyframeTrack.prototype.InterpolantFactoryMethodSmooth = undefined;\n\n/**\n * A Track of vectored keyframe values.\n */\n\nclass VectorKeyframeTrack extends KeyframeTrack {}\n\nVectorKeyframeTrack.prototype.ValueTypeName = 'vector'; // ValueBufferType is inherited\n\nclass AnimationClip {\n\tconstructor(name, duration = -1, tracks, blendMode = NormalAnimationBlendMode) {\n\t\tthis.name = name;\n\t\tthis.tracks = tracks;\n\t\tthis.duration = duration;\n\t\tthis.blendMode = blendMode;\n\t\tthis.uuid = generateUUID(); // this means it should figure out its duration by scanning the tracks\n\n\t\tif (this.duration < 0) {\n\t\t\tthis.resetDuration();\n\t\t}\n\t}\n\n\tstatic parse(json) {\n\t\tconst tracks = [],\n\t\t\t\t\tjsonTracks = json.tracks,\n\t\t\t\t\tframeTime = 1.0 / (json.fps || 1.0);\n\n\t\tfor (let i = 0, n = jsonTracks.length; i !== n; ++i) {\n\t\t\ttracks.push(parseKeyframeTrack(jsonTracks[i]).scale(frameTime));\n\t\t}\n\n\t\tconst clip = new this(json.name, json.duration, tracks, json.blendMode);\n\t\tclip.uuid = json.uuid;\n\t\treturn clip;\n\t}\n\n\tstatic toJSON(clip) {\n\t\tconst tracks = [],\n\t\t\t\t\tclipTracks = clip.tracks;\n\t\tconst json = {\n\t\t\t'name': clip.name,\n\t\t\t'duration': clip.duration,\n\t\t\t'tracks': tracks,\n\t\t\t'uuid': clip.uuid,\n\t\t\t'blendMode': clip.blendMode\n\t\t};\n\n\t\tfor (let i = 0, n = clipTracks.length; i !== n; ++i) {\n\t\t\ttracks.push(KeyframeTrack.toJSON(clipTracks[i]));\n\t\t}\n\n\t\treturn json;\n\t}\n\n\tstatic CreateFromMorphTargetSequence(name, morphTargetSequence, fps, noLoop) {\n\t\tconst numMorphTargets = morphTargetSequence.length;\n\t\tconst tracks = [];\n\n\t\tfor (let i = 0; i < numMorphTargets; i++) {\n\t\t\tlet times = [];\n\t\t\tlet values = [];\n\t\t\ttimes.push((i + numMorphTargets - 1) % numMorphTargets, i, (i + 1) % numMorphTargets);\n\t\t\tvalues.push(0, 1, 0);\n\t\t\tconst order = AnimationUtils.getKeyframeOrder(times);\n\t\t\ttimes = AnimationUtils.sortedArray(times, 1, order);\n\t\t\tvalues = AnimationUtils.sortedArray(values, 1, order); // if there is a key at the first frame, duplicate it as the\n\t\t\t// last frame as well for perfect loop.\n\n\t\t\tif (!noLoop && times[0] === 0) {\n\t\t\t\ttimes.push(numMorphTargets);\n\t\t\t\tvalues.push(values[0]);\n\t\t\t}\n\n\t\t\ttracks.push(new NumberKeyframeTrack('.morphTargetInfluences[' + morphTargetSequence[i].name + ']', times, values).scale(1.0 / fps));\n\t\t}\n\n\t\treturn new this(name, -1, tracks);\n\t}\n\n\tstatic findByName(objectOrClipArray, name) {\n\t\tlet clipArray = objectOrClipArray;\n\n\t\tif (!Array.isArray(objectOrClipArray)) {\n\t\t\tconst o = objectOrClipArray;\n\t\t\tclipArray = o.geometry && o.geometry.animations || o.animations;\n\t\t}\n\n\t\tfor (let i = 0; i < clipArray.length; i++) {\n\t\t\tif (clipArray[i].name === name) {\n\t\t\t\treturn clipArray[i];\n\t\t\t}\n\t\t}\n\n\t\treturn null;\n\t}\n\n\tstatic CreateClipsFromMorphTargetSequences(morphTargets, fps, noLoop) {\n\t\tconst animationToMorphTargets = {}; // tested with https://regex101.com/ on trick sequences\n\t\t// such flamingo_flyA_003, flamingo_run1_003, crdeath0059\n\n\t\tconst pattern = /^([\\w-]*?)([\\d]+)$/; // sort morph target names into animation groups based\n\t\t// patterns like Walk_001, Walk_002, Run_001, Run_002\n\n\t\tfor (let i = 0, il = morphTargets.length; i < il; i++) {\n\t\t\tconst morphTarget = morphTargets[i];\n\t\t\tconst parts = morphTarget.name.match(pattern);\n\n\t\t\tif (parts && parts.length > 1) {\n\t\t\t\tconst name = parts[1];\n\t\t\t\tlet animationMorphTargets = animationToMorphTargets[name];\n\n\t\t\t\tif (!animationMorphTargets) {\n\t\t\t\t\tanimationToMorphTargets[name] = animationMorphTargets = [];\n\t\t\t\t}\n\n\t\t\t\tanimationMorphTargets.push(morphTarget);\n\t\t\t}\n\t\t}\n\n\t\tconst clips = [];\n\n\t\tfor (const name in animationToMorphTargets) {\n\t\t\tclips.push(this.CreateFromMorphTargetSequence(name, animationToMorphTargets[name], fps, noLoop));\n\t\t}\n\n\t\treturn clips;\n\t} // parse the animation.hierarchy format\n\n\n\tstatic parseAnimation(animation, bones) {\n\t\tif (!animation) {\n\t\t\tconsole.error('THREE.AnimationClip: No animation in JSONLoader data.');\n\t\t\treturn null;\n\t\t}\n\n\t\tconst addNonemptyTrack = function (trackType, trackName, animationKeys, propertyName, destTracks) {\n\t\t\t// only return track if there are actually keys.\n\t\t\tif (animationKeys.length !== 0) {\n\t\t\t\tconst times = [];\n\t\t\t\tconst values = [];\n\t\t\t\tAnimationUtils.flattenJSON(animationKeys, times, values, propertyName); // empty keys are filtered out, so check again\n\n\t\t\t\tif (times.length !== 0) {\n\t\t\t\t\tdestTracks.push(new trackType(trackName, times, values));\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\tconst tracks = [];\n\t\tconst clipName = animation.name || 'default';\n\t\tconst fps = animation.fps || 30;\n\t\tconst blendMode = animation.blendMode; // automatic length determination in AnimationClip.\n\n\t\tlet duration = animation.length || -1;\n\t\tconst hierarchyTracks = animation.hierarchy || [];\n\n\t\tfor (let h = 0; h < hierarchyTracks.length; h++) {\n\t\t\tconst animationKeys = hierarchyTracks[h].keys; // skip empty tracks\n\n\t\t\tif (!animationKeys || animationKeys.length === 0) continue; // process morph targets\n\n\t\t\tif (animationKeys[0].morphTargets) {\n\t\t\t\t// figure out all morph targets used in this track\n\t\t\t\tconst morphTargetNames = {};\n\t\t\t\tlet k;\n\n\t\t\t\tfor (k = 0; k < animationKeys.length; k++) {\n\t\t\t\t\tif (animationKeys[k].morphTargets) {\n\t\t\t\t\t\tfor (let m = 0; m < animationKeys[k].morphTargets.length; m++) {\n\t\t\t\t\t\t\tmorphTargetNames[animationKeys[k].morphTargets[m]] = -1;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} // create a track for each morph target with all zero\n\t\t\t\t// morphTargetInfluences except for the keys in which\n\t\t\t\t// the morphTarget is named.\n\n\n\t\t\t\tfor (const morphTargetName in morphTargetNames) {\n\t\t\t\t\tconst times = [];\n\t\t\t\t\tconst values = [];\n\n\t\t\t\t\tfor (let m = 0; m !== animationKeys[k].morphTargets.length; ++m) {\n\t\t\t\t\t\tconst animationKey = animationKeys[k];\n\t\t\t\t\t\ttimes.push(animationKey.time);\n\t\t\t\t\t\tvalues.push(animationKey.morphTarget === morphTargetName ? 1 : 0);\n\t\t\t\t\t}\n\n\t\t\t\t\ttracks.push(new NumberKeyframeTrack('.morphTargetInfluence[' + morphTargetName + ']', times, values));\n\t\t\t\t}\n\n\t\t\t\tduration = morphTargetNames.length * fps;\n\t\t\t} else {\n\t\t\t\t// ...assume skeletal animation\n\t\t\t\tconst boneName = '.bones[' + bones[h].name + ']';\n\t\t\t\taddNonemptyTrack(VectorKeyframeTrack, boneName + '.position', animationKeys, 'pos', tracks);\n\t\t\t\taddNonemptyTrack(QuaternionKeyframeTrack, boneName + '.quaternion', animationKeys, 'rot', tracks);\n\t\t\t\taddNonemptyTrack(VectorKeyframeTrack, boneName + '.scale', animationKeys, 'scl', tracks);\n\t\t\t}\n\t\t}\n\n\t\tif (tracks.length === 0) {\n\t\t\treturn null;\n\t\t}\n\n\t\tconst clip = new this(clipName, duration, tracks, blendMode);\n\t\treturn clip;\n\t}\n\n\tresetDuration() {\n\t\tconst tracks = this.tracks;\n\t\tlet duration = 0;\n\n\t\tfor (let i = 0, n = tracks.length; i !== n; ++i) {\n\t\t\tconst track = this.tracks[i];\n\t\t\tduration = Math.max(duration, track.times[track.times.length - 1]);\n\t\t}\n\n\t\tthis.duration = duration;\n\t\treturn this;\n\t}\n\n\ttrim() {\n\t\tfor (let i = 0; i < this.tracks.length; i++) {\n\t\t\tthis.tracks[i].trim(0, this.duration);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tvalidate() {\n\t\tlet valid = true;\n\n\t\tfor (let i = 0; i < this.tracks.length; i++) {\n\t\t\tvalid = valid && this.tracks[i].validate();\n\t\t}\n\n\t\treturn valid;\n\t}\n\n\toptimize() {\n\t\tfor (let i = 0; i < this.tracks.length; i++) {\n\t\t\tthis.tracks[i].optimize();\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\tconst tracks = [];\n\n\t\tfor (let i = 0; i < this.tracks.length; i++) {\n\t\t\ttracks.push(this.tracks[i].clone());\n\t\t}\n\n\t\treturn new this.constructor(this.name, this.duration, tracks, this.blendMode);\n\t}\n\n\ttoJSON() {\n\t\treturn this.constructor.toJSON(this);\n\t}\n\n}\n\nfunction getTrackTypeForValueTypeName(typeName) {\n\tswitch (typeName.toLowerCase()) {\n\t\tcase 'scalar':\n\t\tcase 'double':\n\t\tcase 'float':\n\t\tcase 'number':\n\t\tcase 'integer':\n\t\t\treturn NumberKeyframeTrack;\n\n\t\tcase 'vector':\n\t\tcase 'vector2':\n\t\tcase 'vector3':\n\t\tcase 'vector4':\n\t\t\treturn VectorKeyframeTrack;\n\n\t\tcase 'color':\n\t\t\treturn ColorKeyframeTrack;\n\n\t\tcase 'quaternion':\n\t\t\treturn QuaternionKeyframeTrack;\n\n\t\tcase 'bool':\n\t\tcase 'boolean':\n\t\t\treturn BooleanKeyframeTrack;\n\n\t\tcase 'string':\n\t\t\treturn StringKeyframeTrack;\n\t}\n\n\tthrow new Error('THREE.KeyframeTrack: Unsupported typeName: ' + typeName);\n}\n\nfunction parseKeyframeTrack(json) {\n\tif (json.type === undefined) {\n\t\tthrow new Error('THREE.KeyframeTrack: track type undefined, can not parse');\n\t}\n\n\tconst trackType = getTrackTypeForValueTypeName(json.type);\n\n\tif (json.times === undefined) {\n\t\tconst times = [],\n\t\t\t\t\tvalues = [];\n\t\tAnimationUtils.flattenJSON(json.keys, times, values, 'value');\n\t\tjson.times = times;\n\t\tjson.values = values;\n\t} // derived classes can define a static parse method\n\n\n\tif (trackType.parse !== undefined) {\n\t\treturn trackType.parse(json);\n\t} else {\n\t\t// by default, we assume a constructor compatible with the base\n\t\treturn new trackType(json.name, json.times, json.values, json.interpolation);\n\t}\n}\n\nconst Cache = {\n\tenabled: false,\n\tfiles: {},\n\tadd: function (key, file) {\n\t\tif (this.enabled === false) return; // console.log( 'THREE.Cache', 'Adding key:', key );\n\n\t\tthis.files[key] = file;\n\t},\n\tget: function (key) {\n\t\tif (this.enabled === false) return; // console.log( 'THREE.Cache', 'Checking key:', key );\n\n\t\treturn this.files[key];\n\t},\n\tremove: function (key) {\n\t\tdelete this.files[key];\n\t},\n\tclear: function () {\n\t\tthis.files = {};\n\t}\n};\n\nclass LoadingManager {\n\tconstructor(onLoad, onProgress, onError) {\n\t\tconst scope = this;\n\t\tlet isLoading = false;\n\t\tlet itemsLoaded = 0;\n\t\tlet itemsTotal = 0;\n\t\tlet urlModifier = undefined;\n\t\tconst handlers = []; // Refer to #5689 for the reason why we don't set .onStart\n\t\t// in the constructor\n\n\t\tthis.onStart = undefined;\n\t\tthis.onLoad = onLoad;\n\t\tthis.onProgress = onProgress;\n\t\tthis.onError = onError;\n\n\t\tthis.itemStart = function (url) {\n\t\t\titemsTotal++;\n\n\t\t\tif (isLoading === false) {\n\t\t\t\tif (scope.onStart !== undefined) {\n\t\t\t\t\tscope.onStart(url, itemsLoaded, itemsTotal);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tisLoading = true;\n\t\t};\n\n\t\tthis.itemEnd = function (url) {\n\t\t\titemsLoaded++;\n\n\t\t\tif (scope.onProgress !== undefined) {\n\t\t\t\tscope.onProgress(url, itemsLoaded, itemsTotal);\n\t\t\t}\n\n\t\t\tif (itemsLoaded === itemsTotal) {\n\t\t\t\tisLoading = false;\n\n\t\t\t\tif (scope.onLoad !== undefined) {\n\t\t\t\t\tscope.onLoad();\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\tthis.itemError = function (url) {\n\t\t\tif (scope.onError !== undefined) {\n\t\t\t\tscope.onError(url);\n\t\t\t}\n\t\t};\n\n\t\tthis.resolveURL = function (url) {\n\t\t\tif (urlModifier) {\n\t\t\t\treturn urlModifier(url);\n\t\t\t}\n\n\t\t\treturn url;\n\t\t};\n\n\t\tthis.setURLModifier = function (transform) {\n\t\t\turlModifier = transform;\n\t\t\treturn this;\n\t\t};\n\n\t\tthis.addHandler = function (regex, loader) {\n\t\t\thandlers.push(regex, loader);\n\t\t\treturn this;\n\t\t};\n\n\t\tthis.removeHandler = function (regex) {\n\t\t\tconst index = handlers.indexOf(regex);\n\n\t\t\tif (index !== -1) {\n\t\t\t\thandlers.splice(index, 2);\n\t\t\t}\n\n\t\t\treturn this;\n\t\t};\n\n\t\tthis.getHandler = function (file) {\n\t\t\tfor (let i = 0, l = handlers.length; i < l; i += 2) {\n\t\t\t\tconst regex = handlers[i];\n\t\t\t\tconst loader = handlers[i + 1];\n\t\t\t\tif (regex.global) regex.lastIndex = 0; // see #17920\n\n\t\t\t\tif (regex.test(file)) {\n\t\t\t\t\treturn loader;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn null;\n\t\t};\n\t}\n\n}\n\nconst DefaultLoadingManager = new LoadingManager();\n\nclass Loader {\n\tconstructor(manager) {\n\t\tthis.manager = manager !== undefined ? manager : DefaultLoadingManager;\n\t\tthis.crossOrigin = 'anonymous';\n\t\tthis.withCredentials = false;\n\t\tthis.path = '';\n\t\tthis.resourcePath = '';\n\t\tthis.requestHeader = {};\n\t}\n\n\tload() {}\n\n\tloadAsync(url, onProgress) {\n\t\tconst scope = this;\n\t\treturn new Promise(function (resolve, reject) {\n\t\t\tscope.load(url, resolve, onProgress, reject);\n\t\t});\n\t}\n\n\tparse() {}\n\n\tsetCrossOrigin(crossOrigin) {\n\t\tthis.crossOrigin = crossOrigin;\n\t\treturn this;\n\t}\n\n\tsetWithCredentials(value) {\n\t\tthis.withCredentials = value;\n\t\treturn this;\n\t}\n\n\tsetPath(path) {\n\t\tthis.path = path;\n\t\treturn this;\n\t}\n\n\tsetResourcePath(resourcePath) {\n\t\tthis.resourcePath = resourcePath;\n\t\treturn this;\n\t}\n\n\tsetRequestHeader(requestHeader) {\n\t\tthis.requestHeader = requestHeader;\n\t\treturn this;\n\t}\n\n}\n\nconst loading = {};\n\nclass FileLoader extends Loader {\n\tconstructor(manager) {\n\t\tsuper(manager);\n\t}\n\n\tload(url, onLoad, onProgress, onError) {\n\t\tif (url === undefined) url = '';\n\t\tif (this.path !== undefined) url = this.path + url;\n\t\turl = this.manager.resolveURL(url);\n\t\tconst cached = Cache.get(url);\n\n\t\tif (cached !== undefined) {\n\t\t\tthis.manager.itemStart(url);\n\t\t\tsetTimeout(() => {\n\t\t\t\tif (onLoad) onLoad(cached);\n\t\t\t\tthis.manager.itemEnd(url);\n\t\t\t}, 0);\n\t\t\treturn cached;\n\t\t} // Check if request is duplicate\n\n\n\t\tif (loading[url] !== undefined) {\n\t\t\tloading[url].push({\n\t\t\t\tonLoad: onLoad,\n\t\t\t\tonProgress: onProgress,\n\t\t\t\tonError: onError\n\t\t\t});\n\t\t\treturn;\n\t\t} // Initialise array for duplicate requests\n\n\n\t\tloading[url] = [];\n\t\tloading[url].push({\n\t\t\tonLoad: onLoad,\n\t\t\tonProgress: onProgress,\n\t\t\tonError: onError\n\t\t}); // create request\n\n\t\tconst req = new Request(url, {\n\t\t\theaders: new Headers(this.requestHeader),\n\t\t\tcredentials: this.withCredentials ? 'include' : 'same-origin' // An abort controller could be added within a future PR\n\n\t\t}); // record states ( avoid data race )\n\n\t\tconst mimeType = this.mimeType;\n\t\tconst responseType = this.responseType; // start the fetch\n\n\t\tfetch(req).then(response => {\n\t\t\tif (response.status === 200 || response.status === 0) {\n\t\t\t\t// Some browsers return HTTP Status 0 when using non-http protocol\n\t\t\t\t// e.g. 'file://' or 'data://'. Handle as success.\n\t\t\t\tif (response.status === 0) {\n\t\t\t\t\tconsole.warn('THREE.FileLoader: HTTP Status 0 received.');\n\t\t\t\t} // Workaround: Checking if response.body === undefined for Alipay browser #23548\n\n\n\t\t\t\tif (typeof ReadableStream === 'undefined' || response.body === undefined || response.body.getReader === undefined) {\n\t\t\t\t\treturn response;\n\t\t\t\t}\n\n\t\t\t\tconst callbacks = loading[url];\n\t\t\t\tconst reader = response.body.getReader();\n\t\t\t\tconst contentLength = response.headers.get('Content-Length');\n\t\t\t\tconst total = contentLength ? parseInt(contentLength) : 0;\n\t\t\t\tconst lengthComputable = total !== 0;\n\t\t\t\tlet loaded = 0; // periodically read data into the new stream tracking while download progress\n\n\t\t\t\tconst stream = new ReadableStream({\n\t\t\t\t\tstart(controller) {\n\t\t\t\t\t\treadData();\n\n\t\t\t\t\t\tfunction readData() {\n\t\t\t\t\t\t\treader.read().then(({\n\t\t\t\t\t\t\t\tdone,\n\t\t\t\t\t\t\t\tvalue\n\t\t\t\t\t\t\t}) => {\n\t\t\t\t\t\t\t\tif (done) {\n\t\t\t\t\t\t\t\t\tcontroller.close();\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tloaded += value.byteLength;\n\t\t\t\t\t\t\t\t\tconst event = new ProgressEvent('progress', {\n\t\t\t\t\t\t\t\t\t\tlengthComputable,\n\t\t\t\t\t\t\t\t\t\tloaded,\n\t\t\t\t\t\t\t\t\t\ttotal\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tfor (let i = 0, il = callbacks.length; i < il; i++) {\n\t\t\t\t\t\t\t\t\t\tconst callback = callbacks[i];\n\t\t\t\t\t\t\t\t\t\tif (callback.onProgress) callback.onProgress(event);\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\tcontroller.enqueue(value);\n\t\t\t\t\t\t\t\t\treadData();\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t});\n\t\t\t\treturn new Response(stream);\n\t\t\t} else {\n\t\t\t\tthrow Error(`fetch for \"${response.url}\" responded with ${response.status}: ${response.statusText}`);\n\t\t\t}\n\t\t}).then(response => {\n\t\t\tswitch (responseType) {\n\t\t\t\tcase 'arraybuffer':\n\t\t\t\t\treturn response.arrayBuffer();\n\n\t\t\t\tcase 'blob':\n\t\t\t\t\treturn response.blob();\n\n\t\t\t\tcase 'document':\n\t\t\t\t\treturn response.text().then(text => {\n\t\t\t\t\t\tconst parser = new DOMParser();\n\t\t\t\t\t\treturn parser.parseFromString(text, mimeType);\n\t\t\t\t\t});\n\n\t\t\t\tcase 'json':\n\t\t\t\t\treturn response.json();\n\n\t\t\t\tdefault:\n\t\t\t\t\tif (mimeType === undefined) {\n\t\t\t\t\t\treturn response.text();\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// sniff encoding\n\t\t\t\t\t\tconst re = /charset=\"?([^;\"\\s]*)\"?/i;\n\t\t\t\t\t\tconst exec = re.exec(mimeType);\n\t\t\t\t\t\tconst label = exec && exec[1] ? exec[1].toLowerCase() : undefined;\n\t\t\t\t\t\tconst decoder = new TextDecoder(label);\n\t\t\t\t\t\treturn response.arrayBuffer().then(ab => decoder.decode(ab));\n\t\t\t\t\t}\n\n\t\t\t}\n\t\t}).then(data => {\n\t\t\t// Add to cache only on HTTP success, so that we do not cache\n\t\t\t// error response bodies as proper responses to requests.\n\t\t\tCache.add(url, data);\n\t\t\tconst callbacks = loading[url];\n\t\t\tdelete loading[url];\n\n\t\t\tfor (let i = 0, il = callbacks.length; i < il; i++) {\n\t\t\t\tconst callback = callbacks[i];\n\t\t\t\tif (callback.onLoad) callback.onLoad(data);\n\t\t\t}\n\t\t}).catch(err => {\n\t\t\t// Abort errors and other errors are handled the same\n\t\t\tconst callbacks = loading[url];\n\n\t\t\tif (callbacks === undefined) {\n\t\t\t\t// When onLoad was called and url was deleted in `loading`\n\t\t\t\tthis.manager.itemError(url);\n\t\t\t\tthrow err;\n\t\t\t}\n\n\t\t\tdelete loading[url];\n\n\t\t\tfor (let i = 0, il = callbacks.length; i < il; i++) {\n\t\t\t\tconst callback = callbacks[i];\n\t\t\t\tif (callback.onError) callback.onError(err);\n\t\t\t}\n\n\t\t\tthis.manager.itemError(url);\n\t\t}).finally(() => {\n\t\t\tthis.manager.itemEnd(url);\n\t\t});\n\t\tthis.manager.itemStart(url);\n\t}\n\n\tsetResponseType(value) {\n\t\tthis.responseType = value;\n\t\treturn this;\n\t}\n\n\tsetMimeType(value) {\n\t\tthis.mimeType = value;\n\t\treturn this;\n\t}\n\n}\n\nclass AnimationLoader extends Loader {\n\tconstructor(manager) {\n\t\tsuper(manager);\n\t}\n\n\tload(url, onLoad, onProgress, onError) {\n\t\tconst scope = this;\n\t\tconst loader = new FileLoader(this.manager);\n\t\tloader.setPath(this.path);\n\t\tloader.setRequestHeader(this.requestHeader);\n\t\tloader.setWithCredentials(this.withCredentials);\n\t\tloader.load(url, function (text) {\n\t\t\ttry {\n\t\t\t\tonLoad(scope.parse(JSON.parse(text)));\n\t\t\t} catch (e) {\n\t\t\t\tif (onError) {\n\t\t\t\t\tonError(e);\n\t\t\t\t} else {\n\t\t\t\t\tconsole.error(e);\n\t\t\t\t}\n\n\t\t\t\tscope.manager.itemError(url);\n\t\t\t}\n\t\t}, onProgress, onError);\n\t}\n\n\tparse(json) {\n\t\tconst animations = [];\n\n\t\tfor (let i = 0; i < json.length; i++) {\n\t\t\tconst clip = AnimationClip.parse(json[i]);\n\t\t\tanimations.push(clip);\n\t\t}\n\n\t\treturn animations;\n\t}\n\n}\n\n/**\n * Abstract Base class to block based textures loader (dds, pvr, ...)\n *\n * Sub classes have to implement the parse() method which will be used in load().\n */\n\nclass CompressedTextureLoader extends Loader {\n\tconstructor(manager) {\n\t\tsuper(manager);\n\t}\n\n\tload(url, onLoad, onProgress, onError) {\n\t\tconst scope = this;\n\t\tconst images = [];\n\t\tconst texture = new CompressedTexture();\n\t\tconst loader = new FileLoader(this.manager);\n\t\tloader.setPath(this.path);\n\t\tloader.setResponseType('arraybuffer');\n\t\tloader.setRequestHeader(this.requestHeader);\n\t\tloader.setWithCredentials(scope.withCredentials);\n\t\tlet loaded = 0;\n\n\t\tfunction loadTexture(i) {\n\t\t\tloader.load(url[i], function (buffer) {\n\t\t\t\tconst texDatas = scope.parse(buffer, true);\n\t\t\t\timages[i] = {\n\t\t\t\t\twidth: texDatas.width,\n\t\t\t\t\theight: texDatas.height,\n\t\t\t\t\tformat: texDatas.format,\n\t\t\t\t\tmipmaps: texDatas.mipmaps\n\t\t\t\t};\n\t\t\t\tloaded += 1;\n\n\t\t\t\tif (loaded === 6) {\n\t\t\t\t\tif (texDatas.mipmapCount === 1) texture.minFilter = LinearFilter;\n\t\t\t\t\ttexture.image = images;\n\t\t\t\t\ttexture.format = texDatas.format;\n\t\t\t\t\ttexture.needsUpdate = true;\n\t\t\t\t\tif (onLoad) onLoad(texture);\n\t\t\t\t}\n\t\t\t}, onProgress, onError);\n\t\t}\n\n\t\tif (Array.isArray(url)) {\n\t\t\tfor (let i = 0, il = url.length; i < il; ++i) {\n\t\t\t\tloadTexture(i);\n\t\t\t}\n\t\t} else {\n\t\t\t// compressed cubemap texture stored in a single DDS file\n\t\t\tloader.load(url, function (buffer) {\n\t\t\t\tconst texDatas = scope.parse(buffer, true);\n\n\t\t\t\tif (texDatas.isCubemap) {\n\t\t\t\t\tconst faces = texDatas.mipmaps.length / texDatas.mipmapCount;\n\n\t\t\t\t\tfor (let f = 0; f < faces; f++) {\n\t\t\t\t\t\timages[f] = {\n\t\t\t\t\t\t\tmipmaps: []\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tfor (let i = 0; i < texDatas.mipmapCount; i++) {\n\t\t\t\t\t\t\timages[f].mipmaps.push(texDatas.mipmaps[f * texDatas.mipmapCount + i]);\n\t\t\t\t\t\t\timages[f].format = texDatas.format;\n\t\t\t\t\t\t\timages[f].width = texDatas.width;\n\t\t\t\t\t\t\timages[f].height = texDatas.height;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\ttexture.image = images;\n\t\t\t\t} else {\n\t\t\t\t\ttexture.image.width = texDatas.width;\n\t\t\t\t\ttexture.image.height = texDatas.height;\n\t\t\t\t\ttexture.mipmaps = texDatas.mipmaps;\n\t\t\t\t}\n\n\t\t\t\tif (texDatas.mipmapCount === 1) {\n\t\t\t\t\ttexture.minFilter = LinearFilter;\n\t\t\t\t}\n\n\t\t\t\ttexture.format = texDatas.format;\n\t\t\t\ttexture.needsUpdate = true;\n\t\t\t\tif (onLoad) onLoad(texture);\n\t\t\t}, onProgress, onError);\n\t\t}\n\n\t\treturn texture;\n\t}\n\n}\n\nclass ImageLoader extends Loader {\n\tconstructor(manager) {\n\t\tsuper(manager);\n\t}\n\n\tload(url, onLoad, onProgress, onError) {\n\t\tif (this.path !== undefined) url = this.path + url;\n\t\turl = this.manager.resolveURL(url);\n\t\tconst scope = this;\n\t\tconst cached = Cache.get(url);\n\n\t\tif (cached !== undefined) {\n\t\t\tscope.manager.itemStart(url);\n\t\t\tsetTimeout(function () {\n\t\t\t\tif (onLoad) onLoad(cached);\n\t\t\t\tscope.manager.itemEnd(url);\n\t\t\t}, 0);\n\t\t\treturn cached;\n\t\t}\n\n\t\tconst image = createElementNS('img');\n\n\t\tfunction onImageLoad() {\n\t\t\tremoveEventListeners();\n\t\t\tCache.add(url, this);\n\t\t\tif (onLoad) onLoad(this);\n\t\t\tscope.manager.itemEnd(url);\n\t\t}\n\n\t\tfunction onImageError(event) {\n\t\t\tremoveEventListeners();\n\t\t\tif (onError) onError(event);\n\t\t\tscope.manager.itemError(url);\n\t\t\tscope.manager.itemEnd(url);\n\t\t}\n\n\t\tfunction removeEventListeners() {\n\t\t\timage.removeEventListener('load', onImageLoad, false);\n\t\t\timage.removeEventListener('error', onImageError, false);\n\t\t}\n\n\t\timage.addEventListener('load', onImageLoad, false);\n\t\timage.addEventListener('error', onImageError, false);\n\n\t\tif (url.slice(0, 5) !== 'data:') {\n\t\t\tif (this.crossOrigin !== undefined) image.crossOrigin = this.crossOrigin;\n\t\t}\n\n\t\tscope.manager.itemStart(url);\n\t\timage.src = url;\n\t\treturn image;\n\t}\n\n}\n\nclass CubeTextureLoader extends Loader {\n\tconstructor(manager) {\n\t\tsuper(manager);\n\t}\n\n\tload(urls, onLoad, onProgress, onError) {\n\t\tconst texture = new CubeTexture();\n\t\tconst loader = new ImageLoader(this.manager);\n\t\tloader.setCrossOrigin(this.crossOrigin);\n\t\tloader.setPath(this.path);\n\t\tlet loaded = 0;\n\n\t\tfunction loadTexture(i) {\n\t\t\tloader.load(urls[i], function (image) {\n\t\t\t\ttexture.images[i] = image;\n\t\t\t\tloaded++;\n\n\t\t\t\tif (loaded === 6) {\n\t\t\t\t\ttexture.needsUpdate = true;\n\t\t\t\t\tif (onLoad) onLoad(texture);\n\t\t\t\t}\n\t\t\t}, undefined, onError);\n\t\t}\n\n\t\tfor (let i = 0; i < urls.length; ++i) {\n\t\t\tloadTexture(i);\n\t\t}\n\n\t\treturn texture;\n\t}\n\n}\n\n/**\n * Abstract Base class to load generic binary textures formats (rgbe, hdr, ...)\n *\n * Sub classes have to implement the parse() method which will be used in load().\n */\n\nclass DataTextureLoader extends Loader {\n\tconstructor(manager) {\n\t\tsuper(manager);\n\t}\n\n\tload(url, onLoad, onProgress, onError) {\n\t\tconst scope = this;\n\t\tconst texture = new DataTexture();\n\t\tconst loader = new FileLoader(this.manager);\n\t\tloader.setResponseType('arraybuffer');\n\t\tloader.setRequestHeader(this.requestHeader);\n\t\tloader.setPath(this.path);\n\t\tloader.setWithCredentials(scope.withCredentials);\n\t\tloader.load(url, function (buffer) {\n\t\t\tconst texData = scope.parse(buffer);\n\t\t\tif (!texData) return;\n\n\t\t\tif (texData.image !== undefined) {\n\t\t\t\ttexture.image = texData.image;\n\t\t\t} else if (texData.data !== undefined) {\n\t\t\t\ttexture.image.width = texData.width;\n\t\t\t\ttexture.image.height = texData.height;\n\t\t\t\ttexture.image.data = texData.data;\n\t\t\t}\n\n\t\t\ttexture.wrapS = texData.wrapS !== undefined ? texData.wrapS : ClampToEdgeWrapping;\n\t\t\ttexture.wrapT = texData.wrapT !== undefined ? texData.wrapT : ClampToEdgeWrapping;\n\t\t\ttexture.magFilter = texData.magFilter !== undefined ? texData.magFilter : LinearFilter;\n\t\t\ttexture.minFilter = texData.minFilter !== undefined ? texData.minFilter : LinearFilter;\n\t\t\ttexture.anisotropy = texData.anisotropy !== undefined ? texData.anisotropy : 1;\n\n\t\t\tif (texData.encoding !== undefined) {\n\t\t\t\ttexture.encoding = texData.encoding;\n\t\t\t}\n\n\t\t\tif (texData.flipY !== undefined) {\n\t\t\t\ttexture.flipY = texData.flipY;\n\t\t\t}\n\n\t\t\tif (texData.format !== undefined) {\n\t\t\t\ttexture.format = texData.format;\n\t\t\t}\n\n\t\t\tif (texData.type !== undefined) {\n\t\t\t\ttexture.type = texData.type;\n\t\t\t}\n\n\t\t\tif (texData.mipmaps !== undefined) {\n\t\t\t\ttexture.mipmaps = texData.mipmaps;\n\t\t\t\ttexture.minFilter = LinearMipmapLinearFilter; // presumably...\n\t\t\t}\n\n\t\t\tif (texData.mipmapCount === 1) {\n\t\t\t\ttexture.minFilter = LinearFilter;\n\t\t\t}\n\n\t\t\tif (texData.generateMipmaps !== undefined) {\n\t\t\t\ttexture.generateMipmaps = texData.generateMipmaps;\n\t\t\t}\n\n\t\t\ttexture.needsUpdate = true;\n\t\t\tif (onLoad) onLoad(texture, texData);\n\t\t}, onProgress, onError);\n\t\treturn texture;\n\t}\n\n}\n\nclass TextureLoader extends Loader {\n\tconstructor(manager) {\n\t\tsuper(manager);\n\t}\n\n\tload(url, onLoad, onProgress, onError) {\n\t\tconst texture = new Texture();\n\t\tconst loader = new ImageLoader(this.manager);\n\t\tloader.setCrossOrigin(this.crossOrigin);\n\t\tloader.setPath(this.path);\n\t\tloader.load(url, function (image) {\n\t\t\ttexture.image = image;\n\t\t\ttexture.needsUpdate = true;\n\n\t\t\tif (onLoad !== undefined) {\n\t\t\t\tonLoad(texture);\n\t\t\t}\n\t\t}, onProgress, onError);\n\t\treturn texture;\n\t}\n\n}\n\nclass Light extends Object3D {\n\tconstructor(color, intensity = 1) {\n\t\tsuper();\n\t\tthis.isLight = true;\n\t\tthis.type = 'Light';\n\t\tthis.color = new Color(color);\n\t\tthis.intensity = intensity;\n\t}\n\n\tdispose() {// Empty here in base class; some subclasses override.\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tthis.color.copy(source.color);\n\t\tthis.intensity = source.intensity;\n\t\treturn this;\n\t}\n\n\ttoJSON(meta) {\n\t\tconst data = super.toJSON(meta);\n\t\tdata.object.color = this.color.getHex();\n\t\tdata.object.intensity = this.intensity;\n\t\tif (this.groundColor !== undefined) data.object.groundColor = this.groundColor.getHex();\n\t\tif (this.distance !== undefined) data.object.distance = this.distance;\n\t\tif (this.angle !== undefined) data.object.angle = this.angle;\n\t\tif (this.decay !== undefined) data.object.decay = this.decay;\n\t\tif (this.penumbra !== undefined) data.object.penumbra = this.penumbra;\n\t\tif (this.shadow !== undefined) data.object.shadow = this.shadow.toJSON();\n\t\treturn data;\n\t}\n\n}\n\nclass HemisphereLight extends Light {\n\tconstructor(skyColor, groundColor, intensity) {\n\t\tsuper(skyColor, intensity);\n\t\tthis.isHemisphereLight = true;\n\t\tthis.type = 'HemisphereLight';\n\t\tthis.position.copy(Object3D.DefaultUp);\n\t\tthis.updateMatrix();\n\t\tthis.groundColor = new Color(groundColor);\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tthis.groundColor.copy(source.groundColor);\n\t\treturn this;\n\t}\n\n}\n\nconst _projScreenMatrix$1 = /*@__PURE__*/new Matrix4();\n\nconst _lightPositionWorld$1 = /*@__PURE__*/new Vector3();\n\nconst _lookTarget$1 = /*@__PURE__*/new Vector3();\n\nclass LightShadow {\n\tconstructor(camera) {\n\t\tthis.camera = camera;\n\t\tthis.bias = 0;\n\t\tthis.normalBias = 0;\n\t\tthis.radius = 1;\n\t\tthis.blurSamples = 8;\n\t\tthis.mapSize = new Vector2(512, 512);\n\t\tthis.map = null;\n\t\tthis.mapPass = null;\n\t\tthis.matrix = new Matrix4();\n\t\tthis.autoUpdate = true;\n\t\tthis.needsUpdate = false;\n\t\tthis._frustum = new Frustum();\n\t\tthis._frameExtents = new Vector2(1, 1);\n\t\tthis._viewportCount = 1;\n\t\tthis._viewports = [new Vector4(0, 0, 1, 1)];\n\t}\n\n\tgetViewportCount() {\n\t\treturn this._viewportCount;\n\t}\n\n\tgetFrustum() {\n\t\treturn this._frustum;\n\t}\n\n\tupdateMatrices(light) {\n\t\tconst shadowCamera = this.camera;\n\t\tconst shadowMatrix = this.matrix;\n\n\t\t_lightPositionWorld$1.setFromMatrixPosition(light.matrixWorld);\n\n\t\tshadowCamera.position.copy(_lightPositionWorld$1);\n\n\t\t_lookTarget$1.setFromMatrixPosition(light.target.matrixWorld);\n\n\t\tshadowCamera.lookAt(_lookTarget$1);\n\t\tshadowCamera.updateMatrixWorld();\n\n\t\t_projScreenMatrix$1.multiplyMatrices(shadowCamera.projectionMatrix, shadowCamera.matrixWorldInverse);\n\n\t\tthis._frustum.setFromProjectionMatrix(_projScreenMatrix$1);\n\n\t\tshadowMatrix.set(0.5, 0.0, 0.0, 0.5, 0.0, 0.5, 0.0, 0.5, 0.0, 0.0, 0.5, 0.5, 0.0, 0.0, 0.0, 1.0);\n\t\tshadowMatrix.multiply(shadowCamera.projectionMatrix);\n\t\tshadowMatrix.multiply(shadowCamera.matrixWorldInverse);\n\t}\n\n\tgetViewport(viewportIndex) {\n\t\treturn this._viewports[viewportIndex];\n\t}\n\n\tgetFrameExtents() {\n\t\treturn this._frameExtents;\n\t}\n\n\tdispose() {\n\t\tif (this.map) {\n\t\t\tthis.map.dispose();\n\t\t}\n\n\t\tif (this.mapPass) {\n\t\t\tthis.mapPass.dispose();\n\t\t}\n\t}\n\n\tcopy(source) {\n\t\tthis.camera = source.camera.clone();\n\t\tthis.bias = source.bias;\n\t\tthis.radius = source.radius;\n\t\tthis.mapSize.copy(source.mapSize);\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n\ttoJSON() {\n\t\tconst object = {};\n\t\tif (this.bias !== 0) object.bias = this.bias;\n\t\tif (this.normalBias !== 0) object.normalBias = this.normalBias;\n\t\tif (this.radius !== 1) object.radius = this.radius;\n\t\tif (this.mapSize.x !== 512 || this.mapSize.y !== 512) object.mapSize = this.mapSize.toArray();\n\t\tobject.camera = this.camera.toJSON(false).object;\n\t\tdelete object.camera.matrix;\n\t\treturn object;\n\t}\n\n}\n\nclass SpotLightShadow extends LightShadow {\n\tconstructor() {\n\t\tsuper(new PerspectiveCamera(50, 1, 0.5, 500));\n\t\tthis.isSpotLightShadow = true;\n\t\tthis.focus = 1;\n\t}\n\n\tupdateMatrices(light) {\n\t\tconst camera = this.camera;\n\t\tconst fov = RAD2DEG * 2 * light.angle * this.focus;\n\t\tconst aspect = this.mapSize.width / this.mapSize.height;\n\t\tconst far = light.distance || camera.far;\n\n\t\tif (fov !== camera.fov || aspect !== camera.aspect || far !== camera.far) {\n\t\t\tcamera.fov = fov;\n\t\t\tcamera.aspect = aspect;\n\t\t\tcamera.far = far;\n\t\t\tcamera.updateProjectionMatrix();\n\t\t}\n\n\t\tsuper.updateMatrices(light);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.focus = source.focus;\n\t\treturn this;\n\t}\n\n}\n\nclass SpotLight extends Light {\n\tconstructor(color, intensity, distance = 0, angle = Math.PI / 3, penumbra = 0, decay = 1) {\n\t\tsuper(color, intensity);\n\t\tthis.isSpotLight = true;\n\t\tthis.type = 'SpotLight';\n\t\tthis.position.copy(Object3D.DefaultUp);\n\t\tthis.updateMatrix();\n\t\tthis.target = new Object3D();\n\t\tthis.distance = distance;\n\t\tthis.angle = angle;\n\t\tthis.penumbra = penumbra;\n\t\tthis.decay = decay; // for physically correct lights, should be 2.\n\n\t\tthis.shadow = new SpotLightShadow();\n\t}\n\n\tget power() {\n\t\t// compute the light's luminous power (in lumens) from its intensity (in candela)\n\t\t// by convention for a spotlight, luminous power (lm) = π * luminous intensity (cd)\n\t\treturn this.intensity * Math.PI;\n\t}\n\n\tset power(power) {\n\t\t// set the light's intensity (in candela) from the desired luminous power (in lumens)\n\t\tthis.intensity = power / Math.PI;\n\t}\n\n\tdispose() {\n\t\tthis.shadow.dispose();\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tthis.distance = source.distance;\n\t\tthis.angle = source.angle;\n\t\tthis.penumbra = source.penumbra;\n\t\tthis.decay = source.decay;\n\t\tthis.target = source.target.clone();\n\t\tthis.shadow = source.shadow.clone();\n\t\treturn this;\n\t}\n\n}\n\nconst _projScreenMatrix = /*@__PURE__*/new Matrix4();\n\nconst _lightPositionWorld = /*@__PURE__*/new Vector3();\n\nconst _lookTarget = /*@__PURE__*/new Vector3();\n\nclass PointLightShadow extends LightShadow {\n\tconstructor() {\n\t\tsuper(new PerspectiveCamera(90, 1, 0.5, 500));\n\t\tthis.isPointLightShadow = true;\n\t\tthis._frameExtents = new Vector2(4, 2);\n\t\tthis._viewportCount = 6;\n\t\tthis._viewports = [// These viewports map a cube-map onto a 2D texture with the\n\t\t// following orientation:\n\t\t//\n\t\t//\txzXZ\n\t\t//\t y Y\n\t\t//\n\t\t// X - Positive x direction\n\t\t// x - Negative x direction\n\t\t// Y - Positive y direction\n\t\t// y - Negative y direction\n\t\t// Z - Positive z direction\n\t\t// z - Negative z direction\n\t\t// positive X\n\t\tnew Vector4(2, 1, 1, 1), // negative X\n\t\tnew Vector4(0, 1, 1, 1), // positive Z\n\t\tnew Vector4(3, 1, 1, 1), // negative Z\n\t\tnew Vector4(1, 1, 1, 1), // positive Y\n\t\tnew Vector4(3, 0, 1, 1), // negative Y\n\t\tnew Vector4(1, 0, 1, 1)];\n\t\tthis._cubeDirections = [new Vector3(1, 0, 0), new Vector3(-1, 0, 0), new Vector3(0, 0, 1), new Vector3(0, 0, -1), new Vector3(0, 1, 0), new Vector3(0, -1, 0)];\n\t\tthis._cubeUps = [new Vector3(0, 1, 0), new Vector3(0, 1, 0), new Vector3(0, 1, 0), new Vector3(0, 1, 0), new Vector3(0, 0, 1), new Vector3(0, 0, -1)];\n\t}\n\n\tupdateMatrices(light, viewportIndex = 0) {\n\t\tconst camera = this.camera;\n\t\tconst shadowMatrix = this.matrix;\n\t\tconst far = light.distance || camera.far;\n\n\t\tif (far !== camera.far) {\n\t\t\tcamera.far = far;\n\t\t\tcamera.updateProjectionMatrix();\n\t\t}\n\n\t\t_lightPositionWorld.setFromMatrixPosition(light.matrixWorld);\n\n\t\tcamera.position.copy(_lightPositionWorld);\n\n\t\t_lookTarget.copy(camera.position);\n\n\t\t_lookTarget.add(this._cubeDirections[viewportIndex]);\n\n\t\tcamera.up.copy(this._cubeUps[viewportIndex]);\n\t\tcamera.lookAt(_lookTarget);\n\t\tcamera.updateMatrixWorld();\n\t\tshadowMatrix.makeTranslation(-_lightPositionWorld.x, -_lightPositionWorld.y, -_lightPositionWorld.z);\n\n\t\t_projScreenMatrix.multiplyMatrices(camera.projectionMatrix, camera.matrixWorldInverse);\n\n\t\tthis._frustum.setFromProjectionMatrix(_projScreenMatrix);\n\t}\n\n}\n\nclass PointLight extends Light {\n\tconstructor(color, intensity, distance = 0, decay = 1) {\n\t\tsuper(color, intensity);\n\t\tthis.isPointLight = true;\n\t\tthis.type = 'PointLight';\n\t\tthis.distance = distance;\n\t\tthis.decay = decay; // for physically correct lights, should be 2.\n\n\t\tthis.shadow = new PointLightShadow();\n\t}\n\n\tget power() {\n\t\t// compute the light's luminous power (in lumens) from its intensity (in candela)\n\t\t// for an isotropic light source, luminous power (lm) = 4 π luminous intensity (cd)\n\t\treturn this.intensity * 4 * Math.PI;\n\t}\n\n\tset power(power) {\n\t\t// set the light's intensity (in candela) from the desired luminous power (in lumens)\n\t\tthis.intensity = power / (4 * Math.PI);\n\t}\n\n\tdispose() {\n\t\tthis.shadow.dispose();\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tthis.distance = source.distance;\n\t\tthis.decay = source.decay;\n\t\tthis.shadow = source.shadow.clone();\n\t\treturn this;\n\t}\n\n}\n\nclass DirectionalLightShadow extends LightShadow {\n\tconstructor() {\n\t\tsuper(new OrthographicCamera(-5, 5, 5, -5, 0.5, 500));\n\t\tthis.isDirectionalLightShadow = true;\n\t}\n\n}\n\nclass DirectionalLight extends Light {\n\tconstructor(color, intensity) {\n\t\tsuper(color, intensity);\n\t\tthis.isDirectionalLight = true;\n\t\tthis.type = 'DirectionalLight';\n\t\tthis.position.copy(Object3D.DefaultUp);\n\t\tthis.updateMatrix();\n\t\tthis.target = new Object3D();\n\t\tthis.shadow = new DirectionalLightShadow();\n\t}\n\n\tdispose() {\n\t\tthis.shadow.dispose();\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.target = source.target.clone();\n\t\tthis.shadow = source.shadow.clone();\n\t\treturn this;\n\t}\n\n}\n\nclass AmbientLight extends Light {\n\tconstructor(color, intensity) {\n\t\tsuper(color, intensity);\n\t\tthis.isAmbientLight = true;\n\t\tthis.type = 'AmbientLight';\n\t}\n\n}\n\nclass RectAreaLight extends Light {\n\tconstructor(color, intensity, width = 10, height = 10) {\n\t\tsuper(color, intensity);\n\t\tthis.isRectAreaLight = true;\n\t\tthis.type = 'RectAreaLight';\n\t\tthis.width = width;\n\t\tthis.height = height;\n\t}\n\n\tget power() {\n\t\t// compute the light's luminous power (in lumens) from its intensity (in nits)\n\t\treturn this.intensity * this.width * this.height * Math.PI;\n\t}\n\n\tset power(power) {\n\t\t// set the light's intensity (in nits) from the desired luminous power (in lumens)\n\t\tthis.intensity = power / (this.width * this.height * Math.PI);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.width = source.width;\n\t\tthis.height = source.height;\n\t\treturn this;\n\t}\n\n\ttoJSON(meta) {\n\t\tconst data = super.toJSON(meta);\n\t\tdata.object.width = this.width;\n\t\tdata.object.height = this.height;\n\t\treturn data;\n\t}\n\n}\n\n/**\n * Primary reference:\n *\t https://graphics.stanford.edu/papers/envmap/envmap.pdf\n *\n * Secondary reference:\n *\t https://www.ppsloan.org/publications/StupidSH36.pdf\n */\n// 3-band SH defined by 9 coefficients\n\nclass SphericalHarmonics3 {\n\tconstructor() {\n\t\tthis.isSphericalHarmonics3 = true;\n\t\tthis.coefficients = [];\n\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tthis.coefficients.push(new Vector3());\n\t\t}\n\t}\n\n\tset(coefficients) {\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tthis.coefficients[i].copy(coefficients[i]);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tzero() {\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tthis.coefficients[i].set(0, 0, 0);\n\t\t}\n\n\t\treturn this;\n\t} // get the radiance in the direction of the normal\n\t// target is a Vector3\n\n\n\tgetAt(normal, target) {\n\t\t// normal is assumed to be unit length\n\t\tconst x = normal.x,\n\t\t\t\t\ty = normal.y,\n\t\t\t\t\tz = normal.z;\n\t\tconst coeff = this.coefficients; // band 0\n\n\t\ttarget.copy(coeff[0]).multiplyScalar(0.282095); // band 1\n\n\t\ttarget.addScaledVector(coeff[1], 0.488603 * y);\n\t\ttarget.addScaledVector(coeff[2], 0.488603 * z);\n\t\ttarget.addScaledVector(coeff[3], 0.488603 * x); // band 2\n\n\t\ttarget.addScaledVector(coeff[4], 1.092548 * (x * y));\n\t\ttarget.addScaledVector(coeff[5], 1.092548 * (y * z));\n\t\ttarget.addScaledVector(coeff[6], 0.315392 * (3.0 * z * z - 1.0));\n\t\ttarget.addScaledVector(coeff[7], 1.092548 * (x * z));\n\t\ttarget.addScaledVector(coeff[8], 0.546274 * (x * x - y * y));\n\t\treturn target;\n\t} // get the irradiance (radiance convolved with cosine lobe) in the direction of the normal\n\t// target is a Vector3\n\t// https://graphics.stanford.edu/papers/envmap/envmap.pdf\n\n\n\tgetIrradianceAt(normal, target) {\n\t\t// normal is assumed to be unit length\n\t\tconst x = normal.x,\n\t\t\t\t\ty = normal.y,\n\t\t\t\t\tz = normal.z;\n\t\tconst coeff = this.coefficients; // band 0\n\n\t\ttarget.copy(coeff[0]).multiplyScalar(0.886227); // π * 0.282095\n\t\t// band 1\n\n\t\ttarget.addScaledVector(coeff[1], 2.0 * 0.511664 * y); // ( 2 * π / 3 ) * 0.488603\n\n\t\ttarget.addScaledVector(coeff[2], 2.0 * 0.511664 * z);\n\t\ttarget.addScaledVector(coeff[3], 2.0 * 0.511664 * x); // band 2\n\n\t\ttarget.addScaledVector(coeff[4], 2.0 * 0.429043 * x * y); // ( π / 4 ) * 1.092548\n\n\t\ttarget.addScaledVector(coeff[5], 2.0 * 0.429043 * y * z);\n\t\ttarget.addScaledVector(coeff[6], 0.743125 * z * z - 0.247708); // ( π / 4 ) * 0.315392 * 3\n\n\t\ttarget.addScaledVector(coeff[7], 2.0 * 0.429043 * x * z);\n\t\ttarget.addScaledVector(coeff[8], 0.429043 * (x * x - y * y)); // ( π / 4 ) * 0.546274\n\n\t\treturn target;\n\t}\n\n\tadd(sh) {\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tthis.coefficients[i].add(sh.coefficients[i]);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\taddScaledSH(sh, s) {\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tthis.coefficients[i].addScaledVector(sh.coefficients[i], s);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tscale(s) {\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tthis.coefficients[i].multiplyScalar(s);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tlerp(sh, alpha) {\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tthis.coefficients[i].lerp(sh.coefficients[i], alpha);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tequals(sh) {\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tif (!this.coefficients[i].equals(sh.coefficients[i])) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\treturn true;\n\t}\n\n\tcopy(sh) {\n\t\treturn this.set(sh.coefficients);\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n\tfromArray(array, offset = 0) {\n\t\tconst coefficients = this.coefficients;\n\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tcoefficients[i].fromArray(array, offset + i * 3);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\ttoArray(array = [], offset = 0) {\n\t\tconst coefficients = this.coefficients;\n\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tcoefficients[i].toArray(array, offset + i * 3);\n\t\t}\n\n\t\treturn array;\n\t} // evaluate the basis functions\n\t// shBasis is an Array[ 9 ]\n\n\n\tstatic getBasisAt(normal, shBasis) {\n\t\t// normal is assumed to be unit length\n\t\tconst x = normal.x,\n\t\t\t\t\ty = normal.y,\n\t\t\t\t\tz = normal.z; // band 0\n\n\t\tshBasis[0] = 0.282095; // band 1\n\n\t\tshBasis[1] = 0.488603 * y;\n\t\tshBasis[2] = 0.488603 * z;\n\t\tshBasis[3] = 0.488603 * x; // band 2\n\n\t\tshBasis[4] = 1.092548 * x * y;\n\t\tshBasis[5] = 1.092548 * y * z;\n\t\tshBasis[6] = 0.315392 * (3 * z * z - 1);\n\t\tshBasis[7] = 1.092548 * x * z;\n\t\tshBasis[8] = 0.546274 * (x * x - y * y);\n\t}\n\n}\n\nclass LightProbe extends Light {\n\tconstructor(sh = new SphericalHarmonics3(), intensity = 1) {\n\t\tsuper(undefined, intensity);\n\t\tthis.isLightProbe = true;\n\t\tthis.sh = sh;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.sh.copy(source.sh);\n\t\treturn this;\n\t}\n\n\tfromJSON(json) {\n\t\tthis.intensity = json.intensity; // TODO: Move this bit to Light.fromJSON();\n\n\t\tthis.sh.fromArray(json.sh);\n\t\treturn this;\n\t}\n\n\ttoJSON(meta) {\n\t\tconst data = super.toJSON(meta);\n\t\tdata.object.sh = this.sh.toArray();\n\t\treturn data;\n\t}\n\n}\n\nclass MaterialLoader extends Loader {\n\tconstructor(manager) {\n\t\tsuper(manager);\n\t\tthis.textures = {};\n\t}\n\n\tload(url, onLoad, onProgress, onError) {\n\t\tconst scope = this;\n\t\tconst loader = new FileLoader(scope.manager);\n\t\tloader.setPath(scope.path);\n\t\tloader.setRequestHeader(scope.requestHeader);\n\t\tloader.setWithCredentials(scope.withCredentials);\n\t\tloader.load(url, function (text) {\n\t\t\ttry {\n\t\t\t\tonLoad(scope.parse(JSON.parse(text)));\n\t\t\t} catch (e) {\n\t\t\t\tif (onError) {\n\t\t\t\t\tonError(e);\n\t\t\t\t} else {\n\t\t\t\t\tconsole.error(e);\n\t\t\t\t}\n\n\t\t\t\tscope.manager.itemError(url);\n\t\t\t}\n\t\t}, onProgress, onError);\n\t}\n\n\tparse(json) {\n\t\tconst textures = this.textures;\n\n\t\tfunction getTexture(name) {\n\t\t\tif (textures[name] === undefined) {\n\t\t\t\tconsole.warn('THREE.MaterialLoader: Undefined texture', name);\n\t\t\t}\n\n\t\t\treturn textures[name];\n\t\t}\n\n\t\tconst material = Material.fromType(json.type);\n\t\tif (json.uuid !== undefined) material.uuid = json.uuid;\n\t\tif (json.name !== undefined) material.name = json.name;\n\t\tif (json.color !== undefined && material.color !== undefined) material.color.setHex(json.color);\n\t\tif (json.roughness !== undefined) material.roughness = json.roughness;\n\t\tif (json.metalness !== undefined) material.metalness = json.metalness;\n\t\tif (json.sheen !== undefined) material.sheen = json.sheen;\n\t\tif (json.sheenColor !== undefined) material.sheenColor = new Color().setHex(json.sheenColor);\n\t\tif (json.sheenRoughness !== undefined) material.sheenRoughness = json.sheenRoughness;\n\t\tif (json.emissive !== undefined && material.emissive !== undefined) material.emissive.setHex(json.emissive);\n\t\tif (json.specular !== undefined && material.specular !== undefined) material.specular.setHex(json.specular);\n\t\tif (json.specularIntensity !== undefined) material.specularIntensity = json.specularIntensity;\n\t\tif (json.specularColor !== undefined && material.specularColor !== undefined) material.specularColor.setHex(json.specularColor);\n\t\tif (json.shininess !== undefined) material.shininess = json.shininess;\n\t\tif (json.clearcoat !== undefined) material.clearcoat = json.clearcoat;\n\t\tif (json.clearcoatRoughness !== undefined) material.clearcoatRoughness = json.clearcoatRoughness;\n\t\tif (json.iridescence !== undefined) material.iridescence = json.iridescence;\n\t\tif (json.iridescenceIOR !== undefined) material.iridescenceIOR = json.iridescenceIOR;\n\t\tif (json.iridescenceThicknessRange !== undefined) material.iridescenceThicknessRange = json.iridescenceThicknessRange;\n\t\tif (json.transmission !== undefined) material.transmission = json.transmission;\n\t\tif (json.thickness !== undefined) material.thickness = json.thickness;\n\t\tif (json.attenuationDistance !== undefined) material.attenuationDistance = json.attenuationDistance;\n\t\tif (json.attenuationColor !== undefined && material.attenuationColor !== undefined) material.attenuationColor.setHex(json.attenuationColor);\n\t\tif (json.fog !== undefined) material.fog = json.fog;\n\t\tif (json.flatShading !== undefined) material.flatShading = json.flatShading;\n\t\tif (json.blending !== undefined) material.blending = json.blending;\n\t\tif (json.combine !== undefined) material.combine = json.combine;\n\t\tif (json.side !== undefined) material.side = json.side;\n\t\tif (json.shadowSide !== undefined) material.shadowSide = json.shadowSide;\n\t\tif (json.opacity !== undefined) material.opacity = json.opacity;\n\t\tif (json.transparent !== undefined) material.transparent = json.transparent;\n\t\tif (json.alphaTest !== undefined) material.alphaTest = json.alphaTest;\n\t\tif (json.depthTest !== undefined) material.depthTest = json.depthTest;\n\t\tif (json.depthWrite !== undefined) material.depthWrite = json.depthWrite;\n\t\tif (json.colorWrite !== undefined) material.colorWrite = json.colorWrite;\n\t\tif (json.stencilWrite !== undefined) material.stencilWrite = json.stencilWrite;\n\t\tif (json.stencilWriteMask !== undefined) material.stencilWriteMask = json.stencilWriteMask;\n\t\tif (json.stencilFunc !== undefined) material.stencilFunc = json.stencilFunc;\n\t\tif (json.stencilRef !== undefined) material.stencilRef = json.stencilRef;\n\t\tif (json.stencilFuncMask !== undefined) material.stencilFuncMask = json.stencilFuncMask;\n\t\tif (json.stencilFail !== undefined) material.stencilFail = json.stencilFail;\n\t\tif (json.stencilZFail !== undefined) material.stencilZFail = json.stencilZFail;\n\t\tif (json.stencilZPass !== undefined) material.stencilZPass = json.stencilZPass;\n\t\tif (json.wireframe !== undefined) material.wireframe = json.wireframe;\n\t\tif (json.wireframeLinewidth !== undefined) material.wireframeLinewidth = json.wireframeLinewidth;\n\t\tif (json.wireframeLinecap !== undefined) material.wireframeLinecap = json.wireframeLinecap;\n\t\tif (json.wireframeLinejoin !== undefined) material.wireframeLinejoin = json.wireframeLinejoin;\n\t\tif (json.rotation !== undefined) material.rotation = json.rotation;\n\t\tif (json.linewidth !== 1) material.linewidth = json.linewidth;\n\t\tif (json.dashSize !== undefined) material.dashSize = json.dashSize;\n\t\tif (json.gapSize !== undefined) material.gapSize = json.gapSize;\n\t\tif (json.scale !== undefined) material.scale = json.scale;\n\t\tif (json.polygonOffset !== undefined) material.polygonOffset = json.polygonOffset;\n\t\tif (json.polygonOffsetFactor !== undefined) material.polygonOffsetFactor = json.polygonOffsetFactor;\n\t\tif (json.polygonOffsetUnits !== undefined) material.polygonOffsetUnits = json.polygonOffsetUnits;\n\t\tif (json.dithering !== undefined) material.dithering = json.dithering;\n\t\tif (json.alphaToCoverage !== undefined) material.alphaToCoverage = json.alphaToCoverage;\n\t\tif (json.premultipliedAlpha !== undefined) material.premultipliedAlpha = json.premultipliedAlpha;\n\t\tif (json.visible !== undefined) material.visible = json.visible;\n\t\tif (json.toneMapped !== undefined) material.toneMapped = json.toneMapped;\n\t\tif (json.userData !== undefined) material.userData = json.userData;\n\n\t\tif (json.vertexColors !== undefined) {\n\t\t\tif (typeof json.vertexColors === 'number') {\n\t\t\t\tmaterial.vertexColors = json.vertexColors > 0 ? true : false;\n\t\t\t} else {\n\t\t\t\tmaterial.vertexColors = json.vertexColors;\n\t\t\t}\n\t\t} // Shader Material\n\n\n\t\tif (json.uniforms !== undefined) {\n\t\t\tfor (const name in json.uniforms) {\n\t\t\t\tconst uniform = json.uniforms[name];\n\t\t\t\tmaterial.uniforms[name] = {};\n\n\t\t\t\tswitch (uniform.type) {\n\t\t\t\t\tcase 't':\n\t\t\t\t\t\tmaterial.uniforms[name].value = getTexture(uniform.value);\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'c':\n\t\t\t\t\t\tmaterial.uniforms[name].value = new Color().setHex(uniform.value);\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'v2':\n\t\t\t\t\t\tmaterial.uniforms[name].value = new Vector2().fromArray(uniform.value);\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'v3':\n\t\t\t\t\t\tmaterial.uniforms[name].value = new Vector3().fromArray(uniform.value);\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'v4':\n\t\t\t\t\t\tmaterial.uniforms[name].value = new Vector4().fromArray(uniform.value);\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'm3':\n\t\t\t\t\t\tmaterial.uniforms[name].value = new Matrix3().fromArray(uniform.value);\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'm4':\n\t\t\t\t\t\tmaterial.uniforms[name].value = new Matrix4().fromArray(uniform.value);\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tmaterial.uniforms[name].value = uniform.value;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (json.defines !== undefined) material.defines = json.defines;\n\t\tif (json.vertexShader !== undefined) material.vertexShader = json.vertexShader;\n\t\tif (json.fragmentShader !== undefined) material.fragmentShader = json.fragmentShader;\n\n\t\tif (json.extensions !== undefined) {\n\t\t\tfor (const key in json.extensions) {\n\t\t\t\tmaterial.extensions[key] = json.extensions[key];\n\t\t\t}\n\t\t} // Deprecated\n\n\n\t\tif (json.shading !== undefined) material.flatShading = json.shading === 1; // THREE.FlatShading\n\t\t// for PointsMaterial\n\n\t\tif (json.size !== undefined) material.size = json.size;\n\t\tif (json.sizeAttenuation !== undefined) material.sizeAttenuation = json.sizeAttenuation; // maps\n\n\t\tif (json.map !== undefined) material.map = getTexture(json.map);\n\t\tif (json.matcap !== undefined) material.matcap = getTexture(json.matcap);\n\t\tif (json.alphaMap !== undefined) material.alphaMap = getTexture(json.alphaMap);\n\t\tif (json.bumpMap !== undefined) material.bumpMap = getTexture(json.bumpMap);\n\t\tif (json.bumpScale !== undefined) material.bumpScale = json.bumpScale;\n\t\tif (json.normalMap !== undefined) material.normalMap = getTexture(json.normalMap);\n\t\tif (json.normalMapType !== undefined) material.normalMapType = json.normalMapType;\n\n\t\tif (json.normalScale !== undefined) {\n\t\t\tlet normalScale = json.normalScale;\n\n\t\t\tif (Array.isArray(normalScale) === false) {\n\t\t\t\t// Blender exporter used to export a scalar. See #7459\n\t\t\t\tnormalScale = [normalScale, normalScale];\n\t\t\t}\n\n\t\t\tmaterial.normalScale = new Vector2().fromArray(normalScale);\n\t\t}\n\n\t\tif (json.displacementMap !== undefined) material.displacementMap = getTexture(json.displacementMap);\n\t\tif (json.displacementScale !== undefined) material.displacementScale = json.displacementScale;\n\t\tif (json.displacementBias !== undefined) material.displacementBias = json.displacementBias;\n\t\tif (json.roughnessMap !== undefined) material.roughnessMap = getTexture(json.roughnessMap);\n\t\tif (json.metalnessMap !== undefined) material.metalnessMap = getTexture(json.metalnessMap);\n\t\tif (json.emissiveMap !== undefined) material.emissiveMap = getTexture(json.emissiveMap);\n\t\tif (json.emissiveIntensity !== undefined) material.emissiveIntensity = json.emissiveIntensity;\n\t\tif (json.specularMap !== undefined) material.specularMap = getTexture(json.specularMap);\n\t\tif (json.specularIntensityMap !== undefined) material.specularIntensityMap = getTexture(json.specularIntensityMap);\n\t\tif (json.specularColorMap !== undefined) material.specularColorMap = getTexture(json.specularColorMap);\n\t\tif (json.envMap !== undefined) material.envMap = getTexture(json.envMap);\n\t\tif (json.envMapIntensity !== undefined) material.envMapIntensity = json.envMapIntensity;\n\t\tif (json.reflectivity !== undefined) material.reflectivity = json.reflectivity;\n\t\tif (json.refractionRatio !== undefined) material.refractionRatio = json.refractionRatio;\n\t\tif (json.lightMap !== undefined) material.lightMap = getTexture(json.lightMap);\n\t\tif (json.lightMapIntensity !== undefined) material.lightMapIntensity = json.lightMapIntensity;\n\t\tif (json.aoMap !== undefined) material.aoMap = getTexture(json.aoMap);\n\t\tif (json.aoMapIntensity !== undefined) material.aoMapIntensity = json.aoMapIntensity;\n\t\tif (json.gradientMap !== undefined) material.gradientMap = getTexture(json.gradientMap);\n\t\tif (json.clearcoatMap !== undefined) material.clearcoatMap = getTexture(json.clearcoatMap);\n\t\tif (json.clearcoatRoughnessMap !== undefined) material.clearcoatRoughnessMap = getTexture(json.clearcoatRoughnessMap);\n\t\tif (json.clearcoatNormalMap !== undefined) material.clearcoatNormalMap = getTexture(json.clearcoatNormalMap);\n\t\tif (json.clearcoatNormalScale !== undefined) material.clearcoatNormalScale = new Vector2().fromArray(json.clearcoatNormalScale);\n\t\tif (json.iridescenceMap !== undefined) material.iridescenceMap = getTexture(json.iridescenceMap);\n\t\tif (json.iridescenceThicknessMap !== undefined) material.iridescenceThicknessMap = getTexture(json.iridescenceThicknessMap);\n\t\tif (json.transmissionMap !== undefined) material.transmissionMap = getTexture(json.transmissionMap);\n\t\tif (json.thicknessMap !== undefined) material.thicknessMap = getTexture(json.thicknessMap);\n\t\tif (json.sheenColorMap !== undefined) material.sheenColorMap = getTexture(json.sheenColorMap);\n\t\tif (json.sheenRoughnessMap !== undefined) material.sheenRoughnessMap = getTexture(json.sheenRoughnessMap);\n\t\treturn material;\n\t}\n\n\tsetTextures(value) {\n\t\tthis.textures = value;\n\t\treturn this;\n\t}\n\n}\n\nclass LoaderUtils {\n\tstatic decodeText(array) {\n\t\tif (typeof TextDecoder !== 'undefined') {\n\t\t\treturn new TextDecoder().decode(array);\n\t\t} // Avoid the String.fromCharCode.apply(null, array) shortcut, which\n\t\t// throws a \"maximum call stack size exceeded\" error for large arrays.\n\n\n\t\tlet s = '';\n\n\t\tfor (let i = 0, il = array.length; i < il; i++) {\n\t\t\t// Implicitly assumes little-endian.\n\t\t\ts += String.fromCharCode(array[i]);\n\t\t}\n\n\t\ttry {\n\t\t\t// merges multi-byte utf-8 characters.\n\t\t\treturn decodeURIComponent(escape(s));\n\t\t} catch (e) {\n\t\t\t// see #16358\n\t\t\treturn s;\n\t\t}\n\t}\n\n\tstatic extractUrlBase(url) {\n\t\tconst index = url.lastIndexOf('/');\n\t\tif (index === -1) return './';\n\t\treturn url.slice(0, index + 1);\n\t}\n\n\tstatic resolveURL(url, path) {\n\t\t// Invalid URL\n\t\tif (typeof url !== 'string' || url === '') return ''; // Host Relative URL\n\n\t\tif (/^https?:\\/\\//i.test(path) && /^\\//.test(url)) {\n\t\t\tpath = path.replace(/(^https?:\\/\\/[^\\/]+).*/i, '$1');\n\t\t} // Absolute URL http://,https://,//\n\n\n\t\tif (/^(https?:)?\\/\\//i.test(url)) return url; // Data URI\n\n\t\tif (/^data:.*,.*$/i.test(url)) return url; // Blob URL\n\n\t\tif (/^blob:.*$/i.test(url)) return url; // Relative URL\n\n\t\treturn path + url;\n\t}\n\n}\n\nclass InstancedBufferGeometry extends BufferGeometry {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.isInstancedBufferGeometry = true;\n\t\tthis.type = 'InstancedBufferGeometry';\n\t\tthis.instanceCount = Infinity;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.instanceCount = source.instanceCount;\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n\ttoJSON() {\n\t\tconst data = super.toJSON(this);\n\t\tdata.instanceCount = this.instanceCount;\n\t\tdata.isInstancedBufferGeometry = true;\n\t\treturn data;\n\t}\n\n}\n\nclass BufferGeometryLoader extends Loader {\n\tconstructor(manager) {\n\t\tsuper(manager);\n\t}\n\n\tload(url, onLoad, onProgress, onError) {\n\t\tconst scope = this;\n\t\tconst loader = new FileLoader(scope.manager);\n\t\tloader.setPath(scope.path);\n\t\tloader.setRequestHeader(scope.requestHeader);\n\t\tloader.setWithCredentials(scope.withCredentials);\n\t\tloader.load(url, function (text) {\n\t\t\ttry {\n\t\t\t\tonLoad(scope.parse(JSON.parse(text)));\n\t\t\t} catch (e) {\n\t\t\t\tif (onError) {\n\t\t\t\t\tonError(e);\n\t\t\t\t} else {\n\t\t\t\t\tconsole.error(e);\n\t\t\t\t}\n\n\t\t\t\tscope.manager.itemError(url);\n\t\t\t}\n\t\t}, onProgress, onError);\n\t}\n\n\tparse(json) {\n\t\tconst interleavedBufferMap = {};\n\t\tconst arrayBufferMap = {};\n\n\t\tfunction getInterleavedBuffer(json, uuid) {\n\t\t\tif (interleavedBufferMap[uuid] !== undefined) return interleavedBufferMap[uuid];\n\t\t\tconst interleavedBuffers = json.interleavedBuffers;\n\t\t\tconst interleavedBuffer = interleavedBuffers[uuid];\n\t\t\tconst buffer = getArrayBuffer(json, interleavedBuffer.buffer);\n\t\t\tconst array = getTypedArray(interleavedBuffer.type, buffer);\n\t\t\tconst ib = new InterleavedBuffer(array, interleavedBuffer.stride);\n\t\t\tib.uuid = interleavedBuffer.uuid;\n\t\t\tinterleavedBufferMap[uuid] = ib;\n\t\t\treturn ib;\n\t\t}\n\n\t\tfunction getArrayBuffer(json, uuid) {\n\t\t\tif (arrayBufferMap[uuid] !== undefined) return arrayBufferMap[uuid];\n\t\t\tconst arrayBuffers = json.arrayBuffers;\n\t\t\tconst arrayBuffer = arrayBuffers[uuid];\n\t\t\tconst ab = new Uint32Array(arrayBuffer).buffer;\n\t\t\tarrayBufferMap[uuid] = ab;\n\t\t\treturn ab;\n\t\t}\n\n\t\tconst geometry = json.isInstancedBufferGeometry ? new InstancedBufferGeometry() : new BufferGeometry();\n\t\tconst index = json.data.index;\n\n\t\tif (index !== undefined) {\n\t\t\tconst typedArray = getTypedArray(index.type, index.array);\n\t\t\tgeometry.setIndex(new BufferAttribute(typedArray, 1));\n\t\t}\n\n\t\tconst attributes = json.data.attributes;\n\n\t\tfor (const key in attributes) {\n\t\t\tconst attribute = attributes[key];\n\t\t\tlet bufferAttribute;\n\n\t\t\tif (attribute.isInterleavedBufferAttribute) {\n\t\t\t\tconst interleavedBuffer = getInterleavedBuffer(json.data, attribute.data);\n\t\t\t\tbufferAttribute = new InterleavedBufferAttribute(interleavedBuffer, attribute.itemSize, attribute.offset, attribute.normalized);\n\t\t\t} else {\n\t\t\t\tconst typedArray = getTypedArray(attribute.type, attribute.array);\n\t\t\t\tconst bufferAttributeConstr = attribute.isInstancedBufferAttribute ? InstancedBufferAttribute : BufferAttribute;\n\t\t\t\tbufferAttribute = new bufferAttributeConstr(typedArray, attribute.itemSize, attribute.normalized);\n\t\t\t}\n\n\t\t\tif (attribute.name !== undefined) bufferAttribute.name = attribute.name;\n\t\t\tif (attribute.usage !== undefined) bufferAttribute.setUsage(attribute.usage);\n\n\t\t\tif (attribute.updateRange !== undefined) {\n\t\t\t\tbufferAttribute.updateRange.offset = attribute.updateRange.offset;\n\t\t\t\tbufferAttribute.updateRange.count = attribute.updateRange.count;\n\t\t\t}\n\n\t\t\tgeometry.setAttribute(key, bufferAttribute);\n\t\t}\n\n\t\tconst morphAttributes = json.data.morphAttributes;\n\n\t\tif (morphAttributes) {\n\t\t\tfor (const key in morphAttributes) {\n\t\t\t\tconst attributeArray = morphAttributes[key];\n\t\t\t\tconst array = [];\n\n\t\t\t\tfor (let i = 0, il = attributeArray.length; i < il; i++) {\n\t\t\t\t\tconst attribute = attributeArray[i];\n\t\t\t\t\tlet bufferAttribute;\n\n\t\t\t\t\tif (attribute.isInterleavedBufferAttribute) {\n\t\t\t\t\t\tconst interleavedBuffer = getInterleavedBuffer(json.data, attribute.data);\n\t\t\t\t\t\tbufferAttribute = new InterleavedBufferAttribute(interleavedBuffer, attribute.itemSize, attribute.offset, attribute.normalized);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tconst typedArray = getTypedArray(attribute.type, attribute.array);\n\t\t\t\t\t\tbufferAttribute = new BufferAttribute(typedArray, attribute.itemSize, attribute.normalized);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (attribute.name !== undefined) bufferAttribute.name = attribute.name;\n\t\t\t\t\tarray.push(bufferAttribute);\n\t\t\t\t}\n\n\t\t\t\tgeometry.morphAttributes[key] = array;\n\t\t\t}\n\t\t}\n\n\t\tconst morphTargetsRelative = json.data.morphTargetsRelative;\n\n\t\tif (morphTargetsRelative) {\n\t\t\tgeometry.morphTargetsRelative = true;\n\t\t}\n\n\t\tconst groups = json.data.groups || json.data.drawcalls || json.data.offsets;\n\n\t\tif (groups !== undefined) {\n\t\t\tfor (let i = 0, n = groups.length; i !== n; ++i) {\n\t\t\t\tconst group = groups[i];\n\t\t\t\tgeometry.addGroup(group.start, group.count, group.materialIndex);\n\t\t\t}\n\t\t}\n\n\t\tconst boundingSphere = json.data.boundingSphere;\n\n\t\tif (boundingSphere !== undefined) {\n\t\t\tconst center = new Vector3();\n\n\t\t\tif (boundingSphere.center !== undefined) {\n\t\t\t\tcenter.fromArray(boundingSphere.center);\n\t\t\t}\n\n\t\t\tgeometry.boundingSphere = new Sphere(center, boundingSphere.radius);\n\t\t}\n\n\t\tif (json.name) geometry.name = json.name;\n\t\tif (json.userData) geometry.userData = json.userData;\n\t\treturn geometry;\n\t}\n\n}\n\nclass ObjectLoader extends Loader {\n\tconstructor(manager) {\n\t\tsuper(manager);\n\t}\n\n\tload(url, onLoad, onProgress, onError) {\n\t\tconst scope = this;\n\t\tconst path = this.path === '' ? LoaderUtils.extractUrlBase(url) : this.path;\n\t\tthis.resourcePath = this.resourcePath || path;\n\t\tconst loader = new FileLoader(this.manager);\n\t\tloader.setPath(this.path);\n\t\tloader.setRequestHeader(this.requestHeader);\n\t\tloader.setWithCredentials(this.withCredentials);\n\t\tloader.load(url, function (text) {\n\t\t\tlet json = null;\n\n\t\t\ttry {\n\t\t\t\tjson = JSON.parse(text);\n\t\t\t} catch (error) {\n\t\t\t\tif (onError !== undefined) onError(error);\n\t\t\t\tconsole.error('THREE:ObjectLoader: Can\\'t parse ' + url + '.', error.message);\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst metadata = json.metadata;\n\n\t\t\tif (metadata === undefined || metadata.type === undefined || metadata.type.toLowerCase() === 'geometry') {\n\t\t\t\tconsole.error('THREE.ObjectLoader: Can\\'t load ' + url);\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tscope.parse(json, onLoad);\n\t\t}, onProgress, onError);\n\t}\n\n\tasync loadAsync(url, onProgress) {\n\t\tconst scope = this;\n\t\tconst path = this.path === '' ? LoaderUtils.extractUrlBase(url) : this.path;\n\t\tthis.resourcePath = this.resourcePath || path;\n\t\tconst loader = new FileLoader(this.manager);\n\t\tloader.setPath(this.path);\n\t\tloader.setRequestHeader(this.requestHeader);\n\t\tloader.setWithCredentials(this.withCredentials);\n\t\tconst text = await loader.loadAsync(url, onProgress);\n\t\tconst json = JSON.parse(text);\n\t\tconst metadata = json.metadata;\n\n\t\tif (metadata === undefined || metadata.type === undefined || metadata.type.toLowerCase() === 'geometry') {\n\t\t\tthrow new Error('THREE.ObjectLoader: Can\\'t load ' + url);\n\t\t}\n\n\t\treturn await scope.parseAsync(json);\n\t}\n\n\tparse(json, onLoad) {\n\t\tconst animations = this.parseAnimations(json.animations);\n\t\tconst shapes = this.parseShapes(json.shapes);\n\t\tconst geometries = this.parseGeometries(json.geometries, shapes);\n\t\tconst images = this.parseImages(json.images, function () {\n\t\t\tif (onLoad !== undefined) onLoad(object);\n\t\t});\n\t\tconst textures = this.parseTextures(json.textures, images);\n\t\tconst materials = this.parseMaterials(json.materials, textures);\n\t\tconst object = this.parseObject(json.object, geometries, materials, textures, animations);\n\t\tconst skeletons = this.parseSkeletons(json.skeletons, object);\n\t\tthis.bindSkeletons(object, skeletons); //\n\n\t\tif (onLoad !== undefined) {\n\t\t\tlet hasImages = false;\n\n\t\t\tfor (const uuid in images) {\n\t\t\t\tif (images[uuid].data instanceof HTMLImageElement) {\n\t\t\t\t\thasImages = true;\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (hasImages === false) onLoad(object);\n\t\t}\n\n\t\treturn object;\n\t}\n\n\tasync parseAsync(json) {\n\t\tconst animations = this.parseAnimations(json.animations);\n\t\tconst shapes = this.parseShapes(json.shapes);\n\t\tconst geometries = this.parseGeometries(json.geometries, shapes);\n\t\tconst images = await this.parseImagesAsync(json.images);\n\t\tconst textures = this.parseTextures(json.textures, images);\n\t\tconst materials = this.parseMaterials(json.materials, textures);\n\t\tconst object = this.parseObject(json.object, geometries, materials, textures, animations);\n\t\tconst skeletons = this.parseSkeletons(json.skeletons, object);\n\t\tthis.bindSkeletons(object, skeletons);\n\t\treturn object;\n\t}\n\n\tparseShapes(json) {\n\t\tconst shapes = {};\n\n\t\tif (json !== undefined) {\n\t\t\tfor (let i = 0, l = json.length; i < l; i++) {\n\t\t\t\tconst shape = new Shape().fromJSON(json[i]);\n\t\t\t\tshapes[shape.uuid] = shape;\n\t\t\t}\n\t\t}\n\n\t\treturn shapes;\n\t}\n\n\tparseSkeletons(json, object) {\n\t\tconst skeletons = {};\n\t\tconst bones = {}; // generate bone lookup table\n\n\t\tobject.traverse(function (child) {\n\t\t\tif (child.isBone) bones[child.uuid] = child;\n\t\t}); // create skeletons\n\n\t\tif (json !== undefined) {\n\t\t\tfor (let i = 0, l = json.length; i < l; i++) {\n\t\t\t\tconst skeleton = new Skeleton().fromJSON(json[i], bones);\n\t\t\t\tskeletons[skeleton.uuid] = skeleton;\n\t\t\t}\n\t\t}\n\n\t\treturn skeletons;\n\t}\n\n\tparseGeometries(json, shapes) {\n\t\tconst geometries = {};\n\n\t\tif (json !== undefined) {\n\t\t\tconst bufferGeometryLoader = new BufferGeometryLoader();\n\n\t\t\tfor (let i = 0, l = json.length; i < l; i++) {\n\t\t\t\tlet geometry;\n\t\t\t\tconst data = json[i];\n\n\t\t\t\tswitch (data.type) {\n\t\t\t\t\tcase 'BufferGeometry':\n\t\t\t\t\tcase 'InstancedBufferGeometry':\n\t\t\t\t\t\tgeometry = bufferGeometryLoader.parse(data);\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'Geometry':\n\t\t\t\t\t\tconsole.error('THREE.ObjectLoader: The legacy Geometry type is no longer supported.');\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tif (data.type in Geometries) {\n\t\t\t\t\t\t\tgeometry = Geometries[data.type].fromJSON(data, shapes);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tconsole.warn(`THREE.ObjectLoader: Unsupported geometry type \"${data.type}\"`);\n\t\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tgeometry.uuid = data.uuid;\n\t\t\t\tif (data.name !== undefined) geometry.name = data.name;\n\t\t\t\tif (geometry.isBufferGeometry === true && data.userData !== undefined) geometry.userData = data.userData;\n\t\t\t\tgeometries[data.uuid] = geometry;\n\t\t\t}\n\t\t}\n\n\t\treturn geometries;\n\t}\n\n\tparseMaterials(json, textures) {\n\t\tconst cache = {}; // MultiMaterial\n\n\t\tconst materials = {};\n\n\t\tif (json !== undefined) {\n\t\t\tconst loader = new MaterialLoader();\n\t\t\tloader.setTextures(textures);\n\n\t\t\tfor (let i = 0, l = json.length; i < l; i++) {\n\t\t\t\tconst data = json[i];\n\n\t\t\t\tif (data.type === 'MultiMaterial') {\n\t\t\t\t\t// Deprecated\n\t\t\t\t\tconst array = [];\n\n\t\t\t\t\tfor (let j = 0; j < data.materials.length; j++) {\n\t\t\t\t\t\tconst material = data.materials[j];\n\n\t\t\t\t\t\tif (cache[material.uuid] === undefined) {\n\t\t\t\t\t\t\tcache[material.uuid] = loader.parse(material);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tarray.push(cache[material.uuid]);\n\t\t\t\t\t}\n\n\t\t\t\t\tmaterials[data.uuid] = array;\n\t\t\t\t} else {\n\t\t\t\t\tif (cache[data.uuid] === undefined) {\n\t\t\t\t\t\tcache[data.uuid] = loader.parse(data);\n\t\t\t\t\t}\n\n\t\t\t\t\tmaterials[data.uuid] = cache[data.uuid];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn materials;\n\t}\n\n\tparseAnimations(json) {\n\t\tconst animations = {};\n\n\t\tif (json !== undefined) {\n\t\t\tfor (let i = 0; i < json.length; i++) {\n\t\t\t\tconst data = json[i];\n\t\t\t\tconst clip = AnimationClip.parse(data);\n\t\t\t\tanimations[clip.uuid] = clip;\n\t\t\t}\n\t\t}\n\n\t\treturn animations;\n\t}\n\n\tparseImages(json, onLoad) {\n\t\tconst scope = this;\n\t\tconst images = {};\n\t\tlet loader;\n\n\t\tfunction loadImage(url) {\n\t\t\tscope.manager.itemStart(url);\n\t\t\treturn loader.load(url, function () {\n\t\t\t\tscope.manager.itemEnd(url);\n\t\t\t}, undefined, function () {\n\t\t\t\tscope.manager.itemError(url);\n\t\t\t\tscope.manager.itemEnd(url);\n\t\t\t});\n\t\t}\n\n\t\tfunction deserializeImage(image) {\n\t\t\tif (typeof image === 'string') {\n\t\t\t\tconst url = image;\n\t\t\t\tconst path = /^(\\/\\/)|([a-z]+:(\\/\\/)?)/i.test(url) ? url : scope.resourcePath + url;\n\t\t\t\treturn loadImage(path);\n\t\t\t} else {\n\t\t\t\tif (image.data) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tdata: getTypedArray(image.type, image.data),\n\t\t\t\t\t\twidth: image.width,\n\t\t\t\t\t\theight: image.height\n\t\t\t\t\t};\n\t\t\t\t} else {\n\t\t\t\t\treturn null;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (json !== undefined && json.length > 0) {\n\t\t\tconst manager = new LoadingManager(onLoad);\n\t\t\tloader = new ImageLoader(manager);\n\t\t\tloader.setCrossOrigin(this.crossOrigin);\n\n\t\t\tfor (let i = 0, il = json.length; i < il; i++) {\n\t\t\t\tconst image = json[i];\n\t\t\t\tconst url = image.url;\n\n\t\t\t\tif (Array.isArray(url)) {\n\t\t\t\t\t// load array of images e.g CubeTexture\n\t\t\t\t\tconst imageArray = [];\n\n\t\t\t\t\tfor (let j = 0, jl = url.length; j < jl; j++) {\n\t\t\t\t\t\tconst currentUrl = url[j];\n\t\t\t\t\t\tconst deserializedImage = deserializeImage(currentUrl);\n\n\t\t\t\t\t\tif (deserializedImage !== null) {\n\t\t\t\t\t\t\tif (deserializedImage instanceof HTMLImageElement) {\n\t\t\t\t\t\t\t\timageArray.push(deserializedImage);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t// special case: handle array of data textures for cube textures\n\t\t\t\t\t\t\t\timageArray.push(new DataTexture(deserializedImage.data, deserializedImage.width, deserializedImage.height));\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\timages[image.uuid] = new Source(imageArray);\n\t\t\t\t} else {\n\t\t\t\t\t// load single image\n\t\t\t\t\tconst deserializedImage = deserializeImage(image.url);\n\t\t\t\t\timages[image.uuid] = new Source(deserializedImage);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn images;\n\t}\n\n\tasync parseImagesAsync(json) {\n\t\tconst scope = this;\n\t\tconst images = {};\n\t\tlet loader;\n\n\t\tasync function deserializeImage(image) {\n\t\t\tif (typeof image === 'string') {\n\t\t\t\tconst url = image;\n\t\t\t\tconst path = /^(\\/\\/)|([a-z]+:(\\/\\/)?)/i.test(url) ? url : scope.resourcePath + url;\n\t\t\t\treturn await loader.loadAsync(path);\n\t\t\t} else {\n\t\t\t\tif (image.data) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tdata: getTypedArray(image.type, image.data),\n\t\t\t\t\t\twidth: image.width,\n\t\t\t\t\t\theight: image.height\n\t\t\t\t\t};\n\t\t\t\t} else {\n\t\t\t\t\treturn null;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (json !== undefined && json.length > 0) {\n\t\t\tloader = new ImageLoader(this.manager);\n\t\t\tloader.setCrossOrigin(this.crossOrigin);\n\n\t\t\tfor (let i = 0, il = json.length; i < il; i++) {\n\t\t\t\tconst image = json[i];\n\t\t\t\tconst url = image.url;\n\n\t\t\t\tif (Array.isArray(url)) {\n\t\t\t\t\t// load array of images e.g CubeTexture\n\t\t\t\t\tconst imageArray = [];\n\n\t\t\t\t\tfor (let j = 0, jl = url.length; j < jl; j++) {\n\t\t\t\t\t\tconst currentUrl = url[j];\n\t\t\t\t\t\tconst deserializedImage = await deserializeImage(currentUrl);\n\n\t\t\t\t\t\tif (deserializedImage !== null) {\n\t\t\t\t\t\t\tif (deserializedImage instanceof HTMLImageElement) {\n\t\t\t\t\t\t\t\timageArray.push(deserializedImage);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t// special case: handle array of data textures for cube textures\n\t\t\t\t\t\t\t\timageArray.push(new DataTexture(deserializedImage.data, deserializedImage.width, deserializedImage.height));\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\timages[image.uuid] = new Source(imageArray);\n\t\t\t\t} else {\n\t\t\t\t\t// load single image\n\t\t\t\t\tconst deserializedImage = await deserializeImage(image.url);\n\t\t\t\t\timages[image.uuid] = new Source(deserializedImage);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn images;\n\t}\n\n\tparseTextures(json, images) {\n\t\tfunction parseConstant(value, type) {\n\t\t\tif (typeof value === 'number') return value;\n\t\t\tconsole.warn('THREE.ObjectLoader.parseTexture: Constant should be in numeric form.', value);\n\t\t\treturn type[value];\n\t\t}\n\n\t\tconst textures = {};\n\n\t\tif (json !== undefined) {\n\t\t\tfor (let i = 0, l = json.length; i < l; i++) {\n\t\t\t\tconst data = json[i];\n\n\t\t\t\tif (data.image === undefined) {\n\t\t\t\t\tconsole.warn('THREE.ObjectLoader: No \"image\" specified for', data.uuid);\n\t\t\t\t}\n\n\t\t\t\tif (images[data.image] === undefined) {\n\t\t\t\t\tconsole.warn('THREE.ObjectLoader: Undefined image', data.image);\n\t\t\t\t}\n\n\t\t\t\tconst source = images[data.image];\n\t\t\t\tconst image = source.data;\n\t\t\t\tlet texture;\n\n\t\t\t\tif (Array.isArray(image)) {\n\t\t\t\t\ttexture = new CubeTexture();\n\t\t\t\t\tif (image.length === 6) texture.needsUpdate = true;\n\t\t\t\t} else {\n\t\t\t\t\tif (image && image.data) {\n\t\t\t\t\t\ttexture = new DataTexture();\n\t\t\t\t\t} else {\n\t\t\t\t\t\ttexture = new Texture();\n\t\t\t\t\t}\n\n\t\t\t\t\tif (image) texture.needsUpdate = true; // textures can have undefined image data\n\t\t\t\t}\n\n\t\t\t\ttexture.source = source;\n\t\t\t\ttexture.uuid = data.uuid;\n\t\t\t\tif (data.name !== undefined) texture.name = data.name;\n\t\t\t\tif (data.mapping !== undefined) texture.mapping = parseConstant(data.mapping, TEXTURE_MAPPING);\n\t\t\t\tif (data.offset !== undefined) texture.offset.fromArray(data.offset);\n\t\t\t\tif (data.repeat !== undefined) texture.repeat.fromArray(data.repeat);\n\t\t\t\tif (data.center !== undefined) texture.center.fromArray(data.center);\n\t\t\t\tif (data.rotation !== undefined) texture.rotation = data.rotation;\n\n\t\t\t\tif (data.wrap !== undefined) {\n\t\t\t\t\ttexture.wrapS = parseConstant(data.wrap[0], TEXTURE_WRAPPING);\n\t\t\t\t\ttexture.wrapT = parseConstant(data.wrap[1], TEXTURE_WRAPPING);\n\t\t\t\t}\n\n\t\t\t\tif (data.format !== undefined) texture.format = data.format;\n\t\t\t\tif (data.type !== undefined) texture.type = data.type;\n\t\t\t\tif (data.encoding !== undefined) texture.encoding = data.encoding;\n\t\t\t\tif (data.minFilter !== undefined) texture.minFilter = parseConstant(data.minFilter, TEXTURE_FILTER);\n\t\t\t\tif (data.magFilter !== undefined) texture.magFilter = parseConstant(data.magFilter, TEXTURE_FILTER);\n\t\t\t\tif (data.anisotropy !== undefined) texture.anisotropy = data.anisotropy;\n\t\t\t\tif (data.flipY !== undefined) texture.flipY = data.flipY;\n\t\t\t\tif (data.premultiplyAlpha !== undefined) texture.premultiplyAlpha = data.premultiplyAlpha;\n\t\t\t\tif (data.unpackAlignment !== undefined) texture.unpackAlignment = data.unpackAlignment;\n\t\t\t\tif (data.userData !== undefined) texture.userData = data.userData;\n\t\t\t\ttextures[data.uuid] = texture;\n\t\t\t}\n\t\t}\n\n\t\treturn textures;\n\t}\n\n\tparseObject(data, geometries, materials, textures, animations) {\n\t\tlet object;\n\n\t\tfunction getGeometry(name) {\n\t\t\tif (geometries[name] === undefined) {\n\t\t\t\tconsole.warn('THREE.ObjectLoader: Undefined geometry', name);\n\t\t\t}\n\n\t\t\treturn geometries[name];\n\t\t}\n\n\t\tfunction getMaterial(name) {\n\t\t\tif (name === undefined) return undefined;\n\n\t\t\tif (Array.isArray(name)) {\n\t\t\t\tconst array = [];\n\n\t\t\t\tfor (let i = 0, l = name.length; i < l; i++) {\n\t\t\t\t\tconst uuid = name[i];\n\n\t\t\t\t\tif (materials[uuid] === undefined) {\n\t\t\t\t\t\tconsole.warn('THREE.ObjectLoader: Undefined material', uuid);\n\t\t\t\t\t}\n\n\t\t\t\t\tarray.push(materials[uuid]);\n\t\t\t\t}\n\n\t\t\t\treturn array;\n\t\t\t}\n\n\t\t\tif (materials[name] === undefined) {\n\t\t\t\tconsole.warn('THREE.ObjectLoader: Undefined material', name);\n\t\t\t}\n\n\t\t\treturn materials[name];\n\t\t}\n\n\t\tfunction getTexture(uuid) {\n\t\t\tif (textures[uuid] === undefined) {\n\t\t\t\tconsole.warn('THREE.ObjectLoader: Undefined texture', uuid);\n\t\t\t}\n\n\t\t\treturn textures[uuid];\n\t\t}\n\n\t\tlet geometry, material;\n\n\t\tswitch (data.type) {\n\t\t\tcase 'Scene':\n\t\t\t\tobject = new Scene();\n\n\t\t\t\tif (data.background !== undefined) {\n\t\t\t\t\tif (Number.isInteger(data.background)) {\n\t\t\t\t\t\tobject.background = new Color(data.background);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tobject.background = getTexture(data.background);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (data.environment !== undefined) {\n\t\t\t\t\tobject.environment = getTexture(data.environment);\n\t\t\t\t}\n\n\t\t\t\tif (data.fog !== undefined) {\n\t\t\t\t\tif (data.fog.type === 'Fog') {\n\t\t\t\t\t\tobject.fog = new Fog(data.fog.color, data.fog.near, data.fog.far);\n\t\t\t\t\t} else if (data.fog.type === 'FogExp2') {\n\t\t\t\t\t\tobject.fog = new FogExp2(data.fog.color, data.fog.density);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'PerspectiveCamera':\n\t\t\t\tobject = new PerspectiveCamera(data.fov, data.aspect, data.near, data.far);\n\t\t\t\tif (data.focus !== undefined) object.focus = data.focus;\n\t\t\t\tif (data.zoom !== undefined) object.zoom = data.zoom;\n\t\t\t\tif (data.filmGauge !== undefined) object.filmGauge = data.filmGauge;\n\t\t\t\tif (data.filmOffset !== undefined) object.filmOffset = data.filmOffset;\n\t\t\t\tif (data.view !== undefined) object.view = Object.assign({}, data.view);\n\t\t\t\tbreak;\n\n\t\t\tcase 'OrthographicCamera':\n\t\t\t\tobject = new OrthographicCamera(data.left, data.right, data.top, data.bottom, data.near, data.far);\n\t\t\t\tif (data.zoom !== undefined) object.zoom = data.zoom;\n\t\t\t\tif (data.view !== undefined) object.view = Object.assign({}, data.view);\n\t\t\t\tbreak;\n\n\t\t\tcase 'AmbientLight':\n\t\t\t\tobject = new AmbientLight(data.color, data.intensity);\n\t\t\t\tbreak;\n\n\t\t\tcase 'DirectionalLight':\n\t\t\t\tobject = new DirectionalLight(data.color, data.intensity);\n\t\t\t\tbreak;\n\n\t\t\tcase 'PointLight':\n\t\t\t\tobject = new PointLight(data.color, data.intensity, data.distance, data.decay);\n\t\t\t\tbreak;\n\n\t\t\tcase 'RectAreaLight':\n\t\t\t\tobject = new RectAreaLight(data.color, data.intensity, data.width, data.height);\n\t\t\t\tbreak;\n\n\t\t\tcase 'SpotLight':\n\t\t\t\tobject = new SpotLight(data.color, data.intensity, data.distance, data.angle, data.penumbra, data.decay);\n\t\t\t\tbreak;\n\n\t\t\tcase 'HemisphereLight':\n\t\t\t\tobject = new HemisphereLight(data.color, data.groundColor, data.intensity);\n\t\t\t\tbreak;\n\n\t\t\tcase 'LightProbe':\n\t\t\t\tobject = new LightProbe().fromJSON(data);\n\t\t\t\tbreak;\n\n\t\t\tcase 'SkinnedMesh':\n\t\t\t\tgeometry = getGeometry(data.geometry);\n\t\t\t\tmaterial = getMaterial(data.material);\n\t\t\t\tobject = new SkinnedMesh(geometry, material);\n\t\t\t\tif (data.bindMode !== undefined) object.bindMode = data.bindMode;\n\t\t\t\tif (data.bindMatrix !== undefined) object.bindMatrix.fromArray(data.bindMatrix);\n\t\t\t\tif (data.skeleton !== undefined) object.skeleton = data.skeleton;\n\t\t\t\tbreak;\n\n\t\t\tcase 'Mesh':\n\t\t\t\tgeometry = getGeometry(data.geometry);\n\t\t\t\tmaterial = getMaterial(data.material);\n\t\t\t\tobject = new Mesh(geometry, material);\n\t\t\t\tbreak;\n\n\t\t\tcase 'InstancedMesh':\n\t\t\t\tgeometry = getGeometry(data.geometry);\n\t\t\t\tmaterial = getMaterial(data.material);\n\t\t\t\tconst count = data.count;\n\t\t\t\tconst instanceMatrix = data.instanceMatrix;\n\t\t\t\tconst instanceColor = data.instanceColor;\n\t\t\t\tobject = new InstancedMesh(geometry, material, count);\n\t\t\t\tobject.instanceMatrix = new InstancedBufferAttribute(new Float32Array(instanceMatrix.array), 16);\n\t\t\t\tif (instanceColor !== undefined) object.instanceColor = new InstancedBufferAttribute(new Float32Array(instanceColor.array), instanceColor.itemSize);\n\t\t\t\tbreak;\n\n\t\t\tcase 'LOD':\n\t\t\t\tobject = new LOD();\n\t\t\t\tbreak;\n\n\t\t\tcase 'Line':\n\t\t\t\tobject = new Line(getGeometry(data.geometry), getMaterial(data.material));\n\t\t\t\tbreak;\n\n\t\t\tcase 'LineLoop':\n\t\t\t\tobject = new LineLoop(getGeometry(data.geometry), getMaterial(data.material));\n\t\t\t\tbreak;\n\n\t\t\tcase 'LineSegments':\n\t\t\t\tobject = new LineSegments(getGeometry(data.geometry), getMaterial(data.material));\n\t\t\t\tbreak;\n\n\t\t\tcase 'PointCloud':\n\t\t\tcase 'Points':\n\t\t\t\tobject = new Points(getGeometry(data.geometry), getMaterial(data.material));\n\t\t\t\tbreak;\n\n\t\t\tcase 'Sprite':\n\t\t\t\tobject = new Sprite(getMaterial(data.material));\n\t\t\t\tbreak;\n\n\t\t\tcase 'Group':\n\t\t\t\tobject = new Group();\n\t\t\t\tbreak;\n\n\t\t\tcase 'Bone':\n\t\t\t\tobject = new Bone();\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tobject = new Object3D();\n\t\t}\n\n\t\tobject.uuid = data.uuid;\n\t\tif (data.name !== undefined) object.name = data.name;\n\n\t\tif (data.matrix !== undefined) {\n\t\t\tobject.matrix.fromArray(data.matrix);\n\t\t\tif (data.matrixAutoUpdate !== undefined) object.matrixAutoUpdate = data.matrixAutoUpdate;\n\t\t\tif (object.matrixAutoUpdate) object.matrix.decompose(object.position, object.quaternion, object.scale);\n\t\t} else {\n\t\t\tif (data.position !== undefined) object.position.fromArray(data.position);\n\t\t\tif (data.rotation !== undefined) object.rotation.fromArray(data.rotation);\n\t\t\tif (data.quaternion !== undefined) object.quaternion.fromArray(data.quaternion);\n\t\t\tif (data.scale !== undefined) object.scale.fromArray(data.scale);\n\t\t}\n\n\t\tif (data.castShadow !== undefined) object.castShadow = data.castShadow;\n\t\tif (data.receiveShadow !== undefined) object.receiveShadow = data.receiveShadow;\n\n\t\tif (data.shadow) {\n\t\t\tif (data.shadow.bias !== undefined) object.shadow.bias = data.shadow.bias;\n\t\t\tif (data.shadow.normalBias !== undefined) object.shadow.normalBias = data.shadow.normalBias;\n\t\t\tif (data.shadow.radius !== undefined) object.shadow.radius = data.shadow.radius;\n\t\t\tif (data.shadow.mapSize !== undefined) object.shadow.mapSize.fromArray(data.shadow.mapSize);\n\t\t\tif (data.shadow.camera !== undefined) object.shadow.camera = this.parseObject(data.shadow.camera);\n\t\t}\n\n\t\tif (data.visible !== undefined) object.visible = data.visible;\n\t\tif (data.frustumCulled !== undefined) object.frustumCulled = data.frustumCulled;\n\t\tif (data.renderOrder !== undefined) object.renderOrder = data.renderOrder;\n\t\tif (data.userData !== undefined) object.userData = data.userData;\n\t\tif (data.layers !== undefined) object.layers.mask = data.layers;\n\n\t\tif (data.children !== undefined) {\n\t\t\tconst children = data.children;\n\n\t\t\tfor (let i = 0; i < children.length; i++) {\n\t\t\t\tobject.add(this.parseObject(children[i], geometries, materials, textures, animations));\n\t\t\t}\n\t\t}\n\n\t\tif (data.animations !== undefined) {\n\t\t\tconst objectAnimations = data.animations;\n\n\t\t\tfor (let i = 0; i < objectAnimations.length; i++) {\n\t\t\t\tconst uuid = objectAnimations[i];\n\t\t\t\tobject.animations.push(animations[uuid]);\n\t\t\t}\n\t\t}\n\n\t\tif (data.type === 'LOD') {\n\t\t\tif (data.autoUpdate !== undefined) object.autoUpdate = data.autoUpdate;\n\t\t\tconst levels = data.levels;\n\n\t\t\tfor (let l = 0; l < levels.length; l++) {\n\t\t\t\tconst level = levels[l];\n\t\t\t\tconst child = object.getObjectByProperty('uuid', level.object);\n\n\t\t\t\tif (child !== undefined) {\n\t\t\t\t\tobject.addLevel(child, level.distance);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn object;\n\t}\n\n\tbindSkeletons(object, skeletons) {\n\t\tif (Object.keys(skeletons).length === 0) return;\n\t\tobject.traverse(function (child) {\n\t\t\tif (child.isSkinnedMesh === true && child.skeleton !== undefined) {\n\t\t\t\tconst skeleton = skeletons[child.skeleton];\n\n\t\t\t\tif (skeleton === undefined) {\n\t\t\t\t\tconsole.warn('THREE.ObjectLoader: No skeleton found with UUID:', child.skeleton);\n\t\t\t\t} else {\n\t\t\t\t\tchild.bind(skeleton, child.bindMatrix);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\t/* DEPRECATED */\n\n\n\tsetTexturePath(value) {\n\t\tconsole.warn('THREE.ObjectLoader: .setTexturePath() has been renamed to .setResourcePath().');\n\t\treturn this.setResourcePath(value);\n\t}\n\n}\n\nconst TEXTURE_MAPPING = {\n\tUVMapping: UVMapping,\n\tCubeReflectionMapping: CubeReflectionMapping,\n\tCubeRefractionMapping: CubeRefractionMapping,\n\tEquirectangularReflectionMapping: EquirectangularReflectionMapping,\n\tEquirectangularRefractionMapping: EquirectangularRefractionMapping,\n\tCubeUVReflectionMapping: CubeUVReflectionMapping\n};\nconst TEXTURE_WRAPPING = {\n\tRepeatWrapping: RepeatWrapping,\n\tClampToEdgeWrapping: ClampToEdgeWrapping,\n\tMirroredRepeatWrapping: MirroredRepeatWrapping\n};\nconst TEXTURE_FILTER = {\n\tNearestFilter: NearestFilter,\n\tNearestMipmapNearestFilter: NearestMipmapNearestFilter,\n\tNearestMipmapLinearFilter: NearestMipmapLinearFilter,\n\tLinearFilter: LinearFilter,\n\tLinearMipmapNearestFilter: LinearMipmapNearestFilter,\n\tLinearMipmapLinearFilter: LinearMipmapLinearFilter\n};\n\nclass ImageBitmapLoader extends Loader {\n\tconstructor(manager) {\n\t\tsuper(manager);\n\t\tthis.isImageBitmapLoader = true;\n\n\t\tif (typeof createImageBitmap === 'undefined') {\n\t\t\tconsole.warn('THREE.ImageBitmapLoader: createImageBitmap() not supported.');\n\t\t}\n\n\t\tif (typeof fetch === 'undefined') {\n\t\t\tconsole.warn('THREE.ImageBitmapLoader: fetch() not supported.');\n\t\t}\n\n\t\tthis.options = {\n\t\t\tpremultiplyAlpha: 'none'\n\t\t};\n\t}\n\n\tsetOptions(options) {\n\t\tthis.options = options;\n\t\treturn this;\n\t}\n\n\tload(url, onLoad, onProgress, onError) {\n\t\tif (url === undefined) url = '';\n\t\tif (this.path !== undefined) url = this.path + url;\n\t\turl = this.manager.resolveURL(url);\n\t\tconst scope = this;\n\t\tconst cached = Cache.get(url);\n\n\t\tif (cached !== undefined) {\n\t\t\tscope.manager.itemStart(url);\n\t\t\tsetTimeout(function () {\n\t\t\t\tif (onLoad) onLoad(cached);\n\t\t\t\tscope.manager.itemEnd(url);\n\t\t\t}, 0);\n\t\t\treturn cached;\n\t\t}\n\n\t\tconst fetchOptions = {};\n\t\tfetchOptions.credentials = this.crossOrigin === 'anonymous' ? 'same-origin' : 'include';\n\t\tfetchOptions.headers = this.requestHeader;\n\t\tfetch(url, fetchOptions).then(function (res) {\n\t\t\treturn res.blob();\n\t\t}).then(function (blob) {\n\t\t\treturn createImageBitmap(blob, Object.assign(scope.options, {\n\t\t\t\tcolorSpaceConversion: 'none'\n\t\t\t}));\n\t\t}).then(function (imageBitmap) {\n\t\t\tCache.add(url, imageBitmap);\n\t\t\tif (onLoad) onLoad(imageBitmap);\n\t\t\tscope.manager.itemEnd(url);\n\t\t}).catch(function (e) {\n\t\t\tif (onError) onError(e);\n\t\t\tscope.manager.itemError(url);\n\t\t\tscope.manager.itemEnd(url);\n\t\t});\n\t\tscope.manager.itemStart(url);\n\t}\n\n}\n\nlet _context;\n\nconst AudioContext = {\n\tgetContext: function () {\n\t\tif (_context === undefined) {\n\t\t\t_context = new (window.AudioContext || window.webkitAudioContext)();\n\t\t}\n\n\t\treturn _context;\n\t},\n\tsetContext: function (value) {\n\t\t_context = value;\n\t}\n};\n\nclass AudioLoader extends Loader {\n\tconstructor(manager) {\n\t\tsuper(manager);\n\t}\n\n\tload(url, onLoad, onProgress, onError) {\n\t\tconst scope = this;\n\t\tconst loader = new FileLoader(this.manager);\n\t\tloader.setResponseType('arraybuffer');\n\t\tloader.setPath(this.path);\n\t\tloader.setRequestHeader(this.requestHeader);\n\t\tloader.setWithCredentials(this.withCredentials);\n\t\tloader.load(url, function (buffer) {\n\t\t\ttry {\n\t\t\t\t// Create a copy of the buffer. The `decodeAudioData` method\n\t\t\t\t// detaches the buffer when complete, preventing reuse.\n\t\t\t\tconst bufferCopy = buffer.slice(0);\n\t\t\t\tconst context = AudioContext.getContext();\n\t\t\t\tcontext.decodeAudioData(bufferCopy, function (audioBuffer) {\n\t\t\t\t\tonLoad(audioBuffer);\n\t\t\t\t});\n\t\t\t} catch (e) {\n\t\t\t\tif (onError) {\n\t\t\t\t\tonError(e);\n\t\t\t\t} else {\n\t\t\t\t\tconsole.error(e);\n\t\t\t\t}\n\n\t\t\t\tscope.manager.itemError(url);\n\t\t\t}\n\t\t}, onProgress, onError);\n\t}\n\n}\n\nclass HemisphereLightProbe extends LightProbe {\n\tconstructor(skyColor, groundColor, intensity = 1) {\n\t\tsuper(undefined, intensity);\n\t\tthis.isHemisphereLightProbe = true;\n\t\tconst color1 = new Color().set(skyColor);\n\t\tconst color2 = new Color().set(groundColor);\n\t\tconst sky = new Vector3(color1.r, color1.g, color1.b);\n\t\tconst ground = new Vector3(color2.r, color2.g, color2.b); // without extra factor of PI in the shader, should = 1 / Math.sqrt( Math.PI );\n\n\t\tconst c0 = Math.sqrt(Math.PI);\n\t\tconst c1 = c0 * Math.sqrt(0.75);\n\t\tthis.sh.coefficients[0].copy(sky).add(ground).multiplyScalar(c0);\n\t\tthis.sh.coefficients[1].copy(sky).sub(ground).multiplyScalar(c1);\n\t}\n\n}\n\nclass AmbientLightProbe extends LightProbe {\n\tconstructor(color, intensity = 1) {\n\t\tsuper(undefined, intensity);\n\t\tthis.isAmbientLightProbe = true;\n\t\tconst color1 = new Color().set(color); // without extra factor of PI in the shader, would be 2 / Math.sqrt( Math.PI );\n\n\t\tthis.sh.coefficients[0].set(color1.r, color1.g, color1.b).multiplyScalar(2 * Math.sqrt(Math.PI));\n\t}\n\n}\n\nconst _eyeRight = /*@__PURE__*/new Matrix4();\n\nconst _eyeLeft = /*@__PURE__*/new Matrix4();\n\nconst _projectionMatrix = /*@__PURE__*/new Matrix4();\n\nclass StereoCamera {\n\tconstructor() {\n\t\tthis.type = 'StereoCamera';\n\t\tthis.aspect = 1;\n\t\tthis.eyeSep = 0.064;\n\t\tthis.cameraL = new PerspectiveCamera();\n\t\tthis.cameraL.layers.enable(1);\n\t\tthis.cameraL.matrixAutoUpdate = false;\n\t\tthis.cameraR = new PerspectiveCamera();\n\t\tthis.cameraR.layers.enable(2);\n\t\tthis.cameraR.matrixAutoUpdate = false;\n\t\tthis._cache = {\n\t\t\tfocus: null,\n\t\t\tfov: null,\n\t\t\taspect: null,\n\t\t\tnear: null,\n\t\t\tfar: null,\n\t\t\tzoom: null,\n\t\t\teyeSep: null\n\t\t};\n\t}\n\n\tupdate(camera) {\n\t\tconst cache = this._cache;\n\t\tconst needsUpdate = cache.focus !== camera.focus || cache.fov !== camera.fov || cache.aspect !== camera.aspect * this.aspect || cache.near !== camera.near || cache.far !== camera.far || cache.zoom !== camera.zoom || cache.eyeSep !== this.eyeSep;\n\n\t\tif (needsUpdate) {\n\t\t\tcache.focus = camera.focus;\n\t\t\tcache.fov = camera.fov;\n\t\t\tcache.aspect = camera.aspect * this.aspect;\n\t\t\tcache.near = camera.near;\n\t\t\tcache.far = camera.far;\n\t\t\tcache.zoom = camera.zoom;\n\t\t\tcache.eyeSep = this.eyeSep; // Off-axis stereoscopic effect based on\n\t\t\t// http://paulbourke.net/stereographics/stereorender/\n\n\t\t\t_projectionMatrix.copy(camera.projectionMatrix);\n\n\t\t\tconst eyeSepHalf = cache.eyeSep / 2;\n\t\t\tconst eyeSepOnProjection = eyeSepHalf * cache.near / cache.focus;\n\t\t\tconst ymax = cache.near * Math.tan(DEG2RAD * cache.fov * 0.5) / cache.zoom;\n\t\t\tlet xmin, xmax; // translate xOffset\n\n\t\t\t_eyeLeft.elements[12] = -eyeSepHalf;\n\t\t\t_eyeRight.elements[12] = eyeSepHalf; // for left eye\n\n\t\t\txmin = -ymax * cache.aspect + eyeSepOnProjection;\n\t\t\txmax = ymax * cache.aspect + eyeSepOnProjection;\n\t\t\t_projectionMatrix.elements[0] = 2 * cache.near / (xmax - xmin);\n\t\t\t_projectionMatrix.elements[8] = (xmax + xmin) / (xmax - xmin);\n\t\t\tthis.cameraL.projectionMatrix.copy(_projectionMatrix); // for right eye\n\n\t\t\txmin = -ymax * cache.aspect - eyeSepOnProjection;\n\t\t\txmax = ymax * cache.aspect - eyeSepOnProjection;\n\t\t\t_projectionMatrix.elements[0] = 2 * cache.near / (xmax - xmin);\n\t\t\t_projectionMatrix.elements[8] = (xmax + xmin) / (xmax - xmin);\n\t\t\tthis.cameraR.projectionMatrix.copy(_projectionMatrix);\n\t\t}\n\n\t\tthis.cameraL.matrixWorld.copy(camera.matrixWorld).multiply(_eyeLeft);\n\t\tthis.cameraR.matrixWorld.copy(camera.matrixWorld).multiply(_eyeRight);\n\t}\n\n}\n\nclass Clock {\n\tconstructor(autoStart = true) {\n\t\tthis.autoStart = autoStart;\n\t\tthis.startTime = 0;\n\t\tthis.oldTime = 0;\n\t\tthis.elapsedTime = 0;\n\t\tthis.running = false;\n\t}\n\n\tstart() {\n\t\tthis.startTime = now();\n\t\tthis.oldTime = this.startTime;\n\t\tthis.elapsedTime = 0;\n\t\tthis.running = true;\n\t}\n\n\tstop() {\n\t\tthis.getElapsedTime();\n\t\tthis.running = false;\n\t\tthis.autoStart = false;\n\t}\n\n\tgetElapsedTime() {\n\t\tthis.getDelta();\n\t\treturn this.elapsedTime;\n\t}\n\n\tgetDelta() {\n\t\tlet diff = 0;\n\n\t\tif (this.autoStart && !this.running) {\n\t\t\tthis.start();\n\t\t\treturn 0;\n\t\t}\n\n\t\tif (this.running) {\n\t\t\tconst newTime = now();\n\t\t\tdiff = (newTime - this.oldTime) / 1000;\n\t\t\tthis.oldTime = newTime;\n\t\t\tthis.elapsedTime += diff;\n\t\t}\n\n\t\treturn diff;\n\t}\n\n}\n\nfunction now() {\n\treturn (typeof performance === 'undefined' ? Date : performance).now(); // see #10732\n}\n\nconst _position$1 = /*@__PURE__*/new Vector3();\n\nconst _quaternion$1 = /*@__PURE__*/new Quaternion();\n\nconst _scale$1 = /*@__PURE__*/new Vector3();\n\nconst _orientation$1 = /*@__PURE__*/new Vector3();\n\nclass AudioListener extends Object3D {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.type = 'AudioListener';\n\t\tthis.context = AudioContext.getContext();\n\t\tthis.gain = this.context.createGain();\n\t\tthis.gain.connect(this.context.destination);\n\t\tthis.filter = null;\n\t\tthis.timeDelta = 0; // private\n\n\t\tthis._clock = new Clock();\n\t}\n\n\tgetInput() {\n\t\treturn this.gain;\n\t}\n\n\tremoveFilter() {\n\t\tif (this.filter !== null) {\n\t\t\tthis.gain.disconnect(this.filter);\n\t\t\tthis.filter.disconnect(this.context.destination);\n\t\t\tthis.gain.connect(this.context.destination);\n\t\t\tthis.filter = null;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tgetFilter() {\n\t\treturn this.filter;\n\t}\n\n\tsetFilter(value) {\n\t\tif (this.filter !== null) {\n\t\t\tthis.gain.disconnect(this.filter);\n\t\t\tthis.filter.disconnect(this.context.destination);\n\t\t} else {\n\t\t\tthis.gain.disconnect(this.context.destination);\n\t\t}\n\n\t\tthis.filter = value;\n\t\tthis.gain.connect(this.filter);\n\t\tthis.filter.connect(this.context.destination);\n\t\treturn this;\n\t}\n\n\tgetMasterVolume() {\n\t\treturn this.gain.gain.value;\n\t}\n\n\tsetMasterVolume(value) {\n\t\tthis.gain.gain.setTargetAtTime(value, this.context.currentTime, 0.01);\n\t\treturn this;\n\t}\n\n\tupdateMatrixWorld(force) {\n\t\tsuper.updateMatrixWorld(force);\n\t\tconst listener = this.context.listener;\n\t\tconst up = this.up;\n\t\tthis.timeDelta = this._clock.getDelta();\n\t\tthis.matrixWorld.decompose(_position$1, _quaternion$1, _scale$1);\n\n\t\t_orientation$1.set(0, 0, -1).applyQuaternion(_quaternion$1);\n\n\t\tif (listener.positionX) {\n\t\t\t// code path for Chrome (see #14393)\n\t\t\tconst endTime = this.context.currentTime + this.timeDelta;\n\t\t\tlistener.positionX.linearRampToValueAtTime(_position$1.x, endTime);\n\t\t\tlistener.positionY.linearRampToValueAtTime(_position$1.y, endTime);\n\t\t\tlistener.positionZ.linearRampToValueAtTime(_position$1.z, endTime);\n\t\t\tlistener.forwardX.linearRampToValueAtTime(_orientation$1.x, endTime);\n\t\t\tlistener.forwardY.linearRampToValueAtTime(_orientation$1.y, endTime);\n\t\t\tlistener.forwardZ.linearRampToValueAtTime(_orientation$1.z, endTime);\n\t\t\tlistener.upX.linearRampToValueAtTime(up.x, endTime);\n\t\t\tlistener.upY.linearRampToValueAtTime(up.y, endTime);\n\t\t\tlistener.upZ.linearRampToValueAtTime(up.z, endTime);\n\t\t} else {\n\t\t\tlistener.setPosition(_position$1.x, _position$1.y, _position$1.z);\n\t\t\tlistener.setOrientation(_orientation$1.x, _orientation$1.y, _orientation$1.z, up.x, up.y, up.z);\n\t\t}\n\t}\n\n}\n\nclass Audio extends Object3D {\n\tconstructor(listener) {\n\t\tsuper();\n\t\tthis.type = 'Audio';\n\t\tthis.listener = listener;\n\t\tthis.context = listener.context;\n\t\tthis.gain = this.context.createGain();\n\t\tthis.gain.connect(listener.getInput());\n\t\tthis.autoplay = false;\n\t\tthis.buffer = null;\n\t\tthis.detune = 0;\n\t\tthis.loop = false;\n\t\tthis.loopStart = 0;\n\t\tthis.loopEnd = 0;\n\t\tthis.offset = 0;\n\t\tthis.duration = undefined;\n\t\tthis.playbackRate = 1;\n\t\tthis.isPlaying = false;\n\t\tthis.hasPlaybackControl = true;\n\t\tthis.source = null;\n\t\tthis.sourceType = 'empty';\n\t\tthis._startedAt = 0;\n\t\tthis._progress = 0;\n\t\tthis._connected = false;\n\t\tthis.filters = [];\n\t}\n\n\tgetOutput() {\n\t\treturn this.gain;\n\t}\n\n\tsetNodeSource(audioNode) {\n\t\tthis.hasPlaybackControl = false;\n\t\tthis.sourceType = 'audioNode';\n\t\tthis.source = audioNode;\n\t\tthis.connect();\n\t\treturn this;\n\t}\n\n\tsetMediaElementSource(mediaElement) {\n\t\tthis.hasPlaybackControl = false;\n\t\tthis.sourceType = 'mediaNode';\n\t\tthis.source = this.context.createMediaElementSource(mediaElement);\n\t\tthis.connect();\n\t\treturn this;\n\t}\n\n\tsetMediaStreamSource(mediaStream) {\n\t\tthis.hasPlaybackControl = false;\n\t\tthis.sourceType = 'mediaStreamNode';\n\t\tthis.source = this.context.createMediaStreamSource(mediaStream);\n\t\tthis.connect();\n\t\treturn this;\n\t}\n\n\tsetBuffer(audioBuffer) {\n\t\tthis.buffer = audioBuffer;\n\t\tthis.sourceType = 'buffer';\n\t\tif (this.autoplay) this.play();\n\t\treturn this;\n\t}\n\n\tplay(delay = 0) {\n\t\tif (this.isPlaying === true) {\n\t\t\tconsole.warn('THREE.Audio: Audio is already playing.');\n\t\t\treturn;\n\t\t}\n\n\t\tif (this.hasPlaybackControl === false) {\n\t\t\tconsole.warn('THREE.Audio: this Audio has no playback control.');\n\t\t\treturn;\n\t\t}\n\n\t\tthis._startedAt = this.context.currentTime + delay;\n\t\tconst source = this.context.createBufferSource();\n\t\tsource.buffer = this.buffer;\n\t\tsource.loop = this.loop;\n\t\tsource.loopStart = this.loopStart;\n\t\tsource.loopEnd = this.loopEnd;\n\t\tsource.onended = this.onEnded.bind(this);\n\t\tsource.start(this._startedAt, this._progress + this.offset, this.duration);\n\t\tthis.isPlaying = true;\n\t\tthis.source = source;\n\t\tthis.setDetune(this.detune);\n\t\tthis.setPlaybackRate(this.playbackRate);\n\t\treturn this.connect();\n\t}\n\n\tpause() {\n\t\tif (this.hasPlaybackControl === false) {\n\t\t\tconsole.warn('THREE.Audio: this Audio has no playback control.');\n\t\t\treturn;\n\t\t}\n\n\t\tif (this.isPlaying === true) {\n\t\t\t// update current progress\n\t\t\tthis._progress += Math.max(this.context.currentTime - this._startedAt, 0) * this.playbackRate;\n\n\t\t\tif (this.loop === true) {\n\t\t\t\t// ensure _progress does not exceed duration with looped audios\n\t\t\t\tthis._progress = this._progress % (this.duration || this.buffer.duration);\n\t\t\t}\n\n\t\t\tthis.source.stop();\n\t\t\tthis.source.onended = null;\n\t\t\tthis.isPlaying = false;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tstop() {\n\t\tif (this.hasPlaybackControl === false) {\n\t\t\tconsole.warn('THREE.Audio: this Audio has no playback control.');\n\t\t\treturn;\n\t\t}\n\n\t\tthis._progress = 0;\n\t\tthis.source.stop();\n\t\tthis.source.onended = null;\n\t\tthis.isPlaying = false;\n\t\treturn this;\n\t}\n\n\tconnect() {\n\t\tif (this.filters.length > 0) {\n\t\t\tthis.source.connect(this.filters[0]);\n\n\t\t\tfor (let i = 1, l = this.filters.length; i < l; i++) {\n\t\t\t\tthis.filters[i - 1].connect(this.filters[i]);\n\t\t\t}\n\n\t\t\tthis.filters[this.filters.length - 1].connect(this.getOutput());\n\t\t} else {\n\t\t\tthis.source.connect(this.getOutput());\n\t\t}\n\n\t\tthis._connected = true;\n\t\treturn this;\n\t}\n\n\tdisconnect() {\n\t\tif (this.filters.length > 0) {\n\t\t\tthis.source.disconnect(this.filters[0]);\n\n\t\t\tfor (let i = 1, l = this.filters.length; i < l; i++) {\n\t\t\t\tthis.filters[i - 1].disconnect(this.filters[i]);\n\t\t\t}\n\n\t\t\tthis.filters[this.filters.length - 1].disconnect(this.getOutput());\n\t\t} else {\n\t\t\tthis.source.disconnect(this.getOutput());\n\t\t}\n\n\t\tthis._connected = false;\n\t\treturn this;\n\t}\n\n\tgetFilters() {\n\t\treturn this.filters;\n\t}\n\n\tsetFilters(value) {\n\t\tif (!value) value = [];\n\n\t\tif (this._connected === true) {\n\t\t\tthis.disconnect();\n\t\t\tthis.filters = value.slice();\n\t\t\tthis.connect();\n\t\t} else {\n\t\t\tthis.filters = value.slice();\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tsetDetune(value) {\n\t\tthis.detune = value;\n\t\tif (this.source.detune === undefined) return; // only set detune when available\n\n\t\tif (this.isPlaying === true) {\n\t\t\tthis.source.detune.setTargetAtTime(this.detune, this.context.currentTime, 0.01);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tgetDetune() {\n\t\treturn this.detune;\n\t}\n\n\tgetFilter() {\n\t\treturn this.getFilters()[0];\n\t}\n\n\tsetFilter(filter) {\n\t\treturn this.setFilters(filter ? [filter] : []);\n\t}\n\n\tsetPlaybackRate(value) {\n\t\tif (this.hasPlaybackControl === false) {\n\t\t\tconsole.warn('THREE.Audio: this Audio has no playback control.');\n\t\t\treturn;\n\t\t}\n\n\t\tthis.playbackRate = value;\n\n\t\tif (this.isPlaying === true) {\n\t\t\tthis.source.playbackRate.setTargetAtTime(this.playbackRate, this.context.currentTime, 0.01);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tgetPlaybackRate() {\n\t\treturn this.playbackRate;\n\t}\n\n\tonEnded() {\n\t\tthis.isPlaying = false;\n\t}\n\n\tgetLoop() {\n\t\tif (this.hasPlaybackControl === false) {\n\t\t\tconsole.warn('THREE.Audio: this Audio has no playback control.');\n\t\t\treturn false;\n\t\t}\n\n\t\treturn this.loop;\n\t}\n\n\tsetLoop(value) {\n\t\tif (this.hasPlaybackControl === false) {\n\t\t\tconsole.warn('THREE.Audio: this Audio has no playback control.');\n\t\t\treturn;\n\t\t}\n\n\t\tthis.loop = value;\n\n\t\tif (this.isPlaying === true) {\n\t\t\tthis.source.loop = this.loop;\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tsetLoopStart(value) {\n\t\tthis.loopStart = value;\n\t\treturn this;\n\t}\n\n\tsetLoopEnd(value) {\n\t\tthis.loopEnd = value;\n\t\treturn this;\n\t}\n\n\tgetVolume() {\n\t\treturn this.gain.gain.value;\n\t}\n\n\tsetVolume(value) {\n\t\tthis.gain.gain.setTargetAtTime(value, this.context.currentTime, 0.01);\n\t\treturn this;\n\t}\n\n}\n\nconst _position = /*@__PURE__*/new Vector3();\n\nconst _quaternion = /*@__PURE__*/new Quaternion();\n\nconst _scale = /*@__PURE__*/new Vector3();\n\nconst _orientation = /*@__PURE__*/new Vector3();\n\nclass PositionalAudio extends Audio {\n\tconstructor(listener) {\n\t\tsuper(listener);\n\t\tthis.panner = this.context.createPanner();\n\t\tthis.panner.panningModel = 'HRTF';\n\t\tthis.panner.connect(this.gain);\n\t}\n\n\tdisconnect() {\n\t\tsuper.disconnect();\n\t\tthis.panner.disconnect(this.gain);\n\t}\n\n\tgetOutput() {\n\t\treturn this.panner;\n\t}\n\n\tgetRefDistance() {\n\t\treturn this.panner.refDistance;\n\t}\n\n\tsetRefDistance(value) {\n\t\tthis.panner.refDistance = value;\n\t\treturn this;\n\t}\n\n\tgetRolloffFactor() {\n\t\treturn this.panner.rolloffFactor;\n\t}\n\n\tsetRolloffFactor(value) {\n\t\tthis.panner.rolloffFactor = value;\n\t\treturn this;\n\t}\n\n\tgetDistanceModel() {\n\t\treturn this.panner.distanceModel;\n\t}\n\n\tsetDistanceModel(value) {\n\t\tthis.panner.distanceModel = value;\n\t\treturn this;\n\t}\n\n\tgetMaxDistance() {\n\t\treturn this.panner.maxDistance;\n\t}\n\n\tsetMaxDistance(value) {\n\t\tthis.panner.maxDistance = value;\n\t\treturn this;\n\t}\n\n\tsetDirectionalCone(coneInnerAngle, coneOuterAngle, coneOuterGain) {\n\t\tthis.panner.coneInnerAngle = coneInnerAngle;\n\t\tthis.panner.coneOuterAngle = coneOuterAngle;\n\t\tthis.panner.coneOuterGain = coneOuterGain;\n\t\treturn this;\n\t}\n\n\tupdateMatrixWorld(force) {\n\t\tsuper.updateMatrixWorld(force);\n\t\tif (this.hasPlaybackControl === true && this.isPlaying === false) return;\n\t\tthis.matrixWorld.decompose(_position, _quaternion, _scale);\n\n\t\t_orientation.set(0, 0, 1).applyQuaternion(_quaternion);\n\n\t\tconst panner = this.panner;\n\n\t\tif (panner.positionX) {\n\t\t\t// code path for Chrome and Firefox (see #14393)\n\t\t\tconst endTime = this.context.currentTime + this.listener.timeDelta;\n\t\t\tpanner.positionX.linearRampToValueAtTime(_position.x, endTime);\n\t\t\tpanner.positionY.linearRampToValueAtTime(_position.y, endTime);\n\t\t\tpanner.positionZ.linearRampToValueAtTime(_position.z, endTime);\n\t\t\tpanner.orientationX.linearRampToValueAtTime(_orientation.x, endTime);\n\t\t\tpanner.orientationY.linearRampToValueAtTime(_orientation.y, endTime);\n\t\t\tpanner.orientationZ.linearRampToValueAtTime(_orientation.z, endTime);\n\t\t} else {\n\t\t\tpanner.setPosition(_position.x, _position.y, _position.z);\n\t\t\tpanner.setOrientation(_orientation.x, _orientation.y, _orientation.z);\n\t\t}\n\t}\n\n}\n\nclass AudioAnalyser {\n\tconstructor(audio, fftSize = 2048) {\n\t\tthis.analyser = audio.context.createAnalyser();\n\t\tthis.analyser.fftSize = fftSize;\n\t\tthis.data = new Uint8Array(this.analyser.frequencyBinCount);\n\t\taudio.getOutput().connect(this.analyser);\n\t}\n\n\tgetFrequencyData() {\n\t\tthis.analyser.getByteFrequencyData(this.data);\n\t\treturn this.data;\n\t}\n\n\tgetAverageFrequency() {\n\t\tlet value = 0;\n\t\tconst data = this.getFrequencyData();\n\n\t\tfor (let i = 0; i < data.length; i++) {\n\t\t\tvalue += data[i];\n\t\t}\n\n\t\treturn value / data.length;\n\t}\n\n}\n\nclass PropertyMixer {\n\tconstructor(binding, typeName, valueSize) {\n\t\tthis.binding = binding;\n\t\tthis.valueSize = valueSize;\n\t\tlet mixFunction, mixFunctionAdditive, setIdentity; // buffer layout: [ incoming | accu0 | accu1 | orig | addAccu | (optional work) ]\n\t\t//\n\t\t// interpolators can use .buffer as their .result\n\t\t// the data then goes to 'incoming'\n\t\t//\n\t\t// 'accu0' and 'accu1' are used frame-interleaved for\n\t\t// the cumulative result and are compared to detect\n\t\t// changes\n\t\t//\n\t\t// 'orig' stores the original state of the property\n\t\t//\n\t\t// 'add' is used for additive cumulative results\n\t\t//\n\t\t// 'work' is optional and is only present for quaternion types. It is used\n\t\t// to store intermediate quaternion multiplication results\n\n\t\tswitch (typeName) {\n\t\t\tcase 'quaternion':\n\t\t\t\tmixFunction = this._slerp;\n\t\t\t\tmixFunctionAdditive = this._slerpAdditive;\n\t\t\t\tsetIdentity = this._setAdditiveIdentityQuaternion;\n\t\t\t\tthis.buffer = new Float64Array(valueSize * 6);\n\t\t\t\tthis._workIndex = 5;\n\t\t\t\tbreak;\n\n\t\t\tcase 'string':\n\t\t\tcase 'bool':\n\t\t\t\tmixFunction = this._select; // Use the regular mix function and for additive on these types,\n\t\t\t\t// additive is not relevant for non-numeric types\n\n\t\t\t\tmixFunctionAdditive = this._select;\n\t\t\t\tsetIdentity = this._setAdditiveIdentityOther;\n\t\t\t\tthis.buffer = new Array(valueSize * 5);\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tmixFunction = this._lerp;\n\t\t\t\tmixFunctionAdditive = this._lerpAdditive;\n\t\t\t\tsetIdentity = this._setAdditiveIdentityNumeric;\n\t\t\t\tthis.buffer = new Float64Array(valueSize * 5);\n\t\t}\n\n\t\tthis._mixBufferRegion = mixFunction;\n\t\tthis._mixBufferRegionAdditive = mixFunctionAdditive;\n\t\tthis._setIdentity = setIdentity;\n\t\tthis._origIndex = 3;\n\t\tthis._addIndex = 4;\n\t\tthis.cumulativeWeight = 0;\n\t\tthis.cumulativeWeightAdditive = 0;\n\t\tthis.useCount = 0;\n\t\tthis.referenceCount = 0;\n\t} // accumulate data in the 'incoming' region into 'accu'\n\n\n\taccumulate(accuIndex, weight) {\n\t\t// note: happily accumulating nothing when weight = 0, the caller knows\n\t\t// the weight and shouldn't have made the call in the first place\n\t\tconst buffer = this.buffer,\n\t\t\t\t\tstride = this.valueSize,\n\t\t\t\t\toffset = accuIndex * stride + stride;\n\t\tlet currentWeight = this.cumulativeWeight;\n\n\t\tif (currentWeight === 0) {\n\t\t\t// accuN := incoming * weight\n\t\t\tfor (let i = 0; i !== stride; ++i) {\n\t\t\t\tbuffer[offset + i] = buffer[i];\n\t\t\t}\n\n\t\t\tcurrentWeight = weight;\n\t\t} else {\n\t\t\t// accuN := accuN + incoming * weight\n\t\t\tcurrentWeight += weight;\n\t\t\tconst mix = weight / currentWeight;\n\n\t\t\tthis._mixBufferRegion(buffer, offset, 0, mix, stride);\n\t\t}\n\n\t\tthis.cumulativeWeight = currentWeight;\n\t} // accumulate data in the 'incoming' region into 'add'\n\n\n\taccumulateAdditive(weight) {\n\t\tconst buffer = this.buffer,\n\t\t\t\t\tstride = this.valueSize,\n\t\t\t\t\toffset = stride * this._addIndex;\n\n\t\tif (this.cumulativeWeightAdditive === 0) {\n\t\t\t// add = identity\n\t\t\tthis._setIdentity();\n\t\t} // add := add + incoming * weight\n\n\n\t\tthis._mixBufferRegionAdditive(buffer, offset, 0, weight, stride);\n\n\t\tthis.cumulativeWeightAdditive += weight;\n\t} // apply the state of 'accu' to the binding when accus differ\n\n\n\tapply(accuIndex) {\n\t\tconst stride = this.valueSize,\n\t\t\t\t\tbuffer = this.buffer,\n\t\t\t\t\toffset = accuIndex * stride + stride,\n\t\t\t\t\tweight = this.cumulativeWeight,\n\t\t\t\t\tweightAdditive = this.cumulativeWeightAdditive,\n\t\t\t\t\tbinding = this.binding;\n\t\tthis.cumulativeWeight = 0;\n\t\tthis.cumulativeWeightAdditive = 0;\n\n\t\tif (weight < 1) {\n\t\t\t// accuN := accuN + original * ( 1 - cumulativeWeight )\n\t\t\tconst originalValueOffset = stride * this._origIndex;\n\n\t\t\tthis._mixBufferRegion(buffer, offset, originalValueOffset, 1 - weight, stride);\n\t\t}\n\n\t\tif (weightAdditive > 0) {\n\t\t\t// accuN := accuN + additive accuN\n\t\t\tthis._mixBufferRegionAdditive(buffer, offset, this._addIndex * stride, 1, stride);\n\t\t}\n\n\t\tfor (let i = stride, e = stride + stride; i !== e; ++i) {\n\t\t\tif (buffer[i] !== buffer[i + stride]) {\n\t\t\t\t// value has changed -> update scene graph\n\t\t\t\tbinding.setValue(buffer, offset);\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t} // remember the state of the bound property and copy it to both accus\n\n\n\tsaveOriginalState() {\n\t\tconst binding = this.binding;\n\t\tconst buffer = this.buffer,\n\t\t\t\t\tstride = this.valueSize,\n\t\t\t\t\toriginalValueOffset = stride * this._origIndex;\n\t\tbinding.getValue(buffer, originalValueOffset); // accu[0..1] := orig -- initially detect changes against the original\n\n\t\tfor (let i = stride, e = originalValueOffset; i !== e; ++i) {\n\t\t\tbuffer[i] = buffer[originalValueOffset + i % stride];\n\t\t} // Add to identity for additive\n\n\n\t\tthis._setIdentity();\n\n\t\tthis.cumulativeWeight = 0;\n\t\tthis.cumulativeWeightAdditive = 0;\n\t} // apply the state previously taken via 'saveOriginalState' to the binding\n\n\n\trestoreOriginalState() {\n\t\tconst originalValueOffset = this.valueSize * 3;\n\t\tthis.binding.setValue(this.buffer, originalValueOffset);\n\t}\n\n\t_setAdditiveIdentityNumeric() {\n\t\tconst startIndex = this._addIndex * this.valueSize;\n\t\tconst endIndex = startIndex + this.valueSize;\n\n\t\tfor (let i = startIndex; i < endIndex; i++) {\n\t\t\tthis.buffer[i] = 0;\n\t\t}\n\t}\n\n\t_setAdditiveIdentityQuaternion() {\n\t\tthis._setAdditiveIdentityNumeric();\n\n\t\tthis.buffer[this._addIndex * this.valueSize + 3] = 1;\n\t}\n\n\t_setAdditiveIdentityOther() {\n\t\tconst startIndex = this._origIndex * this.valueSize;\n\t\tconst targetIndex = this._addIndex * this.valueSize;\n\n\t\tfor (let i = 0; i < this.valueSize; i++) {\n\t\t\tthis.buffer[targetIndex + i] = this.buffer[startIndex + i];\n\t\t}\n\t} // mix functions\n\n\n\t_select(buffer, dstOffset, srcOffset, t, stride) {\n\t\tif (t >= 0.5) {\n\t\t\tfor (let i = 0; i !== stride; ++i) {\n\t\t\t\tbuffer[dstOffset + i] = buffer[srcOffset + i];\n\t\t\t}\n\t\t}\n\t}\n\n\t_slerp(buffer, dstOffset, srcOffset, t) {\n\t\tQuaternion.slerpFlat(buffer, dstOffset, buffer, dstOffset, buffer, srcOffset, t);\n\t}\n\n\t_slerpAdditive(buffer, dstOffset, srcOffset, t, stride) {\n\t\tconst workOffset = this._workIndex * stride; // Store result in intermediate buffer offset\n\n\t\tQuaternion.multiplyQuaternionsFlat(buffer, workOffset, buffer, dstOffset, buffer, srcOffset); // Slerp to the intermediate result\n\n\t\tQuaternion.slerpFlat(buffer, dstOffset, buffer, dstOffset, buffer, workOffset, t);\n\t}\n\n\t_lerp(buffer, dstOffset, srcOffset, t, stride) {\n\t\tconst s = 1 - t;\n\n\t\tfor (let i = 0; i !== stride; ++i) {\n\t\t\tconst j = dstOffset + i;\n\t\t\tbuffer[j] = buffer[j] * s + buffer[srcOffset + i] * t;\n\t\t}\n\t}\n\n\t_lerpAdditive(buffer, dstOffset, srcOffset, t, stride) {\n\t\tfor (let i = 0; i !== stride; ++i) {\n\t\t\tconst j = dstOffset + i;\n\t\t\tbuffer[j] = buffer[j] + buffer[srcOffset + i] * t;\n\t\t}\n\t}\n\n}\n\n// Characters [].:/ are reserved for track binding syntax.\nconst _RESERVED_CHARS_RE = '\\\\[\\\\]\\\\.:\\\\/';\n\nconst _reservedRe = new RegExp('[' + _RESERVED_CHARS_RE + ']', 'g'); // Attempts to allow node names from any language. ES5's `\\w` regexp matches\n// only latin characters, and the unicode \\p{L} is not yet supported. So\n// instead, we exclude reserved characters and match everything else.\n\n\nconst _wordChar = '[^' + _RESERVED_CHARS_RE + ']';\n\nconst _wordCharOrDot = '[^' + _RESERVED_CHARS_RE.replace('\\\\.', '') + ']'; // Parent directories, delimited by '/' or ':'. Currently unused, but must\n// be matched to parse the rest of the track name.\n\n\nconst _directoryRe = /((?:WC+[\\/:])*)/.source.replace('WC', _wordChar); // Target node. May contain word characters (a-zA-Z0-9_) and '.' or '-'.\n\n\nconst _nodeRe = /(WCOD+)?/.source.replace('WCOD', _wordCharOrDot); // Object on target node, and accessor. May not contain reserved\n// characters. Accessor may contain any character except closing bracket.\n\n\nconst _objectRe = /(?:\\.(WC+)(?:\\[(.+)\\])?)?/.source.replace('WC', _wordChar); // Property and accessor. May not contain reserved characters. Accessor may\n// contain any non-bracket characters.\n\n\nconst _propertyRe = /\\.(WC+)(?:\\[(.+)\\])?/.source.replace('WC', _wordChar);\n\nconst _trackRe = new RegExp('' + '^' + _directoryRe + _nodeRe + _objectRe + _propertyRe + '$');\n\nconst _supportedObjectNames = ['material', 'materials', 'bones'];\n\nclass Composite {\n\tconstructor(targetGroup, path, optionalParsedPath) {\n\t\tconst parsedPath = optionalParsedPath || PropertyBinding.parseTrackName(path);\n\t\tthis._targetGroup = targetGroup;\n\t\tthis._bindings = targetGroup.subscribe_(path, parsedPath);\n\t}\n\n\tgetValue(array, offset) {\n\t\tthis.bind(); // bind all binding\n\n\t\tconst firstValidIndex = this._targetGroup.nCachedObjects_,\n\t\t\t\t\tbinding = this._bindings[firstValidIndex]; // and only call .getValue on the first\n\n\t\tif (binding !== undefined) binding.getValue(array, offset);\n\t}\n\n\tsetValue(array, offset) {\n\t\tconst bindings = this._bindings;\n\n\t\tfor (let i = this._targetGroup.nCachedObjects_, n = bindings.length; i !== n; ++i) {\n\t\t\tbindings[i].setValue(array, offset);\n\t\t}\n\t}\n\n\tbind() {\n\t\tconst bindings = this._bindings;\n\n\t\tfor (let i = this._targetGroup.nCachedObjects_, n = bindings.length; i !== n; ++i) {\n\t\t\tbindings[i].bind();\n\t\t}\n\t}\n\n\tunbind() {\n\t\tconst bindings = this._bindings;\n\n\t\tfor (let i = this._targetGroup.nCachedObjects_, n = bindings.length; i !== n; ++i) {\n\t\t\tbindings[i].unbind();\n\t\t}\n\t}\n\n} // Note: This class uses a State pattern on a per-method basis:\n// 'bind' sets 'this.getValue' / 'setValue' and shadows the\n// prototype version of these methods with one that represents\n// the bound state. When the property is not found, the methods\n// become no-ops.\n\n\nclass PropertyBinding {\n\tconstructor(rootNode, path, parsedPath) {\n\t\tthis.path = path;\n\t\tthis.parsedPath = parsedPath || PropertyBinding.parseTrackName(path);\n\t\tthis.node = PropertyBinding.findNode(rootNode, this.parsedPath.nodeName) || rootNode;\n\t\tthis.rootNode = rootNode; // initial state of these methods that calls 'bind'\n\n\t\tthis.getValue = this._getValue_unbound;\n\t\tthis.setValue = this._setValue_unbound;\n\t}\n\n\tstatic create(root, path, parsedPath) {\n\t\tif (!(root && root.isAnimationObjectGroup)) {\n\t\t\treturn new PropertyBinding(root, path, parsedPath);\n\t\t} else {\n\t\t\treturn new PropertyBinding.Composite(root, path, parsedPath);\n\t\t}\n\t}\n\t/**\n\t * Replaces spaces with underscores and removes unsupported characters from\n\t * node names, to ensure compatibility with parseTrackName().\n\t *\n\t * @param {string} name Node name to be sanitized.\n\t * @return {string}\n\t */\n\n\n\tstatic sanitizeNodeName(name) {\n\t\treturn name.replace(/\\s/g, '_').replace(_reservedRe, '');\n\t}\n\n\tstatic parseTrackName(trackName) {\n\t\tconst matches = _trackRe.exec(trackName);\n\n\t\tif (matches === null) {\n\t\t\tthrow new Error('PropertyBinding: Cannot parse trackName: ' + trackName);\n\t\t}\n\n\t\tconst results = {\n\t\t\t// directoryName: matches[ 1 ], // (tschw) currently unused\n\t\t\tnodeName: matches[2],\n\t\t\tobjectName: matches[3],\n\t\t\tobjectIndex: matches[4],\n\t\t\tpropertyName: matches[5],\n\t\t\t// required\n\t\t\tpropertyIndex: matches[6]\n\t\t};\n\t\tconst lastDot = results.nodeName && results.nodeName.lastIndexOf('.');\n\n\t\tif (lastDot !== undefined && lastDot !== -1) {\n\t\t\tconst objectName = results.nodeName.substring(lastDot + 1); // Object names must be checked against an allowlist. Otherwise, there\n\t\t\t// is no way to parse 'foo.bar.baz': 'baz' must be a property, but\n\t\t\t// 'bar' could be the objectName, or part of a nodeName (which can\n\t\t\t// include '.' characters).\n\n\t\t\tif (_supportedObjectNames.indexOf(objectName) !== -1) {\n\t\t\t\tresults.nodeName = results.nodeName.substring(0, lastDot);\n\t\t\t\tresults.objectName = objectName;\n\t\t\t}\n\t\t}\n\n\t\tif (results.propertyName === null || results.propertyName.length === 0) {\n\t\t\tthrow new Error('PropertyBinding: can not parse propertyName from trackName: ' + trackName);\n\t\t}\n\n\t\treturn results;\n\t}\n\n\tstatic findNode(root, nodeName) {\n\t\tif (nodeName === undefined || nodeName === '' || nodeName === '.' || nodeName === -1 || nodeName === root.name || nodeName === root.uuid) {\n\t\t\treturn root;\n\t\t} // search into skeleton bones.\n\n\n\t\tif (root.skeleton) {\n\t\t\tconst bone = root.skeleton.getBoneByName(nodeName);\n\n\t\t\tif (bone !== undefined) {\n\t\t\t\treturn bone;\n\t\t\t}\n\t\t} // search into node subtree.\n\n\n\t\tif (root.children) {\n\t\t\tconst searchNodeSubtree = function (children) {\n\t\t\t\tfor (let i = 0; i < children.length; i++) {\n\t\t\t\t\tconst childNode = children[i];\n\n\t\t\t\t\tif (childNode.name === nodeName || childNode.uuid === nodeName) {\n\t\t\t\t\t\treturn childNode;\n\t\t\t\t\t}\n\n\t\t\t\t\tconst result = searchNodeSubtree(childNode.children);\n\t\t\t\t\tif (result) return result;\n\t\t\t\t}\n\n\t\t\t\treturn null;\n\t\t\t};\n\n\t\t\tconst subTreeNode = searchNodeSubtree(root.children);\n\n\t\t\tif (subTreeNode) {\n\t\t\t\treturn subTreeNode;\n\t\t\t}\n\t\t}\n\n\t\treturn null;\n\t} // these are used to \"bind\" a nonexistent property\n\n\n\t_getValue_unavailable() {}\n\n\t_setValue_unavailable() {} // Getters\n\n\n\t_getValue_direct(buffer, offset) {\n\t\tbuffer[offset] = this.targetObject[this.propertyName];\n\t}\n\n\t_getValue_array(buffer, offset) {\n\t\tconst source = this.resolvedProperty;\n\n\t\tfor (let i = 0, n = source.length; i !== n; ++i) {\n\t\t\tbuffer[offset++] = source[i];\n\t\t}\n\t}\n\n\t_getValue_arrayElement(buffer, offset) {\n\t\tbuffer[offset] = this.resolvedProperty[this.propertyIndex];\n\t}\n\n\t_getValue_toArray(buffer, offset) {\n\t\tthis.resolvedProperty.toArray(buffer, offset);\n\t} // Direct\n\n\n\t_setValue_direct(buffer, offset) {\n\t\tthis.targetObject[this.propertyName] = buffer[offset];\n\t}\n\n\t_setValue_direct_setNeedsUpdate(buffer, offset) {\n\t\tthis.targetObject[this.propertyName] = buffer[offset];\n\t\tthis.targetObject.needsUpdate = true;\n\t}\n\n\t_setValue_direct_setMatrixWorldNeedsUpdate(buffer, offset) {\n\t\tthis.targetObject[this.propertyName] = buffer[offset];\n\t\tthis.targetObject.matrixWorldNeedsUpdate = true;\n\t} // EntireArray\n\n\n\t_setValue_array(buffer, offset) {\n\t\tconst dest = this.resolvedProperty;\n\n\t\tfor (let i = 0, n = dest.length; i !== n; ++i) {\n\t\t\tdest[i] = buffer[offset++];\n\t\t}\n\t}\n\n\t_setValue_array_setNeedsUpdate(buffer, offset) {\n\t\tconst dest = this.resolvedProperty;\n\n\t\tfor (let i = 0, n = dest.length; i !== n; ++i) {\n\t\t\tdest[i] = buffer[offset++];\n\t\t}\n\n\t\tthis.targetObject.needsUpdate = true;\n\t}\n\n\t_setValue_array_setMatrixWorldNeedsUpdate(buffer, offset) {\n\t\tconst dest = this.resolvedProperty;\n\n\t\tfor (let i = 0, n = dest.length; i !== n; ++i) {\n\t\t\tdest[i] = buffer[offset++];\n\t\t}\n\n\t\tthis.targetObject.matrixWorldNeedsUpdate = true;\n\t} // ArrayElement\n\n\n\t_setValue_arrayElement(buffer, offset) {\n\t\tthis.resolvedProperty[this.propertyIndex] = buffer[offset];\n\t}\n\n\t_setValue_arrayElement_setNeedsUpdate(buffer, offset) {\n\t\tthis.resolvedProperty[this.propertyIndex] = buffer[offset];\n\t\tthis.targetObject.needsUpdate = true;\n\t}\n\n\t_setValue_arrayElement_setMatrixWorldNeedsUpdate(buffer, offset) {\n\t\tthis.resolvedProperty[this.propertyIndex] = buffer[offset];\n\t\tthis.targetObject.matrixWorldNeedsUpdate = true;\n\t} // HasToFromArray\n\n\n\t_setValue_fromArray(buffer, offset) {\n\t\tthis.resolvedProperty.fromArray(buffer, offset);\n\t}\n\n\t_setValue_fromArray_setNeedsUpdate(buffer, offset) {\n\t\tthis.resolvedProperty.fromArray(buffer, offset);\n\t\tthis.targetObject.needsUpdate = true;\n\t}\n\n\t_setValue_fromArray_setMatrixWorldNeedsUpdate(buffer, offset) {\n\t\tthis.resolvedProperty.fromArray(buffer, offset);\n\t\tthis.targetObject.matrixWorldNeedsUpdate = true;\n\t}\n\n\t_getValue_unbound(targetArray, offset) {\n\t\tthis.bind();\n\t\tthis.getValue(targetArray, offset);\n\t}\n\n\t_setValue_unbound(sourceArray, offset) {\n\t\tthis.bind();\n\t\tthis.setValue(sourceArray, offset);\n\t} // create getter / setter pair for a property in the scene graph\n\n\n\tbind() {\n\t\tlet targetObject = this.node;\n\t\tconst parsedPath = this.parsedPath;\n\t\tconst objectName = parsedPath.objectName;\n\t\tconst propertyName = parsedPath.propertyName;\n\t\tlet propertyIndex = parsedPath.propertyIndex;\n\n\t\tif (!targetObject) {\n\t\t\ttargetObject = PropertyBinding.findNode(this.rootNode, parsedPath.nodeName) || this.rootNode;\n\t\t\tthis.node = targetObject;\n\t\t} // set fail state so we can just 'return' on error\n\n\n\t\tthis.getValue = this._getValue_unavailable;\n\t\tthis.setValue = this._setValue_unavailable; // ensure there is a value node\n\n\t\tif (!targetObject) {\n\t\t\tconsole.error('THREE.PropertyBinding: Trying to update node for track: ' + this.path + ' but it wasn\\'t found.');\n\t\t\treturn;\n\t\t}\n\n\t\tif (objectName) {\n\t\t\tlet objectIndex = parsedPath.objectIndex; // special cases were we need to reach deeper into the hierarchy to get the face materials....\n\n\t\t\tswitch (objectName) {\n\t\t\t\tcase 'materials':\n\t\t\t\t\tif (!targetObject.material) {\n\t\t\t\t\t\tconsole.error('THREE.PropertyBinding: Can not bind to material as node does not have a material.', this);\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (!targetObject.material.materials) {\n\t\t\t\t\t\tconsole.error('THREE.PropertyBinding: Can not bind to material.materials as node.material does not have a materials array.', this);\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\ttargetObject = targetObject.material.materials;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'bones':\n\t\t\t\t\tif (!targetObject.skeleton) {\n\t\t\t\t\t\tconsole.error('THREE.PropertyBinding: Can not bind to bones as node does not have a skeleton.', this);\n\t\t\t\t\t\treturn;\n\t\t\t\t\t} // potential future optimization: skip this if propertyIndex is already an integer\n\t\t\t\t\t// and convert the integer string to a true integer.\n\n\n\t\t\t\t\ttargetObject = targetObject.skeleton.bones; // support resolving morphTarget names into indices.\n\n\t\t\t\t\tfor (let i = 0; i < targetObject.length; i++) {\n\t\t\t\t\t\tif (targetObject[i].name === objectIndex) {\n\t\t\t\t\t\t\tobjectIndex = i;\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\n\t\t\t\t\tif (targetObject[objectName] === undefined) {\n\t\t\t\t\t\tconsole.error('THREE.PropertyBinding: Can not bind to objectName of node undefined.', this);\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\ttargetObject = targetObject[objectName];\n\t\t\t}\n\n\t\t\tif (objectIndex !== undefined) {\n\t\t\t\tif (targetObject[objectIndex] === undefined) {\n\t\t\t\t\tconsole.error('THREE.PropertyBinding: Trying to bind to objectIndex of objectName, but is undefined.', this, targetObject);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\ttargetObject = targetObject[objectIndex];\n\t\t\t}\n\t\t} // resolve property\n\n\n\t\tconst nodeProperty = targetObject[propertyName];\n\n\t\tif (nodeProperty === undefined) {\n\t\t\tconst nodeName = parsedPath.nodeName;\n\t\t\tconsole.error('THREE.PropertyBinding: Trying to update property for track: ' + nodeName + '.' + propertyName + ' but it wasn\\'t found.', targetObject);\n\t\t\treturn;\n\t\t} // determine versioning scheme\n\n\n\t\tlet versioning = this.Versioning.None;\n\t\tthis.targetObject = targetObject;\n\n\t\tif (targetObject.needsUpdate !== undefined) {\n\t\t\t// material\n\t\t\tversioning = this.Versioning.NeedsUpdate;\n\t\t} else if (targetObject.matrixWorldNeedsUpdate !== undefined) {\n\t\t\t// node transform\n\t\t\tversioning = this.Versioning.MatrixWorldNeedsUpdate;\n\t\t} // determine how the property gets bound\n\n\n\t\tlet bindingType = this.BindingType.Direct;\n\n\t\tif (propertyIndex !== undefined) {\n\t\t\t// access a sub element of the property array (only primitives are supported right now)\n\t\t\tif (propertyName === 'morphTargetInfluences') {\n\t\t\t\t// potential optimization, skip this if propertyIndex is already an integer, and convert the integer string to a true integer.\n\t\t\t\t// support resolving morphTarget names into indices.\n\t\t\t\tif (!targetObject.geometry) {\n\t\t\t\t\tconsole.error('THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.', this);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (!targetObject.geometry.morphAttributes) {\n\t\t\t\t\tconsole.error('THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphAttributes.', this);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (targetObject.morphTargetDictionary[propertyIndex] !== undefined) {\n\t\t\t\t\tpropertyIndex = targetObject.morphTargetDictionary[propertyIndex];\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tbindingType = this.BindingType.ArrayElement;\n\t\t\tthis.resolvedProperty = nodeProperty;\n\t\t\tthis.propertyIndex = propertyIndex;\n\t\t} else if (nodeProperty.fromArray !== undefined && nodeProperty.toArray !== undefined) {\n\t\t\t// must use copy for Object3D.Euler/Quaternion\n\t\t\tbindingType = this.BindingType.HasFromToArray;\n\t\t\tthis.resolvedProperty = nodeProperty;\n\t\t} else if (Array.isArray(nodeProperty)) {\n\t\t\tbindingType = this.BindingType.EntireArray;\n\t\t\tthis.resolvedProperty = nodeProperty;\n\t\t} else {\n\t\t\tthis.propertyName = propertyName;\n\t\t} // select getter / setter\n\n\n\t\tthis.getValue = this.GetterByBindingType[bindingType];\n\t\tthis.setValue = this.SetterByBindingTypeAndVersioning[bindingType][versioning];\n\t}\n\n\tunbind() {\n\t\tthis.node = null; // back to the prototype version of getValue / setValue\n\t\t// note: avoiding to mutate the shape of 'this' via 'delete'\n\n\t\tthis.getValue = this._getValue_unbound;\n\t\tthis.setValue = this._setValue_unbound;\n\t}\n\n}\n\nPropertyBinding.Composite = Composite;\nPropertyBinding.prototype.BindingType = {\n\tDirect: 0,\n\tEntireArray: 1,\n\tArrayElement: 2,\n\tHasFromToArray: 3\n};\nPropertyBinding.prototype.Versioning = {\n\tNone: 0,\n\tNeedsUpdate: 1,\n\tMatrixWorldNeedsUpdate: 2\n};\nPropertyBinding.prototype.GetterByBindingType = [PropertyBinding.prototype._getValue_direct, PropertyBinding.prototype._getValue_array, PropertyBinding.prototype._getValue_arrayElement, PropertyBinding.prototype._getValue_toArray];\nPropertyBinding.prototype.SetterByBindingTypeAndVersioning = [[// Direct\nPropertyBinding.prototype._setValue_direct, PropertyBinding.prototype._setValue_direct_setNeedsUpdate, PropertyBinding.prototype._setValue_direct_setMatrixWorldNeedsUpdate], [// EntireArray\nPropertyBinding.prototype._setValue_array, PropertyBinding.prototype._setValue_array_setNeedsUpdate, PropertyBinding.prototype._setValue_array_setMatrixWorldNeedsUpdate], [// ArrayElement\nPropertyBinding.prototype._setValue_arrayElement, PropertyBinding.prototype._setValue_arrayElement_setNeedsUpdate, PropertyBinding.prototype._setValue_arrayElement_setMatrixWorldNeedsUpdate], [// HasToFromArray\nPropertyBinding.prototype._setValue_fromArray, PropertyBinding.prototype._setValue_fromArray_setNeedsUpdate, PropertyBinding.prototype._setValue_fromArray_setMatrixWorldNeedsUpdate]];\n\n/**\n *\n * A group of objects that receives a shared animation state.\n *\n * Usage:\n *\n *\t- Add objects you would otherwise pass as 'root' to the\n *\t\tconstructor or the .clipAction method of AnimationMixer.\n *\n *\t- Instead pass this object as 'root'.\n *\n *\t- You can also add and remove objects later when the mixer\n *\t\tis running.\n *\n * Note:\n *\n *\t\tObjects of this class appear as one object to the mixer,\n *\t\tso cache control of the individual objects must be done\n *\t\ton the group.\n *\n * Limitation:\n *\n *\t- The animated properties must be compatible among the\n *\t\tall objects in the group.\n *\n *\t- A single property can either be controlled through a\n *\t\ttarget group or directly, but not both.\n */\n\nclass AnimationObjectGroup {\n\tconstructor() {\n\t\tthis.isAnimationObjectGroup = true;\n\t\tthis.uuid = generateUUID(); // cached objects followed by the active ones\n\n\t\tthis._objects = Array.prototype.slice.call(arguments);\n\t\tthis.nCachedObjects_ = 0; // threshold\n\t\t// note: read by PropertyBinding.Composite\n\n\t\tconst indices = {};\n\t\tthis._indicesByUUID = indices; // for bookkeeping\n\n\t\tfor (let i = 0, n = arguments.length; i !== n; ++i) {\n\t\t\tindices[arguments[i].uuid] = i;\n\t\t}\n\n\t\tthis._paths = []; // inside: string\n\n\t\tthis._parsedPaths = []; // inside: { we don't care, here }\n\n\t\tthis._bindings = []; // inside: Array< PropertyBinding >\n\n\t\tthis._bindingsIndicesByPath = {}; // inside: indices in these arrays\n\n\t\tconst scope = this;\n\t\tthis.stats = {\n\t\t\tobjects: {\n\t\t\t\tget total() {\n\t\t\t\t\treturn scope._objects.length;\n\t\t\t\t},\n\n\t\t\t\tget inUse() {\n\t\t\t\t\treturn this.total - scope.nCachedObjects_;\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tget bindingsPerObject() {\n\t\t\t\treturn scope._bindings.length;\n\t\t\t}\n\n\t\t};\n\t}\n\n\tadd() {\n\t\tconst objects = this._objects,\n\t\t\t\t\tindicesByUUID = this._indicesByUUID,\n\t\t\t\t\tpaths = this._paths,\n\t\t\t\t\tparsedPaths = this._parsedPaths,\n\t\t\t\t\tbindings = this._bindings,\n\t\t\t\t\tnBindings = bindings.length;\n\t\tlet knownObject = undefined,\n\t\t\t\tnObjects = objects.length,\n\t\t\t\tnCachedObjects = this.nCachedObjects_;\n\n\t\tfor (let i = 0, n = arguments.length; i !== n; ++i) {\n\t\t\tconst object = arguments[i],\n\t\t\t\t\t\tuuid = object.uuid;\n\t\t\tlet index = indicesByUUID[uuid];\n\n\t\t\tif (index === undefined) {\n\t\t\t\t// unknown object -> add it to the ACTIVE region\n\t\t\t\tindex = nObjects++;\n\t\t\t\tindicesByUUID[uuid] = index;\n\t\t\t\tobjects.push(object); // accounting is done, now do the same for all bindings\n\n\t\t\t\tfor (let j = 0, m = nBindings; j !== m; ++j) {\n\t\t\t\t\tbindings[j].push(new PropertyBinding(object, paths[j], parsedPaths[j]));\n\t\t\t\t}\n\t\t\t} else if (index < nCachedObjects) {\n\t\t\t\tknownObject = objects[index]; // move existing object to the ACTIVE region\n\n\t\t\t\tconst firstActiveIndex = --nCachedObjects,\n\t\t\t\t\t\t\tlastCachedObject = objects[firstActiveIndex];\n\t\t\t\tindicesByUUID[lastCachedObject.uuid] = index;\n\t\t\t\tobjects[index] = lastCachedObject;\n\t\t\t\tindicesByUUID[uuid] = firstActiveIndex;\n\t\t\t\tobjects[firstActiveIndex] = object; // accounting is done, now do the same for all bindings\n\n\t\t\t\tfor (let j = 0, m = nBindings; j !== m; ++j) {\n\t\t\t\t\tconst bindingsForPath = bindings[j],\n\t\t\t\t\t\t\t\tlastCached = bindingsForPath[firstActiveIndex];\n\t\t\t\t\tlet binding = bindingsForPath[index];\n\t\t\t\t\tbindingsForPath[index] = lastCached;\n\n\t\t\t\t\tif (binding === undefined) {\n\t\t\t\t\t\t// since we do not bother to create new bindings\n\t\t\t\t\t\t// for objects that are cached, the binding may\n\t\t\t\t\t\t// or may not exist\n\t\t\t\t\t\tbinding = new PropertyBinding(object, paths[j], parsedPaths[j]);\n\t\t\t\t\t}\n\n\t\t\t\t\tbindingsForPath[firstActiveIndex] = binding;\n\t\t\t\t}\n\t\t\t} else if (objects[index] !== knownObject) {\n\t\t\t\tconsole.error('THREE.AnimationObjectGroup: Different objects with the same UUID ' + 'detected. Clean the caches or recreate your infrastructure when reloading scenes.');\n\t\t\t} // else the object is already where we want it to be\n\n\t\t} // for arguments\n\n\n\t\tthis.nCachedObjects_ = nCachedObjects;\n\t}\n\n\tremove() {\n\t\tconst objects = this._objects,\n\t\t\t\t\tindicesByUUID = this._indicesByUUID,\n\t\t\t\t\tbindings = this._bindings,\n\t\t\t\t\tnBindings = bindings.length;\n\t\tlet nCachedObjects = this.nCachedObjects_;\n\n\t\tfor (let i = 0, n = arguments.length; i !== n; ++i) {\n\t\t\tconst object = arguments[i],\n\t\t\t\t\t\tuuid = object.uuid,\n\t\t\t\t\t\tindex = indicesByUUID[uuid];\n\n\t\t\tif (index !== undefined && index >= nCachedObjects) {\n\t\t\t\t// move existing object into the CACHED region\n\t\t\t\tconst lastCachedIndex = nCachedObjects++,\n\t\t\t\t\t\t\tfirstActiveObject = objects[lastCachedIndex];\n\t\t\t\tindicesByUUID[firstActiveObject.uuid] = index;\n\t\t\t\tobjects[index] = firstActiveObject;\n\t\t\t\tindicesByUUID[uuid] = lastCachedIndex;\n\t\t\t\tobjects[lastCachedIndex] = object; // accounting is done, now do the same for all bindings\n\n\t\t\t\tfor (let j = 0, m = nBindings; j !== m; ++j) {\n\t\t\t\t\tconst bindingsForPath = bindings[j],\n\t\t\t\t\t\t\t\tfirstActive = bindingsForPath[lastCachedIndex],\n\t\t\t\t\t\t\t\tbinding = bindingsForPath[index];\n\t\t\t\t\tbindingsForPath[index] = firstActive;\n\t\t\t\t\tbindingsForPath[lastCachedIndex] = binding;\n\t\t\t\t}\n\t\t\t}\n\t\t} // for arguments\n\n\n\t\tthis.nCachedObjects_ = nCachedObjects;\n\t} // remove & forget\n\n\n\tuncache() {\n\t\tconst objects = this._objects,\n\t\t\t\t\tindicesByUUID = this._indicesByUUID,\n\t\t\t\t\tbindings = this._bindings,\n\t\t\t\t\tnBindings = bindings.length;\n\t\tlet nCachedObjects = this.nCachedObjects_,\n\t\t\t\tnObjects = objects.length;\n\n\t\tfor (let i = 0, n = arguments.length; i !== n; ++i) {\n\t\t\tconst object = arguments[i],\n\t\t\t\t\t\tuuid = object.uuid,\n\t\t\t\t\t\tindex = indicesByUUID[uuid];\n\n\t\t\tif (index !== undefined) {\n\t\t\t\tdelete indicesByUUID[uuid];\n\n\t\t\t\tif (index < nCachedObjects) {\n\t\t\t\t\t// object is cached, shrink the CACHED region\n\t\t\t\t\tconst firstActiveIndex = --nCachedObjects,\n\t\t\t\t\t\t\t\tlastCachedObject = objects[firstActiveIndex],\n\t\t\t\t\t\t\t\tlastIndex = --nObjects,\n\t\t\t\t\t\t\t\tlastObject = objects[lastIndex]; // last cached object takes this object's place\n\n\t\t\t\t\tindicesByUUID[lastCachedObject.uuid] = index;\n\t\t\t\t\tobjects[index] = lastCachedObject; // last object goes to the activated slot and pop\n\n\t\t\t\t\tindicesByUUID[lastObject.uuid] = firstActiveIndex;\n\t\t\t\t\tobjects[firstActiveIndex] = lastObject;\n\t\t\t\t\tobjects.pop(); // accounting is done, now do the same for all bindings\n\n\t\t\t\t\tfor (let j = 0, m = nBindings; j !== m; ++j) {\n\t\t\t\t\t\tconst bindingsForPath = bindings[j],\n\t\t\t\t\t\t\t\t\tlastCached = bindingsForPath[firstActiveIndex],\n\t\t\t\t\t\t\t\t\tlast = bindingsForPath[lastIndex];\n\t\t\t\t\t\tbindingsForPath[index] = lastCached;\n\t\t\t\t\t\tbindingsForPath[firstActiveIndex] = last;\n\t\t\t\t\t\tbindingsForPath.pop();\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// object is active, just swap with the last and pop\n\t\t\t\t\tconst lastIndex = --nObjects,\n\t\t\t\t\t\t\t\tlastObject = objects[lastIndex];\n\n\t\t\t\t\tif (lastIndex > 0) {\n\t\t\t\t\t\tindicesByUUID[lastObject.uuid] = index;\n\t\t\t\t\t}\n\n\t\t\t\t\tobjects[index] = lastObject;\n\t\t\t\t\tobjects.pop(); // accounting is done, now do the same for all bindings\n\n\t\t\t\t\tfor (let j = 0, m = nBindings; j !== m; ++j) {\n\t\t\t\t\t\tconst bindingsForPath = bindings[j];\n\t\t\t\t\t\tbindingsForPath[index] = bindingsForPath[lastIndex];\n\t\t\t\t\t\tbindingsForPath.pop();\n\t\t\t\t\t}\n\t\t\t\t} // cached or active\n\n\t\t\t} // if object is known\n\n\t\t} // for arguments\n\n\n\t\tthis.nCachedObjects_ = nCachedObjects;\n\t} // Internal interface used by befriended PropertyBinding.Composite:\n\n\n\tsubscribe_(path, parsedPath) {\n\t\t// returns an array of bindings for the given path that is changed\n\t\t// according to the contained objects in the group\n\t\tconst indicesByPath = this._bindingsIndicesByPath;\n\t\tlet index = indicesByPath[path];\n\t\tconst bindings = this._bindings;\n\t\tif (index !== undefined) return bindings[index];\n\t\tconst paths = this._paths,\n\t\t\t\t\tparsedPaths = this._parsedPaths,\n\t\t\t\t\tobjects = this._objects,\n\t\t\t\t\tnObjects = objects.length,\n\t\t\t\t\tnCachedObjects = this.nCachedObjects_,\n\t\t\t\t\tbindingsForPath = new Array(nObjects);\n\t\tindex = bindings.length;\n\t\tindicesByPath[path] = index;\n\t\tpaths.push(path);\n\t\tparsedPaths.push(parsedPath);\n\t\tbindings.push(bindingsForPath);\n\n\t\tfor (let i = nCachedObjects, n = objects.length; i !== n; ++i) {\n\t\t\tconst object = objects[i];\n\t\t\tbindingsForPath[i] = new PropertyBinding(object, path, parsedPath);\n\t\t}\n\n\t\treturn bindingsForPath;\n\t}\n\n\tunsubscribe_(path) {\n\t\t// tells the group to forget about a property path and no longer\n\t\t// update the array previously obtained with 'subscribe_'\n\t\tconst indicesByPath = this._bindingsIndicesByPath,\n\t\t\t\t\tindex = indicesByPath[path];\n\n\t\tif (index !== undefined) {\n\t\t\tconst paths = this._paths,\n\t\t\t\t\t\tparsedPaths = this._parsedPaths,\n\t\t\t\t\t\tbindings = this._bindings,\n\t\t\t\t\t\tlastBindingsIndex = bindings.length - 1,\n\t\t\t\t\t\tlastBindings = bindings[lastBindingsIndex],\n\t\t\t\t\t\tlastBindingsPath = path[lastBindingsIndex];\n\t\t\tindicesByPath[lastBindingsPath] = index;\n\t\t\tbindings[index] = lastBindings;\n\t\t\tbindings.pop();\n\t\t\tparsedPaths[index] = parsedPaths[lastBindingsIndex];\n\t\t\tparsedPaths.pop();\n\t\t\tpaths[index] = paths[lastBindingsIndex];\n\t\t\tpaths.pop();\n\t\t}\n\t}\n\n}\n\nclass AnimationAction {\n\tconstructor(mixer, clip, localRoot = null, blendMode = clip.blendMode) {\n\t\tthis._mixer = mixer;\n\t\tthis._clip = clip;\n\t\tthis._localRoot = localRoot;\n\t\tthis.blendMode = blendMode;\n\t\tconst tracks = clip.tracks,\n\t\t\t\t\tnTracks = tracks.length,\n\t\t\t\t\tinterpolants = new Array(nTracks);\n\t\tconst interpolantSettings = {\n\t\t\tendingStart: ZeroCurvatureEnding,\n\t\t\tendingEnd: ZeroCurvatureEnding\n\t\t};\n\n\t\tfor (let i = 0; i !== nTracks; ++i) {\n\t\t\tconst interpolant = tracks[i].createInterpolant(null);\n\t\t\tinterpolants[i] = interpolant;\n\t\t\tinterpolant.settings = interpolantSettings;\n\t\t}\n\n\t\tthis._interpolantSettings = interpolantSettings;\n\t\tthis._interpolants = interpolants; // bound by the mixer\n\t\t// inside: PropertyMixer (managed by the mixer)\n\n\t\tthis._propertyBindings = new Array(nTracks);\n\t\tthis._cacheIndex = null; // for the memory manager\n\n\t\tthis._byClipCacheIndex = null; // for the memory manager\n\n\t\tthis._timeScaleInterpolant = null;\n\t\tthis._weightInterpolant = null;\n\t\tthis.loop = LoopRepeat;\n\t\tthis._loopCount = -1; // global mixer time when the action is to be started\n\t\t// it's set back to 'null' upon start of the action\n\n\t\tthis._startTime = null; // scaled local time of the action\n\t\t// gets clamped or wrapped to 0..clip.duration according to loop\n\n\t\tthis.time = 0;\n\t\tthis.timeScale = 1;\n\t\tthis._effectiveTimeScale = 1;\n\t\tthis.weight = 1;\n\t\tthis._effectiveWeight = 1;\n\t\tthis.repetitions = Infinity; // no. of repetitions when looping\n\n\t\tthis.paused = false; // true -> zero effective time scale\n\n\t\tthis.enabled = true; // false -> zero effective weight\n\n\t\tthis.clampWhenFinished = false; // keep feeding the last frame?\n\n\t\tthis.zeroSlopeAtStart = true; // for smooth interpolation w/o separate\n\n\t\tthis.zeroSlopeAtEnd = true; // clips for start, loop and end\n\t} // State & Scheduling\n\n\n\tplay() {\n\t\tthis._mixer._activateAction(this);\n\n\t\treturn this;\n\t}\n\n\tstop() {\n\t\tthis._mixer._deactivateAction(this);\n\n\t\treturn this.reset();\n\t}\n\n\treset() {\n\t\tthis.paused = false;\n\t\tthis.enabled = true;\n\t\tthis.time = 0; // restart clip\n\n\t\tthis._loopCount = -1; // forget previous loops\n\n\t\tthis._startTime = null; // forget scheduling\n\n\t\treturn this.stopFading().stopWarping();\n\t}\n\n\tisRunning() {\n\t\treturn this.enabled && !this.paused && this.timeScale !== 0 && this._startTime === null && this._mixer._isActiveAction(this);\n\t} // return true when play has been called\n\n\n\tisScheduled() {\n\t\treturn this._mixer._isActiveAction(this);\n\t}\n\n\tstartAt(time) {\n\t\tthis._startTime = time;\n\t\treturn this;\n\t}\n\n\tsetLoop(mode, repetitions) {\n\t\tthis.loop = mode;\n\t\tthis.repetitions = repetitions;\n\t\treturn this;\n\t} // Weight\n\t// set the weight stopping any scheduled fading\n\t// although .enabled = false yields an effective weight of zero, this\n\t// method does *not* change .enabled, because it would be confusing\n\n\n\tsetEffectiveWeight(weight) {\n\t\tthis.weight = weight; // note: same logic as when updated at runtime\n\n\t\tthis._effectiveWeight = this.enabled ? weight : 0;\n\t\treturn this.stopFading();\n\t} // return the weight considering fading and .enabled\n\n\n\tgetEffectiveWeight() {\n\t\treturn this._effectiveWeight;\n\t}\n\n\tfadeIn(duration) {\n\t\treturn this._scheduleFading(duration, 0, 1);\n\t}\n\n\tfadeOut(duration) {\n\t\treturn this._scheduleFading(duration, 1, 0);\n\t}\n\n\tcrossFadeFrom(fadeOutAction, duration, warp) {\n\t\tfadeOutAction.fadeOut(duration);\n\t\tthis.fadeIn(duration);\n\n\t\tif (warp) {\n\t\t\tconst fadeInDuration = this._clip.duration,\n\t\t\t\t\t\tfadeOutDuration = fadeOutAction._clip.duration,\n\t\t\t\t\t\tstartEndRatio = fadeOutDuration / fadeInDuration,\n\t\t\t\t\t\tendStartRatio = fadeInDuration / fadeOutDuration;\n\t\t\tfadeOutAction.warp(1.0, startEndRatio, duration);\n\t\t\tthis.warp(endStartRatio, 1.0, duration);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tcrossFadeTo(fadeInAction, duration, warp) {\n\t\treturn fadeInAction.crossFadeFrom(this, duration, warp);\n\t}\n\n\tstopFading() {\n\t\tconst weightInterpolant = this._weightInterpolant;\n\n\t\tif (weightInterpolant !== null) {\n\t\t\tthis._weightInterpolant = null;\n\n\t\t\tthis._mixer._takeBackControlInterpolant(weightInterpolant);\n\t\t}\n\n\t\treturn this;\n\t} // Time Scale Control\n\t// set the time scale stopping any scheduled warping\n\t// although .paused = true yields an effective time scale of zero, this\n\t// method does *not* change .paused, because it would be confusing\n\n\n\tsetEffectiveTimeScale(timeScale) {\n\t\tthis.timeScale = timeScale;\n\t\tthis._effectiveTimeScale = this.paused ? 0 : timeScale;\n\t\treturn this.stopWarping();\n\t} // return the time scale considering warping and .paused\n\n\n\tgetEffectiveTimeScale() {\n\t\treturn this._effectiveTimeScale;\n\t}\n\n\tsetDuration(duration) {\n\t\tthis.timeScale = this._clip.duration / duration;\n\t\treturn this.stopWarping();\n\t}\n\n\tsyncWith(action) {\n\t\tthis.time = action.time;\n\t\tthis.timeScale = action.timeScale;\n\t\treturn this.stopWarping();\n\t}\n\n\thalt(duration) {\n\t\treturn this.warp(this._effectiveTimeScale, 0, duration);\n\t}\n\n\twarp(startTimeScale, endTimeScale, duration) {\n\t\tconst mixer = this._mixer,\n\t\t\t\t\tnow = mixer.time,\n\t\t\t\t\ttimeScale = this.timeScale;\n\t\tlet interpolant = this._timeScaleInterpolant;\n\n\t\tif (interpolant === null) {\n\t\t\tinterpolant = mixer._lendControlInterpolant();\n\t\t\tthis._timeScaleInterpolant = interpolant;\n\t\t}\n\n\t\tconst times = interpolant.parameterPositions,\n\t\t\t\t\tvalues = interpolant.sampleValues;\n\t\ttimes[0] = now;\n\t\ttimes[1] = now + duration;\n\t\tvalues[0] = startTimeScale / timeScale;\n\t\tvalues[1] = endTimeScale / timeScale;\n\t\treturn this;\n\t}\n\n\tstopWarping() {\n\t\tconst timeScaleInterpolant = this._timeScaleInterpolant;\n\n\t\tif (timeScaleInterpolant !== null) {\n\t\t\tthis._timeScaleInterpolant = null;\n\n\t\t\tthis._mixer._takeBackControlInterpolant(timeScaleInterpolant);\n\t\t}\n\n\t\treturn this;\n\t} // Object Accessors\n\n\n\tgetMixer() {\n\t\treturn this._mixer;\n\t}\n\n\tgetClip() {\n\t\treturn this._clip;\n\t}\n\n\tgetRoot() {\n\t\treturn this._localRoot || this._mixer._root;\n\t} // Interna\n\n\n\t_update(time, deltaTime, timeDirection, accuIndex) {\n\t\t// called by the mixer\n\t\tif (!this.enabled) {\n\t\t\t// call ._updateWeight() to update ._effectiveWeight\n\t\t\tthis._updateWeight(time);\n\n\t\t\treturn;\n\t\t}\n\n\t\tconst startTime = this._startTime;\n\n\t\tif (startTime !== null) {\n\t\t\t// check for scheduled start of action\n\t\t\tconst timeRunning = (time - startTime) * timeDirection;\n\n\t\t\tif (timeRunning < 0 || timeDirection === 0) {\n\t\t\t\treturn; // yet to come / don't decide when delta = 0\n\t\t\t} // start\n\n\n\t\t\tthis._startTime = null; // unschedule\n\n\t\t\tdeltaTime = timeDirection * timeRunning;\n\t\t} // apply time scale and advance time\n\n\n\t\tdeltaTime *= this._updateTimeScale(time);\n\n\t\tconst clipTime = this._updateTime(deltaTime); // note: _updateTime may disable the action resulting in\n\t\t// an effective weight of 0\n\n\n\t\tconst weight = this._updateWeight(time);\n\n\t\tif (weight > 0) {\n\t\t\tconst interpolants = this._interpolants;\n\t\t\tconst propertyMixers = this._propertyBindings;\n\n\t\t\tswitch (this.blendMode) {\n\t\t\t\tcase AdditiveAnimationBlendMode:\n\t\t\t\t\tfor (let j = 0, m = interpolants.length; j !== m; ++j) {\n\t\t\t\t\t\tinterpolants[j].evaluate(clipTime);\n\t\t\t\t\t\tpropertyMixers[j].accumulateAdditive(weight);\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase NormalAnimationBlendMode:\n\t\t\t\tdefault:\n\t\t\t\t\tfor (let j = 0, m = interpolants.length; j !== m; ++j) {\n\t\t\t\t\t\tinterpolants[j].evaluate(clipTime);\n\t\t\t\t\t\tpropertyMixers[j].accumulate(accuIndex, weight);\n\t\t\t\t\t}\n\n\t\t\t}\n\t\t}\n\t}\n\n\t_updateWeight(time) {\n\t\tlet weight = 0;\n\n\t\tif (this.enabled) {\n\t\t\tweight = this.weight;\n\t\t\tconst interpolant = this._weightInterpolant;\n\n\t\t\tif (interpolant !== null) {\n\t\t\t\tconst interpolantValue = interpolant.evaluate(time)[0];\n\t\t\t\tweight *= interpolantValue;\n\n\t\t\t\tif (time > interpolant.parameterPositions[1]) {\n\t\t\t\t\tthis.stopFading();\n\n\t\t\t\t\tif (interpolantValue === 0) {\n\t\t\t\t\t\t// faded out, disable\n\t\t\t\t\t\tthis.enabled = false;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis._effectiveWeight = weight;\n\t\treturn weight;\n\t}\n\n\t_updateTimeScale(time) {\n\t\tlet timeScale = 0;\n\n\t\tif (!this.paused) {\n\t\t\ttimeScale = this.timeScale;\n\t\t\tconst interpolant = this._timeScaleInterpolant;\n\n\t\t\tif (interpolant !== null) {\n\t\t\t\tconst interpolantValue = interpolant.evaluate(time)[0];\n\t\t\t\ttimeScale *= interpolantValue;\n\n\t\t\t\tif (time > interpolant.parameterPositions[1]) {\n\t\t\t\t\tthis.stopWarping();\n\n\t\t\t\t\tif (timeScale === 0) {\n\t\t\t\t\t\t// motion has halted, pause\n\t\t\t\t\t\tthis.paused = true;\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// warp done - apply final time scale\n\t\t\t\t\t\tthis.timeScale = timeScale;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis._effectiveTimeScale = timeScale;\n\t\treturn timeScale;\n\t}\n\n\t_updateTime(deltaTime) {\n\t\tconst duration = this._clip.duration;\n\t\tconst loop = this.loop;\n\t\tlet time = this.time + deltaTime;\n\t\tlet loopCount = this._loopCount;\n\t\tconst pingPong = loop === LoopPingPong;\n\n\t\tif (deltaTime === 0) {\n\t\t\tif (loopCount === -1) return time;\n\t\t\treturn pingPong && (loopCount & 1) === 1 ? duration - time : time;\n\t\t}\n\n\t\tif (loop === LoopOnce) {\n\t\t\tif (loopCount === -1) {\n\t\t\t\t// just started\n\t\t\t\tthis._loopCount = 0;\n\n\t\t\t\tthis._setEndings(true, true, false);\n\t\t\t}\n\n\t\t\thandle_stop: {\n\t\t\t\tif (time >= duration) {\n\t\t\t\t\ttime = duration;\n\t\t\t\t} else if (time < 0) {\n\t\t\t\t\ttime = 0;\n\t\t\t\t} else {\n\t\t\t\t\tthis.time = time;\n\t\t\t\t\tbreak handle_stop;\n\t\t\t\t}\n\n\t\t\t\tif (this.clampWhenFinished) this.paused = true;else this.enabled = false;\n\t\t\t\tthis.time = time;\n\n\t\t\t\tthis._mixer.dispatchEvent({\n\t\t\t\t\ttype: 'finished',\n\t\t\t\t\taction: this,\n\t\t\t\t\tdirection: deltaTime < 0 ? -1 : 1\n\t\t\t\t});\n\t\t\t}\n\t\t} else {\n\t\t\t// repetitive Repeat or PingPong\n\t\t\tif (loopCount === -1) {\n\t\t\t\t// just started\n\t\t\t\tif (deltaTime >= 0) {\n\t\t\t\t\tloopCount = 0;\n\n\t\t\t\t\tthis._setEndings(true, this.repetitions === 0, pingPong);\n\t\t\t\t} else {\n\t\t\t\t\t// when looping in reverse direction, the initial\n\t\t\t\t\t// transition through zero counts as a repetition,\n\t\t\t\t\t// so leave loopCount at -1\n\t\t\t\t\tthis._setEndings(this.repetitions === 0, true, pingPong);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (time >= duration || time < 0) {\n\t\t\t\t// wrap around\n\t\t\t\tconst loopDelta = Math.floor(time / duration); // signed\n\n\t\t\t\ttime -= duration * loopDelta;\n\t\t\t\tloopCount += Math.abs(loopDelta);\n\t\t\t\tconst pending = this.repetitions - loopCount;\n\n\t\t\t\tif (pending <= 0) {\n\t\t\t\t\t// have to stop (switch state, clamp time, fire event)\n\t\t\t\t\tif (this.clampWhenFinished) this.paused = true;else this.enabled = false;\n\t\t\t\t\ttime = deltaTime > 0 ? duration : 0;\n\t\t\t\t\tthis.time = time;\n\n\t\t\t\t\tthis._mixer.dispatchEvent({\n\t\t\t\t\t\ttype: 'finished',\n\t\t\t\t\t\taction: this,\n\t\t\t\t\t\tdirection: deltaTime > 0 ? 1 : -1\n\t\t\t\t\t});\n\t\t\t\t} else {\n\t\t\t\t\t// keep running\n\t\t\t\t\tif (pending === 1) {\n\t\t\t\t\t\t// entering the last round\n\t\t\t\t\t\tconst atStart = deltaTime < 0;\n\n\t\t\t\t\t\tthis._setEndings(atStart, !atStart, pingPong);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis._setEndings(false, false, pingPong);\n\t\t\t\t\t}\n\n\t\t\t\t\tthis._loopCount = loopCount;\n\t\t\t\t\tthis.time = time;\n\n\t\t\t\t\tthis._mixer.dispatchEvent({\n\t\t\t\t\t\ttype: 'loop',\n\t\t\t\t\t\taction: this,\n\t\t\t\t\t\tloopDelta: loopDelta\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthis.time = time;\n\t\t\t}\n\n\t\t\tif (pingPong && (loopCount & 1) === 1) {\n\t\t\t\t// invert time for the \"pong round\"\n\t\t\t\treturn duration - time;\n\t\t\t}\n\t\t}\n\n\t\treturn time;\n\t}\n\n\t_setEndings(atStart, atEnd, pingPong) {\n\t\tconst settings = this._interpolantSettings;\n\n\t\tif (pingPong) {\n\t\t\tsettings.endingStart = ZeroSlopeEnding;\n\t\t\tsettings.endingEnd = ZeroSlopeEnding;\n\t\t} else {\n\t\t\t// assuming for LoopOnce atStart == atEnd == true\n\t\t\tif (atStart) {\n\t\t\t\tsettings.endingStart = this.zeroSlopeAtStart ? ZeroSlopeEnding : ZeroCurvatureEnding;\n\t\t\t} else {\n\t\t\t\tsettings.endingStart = WrapAroundEnding;\n\t\t\t}\n\n\t\t\tif (atEnd) {\n\t\t\t\tsettings.endingEnd = this.zeroSlopeAtEnd ? ZeroSlopeEnding : ZeroCurvatureEnding;\n\t\t\t} else {\n\t\t\t\tsettings.endingEnd = WrapAroundEnding;\n\t\t\t}\n\t\t}\n\t}\n\n\t_scheduleFading(duration, weightNow, weightThen) {\n\t\tconst mixer = this._mixer,\n\t\t\t\t\tnow = mixer.time;\n\t\tlet interpolant = this._weightInterpolant;\n\n\t\tif (interpolant === null) {\n\t\t\tinterpolant = mixer._lendControlInterpolant();\n\t\t\tthis._weightInterpolant = interpolant;\n\t\t}\n\n\t\tconst times = interpolant.parameterPositions,\n\t\t\t\t\tvalues = interpolant.sampleValues;\n\t\ttimes[0] = now;\n\t\tvalues[0] = weightNow;\n\t\ttimes[1] = now + duration;\n\t\tvalues[1] = weightThen;\n\t\treturn this;\n\t}\n\n}\n\nconst _controlInterpolantsResultBuffer = /*@__PURE__*/new Float32Array(1);\n\nclass AnimationMixer extends EventDispatcher {\n\tconstructor(root) {\n\t\tsuper();\n\t\tthis._root = root;\n\n\t\tthis._initMemoryManager();\n\n\t\tthis._accuIndex = 0;\n\t\tthis.time = 0;\n\t\tthis.timeScale = 1.0;\n\t}\n\n\t_bindAction(action, prototypeAction) {\n\t\tconst root = action._localRoot || this._root,\n\t\t\t\t\ttracks = action._clip.tracks,\n\t\t\t\t\tnTracks = tracks.length,\n\t\t\t\t\tbindings = action._propertyBindings,\n\t\t\t\t\tinterpolants = action._interpolants,\n\t\t\t\t\trootUuid = root.uuid,\n\t\t\t\t\tbindingsByRoot = this._bindingsByRootAndName;\n\t\tlet bindingsByName = bindingsByRoot[rootUuid];\n\n\t\tif (bindingsByName === undefined) {\n\t\t\tbindingsByName = {};\n\t\t\tbindingsByRoot[rootUuid] = bindingsByName;\n\t\t}\n\n\t\tfor (let i = 0; i !== nTracks; ++i) {\n\t\t\tconst track = tracks[i],\n\t\t\t\t\t\ttrackName = track.name;\n\t\t\tlet binding = bindingsByName[trackName];\n\n\t\t\tif (binding !== undefined) {\n\t\t\t\t++binding.referenceCount;\n\t\t\t\tbindings[i] = binding;\n\t\t\t} else {\n\t\t\t\tbinding = bindings[i];\n\n\t\t\t\tif (binding !== undefined) {\n\t\t\t\t\t// existing binding, make sure the cache knows\n\t\t\t\t\tif (binding._cacheIndex === null) {\n\t\t\t\t\t\t++binding.referenceCount;\n\n\t\t\t\t\t\tthis._addInactiveBinding(binding, rootUuid, trackName);\n\t\t\t\t\t}\n\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst path = prototypeAction && prototypeAction._propertyBindings[i].binding.parsedPath;\n\t\t\t\tbinding = new PropertyMixer(PropertyBinding.create(root, trackName, path), track.ValueTypeName, track.getValueSize());\n\t\t\t\t++binding.referenceCount;\n\n\t\t\t\tthis._addInactiveBinding(binding, rootUuid, trackName);\n\n\t\t\t\tbindings[i] = binding;\n\t\t\t}\n\n\t\t\tinterpolants[i].resultBuffer = binding.buffer;\n\t\t}\n\t}\n\n\t_activateAction(action) {\n\t\tif (!this._isActiveAction(action)) {\n\t\t\tif (action._cacheIndex === null) {\n\t\t\t\t// this action has been forgotten by the cache, but the user\n\t\t\t\t// appears to be still using it -> rebind\n\t\t\t\tconst rootUuid = (action._localRoot || this._root).uuid,\n\t\t\t\t\t\t\tclipUuid = action._clip.uuid,\n\t\t\t\t\t\t\tactionsForClip = this._actionsByClip[clipUuid];\n\n\t\t\t\tthis._bindAction(action, actionsForClip && actionsForClip.knownActions[0]);\n\n\t\t\t\tthis._addInactiveAction(action, clipUuid, rootUuid);\n\t\t\t}\n\n\t\t\tconst bindings = action._propertyBindings; // increment reference counts / sort out state\n\n\t\t\tfor (let i = 0, n = bindings.length; i !== n; ++i) {\n\t\t\t\tconst binding = bindings[i];\n\n\t\t\t\tif (binding.useCount++ === 0) {\n\t\t\t\t\tthis._lendBinding(binding);\n\n\t\t\t\t\tbinding.saveOriginalState();\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis._lendAction(action);\n\t\t}\n\t}\n\n\t_deactivateAction(action) {\n\t\tif (this._isActiveAction(action)) {\n\t\t\tconst bindings = action._propertyBindings; // decrement reference counts / sort out state\n\n\t\t\tfor (let i = 0, n = bindings.length; i !== n; ++i) {\n\t\t\t\tconst binding = bindings[i];\n\n\t\t\t\tif (--binding.useCount === 0) {\n\t\t\t\t\tbinding.restoreOriginalState();\n\n\t\t\t\t\tthis._takeBackBinding(binding);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis._takeBackAction(action);\n\t\t}\n\t} // Memory manager\n\n\n\t_initMemoryManager() {\n\t\tthis._actions = []; // 'nActiveActions' followed by inactive ones\n\n\t\tthis._nActiveActions = 0;\n\t\tthis._actionsByClip = {}; // inside:\n\t\t// {\n\t\t// \tknownActions: Array< AnimationAction > - used as prototypes\n\t\t// \tactionByRoot: AnimationAction - lookup\n\t\t// }\n\n\t\tthis._bindings = []; // 'nActiveBindings' followed by inactive ones\n\n\t\tthis._nActiveBindings = 0;\n\t\tthis._bindingsByRootAndName = {}; // inside: Map< name, PropertyMixer >\n\n\t\tthis._controlInterpolants = []; // same game as above\n\n\t\tthis._nActiveControlInterpolants = 0;\n\t\tconst scope = this;\n\t\tthis.stats = {\n\t\t\tactions: {\n\t\t\t\tget total() {\n\t\t\t\t\treturn scope._actions.length;\n\t\t\t\t},\n\n\t\t\t\tget inUse() {\n\t\t\t\t\treturn scope._nActiveActions;\n\t\t\t\t}\n\n\t\t\t},\n\t\t\tbindings: {\n\t\t\t\tget total() {\n\t\t\t\t\treturn scope._bindings.length;\n\t\t\t\t},\n\n\t\t\t\tget inUse() {\n\t\t\t\t\treturn scope._nActiveBindings;\n\t\t\t\t}\n\n\t\t\t},\n\t\t\tcontrolInterpolants: {\n\t\t\t\tget total() {\n\t\t\t\t\treturn scope._controlInterpolants.length;\n\t\t\t\t},\n\n\t\t\t\tget inUse() {\n\t\t\t\t\treturn scope._nActiveControlInterpolants;\n\t\t\t\t}\n\n\t\t\t}\n\t\t};\n\t} // Memory management for AnimationAction objects\n\n\n\t_isActiveAction(action) {\n\t\tconst index = action._cacheIndex;\n\t\treturn index !== null && index < this._nActiveActions;\n\t}\n\n\t_addInactiveAction(action, clipUuid, rootUuid) {\n\t\tconst actions = this._actions,\n\t\t\t\t\tactionsByClip = this._actionsByClip;\n\t\tlet actionsForClip = actionsByClip[clipUuid];\n\n\t\tif (actionsForClip === undefined) {\n\t\t\tactionsForClip = {\n\t\t\t\tknownActions: [action],\n\t\t\t\tactionByRoot: {}\n\t\t\t};\n\t\t\taction._byClipCacheIndex = 0;\n\t\t\tactionsByClip[clipUuid] = actionsForClip;\n\t\t} else {\n\t\t\tconst knownActions = actionsForClip.knownActions;\n\t\t\taction._byClipCacheIndex = knownActions.length;\n\t\t\tknownActions.push(action);\n\t\t}\n\n\t\taction._cacheIndex = actions.length;\n\t\tactions.push(action);\n\t\tactionsForClip.actionByRoot[rootUuid] = action;\n\t}\n\n\t_removeInactiveAction(action) {\n\t\tconst actions = this._actions,\n\t\t\t\t\tlastInactiveAction = actions[actions.length - 1],\n\t\t\t\t\tcacheIndex = action._cacheIndex;\n\t\tlastInactiveAction._cacheIndex = cacheIndex;\n\t\tactions[cacheIndex] = lastInactiveAction;\n\t\tactions.pop();\n\t\taction._cacheIndex = null;\n\t\tconst clipUuid = action._clip.uuid,\n\t\t\t\t\tactionsByClip = this._actionsByClip,\n\t\t\t\t\tactionsForClip = actionsByClip[clipUuid],\n\t\t\t\t\tknownActionsForClip = actionsForClip.knownActions,\n\t\t\t\t\tlastKnownAction = knownActionsForClip[knownActionsForClip.length - 1],\n\t\t\t\t\tbyClipCacheIndex = action._byClipCacheIndex;\n\t\tlastKnownAction._byClipCacheIndex = byClipCacheIndex;\n\t\tknownActionsForClip[byClipCacheIndex] = lastKnownAction;\n\t\tknownActionsForClip.pop();\n\t\taction._byClipCacheIndex = null;\n\t\tconst actionByRoot = actionsForClip.actionByRoot,\n\t\t\t\t\trootUuid = (action._localRoot || this._root).uuid;\n\t\tdelete actionByRoot[rootUuid];\n\n\t\tif (knownActionsForClip.length === 0) {\n\t\t\tdelete actionsByClip[clipUuid];\n\t\t}\n\n\t\tthis._removeInactiveBindingsForAction(action);\n\t}\n\n\t_removeInactiveBindingsForAction(action) {\n\t\tconst bindings = action._propertyBindings;\n\n\t\tfor (let i = 0, n = bindings.length; i !== n; ++i) {\n\t\t\tconst binding = bindings[i];\n\n\t\t\tif (--binding.referenceCount === 0) {\n\t\t\t\tthis._removeInactiveBinding(binding);\n\t\t\t}\n\t\t}\n\t}\n\n\t_lendAction(action) {\n\t\t// [ active actions |\tinactive actions\t]\n\t\t// [\tactive actions >| inactive actions ]\n\t\t//\t\t\t\t\t\t\t\t s\t\t\t\ta\n\t\t//\t\t\t\t\t\t\t\t\t<-swap->\n\t\t//\t\t\t\t\t\t\t\t a\t\t\t\ts\n\t\tconst actions = this._actions,\n\t\t\t\t\tprevIndex = action._cacheIndex,\n\t\t\t\t\tlastActiveIndex = this._nActiveActions++,\n\t\t\t\t\tfirstInactiveAction = actions[lastActiveIndex];\n\t\taction._cacheIndex = lastActiveIndex;\n\t\tactions[lastActiveIndex] = action;\n\t\tfirstInactiveAction._cacheIndex = prevIndex;\n\t\tactions[prevIndex] = firstInactiveAction;\n\t}\n\n\t_takeBackAction(action) {\n\t\t// [\tactive actions\t| inactive actions ]\n\t\t// [ active actions |< inactive actions\t]\n\t\t//\t\t\t\ta\t\t\t\ts\n\t\t//\t\t\t\t <-swap->\n\t\t//\t\t\t\ts\t\t\t\ta\n\t\tconst actions = this._actions,\n\t\t\t\t\tprevIndex = action._cacheIndex,\n\t\t\t\t\tfirstInactiveIndex = --this._nActiveActions,\n\t\t\t\t\tlastActiveAction = actions[firstInactiveIndex];\n\t\taction._cacheIndex = firstInactiveIndex;\n\t\tactions[firstInactiveIndex] = action;\n\t\tlastActiveAction._cacheIndex = prevIndex;\n\t\tactions[prevIndex] = lastActiveAction;\n\t} // Memory management for PropertyMixer objects\n\n\n\t_addInactiveBinding(binding, rootUuid, trackName) {\n\t\tconst bindingsByRoot = this._bindingsByRootAndName,\n\t\t\t\t\tbindings = this._bindings;\n\t\tlet bindingByName = bindingsByRoot[rootUuid];\n\n\t\tif (bindingByName === undefined) {\n\t\t\tbindingByName = {};\n\t\t\tbindingsByRoot[rootUuid] = bindingByName;\n\t\t}\n\n\t\tbindingByName[trackName] = binding;\n\t\tbinding._cacheIndex = bindings.length;\n\t\tbindings.push(binding);\n\t}\n\n\t_removeInactiveBinding(binding) {\n\t\tconst bindings = this._bindings,\n\t\t\t\t\tpropBinding = binding.binding,\n\t\t\t\t\trootUuid = propBinding.rootNode.uuid,\n\t\t\t\t\ttrackName = propBinding.path,\n\t\t\t\t\tbindingsByRoot = this._bindingsByRootAndName,\n\t\t\t\t\tbindingByName = bindingsByRoot[rootUuid],\n\t\t\t\t\tlastInactiveBinding = bindings[bindings.length - 1],\n\t\t\t\t\tcacheIndex = binding._cacheIndex;\n\t\tlastInactiveBinding._cacheIndex = cacheIndex;\n\t\tbindings[cacheIndex] = lastInactiveBinding;\n\t\tbindings.pop();\n\t\tdelete bindingByName[trackName];\n\n\t\tif (Object.keys(bindingByName).length === 0) {\n\t\t\tdelete bindingsByRoot[rootUuid];\n\t\t}\n\t}\n\n\t_lendBinding(binding) {\n\t\tconst bindings = this._bindings,\n\t\t\t\t\tprevIndex = binding._cacheIndex,\n\t\t\t\t\tlastActiveIndex = this._nActiveBindings++,\n\t\t\t\t\tfirstInactiveBinding = bindings[lastActiveIndex];\n\t\tbinding._cacheIndex = lastActiveIndex;\n\t\tbindings[lastActiveIndex] = binding;\n\t\tfirstInactiveBinding._cacheIndex = prevIndex;\n\t\tbindings[prevIndex] = firstInactiveBinding;\n\t}\n\n\t_takeBackBinding(binding) {\n\t\tconst bindings = this._bindings,\n\t\t\t\t\tprevIndex = binding._cacheIndex,\n\t\t\t\t\tfirstInactiveIndex = --this._nActiveBindings,\n\t\t\t\t\tlastActiveBinding = bindings[firstInactiveIndex];\n\t\tbinding._cacheIndex = firstInactiveIndex;\n\t\tbindings[firstInactiveIndex] = binding;\n\t\tlastActiveBinding._cacheIndex = prevIndex;\n\t\tbindings[prevIndex] = lastActiveBinding;\n\t} // Memory management of Interpolants for weight and time scale\n\n\n\t_lendControlInterpolant() {\n\t\tconst interpolants = this._controlInterpolants,\n\t\t\t\t\tlastActiveIndex = this._nActiveControlInterpolants++;\n\t\tlet interpolant = interpolants[lastActiveIndex];\n\n\t\tif (interpolant === undefined) {\n\t\t\tinterpolant = new LinearInterpolant(new Float32Array(2), new Float32Array(2), 1, _controlInterpolantsResultBuffer);\n\t\t\tinterpolant.__cacheIndex = lastActiveIndex;\n\t\t\tinterpolants[lastActiveIndex] = interpolant;\n\t\t}\n\n\t\treturn interpolant;\n\t}\n\n\t_takeBackControlInterpolant(interpolant) {\n\t\tconst interpolants = this._controlInterpolants,\n\t\t\t\t\tprevIndex = interpolant.__cacheIndex,\n\t\t\t\t\tfirstInactiveIndex = --this._nActiveControlInterpolants,\n\t\t\t\t\tlastActiveInterpolant = interpolants[firstInactiveIndex];\n\t\tinterpolant.__cacheIndex = firstInactiveIndex;\n\t\tinterpolants[firstInactiveIndex] = interpolant;\n\t\tlastActiveInterpolant.__cacheIndex = prevIndex;\n\t\tinterpolants[prevIndex] = lastActiveInterpolant;\n\t} // return an action for a clip optionally using a custom root target\n\t// object (this method allocates a lot of dynamic memory in case a\n\t// previously unknown clip/root combination is specified)\n\n\n\tclipAction(clip, optionalRoot, blendMode) {\n\t\tconst root = optionalRoot || this._root,\n\t\t\t\t\trootUuid = root.uuid;\n\t\tlet clipObject = typeof clip === 'string' ? AnimationClip.findByName(root, clip) : clip;\n\t\tconst clipUuid = clipObject !== null ? clipObject.uuid : clip;\n\t\tconst actionsForClip = this._actionsByClip[clipUuid];\n\t\tlet prototypeAction = null;\n\n\t\tif (blendMode === undefined) {\n\t\t\tif (clipObject !== null) {\n\t\t\t\tblendMode = clipObject.blendMode;\n\t\t\t} else {\n\t\t\t\tblendMode = NormalAnimationBlendMode;\n\t\t\t}\n\t\t}\n\n\t\tif (actionsForClip !== undefined) {\n\t\t\tconst existingAction = actionsForClip.actionByRoot[rootUuid];\n\n\t\t\tif (existingAction !== undefined && existingAction.blendMode === blendMode) {\n\t\t\t\treturn existingAction;\n\t\t\t} // we know the clip, so we don't have to parse all\n\t\t\t// the bindings again but can just copy\n\n\n\t\t\tprototypeAction = actionsForClip.knownActions[0]; // also, take the clip from the prototype action\n\n\t\t\tif (clipObject === null) clipObject = prototypeAction._clip;\n\t\t} // clip must be known when specified via string\n\n\n\t\tif (clipObject === null) return null; // allocate all resources required to run it\n\n\t\tconst newAction = new AnimationAction(this, clipObject, optionalRoot, blendMode);\n\n\t\tthis._bindAction(newAction, prototypeAction); // and make the action known to the memory manager\n\n\n\t\tthis._addInactiveAction(newAction, clipUuid, rootUuid);\n\n\t\treturn newAction;\n\t} // get an existing action\n\n\n\texistingAction(clip, optionalRoot) {\n\t\tconst root = optionalRoot || this._root,\n\t\t\t\t\trootUuid = root.uuid,\n\t\t\t\t\tclipObject = typeof clip === 'string' ? AnimationClip.findByName(root, clip) : clip,\n\t\t\t\t\tclipUuid = clipObject ? clipObject.uuid : clip,\n\t\t\t\t\tactionsForClip = this._actionsByClip[clipUuid];\n\n\t\tif (actionsForClip !== undefined) {\n\t\t\treturn actionsForClip.actionByRoot[rootUuid] || null;\n\t\t}\n\n\t\treturn null;\n\t} // deactivates all previously scheduled actions\n\n\n\tstopAllAction() {\n\t\tconst actions = this._actions,\n\t\t\t\t\tnActions = this._nActiveActions;\n\n\t\tfor (let i = nActions - 1; i >= 0; --i) {\n\t\t\tactions[i].stop();\n\t\t}\n\n\t\treturn this;\n\t} // advance the time and update apply the animation\n\n\n\tupdate(deltaTime) {\n\t\tdeltaTime *= this.timeScale;\n\t\tconst actions = this._actions,\n\t\t\t\t\tnActions = this._nActiveActions,\n\t\t\t\t\ttime = this.time += deltaTime,\n\t\t\t\t\ttimeDirection = Math.sign(deltaTime),\n\t\t\t\t\taccuIndex = this._accuIndex ^= 1; // run active actions\n\n\t\tfor (let i = 0; i !== nActions; ++i) {\n\t\t\tconst action = actions[i];\n\n\t\t\taction._update(time, deltaTime, timeDirection, accuIndex);\n\t\t} // update scene graph\n\n\n\t\tconst bindings = this._bindings,\n\t\t\t\t\tnBindings = this._nActiveBindings;\n\n\t\tfor (let i = 0; i !== nBindings; ++i) {\n\t\t\tbindings[i].apply(accuIndex);\n\t\t}\n\n\t\treturn this;\n\t} // Allows you to seek to a specific time in an animation.\n\n\n\tsetTime(timeInSeconds) {\n\t\tthis.time = 0; // Zero out time attribute for AnimationMixer object;\n\n\t\tfor (let i = 0; i < this._actions.length; i++) {\n\t\t\tthis._actions[i].time = 0; // Zero out time attribute for all associated AnimationAction objects.\n\t\t}\n\n\t\treturn this.update(timeInSeconds); // Update used to set exact time. Returns \"this\" AnimationMixer object.\n\t} // return this mixer's root target object\n\n\n\tgetRoot() {\n\t\treturn this._root;\n\t} // free all resources specific to a particular clip\n\n\n\tuncacheClip(clip) {\n\t\tconst actions = this._actions,\n\t\t\t\t\tclipUuid = clip.uuid,\n\t\t\t\t\tactionsByClip = this._actionsByClip,\n\t\t\t\t\tactionsForClip = actionsByClip[clipUuid];\n\n\t\tif (actionsForClip !== undefined) {\n\t\t\t// note: just calling _removeInactiveAction would mess up the\n\t\t\t// iteration state and also require updating the state we can\n\t\t\t// just throw away\n\t\t\tconst actionsToRemove = actionsForClip.knownActions;\n\n\t\t\tfor (let i = 0, n = actionsToRemove.length; i !== n; ++i) {\n\t\t\t\tconst action = actionsToRemove[i];\n\n\t\t\t\tthis._deactivateAction(action);\n\n\t\t\t\tconst cacheIndex = action._cacheIndex,\n\t\t\t\t\t\t\tlastInactiveAction = actions[actions.length - 1];\n\t\t\t\taction._cacheIndex = null;\n\t\t\t\taction._byClipCacheIndex = null;\n\t\t\t\tlastInactiveAction._cacheIndex = cacheIndex;\n\t\t\t\tactions[cacheIndex] = lastInactiveAction;\n\t\t\t\tactions.pop();\n\n\t\t\t\tthis._removeInactiveBindingsForAction(action);\n\t\t\t}\n\n\t\t\tdelete actionsByClip[clipUuid];\n\t\t}\n\t} // free all resources specific to a particular root target object\n\n\n\tuncacheRoot(root) {\n\t\tconst rootUuid = root.uuid,\n\t\t\t\t\tactionsByClip = this._actionsByClip;\n\n\t\tfor (const clipUuid in actionsByClip) {\n\t\t\tconst actionByRoot = actionsByClip[clipUuid].actionByRoot,\n\t\t\t\t\t\taction = actionByRoot[rootUuid];\n\n\t\t\tif (action !== undefined) {\n\t\t\t\tthis._deactivateAction(action);\n\n\t\t\t\tthis._removeInactiveAction(action);\n\t\t\t}\n\t\t}\n\n\t\tconst bindingsByRoot = this._bindingsByRootAndName,\n\t\t\t\t\tbindingByName = bindingsByRoot[rootUuid];\n\n\t\tif (bindingByName !== undefined) {\n\t\t\tfor (const trackName in bindingByName) {\n\t\t\t\tconst binding = bindingByName[trackName];\n\t\t\t\tbinding.restoreOriginalState();\n\n\t\t\t\tthis._removeInactiveBinding(binding);\n\t\t\t}\n\t\t}\n\t} // remove a targeted clip from the cache\n\n\n\tuncacheAction(clip, optionalRoot) {\n\t\tconst action = this.existingAction(clip, optionalRoot);\n\n\t\tif (action !== null) {\n\t\t\tthis._deactivateAction(action);\n\n\t\t\tthis._removeInactiveAction(action);\n\t\t}\n\t}\n\n}\n\nclass Uniform {\n\tconstructor(value) {\n\t\tif (typeof value === 'string') {\n\t\t\tconsole.warn('THREE.Uniform: Type parameter is no longer needed.');\n\t\t\tvalue = arguments[1];\n\t\t}\n\n\t\tthis.value = value;\n\t}\n\n\tclone() {\n\t\treturn new Uniform(this.value.clone === undefined ? this.value : this.value.clone());\n\t}\n\n}\n\nclass InstancedInterleavedBuffer extends InterleavedBuffer {\n\tconstructor(array, stride, meshPerAttribute = 1) {\n\t\tsuper(array, stride);\n\t\tthis.isInstancedInterleavedBuffer = true;\n\t\tthis.meshPerAttribute = meshPerAttribute;\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source);\n\t\tthis.meshPerAttribute = source.meshPerAttribute;\n\t\treturn this;\n\t}\n\n\tclone(data) {\n\t\tconst ib = super.clone(data);\n\t\tib.meshPerAttribute = this.meshPerAttribute;\n\t\treturn ib;\n\t}\n\n\ttoJSON(data) {\n\t\tconst json = super.toJSON(data);\n\t\tjson.isInstancedInterleavedBuffer = true;\n\t\tjson.meshPerAttribute = this.meshPerAttribute;\n\t\treturn json;\n\t}\n\n}\n\nclass GLBufferAttribute {\n\tconstructor(buffer, type, itemSize, elementSize, count) {\n\t\tthis.isGLBufferAttribute = true;\n\t\tthis.buffer = buffer;\n\t\tthis.type = type;\n\t\tthis.itemSize = itemSize;\n\t\tthis.elementSize = elementSize;\n\t\tthis.count = count;\n\t\tthis.version = 0;\n\t}\n\n\tset needsUpdate(value) {\n\t\tif (value === true) this.version++;\n\t}\n\n\tsetBuffer(buffer) {\n\t\tthis.buffer = buffer;\n\t\treturn this;\n\t}\n\n\tsetType(type, elementSize) {\n\t\tthis.type = type;\n\t\tthis.elementSize = elementSize;\n\t\treturn this;\n\t}\n\n\tsetItemSize(itemSize) {\n\t\tthis.itemSize = itemSize;\n\t\treturn this;\n\t}\n\n\tsetCount(count) {\n\t\tthis.count = count;\n\t\treturn this;\n\t}\n\n}\n\nclass Raycaster {\n\tconstructor(origin, direction, near = 0, far = Infinity) {\n\t\tthis.ray = new Ray(origin, direction); // direction is assumed to be normalized (for accurate distance calculations)\n\n\t\tthis.near = near;\n\t\tthis.far = far;\n\t\tthis.camera = null;\n\t\tthis.layers = new Layers();\n\t\tthis.params = {\n\t\t\tMesh: {},\n\t\t\tLine: {\n\t\t\t\tthreshold: 1\n\t\t\t},\n\t\t\tLOD: {},\n\t\t\tPoints: {\n\t\t\t\tthreshold: 1\n\t\t\t},\n\t\t\tSprite: {}\n\t\t};\n\t}\n\n\tset(origin, direction) {\n\t\t// direction is assumed to be normalized (for accurate distance calculations)\n\t\tthis.ray.set(origin, direction);\n\t}\n\n\tsetFromCamera(coords, camera) {\n\t\tif (camera.isPerspectiveCamera) {\n\t\t\tthis.ray.origin.setFromMatrixPosition(camera.matrixWorld);\n\t\t\tthis.ray.direction.set(coords.x, coords.y, 0.5).unproject(camera).sub(this.ray.origin).normalize();\n\t\t\tthis.camera = camera;\n\t\t} else if (camera.isOrthographicCamera) {\n\t\t\tthis.ray.origin.set(coords.x, coords.y, (camera.near + camera.far) / (camera.near - camera.far)).unproject(camera); // set origin in plane of camera\n\n\t\t\tthis.ray.direction.set(0, 0, -1).transformDirection(camera.matrixWorld);\n\t\t\tthis.camera = camera;\n\t\t} else {\n\t\t\tconsole.error('THREE.Raycaster: Unsupported camera type: ' + camera.type);\n\t\t}\n\t}\n\n\tintersectObject(object, recursive = true, intersects = []) {\n\t\tintersectObject(object, this, intersects, recursive);\n\t\tintersects.sort(ascSort);\n\t\treturn intersects;\n\t}\n\n\tintersectObjects(objects, recursive = true, intersects = []) {\n\t\tfor (let i = 0, l = objects.length; i < l; i++) {\n\t\t\tintersectObject(objects[i], this, intersects, recursive);\n\t\t}\n\n\t\tintersects.sort(ascSort);\n\t\treturn intersects;\n\t}\n\n}\n\nfunction ascSort(a, b) {\n\treturn a.distance - b.distance;\n}\n\nfunction intersectObject(object, raycaster, intersects, recursive) {\n\tif (object.layers.test(raycaster.layers)) {\n\t\tobject.raycast(raycaster, intersects);\n\t}\n\n\tif (recursive === true) {\n\t\tconst children = object.children;\n\n\t\tfor (let i = 0, l = children.length; i < l; i++) {\n\t\t\tintersectObject(children[i], raycaster, intersects, true);\n\t\t}\n\t}\n}\n\n/**\n * Ref: https://en.wikipedia.org/wiki/Spherical_coordinate_system\n *\n * The polar angle (phi) is measured from the positive y-axis. The positive y-axis is up.\n * The azimuthal angle (theta) is measured from the positive z-axis.\n */\n\nclass Spherical {\n\tconstructor(radius = 1, phi = 0, theta = 0) {\n\t\tthis.radius = radius;\n\t\tthis.phi = phi; // polar angle\n\n\t\tthis.theta = theta; // azimuthal angle\n\n\t\treturn this;\n\t}\n\n\tset(radius, phi, theta) {\n\t\tthis.radius = radius;\n\t\tthis.phi = phi;\n\t\tthis.theta = theta;\n\t\treturn this;\n\t}\n\n\tcopy(other) {\n\t\tthis.radius = other.radius;\n\t\tthis.phi = other.phi;\n\t\tthis.theta = other.theta;\n\t\treturn this;\n\t} // restrict phi to be between EPS and PI-EPS\n\n\n\tmakeSafe() {\n\t\tconst EPS = 0.000001;\n\t\tthis.phi = Math.max(EPS, Math.min(Math.PI - EPS, this.phi));\n\t\treturn this;\n\t}\n\n\tsetFromVector3(v) {\n\t\treturn this.setFromCartesianCoords(v.x, v.y, v.z);\n\t}\n\n\tsetFromCartesianCoords(x, y, z) {\n\t\tthis.radius = Math.sqrt(x * x + y * y + z * z);\n\n\t\tif (this.radius === 0) {\n\t\t\tthis.theta = 0;\n\t\t\tthis.phi = 0;\n\t\t} else {\n\t\t\tthis.theta = Math.atan2(x, z);\n\t\t\tthis.phi = Math.acos(clamp(y / this.radius, -1, 1));\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n}\n\n/**\n * Ref: https://en.wikipedia.org/wiki/Cylindrical_coordinate_system\n */\nclass Cylindrical {\n\tconstructor(radius = 1, theta = 0, y = 0) {\n\t\tthis.radius = radius; // distance from the origin to a point in the x-z plane\n\n\t\tthis.theta = theta; // counterclockwise angle in the x-z plane measured in radians from the positive z-axis\n\n\t\tthis.y = y; // height above the x-z plane\n\n\t\treturn this;\n\t}\n\n\tset(radius, theta, y) {\n\t\tthis.radius = radius;\n\t\tthis.theta = theta;\n\t\tthis.y = y;\n\t\treturn this;\n\t}\n\n\tcopy(other) {\n\t\tthis.radius = other.radius;\n\t\tthis.theta = other.theta;\n\t\tthis.y = other.y;\n\t\treturn this;\n\t}\n\n\tsetFromVector3(v) {\n\t\treturn this.setFromCartesianCoords(v.x, v.y, v.z);\n\t}\n\n\tsetFromCartesianCoords(x, y, z) {\n\t\tthis.radius = Math.sqrt(x * x + z * z);\n\t\tthis.theta = Math.atan2(x, z);\n\t\tthis.y = y;\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n}\n\nconst _vector$4 = /*@__PURE__*/new Vector2();\n\nclass Box2 {\n\tconstructor(min = new Vector2(+Infinity, +Infinity), max = new Vector2(-Infinity, -Infinity)) {\n\t\tthis.isBox2 = true;\n\t\tthis.min = min;\n\t\tthis.max = max;\n\t}\n\n\tset(min, max) {\n\t\tthis.min.copy(min);\n\t\tthis.max.copy(max);\n\t\treturn this;\n\t}\n\n\tsetFromPoints(points) {\n\t\tthis.makeEmpty();\n\n\t\tfor (let i = 0, il = points.length; i < il; i++) {\n\t\t\tthis.expandByPoint(points[i]);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tsetFromCenterAndSize(center, size) {\n\t\tconst halfSize = _vector$4.copy(size).multiplyScalar(0.5);\n\n\t\tthis.min.copy(center).sub(halfSize);\n\t\tthis.max.copy(center).add(halfSize);\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n\tcopy(box) {\n\t\tthis.min.copy(box.min);\n\t\tthis.max.copy(box.max);\n\t\treturn this;\n\t}\n\n\tmakeEmpty() {\n\t\tthis.min.x = this.min.y = +Infinity;\n\t\tthis.max.x = this.max.y = -Infinity;\n\t\treturn this;\n\t}\n\n\tisEmpty() {\n\t\t// this is a more robust check for empty than ( volume <= 0 ) because volume can get positive with two negative axes\n\t\treturn this.max.x < this.min.x || this.max.y < this.min.y;\n\t}\n\n\tgetCenter(target) {\n\t\treturn this.isEmpty() ? target.set(0, 0) : target.addVectors(this.min, this.max).multiplyScalar(0.5);\n\t}\n\n\tgetSize(target) {\n\t\treturn this.isEmpty() ? target.set(0, 0) : target.subVectors(this.max, this.min);\n\t}\n\n\texpandByPoint(point) {\n\t\tthis.min.min(point);\n\t\tthis.max.max(point);\n\t\treturn this;\n\t}\n\n\texpandByVector(vector) {\n\t\tthis.min.sub(vector);\n\t\tthis.max.add(vector);\n\t\treturn this;\n\t}\n\n\texpandByScalar(scalar) {\n\t\tthis.min.addScalar(-scalar);\n\t\tthis.max.addScalar(scalar);\n\t\treturn this;\n\t}\n\n\tcontainsPoint(point) {\n\t\treturn point.x < this.min.x || point.x > this.max.x || point.y < this.min.y || point.y > this.max.y ? false : true;\n\t}\n\n\tcontainsBox(box) {\n\t\treturn this.min.x <= box.min.x && box.max.x <= this.max.x && this.min.y <= box.min.y && box.max.y <= this.max.y;\n\t}\n\n\tgetParameter(point, target) {\n\t\t// This can potentially have a divide by zero if the box\n\t\t// has a size dimension of 0.\n\t\treturn target.set((point.x - this.min.x) / (this.max.x - this.min.x), (point.y - this.min.y) / (this.max.y - this.min.y));\n\t}\n\n\tintersectsBox(box) {\n\t\t// using 4 splitting planes to rule out intersections\n\t\treturn box.max.x < this.min.x || box.min.x > this.max.x || box.max.y < this.min.y || box.min.y > this.max.y ? false : true;\n\t}\n\n\tclampPoint(point, target) {\n\t\treturn target.copy(point).clamp(this.min, this.max);\n\t}\n\n\tdistanceToPoint(point) {\n\t\tconst clampedPoint = _vector$4.copy(point).clamp(this.min, this.max);\n\n\t\treturn clampedPoint.sub(point).length();\n\t}\n\n\tintersect(box) {\n\t\tthis.min.max(box.min);\n\t\tthis.max.min(box.max);\n\t\treturn this;\n\t}\n\n\tunion(box) {\n\t\tthis.min.min(box.min);\n\t\tthis.max.max(box.max);\n\t\treturn this;\n\t}\n\n\ttranslate(offset) {\n\t\tthis.min.add(offset);\n\t\tthis.max.add(offset);\n\t\treturn this;\n\t}\n\n\tequals(box) {\n\t\treturn box.min.equals(this.min) && box.max.equals(this.max);\n\t}\n\n}\n\nconst _startP = /*@__PURE__*/new Vector3();\n\nconst _startEnd = /*@__PURE__*/new Vector3();\n\nclass Line3 {\n\tconstructor(start = new Vector3(), end = new Vector3()) {\n\t\tthis.start = start;\n\t\tthis.end = end;\n\t}\n\n\tset(start, end) {\n\t\tthis.start.copy(start);\n\t\tthis.end.copy(end);\n\t\treturn this;\n\t}\n\n\tcopy(line) {\n\t\tthis.start.copy(line.start);\n\t\tthis.end.copy(line.end);\n\t\treturn this;\n\t}\n\n\tgetCenter(target) {\n\t\treturn target.addVectors(this.start, this.end).multiplyScalar(0.5);\n\t}\n\n\tdelta(target) {\n\t\treturn target.subVectors(this.end, this.start);\n\t}\n\n\tdistanceSq() {\n\t\treturn this.start.distanceToSquared(this.end);\n\t}\n\n\tdistance() {\n\t\treturn this.start.distanceTo(this.end);\n\t}\n\n\tat(t, target) {\n\t\treturn this.delta(target).multiplyScalar(t).add(this.start);\n\t}\n\n\tclosestPointToPointParameter(point, clampToLine) {\n\t\t_startP.subVectors(point, this.start);\n\n\t\t_startEnd.subVectors(this.end, this.start);\n\n\t\tconst startEnd2 = _startEnd.dot(_startEnd);\n\n\t\tconst startEnd_startP = _startEnd.dot(_startP);\n\n\t\tlet t = startEnd_startP / startEnd2;\n\n\t\tif (clampToLine) {\n\t\t\tt = clamp(t, 0, 1);\n\t\t}\n\n\t\treturn t;\n\t}\n\n\tclosestPointToPoint(point, clampToLine, target) {\n\t\tconst t = this.closestPointToPointParameter(point, clampToLine);\n\t\treturn this.delta(target).multiplyScalar(t).add(this.start);\n\t}\n\n\tapplyMatrix4(matrix) {\n\t\tthis.start.applyMatrix4(matrix);\n\t\tthis.end.applyMatrix4(matrix);\n\t\treturn this;\n\t}\n\n\tequals(line) {\n\t\treturn line.start.equals(this.start) && line.end.equals(this.end);\n\t}\n\n\tclone() {\n\t\treturn new this.constructor().copy(this);\n\t}\n\n}\n\nconst _vector$3 = /*@__PURE__*/new Vector3();\n\nclass SpotLightHelper extends Object3D {\n\tconstructor(light, color) {\n\t\tsuper();\n\t\tthis.light = light;\n\t\tthis.light.updateMatrixWorld();\n\t\tthis.matrix = light.matrixWorld;\n\t\tthis.matrixAutoUpdate = false;\n\t\tthis.color = color;\n\t\tconst geometry = new BufferGeometry();\n\t\tconst positions = [0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, -1, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, -1, 1];\n\n\t\tfor (let i = 0, j = 1, l = 32; i < l; i++, j++) {\n\t\t\tconst p1 = i / l * Math.PI * 2;\n\t\t\tconst p2 = j / l * Math.PI * 2;\n\t\t\tpositions.push(Math.cos(p1), Math.sin(p1), 1, Math.cos(p2), Math.sin(p2), 1);\n\t\t}\n\n\t\tgeometry.setAttribute('position', new Float32BufferAttribute(positions, 3));\n\t\tconst material = new LineBasicMaterial({\n\t\t\tfog: false,\n\t\t\ttoneMapped: false\n\t\t});\n\t\tthis.cone = new LineSegments(geometry, material);\n\t\tthis.add(this.cone);\n\t\tthis.update();\n\t}\n\n\tdispose() {\n\t\tthis.cone.geometry.dispose();\n\t\tthis.cone.material.dispose();\n\t}\n\n\tupdate() {\n\t\tthis.light.updateMatrixWorld();\n\t\tconst coneLength = this.light.distance ? this.light.distance : 1000;\n\t\tconst coneWidth = coneLength * Math.tan(this.light.angle);\n\t\tthis.cone.scale.set(coneWidth, coneWidth, coneLength);\n\n\t\t_vector$3.setFromMatrixPosition(this.light.target.matrixWorld);\n\n\t\tthis.cone.lookAt(_vector$3);\n\n\t\tif (this.color !== undefined) {\n\t\t\tthis.cone.material.color.set(this.color);\n\t\t} else {\n\t\t\tthis.cone.material.color.copy(this.light.color);\n\t\t}\n\t}\n\n}\n\nconst _vector$2 = /*@__PURE__*/new Vector3();\n\nconst _boneMatrix = /*@__PURE__*/new Matrix4();\n\nconst _matrixWorldInv = /*@__PURE__*/new Matrix4();\n\nclass SkeletonHelper extends LineSegments {\n\tconstructor(object) {\n\t\tconst bones = getBoneList(object);\n\t\tconst geometry = new BufferGeometry();\n\t\tconst vertices = [];\n\t\tconst colors = [];\n\t\tconst color1 = new Color(0, 0, 1);\n\t\tconst color2 = new Color(0, 1, 0);\n\n\t\tfor (let i = 0; i < bones.length; i++) {\n\t\t\tconst bone = bones[i];\n\n\t\t\tif (bone.parent && bone.parent.isBone) {\n\t\t\t\tvertices.push(0, 0, 0);\n\t\t\t\tvertices.push(0, 0, 0);\n\t\t\t\tcolors.push(color1.r, color1.g, color1.b);\n\t\t\t\tcolors.push(color2.r, color2.g, color2.b);\n\t\t\t}\n\t\t}\n\n\t\tgeometry.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tgeometry.setAttribute('color', new Float32BufferAttribute(colors, 3));\n\t\tconst material = new LineBasicMaterial({\n\t\t\tvertexColors: true,\n\t\t\tdepthTest: false,\n\t\t\tdepthWrite: false,\n\t\t\ttoneMapped: false,\n\t\t\ttransparent: true\n\t\t});\n\t\tsuper(geometry, material);\n\t\tthis.isSkeletonHelper = true;\n\t\tthis.type = 'SkeletonHelper';\n\t\tthis.root = object;\n\t\tthis.bones = bones;\n\t\tthis.matrix = object.matrixWorld;\n\t\tthis.matrixAutoUpdate = false;\n\t}\n\n\tupdateMatrixWorld(force) {\n\t\tconst bones = this.bones;\n\t\tconst geometry = this.geometry;\n\t\tconst position = geometry.getAttribute('position');\n\n\t\t_matrixWorldInv.copy(this.root.matrixWorld).invert();\n\n\t\tfor (let i = 0, j = 0; i < bones.length; i++) {\n\t\t\tconst bone = bones[i];\n\n\t\t\tif (bone.parent && bone.parent.isBone) {\n\t\t\t\t_boneMatrix.multiplyMatrices(_matrixWorldInv, bone.matrixWorld);\n\n\t\t\t\t_vector$2.setFromMatrixPosition(_boneMatrix);\n\n\t\t\t\tposition.setXYZ(j, _vector$2.x, _vector$2.y, _vector$2.z);\n\n\t\t\t\t_boneMatrix.multiplyMatrices(_matrixWorldInv, bone.parent.matrixWorld);\n\n\t\t\t\t_vector$2.setFromMatrixPosition(_boneMatrix);\n\n\t\t\t\tposition.setXYZ(j + 1, _vector$2.x, _vector$2.y, _vector$2.z);\n\t\t\t\tj += 2;\n\t\t\t}\n\t\t}\n\n\t\tgeometry.getAttribute('position').needsUpdate = true;\n\t\tsuper.updateMatrixWorld(force);\n\t}\n\n}\n\nfunction getBoneList(object) {\n\tconst boneList = [];\n\n\tif (object.isBone === true) {\n\t\tboneList.push(object);\n\t}\n\n\tfor (let i = 0; i < object.children.length; i++) {\n\t\tboneList.push.apply(boneList, getBoneList(object.children[i]));\n\t}\n\n\treturn boneList;\n}\n\nclass PointLightHelper extends Mesh {\n\tconstructor(light, sphereSize, color) {\n\t\tconst geometry = new SphereGeometry(sphereSize, 4, 2);\n\t\tconst material = new MeshBasicMaterial({\n\t\t\twireframe: true,\n\t\t\tfog: false,\n\t\t\ttoneMapped: false\n\t\t});\n\t\tsuper(geometry, material);\n\t\tthis.light = light;\n\t\tthis.light.updateMatrixWorld();\n\t\tthis.color = color;\n\t\tthis.type = 'PointLightHelper';\n\t\tthis.matrix = this.light.matrixWorld;\n\t\tthis.matrixAutoUpdate = false;\n\t\tthis.update();\n\t\t/*\n\t\t// TODO: delete this comment?\n\t\tconst distanceGeometry = new THREE.IcosahedronGeometry( 1, 2 );\n\t\tconst distanceMaterial = new THREE.MeshBasicMaterial( { color: hexColor, fog: false, wireframe: true, opacity: 0.1, transparent: true } );\n\t\tthis.lightSphere = new THREE.Mesh( bulbGeometry, bulbMaterial );\n\t\tthis.lightDistance = new THREE.Mesh( distanceGeometry, distanceMaterial );\n\t\tconst d = light.distance;\n\t\tif ( d === 0.0 ) {\n\t\t\tthis.lightDistance.visible = false;\n\t\t} else {\n\t\t\tthis.lightDistance.scale.set( d, d, d );\n\t\t}\n\t\tthis.add( this.lightDistance );\n\t\t*/\n\t}\n\n\tdispose() {\n\t\tthis.geometry.dispose();\n\t\tthis.material.dispose();\n\t}\n\n\tupdate() {\n\t\tif (this.color !== undefined) {\n\t\t\tthis.material.color.set(this.color);\n\t\t} else {\n\t\t\tthis.material.color.copy(this.light.color);\n\t\t}\n\t\t/*\n\t\tconst d = this.light.distance;\n\t\t\tif ( d === 0.0 ) {\n\t\t\t\tthis.lightDistance.visible = false;\n\t\t\t} else {\n\t\t\t\tthis.lightDistance.visible = true;\n\t\t\tthis.lightDistance.scale.set( d, d, d );\n\t\t\t}\n\t\t*/\n\n\t}\n\n}\n\nconst _vector$1 = /*@__PURE__*/new Vector3();\n\nconst _color1 = /*@__PURE__*/new Color();\n\nconst _color2 = /*@__PURE__*/new Color();\n\nclass HemisphereLightHelper extends Object3D {\n\tconstructor(light, size, color) {\n\t\tsuper();\n\t\tthis.light = light;\n\t\tthis.light.updateMatrixWorld();\n\t\tthis.matrix = light.matrixWorld;\n\t\tthis.matrixAutoUpdate = false;\n\t\tthis.color = color;\n\t\tconst geometry = new OctahedronGeometry(size);\n\t\tgeometry.rotateY(Math.PI * 0.5);\n\t\tthis.material = new MeshBasicMaterial({\n\t\t\twireframe: true,\n\t\t\tfog: false,\n\t\t\ttoneMapped: false\n\t\t});\n\t\tif (this.color === undefined) this.material.vertexColors = true;\n\t\tconst position = geometry.getAttribute('position');\n\t\tconst colors = new Float32Array(position.count * 3);\n\t\tgeometry.setAttribute('color', new BufferAttribute(colors, 3));\n\t\tthis.add(new Mesh(geometry, this.material));\n\t\tthis.update();\n\t}\n\n\tdispose() {\n\t\tthis.children[0].geometry.dispose();\n\t\tthis.children[0].material.dispose();\n\t}\n\n\tupdate() {\n\t\tconst mesh = this.children[0];\n\n\t\tif (this.color !== undefined) {\n\t\t\tthis.material.color.set(this.color);\n\t\t} else {\n\t\t\tconst colors = mesh.geometry.getAttribute('color');\n\n\t\t\t_color1.copy(this.light.color);\n\n\t\t\t_color2.copy(this.light.groundColor);\n\n\t\t\tfor (let i = 0, l = colors.count; i < l; i++) {\n\t\t\t\tconst color = i < l / 2 ? _color1 : _color2;\n\t\t\t\tcolors.setXYZ(i, color.r, color.g, color.b);\n\t\t\t}\n\n\t\t\tcolors.needsUpdate = true;\n\t\t}\n\n\t\tmesh.lookAt(_vector$1.setFromMatrixPosition(this.light.matrixWorld).negate());\n\t}\n\n}\n\nclass GridHelper extends LineSegments {\n\tconstructor(size = 10, divisions = 10, color1 = 0x444444, color2 = 0x888888) {\n\t\tcolor1 = new Color(color1);\n\t\tcolor2 = new Color(color2);\n\t\tconst center = divisions / 2;\n\t\tconst step = size / divisions;\n\t\tconst halfSize = size / 2;\n\t\tconst vertices = [],\n\t\t\t\t\tcolors = [];\n\n\t\tfor (let i = 0, j = 0, k = -halfSize; i <= divisions; i++, k += step) {\n\t\t\tvertices.push(-halfSize, 0, k, halfSize, 0, k);\n\t\t\tvertices.push(k, 0, -halfSize, k, 0, halfSize);\n\t\t\tconst color = i === center ? color1 : color2;\n\t\t\tcolor.toArray(colors, j);\n\t\t\tj += 3;\n\t\t\tcolor.toArray(colors, j);\n\t\t\tj += 3;\n\t\t\tcolor.toArray(colors, j);\n\t\t\tj += 3;\n\t\t\tcolor.toArray(colors, j);\n\t\t\tj += 3;\n\t\t}\n\n\t\tconst geometry = new BufferGeometry();\n\t\tgeometry.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tgeometry.setAttribute('color', new Float32BufferAttribute(colors, 3));\n\t\tconst material = new LineBasicMaterial({\n\t\t\tvertexColors: true,\n\t\t\ttoneMapped: false\n\t\t});\n\t\tsuper(geometry, material);\n\t\tthis.type = 'GridHelper';\n\t}\n\n}\n\nclass PolarGridHelper extends LineSegments {\n\tconstructor(radius = 10, radials = 16, circles = 8, divisions = 64, color1 = 0x444444, color2 = 0x888888) {\n\t\tcolor1 = new Color(color1);\n\t\tcolor2 = new Color(color2);\n\t\tconst vertices = [];\n\t\tconst colors = []; // create the radials\n\n\t\tfor (let i = 0; i <= radials; i++) {\n\t\t\tconst v = i / radials * (Math.PI * 2);\n\t\t\tconst x = Math.sin(v) * radius;\n\t\t\tconst z = Math.cos(v) * radius;\n\t\t\tvertices.push(0, 0, 0);\n\t\t\tvertices.push(x, 0, z);\n\t\t\tconst color = i & 1 ? color1 : color2;\n\t\t\tcolors.push(color.r, color.g, color.b);\n\t\t\tcolors.push(color.r, color.g, color.b);\n\t\t} // create the circles\n\n\n\t\tfor (let i = 0; i <= circles; i++) {\n\t\t\tconst color = i & 1 ? color1 : color2;\n\t\t\tconst r = radius - radius / circles * i;\n\n\t\t\tfor (let j = 0; j < divisions; j++) {\n\t\t\t\t// first vertex\n\t\t\t\tlet v = j / divisions * (Math.PI * 2);\n\t\t\t\tlet x = Math.sin(v) * r;\n\t\t\t\tlet z = Math.cos(v) * r;\n\t\t\t\tvertices.push(x, 0, z);\n\t\t\t\tcolors.push(color.r, color.g, color.b); // second vertex\n\n\t\t\t\tv = (j + 1) / divisions * (Math.PI * 2);\n\t\t\t\tx = Math.sin(v) * r;\n\t\t\t\tz = Math.cos(v) * r;\n\t\t\t\tvertices.push(x, 0, z);\n\t\t\t\tcolors.push(color.r, color.g, color.b);\n\t\t\t}\n\t\t}\n\n\t\tconst geometry = new BufferGeometry();\n\t\tgeometry.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tgeometry.setAttribute('color', new Float32BufferAttribute(colors, 3));\n\t\tconst material = new LineBasicMaterial({\n\t\t\tvertexColors: true,\n\t\t\ttoneMapped: false\n\t\t});\n\t\tsuper(geometry, material);\n\t\tthis.type = 'PolarGridHelper';\n\t}\n\n}\n\nconst _v1 = /*@__PURE__*/new Vector3();\n\nconst _v2 = /*@__PURE__*/new Vector3();\n\nconst _v3 = /*@__PURE__*/new Vector3();\n\nclass DirectionalLightHelper extends Object3D {\n\tconstructor(light, size, color) {\n\t\tsuper();\n\t\tthis.light = light;\n\t\tthis.light.updateMatrixWorld();\n\t\tthis.matrix = light.matrixWorld;\n\t\tthis.matrixAutoUpdate = false;\n\t\tthis.color = color;\n\t\tif (size === undefined) size = 1;\n\t\tlet geometry = new BufferGeometry();\n\t\tgeometry.setAttribute('position', new Float32BufferAttribute([-size, size, 0, size, size, 0, size, -size, 0, -size, -size, 0, -size, size, 0], 3));\n\t\tconst material = new LineBasicMaterial({\n\t\t\tfog: false,\n\t\t\ttoneMapped: false\n\t\t});\n\t\tthis.lightPlane = new Line(geometry, material);\n\t\tthis.add(this.lightPlane);\n\t\tgeometry = new BufferGeometry();\n\t\tgeometry.setAttribute('position', new Float32BufferAttribute([0, 0, 0, 0, 0, 1], 3));\n\t\tthis.targetLine = new Line(geometry, material);\n\t\tthis.add(this.targetLine);\n\t\tthis.update();\n\t}\n\n\tdispose() {\n\t\tthis.lightPlane.geometry.dispose();\n\t\tthis.lightPlane.material.dispose();\n\t\tthis.targetLine.geometry.dispose();\n\t\tthis.targetLine.material.dispose();\n\t}\n\n\tupdate() {\n\t\t_v1.setFromMatrixPosition(this.light.matrixWorld);\n\n\t\t_v2.setFromMatrixPosition(this.light.target.matrixWorld);\n\n\t\t_v3.subVectors(_v2, _v1);\n\n\t\tthis.lightPlane.lookAt(_v2);\n\n\t\tif (this.color !== undefined) {\n\t\t\tthis.lightPlane.material.color.set(this.color);\n\t\t\tthis.targetLine.material.color.set(this.color);\n\t\t} else {\n\t\t\tthis.lightPlane.material.color.copy(this.light.color);\n\t\t\tthis.targetLine.material.color.copy(this.light.color);\n\t\t}\n\n\t\tthis.targetLine.lookAt(_v2);\n\t\tthis.targetLine.scale.z = _v3.length();\n\t}\n\n}\n\nconst _vector = /*@__PURE__*/new Vector3();\n\nconst _camera = /*@__PURE__*/new Camera();\n/**\n *\t- shows frustum, line of sight and up of the camera\n *\t- suitable for fast updates\n * \t- based on frustum visualization in lightgl.js shadowmap example\n *\t\thttps://github.com/evanw/lightgl.js/blob/master/tests/shadowmap.html\n */\n\n\nclass CameraHelper extends LineSegments {\n\tconstructor(camera) {\n\t\tconst geometry = new BufferGeometry();\n\t\tconst material = new LineBasicMaterial({\n\t\t\tcolor: 0xffffff,\n\t\t\tvertexColors: true,\n\t\t\ttoneMapped: false\n\t\t});\n\t\tconst vertices = [];\n\t\tconst colors = [];\n\t\tconst pointMap = {}; // colors\n\n\t\tconst colorFrustum = new Color(0xffaa00);\n\t\tconst colorCone = new Color(0xff0000);\n\t\tconst colorUp = new Color(0x00aaff);\n\t\tconst colorTarget = new Color(0xffffff);\n\t\tconst colorCross = new Color(0x333333); // near\n\n\t\taddLine('n1', 'n2', colorFrustum);\n\t\taddLine('n2', 'n4', colorFrustum);\n\t\taddLine('n4', 'n3', colorFrustum);\n\t\taddLine('n3', 'n1', colorFrustum); // far\n\n\t\taddLine('f1', 'f2', colorFrustum);\n\t\taddLine('f2', 'f4', colorFrustum);\n\t\taddLine('f4', 'f3', colorFrustum);\n\t\taddLine('f3', 'f1', colorFrustum); // sides\n\n\t\taddLine('n1', 'f1', colorFrustum);\n\t\taddLine('n2', 'f2', colorFrustum);\n\t\taddLine('n3', 'f3', colorFrustum);\n\t\taddLine('n4', 'f4', colorFrustum); // cone\n\n\t\taddLine('p', 'n1', colorCone);\n\t\taddLine('p', 'n2', colorCone);\n\t\taddLine('p', 'n3', colorCone);\n\t\taddLine('p', 'n4', colorCone); // up\n\n\t\taddLine('u1', 'u2', colorUp);\n\t\taddLine('u2', 'u3', colorUp);\n\t\taddLine('u3', 'u1', colorUp); // target\n\n\t\taddLine('c', 't', colorTarget);\n\t\taddLine('p', 'c', colorCross); // cross\n\n\t\taddLine('cn1', 'cn2', colorCross);\n\t\taddLine('cn3', 'cn4', colorCross);\n\t\taddLine('cf1', 'cf2', colorCross);\n\t\taddLine('cf3', 'cf4', colorCross);\n\n\t\tfunction addLine(a, b, color) {\n\t\t\taddPoint(a, color);\n\t\t\taddPoint(b, color);\n\t\t}\n\n\t\tfunction addPoint(id, color) {\n\t\t\tvertices.push(0, 0, 0);\n\t\t\tcolors.push(color.r, color.g, color.b);\n\n\t\t\tif (pointMap[id] === undefined) {\n\t\t\t\tpointMap[id] = [];\n\t\t\t}\n\n\t\t\tpointMap[id].push(vertices.length / 3 - 1);\n\t\t}\n\n\t\tgeometry.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tgeometry.setAttribute('color', new Float32BufferAttribute(colors, 3));\n\t\tsuper(geometry, material);\n\t\tthis.type = 'CameraHelper';\n\t\tthis.camera = camera;\n\t\tif (this.camera.updateProjectionMatrix) this.camera.updateProjectionMatrix();\n\t\tthis.matrix = camera.matrixWorld;\n\t\tthis.matrixAutoUpdate = false;\n\t\tthis.pointMap = pointMap;\n\t\tthis.update();\n\t}\n\n\tupdate() {\n\t\tconst geometry = this.geometry;\n\t\tconst pointMap = this.pointMap;\n\t\tconst w = 1,\n\t\t\t\t\th = 1; // we need just camera projection matrix inverse\n\t\t// world matrix must be identity\n\n\t\t_camera.projectionMatrixInverse.copy(this.camera.projectionMatrixInverse); // center / target\n\n\n\t\tsetPoint('c', pointMap, geometry, _camera, 0, 0, -1);\n\t\tsetPoint('t', pointMap, geometry, _camera, 0, 0, 1); // near\n\n\t\tsetPoint('n1', pointMap, geometry, _camera, -w, -h, -1);\n\t\tsetPoint('n2', pointMap, geometry, _camera, w, -h, -1);\n\t\tsetPoint('n3', pointMap, geometry, _camera, -w, h, -1);\n\t\tsetPoint('n4', pointMap, geometry, _camera, w, h, -1); // far\n\n\t\tsetPoint('f1', pointMap, geometry, _camera, -w, -h, 1);\n\t\tsetPoint('f2', pointMap, geometry, _camera, w, -h, 1);\n\t\tsetPoint('f3', pointMap, geometry, _camera, -w, h, 1);\n\t\tsetPoint('f4', pointMap, geometry, _camera, w, h, 1); // up\n\n\t\tsetPoint('u1', pointMap, geometry, _camera, w * 0.7, h * 1.1, -1);\n\t\tsetPoint('u2', pointMap, geometry, _camera, -w * 0.7, h * 1.1, -1);\n\t\tsetPoint('u3', pointMap, geometry, _camera, 0, h * 2, -1); // cross\n\n\t\tsetPoint('cf1', pointMap, geometry, _camera, -w, 0, 1);\n\t\tsetPoint('cf2', pointMap, geometry, _camera, w, 0, 1);\n\t\tsetPoint('cf3', pointMap, geometry, _camera, 0, -h, 1);\n\t\tsetPoint('cf4', pointMap, geometry, _camera, 0, h, 1);\n\t\tsetPoint('cn1', pointMap, geometry, _camera, -w, 0, -1);\n\t\tsetPoint('cn2', pointMap, geometry, _camera, w, 0, -1);\n\t\tsetPoint('cn3', pointMap, geometry, _camera, 0, -h, -1);\n\t\tsetPoint('cn4', pointMap, geometry, _camera, 0, h, -1);\n\t\tgeometry.getAttribute('position').needsUpdate = true;\n\t}\n\n\tdispose() {\n\t\tthis.geometry.dispose();\n\t\tthis.material.dispose();\n\t}\n\n}\n\nfunction setPoint(point, pointMap, geometry, camera, x, y, z) {\n\t_vector.set(x, y, z).unproject(camera);\n\n\tconst points = pointMap[point];\n\n\tif (points !== undefined) {\n\t\tconst position = geometry.getAttribute('position');\n\n\t\tfor (let i = 0, l = points.length; i < l; i++) {\n\t\t\tposition.setXYZ(points[i], _vector.x, _vector.y, _vector.z);\n\t\t}\n\t}\n}\n\nconst _box = /*@__PURE__*/new Box3();\n\nclass BoxHelper extends LineSegments {\n\tconstructor(object, color = 0xffff00) {\n\t\tconst indices = new Uint16Array([0, 1, 1, 2, 2, 3, 3, 0, 4, 5, 5, 6, 6, 7, 7, 4, 0, 4, 1, 5, 2, 6, 3, 7]);\n\t\tconst positions = new Float32Array(8 * 3);\n\t\tconst geometry = new BufferGeometry();\n\t\tgeometry.setIndex(new BufferAttribute(indices, 1));\n\t\tgeometry.setAttribute('position', new BufferAttribute(positions, 3));\n\t\tsuper(geometry, new LineBasicMaterial({\n\t\t\tcolor: color,\n\t\t\ttoneMapped: false\n\t\t}));\n\t\tthis.object = object;\n\t\tthis.type = 'BoxHelper';\n\t\tthis.matrixAutoUpdate = false;\n\t\tthis.update();\n\t}\n\n\tupdate(object) {\n\t\tif (object !== undefined) {\n\t\t\tconsole.warn('THREE.BoxHelper: .update() has no longer arguments.');\n\t\t}\n\n\t\tif (this.object !== undefined) {\n\t\t\t_box.setFromObject(this.object);\n\t\t}\n\n\t\tif (_box.isEmpty()) return;\n\t\tconst min = _box.min;\n\t\tconst max = _box.max;\n\t\t/*\n\t\t\t5____4\n\t\t1/___0/|\n\t\t| 6__|_7\n\t\t2/___3/\n\t\t\t0: max.x, max.y, max.z\n\t\t1: min.x, max.y, max.z\n\t\t2: min.x, min.y, max.z\n\t\t3: max.x, min.y, max.z\n\t\t4: max.x, max.y, min.z\n\t\t5: min.x, max.y, min.z\n\t\t6: min.x, min.y, min.z\n\t\t7: max.x, min.y, min.z\n\t\t*/\n\n\t\tconst position = this.geometry.attributes.position;\n\t\tconst array = position.array;\n\t\tarray[0] = max.x;\n\t\tarray[1] = max.y;\n\t\tarray[2] = max.z;\n\t\tarray[3] = min.x;\n\t\tarray[4] = max.y;\n\t\tarray[5] = max.z;\n\t\tarray[6] = min.x;\n\t\tarray[7] = min.y;\n\t\tarray[8] = max.z;\n\t\tarray[9] = max.x;\n\t\tarray[10] = min.y;\n\t\tarray[11] = max.z;\n\t\tarray[12] = max.x;\n\t\tarray[13] = max.y;\n\t\tarray[14] = min.z;\n\t\tarray[15] = min.x;\n\t\tarray[16] = max.y;\n\t\tarray[17] = min.z;\n\t\tarray[18] = min.x;\n\t\tarray[19] = min.y;\n\t\tarray[20] = min.z;\n\t\tarray[21] = max.x;\n\t\tarray[22] = min.y;\n\t\tarray[23] = min.z;\n\t\tposition.needsUpdate = true;\n\t\tthis.geometry.computeBoundingSphere();\n\t}\n\n\tsetFromObject(object) {\n\t\tthis.object = object;\n\t\tthis.update();\n\t\treturn this;\n\t}\n\n\tcopy(source, recursive) {\n\t\tsuper.copy(source, recursive);\n\t\tthis.object = source.object;\n\t\treturn this;\n\t}\n\n}\n\nclass Box3Helper extends LineSegments {\n\tconstructor(box, color = 0xffff00) {\n\t\tconst indices = new Uint16Array([0, 1, 1, 2, 2, 3, 3, 0, 4, 5, 5, 6, 6, 7, 7, 4, 0, 4, 1, 5, 2, 6, 3, 7]);\n\t\tconst positions = [1, 1, 1, -1, 1, 1, -1, -1, 1, 1, -1, 1, 1, 1, -1, -1, 1, -1, -1, -1, -1, 1, -1, -1];\n\t\tconst geometry = new BufferGeometry();\n\t\tgeometry.setIndex(new BufferAttribute(indices, 1));\n\t\tgeometry.setAttribute('position', new Float32BufferAttribute(positions, 3));\n\t\tsuper(geometry, new LineBasicMaterial({\n\t\t\tcolor: color,\n\t\t\ttoneMapped: false\n\t\t}));\n\t\tthis.box = box;\n\t\tthis.type = 'Box3Helper';\n\t\tthis.geometry.computeBoundingSphere();\n\t}\n\n\tupdateMatrixWorld(force) {\n\t\tconst box = this.box;\n\t\tif (box.isEmpty()) return;\n\t\tbox.getCenter(this.position);\n\t\tbox.getSize(this.scale);\n\t\tthis.scale.multiplyScalar(0.5);\n\t\tsuper.updateMatrixWorld(force);\n\t}\n\n}\n\nclass PlaneHelper extends Line {\n\tconstructor(plane, size = 1, hex = 0xffff00) {\n\t\tconst color = hex;\n\t\tconst positions = [1, -1, 1, -1, 1, 1, -1, -1, 1, 1, 1, 1, -1, 1, 1, -1, -1, 1, 1, -1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0];\n\t\tconst geometry = new BufferGeometry();\n\t\tgeometry.setAttribute('position', new Float32BufferAttribute(positions, 3));\n\t\tgeometry.computeBoundingSphere();\n\t\tsuper(geometry, new LineBasicMaterial({\n\t\t\tcolor: color,\n\t\t\ttoneMapped: false\n\t\t}));\n\t\tthis.type = 'PlaneHelper';\n\t\tthis.plane = plane;\n\t\tthis.size = size;\n\t\tconst positions2 = [1, 1, 1, -1, 1, 1, -1, -1, 1, 1, 1, 1, -1, -1, 1, 1, -1, 1];\n\t\tconst geometry2 = new BufferGeometry();\n\t\tgeometry2.setAttribute('position', new Float32BufferAttribute(positions2, 3));\n\t\tgeometry2.computeBoundingSphere();\n\t\tthis.add(new Mesh(geometry2, new MeshBasicMaterial({\n\t\t\tcolor: color,\n\t\t\topacity: 0.2,\n\t\t\ttransparent: true,\n\t\t\tdepthWrite: false,\n\t\t\ttoneMapped: false\n\t\t})));\n\t}\n\n\tupdateMatrixWorld(force) {\n\t\tlet scale = -this.plane.constant;\n\t\tif (Math.abs(scale) < 1e-8) scale = 1e-8; // sign does not matter\n\n\t\tthis.scale.set(0.5 * this.size, 0.5 * this.size, scale);\n\t\tthis.children[0].material.side = scale < 0 ? BackSide : FrontSide; // renderer flips side when determinant < 0; flipping not wanted here\n\n\t\tthis.lookAt(this.plane.normal);\n\t\tsuper.updateMatrixWorld(force);\n\t}\n\n}\n\nconst _axis = /*@__PURE__*/new Vector3();\n\nlet _lineGeometry, _coneGeometry;\n\nclass ArrowHelper extends Object3D {\n\t// dir is assumed to be normalized\n\tconstructor(dir = new Vector3(0, 0, 1), origin = new Vector3(0, 0, 0), length = 1, color = 0xffff00, headLength = length * 0.2, headWidth = headLength * 0.2) {\n\t\tsuper();\n\t\tthis.type = 'ArrowHelper';\n\n\t\tif (_lineGeometry === undefined) {\n\t\t\t_lineGeometry = new BufferGeometry();\n\n\t\t\t_lineGeometry.setAttribute('position', new Float32BufferAttribute([0, 0, 0, 0, 1, 0], 3));\n\n\t\t\t_coneGeometry = new CylinderGeometry(0, 0.5, 1, 5, 1);\n\n\t\t\t_coneGeometry.translate(0, -0.5, 0);\n\t\t}\n\n\t\tthis.position.copy(origin);\n\t\tthis.line = new Line(_lineGeometry, new LineBasicMaterial({\n\t\t\tcolor: color,\n\t\t\ttoneMapped: false\n\t\t}));\n\t\tthis.line.matrixAutoUpdate = false;\n\t\tthis.add(this.line);\n\t\tthis.cone = new Mesh(_coneGeometry, new MeshBasicMaterial({\n\t\t\tcolor: color,\n\t\t\ttoneMapped: false\n\t\t}));\n\t\tthis.cone.matrixAutoUpdate = false;\n\t\tthis.add(this.cone);\n\t\tthis.setDirection(dir);\n\t\tthis.setLength(length, headLength, headWidth);\n\t}\n\n\tsetDirection(dir) {\n\t\t// dir is assumed to be normalized\n\t\tif (dir.y > 0.99999) {\n\t\t\tthis.quaternion.set(0, 0, 0, 1);\n\t\t} else if (dir.y < -0.99999) {\n\t\t\tthis.quaternion.set(1, 0, 0, 0);\n\t\t} else {\n\t\t\t_axis.set(dir.z, 0, -dir.x).normalize();\n\n\t\t\tconst radians = Math.acos(dir.y);\n\t\t\tthis.quaternion.setFromAxisAngle(_axis, radians);\n\t\t}\n\t}\n\n\tsetLength(length, headLength = length * 0.2, headWidth = headLength * 0.2) {\n\t\tthis.line.scale.set(1, Math.max(0.0001, length - headLength), 1); // see #17458\n\n\t\tthis.line.updateMatrix();\n\t\tthis.cone.scale.set(headWidth, headLength, headWidth);\n\t\tthis.cone.position.y = length;\n\t\tthis.cone.updateMatrix();\n\t}\n\n\tsetColor(color) {\n\t\tthis.line.material.color.set(color);\n\t\tthis.cone.material.color.set(color);\n\t}\n\n\tcopy(source) {\n\t\tsuper.copy(source, false);\n\t\tthis.line.copy(source.line);\n\t\tthis.cone.copy(source.cone);\n\t\treturn this;\n\t}\n\n}\n\nclass AxesHelper extends LineSegments {\n\tconstructor(size = 1) {\n\t\tconst vertices = [0, 0, 0, size, 0, 0, 0, 0, 0, 0, size, 0, 0, 0, 0, 0, 0, size];\n\t\tconst colors = [1, 0, 0, 1, 0.6, 0, 0, 1, 0, 0.6, 1, 0, 0, 0, 1, 0, 0.6, 1];\n\t\tconst geometry = new BufferGeometry();\n\t\tgeometry.setAttribute('position', new Float32BufferAttribute(vertices, 3));\n\t\tgeometry.setAttribute('color', new Float32BufferAttribute(colors, 3));\n\t\tconst material = new LineBasicMaterial({\n\t\t\tvertexColors: true,\n\t\t\ttoneMapped: false\n\t\t});\n\t\tsuper(geometry, material);\n\t\tthis.type = 'AxesHelper';\n\t}\n\n\tsetColors(xAxisColor, yAxisColor, zAxisColor) {\n\t\tconst color = new Color();\n\t\tconst array = this.geometry.attributes.color.array;\n\t\tcolor.set(xAxisColor);\n\t\tcolor.toArray(array, 0);\n\t\tcolor.toArray(array, 3);\n\t\tcolor.set(yAxisColor);\n\t\tcolor.toArray(array, 6);\n\t\tcolor.toArray(array, 9);\n\t\tcolor.set(zAxisColor);\n\t\tcolor.toArray(array, 12);\n\t\tcolor.toArray(array, 15);\n\t\tthis.geometry.attributes.color.needsUpdate = true;\n\t\treturn this;\n\t}\n\n\tdispose() {\n\t\tthis.geometry.dispose();\n\t\tthis.material.dispose();\n\t}\n\n}\n\nclass ShapePath {\n\tconstructor() {\n\t\tthis.type = 'ShapePath';\n\t\tthis.color = new Color();\n\t\tthis.subPaths = [];\n\t\tthis.currentPath = null;\n\t}\n\n\tmoveTo(x, y) {\n\t\tthis.currentPath = new Path();\n\t\tthis.subPaths.push(this.currentPath);\n\t\tthis.currentPath.moveTo(x, y);\n\t\treturn this;\n\t}\n\n\tlineTo(x, y) {\n\t\tthis.currentPath.lineTo(x, y);\n\t\treturn this;\n\t}\n\n\tquadraticCurveTo(aCPx, aCPy, aX, aY) {\n\t\tthis.currentPath.quadraticCurveTo(aCPx, aCPy, aX, aY);\n\t\treturn this;\n\t}\n\n\tbezierCurveTo(aCP1x, aCP1y, aCP2x, aCP2y, aX, aY) {\n\t\tthis.currentPath.bezierCurveTo(aCP1x, aCP1y, aCP2x, aCP2y, aX, aY);\n\t\treturn this;\n\t}\n\n\tsplineThru(pts) {\n\t\tthis.currentPath.splineThru(pts);\n\t\treturn this;\n\t}\n\n\ttoShapes(isCCW, noHoles) {\n\t\tfunction toShapesNoHoles(inSubpaths) {\n\t\t\tconst shapes = [];\n\n\t\t\tfor (let i = 0, l = inSubpaths.length; i < l; i++) {\n\t\t\t\tconst tmpPath = inSubpaths[i];\n\t\t\t\tconst tmpShape = new Shape();\n\t\t\t\ttmpShape.curves = tmpPath.curves;\n\t\t\t\tshapes.push(tmpShape);\n\t\t\t}\n\n\t\t\treturn shapes;\n\t\t}\n\n\t\tfunction isPointInsidePolygon(inPt, inPolygon) {\n\t\t\tconst polyLen = inPolygon.length; // inPt on polygon contour => immediate success\t\tor\n\t\t\t// toggling of inside/outside at every single! intersection point of an edge\n\t\t\t//\twith the horizontal line through inPt, left of inPt\n\t\t\t//\tnot counting lowerY endpoints of edges and whole edges on that line\n\n\t\t\tlet inside = false;\n\n\t\t\tfor (let p = polyLen - 1, q = 0; q < polyLen; p = q++) {\n\t\t\t\tlet edgeLowPt = inPolygon[p];\n\t\t\t\tlet edgeHighPt = inPolygon[q];\n\t\t\t\tlet edgeDx = edgeHighPt.x - edgeLowPt.x;\n\t\t\t\tlet edgeDy = edgeHighPt.y - edgeLowPt.y;\n\n\t\t\t\tif (Math.abs(edgeDy) > Number.EPSILON) {\n\t\t\t\t\t// not parallel\n\t\t\t\t\tif (edgeDy < 0) {\n\t\t\t\t\t\tedgeLowPt = inPolygon[q];\n\t\t\t\t\t\tedgeDx = -edgeDx;\n\t\t\t\t\t\tedgeHighPt = inPolygon[p];\n\t\t\t\t\t\tedgeDy = -edgeDy;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (inPt.y < edgeLowPt.y || inPt.y > edgeHighPt.y) continue;\n\n\t\t\t\t\tif (inPt.y === edgeLowPt.y) {\n\t\t\t\t\t\tif (inPt.x === edgeLowPt.x) return true; // inPt is on contour ?\n\t\t\t\t\t\t// continue;\t\t\t\t// no intersection or edgeLowPt => doesn't count !!!\n\t\t\t\t\t} else {\n\t\t\t\t\t\tconst perpEdge = edgeDy * (inPt.x - edgeLowPt.x) - edgeDx * (inPt.y - edgeLowPt.y);\n\t\t\t\t\t\tif (perpEdge === 0) return true; // inPt is on contour ?\n\n\t\t\t\t\t\tif (perpEdge < 0) continue;\n\t\t\t\t\t\tinside = !inside; // true intersection left of inPt\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// parallel or collinear\n\t\t\t\t\tif (inPt.y !== edgeLowPt.y) continue; // parallel\n\t\t\t\t\t// edge lies on the same horizontal line as inPt\n\n\t\t\t\t\tif (edgeHighPt.x <= inPt.x && inPt.x <= edgeLowPt.x || edgeLowPt.x <= inPt.x && inPt.x <= edgeHighPt.x) return true; // inPt: Point on contour !\n\t\t\t\t\t// continue;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn inside;\n\t\t}\n\n\t\tconst isClockWise = ShapeUtils.isClockWise;\n\t\tconst subPaths = this.subPaths;\n\t\tif (subPaths.length === 0) return [];\n\t\tif (noHoles === true) return toShapesNoHoles(subPaths);\n\t\tlet solid, tmpPath, tmpShape;\n\t\tconst shapes = [];\n\n\t\tif (subPaths.length === 1) {\n\t\t\ttmpPath = subPaths[0];\n\t\t\ttmpShape = new Shape();\n\t\t\ttmpShape.curves = tmpPath.curves;\n\t\t\tshapes.push(tmpShape);\n\t\t\treturn shapes;\n\t\t}\n\n\t\tlet holesFirst = !isClockWise(subPaths[0].getPoints());\n\t\tholesFirst = isCCW ? !holesFirst : holesFirst; // console.log(\"Holes first\", holesFirst);\n\n\t\tconst betterShapeHoles = [];\n\t\tconst newShapes = [];\n\t\tlet newShapeHoles = [];\n\t\tlet mainIdx = 0;\n\t\tlet tmpPoints;\n\t\tnewShapes[mainIdx] = undefined;\n\t\tnewShapeHoles[mainIdx] = [];\n\n\t\tfor (let i = 0, l = subPaths.length; i < l; i++) {\n\t\t\ttmpPath = subPaths[i];\n\t\t\ttmpPoints = tmpPath.getPoints();\n\t\t\tsolid = isClockWise(tmpPoints);\n\t\t\tsolid = isCCW ? !solid : solid;\n\n\t\t\tif (solid) {\n\t\t\t\tif (!holesFirst && newShapes[mainIdx]) mainIdx++;\n\t\t\t\tnewShapes[mainIdx] = {\n\t\t\t\t\ts: new Shape(),\n\t\t\t\t\tp: tmpPoints\n\t\t\t\t};\n\t\t\t\tnewShapes[mainIdx].s.curves = tmpPath.curves;\n\t\t\t\tif (holesFirst) mainIdx++;\n\t\t\t\tnewShapeHoles[mainIdx] = []; //console.log('cw', i);\n\t\t\t} else {\n\t\t\t\tnewShapeHoles[mainIdx].push({\n\t\t\t\t\th: tmpPath,\n\t\t\t\t\tp: tmpPoints[0]\n\t\t\t\t}); //console.log('ccw', i);\n\t\t\t}\n\t\t} // only Holes? -> probably all Shapes with wrong orientation\n\n\n\t\tif (!newShapes[0]) return toShapesNoHoles(subPaths);\n\n\t\tif (newShapes.length > 1) {\n\t\t\tlet ambiguous = false;\n\t\t\tlet toChange = 0;\n\n\t\t\tfor (let sIdx = 0, sLen = newShapes.length; sIdx < sLen; sIdx++) {\n\t\t\t\tbetterShapeHoles[sIdx] = [];\n\t\t\t}\n\n\t\t\tfor (let sIdx = 0, sLen = newShapes.length; sIdx < sLen; sIdx++) {\n\t\t\t\tconst sho = newShapeHoles[sIdx];\n\n\t\t\t\tfor (let hIdx = 0; hIdx < sho.length; hIdx++) {\n\t\t\t\t\tconst ho = sho[hIdx];\n\t\t\t\t\tlet hole_unassigned = true;\n\n\t\t\t\t\tfor (let s2Idx = 0; s2Idx < newShapes.length; s2Idx++) {\n\t\t\t\t\t\tif (isPointInsidePolygon(ho.p, newShapes[s2Idx].p)) {\n\t\t\t\t\t\t\tif (sIdx !== s2Idx) toChange++;\n\n\t\t\t\t\t\t\tif (hole_unassigned) {\n\t\t\t\t\t\t\t\thole_unassigned = false;\n\t\t\t\t\t\t\t\tbetterShapeHoles[s2Idx].push(ho);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tambiguous = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (hole_unassigned) {\n\t\t\t\t\t\tbetterShapeHoles[sIdx].push(ho);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (toChange > 0 && ambiguous === false) {\n\t\t\t\tnewShapeHoles = betterShapeHoles;\n\t\t\t}\n\t\t}\n\n\t\tlet tmpHoles;\n\n\t\tfor (let i = 0, il = newShapes.length; i < il; i++) {\n\t\t\ttmpShape = newShapes[i].s;\n\t\t\tshapes.push(tmpShape);\n\t\t\ttmpHoles = newShapeHoles[i];\n\n\t\t\tfor (let j = 0, jl = tmpHoles.length; j < jl; j++) {\n\t\t\t\ttmpShape.holes.push(tmpHoles[j].h);\n\t\t\t}\n\t\t} //console.log(\"shape\", shapes);\n\n\n\t\treturn shapes;\n\t}\n\n}\n\nclass DataUtils {\n\t// float32 to float16\n\tstatic toHalfFloat(val) {\n\t\tif (Math.abs(val) > 65504) console.warn('THREE.DataUtils.toHalfFloat(): Value out of range.');\n\t\tval = clamp(val, -65504, 65504);\n\t\t_floatView[0] = val;\n\t\tconst f = _uint32View[0];\n\t\tconst e = f >> 23 & 0x1ff;\n\t\treturn _baseTable[e] + ((f & 0x007fffff) >> _shiftTable[e]);\n\t} // float16 to float32\n\n\n\tstatic fromHalfFloat(val) {\n\t\tconst m = val >> 10;\n\t\t_uint32View[0] = _mantissaTable[_offsetTable[m] + (val & 0x3ff)] + _exponentTable[m];\n\t\treturn _floatView[0];\n\t}\n\n} // float32 to float16 helpers\n\n\nconst _buffer = new ArrayBuffer(4);\n\nconst _floatView = new Float32Array(_buffer);\n\nconst _uint32View = new Uint32Array(_buffer);\n\nconst _baseTable = new Uint32Array(512);\n\nconst _shiftTable = new Uint32Array(512);\n\nfor (let i = 0; i < 256; ++i) {\n\tconst e = i - 127; // very small number (0, -0)\n\n\tif (e < -27) {\n\t\t_baseTable[i] = 0x0000;\n\t\t_baseTable[i | 0x100] = 0x8000;\n\t\t_shiftTable[i] = 24;\n\t\t_shiftTable[i | 0x100] = 24; // small number (denorm)\n\t} else if (e < -14) {\n\t\t_baseTable[i] = 0x0400 >> -e - 14;\n\t\t_baseTable[i | 0x100] = 0x0400 >> -e - 14 | 0x8000;\n\t\t_shiftTable[i] = -e - 1;\n\t\t_shiftTable[i | 0x100] = -e - 1; // normal number\n\t} else if (e <= 15) {\n\t\t_baseTable[i] = e + 15 << 10;\n\t\t_baseTable[i | 0x100] = e + 15 << 10 | 0x8000;\n\t\t_shiftTable[i] = 13;\n\t\t_shiftTable[i | 0x100] = 13; // large number (Infinity, -Infinity)\n\t} else if (e < 128) {\n\t\t_baseTable[i] = 0x7c00;\n\t\t_baseTable[i | 0x100] = 0xfc00;\n\t\t_shiftTable[i] = 24;\n\t\t_shiftTable[i | 0x100] = 24; // stay (NaN, Infinity, -Infinity)\n\t} else {\n\t\t_baseTable[i] = 0x7c00;\n\t\t_baseTable[i | 0x100] = 0xfc00;\n\t\t_shiftTable[i] = 13;\n\t\t_shiftTable[i | 0x100] = 13;\n\t}\n} // float16 to float32 helpers\n\n\nconst _mantissaTable = new Uint32Array(2048);\n\nconst _exponentTable = new Uint32Array(64);\n\nconst _offsetTable = new Uint32Array(64);\n\nfor (let i = 1; i < 1024; ++i) {\n\tlet m = i << 13; // zero pad mantissa bits\n\n\tlet e = 0; // zero exponent\n\t// normalized\n\n\twhile ((m & 0x00800000) === 0) {\n\t\tm <<= 1;\n\t\te -= 0x00800000; // decrement exponent\n\t}\n\n\tm &= ~0x00800000; // clear leading 1 bit\n\n\te += 0x38800000; // adjust bias\n\n\t_mantissaTable[i] = m | e;\n}\n\nfor (let i = 1024; i < 2048; ++i) {\n\t_mantissaTable[i] = 0x38000000 + (i - 1024 << 13);\n}\n\nfor (let i = 1; i < 31; ++i) {\n\t_exponentTable[i] = i << 23;\n}\n\n_exponentTable[31] = 0x47800000;\n_exponentTable[32] = 0x80000000;\n\nfor (let i = 33; i < 63; ++i) {\n\t_exponentTable[i] = 0x80000000 + (i - 32 << 23);\n}\n\n_exponentTable[63] = 0xc7800000;\n\nfor (let i = 1; i < 64; ++i) {\n\tif (i !== 32) {\n\t\t_offsetTable[i] = 1024;\n\t}\n}\n\nclass ParametricGeometry extends BufferGeometry {\n\tconstructor() {\n\t\tconsole.error('THREE.ParametricGeometry has been moved to /examples/jsm/geometries/ParametricGeometry.js');\n\t\tsuper();\n\t}\n\n} // r133, eb58ff153119090d3bbb24474ea0ffc40c70dc92\n\nclass TextGeometry extends BufferGeometry {\n\tconstructor() {\n\t\tconsole.error('THREE.TextGeometry has been moved to /examples/jsm/geometries/TextGeometry.js');\n\t\tsuper();\n\t}\n\n} // r133, eb58ff153119090d3bbb24474ea0ffc40c70dc92\n\nfunction FontLoader() {\n\tconsole.error('THREE.FontLoader has been moved to /examples/jsm/loaders/FontLoader.js');\n} // r133, eb58ff153119090d3bbb24474ea0ffc40c70dc92\n\nfunction Font() {\n\tconsole.error('THREE.Font has been moved to /examples/jsm/loaders/FontLoader.js');\n} // r134, d65e0af06644fe5a84a6fc0e372f4318f95a04c0\n\nfunction ImmediateRenderObject() {\n\tconsole.error('THREE.ImmediateRenderObject has been removed.');\n} // r138, 48b05d3500acc084df50be9b4c90781ad9b8cb17\n\nclass WebGLMultisampleRenderTarget extends WebGLRenderTarget {\n\tconstructor(width, height, options) {\n\t\tconsole.error('THREE.WebGLMultisampleRenderTarget has been removed. Use a normal render target and set the \"samples\" property to greater 0 to enable multisampling.');\n\t\tsuper(width, height, options);\n\t\tthis.samples = 4;\n\t}\n\n} // r138, f9cd9cab03b7b64244e304900a3a2eeaa3a588ce\n\nclass DataTexture2DArray extends DataArrayTexture {\n\tconstructor(data, width, height, depth) {\n\t\tconsole.warn('THREE.DataTexture2DArray has been renamed to DataArrayTexture.');\n\t\tsuper(data, width, height, depth);\n\t}\n\n} // r138, f9cd9cab03b7b64244e304900a3a2eeaa3a588ce\n\nclass DataTexture3D extends Data3DTexture {\n\tconstructor(data, width, height, depth) {\n\t\tconsole.warn('THREE.DataTexture3D has been renamed to Data3DTexture.');\n\t\tsuper(data, width, height, depth);\n\t}\n\n}\n\nif (typeof __THREE_DEVTOOLS__ !== 'undefined') {\n\t__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent('register', {\n\t\tdetail: {\n\t\t\trevision: REVISION\n\t\t}\n\t}));\n}\n\nif (typeof window !== 'undefined') {\n\tif (window.__THREE__) {\n\t\tconsole.warn('WARNING: Multiple instances of Three.js being imported.');\n\t} else {\n\t\twindow.__THREE__ = REVISION;\n\t}\n}\n\nexports.ACESFilmicToneMapping = ACESFilmicToneMapping;\nexports.AddEquation = AddEquation;\nexports.AddOperation = AddOperation;\nexports.AdditiveAnimationBlendMode = AdditiveAnimationBlendMode;\nexports.AdditiveBlending = AdditiveBlending;\nexports.AlphaFormat = AlphaFormat;\nexports.AlwaysDepth = AlwaysDepth;\nexports.AlwaysStencilFunc = AlwaysStencilFunc;\nexports.AmbientLight = AmbientLight;\nexports.AmbientLightProbe = AmbientLightProbe;\nexports.AnimationClip = AnimationClip;\nexports.AnimationLoader = AnimationLoader;\nexports.AnimationMixer = AnimationMixer;\nexports.AnimationObjectGroup = AnimationObjectGroup;\nexports.AnimationUtils = AnimationUtils;\nexports.ArcCurve = ArcCurve;\nexports.ArrayCamera = ArrayCamera;\nexports.ArrowHelper = ArrowHelper;\nexports.Audio = Audio;\nexports.AudioAnalyser = AudioAnalyser;\nexports.AudioContext = AudioContext;\nexports.AudioListener = AudioListener;\nexports.AudioLoader = AudioLoader;\nexports.AxesHelper = AxesHelper;\nexports.BackSide = BackSide;\nexports.BasicDepthPacking = BasicDepthPacking;\nexports.BasicShadowMap = BasicShadowMap;\nexports.Bone = Bone;\nexports.BooleanKeyframeTrack = BooleanKeyframeTrack;\nexports.Box2 = Box2;\nexports.Box3 = Box3;\nexports.Box3Helper = Box3Helper;\nexports.BoxBufferGeometry = BoxGeometry;\nexports.BoxGeometry = BoxGeometry;\nexports.BoxHelper = BoxHelper;\nexports.BufferAttribute = BufferAttribute;\nexports.BufferGeometry = BufferGeometry;\nexports.BufferGeometryLoader = BufferGeometryLoader;\nexports.ByteType = ByteType;\nexports.Cache = Cache;\nexports.Camera = Camera;\nexports.CameraHelper = CameraHelper;\nexports.CanvasTexture = CanvasTexture;\nexports.CapsuleBufferGeometry = CapsuleGeometry;\nexports.CapsuleGeometry = CapsuleGeometry;\nexports.CatmullRomCurve3 = CatmullRomCurve3;\nexports.CineonToneMapping = CineonToneMapping;\nexports.CircleBufferGeometry = CircleGeometry;\nexports.CircleGeometry = CircleGeometry;\nexports.ClampToEdgeWrapping = ClampToEdgeWrapping;\nexports.Clock = Clock;\nexports.Color = Color;\nexports.ColorKeyframeTrack = ColorKeyframeTrack;\nexports.ColorManagement = ColorManagement;\nexports.CompressedTexture = CompressedTexture;\nexports.CompressedTextureLoader = CompressedTextureLoader;\nexports.ConeBufferGeometry = ConeGeometry;\nexports.ConeGeometry = ConeGeometry;\nexports.CubeCamera = CubeCamera;\nexports.CubeReflectionMapping = CubeReflectionMapping;\nexports.CubeRefractionMapping = CubeRefractionMapping;\nexports.CubeTexture = CubeTexture;\nexports.CubeTextureLoader = CubeTextureLoader;\nexports.CubeUVReflectionMapping = CubeUVReflectionMapping;\nexports.CubicBezierCurve = CubicBezierCurve;\nexports.CubicBezierCurve3 = CubicBezierCurve3;\nexports.CubicInterpolant = CubicInterpolant;\nexports.CullFaceBack = CullFaceBack;\nexports.CullFaceFront = CullFaceFront;\nexports.CullFaceFrontBack = CullFaceFrontBack;\nexports.CullFaceNone = CullFaceNone;\nexports.Curve = Curve;\nexports.CurvePath = CurvePath;\nexports.CustomBlending = CustomBlending;\nexports.CustomToneMapping = CustomToneMapping;\nexports.CylinderBufferGeometry = CylinderGeometry;\nexports.CylinderGeometry = CylinderGeometry;\nexports.Cylindrical = Cylindrical;\nexports.Data3DTexture = Data3DTexture;\nexports.DataArrayTexture = DataArrayTexture;\nexports.DataTexture = DataTexture;\nexports.DataTexture2DArray = DataTexture2DArray;\nexports.DataTexture3D = DataTexture3D;\nexports.DataTextureLoader = DataTextureLoader;\nexports.DataUtils = DataUtils;\nexports.DecrementStencilOp = DecrementStencilOp;\nexports.DecrementWrapStencilOp = DecrementWrapStencilOp;\nexports.DefaultLoadingManager = DefaultLoadingManager;\nexports.DepthFormat = DepthFormat;\nexports.DepthStencilFormat = DepthStencilFormat;\nexports.DepthTexture = DepthTexture;\nexports.DirectionalLight = DirectionalLight;\nexports.DirectionalLightHelper = DirectionalLightHelper;\nexports.DiscreteInterpolant = DiscreteInterpolant;\nexports.DodecahedronBufferGeometry = DodecahedronGeometry;\nexports.DodecahedronGeometry = DodecahedronGeometry;\nexports.DoubleSide = DoubleSide;\nexports.DstAlphaFactor = DstAlphaFactor;\nexports.DstColorFactor = DstColorFactor;\nexports.DynamicCopyUsage = DynamicCopyUsage;\nexports.DynamicDrawUsage = DynamicDrawUsage;\nexports.DynamicReadUsage = DynamicReadUsage;\nexports.EdgesGeometry = EdgesGeometry;\nexports.EllipseCurve = EllipseCurve;\nexports.EqualDepth = EqualDepth;\nexports.EqualStencilFunc = EqualStencilFunc;\nexports.EquirectangularReflectionMapping = EquirectangularReflectionMapping;\nexports.EquirectangularRefractionMapping = EquirectangularRefractionMapping;\nexports.Euler = Euler;\nexports.EventDispatcher = EventDispatcher;\nexports.ExtrudeBufferGeometry = ExtrudeGeometry;\nexports.ExtrudeGeometry = ExtrudeGeometry;\nexports.FileLoader = FileLoader;\nexports.FlatShading = FlatShading;\nexports.Float16BufferAttribute = Float16BufferAttribute;\nexports.Float32BufferAttribute = Float32BufferAttribute;\nexports.Float64BufferAttribute = Float64BufferAttribute;\nexports.FloatType = FloatType;\nexports.Fog = Fog;\nexports.FogExp2 = FogExp2;\nexports.Font = Font;\nexports.FontLoader = FontLoader;\nexports.FramebufferTexture = FramebufferTexture;\nexports.FrontSide = FrontSide;\nexports.Frustum = Frustum;\nexports.GLBufferAttribute = GLBufferAttribute;\nexports.GLSL1 = GLSL1;\nexports.GLSL3 = GLSL3;\nexports.GreaterDepth = GreaterDepth;\nexports.GreaterEqualDepth = GreaterEqualDepth;\nexports.GreaterEqualStencilFunc = GreaterEqualStencilFunc;\nexports.GreaterStencilFunc = GreaterStencilFunc;\nexports.GridHelper = GridHelper;\nexports.Group = Group;\nexports.HalfFloatType = HalfFloatType;\nexports.HemisphereLight = HemisphereLight;\nexports.HemisphereLightHelper = HemisphereLightHelper;\nexports.HemisphereLightProbe = HemisphereLightProbe;\nexports.IcosahedronBufferGeometry = IcosahedronGeometry;\nexports.IcosahedronGeometry = IcosahedronGeometry;\nexports.ImageBitmapLoader = ImageBitmapLoader;\nexports.ImageLoader = ImageLoader;\nexports.ImageUtils = ImageUtils;\nexports.ImmediateRenderObject = ImmediateRenderObject;\nexports.IncrementStencilOp = IncrementStencilOp;\nexports.IncrementWrapStencilOp = IncrementWrapStencilOp;\nexports.InstancedBufferAttribute = InstancedBufferAttribute;\nexports.InstancedBufferGeometry = InstancedBufferGeometry;\nexports.InstancedInterleavedBuffer = InstancedInterleavedBuffer;\nexports.InstancedMesh = InstancedMesh;\nexports.Int16BufferAttribute = Int16BufferAttribute;\nexports.Int32BufferAttribute = Int32BufferAttribute;\nexports.Int8BufferAttribute = Int8BufferAttribute;\nexports.IntType = IntType;\nexports.InterleavedBuffer = InterleavedBuffer;\nexports.InterleavedBufferAttribute = InterleavedBufferAttribute;\nexports.Interpolant = Interpolant;\nexports.InterpolateDiscrete = InterpolateDiscrete;\nexports.InterpolateLinear = InterpolateLinear;\nexports.InterpolateSmooth = InterpolateSmooth;\nexports.InvertStencilOp = InvertStencilOp;\nexports.KeepStencilOp = KeepStencilOp;\nexports.KeyframeTrack = KeyframeTrack;\nexports.LOD = LOD;\nexports.LatheBufferGeometry = LatheGeometry;\nexports.LatheGeometry = LatheGeometry;\nexports.Layers = Layers;\nexports.LessDepth = LessDepth;\nexports.LessEqualDepth = LessEqualDepth;\nexports.LessEqualStencilFunc = LessEqualStencilFunc;\nexports.LessStencilFunc = LessStencilFunc;\nexports.Light = Light;\nexports.LightProbe = LightProbe;\nexports.Line = Line;\nexports.Line3 = Line3;\nexports.LineBasicMaterial = LineBasicMaterial;\nexports.LineCurve = LineCurve;\nexports.LineCurve3 = LineCurve3;\nexports.LineDashedMaterial = LineDashedMaterial;\nexports.LineLoop = LineLoop;\nexports.LineSegments = LineSegments;\nexports.LinearEncoding = LinearEncoding;\nexports.LinearFilter = LinearFilter;\nexports.LinearInterpolant = LinearInterpolant;\nexports.LinearMipMapLinearFilter = LinearMipMapLinearFilter;\nexports.LinearMipMapNearestFilter = LinearMipMapNearestFilter;\nexports.LinearMipmapLinearFilter = LinearMipmapLinearFilter;\nexports.LinearMipmapNearestFilter = LinearMipmapNearestFilter;\nexports.LinearSRGBColorSpace = LinearSRGBColorSpace;\nexports.LinearToneMapping = LinearToneMapping;\nexports.Loader = Loader;\nexports.LoaderUtils = LoaderUtils;\nexports.LoadingManager = LoadingManager;\nexports.LoopOnce = LoopOnce;\nexports.LoopPingPong = LoopPingPong;\nexports.LoopRepeat = LoopRepeat;\nexports.LuminanceAlphaFormat = LuminanceAlphaFormat;\nexports.LuminanceFormat = LuminanceFormat;\nexports.MOUSE = MOUSE;\nexports.Material = Material;\nexports.MaterialLoader = MaterialLoader;\nexports.MathUtils = MathUtils;\nexports.Matrix3 = Matrix3;\nexports.Matrix4 = Matrix4;\nexports.MaxEquation = MaxEquation;\nexports.Mesh = Mesh;\nexports.MeshBasicMaterial = MeshBasicMaterial;\nexports.MeshDepthMaterial = MeshDepthMaterial;\nexports.MeshDistanceMaterial = MeshDistanceMaterial;\nexports.MeshLambertMaterial = MeshLambertMaterial;\nexports.MeshMatcapMaterial = MeshMatcapMaterial;\nexports.MeshNormalMaterial = MeshNormalMaterial;\nexports.MeshPhongMaterial = MeshPhongMaterial;\nexports.MeshPhysicalMaterial = MeshPhysicalMaterial;\nexports.MeshStandardMaterial = MeshStandardMaterial;\nexports.MeshToonMaterial = MeshToonMaterial;\nexports.MinEquation = MinEquation;\nexports.MirroredRepeatWrapping = MirroredRepeatWrapping;\nexports.MixOperation = MixOperation;\nexports.MultiplyBlending = MultiplyBlending;\nexports.MultiplyOperation = MultiplyOperation;\nexports.NearestFilter = NearestFilter;\nexports.NearestMipMapLinearFilter = NearestMipMapLinearFilter;\nexports.NearestMipMapNearestFilter = NearestMipMapNearestFilter;\nexports.NearestMipmapLinearFilter = NearestMipmapLinearFilter;\nexports.NearestMipmapNearestFilter = NearestMipmapNearestFilter;\nexports.NeverDepth = NeverDepth;\nexports.NeverStencilFunc = NeverStencilFunc;\nexports.NoBlending = NoBlending;\nexports.NoColorSpace = NoColorSpace;\nexports.NoToneMapping = NoToneMapping;\nexports.NormalAnimationBlendMode = NormalAnimationBlendMode;\nexports.NormalBlending = NormalBlending;\nexports.NotEqualDepth = NotEqualDepth;\nexports.NotEqualStencilFunc = NotEqualStencilFunc;\nexports.NumberKeyframeTrack = NumberKeyframeTrack;\nexports.Object3D = Object3D;\nexports.ObjectLoader = ObjectLoader;\nexports.ObjectSpaceNormalMap = ObjectSpaceNormalMap;\nexports.OctahedronBufferGeometry = OctahedronGeometry;\nexports.OctahedronGeometry = OctahedronGeometry;\nexports.OneFactor = OneFactor;\nexports.OneMinusDstAlphaFactor = OneMinusDstAlphaFactor;\nexports.OneMinusDstColorFactor = OneMinusDstColorFactor;\nexports.OneMinusSrcAlphaFactor = OneMinusSrcAlphaFactor;\nexports.OneMinusSrcColorFactor = OneMinusSrcColorFactor;\nexports.OrthographicCamera = OrthographicCamera;\nexports.PCFShadowMap = PCFShadowMap;\nexports.PCFSoftShadowMap = PCFSoftShadowMap;\nexports.PMREMGenerator = PMREMGenerator;\nexports.ParametricGeometry = ParametricGeometry;\nexports.Path = Path;\nexports.PerspectiveCamera = PerspectiveCamera;\nexports.Plane = Plane;\nexports.PlaneBufferGeometry = PlaneGeometry;\nexports.PlaneGeometry = PlaneGeometry;\nexports.PlaneHelper = PlaneHelper;\nexports.PointLight = PointLight;\nexports.PointLightHelper = PointLightHelper;\nexports.Points = Points;\nexports.PointsMaterial = PointsMaterial;\nexports.PolarGridHelper = PolarGridHelper;\nexports.PolyhedronBufferGeometry = PolyhedronGeometry;\nexports.PolyhedronGeometry = PolyhedronGeometry;\nexports.PositionalAudio = PositionalAudio;\nexports.PropertyBinding = PropertyBinding;\nexports.PropertyMixer = PropertyMixer;\nexports.QuadraticBezierCurve = QuadraticBezierCurve;\nexports.QuadraticBezierCurve3 = QuadraticBezierCurve3;\nexports.Quaternion = Quaternion;\nexports.QuaternionKeyframeTrack = QuaternionKeyframeTrack;\nexports.QuaternionLinearInterpolant = QuaternionLinearInterpolant;\nexports.REVISION = REVISION;\nexports.RGBADepthPacking = RGBADepthPacking;\nexports.RGBAFormat = RGBAFormat;\nexports.RGBAIntegerFormat = RGBAIntegerFormat;\nexports.RGBA_ASTC_10x10_Format = RGBA_ASTC_10x10_Format;\nexports.RGBA_ASTC_10x5_Format = RGBA_ASTC_10x5_Format;\nexports.RGBA_ASTC_10x6_Format = RGBA_ASTC_10x6_Format;\nexports.RGBA_ASTC_10x8_Format = RGBA_ASTC_10x8_Format;\nexports.RGBA_ASTC_12x10_Format = RGBA_ASTC_12x10_Format;\nexports.RGBA_ASTC_12x12_Format = RGBA_ASTC_12x12_Format;\nexports.RGBA_ASTC_4x4_Format = RGBA_ASTC_4x4_Format;\nexports.RGBA_ASTC_5x4_Format = RGBA_ASTC_5x4_Format;\nexports.RGBA_ASTC_5x5_Format = RGBA_ASTC_5x5_Format;\nexports.RGBA_ASTC_6x5_Format = RGBA_ASTC_6x5_Format;\nexports.RGBA_ASTC_6x6_Format = RGBA_ASTC_6x6_Format;\nexports.RGBA_ASTC_8x5_Format = RGBA_ASTC_8x5_Format;\nexports.RGBA_ASTC_8x6_Format = RGBA_ASTC_8x6_Format;\nexports.RGBA_ASTC_8x8_Format = RGBA_ASTC_8x8_Format;\nexports.RGBA_BPTC_Format = RGBA_BPTC_Format;\nexports.RGBA_ETC2_EAC_Format = RGBA_ETC2_EAC_Format;\nexports.RGBA_PVRTC_2BPPV1_Format = RGBA_PVRTC_2BPPV1_Format;\nexports.RGBA_PVRTC_4BPPV1_Format = RGBA_PVRTC_4BPPV1_Format;\nexports.RGBA_S3TC_DXT1_Format = RGBA_S3TC_DXT1_Format;\nexports.RGBA_S3TC_DXT3_Format = RGBA_S3TC_DXT3_Format;\nexports.RGBA_S3TC_DXT5_Format = RGBA_S3TC_DXT5_Format;\nexports.RGBFormat = RGBFormat;\nexports.RGB_ETC1_Format = RGB_ETC1_Format;\nexports.RGB_ETC2_Format = RGB_ETC2_Format;\nexports.RGB_PVRTC_2BPPV1_Format = RGB_PVRTC_2BPPV1_Format;\nexports.RGB_PVRTC_4BPPV1_Format = RGB_PVRTC_4BPPV1_Format;\nexports.RGB_S3TC_DXT1_Format = RGB_S3TC_DXT1_Format;\nexports.RGFormat = RGFormat;\nexports.RGIntegerFormat = RGIntegerFormat;\nexports.RawShaderMaterial = RawShaderMaterial;\nexports.Ray = Ray;\nexports.Raycaster = Raycaster;\nexports.RectAreaLight = RectAreaLight;\nexports.RedFormat = RedFormat;\nexports.RedIntegerFormat = RedIntegerFormat;\nexports.ReinhardToneMapping = ReinhardToneMapping;\nexports.RepeatWrapping = RepeatWrapping;\nexports.ReplaceStencilOp = ReplaceStencilOp;\nexports.ReverseSubtractEquation = ReverseSubtractEquation;\nexports.RingBufferGeometry = RingGeometry;\nexports.RingGeometry = RingGeometry;\nexports.SRGBColorSpace = SRGBColorSpace;\nexports.Scene = Scene;\nexports.ShaderChunk = ShaderChunk;\nexports.ShaderLib = ShaderLib;\nexports.ShaderMaterial = ShaderMaterial;\nexports.ShadowMaterial = ShadowMaterial;\nexports.Shape = Shape;\nexports.ShapeBufferGeometry = ShapeGeometry;\nexports.ShapeGeometry = ShapeGeometry;\nexports.ShapePath = ShapePath;\nexports.ShapeUtils = ShapeUtils;\nexports.ShortType = ShortType;\nexports.Skeleton = Skeleton;\nexports.SkeletonHelper = SkeletonHelper;\nexports.SkinnedMesh = SkinnedMesh;\nexports.SmoothShading = SmoothShading;\nexports.Source = Source;\nexports.Sphere = Sphere;\nexports.SphereBufferGeometry = SphereGeometry;\nexports.SphereGeometry = SphereGeometry;\nexports.Spherical = Spherical;\nexports.SphericalHarmonics3 = SphericalHarmonics3;\nexports.SplineCurve = SplineCurve;\nexports.SpotLight = SpotLight;\nexports.SpotLightHelper = SpotLightHelper;\nexports.Sprite = Sprite;\nexports.SpriteMaterial = SpriteMaterial;\nexports.SrcAlphaFactor = SrcAlphaFactor;\nexports.SrcAlphaSaturateFactor = SrcAlphaSaturateFactor;\nexports.SrcColorFactor = SrcColorFactor;\nexports.StaticCopyUsage = StaticCopyUsage;\nexports.StaticDrawUsage = StaticDrawUsage;\nexports.StaticReadUsage = StaticReadUsage;\nexports.StereoCamera = StereoCamera;\nexports.StreamCopyUsage = StreamCopyUsage;\nexports.StreamDrawUsage = StreamDrawUsage;\nexports.StreamReadUsage = StreamReadUsage;\nexports.StringKeyframeTrack = StringKeyframeTrack;\nexports.SubtractEquation = SubtractEquation;\nexports.SubtractiveBlending = SubtractiveBlending;\nexports.TOUCH = TOUCH;\nexports.TangentSpaceNormalMap = TangentSpaceNormalMap;\nexports.TetrahedronBufferGeometry = TetrahedronGeometry;\nexports.TetrahedronGeometry = TetrahedronGeometry;\nexports.TextGeometry = TextGeometry;\nexports.Texture = Texture;\nexports.TextureLoader = TextureLoader;\nexports.TorusBufferGeometry = TorusGeometry;\nexports.TorusGeometry = TorusGeometry;\nexports.TorusKnotBufferGeometry = TorusKnotGeometry;\nexports.TorusKnotGeometry = TorusKnotGeometry;\nexports.Triangle = Triangle;\nexports.TriangleFanDrawMode = TriangleFanDrawMode;\nexports.TriangleStripDrawMode = TriangleStripDrawMode;\nexports.TrianglesDrawMode = TrianglesDrawMode;\nexports.TubeBufferGeometry = TubeGeometry;\nexports.TubeGeometry = TubeGeometry;\nexports.UVMapping = UVMapping;\nexports.Uint16BufferAttribute = Uint16BufferAttribute;\nexports.Uint32BufferAttribute = Uint32BufferAttribute;\nexports.Uint8BufferAttribute = Uint8BufferAttribute;\nexports.Uint8ClampedBufferAttribute = Uint8ClampedBufferAttribute;\nexports.Uniform = Uniform;\nexports.UniformsLib = UniformsLib;\nexports.UniformsUtils = UniformsUtils;\nexports.UnsignedByteType = UnsignedByteType;\nexports.UnsignedInt248Type = UnsignedInt248Type;\nexports.UnsignedIntType = UnsignedIntType;\nexports.UnsignedShort4444Type = UnsignedShort4444Type;\nexports.UnsignedShort5551Type = UnsignedShort5551Type;\nexports.UnsignedShortType = UnsignedShortType;\nexports.VSMShadowMap = VSMShadowMap;\nexports.Vector2 = Vector2;\nexports.Vector3 = Vector3;\nexports.Vector4 = Vector4;\nexports.VectorKeyframeTrack = VectorKeyframeTrack;\nexports.VideoTexture = VideoTexture;\nexports.WebGL1Renderer = WebGL1Renderer;\nexports.WebGL3DRenderTarget = WebGL3DRenderTarget;\nexports.WebGLArrayRenderTarget = WebGLArrayRenderTarget;\nexports.WebGLCubeRenderTarget = WebGLCubeRenderTarget;\nexports.WebGLMultipleRenderTargets = WebGLMultipleRenderTargets;\nexports.WebGLMultisampleRenderTarget = WebGLMultisampleRenderTarget;\nexports.WebGLRenderTarget = WebGLRenderTarget;\nexports.WebGLRenderer = WebGLRenderer;\nexports.WebGLUtils = WebGLUtils;\nexports.WireframeGeometry = WireframeGeometry;\nexports.WrapAroundEnding = WrapAroundEnding;\nexports.ZeroCurvatureEnding = ZeroCurvatureEnding;\nexports.ZeroFactor = ZeroFactor;\nexports.ZeroSlopeEnding = ZeroSlopeEnding;\nexports.ZeroStencilOp = ZeroStencilOp;\nexports._SRGBAFormat = _SRGBAFormat;\nexports.sRGBEncoding = sRGBEncoding;\n","/**\n * @license\n * Copyright 2010-2022 Three.js Authors\n * SPDX-License-Identifier: MIT\n */\nconst REVISION = '141';\nconst MOUSE = { LEFT: 0, MIDDLE: 1, RIGHT: 2, ROTATE: 0, DOLLY: 1, PAN: 2 };\nconst TOUCH = { ROTATE: 0, PAN: 1, DOLLY_PAN: 2, DOLLY_ROTATE: 3 };\nconst CullFaceNone = 0;\nconst CullFaceBack = 1;\nconst CullFaceFront = 2;\nconst CullFaceFrontBack = 3;\nconst BasicShadowMap = 0;\nconst PCFShadowMap = 1;\nconst PCFSoftShadowMap = 2;\nconst VSMShadowMap = 3;\nconst FrontSide = 0;\nconst BackSide = 1;\nconst DoubleSide = 2;\nconst FlatShading = 1;\nconst SmoothShading = 2;\nconst NoBlending = 0;\nconst NormalBlending = 1;\nconst AdditiveBlending = 2;\nconst SubtractiveBlending = 3;\nconst MultiplyBlending = 4;\nconst CustomBlending = 5;\nconst AddEquation = 100;\nconst SubtractEquation = 101;\nconst ReverseSubtractEquation = 102;\nconst MinEquation = 103;\nconst MaxEquation = 104;\nconst ZeroFactor = 200;\nconst OneFactor = 201;\nconst SrcColorFactor = 202;\nconst OneMinusSrcColorFactor = 203;\nconst SrcAlphaFactor = 204;\nconst OneMinusSrcAlphaFactor = 205;\nconst DstAlphaFactor = 206;\nconst OneMinusDstAlphaFactor = 207;\nconst DstColorFactor = 208;\nconst OneMinusDstColorFactor = 209;\nconst SrcAlphaSaturateFactor = 210;\nconst NeverDepth = 0;\nconst AlwaysDepth = 1;\nconst LessDepth = 2;\nconst LessEqualDepth = 3;\nconst EqualDepth = 4;\nconst GreaterEqualDepth = 5;\nconst GreaterDepth = 6;\nconst NotEqualDepth = 7;\nconst MultiplyOperation = 0;\nconst MixOperation = 1;\nconst AddOperation = 2;\nconst NoToneMapping = 0;\nconst LinearToneMapping = 1;\nconst ReinhardToneMapping = 2;\nconst CineonToneMapping = 3;\nconst ACESFilmicToneMapping = 4;\nconst CustomToneMapping = 5;\n\nconst UVMapping = 300;\nconst CubeReflectionMapping = 301;\nconst CubeRefractionMapping = 302;\nconst EquirectangularReflectionMapping = 303;\nconst EquirectangularRefractionMapping = 304;\nconst CubeUVReflectionMapping = 306;\nconst RepeatWrapping = 1000;\nconst ClampToEdgeWrapping = 1001;\nconst MirroredRepeatWrapping = 1002;\nconst NearestFilter = 1003;\nconst NearestMipmapNearestFilter = 1004;\nconst NearestMipMapNearestFilter = 1004;\nconst NearestMipmapLinearFilter = 1005;\nconst NearestMipMapLinearFilter = 1005;\nconst LinearFilter = 1006;\nconst LinearMipmapNearestFilter = 1007;\nconst LinearMipMapNearestFilter = 1007;\nconst LinearMipmapLinearFilter = 1008;\nconst LinearMipMapLinearFilter = 1008;\nconst UnsignedByteType = 1009;\nconst ByteType = 1010;\nconst ShortType = 1011;\nconst UnsignedShortType = 1012;\nconst IntType = 1013;\nconst UnsignedIntType = 1014;\nconst FloatType = 1015;\nconst HalfFloatType = 1016;\nconst UnsignedShort4444Type = 1017;\nconst UnsignedShort5551Type = 1018;\nconst UnsignedInt248Type = 1020;\nconst AlphaFormat = 1021;\nconst RGBFormat = 1022;\nconst RGBAFormat = 1023;\nconst LuminanceFormat = 1024;\nconst LuminanceAlphaFormat = 1025;\nconst DepthFormat = 1026;\nconst DepthStencilFormat = 1027;\nconst RedFormat = 1028;\nconst RedIntegerFormat = 1029;\nconst RGFormat = 1030;\nconst RGIntegerFormat = 1031;\nconst RGBAIntegerFormat = 1033;\n\nconst RGB_S3TC_DXT1_Format = 33776;\nconst RGBA_S3TC_DXT1_Format = 33777;\nconst RGBA_S3TC_DXT3_Format = 33778;\nconst RGBA_S3TC_DXT5_Format = 33779;\nconst RGB_PVRTC_4BPPV1_Format = 35840;\nconst RGB_PVRTC_2BPPV1_Format = 35841;\nconst RGBA_PVRTC_4BPPV1_Format = 35842;\nconst RGBA_PVRTC_2BPPV1_Format = 35843;\nconst RGB_ETC1_Format = 36196;\nconst RGB_ETC2_Format = 37492;\nconst RGBA_ETC2_EAC_Format = 37496;\nconst RGBA_ASTC_4x4_Format = 37808;\nconst RGBA_ASTC_5x4_Format = 37809;\nconst RGBA_ASTC_5x5_Format = 37810;\nconst RGBA_ASTC_6x5_Format = 37811;\nconst RGBA_ASTC_6x6_Format = 37812;\nconst RGBA_ASTC_8x5_Format = 37813;\nconst RGBA_ASTC_8x6_Format = 37814;\nconst RGBA_ASTC_8x8_Format = 37815;\nconst RGBA_ASTC_10x5_Format = 37816;\nconst RGBA_ASTC_10x6_Format = 37817;\nconst RGBA_ASTC_10x8_Format = 37818;\nconst RGBA_ASTC_10x10_Format = 37819;\nconst RGBA_ASTC_12x10_Format = 37820;\nconst RGBA_ASTC_12x12_Format = 37821;\nconst RGBA_BPTC_Format = 36492;\nconst LoopOnce = 2200;\nconst LoopRepeat = 2201;\nconst LoopPingPong = 2202;\nconst InterpolateDiscrete = 2300;\nconst InterpolateLinear = 2301;\nconst InterpolateSmooth = 2302;\nconst ZeroCurvatureEnding = 2400;\nconst ZeroSlopeEnding = 2401;\nconst WrapAroundEnding = 2402;\nconst NormalAnimationBlendMode = 2500;\nconst AdditiveAnimationBlendMode = 2501;\nconst TrianglesDrawMode = 0;\nconst TriangleStripDrawMode = 1;\nconst TriangleFanDrawMode = 2;\nconst LinearEncoding = 3000;\nconst sRGBEncoding = 3001;\nconst BasicDepthPacking = 3200;\nconst RGBADepthPacking = 3201;\nconst TangentSpaceNormalMap = 0;\nconst ObjectSpaceNormalMap = 1;\n\n// Color space string identifiers, matching CSS Color Module Level 4 and WebGPU names where available.\nconst NoColorSpace = '';\nconst SRGBColorSpace = 'srgb';\nconst LinearSRGBColorSpace = 'srgb-linear';\n\nconst ZeroStencilOp = 0;\nconst KeepStencilOp = 7680;\nconst ReplaceStencilOp = 7681;\nconst IncrementStencilOp = 7682;\nconst DecrementStencilOp = 7683;\nconst IncrementWrapStencilOp = 34055;\nconst DecrementWrapStencilOp = 34056;\nconst InvertStencilOp = 5386;\n\nconst NeverStencilFunc = 512;\nconst LessStencilFunc = 513;\nconst EqualStencilFunc = 514;\nconst LessEqualStencilFunc = 515;\nconst GreaterStencilFunc = 516;\nconst NotEqualStencilFunc = 517;\nconst GreaterEqualStencilFunc = 518;\nconst AlwaysStencilFunc = 519;\n\nconst StaticDrawUsage = 35044;\nconst DynamicDrawUsage = 35048;\nconst StreamDrawUsage = 35040;\nconst StaticReadUsage = 35045;\nconst DynamicReadUsage = 35049;\nconst StreamReadUsage = 35041;\nconst StaticCopyUsage = 35046;\nconst DynamicCopyUsage = 35050;\nconst StreamCopyUsage = 35042;\n\nconst GLSL1 = '100';\nconst GLSL3 = '300 es';\n\nconst _SRGBAFormat = 1035; // fallback for WebGL 1\n\n/**\n * https://github.com/mrdoob/eventdispatcher.js/\n */\n\nclass EventDispatcher {\n\n\taddEventListener( type, listener ) {\n\n\t\tif ( this._listeners === undefined ) this._listeners = {};\n\n\t\tconst listeners = this._listeners;\n\n\t\tif ( listeners[ type ] === undefined ) {\n\n\t\t\tlisteners[ type ] = [];\n\n\t\t}\n\n\t\tif ( listeners[ type ].indexOf( listener ) === - 1 ) {\n\n\t\t\tlisteners[ type ].push( listener );\n\n\t\t}\n\n\t}\n\n\thasEventListener( type, listener ) {\n\n\t\tif ( this._listeners === undefined ) return false;\n\n\t\tconst listeners = this._listeners;\n\n\t\treturn listeners[ type ] !== undefined && listeners[ type ].indexOf( listener ) !== - 1;\n\n\t}\n\n\tremoveEventListener( type, listener ) {\n\n\t\tif ( this._listeners === undefined ) return;\n\n\t\tconst listeners = this._listeners;\n\t\tconst listenerArray = listeners[ type ];\n\n\t\tif ( listenerArray !== undefined ) {\n\n\t\t\tconst index = listenerArray.indexOf( listener );\n\n\t\t\tif ( index !== - 1 ) {\n\n\t\t\t\tlistenerArray.splice( index, 1 );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tdispatchEvent( event ) {\n\n\t\tif ( this._listeners === undefined ) return;\n\n\t\tconst listeners = this._listeners;\n\t\tconst listenerArray = listeners[ event.type ];\n\n\t\tif ( listenerArray !== undefined ) {\n\n\t\t\tevent.target = this;\n\n\t\t\t// Make a copy, in case listeners are removed while iterating.\n\t\t\tconst array = listenerArray.slice( 0 );\n\n\t\t\tfor ( let i = 0, l = array.length; i < l; i ++ ) {\n\n\t\t\t\tarray[ i ].call( this, event );\n\n\t\t\t}\n\n\t\t\tevent.target = null;\n\n\t\t}\n\n\t}\n\n}\n\nconst _lut = [];\n\nfor ( let i = 0; i < 256; i ++ ) {\n\n\t_lut[ i ] = ( i < 16 ? '0' : '' ) + ( i ).toString( 16 );\n\n}\n\nlet _seed = 1234567;\n\n\nconst DEG2RAD = Math.PI / 180;\nconst RAD2DEG = 180 / Math.PI;\n\n// http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/21963136#21963136\nfunction generateUUID() {\n\n\tconst d0 = Math.random() * 0xffffffff | 0;\n\tconst d1 = Math.random() * 0xffffffff | 0;\n\tconst d2 = Math.random() * 0xffffffff | 0;\n\tconst d3 = Math.random() * 0xffffffff | 0;\n\tconst uuid = _lut[ d0 & 0xff ] + _lut[ d0 >> 8 & 0xff ] + _lut[ d0 >> 16 & 0xff ] + _lut[ d0 >> 24 & 0xff ] + '-' +\n\t\t\t_lut[ d1 & 0xff ] + _lut[ d1 >> 8 & 0xff ] + '-' + _lut[ d1 >> 16 & 0x0f | 0x40 ] + _lut[ d1 >> 24 & 0xff ] + '-' +\n\t\t\t_lut[ d2 & 0x3f | 0x80 ] + _lut[ d2 >> 8 & 0xff ] + '-' + _lut[ d2 >> 16 & 0xff ] + _lut[ d2 >> 24 & 0xff ] +\n\t\t\t_lut[ d3 & 0xff ] + _lut[ d3 >> 8 & 0xff ] + _lut[ d3 >> 16 & 0xff ] + _lut[ d3 >> 24 & 0xff ];\n\n\t// .toLowerCase() here flattens concatenated strings to save heap memory space.\n\treturn uuid.toLowerCase();\n\n}\n\nfunction clamp( value, min, max ) {\n\n\treturn Math.max( min, Math.min( max, value ) );\n\n}\n\n// compute euclidean modulo of m % n\n// https://en.wikipedia.org/wiki/Modulo_operation\nfunction euclideanModulo( n, m ) {\n\n\treturn ( ( n % m ) + m ) % m;\n\n}\n\n// Linear mapping from range to range \nfunction mapLinear( x, a1, a2, b1, b2 ) {\n\n\treturn b1 + ( x - a1 ) * ( b2 - b1 ) / ( a2 - a1 );\n\n}\n\n// https://www.gamedev.net/tutorials/programming/general-and-gameplay-programming/inverse-lerp-a-super-useful-yet-often-overlooked-function-r5230/\nfunction inverseLerp( x, y, value ) {\n\n\tif ( x !== y ) {\n\n\t\treturn ( value - x ) / ( y - x );\n\n\t} else {\n\n\t\treturn 0;\n\n\t}\n\n}\n\n// https://en.wikipedia.org/wiki/Linear_interpolation\nfunction lerp( x, y, t ) {\n\n\treturn ( 1 - t ) * x + t * y;\n\n}\n\n// http://www.rorydriscoll.com/2016/03/07/frame-rate-independent-damping-using-lerp/\nfunction damp( x, y, lambda, dt ) {\n\n\treturn lerp( x, y, 1 - Math.exp( - lambda * dt ) );\n\n}\n\n// https://www.desmos.com/calculator/vcsjnyz7x4\nfunction pingpong( x, length = 1 ) {\n\n\treturn length - Math.abs( euclideanModulo( x, length * 2 ) - length );\n\n}\n\n// http://en.wikipedia.org/wiki/Smoothstep\nfunction smoothstep( x, min, max ) {\n\n\tif ( x <= min ) return 0;\n\tif ( x >= max ) return 1;\n\n\tx = ( x - min ) / ( max - min );\n\n\treturn x * x * ( 3 - 2 * x );\n\n}\n\nfunction smootherstep( x, min, max ) {\n\n\tif ( x <= min ) return 0;\n\tif ( x >= max ) return 1;\n\n\tx = ( x - min ) / ( max - min );\n\n\treturn x * x * x * ( x * ( x * 6 - 15 ) + 10 );\n\n}\n\n// Random integer from interval\nfunction randInt( low, high ) {\n\n\treturn low + Math.floor( Math.random() * ( high - low + 1 ) );\n\n}\n\n// Random float from interval\nfunction randFloat( low, high ) {\n\n\treturn low + Math.random() * ( high - low );\n\n}\n\n// Random float from <-range/2, range/2> interval\nfunction randFloatSpread( range ) {\n\n\treturn range * ( 0.5 - Math.random() );\n\n}\n\n// Deterministic pseudo-random float in the interval [ 0, 1 ]\nfunction seededRandom( s ) {\n\n\tif ( s !== undefined ) _seed = s;\n\n\t// Mulberry32 generator\n\n\tlet t = _seed += 0x6D2B79F5;\n\n\tt = Math.imul( t ^ t >>> 15, t | 1 );\n\n\tt ^= t + Math.imul( t ^ t >>> 7, t | 61 );\n\n\treturn ( ( t ^ t >>> 14 ) >>> 0 ) / 4294967296;\n\n}\n\nfunction degToRad( degrees ) {\n\n\treturn degrees * DEG2RAD;\n\n}\n\nfunction radToDeg( radians ) {\n\n\treturn radians * RAD2DEG;\n\n}\n\nfunction isPowerOfTwo( value ) {\n\n\treturn ( value & ( value - 1 ) ) === 0 && value !== 0;\n\n}\n\nfunction ceilPowerOfTwo( value ) {\n\n\treturn Math.pow( 2, Math.ceil( Math.log( value ) / Math.LN2 ) );\n\n}\n\nfunction floorPowerOfTwo( value ) {\n\n\treturn Math.pow( 2, Math.floor( Math.log( value ) / Math.LN2 ) );\n\n}\n\nfunction setQuaternionFromProperEuler( q, a, b, c, order ) {\n\n\t// Intrinsic Proper Euler Angles - see https://en.wikipedia.org/wiki/Euler_angles\n\n\t// rotations are applied to the axes in the order specified by 'order'\n\t// rotation by angle 'a' is applied first, then by angle 'b', then by angle 'c'\n\t// angles are in radians\n\n\tconst cos = Math.cos;\n\tconst sin = Math.sin;\n\n\tconst c2 = cos( b / 2 );\n\tconst s2 = sin( b / 2 );\n\n\tconst c13 = cos( ( a + c ) / 2 );\n\tconst s13 = sin( ( a + c ) / 2 );\n\n\tconst c1_3 = cos( ( a - c ) / 2 );\n\tconst s1_3 = sin( ( a - c ) / 2 );\n\n\tconst c3_1 = cos( ( c - a ) / 2 );\n\tconst s3_1 = sin( ( c - a ) / 2 );\n\n\tswitch ( order ) {\n\n\t\tcase 'XYX':\n\t\t\tq.set( c2 * s13, s2 * c1_3, s2 * s1_3, c2 * c13 );\n\t\t\tbreak;\n\n\t\tcase 'YZY':\n\t\t\tq.set( s2 * s1_3, c2 * s13, s2 * c1_3, c2 * c13 );\n\t\t\tbreak;\n\n\t\tcase 'ZXZ':\n\t\t\tq.set( s2 * c1_3, s2 * s1_3, c2 * s13, c2 * c13 );\n\t\t\tbreak;\n\n\t\tcase 'XZX':\n\t\t\tq.set( c2 * s13, s2 * s3_1, s2 * c3_1, c2 * c13 );\n\t\t\tbreak;\n\n\t\tcase 'YXY':\n\t\t\tq.set( s2 * c3_1, c2 * s13, s2 * s3_1, c2 * c13 );\n\t\t\tbreak;\n\n\t\tcase 'ZYZ':\n\t\t\tq.set( s2 * s3_1, s2 * c3_1, c2 * s13, c2 * c13 );\n\t\t\tbreak;\n\n\t\tdefault:\n\t\t\tconsole.warn( 'THREE.MathUtils: .setQuaternionFromProperEuler() encountered an unknown order: ' + order );\n\n\t}\n\n}\n\nfunction denormalize$1( value, array ) {\n\n\tswitch ( array.constructor ) {\n\n\t\tcase Float32Array:\n\n\t\t\treturn value;\n\n\t\tcase Uint16Array:\n\n\t\t\treturn value / 65535.0;\n\n\t\tcase Uint8Array:\n\n\t\t\treturn value / 255.0;\n\n\t\tcase Int16Array:\n\n\t\t\treturn Math.max( value / 32767.0, - 1.0 );\n\n\t\tcase Int8Array:\n\n\t\t\treturn Math.max( value / 127.0, - 1.0 );\n\n\t\tdefault:\n\n\t\t\tthrow new Error( 'Invalid component type.' );\n\n\t}\n\n}\n\nfunction normalize( value, array ) {\n\n\tswitch ( array.constructor ) {\n\n\t\tcase Float32Array:\n\n\t\t\treturn value;\n\n\t\tcase Uint16Array:\n\n\t\t\treturn Math.round( value * 65535.0 );\n\n\t\tcase Uint8Array:\n\n\t\t\treturn Math.round( value * 255.0 );\n\n\t\tcase Int16Array:\n\n\t\t\treturn Math.round( value * 32767.0 );\n\n\t\tcase Int8Array:\n\n\t\t\treturn Math.round( value * 127.0 );\n\n\t\tdefault:\n\n\t\t\tthrow new Error( 'Invalid component type.' );\n\n\t}\n\n}\n\nvar MathUtils = /*#__PURE__*/Object.freeze({\n\t__proto__: null,\n\tDEG2RAD: DEG2RAD,\n\tRAD2DEG: RAD2DEG,\n\tgenerateUUID: generateUUID,\n\tclamp: clamp,\n\teuclideanModulo: euclideanModulo,\n\tmapLinear: mapLinear,\n\tinverseLerp: inverseLerp,\n\tlerp: lerp,\n\tdamp: damp,\n\tpingpong: pingpong,\n\tsmoothstep: smoothstep,\n\tsmootherstep: smootherstep,\n\trandInt: randInt,\n\trandFloat: randFloat,\n\trandFloatSpread: randFloatSpread,\n\tseededRandom: seededRandom,\n\tdegToRad: degToRad,\n\tradToDeg: radToDeg,\n\tisPowerOfTwo: isPowerOfTwo,\n\tceilPowerOfTwo: ceilPowerOfTwo,\n\tfloorPowerOfTwo: floorPowerOfTwo,\n\tsetQuaternionFromProperEuler: setQuaternionFromProperEuler,\n\tnormalize: normalize,\n\tdenormalize: denormalize$1\n});\n\nclass Vector2 {\n\n\tconstructor( x = 0, y = 0 ) {\n\n\t\tthis.isVector2 = true;\n\n\t\tthis.x = x;\n\t\tthis.y = y;\n\n\t}\n\n\tget width() {\n\n\t\treturn this.x;\n\n\t}\n\n\tset width( value ) {\n\n\t\tthis.x = value;\n\n\t}\n\n\tget height() {\n\n\t\treturn this.y;\n\n\t}\n\n\tset height( value ) {\n\n\t\tthis.y = value;\n\n\t}\n\n\tset( x, y ) {\n\n\t\tthis.x = x;\n\t\tthis.y = y;\n\n\t\treturn this;\n\n\t}\n\n\tsetScalar( scalar ) {\n\n\t\tthis.x = scalar;\n\t\tthis.y = scalar;\n\n\t\treturn this;\n\n\t}\n\n\tsetX( x ) {\n\n\t\tthis.x = x;\n\n\t\treturn this;\n\n\t}\n\n\tsetY( y ) {\n\n\t\tthis.y = y;\n\n\t\treturn this;\n\n\t}\n\n\tsetComponent( index, value ) {\n\n\t\tswitch ( index ) {\n\n\t\t\tcase 0: this.x = value; break;\n\t\t\tcase 1: this.y = value; break;\n\t\t\tdefault: throw new Error( 'index is out of range: ' + index );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tgetComponent( index ) {\n\n\t\tswitch ( index ) {\n\n\t\t\tcase 0: return this.x;\n\t\t\tcase 1: return this.y;\n\t\t\tdefault: throw new Error( 'index is out of range: ' + index );\n\n\t\t}\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor( this.x, this.y );\n\n\t}\n\n\tcopy( v ) {\n\n\t\tthis.x = v.x;\n\t\tthis.y = v.y;\n\n\t\treturn this;\n\n\t}\n\n\tadd( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector2: .add() now only accepts one argument. Use .addVectors( a, b ) instead.' );\n\t\t\treturn this.addVectors( v, w );\n\n\t\t}\n\n\t\tthis.x += v.x;\n\t\tthis.y += v.y;\n\n\t\treturn this;\n\n\t}\n\n\taddScalar( s ) {\n\n\t\tthis.x += s;\n\t\tthis.y += s;\n\n\t\treturn this;\n\n\t}\n\n\taddVectors( a, b ) {\n\n\t\tthis.x = a.x + b.x;\n\t\tthis.y = a.y + b.y;\n\n\t\treturn this;\n\n\t}\n\n\taddScaledVector( v, s ) {\n\n\t\tthis.x += v.x * s;\n\t\tthis.y += v.y * s;\n\n\t\treturn this;\n\n\t}\n\n\tsub( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector2: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.' );\n\t\t\treturn this.subVectors( v, w );\n\n\t\t}\n\n\t\tthis.x -= v.x;\n\t\tthis.y -= v.y;\n\n\t\treturn this;\n\n\t}\n\n\tsubScalar( s ) {\n\n\t\tthis.x -= s;\n\t\tthis.y -= s;\n\n\t\treturn this;\n\n\t}\n\n\tsubVectors( a, b ) {\n\n\t\tthis.x = a.x - b.x;\n\t\tthis.y = a.y - b.y;\n\n\t\treturn this;\n\n\t}\n\n\tmultiply( v ) {\n\n\t\tthis.x *= v.x;\n\t\tthis.y *= v.y;\n\n\t\treturn this;\n\n\t}\n\n\tmultiplyScalar( scalar ) {\n\n\t\tthis.x *= scalar;\n\t\tthis.y *= scalar;\n\n\t\treturn this;\n\n\t}\n\n\tdivide( v ) {\n\n\t\tthis.x /= v.x;\n\t\tthis.y /= v.y;\n\n\t\treturn this;\n\n\t}\n\n\tdivideScalar( scalar ) {\n\n\t\treturn this.multiplyScalar( 1 / scalar );\n\n\t}\n\n\tapplyMatrix3( m ) {\n\n\t\tconst x = this.x, y = this.y;\n\t\tconst e = m.elements;\n\n\t\tthis.x = e[ 0 ] * x + e[ 3 ] * y + e[ 6 ];\n\t\tthis.y = e[ 1 ] * x + e[ 4 ] * y + e[ 7 ];\n\n\t\treturn this;\n\n\t}\n\n\tmin( v ) {\n\n\t\tthis.x = Math.min( this.x, v.x );\n\t\tthis.y = Math.min( this.y, v.y );\n\n\t\treturn this;\n\n\t}\n\n\tmax( v ) {\n\n\t\tthis.x = Math.max( this.x, v.x );\n\t\tthis.y = Math.max( this.y, v.y );\n\n\t\treturn this;\n\n\t}\n\n\tclamp( min, max ) {\n\n\t\t// assumes min < max, componentwise\n\n\t\tthis.x = Math.max( min.x, Math.min( max.x, this.x ) );\n\t\tthis.y = Math.max( min.y, Math.min( max.y, this.y ) );\n\n\t\treturn this;\n\n\t}\n\n\tclampScalar( minVal, maxVal ) {\n\n\t\tthis.x = Math.max( minVal, Math.min( maxVal, this.x ) );\n\t\tthis.y = Math.max( minVal, Math.min( maxVal, this.y ) );\n\n\t\treturn this;\n\n\t}\n\n\tclampLength( min, max ) {\n\n\t\tconst length = this.length();\n\n\t\treturn this.divideScalar( length || 1 ).multiplyScalar( Math.max( min, Math.min( max, length ) ) );\n\n\t}\n\n\tfloor() {\n\n\t\tthis.x = Math.floor( this.x );\n\t\tthis.y = Math.floor( this.y );\n\n\t\treturn this;\n\n\t}\n\n\tceil() {\n\n\t\tthis.x = Math.ceil( this.x );\n\t\tthis.y = Math.ceil( this.y );\n\n\t\treturn this;\n\n\t}\n\n\tround() {\n\n\t\tthis.x = Math.round( this.x );\n\t\tthis.y = Math.round( this.y );\n\n\t\treturn this;\n\n\t}\n\n\troundToZero() {\n\n\t\tthis.x = ( this.x < 0 ) ? Math.ceil( this.x ) : Math.floor( this.x );\n\t\tthis.y = ( this.y < 0 ) ? Math.ceil( this.y ) : Math.floor( this.y );\n\n\t\treturn this;\n\n\t}\n\n\tnegate() {\n\n\t\tthis.x = - this.x;\n\t\tthis.y = - this.y;\n\n\t\treturn this;\n\n\t}\n\n\tdot( v ) {\n\n\t\treturn this.x * v.x + this.y * v.y;\n\n\t}\n\n\tcross( v ) {\n\n\t\treturn this.x * v.y - this.y * v.x;\n\n\t}\n\n\tlengthSq() {\n\n\t\treturn this.x * this.x + this.y * this.y;\n\n\t}\n\n\tlength() {\n\n\t\treturn Math.sqrt( this.x * this.x + this.y * this.y );\n\n\t}\n\n\tmanhattanLength() {\n\n\t\treturn Math.abs( this.x ) + Math.abs( this.y );\n\n\t}\n\n\tnormalize() {\n\n\t\treturn this.divideScalar( this.length() || 1 );\n\n\t}\n\n\tangle() {\n\n\t\t// computes the angle in radians with respect to the positive x-axis\n\n\t\tconst angle = Math.atan2( - this.y, - this.x ) + Math.PI;\n\n\t\treturn angle;\n\n\t}\n\n\tdistanceTo( v ) {\n\n\t\treturn Math.sqrt( this.distanceToSquared( v ) );\n\n\t}\n\n\tdistanceToSquared( v ) {\n\n\t\tconst dx = this.x - v.x, dy = this.y - v.y;\n\t\treturn dx * dx + dy * dy;\n\n\t}\n\n\tmanhattanDistanceTo( v ) {\n\n\t\treturn Math.abs( this.x - v.x ) + Math.abs( this.y - v.y );\n\n\t}\n\n\tsetLength( length ) {\n\n\t\treturn this.normalize().multiplyScalar( length );\n\n\t}\n\n\tlerp( v, alpha ) {\n\n\t\tthis.x += ( v.x - this.x ) * alpha;\n\t\tthis.y += ( v.y - this.y ) * alpha;\n\n\t\treturn this;\n\n\t}\n\n\tlerpVectors( v1, v2, alpha ) {\n\n\t\tthis.x = v1.x + ( v2.x - v1.x ) * alpha;\n\t\tthis.y = v1.y + ( v2.y - v1.y ) * alpha;\n\n\t\treturn this;\n\n\t}\n\n\tequals( v ) {\n\n\t\treturn ( ( v.x === this.x ) && ( v.y === this.y ) );\n\n\t}\n\n\tfromArray( array, offset = 0 ) {\n\n\t\tthis.x = array[ offset ];\n\t\tthis.y = array[ offset + 1 ];\n\n\t\treturn this;\n\n\t}\n\n\ttoArray( array = [], offset = 0 ) {\n\n\t\tarray[ offset ] = this.x;\n\t\tarray[ offset + 1 ] = this.y;\n\n\t\treturn array;\n\n\t}\n\n\tfromBufferAttribute( attribute, index, offset ) {\n\n\t\tif ( offset !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector2: offset has been removed from .fromBufferAttribute().' );\n\n\t\t}\n\n\t\tthis.x = attribute.getX( index );\n\t\tthis.y = attribute.getY( index );\n\n\t\treturn this;\n\n\t}\n\n\trotateAround( center, angle ) {\n\n\t\tconst c = Math.cos( angle ), s = Math.sin( angle );\n\n\t\tconst x = this.x - center.x;\n\t\tconst y = this.y - center.y;\n\n\t\tthis.x = x * c - y * s + center.x;\n\t\tthis.y = x * s + y * c + center.y;\n\n\t\treturn this;\n\n\t}\n\n\trandom() {\n\n\t\tthis.x = Math.random();\n\t\tthis.y = Math.random();\n\n\t\treturn this;\n\n\t}\n\n\t*[ Symbol.iterator ]() {\n\n\t\tyield this.x;\n\t\tyield this.y;\n\n\t}\n\n}\n\nclass Matrix3 {\n\n\tconstructor() {\n\n\t\tthis.isMatrix3 = true;\n\n\t\tthis.elements = [\n\n\t\t\t1, 0, 0,\n\t\t\t0, 1, 0,\n\t\t\t0, 0, 1\n\n\t\t];\n\n\t\tif ( arguments.length > 0 ) {\n\n\t\t\tconsole.error( 'THREE.Matrix3: the constructor no longer reads arguments. use .set() instead.' );\n\n\t\t}\n\n\t}\n\n\tset( n11, n12, n13, n21, n22, n23, n31, n32, n33 ) {\n\n\t\tconst te = this.elements;\n\n\t\tte[ 0 ] = n11; te[ 1 ] = n21; te[ 2 ] = n31;\n\t\tte[ 3 ] = n12; te[ 4 ] = n22; te[ 5 ] = n32;\n\t\tte[ 6 ] = n13; te[ 7 ] = n23; te[ 8 ] = n33;\n\n\t\treturn this;\n\n\t}\n\n\tidentity() {\n\n\t\tthis.set(\n\n\t\t\t1, 0, 0,\n\t\t\t0, 1, 0,\n\t\t\t0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\tcopy( m ) {\n\n\t\tconst te = this.elements;\n\t\tconst me = m.elements;\n\n\t\tte[ 0 ] = me[ 0 ]; te[ 1 ] = me[ 1 ]; te[ 2 ] = me[ 2 ];\n\t\tte[ 3 ] = me[ 3 ]; te[ 4 ] = me[ 4 ]; te[ 5 ] = me[ 5 ];\n\t\tte[ 6 ] = me[ 6 ]; te[ 7 ] = me[ 7 ]; te[ 8 ] = me[ 8 ];\n\n\t\treturn this;\n\n\t}\n\n\textractBasis( xAxis, yAxis, zAxis ) {\n\n\t\txAxis.setFromMatrix3Column( this, 0 );\n\t\tyAxis.setFromMatrix3Column( this, 1 );\n\t\tzAxis.setFromMatrix3Column( this, 2 );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromMatrix4( m ) {\n\n\t\tconst me = m.elements;\n\n\t\tthis.set(\n\n\t\t\tme[ 0 ], me[ 4 ], me[ 8 ],\n\t\t\tme[ 1 ], me[ 5 ], me[ 9 ],\n\t\t\tme[ 2 ], me[ 6 ], me[ 10 ]\n\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\tmultiply( m ) {\n\n\t\treturn this.multiplyMatrices( this, m );\n\n\t}\n\n\tpremultiply( m ) {\n\n\t\treturn this.multiplyMatrices( m, this );\n\n\t}\n\n\tmultiplyMatrices( a, b ) {\n\n\t\tconst ae = a.elements;\n\t\tconst be = b.elements;\n\t\tconst te = this.elements;\n\n\t\tconst a11 = ae[ 0 ], a12 = ae[ 3 ], a13 = ae[ 6 ];\n\t\tconst a21 = ae[ 1 ], a22 = ae[ 4 ], a23 = ae[ 7 ];\n\t\tconst a31 = ae[ 2 ], a32 = ae[ 5 ], a33 = ae[ 8 ];\n\n\t\tconst b11 = be[ 0 ], b12 = be[ 3 ], b13 = be[ 6 ];\n\t\tconst b21 = be[ 1 ], b22 = be[ 4 ], b23 = be[ 7 ];\n\t\tconst b31 = be[ 2 ], b32 = be[ 5 ], b33 = be[ 8 ];\n\n\t\tte[ 0 ] = a11 * b11 + a12 * b21 + a13 * b31;\n\t\tte[ 3 ] = a11 * b12 + a12 * b22 + a13 * b32;\n\t\tte[ 6 ] = a11 * b13 + a12 * b23 + a13 * b33;\n\n\t\tte[ 1 ] = a21 * b11 + a22 * b21 + a23 * b31;\n\t\tte[ 4 ] = a21 * b12 + a22 * b22 + a23 * b32;\n\t\tte[ 7 ] = a21 * b13 + a22 * b23 + a23 * b33;\n\n\t\tte[ 2 ] = a31 * b11 + a32 * b21 + a33 * b31;\n\t\tte[ 5 ] = a31 * b12 + a32 * b22 + a33 * b32;\n\t\tte[ 8 ] = a31 * b13 + a32 * b23 + a33 * b33;\n\n\t\treturn this;\n\n\t}\n\n\tmultiplyScalar( s ) {\n\n\t\tconst te = this.elements;\n\n\t\tte[ 0 ] *= s; te[ 3 ] *= s; te[ 6 ] *= s;\n\t\tte[ 1 ] *= s; te[ 4 ] *= s; te[ 7 ] *= s;\n\t\tte[ 2 ] *= s; te[ 5 ] *= s; te[ 8 ] *= s;\n\n\t\treturn this;\n\n\t}\n\n\tdeterminant() {\n\n\t\tconst te = this.elements;\n\n\t\tconst a = te[ 0 ], b = te[ 1 ], c = te[ 2 ],\n\t\t\td = te[ 3 ], e = te[ 4 ], f = te[ 5 ],\n\t\t\tg = te[ 6 ], h = te[ 7 ], i = te[ 8 ];\n\n\t\treturn a * e * i - a * f * h - b * d * i + b * f * g + c * d * h - c * e * g;\n\n\t}\n\n\tinvert() {\n\n\t\tconst te = this.elements,\n\n\t\t\tn11 = te[ 0 ], n21 = te[ 1 ], n31 = te[ 2 ],\n\t\t\tn12 = te[ 3 ], n22 = te[ 4 ], n32 = te[ 5 ],\n\t\t\tn13 = te[ 6 ], n23 = te[ 7 ], n33 = te[ 8 ],\n\n\t\t\tt11 = n33 * n22 - n32 * n23,\n\t\t\tt12 = n32 * n13 - n33 * n12,\n\t\t\tt13 = n23 * n12 - n22 * n13,\n\n\t\t\tdet = n11 * t11 + n21 * t12 + n31 * t13;\n\n\t\tif ( det === 0 ) return this.set( 0, 0, 0, 0, 0, 0, 0, 0, 0 );\n\n\t\tconst detInv = 1 / det;\n\n\t\tte[ 0 ] = t11 * detInv;\n\t\tte[ 1 ] = ( n31 * n23 - n33 * n21 ) * detInv;\n\t\tte[ 2 ] = ( n32 * n21 - n31 * n22 ) * detInv;\n\n\t\tte[ 3 ] = t12 * detInv;\n\t\tte[ 4 ] = ( n33 * n11 - n31 * n13 ) * detInv;\n\t\tte[ 5 ] = ( n31 * n12 - n32 * n11 ) * detInv;\n\n\t\tte[ 6 ] = t13 * detInv;\n\t\tte[ 7 ] = ( n21 * n13 - n23 * n11 ) * detInv;\n\t\tte[ 8 ] = ( n22 * n11 - n21 * n12 ) * detInv;\n\n\t\treturn this;\n\n\t}\n\n\ttranspose() {\n\n\t\tlet tmp;\n\t\tconst m = this.elements;\n\n\t\ttmp = m[ 1 ]; m[ 1 ] = m[ 3 ]; m[ 3 ] = tmp;\n\t\ttmp = m[ 2 ]; m[ 2 ] = m[ 6 ]; m[ 6 ] = tmp;\n\t\ttmp = m[ 5 ]; m[ 5 ] = m[ 7 ]; m[ 7 ] = tmp;\n\n\t\treturn this;\n\n\t}\n\n\tgetNormalMatrix( matrix4 ) {\n\n\t\treturn this.setFromMatrix4( matrix4 ).invert().transpose();\n\n\t}\n\n\ttransposeIntoArray( r ) {\n\n\t\tconst m = this.elements;\n\n\t\tr[ 0 ] = m[ 0 ];\n\t\tr[ 1 ] = m[ 3 ];\n\t\tr[ 2 ] = m[ 6 ];\n\t\tr[ 3 ] = m[ 1 ];\n\t\tr[ 4 ] = m[ 4 ];\n\t\tr[ 5 ] = m[ 7 ];\n\t\tr[ 6 ] = m[ 2 ];\n\t\tr[ 7 ] = m[ 5 ];\n\t\tr[ 8 ] = m[ 8 ];\n\n\t\treturn this;\n\n\t}\n\n\tsetUvTransform( tx, ty, sx, sy, rotation, cx, cy ) {\n\n\t\tconst c = Math.cos( rotation );\n\t\tconst s = Math.sin( rotation );\n\n\t\tthis.set(\n\t\t\tsx * c, sx * s, - sx * ( c * cx + s * cy ) + cx + tx,\n\t\t\t- sy * s, sy * c, - sy * ( - s * cx + c * cy ) + cy + ty,\n\t\t\t0, 0, 1\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\tscale( sx, sy ) {\n\n\t\tconst te = this.elements;\n\n\t\tte[ 0 ] *= sx; te[ 3 ] *= sx; te[ 6 ] *= sx;\n\t\tte[ 1 ] *= sy; te[ 4 ] *= sy; te[ 7 ] *= sy;\n\n\t\treturn this;\n\n\t}\n\n\trotate( theta ) {\n\n\t\tconst c = Math.cos( theta );\n\t\tconst s = Math.sin( theta );\n\n\t\tconst te = this.elements;\n\n\t\tconst a11 = te[ 0 ], a12 = te[ 3 ], a13 = te[ 6 ];\n\t\tconst a21 = te[ 1 ], a22 = te[ 4 ], a23 = te[ 7 ];\n\n\t\tte[ 0 ] = c * a11 + s * a21;\n\t\tte[ 3 ] = c * a12 + s * a22;\n\t\tte[ 6 ] = c * a13 + s * a23;\n\n\t\tte[ 1 ] = - s * a11 + c * a21;\n\t\tte[ 4 ] = - s * a12 + c * a22;\n\t\tte[ 7 ] = - s * a13 + c * a23;\n\n\t\treturn this;\n\n\t}\n\n\ttranslate( tx, ty ) {\n\n\t\tconst te = this.elements;\n\n\t\tte[ 0 ] += tx * te[ 2 ]; te[ 3 ] += tx * te[ 5 ]; te[ 6 ] += tx * te[ 8 ];\n\t\tte[ 1 ] += ty * te[ 2 ]; te[ 4 ] += ty * te[ 5 ]; te[ 7 ] += ty * te[ 8 ];\n\n\t\treturn this;\n\n\t}\n\n\tequals( matrix ) {\n\n\t\tconst te = this.elements;\n\t\tconst me = matrix.elements;\n\n\t\tfor ( let i = 0; i < 9; i ++ ) {\n\n\t\t\tif ( te[ i ] !== me[ i ] ) return false;\n\n\t\t}\n\n\t\treturn true;\n\n\t}\n\n\tfromArray( array, offset = 0 ) {\n\n\t\tfor ( let i = 0; i < 9; i ++ ) {\n\n\t\t\tthis.elements[ i ] = array[ i + offset ];\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\ttoArray( array = [], offset = 0 ) {\n\n\t\tconst te = this.elements;\n\n\t\tarray[ offset ] = te[ 0 ];\n\t\tarray[ offset + 1 ] = te[ 1 ];\n\t\tarray[ offset + 2 ] = te[ 2 ];\n\n\t\tarray[ offset + 3 ] = te[ 3 ];\n\t\tarray[ offset + 4 ] = te[ 4 ];\n\t\tarray[ offset + 5 ] = te[ 5 ];\n\n\t\tarray[ offset + 6 ] = te[ 6 ];\n\t\tarray[ offset + 7 ] = te[ 7 ];\n\t\tarray[ offset + 8 ] = te[ 8 ];\n\n\t\treturn array;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().fromArray( this.elements );\n\n\t}\n\n}\n\nfunction arrayNeedsUint32( array ) {\n\n\t// assumes larger values usually on last\n\n\tfor ( let i = array.length - 1; i >= 0; -- i ) {\n\n\t\tif ( array[ i ] > 65535 ) return true;\n\n\t}\n\n\treturn false;\n\n}\n\nconst TYPED_ARRAYS = {\n\tInt8Array: Int8Array,\n\tUint8Array: Uint8Array,\n\tUint8ClampedArray: Uint8ClampedArray,\n\tInt16Array: Int16Array,\n\tUint16Array: Uint16Array,\n\tInt32Array: Int32Array,\n\tUint32Array: Uint32Array,\n\tFloat32Array: Float32Array,\n\tFloat64Array: Float64Array\n};\n\nfunction getTypedArray( type, buffer ) {\n\n\treturn new TYPED_ARRAYS[ type ]( buffer );\n\n}\n\nfunction createElementNS( name ) {\n\n\treturn document.createElementNS( 'http://www.w3.org/1999/xhtml', name );\n\n}\n\nfunction SRGBToLinear( c ) {\n\n\treturn ( c < 0.04045 ) ? c * 0.0773993808 : Math.pow( c * 0.9478672986 + 0.0521327014, 2.4 );\n\n}\n\nfunction LinearToSRGB( c ) {\n\n\treturn ( c < 0.0031308 ) ? c * 12.92 : 1.055 * ( Math.pow( c, 0.41666 ) ) - 0.055;\n\n}\n\n// JavaScript RGB-to-RGB transforms, defined as\n// FN[InputColorSpace][OutputColorSpace] callback functions.\nconst FN = {\n\t[ SRGBColorSpace ]: { [ LinearSRGBColorSpace ]: SRGBToLinear },\n\t[ LinearSRGBColorSpace ]: { [ SRGBColorSpace ]: LinearToSRGB },\n};\n\nconst ColorManagement = {\n\n\tlegacyMode: true,\n\n\tget workingColorSpace() {\n\n\t\treturn LinearSRGBColorSpace;\n\n\t},\n\n\tset workingColorSpace( colorSpace ) {\n\n\t\tconsole.warn( 'THREE.ColorManagement: .workingColorSpace is readonly.' );\n\n\t},\n\n\tconvert: function ( color, sourceColorSpace, targetColorSpace ) {\n\n\t\tif ( this.legacyMode || sourceColorSpace === targetColorSpace || ! sourceColorSpace || ! targetColorSpace ) {\n\n\t\t\treturn color;\n\n\t\t}\n\n\t\tif ( FN[ sourceColorSpace ] && FN[ sourceColorSpace ][ targetColorSpace ] !== undefined ) {\n\n\t\t\tconst fn = FN[ sourceColorSpace ][ targetColorSpace ];\n\n\t\t\tcolor.r = fn( color.r );\n\t\t\tcolor.g = fn( color.g );\n\t\t\tcolor.b = fn( color.b );\n\n\t\t\treturn color;\n\n\t\t}\n\n\t\tthrow new Error( 'Unsupported color space conversion.' );\n\n\t},\n\n\tfromWorkingColorSpace: function ( color, targetColorSpace ) {\n\n\t\treturn this.convert( color, this.workingColorSpace, targetColorSpace );\n\n\t},\n\n\ttoWorkingColorSpace: function ( color, sourceColorSpace ) {\n\n\t\treturn this.convert( color, sourceColorSpace, this.workingColorSpace );\n\n\t},\n\n};\n\nconst _colorKeywords = { 'aliceblue': 0xF0F8FF, 'antiquewhite': 0xFAEBD7, 'aqua': 0x00FFFF, 'aquamarine': 0x7FFFD4, 'azure': 0xF0FFFF,\n\t'beige': 0xF5F5DC, 'bisque': 0xFFE4C4, 'black': 0x000000, 'blanchedalmond': 0xFFEBCD, 'blue': 0x0000FF, 'blueviolet': 0x8A2BE2,\n\t'brown': 0xA52A2A, 'burlywood': 0xDEB887, 'cadetblue': 0x5F9EA0, 'chartreuse': 0x7FFF00, 'chocolate': 0xD2691E, 'coral': 0xFF7F50,\n\t'cornflowerblue': 0x6495ED, 'cornsilk': 0xFFF8DC, 'crimson': 0xDC143C, 'cyan': 0x00FFFF, 'darkblue': 0x00008B, 'darkcyan': 0x008B8B,\n\t'darkgoldenrod': 0xB8860B, 'darkgray': 0xA9A9A9, 'darkgreen': 0x006400, 'darkgrey': 0xA9A9A9, 'darkkhaki': 0xBDB76B, 'darkmagenta': 0x8B008B,\n\t'darkolivegreen': 0x556B2F, 'darkorange': 0xFF8C00, 'darkorchid': 0x9932CC, 'darkred': 0x8B0000, 'darksalmon': 0xE9967A, 'darkseagreen': 0x8FBC8F,\n\t'darkslateblue': 0x483D8B, 'darkslategray': 0x2F4F4F, 'darkslategrey': 0x2F4F4F, 'darkturquoise': 0x00CED1, 'darkviolet': 0x9400D3,\n\t'deeppink': 0xFF1493, 'deepskyblue': 0x00BFFF, 'dimgray': 0x696969, 'dimgrey': 0x696969, 'dodgerblue': 0x1E90FF, 'firebrick': 0xB22222,\n\t'floralwhite': 0xFFFAF0, 'forestgreen': 0x228B22, 'fuchsia': 0xFF00FF, 'gainsboro': 0xDCDCDC, 'ghostwhite': 0xF8F8FF, 'gold': 0xFFD700,\n\t'goldenrod': 0xDAA520, 'gray': 0x808080, 'green': 0x008000, 'greenyellow': 0xADFF2F, 'grey': 0x808080, 'honeydew': 0xF0FFF0, 'hotpink': 0xFF69B4,\n\t'indianred': 0xCD5C5C, 'indigo': 0x4B0082, 'ivory': 0xFFFFF0, 'khaki': 0xF0E68C, 'lavender': 0xE6E6FA, 'lavenderblush': 0xFFF0F5, 'lawngreen': 0x7CFC00,\n\t'lemonchiffon': 0xFFFACD, 'lightblue': 0xADD8E6, 'lightcoral': 0xF08080, 'lightcyan': 0xE0FFFF, 'lightgoldenrodyellow': 0xFAFAD2, 'lightgray': 0xD3D3D3,\n\t'lightgreen': 0x90EE90, 'lightgrey': 0xD3D3D3, 'lightpink': 0xFFB6C1, 'lightsalmon': 0xFFA07A, 'lightseagreen': 0x20B2AA, 'lightskyblue': 0x87CEFA,\n\t'lightslategray': 0x778899, 'lightslategrey': 0x778899, 'lightsteelblue': 0xB0C4DE, 'lightyellow': 0xFFFFE0, 'lime': 0x00FF00, 'limegreen': 0x32CD32,\n\t'linen': 0xFAF0E6, 'magenta': 0xFF00FF, 'maroon': 0x800000, 'mediumaquamarine': 0x66CDAA, 'mediumblue': 0x0000CD, 'mediumorchid': 0xBA55D3,\n\t'mediumpurple': 0x9370DB, 'mediumseagreen': 0x3CB371, 'mediumslateblue': 0x7B68EE, 'mediumspringgreen': 0x00FA9A, 'mediumturquoise': 0x48D1CC,\n\t'mediumvioletred': 0xC71585, 'midnightblue': 0x191970, 'mintcream': 0xF5FFFA, 'mistyrose': 0xFFE4E1, 'moccasin': 0xFFE4B5, 'navajowhite': 0xFFDEAD,\n\t'navy': 0x000080, 'oldlace': 0xFDF5E6, 'olive': 0x808000, 'olivedrab': 0x6B8E23, 'orange': 0xFFA500, 'orangered': 0xFF4500, 'orchid': 0xDA70D6,\n\t'palegoldenrod': 0xEEE8AA, 'palegreen': 0x98FB98, 'paleturquoise': 0xAFEEEE, 'palevioletred': 0xDB7093, 'papayawhip': 0xFFEFD5, 'peachpuff': 0xFFDAB9,\n\t'peru': 0xCD853F, 'pink': 0xFFC0CB, 'plum': 0xDDA0DD, 'powderblue': 0xB0E0E6, 'purple': 0x800080, 'rebeccapurple': 0x663399, 'red': 0xFF0000, 'rosybrown': 0xBC8F8F,\n\t'royalblue': 0x4169E1, 'saddlebrown': 0x8B4513, 'salmon': 0xFA8072, 'sandybrown': 0xF4A460, 'seagreen': 0x2E8B57, 'seashell': 0xFFF5EE,\n\t'sienna': 0xA0522D, 'silver': 0xC0C0C0, 'skyblue': 0x87CEEB, 'slateblue': 0x6A5ACD, 'slategray': 0x708090, 'slategrey': 0x708090, 'snow': 0xFFFAFA,\n\t'springgreen': 0x00FF7F, 'steelblue': 0x4682B4, 'tan': 0xD2B48C, 'teal': 0x008080, 'thistle': 0xD8BFD8, 'tomato': 0xFF6347, 'turquoise': 0x40E0D0,\n\t'violet': 0xEE82EE, 'wheat': 0xF5DEB3, 'white': 0xFFFFFF, 'whitesmoke': 0xF5F5F5, 'yellow': 0xFFFF00, 'yellowgreen': 0x9ACD32 };\n\nconst _rgb = { r: 0, g: 0, b: 0 };\nconst _hslA = { h: 0, s: 0, l: 0 };\nconst _hslB = { h: 0, s: 0, l: 0 };\n\nfunction hue2rgb( p, q, t ) {\n\n\tif ( t < 0 ) t += 1;\n\tif ( t > 1 ) t -= 1;\n\tif ( t < 1 / 6 ) return p + ( q - p ) * 6 * t;\n\tif ( t < 1 / 2 ) return q;\n\tif ( t < 2 / 3 ) return p + ( q - p ) * 6 * ( 2 / 3 - t );\n\treturn p;\n\n}\n\nfunction toComponents( source, target ) {\n\n\ttarget.r = source.r;\n\ttarget.g = source.g;\n\ttarget.b = source.b;\n\n\treturn target;\n\n}\n\nclass Color {\n\n\tconstructor( r, g, b ) {\n\n\t\tthis.isColor = true;\n\n\t\tthis.r = 1;\n\t\tthis.g = 1;\n\t\tthis.b = 1;\n\n\t\tif ( g === undefined && b === undefined ) {\n\n\t\t\t// r is THREE.Color, hex or string\n\t\t\treturn this.set( r );\n\n\t\t}\n\n\t\treturn this.setRGB( r, g, b );\n\n\t}\n\n\tset( value ) {\n\n\t\tif ( value && value.isColor ) {\n\n\t\t\tthis.copy( value );\n\n\t\t} else if ( typeof value === 'number' ) {\n\n\t\t\tthis.setHex( value );\n\n\t\t} else if ( typeof value === 'string' ) {\n\n\t\t\tthis.setStyle( value );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tsetScalar( scalar ) {\n\n\t\tthis.r = scalar;\n\t\tthis.g = scalar;\n\t\tthis.b = scalar;\n\n\t\treturn this;\n\n\t}\n\n\tsetHex( hex, colorSpace = SRGBColorSpace ) {\n\n\t\thex = Math.floor( hex );\n\n\t\tthis.r = ( hex >> 16 & 255 ) / 255;\n\t\tthis.g = ( hex >> 8 & 255 ) / 255;\n\t\tthis.b = ( hex & 255 ) / 255;\n\n\t\tColorManagement.toWorkingColorSpace( this, colorSpace );\n\n\t\treturn this;\n\n\t}\n\n\tsetRGB( r, g, b, colorSpace = LinearSRGBColorSpace ) {\n\n\t\tthis.r = r;\n\t\tthis.g = g;\n\t\tthis.b = b;\n\n\t\tColorManagement.toWorkingColorSpace( this, colorSpace );\n\n\t\treturn this;\n\n\t}\n\n\tsetHSL( h, s, l, colorSpace = LinearSRGBColorSpace ) {\n\n\t\t// h,s,l ranges are in 0.0 - 1.0\n\t\th = euclideanModulo( h, 1 );\n\t\ts = clamp( s, 0, 1 );\n\t\tl = clamp( l, 0, 1 );\n\n\t\tif ( s === 0 ) {\n\n\t\t\tthis.r = this.g = this.b = l;\n\n\t\t} else {\n\n\t\t\tconst p = l <= 0.5 ? l * ( 1 + s ) : l + s - ( l * s );\n\t\t\tconst q = ( 2 * l ) - p;\n\n\t\t\tthis.r = hue2rgb( q, p, h + 1 / 3 );\n\t\t\tthis.g = hue2rgb( q, p, h );\n\t\t\tthis.b = hue2rgb( q, p, h - 1 / 3 );\n\n\t\t}\n\n\t\tColorManagement.toWorkingColorSpace( this, colorSpace );\n\n\t\treturn this;\n\n\t}\n\n\tsetStyle( style, colorSpace = SRGBColorSpace ) {\n\n\t\tfunction handleAlpha( string ) {\n\n\t\t\tif ( string === undefined ) return;\n\n\t\t\tif ( parseFloat( string ) < 1 ) {\n\n\t\t\t\tconsole.warn( 'THREE.Color: Alpha component of ' + style + ' will be ignored.' );\n\n\t\t\t}\n\n\t\t}\n\n\n\t\tlet m;\n\n\t\tif ( m = /^((?:rgb|hsl)a?)\\(([^\\)]*)\\)/.exec( style ) ) {\n\n\t\t\t// rgb / hsl\n\n\t\t\tlet color;\n\t\t\tconst name = m[ 1 ];\n\t\t\tconst components = m[ 2 ];\n\n\t\t\tswitch ( name ) {\n\n\t\t\t\tcase 'rgb':\n\t\t\t\tcase 'rgba':\n\n\t\t\t\t\tif ( color = /^\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d+)\\s*(?:,\\s*(\\d*\\.?\\d+)\\s*)?$/.exec( components ) ) {\n\n\t\t\t\t\t\t// rgb(255,0,0) rgba(255,0,0,0.5)\n\t\t\t\t\t\tthis.r = Math.min( 255, parseInt( color[ 1 ], 10 ) ) / 255;\n\t\t\t\t\t\tthis.g = Math.min( 255, parseInt( color[ 2 ], 10 ) ) / 255;\n\t\t\t\t\t\tthis.b = Math.min( 255, parseInt( color[ 3 ], 10 ) ) / 255;\n\n\t\t\t\t\t\tColorManagement.toWorkingColorSpace( this, colorSpace );\n\n\t\t\t\t\t\thandleAlpha( color[ 4 ] );\n\n\t\t\t\t\t\treturn this;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( color = /^\\s*(\\d+)\\%\\s*,\\s*(\\d+)\\%\\s*,\\s*(\\d+)\\%\\s*(?:,\\s*(\\d*\\.?\\d+)\\s*)?$/.exec( components ) ) {\n\n\t\t\t\t\t\t// rgb(100%,0%,0%) rgba(100%,0%,0%,0.5)\n\t\t\t\t\t\tthis.r = Math.min( 100, parseInt( color[ 1 ], 10 ) ) / 100;\n\t\t\t\t\t\tthis.g = Math.min( 100, parseInt( color[ 2 ], 10 ) ) / 100;\n\t\t\t\t\t\tthis.b = Math.min( 100, parseInt( color[ 3 ], 10 ) ) / 100;\n\n\t\t\t\t\t\tColorManagement.toWorkingColorSpace( this, colorSpace );\n\n\t\t\t\t\t\thandleAlpha( color[ 4 ] );\n\n\t\t\t\t\t\treturn this;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'hsl':\n\t\t\t\tcase 'hsla':\n\n\t\t\t\t\tif ( color = /^\\s*(\\d*\\.?\\d+)\\s*,\\s*(\\d+)\\%\\s*,\\s*(\\d+)\\%\\s*(?:,\\s*(\\d*\\.?\\d+)\\s*)?$/.exec( components ) ) {\n\n\t\t\t\t\t\t// hsl(120,50%,50%) hsla(120,50%,50%,0.5)\n\t\t\t\t\t\tconst h = parseFloat( color[ 1 ] ) / 360;\n\t\t\t\t\t\tconst s = parseInt( color[ 2 ], 10 ) / 100;\n\t\t\t\t\t\tconst l = parseInt( color[ 3 ], 10 ) / 100;\n\n\t\t\t\t\t\thandleAlpha( color[ 4 ] );\n\n\t\t\t\t\t\treturn this.setHSL( h, s, l, colorSpace );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t} else if ( m = /^\\#([A-Fa-f\\d]+)$/.exec( style ) ) {\n\n\t\t\t// hex color\n\n\t\t\tconst hex = m[ 1 ];\n\t\t\tconst size = hex.length;\n\n\t\t\tif ( size === 3 ) {\n\n\t\t\t\t// #ff0\n\t\t\t\tthis.r = parseInt( hex.charAt( 0 ) + hex.charAt( 0 ), 16 ) / 255;\n\t\t\t\tthis.g = parseInt( hex.charAt( 1 ) + hex.charAt( 1 ), 16 ) / 255;\n\t\t\t\tthis.b = parseInt( hex.charAt( 2 ) + hex.charAt( 2 ), 16 ) / 255;\n\n\t\t\t\tColorManagement.toWorkingColorSpace( this, colorSpace );\n\n\t\t\t\treturn this;\n\n\t\t\t} else if ( size === 6 ) {\n\n\t\t\t\t// #ff0000\n\t\t\t\tthis.r = parseInt( hex.charAt( 0 ) + hex.charAt( 1 ), 16 ) / 255;\n\t\t\t\tthis.g = parseInt( hex.charAt( 2 ) + hex.charAt( 3 ), 16 ) / 255;\n\t\t\t\tthis.b = parseInt( hex.charAt( 4 ) + hex.charAt( 5 ), 16 ) / 255;\n\n\t\t\t\tColorManagement.toWorkingColorSpace( this, colorSpace );\n\n\t\t\t\treturn this;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( style && style.length > 0 ) {\n\n\t\t\treturn this.setColorName( style, colorSpace );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tsetColorName( style, colorSpace = SRGBColorSpace ) {\n\n\t\t// color keywords\n\t\tconst hex = _colorKeywords[ style.toLowerCase() ];\n\n\t\tif ( hex !== undefined ) {\n\n\t\t\t// red\n\t\t\tthis.setHex( hex, colorSpace );\n\n\t\t} else {\n\n\t\t\t// unknown color\n\t\t\tconsole.warn( 'THREE.Color: Unknown color ' + style );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor( this.r, this.g, this.b );\n\n\t}\n\n\tcopy( color ) {\n\n\t\tthis.r = color.r;\n\t\tthis.g = color.g;\n\t\tthis.b = color.b;\n\n\t\treturn this;\n\n\t}\n\n\tcopySRGBToLinear( color ) {\n\n\t\tthis.r = SRGBToLinear( color.r );\n\t\tthis.g = SRGBToLinear( color.g );\n\t\tthis.b = SRGBToLinear( color.b );\n\n\t\treturn this;\n\n\t}\n\n\tcopyLinearToSRGB( color ) {\n\n\t\tthis.r = LinearToSRGB( color.r );\n\t\tthis.g = LinearToSRGB( color.g );\n\t\tthis.b = LinearToSRGB( color.b );\n\n\t\treturn this;\n\n\t}\n\n\tconvertSRGBToLinear() {\n\n\t\tthis.copySRGBToLinear( this );\n\n\t\treturn this;\n\n\t}\n\n\tconvertLinearToSRGB() {\n\n\t\tthis.copyLinearToSRGB( this );\n\n\t\treturn this;\n\n\t}\n\n\tgetHex( colorSpace = SRGBColorSpace ) {\n\n\t\tColorManagement.fromWorkingColorSpace( toComponents( this, _rgb ), colorSpace );\n\n\t\treturn clamp( _rgb.r * 255, 0, 255 ) << 16 ^ clamp( _rgb.g * 255, 0, 255 ) << 8 ^ clamp( _rgb.b * 255, 0, 255 ) << 0;\n\n\t}\n\n\tgetHexString( colorSpace = SRGBColorSpace ) {\n\n\t\treturn ( '000000' + this.getHex( colorSpace ).toString( 16 ) ).slice( - 6 );\n\n\t}\n\n\tgetHSL( target, colorSpace = LinearSRGBColorSpace ) {\n\n\t\t// h,s,l ranges are in 0.0 - 1.0\n\n\t\tColorManagement.fromWorkingColorSpace( toComponents( this, _rgb ), colorSpace );\n\n\t\tconst r = _rgb.r, g = _rgb.g, b = _rgb.b;\n\n\t\tconst max = Math.max( r, g, b );\n\t\tconst min = Math.min( r, g, b );\n\n\t\tlet hue, saturation;\n\t\tconst lightness = ( min + max ) / 2.0;\n\n\t\tif ( min === max ) {\n\n\t\t\thue = 0;\n\t\t\tsaturation = 0;\n\n\t\t} else {\n\n\t\t\tconst delta = max - min;\n\n\t\t\tsaturation = lightness <= 0.5 ? delta / ( max + min ) : delta / ( 2 - max - min );\n\n\t\t\tswitch ( max ) {\n\n\t\t\t\tcase r: hue = ( g - b ) / delta + ( g < b ? 6 : 0 ); break;\n\t\t\t\tcase g: hue = ( b - r ) / delta + 2; break;\n\t\t\t\tcase b: hue = ( r - g ) / delta + 4; break;\n\n\t\t\t}\n\n\t\t\thue /= 6;\n\n\t\t}\n\n\t\ttarget.h = hue;\n\t\ttarget.s = saturation;\n\t\ttarget.l = lightness;\n\n\t\treturn target;\n\n\t}\n\n\tgetRGB( target, colorSpace = LinearSRGBColorSpace ) {\n\n\t\tColorManagement.fromWorkingColorSpace( toComponents( this, _rgb ), colorSpace );\n\n\t\ttarget.r = _rgb.r;\n\t\ttarget.g = _rgb.g;\n\t\ttarget.b = _rgb.b;\n\n\t\treturn target;\n\n\t}\n\n\tgetStyle( colorSpace = SRGBColorSpace ) {\n\n\t\tColorManagement.fromWorkingColorSpace( toComponents( this, _rgb ), colorSpace );\n\n\t\tif ( colorSpace !== SRGBColorSpace ) {\n\n\t\t\t// Requires CSS Color Module Level 4 (https://www.w3.org/TR/css-color-4/).\n\t\t\treturn `color(${ colorSpace } ${ _rgb.r } ${ _rgb.g } ${ _rgb.b })`;\n\n\t\t}\n\n\t\treturn `rgb(${( _rgb.r * 255 ) | 0},${( _rgb.g * 255 ) | 0},${( _rgb.b * 255 ) | 0})`;\n\n\t}\n\n\toffsetHSL( h, s, l ) {\n\n\t\tthis.getHSL( _hslA );\n\n\t\t_hslA.h += h; _hslA.s += s; _hslA.l += l;\n\n\t\tthis.setHSL( _hslA.h, _hslA.s, _hslA.l );\n\n\t\treturn this;\n\n\t}\n\n\tadd( color ) {\n\n\t\tthis.r += color.r;\n\t\tthis.g += color.g;\n\t\tthis.b += color.b;\n\n\t\treturn this;\n\n\t}\n\n\taddColors( color1, color2 ) {\n\n\t\tthis.r = color1.r + color2.r;\n\t\tthis.g = color1.g + color2.g;\n\t\tthis.b = color1.b + color2.b;\n\n\t\treturn this;\n\n\t}\n\n\taddScalar( s ) {\n\n\t\tthis.r += s;\n\t\tthis.g += s;\n\t\tthis.b += s;\n\n\t\treturn this;\n\n\t}\n\n\tsub( color ) {\n\n\t\tthis.r = Math.max( 0, this.r - color.r );\n\t\tthis.g = Math.max( 0, this.g - color.g );\n\t\tthis.b = Math.max( 0, this.b - color.b );\n\n\t\treturn this;\n\n\t}\n\n\tmultiply( color ) {\n\n\t\tthis.r *= color.r;\n\t\tthis.g *= color.g;\n\t\tthis.b *= color.b;\n\n\t\treturn this;\n\n\t}\n\n\tmultiplyScalar( s ) {\n\n\t\tthis.r *= s;\n\t\tthis.g *= s;\n\t\tthis.b *= s;\n\n\t\treturn this;\n\n\t}\n\n\tlerp( color, alpha ) {\n\n\t\tthis.r += ( color.r - this.r ) * alpha;\n\t\tthis.g += ( color.g - this.g ) * alpha;\n\t\tthis.b += ( color.b - this.b ) * alpha;\n\n\t\treturn this;\n\n\t}\n\n\tlerpColors( color1, color2, alpha ) {\n\n\t\tthis.r = color1.r + ( color2.r - color1.r ) * alpha;\n\t\tthis.g = color1.g + ( color2.g - color1.g ) * alpha;\n\t\tthis.b = color1.b + ( color2.b - color1.b ) * alpha;\n\n\t\treturn this;\n\n\t}\n\n\tlerpHSL( color, alpha ) {\n\n\t\tthis.getHSL( _hslA );\n\t\tcolor.getHSL( _hslB );\n\n\t\tconst h = lerp( _hslA.h, _hslB.h, alpha );\n\t\tconst s = lerp( _hslA.s, _hslB.s, alpha );\n\t\tconst l = lerp( _hslA.l, _hslB.l, alpha );\n\n\t\tthis.setHSL( h, s, l );\n\n\t\treturn this;\n\n\t}\n\n\tequals( c ) {\n\n\t\treturn ( c.r === this.r ) && ( c.g === this.g ) && ( c.b === this.b );\n\n\t}\n\n\tfromArray( array, offset = 0 ) {\n\n\t\tthis.r = array[ offset ];\n\t\tthis.g = array[ offset + 1 ];\n\t\tthis.b = array[ offset + 2 ];\n\n\t\treturn this;\n\n\t}\n\n\ttoArray( array = [], offset = 0 ) {\n\n\t\tarray[ offset ] = this.r;\n\t\tarray[ offset + 1 ] = this.g;\n\t\tarray[ offset + 2 ] = this.b;\n\n\t\treturn array;\n\n\t}\n\n\tfromBufferAttribute( attribute, index ) {\n\n\t\tthis.r = attribute.getX( index );\n\t\tthis.g = attribute.getY( index );\n\t\tthis.b = attribute.getZ( index );\n\n\t\tif ( attribute.normalized === true ) {\n\n\t\t\t// assuming Uint8Array\n\n\t\t\tthis.r /= 255;\n\t\t\tthis.g /= 255;\n\t\t\tthis.b /= 255;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\treturn this.getHex();\n\n\t}\n\n\t*[ Symbol.iterator ]() {\n\n\t\tyield this.r;\n\t\tyield this.g;\n\t\tyield this.b;\n\n\t}\n\n}\n\nColor.NAMES = _colorKeywords;\n\nlet _canvas;\n\nclass ImageUtils {\n\n\tstatic getDataURL( image ) {\n\n\t\tif ( /^data:/i.test( image.src ) ) {\n\n\t\t\treturn image.src;\n\n\t\t}\n\n\t\tif ( typeof HTMLCanvasElement == 'undefined' ) {\n\n\t\t\treturn image.src;\n\n\t\t}\n\n\t\tlet canvas;\n\n\t\tif ( image instanceof HTMLCanvasElement ) {\n\n\t\t\tcanvas = image;\n\n\t\t} else {\n\n\t\t\tif ( _canvas === undefined ) _canvas = createElementNS( 'canvas' );\n\n\t\t\t_canvas.width = image.width;\n\t\t\t_canvas.height = image.height;\n\n\t\t\tconst context = _canvas.getContext( '2d' );\n\n\t\t\tif ( image instanceof ImageData ) {\n\n\t\t\t\tcontext.putImageData( image, 0, 0 );\n\n\t\t\t} else {\n\n\t\t\t\tcontext.drawImage( image, 0, 0, image.width, image.height );\n\n\t\t\t}\n\n\t\t\tcanvas = _canvas;\n\n\t\t}\n\n\t\tif ( canvas.width > 2048 || canvas.height > 2048 ) {\n\n\t\t\tconsole.warn( 'THREE.ImageUtils.getDataURL: Image converted to jpg for performance reasons', image );\n\n\t\t\treturn canvas.toDataURL( 'image/jpeg', 0.6 );\n\n\t\t} else {\n\n\t\t\treturn canvas.toDataURL( 'image/png' );\n\n\t\t}\n\n\t}\n\n\tstatic sRGBToLinear( image ) {\n\n\t\tif ( ( typeof HTMLImageElement !== 'undefined' && image instanceof HTMLImageElement ) ||\n\t\t\t( typeof HTMLCanvasElement !== 'undefined' && image instanceof HTMLCanvasElement ) ||\n\t\t\t( typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap ) ) {\n\n\t\t\tconst canvas = createElementNS( 'canvas' );\n\n\t\t\tcanvas.width = image.width;\n\t\t\tcanvas.height = image.height;\n\n\t\t\tconst context = canvas.getContext( '2d' );\n\t\t\tcontext.drawImage( image, 0, 0, image.width, image.height );\n\n\t\t\tconst imageData = context.getImageData( 0, 0, image.width, image.height );\n\t\t\tconst data = imageData.data;\n\n\t\t\tfor ( let i = 0; i < data.length; i ++ ) {\n\n\t\t\t\tdata[ i ] = SRGBToLinear( data[ i ] / 255 ) * 255;\n\n\t\t\t}\n\n\t\t\tcontext.putImageData( imageData, 0, 0 );\n\n\t\t\treturn canvas;\n\n\t\t} else if ( image.data ) {\n\n\t\t\tconst data = image.data.slice( 0 );\n\n\t\t\tfor ( let i = 0; i < data.length; i ++ ) {\n\n\t\t\t\tif ( data instanceof Uint8Array || data instanceof Uint8ClampedArray ) {\n\n\t\t\t\t\tdata[ i ] = Math.floor( SRGBToLinear( data[ i ] / 255 ) * 255 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// assuming float\n\n\t\t\t\t\tdata[ i ] = SRGBToLinear( data[ i ] );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn {\n\t\t\t\tdata: data,\n\t\t\t\twidth: image.width,\n\t\t\t\theight: image.height\n\t\t\t};\n\n\t\t} else {\n\n\t\t\tconsole.warn( 'THREE.ImageUtils.sRGBToLinear(): Unsupported image type. No color space conversion applied.' );\n\t\t\treturn image;\n\n\t\t}\n\n\t}\n\n}\n\nclass Source {\n\n\tconstructor( data = null ) {\n\n\t\tthis.isSource = true;\n\n\t\tthis.uuid = generateUUID();\n\n\t\tthis.data = data;\n\n\t\tthis.version = 0;\n\n\t}\n\n\tset needsUpdate( value ) {\n\n\t\tif ( value === true ) this.version ++;\n\n\t}\n\n\ttoJSON( meta ) {\n\n\t\tconst isRootObject = ( meta === undefined || typeof meta === 'string' );\n\n\t\tif ( ! isRootObject && meta.images[ this.uuid ] !== undefined ) {\n\n\t\t\treturn meta.images[ this.uuid ];\n\n\t\t}\n\n\t\tconst output = {\n\t\t\tuuid: this.uuid,\n\t\t\turl: ''\n\t\t};\n\n\t\tconst data = this.data;\n\n\t\tif ( data !== null ) {\n\n\t\t\tlet url;\n\n\t\t\tif ( Array.isArray( data ) ) {\n\n\t\t\t\t// cube texture\n\n\t\t\t\turl = [];\n\n\t\t\t\tfor ( let i = 0, l = data.length; i < l; i ++ ) {\n\n\t\t\t\t\tif ( data[ i ].isDataTexture ) {\n\n\t\t\t\t\t\turl.push( serializeImage( data[ i ].image ) );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\turl.push( serializeImage( data[ i ] ) );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t// texture\n\n\t\t\t\turl = serializeImage( data );\n\n\t\t\t}\n\n\t\t\toutput.url = url;\n\n\t\t}\n\n\t\tif ( ! isRootObject ) {\n\n\t\t\tmeta.images[ this.uuid ] = output;\n\n\t\t}\n\n\t\treturn output;\n\n\t}\n\n}\n\nfunction serializeImage( image ) {\n\n\tif ( ( typeof HTMLImageElement !== 'undefined' && image instanceof HTMLImageElement ) ||\n\t\t( typeof HTMLCanvasElement !== 'undefined' && image instanceof HTMLCanvasElement ) ||\n\t\t( typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap ) ) {\n\n\t\t// default images\n\n\t\treturn ImageUtils.getDataURL( image );\n\n\t} else {\n\n\t\tif ( image.data ) {\n\n\t\t\t// images of DataTexture\n\n\t\t\treturn {\n\t\t\t\tdata: Array.prototype.slice.call( image.data ),\n\t\t\t\twidth: image.width,\n\t\t\t\theight: image.height,\n\t\t\t\ttype: image.data.constructor.name\n\t\t\t};\n\n\t\t} else {\n\n\t\t\tconsole.warn( 'THREE.Texture: Unable to serialize Texture.' );\n\t\t\treturn {};\n\n\t\t}\n\n\t}\n\n}\n\nlet textureId = 0;\n\nclass Texture extends EventDispatcher {\n\n\tconstructor( image = Texture.DEFAULT_IMAGE, mapping = Texture.DEFAULT_MAPPING, wrapS = ClampToEdgeWrapping, wrapT = ClampToEdgeWrapping, magFilter = LinearFilter, minFilter = LinearMipmapLinearFilter, format = RGBAFormat, type = UnsignedByteType, anisotropy = 1, encoding = LinearEncoding ) {\n\n\t\tsuper();\n\n\t\tthis.isTexture = true;\n\n\t\tObject.defineProperty( this, 'id', { value: textureId ++ } );\n\n\t\tthis.uuid = generateUUID();\n\n\t\tthis.name = '';\n\n\t\tthis.source = new Source( image );\n\t\tthis.mipmaps = [];\n\n\t\tthis.mapping = mapping;\n\n\t\tthis.wrapS = wrapS;\n\t\tthis.wrapT = wrapT;\n\n\t\tthis.magFilter = magFilter;\n\t\tthis.minFilter = minFilter;\n\n\t\tthis.anisotropy = anisotropy;\n\n\t\tthis.format = format;\n\t\tthis.internalFormat = null;\n\t\tthis.type = type;\n\n\t\tthis.offset = new Vector2( 0, 0 );\n\t\tthis.repeat = new Vector2( 1, 1 );\n\t\tthis.center = new Vector2( 0, 0 );\n\t\tthis.rotation = 0;\n\n\t\tthis.matrixAutoUpdate = true;\n\t\tthis.matrix = new Matrix3();\n\n\t\tthis.generateMipmaps = true;\n\t\tthis.premultiplyAlpha = false;\n\t\tthis.flipY = true;\n\t\tthis.unpackAlignment = 4;\t// valid values: 1, 2, 4, 8 (see http://www.khronos.org/opengles/sdk/docs/man/xhtml/glPixelStorei.xml)\n\n\t\t// Values of encoding !== THREE.LinearEncoding only supported on map, envMap and emissiveMap.\n\t\t//\n\t\t// Also changing the encoding after already used by a Material will not automatically make the Material\n\t\t// update. You need to explicitly call Material.needsUpdate to trigger it to recompile.\n\t\tthis.encoding = encoding;\n\n\t\tthis.userData = {};\n\n\t\tthis.version = 0;\n\t\tthis.onUpdate = null;\n\n\t\tthis.isRenderTargetTexture = false; // indicates whether a texture belongs to a render target or not\n\t\tthis.needsPMREMUpdate = false; // indicates whether this texture should be processed by PMREMGenerator or not (only relevant for render target textures)\n\n\t}\n\n\tget image() {\n\n\t\treturn this.source.data;\n\n\t}\n\n\tset image( value ) {\n\n\t\tthis.source.data = value;\n\n\t}\n\n\tupdateMatrix() {\n\n\t\tthis.matrix.setUvTransform( this.offset.x, this.offset.y, this.repeat.x, this.repeat.y, this.rotation, this.center.x, this.center.y );\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tthis.name = source.name;\n\n\t\tthis.source = source.source;\n\t\tthis.mipmaps = source.mipmaps.slice( 0 );\n\n\t\tthis.mapping = source.mapping;\n\n\t\tthis.wrapS = source.wrapS;\n\t\tthis.wrapT = source.wrapT;\n\n\t\tthis.magFilter = source.magFilter;\n\t\tthis.minFilter = source.minFilter;\n\n\t\tthis.anisotropy = source.anisotropy;\n\n\t\tthis.format = source.format;\n\t\tthis.internalFormat = source.internalFormat;\n\t\tthis.type = source.type;\n\n\t\tthis.offset.copy( source.offset );\n\t\tthis.repeat.copy( source.repeat );\n\t\tthis.center.copy( source.center );\n\t\tthis.rotation = source.rotation;\n\n\t\tthis.matrixAutoUpdate = source.matrixAutoUpdate;\n\t\tthis.matrix.copy( source.matrix );\n\n\t\tthis.generateMipmaps = source.generateMipmaps;\n\t\tthis.premultiplyAlpha = source.premultiplyAlpha;\n\t\tthis.flipY = source.flipY;\n\t\tthis.unpackAlignment = source.unpackAlignment;\n\t\tthis.encoding = source.encoding;\n\n\t\tthis.userData = JSON.parse( JSON.stringify( source.userData ) );\n\n\t\tthis.needsUpdate = true;\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON( meta ) {\n\n\t\tconst isRootObject = ( meta === undefined || typeof meta === 'string' );\n\n\t\tif ( ! isRootObject && meta.textures[ this.uuid ] !== undefined ) {\n\n\t\t\treturn meta.textures[ this.uuid ];\n\n\t\t}\n\n\t\tconst output = {\n\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Texture',\n\t\t\t\tgenerator: 'Texture.toJSON'\n\t\t\t},\n\n\t\t\tuuid: this.uuid,\n\t\t\tname: this.name,\n\n\t\t\timage: this.source.toJSON( meta ).uuid,\n\n\t\t\tmapping: this.mapping,\n\n\t\t\trepeat: [ this.repeat.x, this.repeat.y ],\n\t\t\toffset: [ this.offset.x, this.offset.y ],\n\t\t\tcenter: [ this.center.x, this.center.y ],\n\t\t\trotation: this.rotation,\n\n\t\t\twrap: [ this.wrapS, this.wrapT ],\n\n\t\t\tformat: this.format,\n\t\t\ttype: this.type,\n\t\t\tencoding: this.encoding,\n\n\t\t\tminFilter: this.minFilter,\n\t\t\tmagFilter: this.magFilter,\n\t\t\tanisotropy: this.anisotropy,\n\n\t\t\tflipY: this.flipY,\n\n\t\t\tpremultiplyAlpha: this.premultiplyAlpha,\n\t\t\tunpackAlignment: this.unpackAlignment\n\n\t\t};\n\n\t\tif ( JSON.stringify( this.userData ) !== '{}' ) output.userData = this.userData;\n\n\t\tif ( ! isRootObject ) {\n\n\t\t\tmeta.textures[ this.uuid ] = output;\n\n\t\t}\n\n\t\treturn output;\n\n\t}\n\n\tdispose() {\n\n\t\tthis.dispatchEvent( { type: 'dispose' } );\n\n\t}\n\n\ttransformUv( uv ) {\n\n\t\tif ( this.mapping !== UVMapping ) return uv;\n\n\t\tuv.applyMatrix3( this.matrix );\n\n\t\tif ( uv.x < 0 || uv.x > 1 ) {\n\n\t\t\tswitch ( this.wrapS ) {\n\n\t\t\t\tcase RepeatWrapping:\n\n\t\t\t\t\tuv.x = uv.x - Math.floor( uv.x );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase ClampToEdgeWrapping:\n\n\t\t\t\t\tuv.x = uv.x < 0 ? 0 : 1;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase MirroredRepeatWrapping:\n\n\t\t\t\t\tif ( Math.abs( Math.floor( uv.x ) % 2 ) === 1 ) {\n\n\t\t\t\t\t\tuv.x = Math.ceil( uv.x ) - uv.x;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tuv.x = uv.x - Math.floor( uv.x );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( uv.y < 0 || uv.y > 1 ) {\n\n\t\t\tswitch ( this.wrapT ) {\n\n\t\t\t\tcase RepeatWrapping:\n\n\t\t\t\t\tuv.y = uv.y - Math.floor( uv.y );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase ClampToEdgeWrapping:\n\n\t\t\t\t\tuv.y = uv.y < 0 ? 0 : 1;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase MirroredRepeatWrapping:\n\n\t\t\t\t\tif ( Math.abs( Math.floor( uv.y ) % 2 ) === 1 ) {\n\n\t\t\t\t\t\tuv.y = Math.ceil( uv.y ) - uv.y;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tuv.y = uv.y - Math.floor( uv.y );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( this.flipY ) {\n\n\t\t\tuv.y = 1 - uv.y;\n\n\t\t}\n\n\t\treturn uv;\n\n\t}\n\n\tset needsUpdate( value ) {\n\n\t\tif ( value === true ) {\n\n\t\t\tthis.version ++;\n\t\t\tthis.source.needsUpdate = true;\n\n\t\t}\n\n\t}\n\n}\n\nTexture.DEFAULT_IMAGE = null;\nTexture.DEFAULT_MAPPING = UVMapping;\n\nclass Vector4 {\n\n\tconstructor( x = 0, y = 0, z = 0, w = 1 ) {\n\n\t\tthis.isVector4 = true;\n\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.z = z;\n\t\tthis.w = w;\n\n\t}\n\n\tget width() {\n\n\t\treturn this.z;\n\n\t}\n\n\tset width( value ) {\n\n\t\tthis.z = value;\n\n\t}\n\n\tget height() {\n\n\t\treturn this.w;\n\n\t}\n\n\tset height( value ) {\n\n\t\tthis.w = value;\n\n\t}\n\n\tset( x, y, z, w ) {\n\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.z = z;\n\t\tthis.w = w;\n\n\t\treturn this;\n\n\t}\n\n\tsetScalar( scalar ) {\n\n\t\tthis.x = scalar;\n\t\tthis.y = scalar;\n\t\tthis.z = scalar;\n\t\tthis.w = scalar;\n\n\t\treturn this;\n\n\t}\n\n\tsetX( x ) {\n\n\t\tthis.x = x;\n\n\t\treturn this;\n\n\t}\n\n\tsetY( y ) {\n\n\t\tthis.y = y;\n\n\t\treturn this;\n\n\t}\n\n\tsetZ( z ) {\n\n\t\tthis.z = z;\n\n\t\treturn this;\n\n\t}\n\n\tsetW( w ) {\n\n\t\tthis.w = w;\n\n\t\treturn this;\n\n\t}\n\n\tsetComponent( index, value ) {\n\n\t\tswitch ( index ) {\n\n\t\t\tcase 0: this.x = value; break;\n\t\t\tcase 1: this.y = value; break;\n\t\t\tcase 2: this.z = value; break;\n\t\t\tcase 3: this.w = value; break;\n\t\t\tdefault: throw new Error( 'index is out of range: ' + index );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tgetComponent( index ) {\n\n\t\tswitch ( index ) {\n\n\t\t\tcase 0: return this.x;\n\t\t\tcase 1: return this.y;\n\t\t\tcase 2: return this.z;\n\t\t\tcase 3: return this.w;\n\t\t\tdefault: throw new Error( 'index is out of range: ' + index );\n\n\t\t}\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor( this.x, this.y, this.z, this.w );\n\n\t}\n\n\tcopy( v ) {\n\n\t\tthis.x = v.x;\n\t\tthis.y = v.y;\n\t\tthis.z = v.z;\n\t\tthis.w = ( v.w !== undefined ) ? v.w : 1;\n\n\t\treturn this;\n\n\t}\n\n\tadd( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector4: .add() now only accepts one argument. Use .addVectors( a, b ) instead.' );\n\t\t\treturn this.addVectors( v, w );\n\n\t\t}\n\n\t\tthis.x += v.x;\n\t\tthis.y += v.y;\n\t\tthis.z += v.z;\n\t\tthis.w += v.w;\n\n\t\treturn this;\n\n\t}\n\n\taddScalar( s ) {\n\n\t\tthis.x += s;\n\t\tthis.y += s;\n\t\tthis.z += s;\n\t\tthis.w += s;\n\n\t\treturn this;\n\n\t}\n\n\taddVectors( a, b ) {\n\n\t\tthis.x = a.x + b.x;\n\t\tthis.y = a.y + b.y;\n\t\tthis.z = a.z + b.z;\n\t\tthis.w = a.w + b.w;\n\n\t\treturn this;\n\n\t}\n\n\taddScaledVector( v, s ) {\n\n\t\tthis.x += v.x * s;\n\t\tthis.y += v.y * s;\n\t\tthis.z += v.z * s;\n\t\tthis.w += v.w * s;\n\n\t\treturn this;\n\n\t}\n\n\tsub( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector4: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.' );\n\t\t\treturn this.subVectors( v, w );\n\n\t\t}\n\n\t\tthis.x -= v.x;\n\t\tthis.y -= v.y;\n\t\tthis.z -= v.z;\n\t\tthis.w -= v.w;\n\n\t\treturn this;\n\n\t}\n\n\tsubScalar( s ) {\n\n\t\tthis.x -= s;\n\t\tthis.y -= s;\n\t\tthis.z -= s;\n\t\tthis.w -= s;\n\n\t\treturn this;\n\n\t}\n\n\tsubVectors( a, b ) {\n\n\t\tthis.x = a.x - b.x;\n\t\tthis.y = a.y - b.y;\n\t\tthis.z = a.z - b.z;\n\t\tthis.w = a.w - b.w;\n\n\t\treturn this;\n\n\t}\n\n\tmultiply( v ) {\n\n\t\tthis.x *= v.x;\n\t\tthis.y *= v.y;\n\t\tthis.z *= v.z;\n\t\tthis.w *= v.w;\n\n\t\treturn this;\n\n\t}\n\n\tmultiplyScalar( scalar ) {\n\n\t\tthis.x *= scalar;\n\t\tthis.y *= scalar;\n\t\tthis.z *= scalar;\n\t\tthis.w *= scalar;\n\n\t\treturn this;\n\n\t}\n\n\tapplyMatrix4( m ) {\n\n\t\tconst x = this.x, y = this.y, z = this.z, w = this.w;\n\t\tconst e = m.elements;\n\n\t\tthis.x = e[ 0 ] * x + e[ 4 ] * y + e[ 8 ] * z + e[ 12 ] * w;\n\t\tthis.y = e[ 1 ] * x + e[ 5 ] * y + e[ 9 ] * z + e[ 13 ] * w;\n\t\tthis.z = e[ 2 ] * x + e[ 6 ] * y + e[ 10 ] * z + e[ 14 ] * w;\n\t\tthis.w = e[ 3 ] * x + e[ 7 ] * y + e[ 11 ] * z + e[ 15 ] * w;\n\n\t\treturn this;\n\n\t}\n\n\tdivideScalar( scalar ) {\n\n\t\treturn this.multiplyScalar( 1 / scalar );\n\n\t}\n\n\tsetAxisAngleFromQuaternion( q ) {\n\n\t\t// http://www.euclideanspace.com/maths/geometry/rotations/conversions/quaternionToAngle/index.htm\n\n\t\t// q is assumed to be normalized\n\n\t\tthis.w = 2 * Math.acos( q.w );\n\n\t\tconst s = Math.sqrt( 1 - q.w * q.w );\n\n\t\tif ( s < 0.0001 ) {\n\n\t\t\tthis.x = 1;\n\t\t\tthis.y = 0;\n\t\t\tthis.z = 0;\n\n\t\t} else {\n\n\t\t\tthis.x = q.x / s;\n\t\t\tthis.y = q.y / s;\n\t\t\tthis.z = q.z / s;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tsetAxisAngleFromRotationMatrix( m ) {\n\n\t\t// http://www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToAngle/index.htm\n\n\t\t// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n\n\t\tlet angle, x, y, z; // variables for result\n\t\tconst epsilon = 0.01,\t\t// margin to allow for rounding errors\n\t\t\tepsilon2 = 0.1,\t\t// margin to distinguish between 0 and 180 degrees\n\n\t\t\tte = m.elements,\n\n\t\t\tm11 = te[ 0 ], m12 = te[ 4 ], m13 = te[ 8 ],\n\t\t\tm21 = te[ 1 ], m22 = te[ 5 ], m23 = te[ 9 ],\n\t\t\tm31 = te[ 2 ], m32 = te[ 6 ], m33 = te[ 10 ];\n\n\t\tif ( ( Math.abs( m12 - m21 ) < epsilon ) &&\n\t\t ( Math.abs( m13 - m31 ) < epsilon ) &&\n\t\t ( Math.abs( m23 - m32 ) < epsilon ) ) {\n\n\t\t\t// singularity found\n\t\t\t// first check for identity matrix which must have +1 for all terms\n\t\t\t// in leading diagonal and zero in other terms\n\n\t\t\tif ( ( Math.abs( m12 + m21 ) < epsilon2 ) &&\n\t\t\t ( Math.abs( m13 + m31 ) < epsilon2 ) &&\n\t\t\t ( Math.abs( m23 + m32 ) < epsilon2 ) &&\n\t\t\t ( Math.abs( m11 + m22 + m33 - 3 ) < epsilon2 ) ) {\n\n\t\t\t\t// this singularity is identity matrix so angle = 0\n\n\t\t\t\tthis.set( 1, 0, 0, 0 );\n\n\t\t\t\treturn this; // zero angle, arbitrary axis\n\n\t\t\t}\n\n\t\t\t// otherwise this singularity is angle = 180\n\n\t\t\tangle = Math.PI;\n\n\t\t\tconst xx = ( m11 + 1 ) / 2;\n\t\t\tconst yy = ( m22 + 1 ) / 2;\n\t\t\tconst zz = ( m33 + 1 ) / 2;\n\t\t\tconst xy = ( m12 + m21 ) / 4;\n\t\t\tconst xz = ( m13 + m31 ) / 4;\n\t\t\tconst yz = ( m23 + m32 ) / 4;\n\n\t\t\tif ( ( xx > yy ) && ( xx > zz ) ) {\n\n\t\t\t\t// m11 is the largest diagonal term\n\n\t\t\t\tif ( xx < epsilon ) {\n\n\t\t\t\t\tx = 0;\n\t\t\t\t\ty = 0.707106781;\n\t\t\t\t\tz = 0.707106781;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tx = Math.sqrt( xx );\n\t\t\t\t\ty = xy / x;\n\t\t\t\t\tz = xz / x;\n\n\t\t\t\t}\n\n\t\t\t} else if ( yy > zz ) {\n\n\t\t\t\t// m22 is the largest diagonal term\n\n\t\t\t\tif ( yy < epsilon ) {\n\n\t\t\t\t\tx = 0.707106781;\n\t\t\t\t\ty = 0;\n\t\t\t\t\tz = 0.707106781;\n\n\t\t\t\t} else {\n\n\t\t\t\t\ty = Math.sqrt( yy );\n\t\t\t\t\tx = xy / y;\n\t\t\t\t\tz = yz / y;\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t// m33 is the largest diagonal term so base result on this\n\n\t\t\t\tif ( zz < epsilon ) {\n\n\t\t\t\t\tx = 0.707106781;\n\t\t\t\t\ty = 0.707106781;\n\t\t\t\t\tz = 0;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tz = Math.sqrt( zz );\n\t\t\t\t\tx = xz / z;\n\t\t\t\t\ty = yz / z;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis.set( x, y, z, angle );\n\n\t\t\treturn this; // return 180 deg rotation\n\n\t\t}\n\n\t\t// as we have reached here there are no singularities so we can handle normally\n\n\t\tlet s = Math.sqrt( ( m32 - m23 ) * ( m32 - m23 ) +\n\t\t\t( m13 - m31 ) * ( m13 - m31 ) +\n\t\t\t( m21 - m12 ) * ( m21 - m12 ) ); // used to normalize\n\n\t\tif ( Math.abs( s ) < 0.001 ) s = 1;\n\n\t\t// prevent divide by zero, should not happen if matrix is orthogonal and should be\n\t\t// caught by singularity test above, but I've left it in just in case\n\n\t\tthis.x = ( m32 - m23 ) / s;\n\t\tthis.y = ( m13 - m31 ) / s;\n\t\tthis.z = ( m21 - m12 ) / s;\n\t\tthis.w = Math.acos( ( m11 + m22 + m33 - 1 ) / 2 );\n\n\t\treturn this;\n\n\t}\n\n\tmin( v ) {\n\n\t\tthis.x = Math.min( this.x, v.x );\n\t\tthis.y = Math.min( this.y, v.y );\n\t\tthis.z = Math.min( this.z, v.z );\n\t\tthis.w = Math.min( this.w, v.w );\n\n\t\treturn this;\n\n\t}\n\n\tmax( v ) {\n\n\t\tthis.x = Math.max( this.x, v.x );\n\t\tthis.y = Math.max( this.y, v.y );\n\t\tthis.z = Math.max( this.z, v.z );\n\t\tthis.w = Math.max( this.w, v.w );\n\n\t\treturn this;\n\n\t}\n\n\tclamp( min, max ) {\n\n\t\t// assumes min < max, componentwise\n\n\t\tthis.x = Math.max( min.x, Math.min( max.x, this.x ) );\n\t\tthis.y = Math.max( min.y, Math.min( max.y, this.y ) );\n\t\tthis.z = Math.max( min.z, Math.min( max.z, this.z ) );\n\t\tthis.w = Math.max( min.w, Math.min( max.w, this.w ) );\n\n\t\treturn this;\n\n\t}\n\n\tclampScalar( minVal, maxVal ) {\n\n\t\tthis.x = Math.max( minVal, Math.min( maxVal, this.x ) );\n\t\tthis.y = Math.max( minVal, Math.min( maxVal, this.y ) );\n\t\tthis.z = Math.max( minVal, Math.min( maxVal, this.z ) );\n\t\tthis.w = Math.max( minVal, Math.min( maxVal, this.w ) );\n\n\t\treturn this;\n\n\t}\n\n\tclampLength( min, max ) {\n\n\t\tconst length = this.length();\n\n\t\treturn this.divideScalar( length || 1 ).multiplyScalar( Math.max( min, Math.min( max, length ) ) );\n\n\t}\n\n\tfloor() {\n\n\t\tthis.x = Math.floor( this.x );\n\t\tthis.y = Math.floor( this.y );\n\t\tthis.z = Math.floor( this.z );\n\t\tthis.w = Math.floor( this.w );\n\n\t\treturn this;\n\n\t}\n\n\tceil() {\n\n\t\tthis.x = Math.ceil( this.x );\n\t\tthis.y = Math.ceil( this.y );\n\t\tthis.z = Math.ceil( this.z );\n\t\tthis.w = Math.ceil( this.w );\n\n\t\treturn this;\n\n\t}\n\n\tround() {\n\n\t\tthis.x = Math.round( this.x );\n\t\tthis.y = Math.round( this.y );\n\t\tthis.z = Math.round( this.z );\n\t\tthis.w = Math.round( this.w );\n\n\t\treturn this;\n\n\t}\n\n\troundToZero() {\n\n\t\tthis.x = ( this.x < 0 ) ? Math.ceil( this.x ) : Math.floor( this.x );\n\t\tthis.y = ( this.y < 0 ) ? Math.ceil( this.y ) : Math.floor( this.y );\n\t\tthis.z = ( this.z < 0 ) ? Math.ceil( this.z ) : Math.floor( this.z );\n\t\tthis.w = ( this.w < 0 ) ? Math.ceil( this.w ) : Math.floor( this.w );\n\n\t\treturn this;\n\n\t}\n\n\tnegate() {\n\n\t\tthis.x = - this.x;\n\t\tthis.y = - this.y;\n\t\tthis.z = - this.z;\n\t\tthis.w = - this.w;\n\n\t\treturn this;\n\n\t}\n\n\tdot( v ) {\n\n\t\treturn this.x * v.x + this.y * v.y + this.z * v.z + this.w * v.w;\n\n\t}\n\n\tlengthSq() {\n\n\t\treturn this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w;\n\n\t}\n\n\tlength() {\n\n\t\treturn Math.sqrt( this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w );\n\n\t}\n\n\tmanhattanLength() {\n\n\t\treturn Math.abs( this.x ) + Math.abs( this.y ) + Math.abs( this.z ) + Math.abs( this.w );\n\n\t}\n\n\tnormalize() {\n\n\t\treturn this.divideScalar( this.length() || 1 );\n\n\t}\n\n\tsetLength( length ) {\n\n\t\treturn this.normalize().multiplyScalar( length );\n\n\t}\n\n\tlerp( v, alpha ) {\n\n\t\tthis.x += ( v.x - this.x ) * alpha;\n\t\tthis.y += ( v.y - this.y ) * alpha;\n\t\tthis.z += ( v.z - this.z ) * alpha;\n\t\tthis.w += ( v.w - this.w ) * alpha;\n\n\t\treturn this;\n\n\t}\n\n\tlerpVectors( v1, v2, alpha ) {\n\n\t\tthis.x = v1.x + ( v2.x - v1.x ) * alpha;\n\t\tthis.y = v1.y + ( v2.y - v1.y ) * alpha;\n\t\tthis.z = v1.z + ( v2.z - v1.z ) * alpha;\n\t\tthis.w = v1.w + ( v2.w - v1.w ) * alpha;\n\n\t\treturn this;\n\n\t}\n\n\tequals( v ) {\n\n\t\treturn ( ( v.x === this.x ) && ( v.y === this.y ) && ( v.z === this.z ) && ( v.w === this.w ) );\n\n\t}\n\n\tfromArray( array, offset = 0 ) {\n\n\t\tthis.x = array[ offset ];\n\t\tthis.y = array[ offset + 1 ];\n\t\tthis.z = array[ offset + 2 ];\n\t\tthis.w = array[ offset + 3 ];\n\n\t\treturn this;\n\n\t}\n\n\ttoArray( array = [], offset = 0 ) {\n\n\t\tarray[ offset ] = this.x;\n\t\tarray[ offset + 1 ] = this.y;\n\t\tarray[ offset + 2 ] = this.z;\n\t\tarray[ offset + 3 ] = this.w;\n\n\t\treturn array;\n\n\t}\n\n\tfromBufferAttribute( attribute, index, offset ) {\n\n\t\tif ( offset !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector4: offset has been removed from .fromBufferAttribute().' );\n\n\t\t}\n\n\t\tthis.x = attribute.getX( index );\n\t\tthis.y = attribute.getY( index );\n\t\tthis.z = attribute.getZ( index );\n\t\tthis.w = attribute.getW( index );\n\n\t\treturn this;\n\n\t}\n\n\trandom() {\n\n\t\tthis.x = Math.random();\n\t\tthis.y = Math.random();\n\t\tthis.z = Math.random();\n\t\tthis.w = Math.random();\n\n\t\treturn this;\n\n\t}\n\n\t*[ Symbol.iterator ]() {\n\n\t\tyield this.x;\n\t\tyield this.y;\n\t\tyield this.z;\n\t\tyield this.w;\n\n\t}\n\n}\n\n/*\n In options, we can specify:\n * Texture parameters for an auto-generated target texture\n * depthBuffer/stencilBuffer: Booleans to indicate if we should generate these buffers\n*/\nclass WebGLRenderTarget extends EventDispatcher {\n\n\tconstructor( width, height, options = {} ) {\n\n\t\tsuper();\n\n\t\tthis.isWebGLRenderTarget = true;\n\n\t\tthis.width = width;\n\t\tthis.height = height;\n\t\tthis.depth = 1;\n\n\t\tthis.scissor = new Vector4( 0, 0, width, height );\n\t\tthis.scissorTest = false;\n\n\t\tthis.viewport = new Vector4( 0, 0, width, height );\n\n\t\tconst image = { width: width, height: height, depth: 1 };\n\n\t\tthis.texture = new Texture( image, options.mapping, options.wrapS, options.wrapT, options.magFilter, options.minFilter, options.format, options.type, options.anisotropy, options.encoding );\n\t\tthis.texture.isRenderTargetTexture = true;\n\n\t\tthis.texture.flipY = false;\n\t\tthis.texture.generateMipmaps = options.generateMipmaps !== undefined ? options.generateMipmaps : false;\n\t\tthis.texture.internalFormat = options.internalFormat !== undefined ? options.internalFormat : null;\n\t\tthis.texture.minFilter = options.minFilter !== undefined ? options.minFilter : LinearFilter;\n\n\t\tthis.depthBuffer = options.depthBuffer !== undefined ? options.depthBuffer : true;\n\t\tthis.stencilBuffer = options.stencilBuffer !== undefined ? options.stencilBuffer : false;\n\n\t\tthis.depthTexture = options.depthTexture !== undefined ? options.depthTexture : null;\n\n\t\tthis.samples = options.samples !== undefined ? options.samples : 0;\n\n\t}\n\n\tsetSize( width, height, depth = 1 ) {\n\n\t\tif ( this.width !== width || this.height !== height || this.depth !== depth ) {\n\n\t\t\tthis.width = width;\n\t\t\tthis.height = height;\n\t\t\tthis.depth = depth;\n\n\t\t\tthis.texture.image.width = width;\n\t\t\tthis.texture.image.height = height;\n\t\t\tthis.texture.image.depth = depth;\n\n\t\t\tthis.dispose();\n\n\t\t}\n\n\t\tthis.viewport.set( 0, 0, width, height );\n\t\tthis.scissor.set( 0, 0, width, height );\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tthis.width = source.width;\n\t\tthis.height = source.height;\n\t\tthis.depth = source.depth;\n\n\t\tthis.viewport.copy( source.viewport );\n\n\t\tthis.texture = source.texture.clone();\n\t\tthis.texture.isRenderTargetTexture = true;\n\n\t\t// ensure image object is not shared, see #20328\n\n\t\tconst image = Object.assign( {}, source.texture.image );\n\t\tthis.texture.source = new Source( image );\n\n\t\tthis.depthBuffer = source.depthBuffer;\n\t\tthis.stencilBuffer = source.stencilBuffer;\n\n\t\tif ( source.depthTexture !== null ) this.depthTexture = source.depthTexture.clone();\n\n\t\tthis.samples = source.samples;\n\n\t\treturn this;\n\n\t}\n\n\tdispose() {\n\n\t\tthis.dispatchEvent( { type: 'dispose' } );\n\n\t}\n\n}\n\nclass DataArrayTexture extends Texture {\n\n\tconstructor( data = null, width = 1, height = 1, depth = 1 ) {\n\n\t\tsuper( null );\n\n\t\tthis.isDataArrayTexture = true;\n\n\t\tthis.image = { data, width, height, depth };\n\n\t\tthis.magFilter = NearestFilter;\n\t\tthis.minFilter = NearestFilter;\n\n\t\tthis.wrapR = ClampToEdgeWrapping;\n\n\t\tthis.generateMipmaps = false;\n\t\tthis.flipY = false;\n\t\tthis.unpackAlignment = 1;\n\n\t}\n\n}\n\nclass WebGLArrayRenderTarget extends WebGLRenderTarget {\n\n\tconstructor( width, height, depth ) {\n\n\t\tsuper( width, height );\n\n\t\tthis.isWebGLArrayRenderTarget = true;\n\n\t\tthis.depth = depth;\n\n\t\tthis.texture = new DataArrayTexture( null, width, height, depth );\n\n\t\tthis.texture.isRenderTargetTexture = true;\n\n\t}\n\n}\n\nclass Data3DTexture extends Texture {\n\n\tconstructor( data = null, width = 1, height = 1, depth = 1 ) {\n\n\t\t// We're going to add .setXXX() methods for setting properties later.\n\t\t// Users can still set in DataTexture3D directly.\n\t\t//\n\t\t//\tconst texture = new THREE.DataTexture3D( data, width, height, depth );\n\t\t// \ttexture.anisotropy = 16;\n\t\t//\n\t\t// See #14839\n\n\t\tsuper( null );\n\n\t\tthis.isData3DTexture = true;\n\n\t\tthis.image = { data, width, height, depth };\n\n\t\tthis.magFilter = NearestFilter;\n\t\tthis.minFilter = NearestFilter;\n\n\t\tthis.wrapR = ClampToEdgeWrapping;\n\n\t\tthis.generateMipmaps = false;\n\t\tthis.flipY = false;\n\t\tthis.unpackAlignment = 1;\n\n\t}\n\n}\n\nclass WebGL3DRenderTarget extends WebGLRenderTarget {\n\n\tconstructor( width, height, depth ) {\n\n\t\tsuper( width, height );\n\n\t\tthis.isWebGL3DRenderTarget = true;\n\n\t\tthis.depth = depth;\n\n\t\tthis.texture = new Data3DTexture( null, width, height, depth );\n\n\t\tthis.texture.isRenderTargetTexture = true;\n\n\t}\n\n}\n\nclass WebGLMultipleRenderTargets extends WebGLRenderTarget {\n\n\tconstructor( width, height, count, options = {} ) {\n\n\t\tsuper( width, height, options );\n\n\t\tthis.isWebGLMultipleRenderTargets = true;\n\n\t\tconst texture = this.texture;\n\n\t\tthis.texture = [];\n\n\t\tfor ( let i = 0; i < count; i ++ ) {\n\n\t\t\tthis.texture[ i ] = texture.clone();\n\t\t\tthis.texture[ i ].isRenderTargetTexture = true;\n\n\t\t}\n\n\t}\n\n\tsetSize( width, height, depth = 1 ) {\n\n\t\tif ( this.width !== width || this.height !== height || this.depth !== depth ) {\n\n\t\t\tthis.width = width;\n\t\t\tthis.height = height;\n\t\t\tthis.depth = depth;\n\n\t\t\tfor ( let i = 0, il = this.texture.length; i < il; i ++ ) {\n\n\t\t\t\tthis.texture[ i ].image.width = width;\n\t\t\t\tthis.texture[ i ].image.height = height;\n\t\t\t\tthis.texture[ i ].image.depth = depth;\n\n\t\t\t}\n\n\t\t\tthis.dispose();\n\n\t\t}\n\n\t\tthis.viewport.set( 0, 0, width, height );\n\t\tthis.scissor.set( 0, 0, width, height );\n\n\t\treturn this;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tthis.dispose();\n\n\t\tthis.width = source.width;\n\t\tthis.height = source.height;\n\t\tthis.depth = source.depth;\n\n\t\tthis.viewport.set( 0, 0, this.width, this.height );\n\t\tthis.scissor.set( 0, 0, this.width, this.height );\n\n\t\tthis.depthBuffer = source.depthBuffer;\n\t\tthis.stencilBuffer = source.stencilBuffer;\n\n\t\tif ( source.depthTexture !== null ) this.depthTexture = source.depthTexture.clone();\n\n\t\tthis.texture.length = 0;\n\n\t\tfor ( let i = 0, il = source.texture.length; i < il; i ++ ) {\n\n\t\t\tthis.texture[ i ] = source.texture[ i ].clone();\n\t\t\tthis.texture[ i ].isRenderTargetTexture = true;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass Quaternion {\n\n\tconstructor( x = 0, y = 0, z = 0, w = 1 ) {\n\n\t\tthis.isQuaternion = true;\n\n\t\tthis._x = x;\n\t\tthis._y = y;\n\t\tthis._z = z;\n\t\tthis._w = w;\n\n\t}\n\n\tstatic slerp( qa, qb, qm, t ) {\n\n\t\tconsole.warn( 'THREE.Quaternion: Static .slerp() has been deprecated. Use qm.slerpQuaternions( qa, qb, t ) instead.' );\n\t\treturn qm.slerpQuaternions( qa, qb, t );\n\n\t}\n\n\tstatic slerpFlat( dst, dstOffset, src0, srcOffset0, src1, srcOffset1, t ) {\n\n\t\t// fuzz-free, array-based Quaternion SLERP operation\n\n\t\tlet x0 = src0[ srcOffset0 + 0 ],\n\t\t\ty0 = src0[ srcOffset0 + 1 ],\n\t\t\tz0 = src0[ srcOffset0 + 2 ],\n\t\t\tw0 = src0[ srcOffset0 + 3 ];\n\n\t\tconst x1 = src1[ srcOffset1 + 0 ],\n\t\t\ty1 = src1[ srcOffset1 + 1 ],\n\t\t\tz1 = src1[ srcOffset1 + 2 ],\n\t\t\tw1 = src1[ srcOffset1 + 3 ];\n\n\t\tif ( t === 0 ) {\n\n\t\t\tdst[ dstOffset + 0 ] = x0;\n\t\t\tdst[ dstOffset + 1 ] = y0;\n\t\t\tdst[ dstOffset + 2 ] = z0;\n\t\t\tdst[ dstOffset + 3 ] = w0;\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( t === 1 ) {\n\n\t\t\tdst[ dstOffset + 0 ] = x1;\n\t\t\tdst[ dstOffset + 1 ] = y1;\n\t\t\tdst[ dstOffset + 2 ] = z1;\n\t\t\tdst[ dstOffset + 3 ] = w1;\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( w0 !== w1 || x0 !== x1 || y0 !== y1 || z0 !== z1 ) {\n\n\t\t\tlet s = 1 - t;\n\t\t\tconst cos = x0 * x1 + y0 * y1 + z0 * z1 + w0 * w1,\n\t\t\t\tdir = ( cos >= 0 ? 1 : - 1 ),\n\t\t\t\tsqrSin = 1 - cos * cos;\n\n\t\t\t// Skip the Slerp for tiny steps to avoid numeric problems:\n\t\t\tif ( sqrSin > Number.EPSILON ) {\n\n\t\t\t\tconst sin = Math.sqrt( sqrSin ),\n\t\t\t\t\tlen = Math.atan2( sin, cos * dir );\n\n\t\t\t\ts = Math.sin( s * len ) / sin;\n\t\t\t\tt = Math.sin( t * len ) / sin;\n\n\t\t\t}\n\n\t\t\tconst tDir = t * dir;\n\n\t\t\tx0 = x0 * s + x1 * tDir;\n\t\t\ty0 = y0 * s + y1 * tDir;\n\t\t\tz0 = z0 * s + z1 * tDir;\n\t\t\tw0 = w0 * s + w1 * tDir;\n\n\t\t\t// Normalize in case we just did a lerp:\n\t\t\tif ( s === 1 - t ) {\n\n\t\t\t\tconst f = 1 / Math.sqrt( x0 * x0 + y0 * y0 + z0 * z0 + w0 * w0 );\n\n\t\t\t\tx0 *= f;\n\t\t\t\ty0 *= f;\n\t\t\t\tz0 *= f;\n\t\t\t\tw0 *= f;\n\n\t\t\t}\n\n\t\t}\n\n\t\tdst[ dstOffset ] = x0;\n\t\tdst[ dstOffset + 1 ] = y0;\n\t\tdst[ dstOffset + 2 ] = z0;\n\t\tdst[ dstOffset + 3 ] = w0;\n\n\t}\n\n\tstatic multiplyQuaternionsFlat( dst, dstOffset, src0, srcOffset0, src1, srcOffset1 ) {\n\n\t\tconst x0 = src0[ srcOffset0 ];\n\t\tconst y0 = src0[ srcOffset0 + 1 ];\n\t\tconst z0 = src0[ srcOffset0 + 2 ];\n\t\tconst w0 = src0[ srcOffset0 + 3 ];\n\n\t\tconst x1 = src1[ srcOffset1 ];\n\t\tconst y1 = src1[ srcOffset1 + 1 ];\n\t\tconst z1 = src1[ srcOffset1 + 2 ];\n\t\tconst w1 = src1[ srcOffset1 + 3 ];\n\n\t\tdst[ dstOffset ] = x0 * w1 + w0 * x1 + y0 * z1 - z0 * y1;\n\t\tdst[ dstOffset + 1 ] = y0 * w1 + w0 * y1 + z0 * x1 - x0 * z1;\n\t\tdst[ dstOffset + 2 ] = z0 * w1 + w0 * z1 + x0 * y1 - y0 * x1;\n\t\tdst[ dstOffset + 3 ] = w0 * w1 - x0 * x1 - y0 * y1 - z0 * z1;\n\n\t\treturn dst;\n\n\t}\n\n\tget x() {\n\n\t\treturn this._x;\n\n\t}\n\n\tset x( value ) {\n\n\t\tthis._x = value;\n\t\tthis._onChangeCallback();\n\n\t}\n\n\tget y() {\n\n\t\treturn this._y;\n\n\t}\n\n\tset y( value ) {\n\n\t\tthis._y = value;\n\t\tthis._onChangeCallback();\n\n\t}\n\n\tget z() {\n\n\t\treturn this._z;\n\n\t}\n\n\tset z( value ) {\n\n\t\tthis._z = value;\n\t\tthis._onChangeCallback();\n\n\t}\n\n\tget w() {\n\n\t\treturn this._w;\n\n\t}\n\n\tset w( value ) {\n\n\t\tthis._w = value;\n\t\tthis._onChangeCallback();\n\n\t}\n\n\tset( x, y, z, w ) {\n\n\t\tthis._x = x;\n\t\tthis._y = y;\n\t\tthis._z = z;\n\t\tthis._w = w;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor( this._x, this._y, this._z, this._w );\n\n\t}\n\n\tcopy( quaternion ) {\n\n\t\tthis._x = quaternion.x;\n\t\tthis._y = quaternion.y;\n\t\tthis._z = quaternion.z;\n\t\tthis._w = quaternion.w;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\tsetFromEuler( euler, update ) {\n\n\t\tif ( ! ( euler && euler.isEuler ) ) {\n\n\t\t\tthrow new Error( 'THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order.' );\n\n\t\t}\n\n\t\tconst x = euler._x, y = euler._y, z = euler._z, order = euler._order;\n\n\t\t// http://www.mathworks.com/matlabcentral/fileexchange/\n\t\t// \t20696-function-to-convert-between-dcm-euler-angles-quaternions-and-euler-vectors/\n\t\t//\tcontent/SpinCalc.m\n\n\t\tconst cos = Math.cos;\n\t\tconst sin = Math.sin;\n\n\t\tconst c1 = cos( x / 2 );\n\t\tconst c2 = cos( y / 2 );\n\t\tconst c3 = cos( z / 2 );\n\n\t\tconst s1 = sin( x / 2 );\n\t\tconst s2 = sin( y / 2 );\n\t\tconst s3 = sin( z / 2 );\n\n\t\tswitch ( order ) {\n\n\t\t\tcase 'XYZ':\n\t\t\t\tthis._x = s1 * c2 * c3 + c1 * s2 * s3;\n\t\t\t\tthis._y = c1 * s2 * c3 - s1 * c2 * s3;\n\t\t\t\tthis._z = c1 * c2 * s3 + s1 * s2 * c3;\n\t\t\t\tthis._w = c1 * c2 * c3 - s1 * s2 * s3;\n\t\t\t\tbreak;\n\n\t\t\tcase 'YXZ':\n\t\t\t\tthis._x = s1 * c2 * c3 + c1 * s2 * s3;\n\t\t\t\tthis._y = c1 * s2 * c3 - s1 * c2 * s3;\n\t\t\t\tthis._z = c1 * c2 * s3 - s1 * s2 * c3;\n\t\t\t\tthis._w = c1 * c2 * c3 + s1 * s2 * s3;\n\t\t\t\tbreak;\n\n\t\t\tcase 'ZXY':\n\t\t\t\tthis._x = s1 * c2 * c3 - c1 * s2 * s3;\n\t\t\t\tthis._y = c1 * s2 * c3 + s1 * c2 * s3;\n\t\t\t\tthis._z = c1 * c2 * s3 + s1 * s2 * c3;\n\t\t\t\tthis._w = c1 * c2 * c3 - s1 * s2 * s3;\n\t\t\t\tbreak;\n\n\t\t\tcase 'ZYX':\n\t\t\t\tthis._x = s1 * c2 * c3 - c1 * s2 * s3;\n\t\t\t\tthis._y = c1 * s2 * c3 + s1 * c2 * s3;\n\t\t\t\tthis._z = c1 * c2 * s3 - s1 * s2 * c3;\n\t\t\t\tthis._w = c1 * c2 * c3 + s1 * s2 * s3;\n\t\t\t\tbreak;\n\n\t\t\tcase 'YZX':\n\t\t\t\tthis._x = s1 * c2 * c3 + c1 * s2 * s3;\n\t\t\t\tthis._y = c1 * s2 * c3 + s1 * c2 * s3;\n\t\t\t\tthis._z = c1 * c2 * s3 - s1 * s2 * c3;\n\t\t\t\tthis._w = c1 * c2 * c3 - s1 * s2 * s3;\n\t\t\t\tbreak;\n\n\t\t\tcase 'XZY':\n\t\t\t\tthis._x = s1 * c2 * c3 - c1 * s2 * s3;\n\t\t\t\tthis._y = c1 * s2 * c3 - s1 * c2 * s3;\n\t\t\t\tthis._z = c1 * c2 * s3 + s1 * s2 * c3;\n\t\t\t\tthis._w = c1 * c2 * c3 + s1 * s2 * s3;\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tconsole.warn( 'THREE.Quaternion: .setFromEuler() encountered an unknown order: ' + order );\n\n\t\t}\n\n\t\tif ( update !== false ) this._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\tsetFromAxisAngle( axis, angle ) {\n\n\t\t// http://www.euclideanspace.com/maths/geometry/rotations/conversions/angleToQuaternion/index.htm\n\n\t\t// assumes axis is normalized\n\n\t\tconst halfAngle = angle / 2, s = Math.sin( halfAngle );\n\n\t\tthis._x = axis.x * s;\n\t\tthis._y = axis.y * s;\n\t\tthis._z = axis.z * s;\n\t\tthis._w = Math.cos( halfAngle );\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\tsetFromRotationMatrix( m ) {\n\n\t\t// http://www.euclideanspace.com/maths/geometry/rotations/conversions/matrixToQuaternion/index.htm\n\n\t\t// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n\n\t\tconst te = m.elements,\n\n\t\t\tm11 = te[ 0 ], m12 = te[ 4 ], m13 = te[ 8 ],\n\t\t\tm21 = te[ 1 ], m22 = te[ 5 ], m23 = te[ 9 ],\n\t\t\tm31 = te[ 2 ], m32 = te[ 6 ], m33 = te[ 10 ],\n\n\t\t\ttrace = m11 + m22 + m33;\n\n\t\tif ( trace > 0 ) {\n\n\t\t\tconst s = 0.5 / Math.sqrt( trace + 1.0 );\n\n\t\t\tthis._w = 0.25 / s;\n\t\t\tthis._x = ( m32 - m23 ) * s;\n\t\t\tthis._y = ( m13 - m31 ) * s;\n\t\t\tthis._z = ( m21 - m12 ) * s;\n\n\t\t} else if ( m11 > m22 && m11 > m33 ) {\n\n\t\t\tconst s = 2.0 * Math.sqrt( 1.0 + m11 - m22 - m33 );\n\n\t\t\tthis._w = ( m32 - m23 ) / s;\n\t\t\tthis._x = 0.25 * s;\n\t\t\tthis._y = ( m12 + m21 ) / s;\n\t\t\tthis._z = ( m13 + m31 ) / s;\n\n\t\t} else if ( m22 > m33 ) {\n\n\t\t\tconst s = 2.0 * Math.sqrt( 1.0 + m22 - m11 - m33 );\n\n\t\t\tthis._w = ( m13 - m31 ) / s;\n\t\t\tthis._x = ( m12 + m21 ) / s;\n\t\t\tthis._y = 0.25 * s;\n\t\t\tthis._z = ( m23 + m32 ) / s;\n\n\t\t} else {\n\n\t\t\tconst s = 2.0 * Math.sqrt( 1.0 + m33 - m11 - m22 );\n\n\t\t\tthis._w = ( m21 - m12 ) / s;\n\t\t\tthis._x = ( m13 + m31 ) / s;\n\t\t\tthis._y = ( m23 + m32 ) / s;\n\t\t\tthis._z = 0.25 * s;\n\n\t\t}\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\tsetFromUnitVectors( vFrom, vTo ) {\n\n\t\t// assumes direction vectors vFrom and vTo are normalized\n\n\t\tlet r = vFrom.dot( vTo ) + 1;\n\n\t\tif ( r < Number.EPSILON ) {\n\n\t\t\t// vFrom and vTo point in opposite directions\n\n\t\t\tr = 0;\n\n\t\t\tif ( Math.abs( vFrom.x ) > Math.abs( vFrom.z ) ) {\n\n\t\t\t\tthis._x = - vFrom.y;\n\t\t\t\tthis._y = vFrom.x;\n\t\t\t\tthis._z = 0;\n\t\t\t\tthis._w = r;\n\n\t\t\t} else {\n\n\t\t\t\tthis._x = 0;\n\t\t\t\tthis._y = - vFrom.z;\n\t\t\t\tthis._z = vFrom.y;\n\t\t\t\tthis._w = r;\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t// crossVectors( vFrom, vTo ); // inlined to avoid cyclic dependency on Vector3\n\n\t\t\tthis._x = vFrom.y * vTo.z - vFrom.z * vTo.y;\n\t\t\tthis._y = vFrom.z * vTo.x - vFrom.x * vTo.z;\n\t\t\tthis._z = vFrom.x * vTo.y - vFrom.y * vTo.x;\n\t\t\tthis._w = r;\n\n\t\t}\n\n\t\treturn this.normalize();\n\n\t}\n\n\tangleTo( q ) {\n\n\t\treturn 2 * Math.acos( Math.abs( clamp( this.dot( q ), - 1, 1 ) ) );\n\n\t}\n\n\trotateTowards( q, step ) {\n\n\t\tconst angle = this.angleTo( q );\n\n\t\tif ( angle === 0 ) return this;\n\n\t\tconst t = Math.min( 1, step / angle );\n\n\t\tthis.slerp( q, t );\n\n\t\treturn this;\n\n\t}\n\n\tidentity() {\n\n\t\treturn this.set( 0, 0, 0, 1 );\n\n\t}\n\n\tinvert() {\n\n\t\t// quaternion is assumed to have unit length\n\n\t\treturn this.conjugate();\n\n\t}\n\n\tconjugate() {\n\n\t\tthis._x *= - 1;\n\t\tthis._y *= - 1;\n\t\tthis._z *= - 1;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\tdot( v ) {\n\n\t\treturn this._x * v._x + this._y * v._y + this._z * v._z + this._w * v._w;\n\n\t}\n\n\tlengthSq() {\n\n\t\treturn this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w;\n\n\t}\n\n\tlength() {\n\n\t\treturn Math.sqrt( this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w );\n\n\t}\n\n\tnormalize() {\n\n\t\tlet l = this.length();\n\n\t\tif ( l === 0 ) {\n\n\t\t\tthis._x = 0;\n\t\t\tthis._y = 0;\n\t\t\tthis._z = 0;\n\t\t\tthis._w = 1;\n\n\t\t} else {\n\n\t\t\tl = 1 / l;\n\n\t\t\tthis._x = this._x * l;\n\t\t\tthis._y = this._y * l;\n\t\t\tthis._z = this._z * l;\n\t\t\tthis._w = this._w * l;\n\n\t\t}\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\tmultiply( q, p ) {\n\n\t\tif ( p !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Quaternion: .multiply() now only accepts one argument. Use .multiplyQuaternions( a, b ) instead.' );\n\t\t\treturn this.multiplyQuaternions( q, p );\n\n\t\t}\n\n\t\treturn this.multiplyQuaternions( this, q );\n\n\t}\n\n\tpremultiply( q ) {\n\n\t\treturn this.multiplyQuaternions( q, this );\n\n\t}\n\n\tmultiplyQuaternions( a, b ) {\n\n\t\t// from http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/code/index.htm\n\n\t\tconst qax = a._x, qay = a._y, qaz = a._z, qaw = a._w;\n\t\tconst qbx = b._x, qby = b._y, qbz = b._z, qbw = b._w;\n\n\t\tthis._x = qax * qbw + qaw * qbx + qay * qbz - qaz * qby;\n\t\tthis._y = qay * qbw + qaw * qby + qaz * qbx - qax * qbz;\n\t\tthis._z = qaz * qbw + qaw * qbz + qax * qby - qay * qbx;\n\t\tthis._w = qaw * qbw - qax * qbx - qay * qby - qaz * qbz;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\tslerp( qb, t ) {\n\n\t\tif ( t === 0 ) return this;\n\t\tif ( t === 1 ) return this.copy( qb );\n\n\t\tconst x = this._x, y = this._y, z = this._z, w = this._w;\n\n\t\t// http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/slerp/\n\n\t\tlet cosHalfTheta = w * qb._w + x * qb._x + y * qb._y + z * qb._z;\n\n\t\tif ( cosHalfTheta < 0 ) {\n\n\t\t\tthis._w = - qb._w;\n\t\t\tthis._x = - qb._x;\n\t\t\tthis._y = - qb._y;\n\t\t\tthis._z = - qb._z;\n\n\t\t\tcosHalfTheta = - cosHalfTheta;\n\n\t\t} else {\n\n\t\t\tthis.copy( qb );\n\n\t\t}\n\n\t\tif ( cosHalfTheta >= 1.0 ) {\n\n\t\t\tthis._w = w;\n\t\t\tthis._x = x;\n\t\t\tthis._y = y;\n\t\t\tthis._z = z;\n\n\t\t\treturn this;\n\n\t\t}\n\n\t\tconst sqrSinHalfTheta = 1.0 - cosHalfTheta * cosHalfTheta;\n\n\t\tif ( sqrSinHalfTheta <= Number.EPSILON ) {\n\n\t\t\tconst s = 1 - t;\n\t\t\tthis._w = s * w + t * this._w;\n\t\t\tthis._x = s * x + t * this._x;\n\t\t\tthis._y = s * y + t * this._y;\n\t\t\tthis._z = s * z + t * this._z;\n\n\t\t\tthis.normalize();\n\t\t\tthis._onChangeCallback();\n\n\t\t\treturn this;\n\n\t\t}\n\n\t\tconst sinHalfTheta = Math.sqrt( sqrSinHalfTheta );\n\t\tconst halfTheta = Math.atan2( sinHalfTheta, cosHalfTheta );\n\t\tconst ratioA = Math.sin( ( 1 - t ) * halfTheta ) / sinHalfTheta,\n\t\t\tratioB = Math.sin( t * halfTheta ) / sinHalfTheta;\n\n\t\tthis._w = ( w * ratioA + this._w * ratioB );\n\t\tthis._x = ( x * ratioA + this._x * ratioB );\n\t\tthis._y = ( y * ratioA + this._y * ratioB );\n\t\tthis._z = ( z * ratioA + this._z * ratioB );\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\tslerpQuaternions( qa, qb, t ) {\n\n\t\treturn this.copy( qa ).slerp( qb, t );\n\n\t}\n\n\trandom() {\n\n\t\t// Derived from http://planning.cs.uiuc.edu/node198.html\n\t\t// Note, this source uses w, x, y, z ordering,\n\t\t// so we swap the order below.\n\n\t\tconst u1 = Math.random();\n\t\tconst sqrt1u1 = Math.sqrt( 1 - u1 );\n\t\tconst sqrtu1 = Math.sqrt( u1 );\n\n\t\tconst u2 = 2 * Math.PI * Math.random();\n\n\t\tconst u3 = 2 * Math.PI * Math.random();\n\n\t\treturn this.set(\n\t\t\tsqrt1u1 * Math.cos( u2 ),\n\t\t\tsqrtu1 * Math.sin( u3 ),\n\t\t\tsqrtu1 * Math.cos( u3 ),\n\t\t\tsqrt1u1 * Math.sin( u2 ),\n\t\t);\n\n\t}\n\n\tequals( quaternion ) {\n\n\t\treturn ( quaternion._x === this._x ) && ( quaternion._y === this._y ) && ( quaternion._z === this._z ) && ( quaternion._w === this._w );\n\n\t}\n\n\tfromArray( array, offset = 0 ) {\n\n\t\tthis._x = array[ offset ];\n\t\tthis._y = array[ offset + 1 ];\n\t\tthis._z = array[ offset + 2 ];\n\t\tthis._w = array[ offset + 3 ];\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\ttoArray( array = [], offset = 0 ) {\n\n\t\tarray[ offset ] = this._x;\n\t\tarray[ offset + 1 ] = this._y;\n\t\tarray[ offset + 2 ] = this._z;\n\t\tarray[ offset + 3 ] = this._w;\n\n\t\treturn array;\n\n\t}\n\n\tfromBufferAttribute( attribute, index ) {\n\n\t\tthis._x = attribute.getX( index );\n\t\tthis._y = attribute.getY( index );\n\t\tthis._z = attribute.getZ( index );\n\t\tthis._w = attribute.getW( index );\n\n\t\treturn this;\n\n\t}\n\n\t_onChange( callback ) {\n\n\t\tthis._onChangeCallback = callback;\n\n\t\treturn this;\n\n\t}\n\n\t_onChangeCallback() {}\n\n\t*[ Symbol.iterator ]() {\n\n\t\tyield this._x;\n\t\tyield this._y;\n\t\tyield this._z;\n\t\tyield this._w;\n\n\t}\n\n}\n\nclass Vector3 {\n\n\tconstructor( x = 0, y = 0, z = 0 ) {\n\n\t\tthis.isVector3 = true;\n\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.z = z;\n\n\t}\n\n\tset( x, y, z ) {\n\n\t\tif ( z === undefined ) z = this.z; // sprite.scale.set(x,y)\n\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.z = z;\n\n\t\treturn this;\n\n\t}\n\n\tsetScalar( scalar ) {\n\n\t\tthis.x = scalar;\n\t\tthis.y = scalar;\n\t\tthis.z = scalar;\n\n\t\treturn this;\n\n\t}\n\n\tsetX( x ) {\n\n\t\tthis.x = x;\n\n\t\treturn this;\n\n\t}\n\n\tsetY( y ) {\n\n\t\tthis.y = y;\n\n\t\treturn this;\n\n\t}\n\n\tsetZ( z ) {\n\n\t\tthis.z = z;\n\n\t\treturn this;\n\n\t}\n\n\tsetComponent( index, value ) {\n\n\t\tswitch ( index ) {\n\n\t\t\tcase 0: this.x = value; break;\n\t\t\tcase 1: this.y = value; break;\n\t\t\tcase 2: this.z = value; break;\n\t\t\tdefault: throw new Error( 'index is out of range: ' + index );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tgetComponent( index ) {\n\n\t\tswitch ( index ) {\n\n\t\t\tcase 0: return this.x;\n\t\t\tcase 1: return this.y;\n\t\t\tcase 2: return this.z;\n\t\t\tdefault: throw new Error( 'index is out of range: ' + index );\n\n\t\t}\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor( this.x, this.y, this.z );\n\n\t}\n\n\tcopy( v ) {\n\n\t\tthis.x = v.x;\n\t\tthis.y = v.y;\n\t\tthis.z = v.z;\n\n\t\treturn this;\n\n\t}\n\n\tadd( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead.' );\n\t\t\treturn this.addVectors( v, w );\n\n\t\t}\n\n\t\tthis.x += v.x;\n\t\tthis.y += v.y;\n\t\tthis.z += v.z;\n\n\t\treturn this;\n\n\t}\n\n\taddScalar( s ) {\n\n\t\tthis.x += s;\n\t\tthis.y += s;\n\t\tthis.z += s;\n\n\t\treturn this;\n\n\t}\n\n\taddVectors( a, b ) {\n\n\t\tthis.x = a.x + b.x;\n\t\tthis.y = a.y + b.y;\n\t\tthis.z = a.z + b.z;\n\n\t\treturn this;\n\n\t}\n\n\taddScaledVector( v, s ) {\n\n\t\tthis.x += v.x * s;\n\t\tthis.y += v.y * s;\n\t\tthis.z += v.z * s;\n\n\t\treturn this;\n\n\t}\n\n\tsub( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.' );\n\t\t\treturn this.subVectors( v, w );\n\n\t\t}\n\n\t\tthis.x -= v.x;\n\t\tthis.y -= v.y;\n\t\tthis.z -= v.z;\n\n\t\treturn this;\n\n\t}\n\n\tsubScalar( s ) {\n\n\t\tthis.x -= s;\n\t\tthis.y -= s;\n\t\tthis.z -= s;\n\n\t\treturn this;\n\n\t}\n\n\tsubVectors( a, b ) {\n\n\t\tthis.x = a.x - b.x;\n\t\tthis.y = a.y - b.y;\n\t\tthis.z = a.z - b.z;\n\n\t\treturn this;\n\n\t}\n\n\tmultiply( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead.' );\n\t\t\treturn this.multiplyVectors( v, w );\n\n\t\t}\n\n\t\tthis.x *= v.x;\n\t\tthis.y *= v.y;\n\t\tthis.z *= v.z;\n\n\t\treturn this;\n\n\t}\n\n\tmultiplyScalar( scalar ) {\n\n\t\tthis.x *= scalar;\n\t\tthis.y *= scalar;\n\t\tthis.z *= scalar;\n\n\t\treturn this;\n\n\t}\n\n\tmultiplyVectors( a, b ) {\n\n\t\tthis.x = a.x * b.x;\n\t\tthis.y = a.y * b.y;\n\t\tthis.z = a.z * b.z;\n\n\t\treturn this;\n\n\t}\n\n\tapplyEuler( euler ) {\n\n\t\tif ( ! ( euler && euler.isEuler ) ) {\n\n\t\t\tconsole.error( 'THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order.' );\n\n\t\t}\n\n\t\treturn this.applyQuaternion( _quaternion$4.setFromEuler( euler ) );\n\n\t}\n\n\tapplyAxisAngle( axis, angle ) {\n\n\t\treturn this.applyQuaternion( _quaternion$4.setFromAxisAngle( axis, angle ) );\n\n\t}\n\n\tapplyMatrix3( m ) {\n\n\t\tconst x = this.x, y = this.y, z = this.z;\n\t\tconst e = m.elements;\n\n\t\tthis.x = e[ 0 ] * x + e[ 3 ] * y + e[ 6 ] * z;\n\t\tthis.y = e[ 1 ] * x + e[ 4 ] * y + e[ 7 ] * z;\n\t\tthis.z = e[ 2 ] * x + e[ 5 ] * y + e[ 8 ] * z;\n\n\t\treturn this;\n\n\t}\n\n\tapplyNormalMatrix( m ) {\n\n\t\treturn this.applyMatrix3( m ).normalize();\n\n\t}\n\n\tapplyMatrix4( m ) {\n\n\t\tconst x = this.x, y = this.y, z = this.z;\n\t\tconst e = m.elements;\n\n\t\tconst w = 1 / ( e[ 3 ] * x + e[ 7 ] * y + e[ 11 ] * z + e[ 15 ] );\n\n\t\tthis.x = ( e[ 0 ] * x + e[ 4 ] * y + e[ 8 ] * z + e[ 12 ] ) * w;\n\t\tthis.y = ( e[ 1 ] * x + e[ 5 ] * y + e[ 9 ] * z + e[ 13 ] ) * w;\n\t\tthis.z = ( e[ 2 ] * x + e[ 6 ] * y + e[ 10 ] * z + e[ 14 ] ) * w;\n\n\t\treturn this;\n\n\t}\n\n\tapplyQuaternion( q ) {\n\n\t\tconst x = this.x, y = this.y, z = this.z;\n\t\tconst qx = q.x, qy = q.y, qz = q.z, qw = q.w;\n\n\t\t// calculate quat * vector\n\n\t\tconst ix = qw * x + qy * z - qz * y;\n\t\tconst iy = qw * y + qz * x - qx * z;\n\t\tconst iz = qw * z + qx * y - qy * x;\n\t\tconst iw = - qx * x - qy * y - qz * z;\n\n\t\t// calculate result * inverse quat\n\n\t\tthis.x = ix * qw + iw * - qx + iy * - qz - iz * - qy;\n\t\tthis.y = iy * qw + iw * - qy + iz * - qx - ix * - qz;\n\t\tthis.z = iz * qw + iw * - qz + ix * - qy - iy * - qx;\n\n\t\treturn this;\n\n\t}\n\n\tproject( camera ) {\n\n\t\treturn this.applyMatrix4( camera.matrixWorldInverse ).applyMatrix4( camera.projectionMatrix );\n\n\t}\n\n\tunproject( camera ) {\n\n\t\treturn this.applyMatrix4( camera.projectionMatrixInverse ).applyMatrix4( camera.matrixWorld );\n\n\t}\n\n\ttransformDirection( m ) {\n\n\t\t// input: THREE.Matrix4 affine matrix\n\t\t// vector interpreted as a direction\n\n\t\tconst x = this.x, y = this.y, z = this.z;\n\t\tconst e = m.elements;\n\n\t\tthis.x = e[ 0 ] * x + e[ 4 ] * y + e[ 8 ] * z;\n\t\tthis.y = e[ 1 ] * x + e[ 5 ] * y + e[ 9 ] * z;\n\t\tthis.z = e[ 2 ] * x + e[ 6 ] * y + e[ 10 ] * z;\n\n\t\treturn this.normalize();\n\n\t}\n\n\tdivide( v ) {\n\n\t\tthis.x /= v.x;\n\t\tthis.y /= v.y;\n\t\tthis.z /= v.z;\n\n\t\treturn this;\n\n\t}\n\n\tdivideScalar( scalar ) {\n\n\t\treturn this.multiplyScalar( 1 / scalar );\n\n\t}\n\n\tmin( v ) {\n\n\t\tthis.x = Math.min( this.x, v.x );\n\t\tthis.y = Math.min( this.y, v.y );\n\t\tthis.z = Math.min( this.z, v.z );\n\n\t\treturn this;\n\n\t}\n\n\tmax( v ) {\n\n\t\tthis.x = Math.max( this.x, v.x );\n\t\tthis.y = Math.max( this.y, v.y );\n\t\tthis.z = Math.max( this.z, v.z );\n\n\t\treturn this;\n\n\t}\n\n\tclamp( min, max ) {\n\n\t\t// assumes min < max, componentwise\n\n\t\tthis.x = Math.max( min.x, Math.min( max.x, this.x ) );\n\t\tthis.y = Math.max( min.y, Math.min( max.y, this.y ) );\n\t\tthis.z = Math.max( min.z, Math.min( max.z, this.z ) );\n\n\t\treturn this;\n\n\t}\n\n\tclampScalar( minVal, maxVal ) {\n\n\t\tthis.x = Math.max( minVal, Math.min( maxVal, this.x ) );\n\t\tthis.y = Math.max( minVal, Math.min( maxVal, this.y ) );\n\t\tthis.z = Math.max( minVal, Math.min( maxVal, this.z ) );\n\n\t\treturn this;\n\n\t}\n\n\tclampLength( min, max ) {\n\n\t\tconst length = this.length();\n\n\t\treturn this.divideScalar( length || 1 ).multiplyScalar( Math.max( min, Math.min( max, length ) ) );\n\n\t}\n\n\tfloor() {\n\n\t\tthis.x = Math.floor( this.x );\n\t\tthis.y = Math.floor( this.y );\n\t\tthis.z = Math.floor( this.z );\n\n\t\treturn this;\n\n\t}\n\n\tceil() {\n\n\t\tthis.x = Math.ceil( this.x );\n\t\tthis.y = Math.ceil( this.y );\n\t\tthis.z = Math.ceil( this.z );\n\n\t\treturn this;\n\n\t}\n\n\tround() {\n\n\t\tthis.x = Math.round( this.x );\n\t\tthis.y = Math.round( this.y );\n\t\tthis.z = Math.round( this.z );\n\n\t\treturn this;\n\n\t}\n\n\troundToZero() {\n\n\t\tthis.x = ( this.x < 0 ) ? Math.ceil( this.x ) : Math.floor( this.x );\n\t\tthis.y = ( this.y < 0 ) ? Math.ceil( this.y ) : Math.floor( this.y );\n\t\tthis.z = ( this.z < 0 ) ? Math.ceil( this.z ) : Math.floor( this.z );\n\n\t\treturn this;\n\n\t}\n\n\tnegate() {\n\n\t\tthis.x = - this.x;\n\t\tthis.y = - this.y;\n\t\tthis.z = - this.z;\n\n\t\treturn this;\n\n\t}\n\n\tdot( v ) {\n\n\t\treturn this.x * v.x + this.y * v.y + this.z * v.z;\n\n\t}\n\n\t// TODO lengthSquared?\n\n\tlengthSq() {\n\n\t\treturn this.x * this.x + this.y * this.y + this.z * this.z;\n\n\t}\n\n\tlength() {\n\n\t\treturn Math.sqrt( this.x * this.x + this.y * this.y + this.z * this.z );\n\n\t}\n\n\tmanhattanLength() {\n\n\t\treturn Math.abs( this.x ) + Math.abs( this.y ) + Math.abs( this.z );\n\n\t}\n\n\tnormalize() {\n\n\t\treturn this.divideScalar( this.length() || 1 );\n\n\t}\n\n\tsetLength( length ) {\n\n\t\treturn this.normalize().multiplyScalar( length );\n\n\t}\n\n\tlerp( v, alpha ) {\n\n\t\tthis.x += ( v.x - this.x ) * alpha;\n\t\tthis.y += ( v.y - this.y ) * alpha;\n\t\tthis.z += ( v.z - this.z ) * alpha;\n\n\t\treturn this;\n\n\t}\n\n\tlerpVectors( v1, v2, alpha ) {\n\n\t\tthis.x = v1.x + ( v2.x - v1.x ) * alpha;\n\t\tthis.y = v1.y + ( v2.y - v1.y ) * alpha;\n\t\tthis.z = v1.z + ( v2.z - v1.z ) * alpha;\n\n\t\treturn this;\n\n\t}\n\n\tcross( v, w ) {\n\n\t\tif ( w !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead.' );\n\t\t\treturn this.crossVectors( v, w );\n\n\t\t}\n\n\t\treturn this.crossVectors( this, v );\n\n\t}\n\n\tcrossVectors( a, b ) {\n\n\t\tconst ax = a.x, ay = a.y, az = a.z;\n\t\tconst bx = b.x, by = b.y, bz = b.z;\n\n\t\tthis.x = ay * bz - az * by;\n\t\tthis.y = az * bx - ax * bz;\n\t\tthis.z = ax * by - ay * bx;\n\n\t\treturn this;\n\n\t}\n\n\tprojectOnVector( v ) {\n\n\t\tconst denominator = v.lengthSq();\n\n\t\tif ( denominator === 0 ) return this.set( 0, 0, 0 );\n\n\t\tconst scalar = v.dot( this ) / denominator;\n\n\t\treturn this.copy( v ).multiplyScalar( scalar );\n\n\t}\n\n\tprojectOnPlane( planeNormal ) {\n\n\t\t_vector$c.copy( this ).projectOnVector( planeNormal );\n\n\t\treturn this.sub( _vector$c );\n\n\t}\n\n\treflect( normal ) {\n\n\t\t// reflect incident vector off plane orthogonal to normal\n\t\t// normal is assumed to have unit length\n\n\t\treturn this.sub( _vector$c.copy( normal ).multiplyScalar( 2 * this.dot( normal ) ) );\n\n\t}\n\n\tangleTo( v ) {\n\n\t\tconst denominator = Math.sqrt( this.lengthSq() * v.lengthSq() );\n\n\t\tif ( denominator === 0 ) return Math.PI / 2;\n\n\t\tconst theta = this.dot( v ) / denominator;\n\n\t\t// clamp, to handle numerical problems\n\n\t\treturn Math.acos( clamp( theta, - 1, 1 ) );\n\n\t}\n\n\tdistanceTo( v ) {\n\n\t\treturn Math.sqrt( this.distanceToSquared( v ) );\n\n\t}\n\n\tdistanceToSquared( v ) {\n\n\t\tconst dx = this.x - v.x, dy = this.y - v.y, dz = this.z - v.z;\n\n\t\treturn dx * dx + dy * dy + dz * dz;\n\n\t}\n\n\tmanhattanDistanceTo( v ) {\n\n\t\treturn Math.abs( this.x - v.x ) + Math.abs( this.y - v.y ) + Math.abs( this.z - v.z );\n\n\t}\n\n\tsetFromSpherical( s ) {\n\n\t\treturn this.setFromSphericalCoords( s.radius, s.phi, s.theta );\n\n\t}\n\n\tsetFromSphericalCoords( radius, phi, theta ) {\n\n\t\tconst sinPhiRadius = Math.sin( phi ) * radius;\n\n\t\tthis.x = sinPhiRadius * Math.sin( theta );\n\t\tthis.y = Math.cos( phi ) * radius;\n\t\tthis.z = sinPhiRadius * Math.cos( theta );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromCylindrical( c ) {\n\n\t\treturn this.setFromCylindricalCoords( c.radius, c.theta, c.y );\n\n\t}\n\n\tsetFromCylindricalCoords( radius, theta, y ) {\n\n\t\tthis.x = radius * Math.sin( theta );\n\t\tthis.y = y;\n\t\tthis.z = radius * Math.cos( theta );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromMatrixPosition( m ) {\n\n\t\tconst e = m.elements;\n\n\t\tthis.x = e[ 12 ];\n\t\tthis.y = e[ 13 ];\n\t\tthis.z = e[ 14 ];\n\n\t\treturn this;\n\n\t}\n\n\tsetFromMatrixScale( m ) {\n\n\t\tconst sx = this.setFromMatrixColumn( m, 0 ).length();\n\t\tconst sy = this.setFromMatrixColumn( m, 1 ).length();\n\t\tconst sz = this.setFromMatrixColumn( m, 2 ).length();\n\n\t\tthis.x = sx;\n\t\tthis.y = sy;\n\t\tthis.z = sz;\n\n\t\treturn this;\n\n\t}\n\n\tsetFromMatrixColumn( m, index ) {\n\n\t\treturn this.fromArray( m.elements, index * 4 );\n\n\t}\n\n\tsetFromMatrix3Column( m, index ) {\n\n\t\treturn this.fromArray( m.elements, index * 3 );\n\n\t}\n\n\tsetFromEuler( e ) {\n\n\t\tthis.x = e._x;\n\t\tthis.y = e._y;\n\t\tthis.z = e._z;\n\n\t\treturn this;\n\n\t}\n\n\tequals( v ) {\n\n\t\treturn ( ( v.x === this.x ) && ( v.y === this.y ) && ( v.z === this.z ) );\n\n\t}\n\n\tfromArray( array, offset = 0 ) {\n\n\t\tthis.x = array[ offset ];\n\t\tthis.y = array[ offset + 1 ];\n\t\tthis.z = array[ offset + 2 ];\n\n\t\treturn this;\n\n\t}\n\n\ttoArray( array = [], offset = 0 ) {\n\n\t\tarray[ offset ] = this.x;\n\t\tarray[ offset + 1 ] = this.y;\n\t\tarray[ offset + 2 ] = this.z;\n\n\t\treturn array;\n\n\t}\n\n\tfromBufferAttribute( attribute, index, offset ) {\n\n\t\tif ( offset !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Vector3: offset has been removed from .fromBufferAttribute().' );\n\n\t\t}\n\n\t\tthis.x = attribute.getX( index );\n\t\tthis.y = attribute.getY( index );\n\t\tthis.z = attribute.getZ( index );\n\n\t\treturn this;\n\n\t}\n\n\trandom() {\n\n\t\tthis.x = Math.random();\n\t\tthis.y = Math.random();\n\t\tthis.z = Math.random();\n\n\t\treturn this;\n\n\t}\n\n\trandomDirection() {\n\n\t\t// Derived from https://mathworld.wolfram.com/SpherePointPicking.html\n\n\t\tconst u = ( Math.random() - 0.5 ) * 2;\n\t\tconst t = Math.random() * Math.PI * 2;\n\t\tconst f = Math.sqrt( 1 - u ** 2 );\n\n\t\tthis.x = f * Math.cos( t );\n\t\tthis.y = f * Math.sin( t );\n\t\tthis.z = u;\n\n\t\treturn this;\n\n\t}\n\n\t*[ Symbol.iterator ]() {\n\n\t\tyield this.x;\n\t\tyield this.y;\n\t\tyield this.z;\n\n\t}\n\n}\n\nconst _vector$c = /*@__PURE__*/ new Vector3();\nconst _quaternion$4 = /*@__PURE__*/ new Quaternion();\n\nclass Box3 {\n\n\tconstructor( min = new Vector3( + Infinity, + Infinity, + Infinity ), max = new Vector3( - Infinity, - Infinity, - Infinity ) ) {\n\n\t\tthis.isBox3 = true;\n\n\t\tthis.min = min;\n\t\tthis.max = max;\n\n\t}\n\n\tset( min, max ) {\n\n\t\tthis.min.copy( min );\n\t\tthis.max.copy( max );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromArray( array ) {\n\n\t\tlet minX = + Infinity;\n\t\tlet minY = + Infinity;\n\t\tlet minZ = + Infinity;\n\n\t\tlet maxX = - Infinity;\n\t\tlet maxY = - Infinity;\n\t\tlet maxZ = - Infinity;\n\n\t\tfor ( let i = 0, l = array.length; i < l; i += 3 ) {\n\n\t\t\tconst x = array[ i ];\n\t\t\tconst y = array[ i + 1 ];\n\t\t\tconst z = array[ i + 2 ];\n\n\t\t\tif ( x < minX ) minX = x;\n\t\t\tif ( y < minY ) minY = y;\n\t\t\tif ( z < minZ ) minZ = z;\n\n\t\t\tif ( x > maxX ) maxX = x;\n\t\t\tif ( y > maxY ) maxY = y;\n\t\t\tif ( z > maxZ ) maxZ = z;\n\n\t\t}\n\n\t\tthis.min.set( minX, minY, minZ );\n\t\tthis.max.set( maxX, maxY, maxZ );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromBufferAttribute( attribute ) {\n\n\t\tlet minX = + Infinity;\n\t\tlet minY = + Infinity;\n\t\tlet minZ = + Infinity;\n\n\t\tlet maxX = - Infinity;\n\t\tlet maxY = - Infinity;\n\t\tlet maxZ = - Infinity;\n\n\t\tfor ( let i = 0, l = attribute.count; i < l; i ++ ) {\n\n\t\t\tconst x = attribute.getX( i );\n\t\t\tconst y = attribute.getY( i );\n\t\t\tconst z = attribute.getZ( i );\n\n\t\t\tif ( x < minX ) minX = x;\n\t\t\tif ( y < minY ) minY = y;\n\t\t\tif ( z < minZ ) minZ = z;\n\n\t\t\tif ( x > maxX ) maxX = x;\n\t\t\tif ( y > maxY ) maxY = y;\n\t\t\tif ( z > maxZ ) maxZ = z;\n\n\t\t}\n\n\t\tthis.min.set( minX, minY, minZ );\n\t\tthis.max.set( maxX, maxY, maxZ );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromPoints( points ) {\n\n\t\tthis.makeEmpty();\n\n\t\tfor ( let i = 0, il = points.length; i < il; i ++ ) {\n\n\t\t\tthis.expandByPoint( points[ i ] );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tsetFromCenterAndSize( center, size ) {\n\n\t\tconst halfSize = _vector$b.copy( size ).multiplyScalar( 0.5 );\n\n\t\tthis.min.copy( center ).sub( halfSize );\n\t\tthis.max.copy( center ).add( halfSize );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromObject( object, precise = false ) {\n\n\t\tthis.makeEmpty();\n\n\t\treturn this.expandByObject( object, precise );\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n\tcopy( box ) {\n\n\t\tthis.min.copy( box.min );\n\t\tthis.max.copy( box.max );\n\n\t\treturn this;\n\n\t}\n\n\tmakeEmpty() {\n\n\t\tthis.min.x = this.min.y = this.min.z = + Infinity;\n\t\tthis.max.x = this.max.y = this.max.z = - Infinity;\n\n\t\treturn this;\n\n\t}\n\n\tisEmpty() {\n\n\t\t// this is a more robust check for empty than ( volume <= 0 ) because volume can get positive with two negative axes\n\n\t\treturn ( this.max.x < this.min.x ) || ( this.max.y < this.min.y ) || ( this.max.z < this.min.z );\n\n\t}\n\n\tgetCenter( target ) {\n\n\t\treturn this.isEmpty() ? target.set( 0, 0, 0 ) : target.addVectors( this.min, this.max ).multiplyScalar( 0.5 );\n\n\t}\n\n\tgetSize( target ) {\n\n\t\treturn this.isEmpty() ? target.set( 0, 0, 0 ) : target.subVectors( this.max, this.min );\n\n\t}\n\n\texpandByPoint( point ) {\n\n\t\tthis.min.min( point );\n\t\tthis.max.max( point );\n\n\t\treturn this;\n\n\t}\n\n\texpandByVector( vector ) {\n\n\t\tthis.min.sub( vector );\n\t\tthis.max.add( vector );\n\n\t\treturn this;\n\n\t}\n\n\texpandByScalar( scalar ) {\n\n\t\tthis.min.addScalar( - scalar );\n\t\tthis.max.addScalar( scalar );\n\n\t\treturn this;\n\n\t}\n\n\texpandByObject( object, precise = false ) {\n\n\t\t// Computes the world-axis-aligned bounding box of an object (including its children),\n\t\t// accounting for both the object's, and children's, world transforms\n\n\t\tobject.updateWorldMatrix( false, false );\n\n\t\tconst geometry = object.geometry;\n\n\t\tif ( geometry !== undefined ) {\n\n\t\t\tif ( precise && geometry.attributes != undefined && geometry.attributes.position !== undefined ) {\n\n\t\t\t\tconst position = geometry.attributes.position;\n\t\t\t\tfor ( let i = 0, l = position.count; i < l; i ++ ) {\n\n\t\t\t\t\t_vector$b.fromBufferAttribute( position, i ).applyMatrix4( object.matrixWorld );\n\t\t\t\t\tthis.expandByPoint( _vector$b );\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tif ( geometry.boundingBox === null ) {\n\n\t\t\t\t\tgeometry.computeBoundingBox();\n\n\t\t\t\t}\n\n\t\t\t\t_box$3.copy( geometry.boundingBox );\n\t\t\t\t_box$3.applyMatrix4( object.matrixWorld );\n\n\t\t\t\tthis.union( _box$3 );\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst children = object.children;\n\n\t\tfor ( let i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\tthis.expandByObject( children[ i ], precise );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tcontainsPoint( point ) {\n\n\t\treturn point.x < this.min.x || point.x > this.max.x ||\n\t\t\tpoint.y < this.min.y || point.y > this.max.y ||\n\t\t\tpoint.z < this.min.z || point.z > this.max.z ? false : true;\n\n\t}\n\n\tcontainsBox( box ) {\n\n\t\treturn this.min.x <= box.min.x && box.max.x <= this.max.x &&\n\t\t\tthis.min.y <= box.min.y && box.max.y <= this.max.y &&\n\t\t\tthis.min.z <= box.min.z && box.max.z <= this.max.z;\n\n\t}\n\n\tgetParameter( point, target ) {\n\n\t\t// This can potentially have a divide by zero if the box\n\t\t// has a size dimension of 0.\n\n\t\treturn target.set(\n\t\t\t( point.x - this.min.x ) / ( this.max.x - this.min.x ),\n\t\t\t( point.y - this.min.y ) / ( this.max.y - this.min.y ),\n\t\t\t( point.z - this.min.z ) / ( this.max.z - this.min.z )\n\t\t);\n\n\t}\n\n\tintersectsBox( box ) {\n\n\t\t// using 6 splitting planes to rule out intersections.\n\t\treturn box.max.x < this.min.x || box.min.x > this.max.x ||\n\t\t\tbox.max.y < this.min.y || box.min.y > this.max.y ||\n\t\t\tbox.max.z < this.min.z || box.min.z > this.max.z ? false : true;\n\n\t}\n\n\tintersectsSphere( sphere ) {\n\n\t\t// Find the point on the AABB closest to the sphere center.\n\t\tthis.clampPoint( sphere.center, _vector$b );\n\n\t\t// If that point is inside the sphere, the AABB and sphere intersect.\n\t\treturn _vector$b.distanceToSquared( sphere.center ) <= ( sphere.radius * sphere.radius );\n\n\t}\n\n\tintersectsPlane( plane ) {\n\n\t\t// We compute the minimum and maximum dot product values. If those values\n\t\t// are on the same side (back or front) of the plane, then there is no intersection.\n\n\t\tlet min, max;\n\n\t\tif ( plane.normal.x > 0 ) {\n\n\t\t\tmin = plane.normal.x * this.min.x;\n\t\t\tmax = plane.normal.x * this.max.x;\n\n\t\t} else {\n\n\t\t\tmin = plane.normal.x * this.max.x;\n\t\t\tmax = plane.normal.x * this.min.x;\n\n\t\t}\n\n\t\tif ( plane.normal.y > 0 ) {\n\n\t\t\tmin += plane.normal.y * this.min.y;\n\t\t\tmax += plane.normal.y * this.max.y;\n\n\t\t} else {\n\n\t\t\tmin += plane.normal.y * this.max.y;\n\t\t\tmax += plane.normal.y * this.min.y;\n\n\t\t}\n\n\t\tif ( plane.normal.z > 0 ) {\n\n\t\t\tmin += plane.normal.z * this.min.z;\n\t\t\tmax += plane.normal.z * this.max.z;\n\n\t\t} else {\n\n\t\t\tmin += plane.normal.z * this.max.z;\n\t\t\tmax += plane.normal.z * this.min.z;\n\n\t\t}\n\n\t\treturn ( min <= - plane.constant && max >= - plane.constant );\n\n\t}\n\n\tintersectsTriangle( triangle ) {\n\n\t\tif ( this.isEmpty() ) {\n\n\t\t\treturn false;\n\n\t\t}\n\n\t\t// compute box center and extents\n\t\tthis.getCenter( _center );\n\t\t_extents.subVectors( this.max, _center );\n\n\t\t// translate triangle to aabb origin\n\t\t_v0$2.subVectors( triangle.a, _center );\n\t\t_v1$7.subVectors( triangle.b, _center );\n\t\t_v2$3.subVectors( triangle.c, _center );\n\n\t\t// compute edge vectors for triangle\n\t\t_f0.subVectors( _v1$7, _v0$2 );\n\t\t_f1.subVectors( _v2$3, _v1$7 );\n\t\t_f2.subVectors( _v0$2, _v2$3 );\n\n\t\t// test against axes that are given by cross product combinations of the edges of the triangle and the edges of the aabb\n\t\t// make an axis testing of each of the 3 sides of the aabb against each of the 3 sides of the triangle = 9 axis of separation\n\t\t// axis_ij = u_i x f_j (u0, u1, u2 = face normals of aabb = x,y,z axes vectors since aabb is axis aligned)\n\t\tlet axes = [\n\t\t\t0, - _f0.z, _f0.y, 0, - _f1.z, _f1.y, 0, - _f2.z, _f2.y,\n\t\t\t_f0.z, 0, - _f0.x, _f1.z, 0, - _f1.x, _f2.z, 0, - _f2.x,\n\t\t\t- _f0.y, _f0.x, 0, - _f1.y, _f1.x, 0, - _f2.y, _f2.x, 0\n\t\t];\n\t\tif ( ! satForAxes( axes, _v0$2, _v1$7, _v2$3, _extents ) ) {\n\n\t\t\treturn false;\n\n\t\t}\n\n\t\t// test 3 face normals from the aabb\n\t\taxes = [ 1, 0, 0, 0, 1, 0, 0, 0, 1 ];\n\t\tif ( ! satForAxes( axes, _v0$2, _v1$7, _v2$3, _extents ) ) {\n\n\t\t\treturn false;\n\n\t\t}\n\n\t\t// finally testing the face normal of the triangle\n\t\t// use already existing triangle edge vectors here\n\t\t_triangleNormal.crossVectors( _f0, _f1 );\n\t\taxes = [ _triangleNormal.x, _triangleNormal.y, _triangleNormal.z ];\n\n\t\treturn satForAxes( axes, _v0$2, _v1$7, _v2$3, _extents );\n\n\t}\n\n\tclampPoint( point, target ) {\n\n\t\treturn target.copy( point ).clamp( this.min, this.max );\n\n\t}\n\n\tdistanceToPoint( point ) {\n\n\t\tconst clampedPoint = _vector$b.copy( point ).clamp( this.min, this.max );\n\n\t\treturn clampedPoint.sub( point ).length();\n\n\t}\n\n\tgetBoundingSphere( target ) {\n\n\t\tthis.getCenter( target.center );\n\n\t\ttarget.radius = this.getSize( _vector$b ).length() * 0.5;\n\n\t\treturn target;\n\n\t}\n\n\tintersect( box ) {\n\n\t\tthis.min.max( box.min );\n\t\tthis.max.min( box.max );\n\n\t\t// ensure that if there is no overlap, the result is fully empty, not slightly empty with non-inf/+inf values that will cause subsequence intersects to erroneously return valid values.\n\t\tif ( this.isEmpty() ) this.makeEmpty();\n\n\t\treturn this;\n\n\t}\n\n\tunion( box ) {\n\n\t\tthis.min.min( box.min );\n\t\tthis.max.max( box.max );\n\n\t\treturn this;\n\n\t}\n\n\tapplyMatrix4( matrix ) {\n\n\t\t// transform of empty box is an empty box.\n\t\tif ( this.isEmpty() ) return this;\n\n\t\t// NOTE: I am using a binary pattern to specify all 2^3 combinations below\n\t\t_points[ 0 ].set( this.min.x, this.min.y, this.min.z ).applyMatrix4( matrix ); // 000\n\t\t_points[ 1 ].set( this.min.x, this.min.y, this.max.z ).applyMatrix4( matrix ); // 001\n\t\t_points[ 2 ].set( this.min.x, this.max.y, this.min.z ).applyMatrix4( matrix ); // 010\n\t\t_points[ 3 ].set( this.min.x, this.max.y, this.max.z ).applyMatrix4( matrix ); // 011\n\t\t_points[ 4 ].set( this.max.x, this.min.y, this.min.z ).applyMatrix4( matrix ); // 100\n\t\t_points[ 5 ].set( this.max.x, this.min.y, this.max.z ).applyMatrix4( matrix ); // 101\n\t\t_points[ 6 ].set( this.max.x, this.max.y, this.min.z ).applyMatrix4( matrix ); // 110\n\t\t_points[ 7 ].set( this.max.x, this.max.y, this.max.z ).applyMatrix4( matrix ); // 111\n\n\t\tthis.setFromPoints( _points );\n\n\t\treturn this;\n\n\t}\n\n\ttranslate( offset ) {\n\n\t\tthis.min.add( offset );\n\t\tthis.max.add( offset );\n\n\t\treturn this;\n\n\t}\n\n\tequals( box ) {\n\n\t\treturn box.min.equals( this.min ) && box.max.equals( this.max );\n\n\t}\n\n}\n\nconst _points = [\n\t/*@__PURE__*/ new Vector3(),\n\t/*@__PURE__*/ new Vector3(),\n\t/*@__PURE__*/ new Vector3(),\n\t/*@__PURE__*/ new Vector3(),\n\t/*@__PURE__*/ new Vector3(),\n\t/*@__PURE__*/ new Vector3(),\n\t/*@__PURE__*/ new Vector3(),\n\t/*@__PURE__*/ new Vector3()\n];\n\nconst _vector$b = /*@__PURE__*/ new Vector3();\n\nconst _box$3 = /*@__PURE__*/ new Box3();\n\n// triangle centered vertices\n\nconst _v0$2 = /*@__PURE__*/ new Vector3();\nconst _v1$7 = /*@__PURE__*/ new Vector3();\nconst _v2$3 = /*@__PURE__*/ new Vector3();\n\n// triangle edge vectors\n\nconst _f0 = /*@__PURE__*/ new Vector3();\nconst _f1 = /*@__PURE__*/ new Vector3();\nconst _f2 = /*@__PURE__*/ new Vector3();\n\nconst _center = /*@__PURE__*/ new Vector3();\nconst _extents = /*@__PURE__*/ new Vector3();\nconst _triangleNormal = /*@__PURE__*/ new Vector3();\nconst _testAxis = /*@__PURE__*/ new Vector3();\n\nfunction satForAxes( axes, v0, v1, v2, extents ) {\n\n\tfor ( let i = 0, j = axes.length - 3; i <= j; i += 3 ) {\n\n\t\t_testAxis.fromArray( axes, i );\n\t\t// project the aabb onto the separating axis\n\t\tconst r = extents.x * Math.abs( _testAxis.x ) + extents.y * Math.abs( _testAxis.y ) + extents.z * Math.abs( _testAxis.z );\n\t\t// project all 3 vertices of the triangle onto the separating axis\n\t\tconst p0 = v0.dot( _testAxis );\n\t\tconst p1 = v1.dot( _testAxis );\n\t\tconst p2 = v2.dot( _testAxis );\n\t\t// actual test, basically see if either of the most extreme of the triangle points intersects r\n\t\tif ( Math.max( - Math.max( p0, p1, p2 ), Math.min( p0, p1, p2 ) ) > r ) {\n\n\t\t\t// points of the projected triangle are outside the projected half-length of the aabb\n\t\t\t// the axis is separating and we can exit\n\t\t\treturn false;\n\n\t\t}\n\n\t}\n\n\treturn true;\n\n}\n\nconst _box$2 = /*@__PURE__*/ new Box3();\nconst _v1$6 = /*@__PURE__*/ new Vector3();\nconst _toFarthestPoint = /*@__PURE__*/ new Vector3();\nconst _toPoint = /*@__PURE__*/ new Vector3();\n\nclass Sphere {\n\n\tconstructor( center = new Vector3(), radius = - 1 ) {\n\n\t\tthis.center = center;\n\t\tthis.radius = radius;\n\n\t}\n\n\tset( center, radius ) {\n\n\t\tthis.center.copy( center );\n\t\tthis.radius = radius;\n\n\t\treturn this;\n\n\t}\n\n\tsetFromPoints( points, optionalCenter ) {\n\n\t\tconst center = this.center;\n\n\t\tif ( optionalCenter !== undefined ) {\n\n\t\t\tcenter.copy( optionalCenter );\n\n\t\t} else {\n\n\t\t\t_box$2.setFromPoints( points ).getCenter( center );\n\n\t\t}\n\n\t\tlet maxRadiusSq = 0;\n\n\t\tfor ( let i = 0, il = points.length; i < il; i ++ ) {\n\n\t\t\tmaxRadiusSq = Math.max( maxRadiusSq, center.distanceToSquared( points[ i ] ) );\n\n\t\t}\n\n\t\tthis.radius = Math.sqrt( maxRadiusSq );\n\n\t\treturn this;\n\n\t}\n\n\tcopy( sphere ) {\n\n\t\tthis.center.copy( sphere.center );\n\t\tthis.radius = sphere.radius;\n\n\t\treturn this;\n\n\t}\n\n\tisEmpty() {\n\n\t\treturn ( this.radius < 0 );\n\n\t}\n\n\tmakeEmpty() {\n\n\t\tthis.center.set( 0, 0, 0 );\n\t\tthis.radius = - 1;\n\n\t\treturn this;\n\n\t}\n\n\tcontainsPoint( point ) {\n\n\t\treturn ( point.distanceToSquared( this.center ) <= ( this.radius * this.radius ) );\n\n\t}\n\n\tdistanceToPoint( point ) {\n\n\t\treturn ( point.distanceTo( this.center ) - this.radius );\n\n\t}\n\n\tintersectsSphere( sphere ) {\n\n\t\tconst radiusSum = this.radius + sphere.radius;\n\n\t\treturn sphere.center.distanceToSquared( this.center ) <= ( radiusSum * radiusSum );\n\n\t}\n\n\tintersectsBox( box ) {\n\n\t\treturn box.intersectsSphere( this );\n\n\t}\n\n\tintersectsPlane( plane ) {\n\n\t\treturn Math.abs( plane.distanceToPoint( this.center ) ) <= this.radius;\n\n\t}\n\n\tclampPoint( point, target ) {\n\n\t\tconst deltaLengthSq = this.center.distanceToSquared( point );\n\n\t\ttarget.copy( point );\n\n\t\tif ( deltaLengthSq > ( this.radius * this.radius ) ) {\n\n\t\t\ttarget.sub( this.center ).normalize();\n\t\t\ttarget.multiplyScalar( this.radius ).add( this.center );\n\n\t\t}\n\n\t\treturn target;\n\n\t}\n\n\tgetBoundingBox( target ) {\n\n\t\tif ( this.isEmpty() ) {\n\n\t\t\t// Empty sphere produces empty bounding box\n\t\t\ttarget.makeEmpty();\n\t\t\treturn target;\n\n\t\t}\n\n\t\ttarget.set( this.center, this.center );\n\t\ttarget.expandByScalar( this.radius );\n\n\t\treturn target;\n\n\t}\n\n\tapplyMatrix4( matrix ) {\n\n\t\tthis.center.applyMatrix4( matrix );\n\t\tthis.radius = this.radius * matrix.getMaxScaleOnAxis();\n\n\t\treturn this;\n\n\t}\n\n\ttranslate( offset ) {\n\n\t\tthis.center.add( offset );\n\n\t\treturn this;\n\n\t}\n\n\texpandByPoint( point ) {\n\n\t\t// from https://github.com/juj/MathGeoLib/blob/2940b99b99cfe575dd45103ef20f4019dee15b54/src/Geometry/Sphere.cpp#L649-L671\n\n\t\t_toPoint.subVectors( point, this.center );\n\n\t\tconst lengthSq = _toPoint.lengthSq();\n\n\t\tif ( lengthSq > ( this.radius * this.radius ) ) {\n\n\t\t\tconst length = Math.sqrt( lengthSq );\n\t\t\tconst missingRadiusHalf = ( length - this.radius ) * 0.5;\n\n\t\t\t// Nudge this sphere towards the target point. Add half the missing distance to radius,\n\t\t\t// and the other half to position. This gives a tighter enclosure, instead of if\n\t\t\t// the whole missing distance were just added to radius.\n\n\t\t\tthis.center.add( _toPoint.multiplyScalar( missingRadiusHalf / length ) );\n\t\t\tthis.radius += missingRadiusHalf;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tunion( sphere ) {\n\n\t\t// from https://github.com/juj/MathGeoLib/blob/2940b99b99cfe575dd45103ef20f4019dee15b54/src/Geometry/Sphere.cpp#L759-L769\n\n\t\t// To enclose another sphere into this sphere, we only need to enclose two points:\n\t\t// 1) Enclose the farthest point on the other sphere into this sphere.\n\t\t// 2) Enclose the opposite point of the farthest point into this sphere.\n\n\t\t if ( this.center.equals( sphere.center ) === true ) {\n\n\t\t\t _toFarthestPoint.set( 0, 0, 1 ).multiplyScalar( sphere.radius );\n\n\n\t\t} else {\n\n\t\t\t_toFarthestPoint.subVectors( sphere.center, this.center ).normalize().multiplyScalar( sphere.radius );\n\n\t\t}\n\n\t\tthis.expandByPoint( _v1$6.copy( sphere.center ).add( _toFarthestPoint ) );\n\t\tthis.expandByPoint( _v1$6.copy( sphere.center ).sub( _toFarthestPoint ) );\n\n\t\treturn this;\n\n\t}\n\n\tequals( sphere ) {\n\n\t\treturn sphere.center.equals( this.center ) && ( sphere.radius === this.radius );\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n}\n\nconst _vector$a = /*@__PURE__*/ new Vector3();\nconst _segCenter = /*@__PURE__*/ new Vector3();\nconst _segDir = /*@__PURE__*/ new Vector3();\nconst _diff = /*@__PURE__*/ new Vector3();\n\nconst _edge1 = /*@__PURE__*/ new Vector3();\nconst _edge2 = /*@__PURE__*/ new Vector3();\nconst _normal$1 = /*@__PURE__*/ new Vector3();\n\nclass Ray {\n\n\tconstructor( origin = new Vector3(), direction = new Vector3( 0, 0, - 1 ) ) {\n\n\t\tthis.origin = origin;\n\t\tthis.direction = direction;\n\n\t}\n\n\tset( origin, direction ) {\n\n\t\tthis.origin.copy( origin );\n\t\tthis.direction.copy( direction );\n\n\t\treturn this;\n\n\t}\n\n\tcopy( ray ) {\n\n\t\tthis.origin.copy( ray.origin );\n\t\tthis.direction.copy( ray.direction );\n\n\t\treturn this;\n\n\t}\n\n\tat( t, target ) {\n\n\t\treturn target.copy( this.direction ).multiplyScalar( t ).add( this.origin );\n\n\t}\n\n\tlookAt( v ) {\n\n\t\tthis.direction.copy( v ).sub( this.origin ).normalize();\n\n\t\treturn this;\n\n\t}\n\n\trecast( t ) {\n\n\t\tthis.origin.copy( this.at( t, _vector$a ) );\n\n\t\treturn this;\n\n\t}\n\n\tclosestPointToPoint( point, target ) {\n\n\t\ttarget.subVectors( point, this.origin );\n\n\t\tconst directionDistance = target.dot( this.direction );\n\n\t\tif ( directionDistance < 0 ) {\n\n\t\t\treturn target.copy( this.origin );\n\n\t\t}\n\n\t\treturn target.copy( this.direction ).multiplyScalar( directionDistance ).add( this.origin );\n\n\t}\n\n\tdistanceToPoint( point ) {\n\n\t\treturn Math.sqrt( this.distanceSqToPoint( point ) );\n\n\t}\n\n\tdistanceSqToPoint( point ) {\n\n\t\tconst directionDistance = _vector$a.subVectors( point, this.origin ).dot( this.direction );\n\n\t\t// point behind the ray\n\n\t\tif ( directionDistance < 0 ) {\n\n\t\t\treturn this.origin.distanceToSquared( point );\n\n\t\t}\n\n\t\t_vector$a.copy( this.direction ).multiplyScalar( directionDistance ).add( this.origin );\n\n\t\treturn _vector$a.distanceToSquared( point );\n\n\t}\n\n\tdistanceSqToSegment( v0, v1, optionalPointOnRay, optionalPointOnSegment ) {\n\n\t\t// from https://github.com/pmjoniak/GeometricTools/blob/master/GTEngine/Include/Mathematics/GteDistRaySegment.h\n\t\t// It returns the min distance between the ray and the segment\n\t\t// defined by v0 and v1\n\t\t// It can also set two optional targets :\n\t\t// - The closest point on the ray\n\t\t// - The closest point on the segment\n\n\t\t_segCenter.copy( v0 ).add( v1 ).multiplyScalar( 0.5 );\n\t\t_segDir.copy( v1 ).sub( v0 ).normalize();\n\t\t_diff.copy( this.origin ).sub( _segCenter );\n\n\t\tconst segExtent = v0.distanceTo( v1 ) * 0.5;\n\t\tconst a01 = - this.direction.dot( _segDir );\n\t\tconst b0 = _diff.dot( this.direction );\n\t\tconst b1 = - _diff.dot( _segDir );\n\t\tconst c = _diff.lengthSq();\n\t\tconst det = Math.abs( 1 - a01 * a01 );\n\t\tlet s0, s1, sqrDist, extDet;\n\n\t\tif ( det > 0 ) {\n\n\t\t\t// The ray and segment are not parallel.\n\n\t\t\ts0 = a01 * b1 - b0;\n\t\t\ts1 = a01 * b0 - b1;\n\t\t\textDet = segExtent * det;\n\n\t\t\tif ( s0 >= 0 ) {\n\n\t\t\t\tif ( s1 >= - extDet ) {\n\n\t\t\t\t\tif ( s1 <= extDet ) {\n\n\t\t\t\t\t\t// region 0\n\t\t\t\t\t\t// Minimum at interior points of ray and segment.\n\n\t\t\t\t\t\tconst invDet = 1 / det;\n\t\t\t\t\t\ts0 *= invDet;\n\t\t\t\t\t\ts1 *= invDet;\n\t\t\t\t\t\tsqrDist = s0 * ( s0 + a01 * s1 + 2 * b0 ) + s1 * ( a01 * s0 + s1 + 2 * b1 ) + c;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// region 1\n\n\t\t\t\t\t\ts1 = segExtent;\n\t\t\t\t\t\ts0 = Math.max( 0, - ( a01 * s1 + b0 ) );\n\t\t\t\t\t\tsqrDist = - s0 * s0 + s1 * ( s1 + 2 * b1 ) + c;\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// region 5\n\n\t\t\t\t\ts1 = - segExtent;\n\t\t\t\t\ts0 = Math.max( 0, - ( a01 * s1 + b0 ) );\n\t\t\t\t\tsqrDist = - s0 * s0 + s1 * ( s1 + 2 * b1 ) + c;\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tif ( s1 <= - extDet ) {\n\n\t\t\t\t\t// region 4\n\n\t\t\t\t\ts0 = Math.max( 0, - ( - a01 * segExtent + b0 ) );\n\t\t\t\t\ts1 = ( s0 > 0 ) ? - segExtent : Math.min( Math.max( - segExtent, - b1 ), segExtent );\n\t\t\t\t\tsqrDist = - s0 * s0 + s1 * ( s1 + 2 * b1 ) + c;\n\n\t\t\t\t} else if ( s1 <= extDet ) {\n\n\t\t\t\t\t// region 3\n\n\t\t\t\t\ts0 = 0;\n\t\t\t\t\ts1 = Math.min( Math.max( - segExtent, - b1 ), segExtent );\n\t\t\t\t\tsqrDist = s1 * ( s1 + 2 * b1 ) + c;\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// region 2\n\n\t\t\t\t\ts0 = Math.max( 0, - ( a01 * segExtent + b0 ) );\n\t\t\t\t\ts1 = ( s0 > 0 ) ? segExtent : Math.min( Math.max( - segExtent, - b1 ), segExtent );\n\t\t\t\t\tsqrDist = - s0 * s0 + s1 * ( s1 + 2 * b1 ) + c;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t// Ray and segment are parallel.\n\n\t\t\ts1 = ( a01 > 0 ) ? - segExtent : segExtent;\n\t\t\ts0 = Math.max( 0, - ( a01 * s1 + b0 ) );\n\t\t\tsqrDist = - s0 * s0 + s1 * ( s1 + 2 * b1 ) + c;\n\n\t\t}\n\n\t\tif ( optionalPointOnRay ) {\n\n\t\t\toptionalPointOnRay.copy( this.direction ).multiplyScalar( s0 ).add( this.origin );\n\n\t\t}\n\n\t\tif ( optionalPointOnSegment ) {\n\n\t\t\toptionalPointOnSegment.copy( _segDir ).multiplyScalar( s1 ).add( _segCenter );\n\n\t\t}\n\n\t\treturn sqrDist;\n\n\t}\n\n\tintersectSphere( sphere, target ) {\n\n\t\t_vector$a.subVectors( sphere.center, this.origin );\n\t\tconst tca = _vector$a.dot( this.direction );\n\t\tconst d2 = _vector$a.dot( _vector$a ) - tca * tca;\n\t\tconst radius2 = sphere.radius * sphere.radius;\n\n\t\tif ( d2 > radius2 ) return null;\n\n\t\tconst thc = Math.sqrt( radius2 - d2 );\n\n\t\t// t0 = first intersect point - entrance on front of sphere\n\t\tconst t0 = tca - thc;\n\n\t\t// t1 = second intersect point - exit point on back of sphere\n\t\tconst t1 = tca + thc;\n\n\t\t// test to see if both t0 and t1 are behind the ray - if so, return null\n\t\tif ( t0 < 0 && t1 < 0 ) return null;\n\n\t\t// test to see if t0 is behind the ray:\n\t\t// if it is, the ray is inside the sphere, so return the second exit point scaled by t1,\n\t\t// in order to always return an intersect point that is in front of the ray.\n\t\tif ( t0 < 0 ) return this.at( t1, target );\n\n\t\t// else t0 is in front of the ray, so return the first collision point scaled by t0\n\t\treturn this.at( t0, target );\n\n\t}\n\n\tintersectsSphere( sphere ) {\n\n\t\treturn this.distanceSqToPoint( sphere.center ) <= ( sphere.radius * sphere.radius );\n\n\t}\n\n\tdistanceToPlane( plane ) {\n\n\t\tconst denominator = plane.normal.dot( this.direction );\n\n\t\tif ( denominator === 0 ) {\n\n\t\t\t// line is coplanar, return origin\n\t\t\tif ( plane.distanceToPoint( this.origin ) === 0 ) {\n\n\t\t\t\treturn 0;\n\n\t\t\t}\n\n\t\t\t// Null is preferable to undefined since undefined means.... it is undefined\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\tconst t = - ( this.origin.dot( plane.normal ) + plane.constant ) / denominator;\n\n\t\t// Return if the ray never intersects the plane\n\n\t\treturn t >= 0 ? t : null;\n\n\t}\n\n\tintersectPlane( plane, target ) {\n\n\t\tconst t = this.distanceToPlane( plane );\n\n\t\tif ( t === null ) {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\treturn this.at( t, target );\n\n\t}\n\n\tintersectsPlane( plane ) {\n\n\t\t// check if the ray lies on the plane first\n\n\t\tconst distToPoint = plane.distanceToPoint( this.origin );\n\n\t\tif ( distToPoint === 0 ) {\n\n\t\t\treturn true;\n\n\t\t}\n\n\t\tconst denominator = plane.normal.dot( this.direction );\n\n\t\tif ( denominator * distToPoint < 0 ) {\n\n\t\t\treturn true;\n\n\t\t}\n\n\t\t// ray origin is behind the plane (and is pointing behind it)\n\n\t\treturn false;\n\n\t}\n\n\tintersectBox( box, target ) {\n\n\t\tlet tmin, tmax, tymin, tymax, tzmin, tzmax;\n\n\t\tconst invdirx = 1 / this.direction.x,\n\t\t\tinvdiry = 1 / this.direction.y,\n\t\t\tinvdirz = 1 / this.direction.z;\n\n\t\tconst origin = this.origin;\n\n\t\tif ( invdirx >= 0 ) {\n\n\t\t\ttmin = ( box.min.x - origin.x ) * invdirx;\n\t\t\ttmax = ( box.max.x - origin.x ) * invdirx;\n\n\t\t} else {\n\n\t\t\ttmin = ( box.max.x - origin.x ) * invdirx;\n\t\t\ttmax = ( box.min.x - origin.x ) * invdirx;\n\n\t\t}\n\n\t\tif ( invdiry >= 0 ) {\n\n\t\t\ttymin = ( box.min.y - origin.y ) * invdiry;\n\t\t\ttymax = ( box.max.y - origin.y ) * invdiry;\n\n\t\t} else {\n\n\t\t\ttymin = ( box.max.y - origin.y ) * invdiry;\n\t\t\ttymax = ( box.min.y - origin.y ) * invdiry;\n\n\t\t}\n\n\t\tif ( ( tmin > tymax ) || ( tymin > tmax ) ) return null;\n\n\t\t// These lines also handle the case where tmin or tmax is NaN\n\t\t// (result of 0 * Infinity). x !== x returns true if x is NaN\n\n\t\tif ( tymin > tmin || tmin !== tmin ) tmin = tymin;\n\n\t\tif ( tymax < tmax || tmax !== tmax ) tmax = tymax;\n\n\t\tif ( invdirz >= 0 ) {\n\n\t\t\ttzmin = ( box.min.z - origin.z ) * invdirz;\n\t\t\ttzmax = ( box.max.z - origin.z ) * invdirz;\n\n\t\t} else {\n\n\t\t\ttzmin = ( box.max.z - origin.z ) * invdirz;\n\t\t\ttzmax = ( box.min.z - origin.z ) * invdirz;\n\n\t\t}\n\n\t\tif ( ( tmin > tzmax ) || ( tzmin > tmax ) ) return null;\n\n\t\tif ( tzmin > tmin || tmin !== tmin ) tmin = tzmin;\n\n\t\tif ( tzmax < tmax || tmax !== tmax ) tmax = tzmax;\n\n\t\t//return point closest to the ray (positive side)\n\n\t\tif ( tmax < 0 ) return null;\n\n\t\treturn this.at( tmin >= 0 ? tmin : tmax, target );\n\n\t}\n\n\tintersectsBox( box ) {\n\n\t\treturn this.intersectBox( box, _vector$a ) !== null;\n\n\t}\n\n\tintersectTriangle( a, b, c, backfaceCulling, target ) {\n\n\t\t// Compute the offset origin, edges, and normal.\n\n\t\t// from https://github.com/pmjoniak/GeometricTools/blob/master/GTEngine/Include/Mathematics/GteIntrRay3Triangle3.h\n\n\t\t_edge1.subVectors( b, a );\n\t\t_edge2.subVectors( c, a );\n\t\t_normal$1.crossVectors( _edge1, _edge2 );\n\n\t\t// Solve Q + t*D = b1*E1 + b2*E2 (Q = kDiff, D = ray direction,\n\t\t// E1 = kEdge1, E2 = kEdge2, N = Cross(E1,E2)) by\n\t\t// |Dot(D,N)|*b1 = sign(Dot(D,N))*Dot(D,Cross(Q,E2))\n\t\t// |Dot(D,N)|*b2 = sign(Dot(D,N))*Dot(D,Cross(E1,Q))\n\t\t// |Dot(D,N)|*t = -sign(Dot(D,N))*Dot(Q,N)\n\t\tlet DdN = this.direction.dot( _normal$1 );\n\t\tlet sign;\n\n\t\tif ( DdN > 0 ) {\n\n\t\t\tif ( backfaceCulling ) return null;\n\t\t\tsign = 1;\n\n\t\t} else if ( DdN < 0 ) {\n\n\t\t\tsign = - 1;\n\t\t\tDdN = - DdN;\n\n\t\t} else {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\t_diff.subVectors( this.origin, a );\n\t\tconst DdQxE2 = sign * this.direction.dot( _edge2.crossVectors( _diff, _edge2 ) );\n\n\t\t// b1 < 0, no intersection\n\t\tif ( DdQxE2 < 0 ) {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\tconst DdE1xQ = sign * this.direction.dot( _edge1.cross( _diff ) );\n\n\t\t// b2 < 0, no intersection\n\t\tif ( DdE1xQ < 0 ) {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\t// b1+b2 > 1, no intersection\n\t\tif ( DdQxE2 + DdE1xQ > DdN ) {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\t// Line intersects triangle, check if ray does.\n\t\tconst QdN = - sign * _diff.dot( _normal$1 );\n\n\t\t// t < 0, no intersection\n\t\tif ( QdN < 0 ) {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\t// Ray intersects triangle.\n\t\treturn this.at( QdN / DdN, target );\n\n\t}\n\n\tapplyMatrix4( matrix4 ) {\n\n\t\tthis.origin.applyMatrix4( matrix4 );\n\t\tthis.direction.transformDirection( matrix4 );\n\n\t\treturn this;\n\n\t}\n\n\tequals( ray ) {\n\n\t\treturn ray.origin.equals( this.origin ) && ray.direction.equals( this.direction );\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n}\n\nclass Matrix4 {\n\n\tconstructor() {\n\n\t\tthis.isMatrix4 = true;\n\n\t\tthis.elements = [\n\n\t\t\t1, 0, 0, 0,\n\t\t\t0, 1, 0, 0,\n\t\t\t0, 0, 1, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t];\n\n\t\tif ( arguments.length > 0 ) {\n\n\t\t\tconsole.error( 'THREE.Matrix4: the constructor no longer reads arguments. use .set() instead.' );\n\n\t\t}\n\n\t}\n\n\tset( n11, n12, n13, n14, n21, n22, n23, n24, n31, n32, n33, n34, n41, n42, n43, n44 ) {\n\n\t\tconst te = this.elements;\n\n\t\tte[ 0 ] = n11; te[ 4 ] = n12; te[ 8 ] = n13; te[ 12 ] = n14;\n\t\tte[ 1 ] = n21; te[ 5 ] = n22; te[ 9 ] = n23; te[ 13 ] = n24;\n\t\tte[ 2 ] = n31; te[ 6 ] = n32; te[ 10 ] = n33; te[ 14 ] = n34;\n\t\tte[ 3 ] = n41; te[ 7 ] = n42; te[ 11 ] = n43; te[ 15 ] = n44;\n\n\t\treturn this;\n\n\t}\n\n\tidentity() {\n\n\t\tthis.set(\n\n\t\t\t1, 0, 0, 0,\n\t\t\t0, 1, 0, 0,\n\t\t\t0, 0, 1, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\treturn new Matrix4().fromArray( this.elements );\n\n\t}\n\n\tcopy( m ) {\n\n\t\tconst te = this.elements;\n\t\tconst me = m.elements;\n\n\t\tte[ 0 ] = me[ 0 ]; te[ 1 ] = me[ 1 ]; te[ 2 ] = me[ 2 ]; te[ 3 ] = me[ 3 ];\n\t\tte[ 4 ] = me[ 4 ]; te[ 5 ] = me[ 5 ]; te[ 6 ] = me[ 6 ]; te[ 7 ] = me[ 7 ];\n\t\tte[ 8 ] = me[ 8 ]; te[ 9 ] = me[ 9 ]; te[ 10 ] = me[ 10 ]; te[ 11 ] = me[ 11 ];\n\t\tte[ 12 ] = me[ 12 ]; te[ 13 ] = me[ 13 ]; te[ 14 ] = me[ 14 ]; te[ 15 ] = me[ 15 ];\n\n\t\treturn this;\n\n\t}\n\n\tcopyPosition( m ) {\n\n\t\tconst te = this.elements, me = m.elements;\n\n\t\tte[ 12 ] = me[ 12 ];\n\t\tte[ 13 ] = me[ 13 ];\n\t\tte[ 14 ] = me[ 14 ];\n\n\t\treturn this;\n\n\t}\n\n\tsetFromMatrix3( m ) {\n\n\t\tconst me = m.elements;\n\n\t\tthis.set(\n\n\t\t\tme[ 0 ], me[ 3 ], me[ 6 ], 0,\n\t\t\tme[ 1 ], me[ 4 ], me[ 7 ], 0,\n\t\t\tme[ 2 ], me[ 5 ], me[ 8 ], 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\textractBasis( xAxis, yAxis, zAxis ) {\n\n\t\txAxis.setFromMatrixColumn( this, 0 );\n\t\tyAxis.setFromMatrixColumn( this, 1 );\n\t\tzAxis.setFromMatrixColumn( this, 2 );\n\n\t\treturn this;\n\n\t}\n\n\tmakeBasis( xAxis, yAxis, zAxis ) {\n\n\t\tthis.set(\n\t\t\txAxis.x, yAxis.x, zAxis.x, 0,\n\t\t\txAxis.y, yAxis.y, zAxis.y, 0,\n\t\t\txAxis.z, yAxis.z, zAxis.z, 0,\n\t\t\t0, 0, 0, 1\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\textractRotation( m ) {\n\n\t\t// this method does not support reflection matrices\n\n\t\tconst te = this.elements;\n\t\tconst me = m.elements;\n\n\t\tconst scaleX = 1 / _v1$5.setFromMatrixColumn( m, 0 ).length();\n\t\tconst scaleY = 1 / _v1$5.setFromMatrixColumn( m, 1 ).length();\n\t\tconst scaleZ = 1 / _v1$5.setFromMatrixColumn( m, 2 ).length();\n\n\t\tte[ 0 ] = me[ 0 ] * scaleX;\n\t\tte[ 1 ] = me[ 1 ] * scaleX;\n\t\tte[ 2 ] = me[ 2 ] * scaleX;\n\t\tte[ 3 ] = 0;\n\n\t\tte[ 4 ] = me[ 4 ] * scaleY;\n\t\tte[ 5 ] = me[ 5 ] * scaleY;\n\t\tte[ 6 ] = me[ 6 ] * scaleY;\n\t\tte[ 7 ] = 0;\n\n\t\tte[ 8 ] = me[ 8 ] * scaleZ;\n\t\tte[ 9 ] = me[ 9 ] * scaleZ;\n\t\tte[ 10 ] = me[ 10 ] * scaleZ;\n\t\tte[ 11 ] = 0;\n\n\t\tte[ 12 ] = 0;\n\t\tte[ 13 ] = 0;\n\t\tte[ 14 ] = 0;\n\t\tte[ 15 ] = 1;\n\n\t\treturn this;\n\n\t}\n\n\tmakeRotationFromEuler( euler ) {\n\n\t\tif ( ! ( euler && euler.isEuler ) ) {\n\n\t\t\tconsole.error( 'THREE.Matrix4: .makeRotationFromEuler() now expects a Euler rotation rather than a Vector3 and order.' );\n\n\t\t}\n\n\t\tconst te = this.elements;\n\n\t\tconst x = euler.x, y = euler.y, z = euler.z;\n\t\tconst a = Math.cos( x ), b = Math.sin( x );\n\t\tconst c = Math.cos( y ), d = Math.sin( y );\n\t\tconst e = Math.cos( z ), f = Math.sin( z );\n\n\t\tif ( euler.order === 'XYZ' ) {\n\n\t\t\tconst ae = a * e, af = a * f, be = b * e, bf = b * f;\n\n\t\t\tte[ 0 ] = c * e;\n\t\t\tte[ 4 ] = - c * f;\n\t\t\tte[ 8 ] = d;\n\n\t\t\tte[ 1 ] = af + be * d;\n\t\t\tte[ 5 ] = ae - bf * d;\n\t\t\tte[ 9 ] = - b * c;\n\n\t\t\tte[ 2 ] = bf - ae * d;\n\t\t\tte[ 6 ] = be + af * d;\n\t\t\tte[ 10 ] = a * c;\n\n\t\t} else if ( euler.order === 'YXZ' ) {\n\n\t\t\tconst ce = c * e, cf = c * f, de = d * e, df = d * f;\n\n\t\t\tte[ 0 ] = ce + df * b;\n\t\t\tte[ 4 ] = de * b - cf;\n\t\t\tte[ 8 ] = a * d;\n\n\t\t\tte[ 1 ] = a * f;\n\t\t\tte[ 5 ] = a * e;\n\t\t\tte[ 9 ] = - b;\n\n\t\t\tte[ 2 ] = cf * b - de;\n\t\t\tte[ 6 ] = df + ce * b;\n\t\t\tte[ 10 ] = a * c;\n\n\t\t} else if ( euler.order === 'ZXY' ) {\n\n\t\t\tconst ce = c * e, cf = c * f, de = d * e, df = d * f;\n\n\t\t\tte[ 0 ] = ce - df * b;\n\t\t\tte[ 4 ] = - a * f;\n\t\t\tte[ 8 ] = de + cf * b;\n\n\t\t\tte[ 1 ] = cf + de * b;\n\t\t\tte[ 5 ] = a * e;\n\t\t\tte[ 9 ] = df - ce * b;\n\n\t\t\tte[ 2 ] = - a * d;\n\t\t\tte[ 6 ] = b;\n\t\t\tte[ 10 ] = a * c;\n\n\t\t} else if ( euler.order === 'ZYX' ) {\n\n\t\t\tconst ae = a * e, af = a * f, be = b * e, bf = b * f;\n\n\t\t\tte[ 0 ] = c * e;\n\t\t\tte[ 4 ] = be * d - af;\n\t\t\tte[ 8 ] = ae * d + bf;\n\n\t\t\tte[ 1 ] = c * f;\n\t\t\tte[ 5 ] = bf * d + ae;\n\t\t\tte[ 9 ] = af * d - be;\n\n\t\t\tte[ 2 ] = - d;\n\t\t\tte[ 6 ] = b * c;\n\t\t\tte[ 10 ] = a * c;\n\n\t\t} else if ( euler.order === 'YZX' ) {\n\n\t\t\tconst ac = a * c, ad = a * d, bc = b * c, bd = b * d;\n\n\t\t\tte[ 0 ] = c * e;\n\t\t\tte[ 4 ] = bd - ac * f;\n\t\t\tte[ 8 ] = bc * f + ad;\n\n\t\t\tte[ 1 ] = f;\n\t\t\tte[ 5 ] = a * e;\n\t\t\tte[ 9 ] = - b * e;\n\n\t\t\tte[ 2 ] = - d * e;\n\t\t\tte[ 6 ] = ad * f + bc;\n\t\t\tte[ 10 ] = ac - bd * f;\n\n\t\t} else if ( euler.order === 'XZY' ) {\n\n\t\t\tconst ac = a * c, ad = a * d, bc = b * c, bd = b * d;\n\n\t\t\tte[ 0 ] = c * e;\n\t\t\tte[ 4 ] = - f;\n\t\t\tte[ 8 ] = d * e;\n\n\t\t\tte[ 1 ] = ac * f + bd;\n\t\t\tte[ 5 ] = a * e;\n\t\t\tte[ 9 ] = ad * f - bc;\n\n\t\t\tte[ 2 ] = bc * f - ad;\n\t\t\tte[ 6 ] = b * e;\n\t\t\tte[ 10 ] = bd * f + ac;\n\n\t\t}\n\n\t\t// bottom row\n\t\tte[ 3 ] = 0;\n\t\tte[ 7 ] = 0;\n\t\tte[ 11 ] = 0;\n\n\t\t// last column\n\t\tte[ 12 ] = 0;\n\t\tte[ 13 ] = 0;\n\t\tte[ 14 ] = 0;\n\t\tte[ 15 ] = 1;\n\n\t\treturn this;\n\n\t}\n\n\tmakeRotationFromQuaternion( q ) {\n\n\t\treturn this.compose( _zero, q, _one );\n\n\t}\n\n\tlookAt( eye, target, up ) {\n\n\t\tconst te = this.elements;\n\n\t\t_z.subVectors( eye, target );\n\n\t\tif ( _z.lengthSq() === 0 ) {\n\n\t\t\t// eye and target are in the same position\n\n\t\t\t_z.z = 1;\n\n\t\t}\n\n\t\t_z.normalize();\n\t\t_x.crossVectors( up, _z );\n\n\t\tif ( _x.lengthSq() === 0 ) {\n\n\t\t\t// up and z are parallel\n\n\t\t\tif ( Math.abs( up.z ) === 1 ) {\n\n\t\t\t\t_z.x += 0.0001;\n\n\t\t\t} else {\n\n\t\t\t\t_z.z += 0.0001;\n\n\t\t\t}\n\n\t\t\t_z.normalize();\n\t\t\t_x.crossVectors( up, _z );\n\n\t\t}\n\n\t\t_x.normalize();\n\t\t_y.crossVectors( _z, _x );\n\n\t\tte[ 0 ] = _x.x; te[ 4 ] = _y.x; te[ 8 ] = _z.x;\n\t\tte[ 1 ] = _x.y; te[ 5 ] = _y.y; te[ 9 ] = _z.y;\n\t\tte[ 2 ] = _x.z; te[ 6 ] = _y.z; te[ 10 ] = _z.z;\n\n\t\treturn this;\n\n\t}\n\n\tmultiply( m, n ) {\n\n\t\tif ( n !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Matrix4: .multiply() now only accepts one argument. Use .multiplyMatrices( a, b ) instead.' );\n\t\t\treturn this.multiplyMatrices( m, n );\n\n\t\t}\n\n\t\treturn this.multiplyMatrices( this, m );\n\n\t}\n\n\tpremultiply( m ) {\n\n\t\treturn this.multiplyMatrices( m, this );\n\n\t}\n\n\tmultiplyMatrices( a, b ) {\n\n\t\tconst ae = a.elements;\n\t\tconst be = b.elements;\n\t\tconst te = this.elements;\n\n\t\tconst a11 = ae[ 0 ], a12 = ae[ 4 ], a13 = ae[ 8 ], a14 = ae[ 12 ];\n\t\tconst a21 = ae[ 1 ], a22 = ae[ 5 ], a23 = ae[ 9 ], a24 = ae[ 13 ];\n\t\tconst a31 = ae[ 2 ], a32 = ae[ 6 ], a33 = ae[ 10 ], a34 = ae[ 14 ];\n\t\tconst a41 = ae[ 3 ], a42 = ae[ 7 ], a43 = ae[ 11 ], a44 = ae[ 15 ];\n\n\t\tconst b11 = be[ 0 ], b12 = be[ 4 ], b13 = be[ 8 ], b14 = be[ 12 ];\n\t\tconst b21 = be[ 1 ], b22 = be[ 5 ], b23 = be[ 9 ], b24 = be[ 13 ];\n\t\tconst b31 = be[ 2 ], b32 = be[ 6 ], b33 = be[ 10 ], b34 = be[ 14 ];\n\t\tconst b41 = be[ 3 ], b42 = be[ 7 ], b43 = be[ 11 ], b44 = be[ 15 ];\n\n\t\tte[ 0 ] = a11 * b11 + a12 * b21 + a13 * b31 + a14 * b41;\n\t\tte[ 4 ] = a11 * b12 + a12 * b22 + a13 * b32 + a14 * b42;\n\t\tte[ 8 ] = a11 * b13 + a12 * b23 + a13 * b33 + a14 * b43;\n\t\tte[ 12 ] = a11 * b14 + a12 * b24 + a13 * b34 + a14 * b44;\n\n\t\tte[ 1 ] = a21 * b11 + a22 * b21 + a23 * b31 + a24 * b41;\n\t\tte[ 5 ] = a21 * b12 + a22 * b22 + a23 * b32 + a24 * b42;\n\t\tte[ 9 ] = a21 * b13 + a22 * b23 + a23 * b33 + a24 * b43;\n\t\tte[ 13 ] = a21 * b14 + a22 * b24 + a23 * b34 + a24 * b44;\n\n\t\tte[ 2 ] = a31 * b11 + a32 * b21 + a33 * b31 + a34 * b41;\n\t\tte[ 6 ] = a31 * b12 + a32 * b22 + a33 * b32 + a34 * b42;\n\t\tte[ 10 ] = a31 * b13 + a32 * b23 + a33 * b33 + a34 * b43;\n\t\tte[ 14 ] = a31 * b14 + a32 * b24 + a33 * b34 + a34 * b44;\n\n\t\tte[ 3 ] = a41 * b11 + a42 * b21 + a43 * b31 + a44 * b41;\n\t\tte[ 7 ] = a41 * b12 + a42 * b22 + a43 * b32 + a44 * b42;\n\t\tte[ 11 ] = a41 * b13 + a42 * b23 + a43 * b33 + a44 * b43;\n\t\tte[ 15 ] = a41 * b14 + a42 * b24 + a43 * b34 + a44 * b44;\n\n\t\treturn this;\n\n\t}\n\n\tmultiplyScalar( s ) {\n\n\t\tconst te = this.elements;\n\n\t\tte[ 0 ] *= s; te[ 4 ] *= s; te[ 8 ] *= s; te[ 12 ] *= s;\n\t\tte[ 1 ] *= s; te[ 5 ] *= s; te[ 9 ] *= s; te[ 13 ] *= s;\n\t\tte[ 2 ] *= s; te[ 6 ] *= s; te[ 10 ] *= s; te[ 14 ] *= s;\n\t\tte[ 3 ] *= s; te[ 7 ] *= s; te[ 11 ] *= s; te[ 15 ] *= s;\n\n\t\treturn this;\n\n\t}\n\n\tdeterminant() {\n\n\t\tconst te = this.elements;\n\n\t\tconst n11 = te[ 0 ], n12 = te[ 4 ], n13 = te[ 8 ], n14 = te[ 12 ];\n\t\tconst n21 = te[ 1 ], n22 = te[ 5 ], n23 = te[ 9 ], n24 = te[ 13 ];\n\t\tconst n31 = te[ 2 ], n32 = te[ 6 ], n33 = te[ 10 ], n34 = te[ 14 ];\n\t\tconst n41 = te[ 3 ], n42 = te[ 7 ], n43 = te[ 11 ], n44 = te[ 15 ];\n\n\t\t//TODO: make this more efficient\n\t\t//( based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm )\n\n\t\treturn (\n\t\t\tn41 * (\n\t\t\t\t+ n14 * n23 * n32\n\t\t\t\t - n13 * n24 * n32\n\t\t\t\t - n14 * n22 * n33\n\t\t\t\t + n12 * n24 * n33\n\t\t\t\t + n13 * n22 * n34\n\t\t\t\t - n12 * n23 * n34\n\t\t\t) +\n\t\t\tn42 * (\n\t\t\t\t+ n11 * n23 * n34\n\t\t\t\t - n11 * n24 * n33\n\t\t\t\t + n14 * n21 * n33\n\t\t\t\t - n13 * n21 * n34\n\t\t\t\t + n13 * n24 * n31\n\t\t\t\t - n14 * n23 * n31\n\t\t\t) +\n\t\t\tn43 * (\n\t\t\t\t+ n11 * n24 * n32\n\t\t\t\t - n11 * n22 * n34\n\t\t\t\t - n14 * n21 * n32\n\t\t\t\t + n12 * n21 * n34\n\t\t\t\t + n14 * n22 * n31\n\t\t\t\t - n12 * n24 * n31\n\t\t\t) +\n\t\t\tn44 * (\n\t\t\t\t- n13 * n22 * n31\n\t\t\t\t - n11 * n23 * n32\n\t\t\t\t + n11 * n22 * n33\n\t\t\t\t + n13 * n21 * n32\n\t\t\t\t - n12 * n21 * n33\n\t\t\t\t + n12 * n23 * n31\n\t\t\t)\n\n\t\t);\n\n\t}\n\n\ttranspose() {\n\n\t\tconst te = this.elements;\n\t\tlet tmp;\n\n\t\ttmp = te[ 1 ]; te[ 1 ] = te[ 4 ]; te[ 4 ] = tmp;\n\t\ttmp = te[ 2 ]; te[ 2 ] = te[ 8 ]; te[ 8 ] = tmp;\n\t\ttmp = te[ 6 ]; te[ 6 ] = te[ 9 ]; te[ 9 ] = tmp;\n\n\t\ttmp = te[ 3 ]; te[ 3 ] = te[ 12 ]; te[ 12 ] = tmp;\n\t\ttmp = te[ 7 ]; te[ 7 ] = te[ 13 ]; te[ 13 ] = tmp;\n\t\ttmp = te[ 11 ]; te[ 11 ] = te[ 14 ]; te[ 14 ] = tmp;\n\n\t\treturn this;\n\n\t}\n\n\tsetPosition( x, y, z ) {\n\n\t\tconst te = this.elements;\n\n\t\tif ( x.isVector3 ) {\n\n\t\t\tte[ 12 ] = x.x;\n\t\t\tte[ 13 ] = x.y;\n\t\t\tte[ 14 ] = x.z;\n\n\t\t} else {\n\n\t\t\tte[ 12 ] = x;\n\t\t\tte[ 13 ] = y;\n\t\t\tte[ 14 ] = z;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tinvert() {\n\n\t\t// based on http://www.euclideanspace.com/maths/algebra/matrix/functions/inverse/fourD/index.htm\n\t\tconst te = this.elements,\n\n\t\t\tn11 = te[ 0 ], n21 = te[ 1 ], n31 = te[ 2 ], n41 = te[ 3 ],\n\t\t\tn12 = te[ 4 ], n22 = te[ 5 ], n32 = te[ 6 ], n42 = te[ 7 ],\n\t\t\tn13 = te[ 8 ], n23 = te[ 9 ], n33 = te[ 10 ], n43 = te[ 11 ],\n\t\t\tn14 = te[ 12 ], n24 = te[ 13 ], n34 = te[ 14 ], n44 = te[ 15 ],\n\n\t\t\tt11 = n23 * n34 * n42 - n24 * n33 * n42 + n24 * n32 * n43 - n22 * n34 * n43 - n23 * n32 * n44 + n22 * n33 * n44,\n\t\t\tt12 = n14 * n33 * n42 - n13 * n34 * n42 - n14 * n32 * n43 + n12 * n34 * n43 + n13 * n32 * n44 - n12 * n33 * n44,\n\t\t\tt13 = n13 * n24 * n42 - n14 * n23 * n42 + n14 * n22 * n43 - n12 * n24 * n43 - n13 * n22 * n44 + n12 * n23 * n44,\n\t\t\tt14 = n14 * n23 * n32 - n13 * n24 * n32 - n14 * n22 * n33 + n12 * n24 * n33 + n13 * n22 * n34 - n12 * n23 * n34;\n\n\t\tconst det = n11 * t11 + n21 * t12 + n31 * t13 + n41 * t14;\n\n\t\tif ( det === 0 ) return this.set( 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 );\n\n\t\tconst detInv = 1 / det;\n\n\t\tte[ 0 ] = t11 * detInv;\n\t\tte[ 1 ] = ( n24 * n33 * n41 - n23 * n34 * n41 - n24 * n31 * n43 + n21 * n34 * n43 + n23 * n31 * n44 - n21 * n33 * n44 ) * detInv;\n\t\tte[ 2 ] = ( n22 * n34 * n41 - n24 * n32 * n41 + n24 * n31 * n42 - n21 * n34 * n42 - n22 * n31 * n44 + n21 * n32 * n44 ) * detInv;\n\t\tte[ 3 ] = ( n23 * n32 * n41 - n22 * n33 * n41 - n23 * n31 * n42 + n21 * n33 * n42 + n22 * n31 * n43 - n21 * n32 * n43 ) * detInv;\n\n\t\tte[ 4 ] = t12 * detInv;\n\t\tte[ 5 ] = ( n13 * n34 * n41 - n14 * n33 * n41 + n14 * n31 * n43 - n11 * n34 * n43 - n13 * n31 * n44 + n11 * n33 * n44 ) * detInv;\n\t\tte[ 6 ] = ( n14 * n32 * n41 - n12 * n34 * n41 - n14 * n31 * n42 + n11 * n34 * n42 + n12 * n31 * n44 - n11 * n32 * n44 ) * detInv;\n\t\tte[ 7 ] = ( n12 * n33 * n41 - n13 * n32 * n41 + n13 * n31 * n42 - n11 * n33 * n42 - n12 * n31 * n43 + n11 * n32 * n43 ) * detInv;\n\n\t\tte[ 8 ] = t13 * detInv;\n\t\tte[ 9 ] = ( n14 * n23 * n41 - n13 * n24 * n41 - n14 * n21 * n43 + n11 * n24 * n43 + n13 * n21 * n44 - n11 * n23 * n44 ) * detInv;\n\t\tte[ 10 ] = ( n12 * n24 * n41 - n14 * n22 * n41 + n14 * n21 * n42 - n11 * n24 * n42 - n12 * n21 * n44 + n11 * n22 * n44 ) * detInv;\n\t\tte[ 11 ] = ( n13 * n22 * n41 - n12 * n23 * n41 - n13 * n21 * n42 + n11 * n23 * n42 + n12 * n21 * n43 - n11 * n22 * n43 ) * detInv;\n\n\t\tte[ 12 ] = t14 * detInv;\n\t\tte[ 13 ] = ( n13 * n24 * n31 - n14 * n23 * n31 + n14 * n21 * n33 - n11 * n24 * n33 - n13 * n21 * n34 + n11 * n23 * n34 ) * detInv;\n\t\tte[ 14 ] = ( n14 * n22 * n31 - n12 * n24 * n31 - n14 * n21 * n32 + n11 * n24 * n32 + n12 * n21 * n34 - n11 * n22 * n34 ) * detInv;\n\t\tte[ 15 ] = ( n12 * n23 * n31 - n13 * n22 * n31 + n13 * n21 * n32 - n11 * n23 * n32 - n12 * n21 * n33 + n11 * n22 * n33 ) * detInv;\n\n\t\treturn this;\n\n\t}\n\n\tscale( v ) {\n\n\t\tconst te = this.elements;\n\t\tconst x = v.x, y = v.y, z = v.z;\n\n\t\tte[ 0 ] *= x; te[ 4 ] *= y; te[ 8 ] *= z;\n\t\tte[ 1 ] *= x; te[ 5 ] *= y; te[ 9 ] *= z;\n\t\tte[ 2 ] *= x; te[ 6 ] *= y; te[ 10 ] *= z;\n\t\tte[ 3 ] *= x; te[ 7 ] *= y; te[ 11 ] *= z;\n\n\t\treturn this;\n\n\t}\n\n\tgetMaxScaleOnAxis() {\n\n\t\tconst te = this.elements;\n\n\t\tconst scaleXSq = te[ 0 ] * te[ 0 ] + te[ 1 ] * te[ 1 ] + te[ 2 ] * te[ 2 ];\n\t\tconst scaleYSq = te[ 4 ] * te[ 4 ] + te[ 5 ] * te[ 5 ] + te[ 6 ] * te[ 6 ];\n\t\tconst scaleZSq = te[ 8 ] * te[ 8 ] + te[ 9 ] * te[ 9 ] + te[ 10 ] * te[ 10 ];\n\n\t\treturn Math.sqrt( Math.max( scaleXSq, scaleYSq, scaleZSq ) );\n\n\t}\n\n\tmakeTranslation( x, y, z ) {\n\n\t\tthis.set(\n\n\t\t\t1, 0, 0, x,\n\t\t\t0, 1, 0, y,\n\t\t\t0, 0, 1, z,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\tmakeRotationX( theta ) {\n\n\t\tconst c = Math.cos( theta ), s = Math.sin( theta );\n\n\t\tthis.set(\n\n\t\t\t1, 0, 0, 0,\n\t\t\t0, c, - s, 0,\n\t\t\t0, s, c, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\tmakeRotationY( theta ) {\n\n\t\tconst c = Math.cos( theta ), s = Math.sin( theta );\n\n\t\tthis.set(\n\n\t\t\t c, 0, s, 0,\n\t\t\t 0, 1, 0, 0,\n\t\t\t- s, 0, c, 0,\n\t\t\t 0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\tmakeRotationZ( theta ) {\n\n\t\tconst c = Math.cos( theta ), s = Math.sin( theta );\n\n\t\tthis.set(\n\n\t\t\tc, - s, 0, 0,\n\t\t\ts, c, 0, 0,\n\t\t\t0, 0, 1, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\tmakeRotationAxis( axis, angle ) {\n\n\t\t// Based on http://www.gamedev.net/reference/articles/article1199.asp\n\n\t\tconst c = Math.cos( angle );\n\t\tconst s = Math.sin( angle );\n\t\tconst t = 1 - c;\n\t\tconst x = axis.x, y = axis.y, z = axis.z;\n\t\tconst tx = t * x, ty = t * y;\n\n\t\tthis.set(\n\n\t\t\ttx * x + c, tx * y - s * z, tx * z + s * y, 0,\n\t\t\ttx * y + s * z, ty * y + c, ty * z - s * x, 0,\n\t\t\ttx * z - s * y, ty * z + s * x, t * z * z + c, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\tmakeScale( x, y, z ) {\n\n\t\tthis.set(\n\n\t\t\tx, 0, 0, 0,\n\t\t\t0, y, 0, 0,\n\t\t\t0, 0, z, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\tmakeShear( xy, xz, yx, yz, zx, zy ) {\n\n\t\tthis.set(\n\n\t\t\t1, yx, zx, 0,\n\t\t\txy, 1, zy, 0,\n\t\t\txz, yz, 1, 0,\n\t\t\t0, 0, 0, 1\n\n\t\t);\n\n\t\treturn this;\n\n\t}\n\n\tcompose( position, quaternion, scale ) {\n\n\t\tconst te = this.elements;\n\n\t\tconst x = quaternion._x, y = quaternion._y, z = quaternion._z, w = quaternion._w;\n\t\tconst x2 = x + x,\ty2 = y + y, z2 = z + z;\n\t\tconst xx = x * x2, xy = x * y2, xz = x * z2;\n\t\tconst yy = y * y2, yz = y * z2, zz = z * z2;\n\t\tconst wx = w * x2, wy = w * y2, wz = w * z2;\n\n\t\tconst sx = scale.x, sy = scale.y, sz = scale.z;\n\n\t\tte[ 0 ] = ( 1 - ( yy + zz ) ) * sx;\n\t\tte[ 1 ] = ( xy + wz ) * sx;\n\t\tte[ 2 ] = ( xz - wy ) * sx;\n\t\tte[ 3 ] = 0;\n\n\t\tte[ 4 ] = ( xy - wz ) * sy;\n\t\tte[ 5 ] = ( 1 - ( xx + zz ) ) * sy;\n\t\tte[ 6 ] = ( yz + wx ) * sy;\n\t\tte[ 7 ] = 0;\n\n\t\tte[ 8 ] = ( xz + wy ) * sz;\n\t\tte[ 9 ] = ( yz - wx ) * sz;\n\t\tte[ 10 ] = ( 1 - ( xx + yy ) ) * sz;\n\t\tte[ 11 ] = 0;\n\n\t\tte[ 12 ] = position.x;\n\t\tte[ 13 ] = position.y;\n\t\tte[ 14 ] = position.z;\n\t\tte[ 15 ] = 1;\n\n\t\treturn this;\n\n\t}\n\n\tdecompose( position, quaternion, scale ) {\n\n\t\tconst te = this.elements;\n\n\t\tlet sx = _v1$5.set( te[ 0 ], te[ 1 ], te[ 2 ] ).length();\n\t\tconst sy = _v1$5.set( te[ 4 ], te[ 5 ], te[ 6 ] ).length();\n\t\tconst sz = _v1$5.set( te[ 8 ], te[ 9 ], te[ 10 ] ).length();\n\n\t\t// if determine is negative, we need to invert one scale\n\t\tconst det = this.determinant();\n\t\tif ( det < 0 ) sx = - sx;\n\n\t\tposition.x = te[ 12 ];\n\t\tposition.y = te[ 13 ];\n\t\tposition.z = te[ 14 ];\n\n\t\t// scale the rotation part\n\t\t_m1$2.copy( this );\n\n\t\tconst invSX = 1 / sx;\n\t\tconst invSY = 1 / sy;\n\t\tconst invSZ = 1 / sz;\n\n\t\t_m1$2.elements[ 0 ] *= invSX;\n\t\t_m1$2.elements[ 1 ] *= invSX;\n\t\t_m1$2.elements[ 2 ] *= invSX;\n\n\t\t_m1$2.elements[ 4 ] *= invSY;\n\t\t_m1$2.elements[ 5 ] *= invSY;\n\t\t_m1$2.elements[ 6 ] *= invSY;\n\n\t\t_m1$2.elements[ 8 ] *= invSZ;\n\t\t_m1$2.elements[ 9 ] *= invSZ;\n\t\t_m1$2.elements[ 10 ] *= invSZ;\n\n\t\tquaternion.setFromRotationMatrix( _m1$2 );\n\n\t\tscale.x = sx;\n\t\tscale.y = sy;\n\t\tscale.z = sz;\n\n\t\treturn this;\n\n\t}\n\n\tmakePerspective( left, right, top, bottom, near, far ) {\n\n\t\tif ( far === undefined ) {\n\n\t\t\tconsole.warn( 'THREE.Matrix4: .makePerspective() has been redefined and has a new signature. Please check the docs.' );\n\n\t\t}\n\n\t\tconst te = this.elements;\n\t\tconst x = 2 * near / ( right - left );\n\t\tconst y = 2 * near / ( top - bottom );\n\n\t\tconst a = ( right + left ) / ( right - left );\n\t\tconst b = ( top + bottom ) / ( top - bottom );\n\t\tconst c = - ( far + near ) / ( far - near );\n\t\tconst d = - 2 * far * near / ( far - near );\n\n\t\tte[ 0 ] = x;\tte[ 4 ] = 0;\tte[ 8 ] = a;\tte[ 12 ] = 0;\n\t\tte[ 1 ] = 0;\tte[ 5 ] = y;\tte[ 9 ] = b;\tte[ 13 ] = 0;\n\t\tte[ 2 ] = 0;\tte[ 6 ] = 0;\tte[ 10 ] = c;\tte[ 14 ] = d;\n\t\tte[ 3 ] = 0;\tte[ 7 ] = 0;\tte[ 11 ] = - 1;\tte[ 15 ] = 0;\n\n\t\treturn this;\n\n\t}\n\n\tmakeOrthographic( left, right, top, bottom, near, far ) {\n\n\t\tconst te = this.elements;\n\t\tconst w = 1.0 / ( right - left );\n\t\tconst h = 1.0 / ( top - bottom );\n\t\tconst p = 1.0 / ( far - near );\n\n\t\tconst x = ( right + left ) * w;\n\t\tconst y = ( top + bottom ) * h;\n\t\tconst z = ( far + near ) * p;\n\n\t\tte[ 0 ] = 2 * w;\tte[ 4 ] = 0;\tte[ 8 ] = 0;\tte[ 12 ] = - x;\n\t\tte[ 1 ] = 0;\tte[ 5 ] = 2 * h;\tte[ 9 ] = 0;\tte[ 13 ] = - y;\n\t\tte[ 2 ] = 0;\tte[ 6 ] = 0;\tte[ 10 ] = - 2 * p;\tte[ 14 ] = - z;\n\t\tte[ 3 ] = 0;\tte[ 7 ] = 0;\tte[ 11 ] = 0;\tte[ 15 ] = 1;\n\n\t\treturn this;\n\n\t}\n\n\tequals( matrix ) {\n\n\t\tconst te = this.elements;\n\t\tconst me = matrix.elements;\n\n\t\tfor ( let i = 0; i < 16; i ++ ) {\n\n\t\t\tif ( te[ i ] !== me[ i ] ) return false;\n\n\t\t}\n\n\t\treturn true;\n\n\t}\n\n\tfromArray( array, offset = 0 ) {\n\n\t\tfor ( let i = 0; i < 16; i ++ ) {\n\n\t\t\tthis.elements[ i ] = array[ i + offset ];\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\ttoArray( array = [], offset = 0 ) {\n\n\t\tconst te = this.elements;\n\n\t\tarray[ offset ] = te[ 0 ];\n\t\tarray[ offset + 1 ] = te[ 1 ];\n\t\tarray[ offset + 2 ] = te[ 2 ];\n\t\tarray[ offset + 3 ] = te[ 3 ];\n\n\t\tarray[ offset + 4 ] = te[ 4 ];\n\t\tarray[ offset + 5 ] = te[ 5 ];\n\t\tarray[ offset + 6 ] = te[ 6 ];\n\t\tarray[ offset + 7 ] = te[ 7 ];\n\n\t\tarray[ offset + 8 ] = te[ 8 ];\n\t\tarray[ offset + 9 ] = te[ 9 ];\n\t\tarray[ offset + 10 ] = te[ 10 ];\n\t\tarray[ offset + 11 ] = te[ 11 ];\n\n\t\tarray[ offset + 12 ] = te[ 12 ];\n\t\tarray[ offset + 13 ] = te[ 13 ];\n\t\tarray[ offset + 14 ] = te[ 14 ];\n\t\tarray[ offset + 15 ] = te[ 15 ];\n\n\t\treturn array;\n\n\t}\n\n}\n\nconst _v1$5 = /*@__PURE__*/ new Vector3();\nconst _m1$2 = /*@__PURE__*/ new Matrix4();\nconst _zero = /*@__PURE__*/ new Vector3( 0, 0, 0 );\nconst _one = /*@__PURE__*/ new Vector3( 1, 1, 1 );\nconst _x = /*@__PURE__*/ new Vector3();\nconst _y = /*@__PURE__*/ new Vector3();\nconst _z = /*@__PURE__*/ new Vector3();\n\nconst _matrix$1 = /*@__PURE__*/ new Matrix4();\nconst _quaternion$3 = /*@__PURE__*/ new Quaternion();\n\nclass Euler {\n\n\tconstructor( x = 0, y = 0, z = 0, order = Euler.DefaultOrder ) {\n\n\t\tthis.isEuler = true;\n\n\t\tthis._x = x;\n\t\tthis._y = y;\n\t\tthis._z = z;\n\t\tthis._order = order;\n\n\t}\n\n\tget x() {\n\n\t\treturn this._x;\n\n\t}\n\n\tset x( value ) {\n\n\t\tthis._x = value;\n\t\tthis._onChangeCallback();\n\n\t}\n\n\tget y() {\n\n\t\treturn this._y;\n\n\t}\n\n\tset y( value ) {\n\n\t\tthis._y = value;\n\t\tthis._onChangeCallback();\n\n\t}\n\n\tget z() {\n\n\t\treturn this._z;\n\n\t}\n\n\tset z( value ) {\n\n\t\tthis._z = value;\n\t\tthis._onChangeCallback();\n\n\t}\n\n\tget order() {\n\n\t\treturn this._order;\n\n\t}\n\n\tset order( value ) {\n\n\t\tthis._order = value;\n\t\tthis._onChangeCallback();\n\n\t}\n\n\tset( x, y, z, order = this._order ) {\n\n\t\tthis._x = x;\n\t\tthis._y = y;\n\t\tthis._z = z;\n\t\tthis._order = order;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor( this._x, this._y, this._z, this._order );\n\n\t}\n\n\tcopy( euler ) {\n\n\t\tthis._x = euler._x;\n\t\tthis._y = euler._y;\n\t\tthis._z = euler._z;\n\t\tthis._order = euler._order;\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\tsetFromRotationMatrix( m, order = this._order, update = true ) {\n\n\t\t// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n\n\t\tconst te = m.elements;\n\t\tconst m11 = te[ 0 ], m12 = te[ 4 ], m13 = te[ 8 ];\n\t\tconst m21 = te[ 1 ], m22 = te[ 5 ], m23 = te[ 9 ];\n\t\tconst m31 = te[ 2 ], m32 = te[ 6 ], m33 = te[ 10 ];\n\n\t\tswitch ( order ) {\n\n\t\t\tcase 'XYZ':\n\n\t\t\t\tthis._y = Math.asin( clamp( m13, - 1, 1 ) );\n\n\t\t\t\tif ( Math.abs( m13 ) < 0.9999999 ) {\n\n\t\t\t\t\tthis._x = Math.atan2( - m23, m33 );\n\t\t\t\t\tthis._z = Math.atan2( - m12, m11 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthis._x = Math.atan2( m32, m22 );\n\t\t\t\t\tthis._z = 0;\n\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'YXZ':\n\n\t\t\t\tthis._x = Math.asin( - clamp( m23, - 1, 1 ) );\n\n\t\t\t\tif ( Math.abs( m23 ) < 0.9999999 ) {\n\n\t\t\t\t\tthis._y = Math.atan2( m13, m33 );\n\t\t\t\t\tthis._z = Math.atan2( m21, m22 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthis._y = Math.atan2( - m31, m11 );\n\t\t\t\t\tthis._z = 0;\n\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'ZXY':\n\n\t\t\t\tthis._x = Math.asin( clamp( m32, - 1, 1 ) );\n\n\t\t\t\tif ( Math.abs( m32 ) < 0.9999999 ) {\n\n\t\t\t\t\tthis._y = Math.atan2( - m31, m33 );\n\t\t\t\t\tthis._z = Math.atan2( - m12, m22 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthis._y = 0;\n\t\t\t\t\tthis._z = Math.atan2( m21, m11 );\n\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'ZYX':\n\n\t\t\t\tthis._y = Math.asin( - clamp( m31, - 1, 1 ) );\n\n\t\t\t\tif ( Math.abs( m31 ) < 0.9999999 ) {\n\n\t\t\t\t\tthis._x = Math.atan2( m32, m33 );\n\t\t\t\t\tthis._z = Math.atan2( m21, m11 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthis._x = 0;\n\t\t\t\t\tthis._z = Math.atan2( - m12, m22 );\n\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'YZX':\n\n\t\t\t\tthis._z = Math.asin( clamp( m21, - 1, 1 ) );\n\n\t\t\t\tif ( Math.abs( m21 ) < 0.9999999 ) {\n\n\t\t\t\t\tthis._x = Math.atan2( - m23, m22 );\n\t\t\t\t\tthis._y = Math.atan2( - m31, m11 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthis._x = 0;\n\t\t\t\t\tthis._y = Math.atan2( m13, m33 );\n\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'XZY':\n\n\t\t\t\tthis._z = Math.asin( - clamp( m12, - 1, 1 ) );\n\n\t\t\t\tif ( Math.abs( m12 ) < 0.9999999 ) {\n\n\t\t\t\t\tthis._x = Math.atan2( m32, m22 );\n\t\t\t\t\tthis._y = Math.atan2( m13, m11 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthis._x = Math.atan2( - m23, m33 );\n\t\t\t\t\tthis._y = 0;\n\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\n\t\t\t\tconsole.warn( 'THREE.Euler: .setFromRotationMatrix() encountered an unknown order: ' + order );\n\n\t\t}\n\n\t\tthis._order = order;\n\n\t\tif ( update === true ) this._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\tsetFromQuaternion( q, order, update ) {\n\n\t\t_matrix$1.makeRotationFromQuaternion( q );\n\n\t\treturn this.setFromRotationMatrix( _matrix$1, order, update );\n\n\t}\n\n\tsetFromVector3( v, order = this._order ) {\n\n\t\treturn this.set( v.x, v.y, v.z, order );\n\n\t}\n\n\treorder( newOrder ) {\n\n\t\t// WARNING: this discards revolution information -bhouston\n\n\t\t_quaternion$3.setFromEuler( this );\n\n\t\treturn this.setFromQuaternion( _quaternion$3, newOrder );\n\n\t}\n\n\tequals( euler ) {\n\n\t\treturn ( euler._x === this._x ) && ( euler._y === this._y ) && ( euler._z === this._z ) && ( euler._order === this._order );\n\n\t}\n\n\tfromArray( array ) {\n\n\t\tthis._x = array[ 0 ];\n\t\tthis._y = array[ 1 ];\n\t\tthis._z = array[ 2 ];\n\t\tif ( array[ 3 ] !== undefined ) this._order = array[ 3 ];\n\n\t\tthis._onChangeCallback();\n\n\t\treturn this;\n\n\t}\n\n\ttoArray( array = [], offset = 0 ) {\n\n\t\tarray[ offset ] = this._x;\n\t\tarray[ offset + 1 ] = this._y;\n\t\tarray[ offset + 2 ] = this._z;\n\t\tarray[ offset + 3 ] = this._order;\n\n\t\treturn array;\n\n\t}\n\n\t_onChange( callback ) {\n\n\t\tthis._onChangeCallback = callback;\n\n\t\treturn this;\n\n\t}\n\n\t_onChangeCallback() {}\n\n\t*[ Symbol.iterator ]() {\n\n\t\tyield this._x;\n\t\tyield this._y;\n\t\tyield this._z;\n\t\tyield this._order;\n\n\t}\n\n\t// @deprecated since r138, 02cf0df1cb4575d5842fef9c85bb5a89fe020d53\n\n\ttoVector3() {\n\n\t\tconsole.error( 'THREE.Euler: .toVector3() has been removed. Use Vector3.setFromEuler() instead' );\n\n\t}\n\n}\n\nEuler.DefaultOrder = 'XYZ';\nEuler.RotationOrders = [ 'XYZ', 'YZX', 'ZXY', 'XZY', 'YXZ', 'ZYX' ];\n\nclass Layers {\n\n\tconstructor() {\n\n\t\tthis.mask = 1 | 0;\n\n\t}\n\n\tset( channel ) {\n\n\t\tthis.mask = ( 1 << channel | 0 ) >>> 0;\n\n\t}\n\n\tenable( channel ) {\n\n\t\tthis.mask |= 1 << channel | 0;\n\n\t}\n\n\tenableAll() {\n\n\t\tthis.mask = 0xffffffff | 0;\n\n\t}\n\n\ttoggle( channel ) {\n\n\t\tthis.mask ^= 1 << channel | 0;\n\n\t}\n\n\tdisable( channel ) {\n\n\t\tthis.mask &= ~ ( 1 << channel | 0 );\n\n\t}\n\n\tdisableAll() {\n\n\t\tthis.mask = 0;\n\n\t}\n\n\ttest( layers ) {\n\n\t\treturn ( this.mask & layers.mask ) !== 0;\n\n\t}\n\n\tisEnabled( channel ) {\n\n\t\treturn ( this.mask & ( 1 << channel | 0 ) ) !== 0;\n\n\t}\n\n}\n\nlet _object3DId = 0;\n\nconst _v1$4 = /*@__PURE__*/ new Vector3();\nconst _q1 = /*@__PURE__*/ new Quaternion();\nconst _m1$1 = /*@__PURE__*/ new Matrix4();\nconst _target = /*@__PURE__*/ new Vector3();\n\nconst _position$3 = /*@__PURE__*/ new Vector3();\nconst _scale$2 = /*@__PURE__*/ new Vector3();\nconst _quaternion$2 = /*@__PURE__*/ new Quaternion();\n\nconst _xAxis = /*@__PURE__*/ new Vector3( 1, 0, 0 );\nconst _yAxis = /*@__PURE__*/ new Vector3( 0, 1, 0 );\nconst _zAxis = /*@__PURE__*/ new Vector3( 0, 0, 1 );\n\nconst _addedEvent = { type: 'added' };\nconst _removedEvent = { type: 'removed' };\n\nclass Object3D extends EventDispatcher {\n\n\tconstructor() {\n\n\t\tsuper();\n\n\t\tthis.isObject3D = true;\n\n\t\tObject.defineProperty( this, 'id', { value: _object3DId ++ } );\n\n\t\tthis.uuid = generateUUID();\n\n\t\tthis.name = '';\n\t\tthis.type = 'Object3D';\n\n\t\tthis.parent = null;\n\t\tthis.children = [];\n\n\t\tthis.up = Object3D.DefaultUp.clone();\n\n\t\tconst position = new Vector3();\n\t\tconst rotation = new Euler();\n\t\tconst quaternion = new Quaternion();\n\t\tconst scale = new Vector3( 1, 1, 1 );\n\n\t\tfunction onRotationChange() {\n\n\t\t\tquaternion.setFromEuler( rotation, false );\n\n\t\t}\n\n\t\tfunction onQuaternionChange() {\n\n\t\t\trotation.setFromQuaternion( quaternion, undefined, false );\n\n\t\t}\n\n\t\trotation._onChange( onRotationChange );\n\t\tquaternion._onChange( onQuaternionChange );\n\n\t\tObject.defineProperties( this, {\n\t\t\tposition: {\n\t\t\t\tconfigurable: true,\n\t\t\t\tenumerable: true,\n\t\t\t\tvalue: position\n\t\t\t},\n\t\t\trotation: {\n\t\t\t\tconfigurable: true,\n\t\t\t\tenumerable: true,\n\t\t\t\tvalue: rotation\n\t\t\t},\n\t\t\tquaternion: {\n\t\t\t\tconfigurable: true,\n\t\t\t\tenumerable: true,\n\t\t\t\tvalue: quaternion\n\t\t\t},\n\t\t\tscale: {\n\t\t\t\tconfigurable: true,\n\t\t\t\tenumerable: true,\n\t\t\t\tvalue: scale\n\t\t\t},\n\t\t\tmodelViewMatrix: {\n\t\t\t\tvalue: new Matrix4()\n\t\t\t},\n\t\t\tnormalMatrix: {\n\t\t\t\tvalue: new Matrix3()\n\t\t\t}\n\t\t} );\n\n\t\tthis.matrix = new Matrix4();\n\t\tthis.matrixWorld = new Matrix4();\n\n\t\tthis.matrixAutoUpdate = Object3D.DefaultMatrixAutoUpdate;\n\t\tthis.matrixWorldNeedsUpdate = false;\n\n\t\tthis.layers = new Layers();\n\t\tthis.visible = true;\n\n\t\tthis.castShadow = false;\n\t\tthis.receiveShadow = false;\n\n\t\tthis.frustumCulled = true;\n\t\tthis.renderOrder = 0;\n\n\t\tthis.animations = [];\n\n\t\tthis.userData = {};\n\n\t}\n\n\tonBeforeRender( /* renderer, scene, camera, geometry, material, group */ ) {}\n\n\tonAfterRender( /* renderer, scene, camera, geometry, material, group */ ) {}\n\n\tapplyMatrix4( matrix ) {\n\n\t\tif ( this.matrixAutoUpdate ) this.updateMatrix();\n\n\t\tthis.matrix.premultiply( matrix );\n\n\t\tthis.matrix.decompose( this.position, this.quaternion, this.scale );\n\n\t}\n\n\tapplyQuaternion( q ) {\n\n\t\tthis.quaternion.premultiply( q );\n\n\t\treturn this;\n\n\t}\n\n\tsetRotationFromAxisAngle( axis, angle ) {\n\n\t\t// assumes axis is normalized\n\n\t\tthis.quaternion.setFromAxisAngle( axis, angle );\n\n\t}\n\n\tsetRotationFromEuler( euler ) {\n\n\t\tthis.quaternion.setFromEuler( euler, true );\n\n\t}\n\n\tsetRotationFromMatrix( m ) {\n\n\t\t// assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n\n\t\tthis.quaternion.setFromRotationMatrix( m );\n\n\t}\n\n\tsetRotationFromQuaternion( q ) {\n\n\t\t// assumes q is normalized\n\n\t\tthis.quaternion.copy( q );\n\n\t}\n\n\trotateOnAxis( axis, angle ) {\n\n\t\t// rotate object on axis in object space\n\t\t// axis is assumed to be normalized\n\n\t\t_q1.setFromAxisAngle( axis, angle );\n\n\t\tthis.quaternion.multiply( _q1 );\n\n\t\treturn this;\n\n\t}\n\n\trotateOnWorldAxis( axis, angle ) {\n\n\t\t// rotate object on axis in world space\n\t\t// axis is assumed to be normalized\n\t\t// method assumes no rotated parent\n\n\t\t_q1.setFromAxisAngle( axis, angle );\n\n\t\tthis.quaternion.premultiply( _q1 );\n\n\t\treturn this;\n\n\t}\n\n\trotateX( angle ) {\n\n\t\treturn this.rotateOnAxis( _xAxis, angle );\n\n\t}\n\n\trotateY( angle ) {\n\n\t\treturn this.rotateOnAxis( _yAxis, angle );\n\n\t}\n\n\trotateZ( angle ) {\n\n\t\treturn this.rotateOnAxis( _zAxis, angle );\n\n\t}\n\n\ttranslateOnAxis( axis, distance ) {\n\n\t\t// translate object by distance along axis in object space\n\t\t// axis is assumed to be normalized\n\n\t\t_v1$4.copy( axis ).applyQuaternion( this.quaternion );\n\n\t\tthis.position.add( _v1$4.multiplyScalar( distance ) );\n\n\t\treturn this;\n\n\t}\n\n\ttranslateX( distance ) {\n\n\t\treturn this.translateOnAxis( _xAxis, distance );\n\n\t}\n\n\ttranslateY( distance ) {\n\n\t\treturn this.translateOnAxis( _yAxis, distance );\n\n\t}\n\n\ttranslateZ( distance ) {\n\n\t\treturn this.translateOnAxis( _zAxis, distance );\n\n\t}\n\n\tlocalToWorld( vector ) {\n\n\t\treturn vector.applyMatrix4( this.matrixWorld );\n\n\t}\n\n\tworldToLocal( vector ) {\n\n\t\treturn vector.applyMatrix4( _m1$1.copy( this.matrixWorld ).invert() );\n\n\t}\n\n\tlookAt( x, y, z ) {\n\n\t\t// This method does not support objects having non-uniformly-scaled parent(s)\n\n\t\tif ( x.isVector3 ) {\n\n\t\t\t_target.copy( x );\n\n\t\t} else {\n\n\t\t\t_target.set( x, y, z );\n\n\t\t}\n\n\t\tconst parent = this.parent;\n\n\t\tthis.updateWorldMatrix( true, false );\n\n\t\t_position$3.setFromMatrixPosition( this.matrixWorld );\n\n\t\tif ( this.isCamera || this.isLight ) {\n\n\t\t\t_m1$1.lookAt( _position$3, _target, this.up );\n\n\t\t} else {\n\n\t\t\t_m1$1.lookAt( _target, _position$3, this.up );\n\n\t\t}\n\n\t\tthis.quaternion.setFromRotationMatrix( _m1$1 );\n\n\t\tif ( parent ) {\n\n\t\t\t_m1$1.extractRotation( parent.matrixWorld );\n\t\t\t_q1.setFromRotationMatrix( _m1$1 );\n\t\t\tthis.quaternion.premultiply( _q1.invert() );\n\n\t\t}\n\n\t}\n\n\tadd( object ) {\n\n\t\tif ( arguments.length > 1 ) {\n\n\t\t\tfor ( let i = 0; i < arguments.length; i ++ ) {\n\n\t\t\t\tthis.add( arguments[ i ] );\n\n\t\t\t}\n\n\t\t\treturn this;\n\n\t\t}\n\n\t\tif ( object === this ) {\n\n\t\t\tconsole.error( 'THREE.Object3D.add: object can\\'t be added as a child of itself.', object );\n\t\t\treturn this;\n\n\t\t}\n\n\t\tif ( object && object.isObject3D ) {\n\n\t\t\tif ( object.parent !== null ) {\n\n\t\t\t\tobject.parent.remove( object );\n\n\t\t\t}\n\n\t\t\tobject.parent = this;\n\t\t\tthis.children.push( object );\n\n\t\t\tobject.dispatchEvent( _addedEvent );\n\n\t\t} else {\n\n\t\t\tconsole.error( 'THREE.Object3D.add: object not an instance of THREE.Object3D.', object );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tremove( object ) {\n\n\t\tif ( arguments.length > 1 ) {\n\n\t\t\tfor ( let i = 0; i < arguments.length; i ++ ) {\n\n\t\t\t\tthis.remove( arguments[ i ] );\n\n\t\t\t}\n\n\t\t\treturn this;\n\n\t\t}\n\n\t\tconst index = this.children.indexOf( object );\n\n\t\tif ( index !== - 1 ) {\n\n\t\t\tobject.parent = null;\n\t\t\tthis.children.splice( index, 1 );\n\n\t\t\tobject.dispatchEvent( _removedEvent );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tremoveFromParent() {\n\n\t\tconst parent = this.parent;\n\n\t\tif ( parent !== null ) {\n\n\t\t\tparent.remove( this );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tclear() {\n\n\t\tfor ( let i = 0; i < this.children.length; i ++ ) {\n\n\t\t\tconst object = this.children[ i ];\n\n\t\t\tobject.parent = null;\n\n\t\t\tobject.dispatchEvent( _removedEvent );\n\n\t\t}\n\n\t\tthis.children.length = 0;\n\n\t\treturn this;\n\n\n\t}\n\n\tattach( object ) {\n\n\t\t// adds object as a child of this, while maintaining the object's world transform\n\n\t\t// Note: This method does not support scene graphs having non-uniformly-scaled nodes(s)\n\n\t\tthis.updateWorldMatrix( true, false );\n\n\t\t_m1$1.copy( this.matrixWorld ).invert();\n\n\t\tif ( object.parent !== null ) {\n\n\t\t\tobject.parent.updateWorldMatrix( true, false );\n\n\t\t\t_m1$1.multiply( object.parent.matrixWorld );\n\n\t\t}\n\n\t\tobject.applyMatrix4( _m1$1 );\n\n\t\tthis.add( object );\n\n\t\tobject.updateWorldMatrix( false, true );\n\n\t\treturn this;\n\n\t}\n\n\tgetObjectById( id ) {\n\n\t\treturn this.getObjectByProperty( 'id', id );\n\n\t}\n\n\tgetObjectByName( name ) {\n\n\t\treturn this.getObjectByProperty( 'name', name );\n\n\t}\n\n\tgetObjectByProperty( name, value ) {\n\n\t\tif ( this[ name ] === value ) return this;\n\n\t\tfor ( let i = 0, l = this.children.length; i < l; i ++ ) {\n\n\t\t\tconst child = this.children[ i ];\n\t\t\tconst object = child.getObjectByProperty( name, value );\n\n\t\t\tif ( object !== undefined ) {\n\n\t\t\t\treturn object;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn undefined;\n\n\t}\n\n\tgetWorldPosition( target ) {\n\n\t\tthis.updateWorldMatrix( true, false );\n\n\t\treturn target.setFromMatrixPosition( this.matrixWorld );\n\n\t}\n\n\tgetWorldQuaternion( target ) {\n\n\t\tthis.updateWorldMatrix( true, false );\n\n\t\tthis.matrixWorld.decompose( _position$3, target, _scale$2 );\n\n\t\treturn target;\n\n\t}\n\n\tgetWorldScale( target ) {\n\n\t\tthis.updateWorldMatrix( true, false );\n\n\t\tthis.matrixWorld.decompose( _position$3, _quaternion$2, target );\n\n\t\treturn target;\n\n\t}\n\n\tgetWorldDirection( target ) {\n\n\t\tthis.updateWorldMatrix( true, false );\n\n\t\tconst e = this.matrixWorld.elements;\n\n\t\treturn target.set( e[ 8 ], e[ 9 ], e[ 10 ] ).normalize();\n\n\t}\n\n\traycast( /* raycaster, intersects */ ) {}\n\n\ttraverse( callback ) {\n\n\t\tcallback( this );\n\n\t\tconst children = this.children;\n\n\t\tfor ( let i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\tchildren[ i ].traverse( callback );\n\n\t\t}\n\n\t}\n\n\ttraverseVisible( callback ) {\n\n\t\tif ( this.visible === false ) return;\n\n\t\tcallback( this );\n\n\t\tconst children = this.children;\n\n\t\tfor ( let i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\tchildren[ i ].traverseVisible( callback );\n\n\t\t}\n\n\t}\n\n\ttraverseAncestors( callback ) {\n\n\t\tconst parent = this.parent;\n\n\t\tif ( parent !== null ) {\n\n\t\t\tcallback( parent );\n\n\t\t\tparent.traverseAncestors( callback );\n\n\t\t}\n\n\t}\n\n\tupdateMatrix() {\n\n\t\tthis.matrix.compose( this.position, this.quaternion, this.scale );\n\n\t\tthis.matrixWorldNeedsUpdate = true;\n\n\t}\n\n\tupdateMatrixWorld( force ) {\n\n\t\tif ( this.matrixAutoUpdate ) this.updateMatrix();\n\n\t\tif ( this.matrixWorldNeedsUpdate || force ) {\n\n\t\t\tif ( this.parent === null ) {\n\n\t\t\t\tthis.matrixWorld.copy( this.matrix );\n\n\t\t\t} else {\n\n\t\t\t\tthis.matrixWorld.multiplyMatrices( this.parent.matrixWorld, this.matrix );\n\n\t\t\t}\n\n\t\t\tthis.matrixWorldNeedsUpdate = false;\n\n\t\t\tforce = true;\n\n\t\t}\n\n\t\t// update children\n\n\t\tconst children = this.children;\n\n\t\tfor ( let i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\tchildren[ i ].updateMatrixWorld( force );\n\n\t\t}\n\n\t}\n\n\tupdateWorldMatrix( updateParents, updateChildren ) {\n\n\t\tconst parent = this.parent;\n\n\t\tif ( updateParents === true && parent !== null ) {\n\n\t\t\tparent.updateWorldMatrix( true, false );\n\n\t\t}\n\n\t\tif ( this.matrixAutoUpdate ) this.updateMatrix();\n\n\t\tif ( this.parent === null ) {\n\n\t\t\tthis.matrixWorld.copy( this.matrix );\n\n\t\t} else {\n\n\t\t\tthis.matrixWorld.multiplyMatrices( this.parent.matrixWorld, this.matrix );\n\n\t\t}\n\n\t\t// update children\n\n\t\tif ( updateChildren === true ) {\n\n\t\t\tconst children = this.children;\n\n\t\t\tfor ( let i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\t\tchildren[ i ].updateWorldMatrix( false, true );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\ttoJSON( meta ) {\n\n\t\t// meta is a string when called from JSON.stringify\n\t\tconst isRootObject = ( meta === undefined || typeof meta === 'string' );\n\n\t\tconst output = {};\n\n\t\t// meta is a hash used to collect geometries, materials.\n\t\t// not providing it implies that this is the root object\n\t\t// being serialized.\n\t\tif ( isRootObject ) {\n\n\t\t\t// initialize meta obj\n\t\t\tmeta = {\n\t\t\t\tgeometries: {},\n\t\t\t\tmaterials: {},\n\t\t\t\ttextures: {},\n\t\t\t\timages: {},\n\t\t\t\tshapes: {},\n\t\t\t\tskeletons: {},\n\t\t\t\tanimations: {},\n\t\t\t\tnodes: {}\n\t\t\t};\n\n\t\t\toutput.metadata = {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Object',\n\t\t\t\tgenerator: 'Object3D.toJSON'\n\t\t\t};\n\n\t\t}\n\n\t\t// standard Object3D serialization\n\n\t\tconst object = {};\n\n\t\tobject.uuid = this.uuid;\n\t\tobject.type = this.type;\n\n\t\tif ( this.name !== '' ) object.name = this.name;\n\t\tif ( this.castShadow === true ) object.castShadow = true;\n\t\tif ( this.receiveShadow === true ) object.receiveShadow = true;\n\t\tif ( this.visible === false ) object.visible = false;\n\t\tif ( this.frustumCulled === false ) object.frustumCulled = false;\n\t\tif ( this.renderOrder !== 0 ) object.renderOrder = this.renderOrder;\n\t\tif ( JSON.stringify( this.userData ) !== '{}' ) object.userData = this.userData;\n\n\t\tobject.layers = this.layers.mask;\n\t\tobject.matrix = this.matrix.toArray();\n\n\t\tif ( this.matrixAutoUpdate === false ) object.matrixAutoUpdate = false;\n\n\t\t// object specific properties\n\n\t\tif ( this.isInstancedMesh ) {\n\n\t\t\tobject.type = 'InstancedMesh';\n\t\t\tobject.count = this.count;\n\t\t\tobject.instanceMatrix = this.instanceMatrix.toJSON();\n\t\t\tif ( this.instanceColor !== null ) object.instanceColor = this.instanceColor.toJSON();\n\n\t\t}\n\n\t\t//\n\n\t\tfunction serialize( library, element ) {\n\n\t\t\tif ( library[ element.uuid ] === undefined ) {\n\n\t\t\t\tlibrary[ element.uuid ] = element.toJSON( meta );\n\n\t\t\t}\n\n\t\t\treturn element.uuid;\n\n\t\t}\n\n\t\tif ( this.isScene ) {\n\n\t\t\tif ( this.background ) {\n\n\t\t\t\tif ( this.background.isColor ) {\n\n\t\t\t\t\tobject.background = this.background.toJSON();\n\n\t\t\t\t} else if ( this.background.isTexture ) {\n\n\t\t\t\t\tobject.background = this.background.toJSON( meta ).uuid;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( this.environment && this.environment.isTexture ) {\n\n\t\t\t\tobject.environment = this.environment.toJSON( meta ).uuid;\n\n\t\t\t}\n\n\t\t} else if ( this.isMesh || this.isLine || this.isPoints ) {\n\n\t\t\tobject.geometry = serialize( meta.geometries, this.geometry );\n\n\t\t\tconst parameters = this.geometry.parameters;\n\n\t\t\tif ( parameters !== undefined && parameters.shapes !== undefined ) {\n\n\t\t\t\tconst shapes = parameters.shapes;\n\n\t\t\t\tif ( Array.isArray( shapes ) ) {\n\n\t\t\t\t\tfor ( let i = 0, l = shapes.length; i < l; i ++ ) {\n\n\t\t\t\t\t\tconst shape = shapes[ i ];\n\n\t\t\t\t\t\tserialize( meta.shapes, shape );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tserialize( meta.shapes, shapes );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( this.isSkinnedMesh ) {\n\n\t\t\tobject.bindMode = this.bindMode;\n\t\t\tobject.bindMatrix = this.bindMatrix.toArray();\n\n\t\t\tif ( this.skeleton !== undefined ) {\n\n\t\t\t\tserialize( meta.skeletons, this.skeleton );\n\n\t\t\t\tobject.skeleton = this.skeleton.uuid;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( this.material !== undefined ) {\n\n\t\t\tif ( Array.isArray( this.material ) ) {\n\n\t\t\t\tconst uuids = [];\n\n\t\t\t\tfor ( let i = 0, l = this.material.length; i < l; i ++ ) {\n\n\t\t\t\t\tuuids.push( serialize( meta.materials, this.material[ i ] ) );\n\n\t\t\t\t}\n\n\t\t\t\tobject.material = uuids;\n\n\t\t\t} else {\n\n\t\t\t\tobject.material = serialize( meta.materials, this.material );\n\n\t\t\t}\n\n\t\t}\n\n\t\t//\n\n\t\tif ( this.children.length > 0 ) {\n\n\t\t\tobject.children = [];\n\n\t\t\tfor ( let i = 0; i < this.children.length; i ++ ) {\n\n\t\t\t\tobject.children.push( this.children[ i ].toJSON( meta ).object );\n\n\t\t\t}\n\n\t\t}\n\n\t\t//\n\n\t\tif ( this.animations.length > 0 ) {\n\n\t\t\tobject.animations = [];\n\n\t\t\tfor ( let i = 0; i < this.animations.length; i ++ ) {\n\n\t\t\t\tconst animation = this.animations[ i ];\n\n\t\t\t\tobject.animations.push( serialize( meta.animations, animation ) );\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( isRootObject ) {\n\n\t\t\tconst geometries = extractFromCache( meta.geometries );\n\t\t\tconst materials = extractFromCache( meta.materials );\n\t\t\tconst textures = extractFromCache( meta.textures );\n\t\t\tconst images = extractFromCache( meta.images );\n\t\t\tconst shapes = extractFromCache( meta.shapes );\n\t\t\tconst skeletons = extractFromCache( meta.skeletons );\n\t\t\tconst animations = extractFromCache( meta.animations );\n\t\t\tconst nodes = extractFromCache( meta.nodes );\n\n\t\t\tif ( geometries.length > 0 ) output.geometries = geometries;\n\t\t\tif ( materials.length > 0 ) output.materials = materials;\n\t\t\tif ( textures.length > 0 ) output.textures = textures;\n\t\t\tif ( images.length > 0 ) output.images = images;\n\t\t\tif ( shapes.length > 0 ) output.shapes = shapes;\n\t\t\tif ( skeletons.length > 0 ) output.skeletons = skeletons;\n\t\t\tif ( animations.length > 0 ) output.animations = animations;\n\t\t\tif ( nodes.length > 0 ) output.nodes = nodes;\n\n\t\t}\n\n\t\toutput.object = object;\n\n\t\treturn output;\n\n\t\t// extract data from the cache hash\n\t\t// remove metadata on each item\n\t\t// and return as array\n\t\tfunction extractFromCache( cache ) {\n\n\t\t\tconst values = [];\n\t\t\tfor ( const key in cache ) {\n\n\t\t\t\tconst data = cache[ key ];\n\t\t\t\tdelete data.metadata;\n\t\t\t\tvalues.push( data );\n\n\t\t\t}\n\n\t\t\treturn values;\n\n\t\t}\n\n\t}\n\n\tclone( recursive ) {\n\n\t\treturn new this.constructor().copy( this, recursive );\n\n\t}\n\n\tcopy( source, recursive = true ) {\n\n\t\tthis.name = source.name;\n\n\t\tthis.up.copy( source.up );\n\n\t\tthis.position.copy( source.position );\n\t\tthis.rotation.order = source.rotation.order;\n\t\tthis.quaternion.copy( source.quaternion );\n\t\tthis.scale.copy( source.scale );\n\n\t\tthis.matrix.copy( source.matrix );\n\t\tthis.matrixWorld.copy( source.matrixWorld );\n\n\t\tthis.matrixAutoUpdate = source.matrixAutoUpdate;\n\t\tthis.matrixWorldNeedsUpdate = source.matrixWorldNeedsUpdate;\n\n\t\tthis.layers.mask = source.layers.mask;\n\t\tthis.visible = source.visible;\n\n\t\tthis.castShadow = source.castShadow;\n\t\tthis.receiveShadow = source.receiveShadow;\n\n\t\tthis.frustumCulled = source.frustumCulled;\n\t\tthis.renderOrder = source.renderOrder;\n\n\t\tthis.userData = JSON.parse( JSON.stringify( source.userData ) );\n\n\t\tif ( recursive === true ) {\n\n\t\t\tfor ( let i = 0; i < source.children.length; i ++ ) {\n\n\t\t\t\tconst child = source.children[ i ];\n\t\t\t\tthis.add( child.clone() );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n}\n\nObject3D.DefaultUp = new Vector3( 0, 1, 0 );\nObject3D.DefaultMatrixAutoUpdate = true;\n\nconst _v0$1 = /*@__PURE__*/ new Vector3();\nconst _v1$3 = /*@__PURE__*/ new Vector3();\nconst _v2$2 = /*@__PURE__*/ new Vector3();\nconst _v3$1 = /*@__PURE__*/ new Vector3();\n\nconst _vab = /*@__PURE__*/ new Vector3();\nconst _vac = /*@__PURE__*/ new Vector3();\nconst _vbc = /*@__PURE__*/ new Vector3();\nconst _vap = /*@__PURE__*/ new Vector3();\nconst _vbp = /*@__PURE__*/ new Vector3();\nconst _vcp = /*@__PURE__*/ new Vector3();\n\nclass Triangle {\n\n\tconstructor( a = new Vector3(), b = new Vector3(), c = new Vector3() ) {\n\n\t\tthis.a = a;\n\t\tthis.b = b;\n\t\tthis.c = c;\n\n\t}\n\n\tstatic getNormal( a, b, c, target ) {\n\n\t\ttarget.subVectors( c, b );\n\t\t_v0$1.subVectors( a, b );\n\t\ttarget.cross( _v0$1 );\n\n\t\tconst targetLengthSq = target.lengthSq();\n\t\tif ( targetLengthSq > 0 ) {\n\n\t\t\treturn target.multiplyScalar( 1 / Math.sqrt( targetLengthSq ) );\n\n\t\t}\n\n\t\treturn target.set( 0, 0, 0 );\n\n\t}\n\n\t// static/instance method to calculate barycentric coordinates\n\t// based on: http://www.blackpawn.com/texts/pointinpoly/default.html\n\tstatic getBarycoord( point, a, b, c, target ) {\n\n\t\t_v0$1.subVectors( c, a );\n\t\t_v1$3.subVectors( b, a );\n\t\t_v2$2.subVectors( point, a );\n\n\t\tconst dot00 = _v0$1.dot( _v0$1 );\n\t\tconst dot01 = _v0$1.dot( _v1$3 );\n\t\tconst dot02 = _v0$1.dot( _v2$2 );\n\t\tconst dot11 = _v1$3.dot( _v1$3 );\n\t\tconst dot12 = _v1$3.dot( _v2$2 );\n\n\t\tconst denom = ( dot00 * dot11 - dot01 * dot01 );\n\n\t\t// collinear or singular triangle\n\t\tif ( denom === 0 ) {\n\n\t\t\t// arbitrary location outside of triangle?\n\t\t\t// not sure if this is the best idea, maybe should be returning undefined\n\t\t\treturn target.set( - 2, - 1, - 1 );\n\n\t\t}\n\n\t\tconst invDenom = 1 / denom;\n\t\tconst u = ( dot11 * dot02 - dot01 * dot12 ) * invDenom;\n\t\tconst v = ( dot00 * dot12 - dot01 * dot02 ) * invDenom;\n\n\t\t// barycentric coordinates must always sum to 1\n\t\treturn target.set( 1 - u - v, v, u );\n\n\t}\n\n\tstatic containsPoint( point, a, b, c ) {\n\n\t\tthis.getBarycoord( point, a, b, c, _v3$1 );\n\n\t\treturn ( _v3$1.x >= 0 ) && ( _v3$1.y >= 0 ) && ( ( _v3$1.x + _v3$1.y ) <= 1 );\n\n\t}\n\n\tstatic getUV( point, p1, p2, p3, uv1, uv2, uv3, target ) {\n\n\t\tthis.getBarycoord( point, p1, p2, p3, _v3$1 );\n\n\t\ttarget.set( 0, 0 );\n\t\ttarget.addScaledVector( uv1, _v3$1.x );\n\t\ttarget.addScaledVector( uv2, _v3$1.y );\n\t\ttarget.addScaledVector( uv3, _v3$1.z );\n\n\t\treturn target;\n\n\t}\n\n\tstatic isFrontFacing( a, b, c, direction ) {\n\n\t\t_v0$1.subVectors( c, b );\n\t\t_v1$3.subVectors( a, b );\n\n\t\t// strictly front facing\n\t\treturn ( _v0$1.cross( _v1$3 ).dot( direction ) < 0 ) ? true : false;\n\n\t}\n\n\tset( a, b, c ) {\n\n\t\tthis.a.copy( a );\n\t\tthis.b.copy( b );\n\t\tthis.c.copy( c );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromPointsAndIndices( points, i0, i1, i2 ) {\n\n\t\tthis.a.copy( points[ i0 ] );\n\t\tthis.b.copy( points[ i1 ] );\n\t\tthis.c.copy( points[ i2 ] );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromAttributeAndIndices( attribute, i0, i1, i2 ) {\n\n\t\tthis.a.fromBufferAttribute( attribute, i0 );\n\t\tthis.b.fromBufferAttribute( attribute, i1 );\n\t\tthis.c.fromBufferAttribute( attribute, i2 );\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n\tcopy( triangle ) {\n\n\t\tthis.a.copy( triangle.a );\n\t\tthis.b.copy( triangle.b );\n\t\tthis.c.copy( triangle.c );\n\n\t\treturn this;\n\n\t}\n\n\tgetArea() {\n\n\t\t_v0$1.subVectors( this.c, this.b );\n\t\t_v1$3.subVectors( this.a, this.b );\n\n\t\treturn _v0$1.cross( _v1$3 ).length() * 0.5;\n\n\t}\n\n\tgetMidpoint( target ) {\n\n\t\treturn target.addVectors( this.a, this.b ).add( this.c ).multiplyScalar( 1 / 3 );\n\n\t}\n\n\tgetNormal( target ) {\n\n\t\treturn Triangle.getNormal( this.a, this.b, this.c, target );\n\n\t}\n\n\tgetPlane( target ) {\n\n\t\treturn target.setFromCoplanarPoints( this.a, this.b, this.c );\n\n\t}\n\n\tgetBarycoord( point, target ) {\n\n\t\treturn Triangle.getBarycoord( point, this.a, this.b, this.c, target );\n\n\t}\n\n\tgetUV( point, uv1, uv2, uv3, target ) {\n\n\t\treturn Triangle.getUV( point, this.a, this.b, this.c, uv1, uv2, uv3, target );\n\n\t}\n\n\tcontainsPoint( point ) {\n\n\t\treturn Triangle.containsPoint( point, this.a, this.b, this.c );\n\n\t}\n\n\tisFrontFacing( direction ) {\n\n\t\treturn Triangle.isFrontFacing( this.a, this.b, this.c, direction );\n\n\t}\n\n\tintersectsBox( box ) {\n\n\t\treturn box.intersectsTriangle( this );\n\n\t}\n\n\tclosestPointToPoint( p, target ) {\n\n\t\tconst a = this.a, b = this.b, c = this.c;\n\t\tlet v, w;\n\n\t\t// algorithm thanks to Real-Time Collision Detection by Christer Ericson,\n\t\t// published by Morgan Kaufmann Publishers, (c) 2005 Elsevier Inc.,\n\t\t// under the accompanying license; see chapter 5.1.5 for detailed explanation.\n\t\t// basically, we're distinguishing which of the voronoi regions of the triangle\n\t\t// the point lies in with the minimum amount of redundant computation.\n\n\t\t_vab.subVectors( b, a );\n\t\t_vac.subVectors( c, a );\n\t\t_vap.subVectors( p, a );\n\t\tconst d1 = _vab.dot( _vap );\n\t\tconst d2 = _vac.dot( _vap );\n\t\tif ( d1 <= 0 && d2 <= 0 ) {\n\n\t\t\t// vertex region of A; barycentric coords (1, 0, 0)\n\t\t\treturn target.copy( a );\n\n\t\t}\n\n\t\t_vbp.subVectors( p, b );\n\t\tconst d3 = _vab.dot( _vbp );\n\t\tconst d4 = _vac.dot( _vbp );\n\t\tif ( d3 >= 0 && d4 <= d3 ) {\n\n\t\t\t// vertex region of B; barycentric coords (0, 1, 0)\n\t\t\treturn target.copy( b );\n\n\t\t}\n\n\t\tconst vc = d1 * d4 - d3 * d2;\n\t\tif ( vc <= 0 && d1 >= 0 && d3 <= 0 ) {\n\n\t\t\tv = d1 / ( d1 - d3 );\n\t\t\t// edge region of AB; barycentric coords (1-v, v, 0)\n\t\t\treturn target.copy( a ).addScaledVector( _vab, v );\n\n\t\t}\n\n\t\t_vcp.subVectors( p, c );\n\t\tconst d5 = _vab.dot( _vcp );\n\t\tconst d6 = _vac.dot( _vcp );\n\t\tif ( d6 >= 0 && d5 <= d6 ) {\n\n\t\t\t// vertex region of C; barycentric coords (0, 0, 1)\n\t\t\treturn target.copy( c );\n\n\t\t}\n\n\t\tconst vb = d5 * d2 - d1 * d6;\n\t\tif ( vb <= 0 && d2 >= 0 && d6 <= 0 ) {\n\n\t\t\tw = d2 / ( d2 - d6 );\n\t\t\t// edge region of AC; barycentric coords (1-w, 0, w)\n\t\t\treturn target.copy( a ).addScaledVector( _vac, w );\n\n\t\t}\n\n\t\tconst va = d3 * d6 - d5 * d4;\n\t\tif ( va <= 0 && ( d4 - d3 ) >= 0 && ( d5 - d6 ) >= 0 ) {\n\n\t\t\t_vbc.subVectors( c, b );\n\t\t\tw = ( d4 - d3 ) / ( ( d4 - d3 ) + ( d5 - d6 ) );\n\t\t\t// edge region of BC; barycentric coords (0, 1-w, w)\n\t\t\treturn target.copy( b ).addScaledVector( _vbc, w ); // edge region of BC\n\n\t\t}\n\n\t\t// face region\n\t\tconst denom = 1 / ( va + vb + vc );\n\t\t// u = va * denom\n\t\tv = vb * denom;\n\t\tw = vc * denom;\n\n\t\treturn target.copy( a ).addScaledVector( _vab, v ).addScaledVector( _vac, w );\n\n\t}\n\n\tequals( triangle ) {\n\n\t\treturn triangle.a.equals( this.a ) && triangle.b.equals( this.b ) && triangle.c.equals( this.c );\n\n\t}\n\n}\n\nlet materialId = 0;\n\nclass Material extends EventDispatcher {\n\n\tconstructor() {\n\n\t\tsuper();\n\n\t\tthis.isMaterial = true;\n\n\t\tObject.defineProperty( this, 'id', { value: materialId ++ } );\n\n\t\tthis.uuid = generateUUID();\n\n\t\tthis.name = '';\n\t\tthis.type = 'Material';\n\n\t\tthis.blending = NormalBlending;\n\t\tthis.side = FrontSide;\n\t\tthis.vertexColors = false;\n\n\t\tthis.opacity = 1;\n\t\tthis.transparent = false;\n\n\t\tthis.blendSrc = SrcAlphaFactor;\n\t\tthis.blendDst = OneMinusSrcAlphaFactor;\n\t\tthis.blendEquation = AddEquation;\n\t\tthis.blendSrcAlpha = null;\n\t\tthis.blendDstAlpha = null;\n\t\tthis.blendEquationAlpha = null;\n\n\t\tthis.depthFunc = LessEqualDepth;\n\t\tthis.depthTest = true;\n\t\tthis.depthWrite = true;\n\n\t\tthis.stencilWriteMask = 0xff;\n\t\tthis.stencilFunc = AlwaysStencilFunc;\n\t\tthis.stencilRef = 0;\n\t\tthis.stencilFuncMask = 0xff;\n\t\tthis.stencilFail = KeepStencilOp;\n\t\tthis.stencilZFail = KeepStencilOp;\n\t\tthis.stencilZPass = KeepStencilOp;\n\t\tthis.stencilWrite = false;\n\n\t\tthis.clippingPlanes = null;\n\t\tthis.clipIntersection = false;\n\t\tthis.clipShadows = false;\n\n\t\tthis.shadowSide = null;\n\n\t\tthis.colorWrite = true;\n\n\t\tthis.precision = null; // override the renderer's default precision for this material\n\n\t\tthis.polygonOffset = false;\n\t\tthis.polygonOffsetFactor = 0;\n\t\tthis.polygonOffsetUnits = 0;\n\n\t\tthis.dithering = false;\n\n\t\tthis.alphaToCoverage = false;\n\t\tthis.premultipliedAlpha = false;\n\n\t\tthis.visible = true;\n\n\t\tthis.toneMapped = true;\n\n\t\tthis.userData = {};\n\n\t\tthis.version = 0;\n\n\t\tthis._alphaTest = 0;\n\n\t}\n\n\tget alphaTest() {\n\n\t\treturn this._alphaTest;\n\n\t}\n\n\tset alphaTest( value ) {\n\n\t\tif ( this._alphaTest > 0 !== value > 0 ) {\n\n\t\t\tthis.version ++;\n\n\t\t}\n\n\t\tthis._alphaTest = value;\n\n\t}\n\n\tonBuild( /* shaderobject, renderer */ ) {}\n\n\tonBeforeRender( /* renderer, scene, camera, geometry, object, group */ ) {}\n\n\tonBeforeCompile( /* shaderobject, renderer */ ) {}\n\n\tcustomProgramCacheKey() {\n\n\t\treturn this.onBeforeCompile.toString();\n\n\t}\n\n\tsetValues( values ) {\n\n\t\tif ( values === undefined ) return;\n\n\t\tfor ( const key in values ) {\n\n\t\t\tconst newValue = values[ key ];\n\n\t\t\tif ( newValue === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.Material: \\'' + key + '\\' parameter is undefined.' );\n\t\t\t\tcontinue;\n\n\t\t\t}\n\n\t\t\t// for backward compatibility if shading is set in the constructor\n\t\t\tif ( key === 'shading' ) {\n\n\t\t\t\tconsole.warn( 'THREE.' + this.type + ': .shading has been removed. Use the boolean .flatShading instead.' );\n\t\t\t\tthis.flatShading = ( newValue === FlatShading ) ? true : false;\n\t\t\t\tcontinue;\n\n\t\t\t}\n\n\t\t\tconst currentValue = this[ key ];\n\n\t\t\tif ( currentValue === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.' + this.type + ': \\'' + key + '\\' is not a property of this material.' );\n\t\t\t\tcontinue;\n\n\t\t\t}\n\n\t\t\tif ( currentValue && currentValue.isColor ) {\n\n\t\t\t\tcurrentValue.set( newValue );\n\n\t\t\t} else if ( ( currentValue && currentValue.isVector3 ) && ( newValue && newValue.isVector3 ) ) {\n\n\t\t\t\tcurrentValue.copy( newValue );\n\n\t\t\t} else {\n\n\t\t\t\tthis[ key ] = newValue;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\ttoJSON( meta ) {\n\n\t\tconst isRootObject = ( meta === undefined || typeof meta === 'string' );\n\n\t\tif ( isRootObject ) {\n\n\t\t\tmeta = {\n\t\t\t\ttextures: {},\n\t\t\t\timages: {}\n\t\t\t};\n\n\t\t}\n\n\t\tconst data = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Material',\n\t\t\t\tgenerator: 'Material.toJSON'\n\t\t\t}\n\t\t};\n\n\t\t// standard Material serialization\n\t\tdata.uuid = this.uuid;\n\t\tdata.type = this.type;\n\n\t\tif ( this.name !== '' ) data.name = this.name;\n\n\t\tif ( this.color && this.color.isColor ) data.color = this.color.getHex();\n\n\t\tif ( this.roughness !== undefined ) data.roughness = this.roughness;\n\t\tif ( this.metalness !== undefined ) data.metalness = this.metalness;\n\n\t\tif ( this.sheen !== undefined ) data.sheen = this.sheen;\n\t\tif ( this.sheenColor && this.sheenColor.isColor ) data.sheenColor = this.sheenColor.getHex();\n\t\tif ( this.sheenRoughness !== undefined ) data.sheenRoughness = this.sheenRoughness;\n\t\tif ( this.emissive && this.emissive.isColor ) data.emissive = this.emissive.getHex();\n\t\tif ( this.emissiveIntensity && this.emissiveIntensity !== 1 ) data.emissiveIntensity = this.emissiveIntensity;\n\n\t\tif ( this.specular && this.specular.isColor ) data.specular = this.specular.getHex();\n\t\tif ( this.specularIntensity !== undefined ) data.specularIntensity = this.specularIntensity;\n\t\tif ( this.specularColor && this.specularColor.isColor ) data.specularColor = this.specularColor.getHex();\n\t\tif ( this.shininess !== undefined ) data.shininess = this.shininess;\n\t\tif ( this.clearcoat !== undefined ) data.clearcoat = this.clearcoat;\n\t\tif ( this.clearcoatRoughness !== undefined ) data.clearcoatRoughness = this.clearcoatRoughness;\n\n\t\tif ( this.clearcoatMap && this.clearcoatMap.isTexture ) {\n\n\t\t\tdata.clearcoatMap = this.clearcoatMap.toJSON( meta ).uuid;\n\n\t\t}\n\n\t\tif ( this.clearcoatRoughnessMap && this.clearcoatRoughnessMap.isTexture ) {\n\n\t\t\tdata.clearcoatRoughnessMap = this.clearcoatRoughnessMap.toJSON( meta ).uuid;\n\n\t\t}\n\n\t\tif ( this.clearcoatNormalMap && this.clearcoatNormalMap.isTexture ) {\n\n\t\t\tdata.clearcoatNormalMap = this.clearcoatNormalMap.toJSON( meta ).uuid;\n\t\t\tdata.clearcoatNormalScale = this.clearcoatNormalScale.toArray();\n\n\t\t}\n\n\t\tif ( this.iridescence !== undefined ) data.iridescence = this.iridescence;\n\t\tif ( this.iridescenceIOR !== undefined ) data.iridescenceIOR = this.iridescenceIOR;\n\t\tif ( this.iridescenceThicknessRange !== undefined ) data.iridescenceThicknessRange = this.iridescenceThicknessRange;\n\n\t\tif ( this.iridescenceMap && this.iridescenceMap.isTexture ) {\n\n\t\t\tdata.iridescenceMap = this.iridescenceMap.toJSON( meta ).uuid;\n\n\t\t}\n\n\t\tif ( this.iridescenceThicknessMap && this.iridescenceThicknessMap.isTexture ) {\n\n\t\t\tdata.iridescenceThicknessMap = this.iridescenceThicknessMap.toJSON( meta ).uuid;\n\n\t\t}\n\n\t\tif ( this.map && this.map.isTexture ) data.map = this.map.toJSON( meta ).uuid;\n\t\tif ( this.matcap && this.matcap.isTexture ) data.matcap = this.matcap.toJSON( meta ).uuid;\n\t\tif ( this.alphaMap && this.alphaMap.isTexture ) data.alphaMap = this.alphaMap.toJSON( meta ).uuid;\n\n\t\tif ( this.lightMap && this.lightMap.isTexture ) {\n\n\t\t\tdata.lightMap = this.lightMap.toJSON( meta ).uuid;\n\t\t\tdata.lightMapIntensity = this.lightMapIntensity;\n\n\t\t}\n\n\t\tif ( this.aoMap && this.aoMap.isTexture ) {\n\n\t\t\tdata.aoMap = this.aoMap.toJSON( meta ).uuid;\n\t\t\tdata.aoMapIntensity = this.aoMapIntensity;\n\n\t\t}\n\n\t\tif ( this.bumpMap && this.bumpMap.isTexture ) {\n\n\t\t\tdata.bumpMap = this.bumpMap.toJSON( meta ).uuid;\n\t\t\tdata.bumpScale = this.bumpScale;\n\n\t\t}\n\n\t\tif ( this.normalMap && this.normalMap.isTexture ) {\n\n\t\t\tdata.normalMap = this.normalMap.toJSON( meta ).uuid;\n\t\t\tdata.normalMapType = this.normalMapType;\n\t\t\tdata.normalScale = this.normalScale.toArray();\n\n\t\t}\n\n\t\tif ( this.displacementMap && this.displacementMap.isTexture ) {\n\n\t\t\tdata.displacementMap = this.displacementMap.toJSON( meta ).uuid;\n\t\t\tdata.displacementScale = this.displacementScale;\n\t\t\tdata.displacementBias = this.displacementBias;\n\n\t\t}\n\n\t\tif ( this.roughnessMap && this.roughnessMap.isTexture ) data.roughnessMap = this.roughnessMap.toJSON( meta ).uuid;\n\t\tif ( this.metalnessMap && this.metalnessMap.isTexture ) data.metalnessMap = this.metalnessMap.toJSON( meta ).uuid;\n\n\t\tif ( this.emissiveMap && this.emissiveMap.isTexture ) data.emissiveMap = this.emissiveMap.toJSON( meta ).uuid;\n\t\tif ( this.specularMap && this.specularMap.isTexture ) data.specularMap = this.specularMap.toJSON( meta ).uuid;\n\t\tif ( this.specularIntensityMap && this.specularIntensityMap.isTexture ) data.specularIntensityMap = this.specularIntensityMap.toJSON( meta ).uuid;\n\t\tif ( this.specularColorMap && this.specularColorMap.isTexture ) data.specularColorMap = this.specularColorMap.toJSON( meta ).uuid;\n\n\t\tif ( this.envMap && this.envMap.isTexture ) {\n\n\t\t\tdata.envMap = this.envMap.toJSON( meta ).uuid;\n\n\t\t\tif ( this.combine !== undefined ) data.combine = this.combine;\n\n\t\t}\n\n\t\tif ( this.envMapIntensity !== undefined ) data.envMapIntensity = this.envMapIntensity;\n\t\tif ( this.reflectivity !== undefined ) data.reflectivity = this.reflectivity;\n\t\tif ( this.refractionRatio !== undefined ) data.refractionRatio = this.refractionRatio;\n\n\t\tif ( this.gradientMap && this.gradientMap.isTexture ) {\n\n\t\t\tdata.gradientMap = this.gradientMap.toJSON( meta ).uuid;\n\n\t\t}\n\n\t\tif ( this.transmission !== undefined ) data.transmission = this.transmission;\n\t\tif ( this.transmissionMap && this.transmissionMap.isTexture ) data.transmissionMap = this.transmissionMap.toJSON( meta ).uuid;\n\t\tif ( this.thickness !== undefined ) data.thickness = this.thickness;\n\t\tif ( this.thicknessMap && this.thicknessMap.isTexture ) data.thicknessMap = this.thicknessMap.toJSON( meta ).uuid;\n\t\tif ( this.attenuationDistance !== undefined ) data.attenuationDistance = this.attenuationDistance;\n\t\tif ( this.attenuationColor !== undefined ) data.attenuationColor = this.attenuationColor.getHex();\n\n\t\tif ( this.size !== undefined ) data.size = this.size;\n\t\tif ( this.shadowSide !== null ) data.shadowSide = this.shadowSide;\n\t\tif ( this.sizeAttenuation !== undefined ) data.sizeAttenuation = this.sizeAttenuation;\n\n\t\tif ( this.blending !== NormalBlending ) data.blending = this.blending;\n\t\tif ( this.side !== FrontSide ) data.side = this.side;\n\t\tif ( this.vertexColors ) data.vertexColors = true;\n\n\t\tif ( this.opacity < 1 ) data.opacity = this.opacity;\n\t\tif ( this.transparent === true ) data.transparent = this.transparent;\n\n\t\tdata.depthFunc = this.depthFunc;\n\t\tdata.depthTest = this.depthTest;\n\t\tdata.depthWrite = this.depthWrite;\n\t\tdata.colorWrite = this.colorWrite;\n\n\t\tdata.stencilWrite = this.stencilWrite;\n\t\tdata.stencilWriteMask = this.stencilWriteMask;\n\t\tdata.stencilFunc = this.stencilFunc;\n\t\tdata.stencilRef = this.stencilRef;\n\t\tdata.stencilFuncMask = this.stencilFuncMask;\n\t\tdata.stencilFail = this.stencilFail;\n\t\tdata.stencilZFail = this.stencilZFail;\n\t\tdata.stencilZPass = this.stencilZPass;\n\n\t\t// rotation (SpriteMaterial)\n\t\tif ( this.rotation !== undefined && this.rotation !== 0 ) data.rotation = this.rotation;\n\n\t\tif ( this.polygonOffset === true ) data.polygonOffset = true;\n\t\tif ( this.polygonOffsetFactor !== 0 ) data.polygonOffsetFactor = this.polygonOffsetFactor;\n\t\tif ( this.polygonOffsetUnits !== 0 ) data.polygonOffsetUnits = this.polygonOffsetUnits;\n\n\t\tif ( this.linewidth !== undefined && this.linewidth !== 1 ) data.linewidth = this.linewidth;\n\t\tif ( this.dashSize !== undefined ) data.dashSize = this.dashSize;\n\t\tif ( this.gapSize !== undefined ) data.gapSize = this.gapSize;\n\t\tif ( this.scale !== undefined ) data.scale = this.scale;\n\n\t\tif ( this.dithering === true ) data.dithering = true;\n\n\t\tif ( this.alphaTest > 0 ) data.alphaTest = this.alphaTest;\n\t\tif ( this.alphaToCoverage === true ) data.alphaToCoverage = this.alphaToCoverage;\n\t\tif ( this.premultipliedAlpha === true ) data.premultipliedAlpha = this.premultipliedAlpha;\n\n\t\tif ( this.wireframe === true ) data.wireframe = this.wireframe;\n\t\tif ( this.wireframeLinewidth > 1 ) data.wireframeLinewidth = this.wireframeLinewidth;\n\t\tif ( this.wireframeLinecap !== 'round' ) data.wireframeLinecap = this.wireframeLinecap;\n\t\tif ( this.wireframeLinejoin !== 'round' ) data.wireframeLinejoin = this.wireframeLinejoin;\n\n\t\tif ( this.flatShading === true ) data.flatShading = this.flatShading;\n\n\t\tif ( this.visible === false ) data.visible = false;\n\n\t\tif ( this.toneMapped === false ) data.toneMapped = false;\n\n\t\tif ( this.fog === false ) data.fog = false;\n\n\t\tif ( JSON.stringify( this.userData ) !== '{}' ) data.userData = this.userData;\n\n\t\t// TODO: Copied from Object3D.toJSON\n\n\t\tfunction extractFromCache( cache ) {\n\n\t\t\tconst values = [];\n\n\t\t\tfor ( const key in cache ) {\n\n\t\t\t\tconst data = cache[ key ];\n\t\t\t\tdelete data.metadata;\n\t\t\t\tvalues.push( data );\n\n\t\t\t}\n\n\t\t\treturn values;\n\n\t\t}\n\n\t\tif ( isRootObject ) {\n\n\t\t\tconst textures = extractFromCache( meta.textures );\n\t\t\tconst images = extractFromCache( meta.images );\n\n\t\t\tif ( textures.length > 0 ) data.textures = textures;\n\t\t\tif ( images.length > 0 ) data.images = images;\n\n\t\t}\n\n\t\treturn data;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tthis.name = source.name;\n\n\t\tthis.blending = source.blending;\n\t\tthis.side = source.side;\n\t\tthis.vertexColors = source.vertexColors;\n\n\t\tthis.opacity = source.opacity;\n\t\tthis.transparent = source.transparent;\n\n\t\tthis.blendSrc = source.blendSrc;\n\t\tthis.blendDst = source.blendDst;\n\t\tthis.blendEquation = source.blendEquation;\n\t\tthis.blendSrcAlpha = source.blendSrcAlpha;\n\t\tthis.blendDstAlpha = source.blendDstAlpha;\n\t\tthis.blendEquationAlpha = source.blendEquationAlpha;\n\n\t\tthis.depthFunc = source.depthFunc;\n\t\tthis.depthTest = source.depthTest;\n\t\tthis.depthWrite = source.depthWrite;\n\n\t\tthis.stencilWriteMask = source.stencilWriteMask;\n\t\tthis.stencilFunc = source.stencilFunc;\n\t\tthis.stencilRef = source.stencilRef;\n\t\tthis.stencilFuncMask = source.stencilFuncMask;\n\t\tthis.stencilFail = source.stencilFail;\n\t\tthis.stencilZFail = source.stencilZFail;\n\t\tthis.stencilZPass = source.stencilZPass;\n\t\tthis.stencilWrite = source.stencilWrite;\n\n\t\tconst srcPlanes = source.clippingPlanes;\n\t\tlet dstPlanes = null;\n\n\t\tif ( srcPlanes !== null ) {\n\n\t\t\tconst n = srcPlanes.length;\n\t\t\tdstPlanes = new Array( n );\n\n\t\t\tfor ( let i = 0; i !== n; ++ i ) {\n\n\t\t\t\tdstPlanes[ i ] = srcPlanes[ i ].clone();\n\n\t\t\t}\n\n\t\t}\n\n\t\tthis.clippingPlanes = dstPlanes;\n\t\tthis.clipIntersection = source.clipIntersection;\n\t\tthis.clipShadows = source.clipShadows;\n\n\t\tthis.shadowSide = source.shadowSide;\n\n\t\tthis.colorWrite = source.colorWrite;\n\n\t\tthis.precision = source.precision;\n\n\t\tthis.polygonOffset = source.polygonOffset;\n\t\tthis.polygonOffsetFactor = source.polygonOffsetFactor;\n\t\tthis.polygonOffsetUnits = source.polygonOffsetUnits;\n\n\t\tthis.dithering = source.dithering;\n\n\t\tthis.alphaTest = source.alphaTest;\n\t\tthis.alphaToCoverage = source.alphaToCoverage;\n\t\tthis.premultipliedAlpha = source.premultipliedAlpha;\n\n\t\tthis.visible = source.visible;\n\n\t\tthis.toneMapped = source.toneMapped;\n\n\t\tthis.userData = JSON.parse( JSON.stringify( source.userData ) );\n\n\t\treturn this;\n\n\t}\n\n\tdispose() {\n\n\t\tthis.dispatchEvent( { type: 'dispose' } );\n\n\t}\n\n\tset needsUpdate( value ) {\n\n\t\tif ( value === true ) this.version ++;\n\n\t}\n\n\t// @deprecated since r131, f5803c62cc4a29d90744e9dc7811d086e354c1d8\n\n\tget vertexTangents() {\n\n\t\tconsole.warn( 'THREE.' + this.type + ': .vertexTangents has been removed.' );\n\t\treturn false;\n\n\t}\n\n\tset vertexTangents( value ) {\n\n\t\tconsole.warn( 'THREE.' + this.type + ': .vertexTangents has been removed.' );\n\n\t}\n\n}\n\nMaterial.fromType = function ( /*type*/ ) {\n\n\t// TODO: Behavior added in Materials.js\n\n\treturn null;\n\n};\n\nclass MeshBasicMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isMeshBasicMaterial = true;\n\n\t\tthis.type = 'MeshBasicMaterial';\n\n\t\tthis.color = new Color( 0xffffff ); // emissive\n\n\t\tthis.map = null;\n\n\t\tthis.lightMap = null;\n\t\tthis.lightMapIntensity = 1.0;\n\n\t\tthis.aoMap = null;\n\t\tthis.aoMapIntensity = 1.0;\n\n\t\tthis.specularMap = null;\n\n\t\tthis.alphaMap = null;\n\n\t\tthis.envMap = null;\n\t\tthis.combine = MultiplyOperation;\n\t\tthis.reflectivity = 1;\n\t\tthis.refractionRatio = 0.98;\n\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.wireframeLinecap = 'round';\n\t\tthis.wireframeLinejoin = 'round';\n\n\t\tthis.fog = true;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.color.copy( source.color );\n\n\t\tthis.map = source.map;\n\n\t\tthis.lightMap = source.lightMap;\n\t\tthis.lightMapIntensity = source.lightMapIntensity;\n\n\t\tthis.aoMap = source.aoMap;\n\t\tthis.aoMapIntensity = source.aoMapIntensity;\n\n\t\tthis.specularMap = source.specularMap;\n\n\t\tthis.alphaMap = source.alphaMap;\n\n\t\tthis.envMap = source.envMap;\n\t\tthis.combine = source.combine;\n\t\tthis.reflectivity = source.reflectivity;\n\t\tthis.refractionRatio = source.refractionRatio;\n\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\tthis.wireframeLinecap = source.wireframeLinecap;\n\t\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\n\t\tthis.fog = source.fog;\n\n\t\treturn this;\n\n\t}\n\n}\n\nconst _vector$9 = /*@__PURE__*/ new Vector3();\nconst _vector2$1 = /*@__PURE__*/ new Vector2();\n\nclass BufferAttribute {\n\n\tconstructor( array, itemSize, normalized ) {\n\n\t\tif ( Array.isArray( array ) ) {\n\n\t\t\tthrow new TypeError( 'THREE.BufferAttribute: array should be a Typed Array.' );\n\n\t\t}\n\n\t\tthis.isBufferAttribute = true;\n\n\t\tthis.name = '';\n\n\t\tthis.array = array;\n\t\tthis.itemSize = itemSize;\n\t\tthis.count = array !== undefined ? array.length / itemSize : 0;\n\t\tthis.normalized = normalized === true;\n\n\t\tthis.usage = StaticDrawUsage;\n\t\tthis.updateRange = { offset: 0, count: - 1 };\n\n\t\tthis.version = 0;\n\n\t}\n\n\tonUploadCallback() {}\n\n\tset needsUpdate( value ) {\n\n\t\tif ( value === true ) this.version ++;\n\n\t}\n\n\tsetUsage( value ) {\n\n\t\tthis.usage = value;\n\n\t\treturn this;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tthis.name = source.name;\n\t\tthis.array = new source.array.constructor( source.array );\n\t\tthis.itemSize = source.itemSize;\n\t\tthis.count = source.count;\n\t\tthis.normalized = source.normalized;\n\n\t\tthis.usage = source.usage;\n\n\t\treturn this;\n\n\t}\n\n\tcopyAt( index1, attribute, index2 ) {\n\n\t\tindex1 *= this.itemSize;\n\t\tindex2 *= attribute.itemSize;\n\n\t\tfor ( let i = 0, l = this.itemSize; i < l; i ++ ) {\n\n\t\t\tthis.array[ index1 + i ] = attribute.array[ index2 + i ];\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tcopyArray( array ) {\n\n\t\tthis.array.set( array );\n\n\t\treturn this;\n\n\t}\n\n\tcopyColorsArray( colors ) {\n\n\t\tconst array = this.array;\n\t\tlet offset = 0;\n\n\t\tfor ( let i = 0, l = colors.length; i < l; i ++ ) {\n\n\t\t\tlet color = colors[ i ];\n\n\t\t\tif ( color === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.BufferAttribute.copyColorsArray(): color is undefined', i );\n\t\t\t\tcolor = new Color();\n\n\t\t\t}\n\n\t\t\tarray[ offset ++ ] = color.r;\n\t\t\tarray[ offset ++ ] = color.g;\n\t\t\tarray[ offset ++ ] = color.b;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tcopyVector2sArray( vectors ) {\n\n\t\tconst array = this.array;\n\t\tlet offset = 0;\n\n\t\tfor ( let i = 0, l = vectors.length; i < l; i ++ ) {\n\n\t\t\tlet vector = vectors[ i ];\n\n\t\t\tif ( vector === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.BufferAttribute.copyVector2sArray(): vector is undefined', i );\n\t\t\t\tvector = new Vector2();\n\n\t\t\t}\n\n\t\t\tarray[ offset ++ ] = vector.x;\n\t\t\tarray[ offset ++ ] = vector.y;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tcopyVector3sArray( vectors ) {\n\n\t\tconst array = this.array;\n\t\tlet offset = 0;\n\n\t\tfor ( let i = 0, l = vectors.length; i < l; i ++ ) {\n\n\t\t\tlet vector = vectors[ i ];\n\n\t\t\tif ( vector === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.BufferAttribute.copyVector3sArray(): vector is undefined', i );\n\t\t\t\tvector = new Vector3();\n\n\t\t\t}\n\n\t\t\tarray[ offset ++ ] = vector.x;\n\t\t\tarray[ offset ++ ] = vector.y;\n\t\t\tarray[ offset ++ ] = vector.z;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tcopyVector4sArray( vectors ) {\n\n\t\tconst array = this.array;\n\t\tlet offset = 0;\n\n\t\tfor ( let i = 0, l = vectors.length; i < l; i ++ ) {\n\n\t\t\tlet vector = vectors[ i ];\n\n\t\t\tif ( vector === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.BufferAttribute.copyVector4sArray(): vector is undefined', i );\n\t\t\t\tvector = new Vector4();\n\n\t\t\t}\n\n\t\t\tarray[ offset ++ ] = vector.x;\n\t\t\tarray[ offset ++ ] = vector.y;\n\t\t\tarray[ offset ++ ] = vector.z;\n\t\t\tarray[ offset ++ ] = vector.w;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tapplyMatrix3( m ) {\n\n\t\tif ( this.itemSize === 2 ) {\n\n\t\t\tfor ( let i = 0, l = this.count; i < l; i ++ ) {\n\n\t\t\t\t_vector2$1.fromBufferAttribute( this, i );\n\t\t\t\t_vector2$1.applyMatrix3( m );\n\n\t\t\t\tthis.setXY( i, _vector2$1.x, _vector2$1.y );\n\n\t\t\t}\n\n\t\t} else if ( this.itemSize === 3 ) {\n\n\t\t\tfor ( let i = 0, l = this.count; i < l; i ++ ) {\n\n\t\t\t\t_vector$9.fromBufferAttribute( this, i );\n\t\t\t\t_vector$9.applyMatrix3( m );\n\n\t\t\t\tthis.setXYZ( i, _vector$9.x, _vector$9.y, _vector$9.z );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tapplyMatrix4( m ) {\n\n\t\tfor ( let i = 0, l = this.count; i < l; i ++ ) {\n\n\t\t\t_vector$9.fromBufferAttribute( this, i );\n\n\t\t\t_vector$9.applyMatrix4( m );\n\n\t\t\tthis.setXYZ( i, _vector$9.x, _vector$9.y, _vector$9.z );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tapplyNormalMatrix( m ) {\n\n\t\tfor ( let i = 0, l = this.count; i < l; i ++ ) {\n\n\t\t\t_vector$9.fromBufferAttribute( this, i );\n\n\t\t\t_vector$9.applyNormalMatrix( m );\n\n\t\t\tthis.setXYZ( i, _vector$9.x, _vector$9.y, _vector$9.z );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\ttransformDirection( m ) {\n\n\t\tfor ( let i = 0, l = this.count; i < l; i ++ ) {\n\n\t\t\t_vector$9.fromBufferAttribute( this, i );\n\n\t\t\t_vector$9.transformDirection( m );\n\n\t\t\tthis.setXYZ( i, _vector$9.x, _vector$9.y, _vector$9.z );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tset( value, offset = 0 ) {\n\n\t\tthis.array.set( value, offset );\n\n\t\treturn this;\n\n\t}\n\n\tgetX( index ) {\n\n\t\treturn this.array[ index * this.itemSize ];\n\n\t}\n\n\tsetX( index, x ) {\n\n\t\tthis.array[ index * this.itemSize ] = x;\n\n\t\treturn this;\n\n\t}\n\n\tgetY( index ) {\n\n\t\treturn this.array[ index * this.itemSize + 1 ];\n\n\t}\n\n\tsetY( index, y ) {\n\n\t\tthis.array[ index * this.itemSize + 1 ] = y;\n\n\t\treturn this;\n\n\t}\n\n\tgetZ( index ) {\n\n\t\treturn this.array[ index * this.itemSize + 2 ];\n\n\t}\n\n\tsetZ( index, z ) {\n\n\t\tthis.array[ index * this.itemSize + 2 ] = z;\n\n\t\treturn this;\n\n\t}\n\n\tgetW( index ) {\n\n\t\treturn this.array[ index * this.itemSize + 3 ];\n\n\t}\n\n\tsetW( index, w ) {\n\n\t\tthis.array[ index * this.itemSize + 3 ] = w;\n\n\t\treturn this;\n\n\t}\n\n\tsetXY( index, x, y ) {\n\n\t\tindex *= this.itemSize;\n\n\t\tthis.array[ index + 0 ] = x;\n\t\tthis.array[ index + 1 ] = y;\n\n\t\treturn this;\n\n\t}\n\n\tsetXYZ( index, x, y, z ) {\n\n\t\tindex *= this.itemSize;\n\n\t\tthis.array[ index + 0 ] = x;\n\t\tthis.array[ index + 1 ] = y;\n\t\tthis.array[ index + 2 ] = z;\n\n\t\treturn this;\n\n\t}\n\n\tsetXYZW( index, x, y, z, w ) {\n\n\t\tindex *= this.itemSize;\n\n\t\tthis.array[ index + 0 ] = x;\n\t\tthis.array[ index + 1 ] = y;\n\t\tthis.array[ index + 2 ] = z;\n\t\tthis.array[ index + 3 ] = w;\n\n\t\treturn this;\n\n\t}\n\n\tonUpload( callback ) {\n\n\t\tthis.onUploadCallback = callback;\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor( this.array, this.itemSize ).copy( this );\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = {\n\t\t\titemSize: this.itemSize,\n\t\t\ttype: this.array.constructor.name,\n\t\t\tarray: Array.prototype.slice.call( this.array ),\n\t\t\tnormalized: this.normalized\n\t\t};\n\n\t\tif ( this.name !== '' ) data.name = this.name;\n\t\tif ( this.usage !== StaticDrawUsage ) data.usage = this.usage;\n\t\tif ( this.updateRange.offset !== 0 || this.updateRange.count !== - 1 ) data.updateRange = this.updateRange;\n\n\t\treturn data;\n\n\t}\n\n}\n\n//\n\nclass Int8BufferAttribute extends BufferAttribute {\n\n\tconstructor( array, itemSize, normalized ) {\n\n\t\tsuper( new Int8Array( array ), itemSize, normalized );\n\n\t}\n\n}\n\nclass Uint8BufferAttribute extends BufferAttribute {\n\n\tconstructor( array, itemSize, normalized ) {\n\n\t\tsuper( new Uint8Array( array ), itemSize, normalized );\n\n\t}\n\n}\n\nclass Uint8ClampedBufferAttribute extends BufferAttribute {\n\n\tconstructor( array, itemSize, normalized ) {\n\n\t\tsuper( new Uint8ClampedArray( array ), itemSize, normalized );\n\n\t}\n\n}\n\nclass Int16BufferAttribute extends BufferAttribute {\n\n\tconstructor( array, itemSize, normalized ) {\n\n\t\tsuper( new Int16Array( array ), itemSize, normalized );\n\n\t}\n\n}\n\nclass Uint16BufferAttribute extends BufferAttribute {\n\n\tconstructor( array, itemSize, normalized ) {\n\n\t\tsuper( new Uint16Array( array ), itemSize, normalized );\n\n\t}\n\n}\n\nclass Int32BufferAttribute extends BufferAttribute {\n\n\tconstructor( array, itemSize, normalized ) {\n\n\t\tsuper( new Int32Array( array ), itemSize, normalized );\n\n\t}\n\n}\n\nclass Uint32BufferAttribute extends BufferAttribute {\n\n\tconstructor( array, itemSize, normalized ) {\n\n\t\tsuper( new Uint32Array( array ), itemSize, normalized );\n\n\t}\n\n}\n\nclass Float16BufferAttribute extends BufferAttribute {\n\n\tconstructor( array, itemSize, normalized ) {\n\n\t\tsuper( new Uint16Array( array ), itemSize, normalized );\n\n\t\tthis.isFloat16BufferAttribute = true;\n\n\t}\n\n}\n\n\nclass Float32BufferAttribute extends BufferAttribute {\n\n\tconstructor( array, itemSize, normalized ) {\n\n\t\tsuper( new Float32Array( array ), itemSize, normalized );\n\n\t}\n\n}\n\nclass Float64BufferAttribute extends BufferAttribute {\n\n\tconstructor( array, itemSize, normalized ) {\n\n\t\tsuper( new Float64Array( array ), itemSize, normalized );\n\n\t}\n\n}\n\nlet _id$1 = 0;\n\nconst _m1 = /*@__PURE__*/ new Matrix4();\nconst _obj = /*@__PURE__*/ new Object3D();\nconst _offset = /*@__PURE__*/ new Vector3();\nconst _box$1 = /*@__PURE__*/ new Box3();\nconst _boxMorphTargets = /*@__PURE__*/ new Box3();\nconst _vector$8 = /*@__PURE__*/ new Vector3();\n\nclass BufferGeometry extends EventDispatcher {\n\n\tconstructor() {\n\n\t\tsuper();\n\n\t\tthis.isBufferGeometry = true;\n\n\t\tObject.defineProperty( this, 'id', { value: _id$1 ++ } );\n\n\t\tthis.uuid = generateUUID();\n\n\t\tthis.name = '';\n\t\tthis.type = 'BufferGeometry';\n\n\t\tthis.index = null;\n\t\tthis.attributes = {};\n\n\t\tthis.morphAttributes = {};\n\t\tthis.morphTargetsRelative = false;\n\n\t\tthis.groups = [];\n\n\t\tthis.boundingBox = null;\n\t\tthis.boundingSphere = null;\n\n\t\tthis.drawRange = { start: 0, count: Infinity };\n\n\t\tthis.userData = {};\n\n\t}\n\n\tgetIndex() {\n\n\t\treturn this.index;\n\n\t}\n\n\tsetIndex( index ) {\n\n\t\tif ( Array.isArray( index ) ) {\n\n\t\t\tthis.index = new ( arrayNeedsUint32( index ) ? Uint32BufferAttribute : Uint16BufferAttribute )( index, 1 );\n\n\t\t} else {\n\n\t\t\tthis.index = index;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tgetAttribute( name ) {\n\n\t\treturn this.attributes[ name ];\n\n\t}\n\n\tsetAttribute( name, attribute ) {\n\n\t\tthis.attributes[ name ] = attribute;\n\n\t\treturn this;\n\n\t}\n\n\tdeleteAttribute( name ) {\n\n\t\tdelete this.attributes[ name ];\n\n\t\treturn this;\n\n\t}\n\n\thasAttribute( name ) {\n\n\t\treturn this.attributes[ name ] !== undefined;\n\n\t}\n\n\taddGroup( start, count, materialIndex = 0 ) {\n\n\t\tthis.groups.push( {\n\n\t\t\tstart: start,\n\t\t\tcount: count,\n\t\t\tmaterialIndex: materialIndex\n\n\t\t} );\n\n\t}\n\n\tclearGroups() {\n\n\t\tthis.groups = [];\n\n\t}\n\n\tsetDrawRange( start, count ) {\n\n\t\tthis.drawRange.start = start;\n\t\tthis.drawRange.count = count;\n\n\t}\n\n\tapplyMatrix4( matrix ) {\n\n\t\tconst position = this.attributes.position;\n\n\t\tif ( position !== undefined ) {\n\n\t\t\tposition.applyMatrix4( matrix );\n\n\t\t\tposition.needsUpdate = true;\n\n\t\t}\n\n\t\tconst normal = this.attributes.normal;\n\n\t\tif ( normal !== undefined ) {\n\n\t\t\tconst normalMatrix = new Matrix3().getNormalMatrix( matrix );\n\n\t\t\tnormal.applyNormalMatrix( normalMatrix );\n\n\t\t\tnormal.needsUpdate = true;\n\n\t\t}\n\n\t\tconst tangent = this.attributes.tangent;\n\n\t\tif ( tangent !== undefined ) {\n\n\t\t\ttangent.transformDirection( matrix );\n\n\t\t\ttangent.needsUpdate = true;\n\n\t\t}\n\n\t\tif ( this.boundingBox !== null ) {\n\n\t\t\tthis.computeBoundingBox();\n\n\t\t}\n\n\t\tif ( this.boundingSphere !== null ) {\n\n\t\t\tthis.computeBoundingSphere();\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tapplyQuaternion( q ) {\n\n\t\t_m1.makeRotationFromQuaternion( q );\n\n\t\tthis.applyMatrix4( _m1 );\n\n\t\treturn this;\n\n\t}\n\n\trotateX( angle ) {\n\n\t\t// rotate geometry around world x-axis\n\n\t\t_m1.makeRotationX( angle );\n\n\t\tthis.applyMatrix4( _m1 );\n\n\t\treturn this;\n\n\t}\n\n\trotateY( angle ) {\n\n\t\t// rotate geometry around world y-axis\n\n\t\t_m1.makeRotationY( angle );\n\n\t\tthis.applyMatrix4( _m1 );\n\n\t\treturn this;\n\n\t}\n\n\trotateZ( angle ) {\n\n\t\t// rotate geometry around world z-axis\n\n\t\t_m1.makeRotationZ( angle );\n\n\t\tthis.applyMatrix4( _m1 );\n\n\t\treturn this;\n\n\t}\n\n\ttranslate( x, y, z ) {\n\n\t\t// translate geometry\n\n\t\t_m1.makeTranslation( x, y, z );\n\n\t\tthis.applyMatrix4( _m1 );\n\n\t\treturn this;\n\n\t}\n\n\tscale( x, y, z ) {\n\n\t\t// scale geometry\n\n\t\t_m1.makeScale( x, y, z );\n\n\t\tthis.applyMatrix4( _m1 );\n\n\t\treturn this;\n\n\t}\n\n\tlookAt( vector ) {\n\n\t\t_obj.lookAt( vector );\n\n\t\t_obj.updateMatrix();\n\n\t\tthis.applyMatrix4( _obj.matrix );\n\n\t\treturn this;\n\n\t}\n\n\tcenter() {\n\n\t\tthis.computeBoundingBox();\n\n\t\tthis.boundingBox.getCenter( _offset ).negate();\n\n\t\tthis.translate( _offset.x, _offset.y, _offset.z );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromPoints( points ) {\n\n\t\tconst position = [];\n\n\t\tfor ( let i = 0, l = points.length; i < l; i ++ ) {\n\n\t\t\tconst point = points[ i ];\n\t\t\tposition.push( point.x, point.y, point.z || 0 );\n\n\t\t}\n\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( position, 3 ) );\n\n\t\treturn this;\n\n\t}\n\n\tcomputeBoundingBox() {\n\n\t\tif ( this.boundingBox === null ) {\n\n\t\t\tthis.boundingBox = new Box3();\n\n\t\t}\n\n\t\tconst position = this.attributes.position;\n\t\tconst morphAttributesPosition = this.morphAttributes.position;\n\n\t\tif ( position && position.isGLBufferAttribute ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometry.computeBoundingBox(): GLBufferAttribute requires a manual bounding box. Alternatively set \"mesh.frustumCulled\" to \"false\".', this );\n\n\t\t\tthis.boundingBox.set(\n\t\t\t\tnew Vector3( - Infinity, - Infinity, - Infinity ),\n\t\t\t\tnew Vector3( + Infinity, + Infinity, + Infinity )\n\t\t\t);\n\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( position !== undefined ) {\n\n\t\t\tthis.boundingBox.setFromBufferAttribute( position );\n\n\t\t\t// process morph attributes if present\n\n\t\t\tif ( morphAttributesPosition ) {\n\n\t\t\t\tfor ( let i = 0, il = morphAttributesPosition.length; i < il; i ++ ) {\n\n\t\t\t\t\tconst morphAttribute = morphAttributesPosition[ i ];\n\t\t\t\t\t_box$1.setFromBufferAttribute( morphAttribute );\n\n\t\t\t\t\tif ( this.morphTargetsRelative ) {\n\n\t\t\t\t\t\t_vector$8.addVectors( this.boundingBox.min, _box$1.min );\n\t\t\t\t\t\tthis.boundingBox.expandByPoint( _vector$8 );\n\n\t\t\t\t\t\t_vector$8.addVectors( this.boundingBox.max, _box$1.max );\n\t\t\t\t\t\tthis.boundingBox.expandByPoint( _vector$8 );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tthis.boundingBox.expandByPoint( _box$1.min );\n\t\t\t\t\t\tthis.boundingBox.expandByPoint( _box$1.max );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tthis.boundingBox.makeEmpty();\n\n\t\t}\n\n\t\tif ( isNaN( this.boundingBox.min.x ) || isNaN( this.boundingBox.min.y ) || isNaN( this.boundingBox.min.z ) ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometry.computeBoundingBox(): Computed min/max have NaN values. The \"position\" attribute is likely to have NaN values.', this );\n\n\t\t}\n\n\t}\n\n\tcomputeBoundingSphere() {\n\n\t\tif ( this.boundingSphere === null ) {\n\n\t\t\tthis.boundingSphere = new Sphere();\n\n\t\t}\n\n\t\tconst position = this.attributes.position;\n\t\tconst morphAttributesPosition = this.morphAttributes.position;\n\n\t\tif ( position && position.isGLBufferAttribute ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometry.computeBoundingSphere(): GLBufferAttribute requires a manual bounding sphere. Alternatively set \"mesh.frustumCulled\" to \"false\".', this );\n\n\t\t\tthis.boundingSphere.set( new Vector3(), Infinity );\n\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( position ) {\n\n\t\t\t// first, find the center of the bounding sphere\n\n\t\t\tconst center = this.boundingSphere.center;\n\n\t\t\t_box$1.setFromBufferAttribute( position );\n\n\t\t\t// process morph attributes if present\n\n\t\t\tif ( morphAttributesPosition ) {\n\n\t\t\t\tfor ( let i = 0, il = morphAttributesPosition.length; i < il; i ++ ) {\n\n\t\t\t\t\tconst morphAttribute = morphAttributesPosition[ i ];\n\t\t\t\t\t_boxMorphTargets.setFromBufferAttribute( morphAttribute );\n\n\t\t\t\t\tif ( this.morphTargetsRelative ) {\n\n\t\t\t\t\t\t_vector$8.addVectors( _box$1.min, _boxMorphTargets.min );\n\t\t\t\t\t\t_box$1.expandByPoint( _vector$8 );\n\n\t\t\t\t\t\t_vector$8.addVectors( _box$1.max, _boxMorphTargets.max );\n\t\t\t\t\t\t_box$1.expandByPoint( _vector$8 );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t_box$1.expandByPoint( _boxMorphTargets.min );\n\t\t\t\t\t\t_box$1.expandByPoint( _boxMorphTargets.max );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t_box$1.getCenter( center );\n\n\t\t\t// second, try to find a boundingSphere with a radius smaller than the\n\t\t\t// boundingSphere of the boundingBox: sqrt(3) smaller in the best case\n\n\t\t\tlet maxRadiusSq = 0;\n\n\t\t\tfor ( let i = 0, il = position.count; i < il; i ++ ) {\n\n\t\t\t\t_vector$8.fromBufferAttribute( position, i );\n\n\t\t\t\tmaxRadiusSq = Math.max( maxRadiusSq, center.distanceToSquared( _vector$8 ) );\n\n\t\t\t}\n\n\t\t\t// process morph attributes if present\n\n\t\t\tif ( morphAttributesPosition ) {\n\n\t\t\t\tfor ( let i = 0, il = morphAttributesPosition.length; i < il; i ++ ) {\n\n\t\t\t\t\tconst morphAttribute = morphAttributesPosition[ i ];\n\t\t\t\t\tconst morphTargetsRelative = this.morphTargetsRelative;\n\n\t\t\t\t\tfor ( let j = 0, jl = morphAttribute.count; j < jl; j ++ ) {\n\n\t\t\t\t\t\t_vector$8.fromBufferAttribute( morphAttribute, j );\n\n\t\t\t\t\t\tif ( morphTargetsRelative ) {\n\n\t\t\t\t\t\t\t_offset.fromBufferAttribute( position, j );\n\t\t\t\t\t\t\t_vector$8.add( _offset );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tmaxRadiusSq = Math.max( maxRadiusSq, center.distanceToSquared( _vector$8 ) );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis.boundingSphere.radius = Math.sqrt( maxRadiusSq );\n\n\t\t\tif ( isNaN( this.boundingSphere.radius ) ) {\n\n\t\t\t\tconsole.error( 'THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The \"position\" attribute is likely to have NaN values.', this );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tcomputeTangents() {\n\n\t\tconst index = this.index;\n\t\tconst attributes = this.attributes;\n\n\t\t// based on http://www.terathon.com/code/tangent.html\n\t\t// (per vertex tangents)\n\n\t\tif ( index === null ||\n\t\t\t attributes.position === undefined ||\n\t\t\t attributes.normal === undefined ||\n\t\t\t attributes.uv === undefined ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometry: .computeTangents() failed. Missing required attributes (index, position, normal or uv)' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tconst indices = index.array;\n\t\tconst positions = attributes.position.array;\n\t\tconst normals = attributes.normal.array;\n\t\tconst uvs = attributes.uv.array;\n\n\t\tconst nVertices = positions.length / 3;\n\n\t\tif ( this.hasAttribute( 'tangent' ) === false ) {\n\n\t\t\tthis.setAttribute( 'tangent', new BufferAttribute( new Float32Array( 4 * nVertices ), 4 ) );\n\n\t\t}\n\n\t\tconst tangents = this.getAttribute( 'tangent' ).array;\n\n\t\tconst tan1 = [], tan2 = [];\n\n\t\tfor ( let i = 0; i < nVertices; i ++ ) {\n\n\t\t\ttan1[ i ] = new Vector3();\n\t\t\ttan2[ i ] = new Vector3();\n\n\t\t}\n\n\t\tconst vA = new Vector3(),\n\t\t\tvB = new Vector3(),\n\t\t\tvC = new Vector3(),\n\n\t\t\tuvA = new Vector2(),\n\t\t\tuvB = new Vector2(),\n\t\t\tuvC = new Vector2(),\n\n\t\t\tsdir = new Vector3(),\n\t\t\ttdir = new Vector3();\n\n\t\tfunction handleTriangle( a, b, c ) {\n\n\t\t\tvA.fromArray( positions, a * 3 );\n\t\t\tvB.fromArray( positions, b * 3 );\n\t\t\tvC.fromArray( positions, c * 3 );\n\n\t\t\tuvA.fromArray( uvs, a * 2 );\n\t\t\tuvB.fromArray( uvs, b * 2 );\n\t\t\tuvC.fromArray( uvs, c * 2 );\n\n\t\t\tvB.sub( vA );\n\t\t\tvC.sub( vA );\n\n\t\t\tuvB.sub( uvA );\n\t\t\tuvC.sub( uvA );\n\n\t\t\tconst r = 1.0 / ( uvB.x * uvC.y - uvC.x * uvB.y );\n\n\t\t\t// silently ignore degenerate uv triangles having coincident or colinear vertices\n\n\t\t\tif ( ! isFinite( r ) ) return;\n\n\t\t\tsdir.copy( vB ).multiplyScalar( uvC.y ).addScaledVector( vC, - uvB.y ).multiplyScalar( r );\n\t\t\ttdir.copy( vC ).multiplyScalar( uvB.x ).addScaledVector( vB, - uvC.x ).multiplyScalar( r );\n\n\t\t\ttan1[ a ].add( sdir );\n\t\t\ttan1[ b ].add( sdir );\n\t\t\ttan1[ c ].add( sdir );\n\n\t\t\ttan2[ a ].add( tdir );\n\t\t\ttan2[ b ].add( tdir );\n\t\t\ttan2[ c ].add( tdir );\n\n\t\t}\n\n\t\tlet groups = this.groups;\n\n\t\tif ( groups.length === 0 ) {\n\n\t\t\tgroups = [ {\n\t\t\t\tstart: 0,\n\t\t\t\tcount: indices.length\n\t\t\t} ];\n\n\t\t}\n\n\t\tfor ( let i = 0, il = groups.length; i < il; ++ i ) {\n\n\t\t\tconst group = groups[ i ];\n\n\t\t\tconst start = group.start;\n\t\t\tconst count = group.count;\n\n\t\t\tfor ( let j = start, jl = start + count; j < jl; j += 3 ) {\n\n\t\t\t\thandleTriangle(\n\t\t\t\t\tindices[ j + 0 ],\n\t\t\t\t\tindices[ j + 1 ],\n\t\t\t\t\tindices[ j + 2 ]\n\t\t\t\t);\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst tmp = new Vector3(), tmp2 = new Vector3();\n\t\tconst n = new Vector3(), n2 = new Vector3();\n\n\t\tfunction handleVertex( v ) {\n\n\t\t\tn.fromArray( normals, v * 3 );\n\t\t\tn2.copy( n );\n\n\t\t\tconst t = tan1[ v ];\n\n\t\t\t// Gram-Schmidt orthogonalize\n\n\t\t\ttmp.copy( t );\n\t\t\ttmp.sub( n.multiplyScalar( n.dot( t ) ) ).normalize();\n\n\t\t\t// Calculate handedness\n\n\t\t\ttmp2.crossVectors( n2, t );\n\t\t\tconst test = tmp2.dot( tan2[ v ] );\n\t\t\tconst w = ( test < 0.0 ) ? - 1.0 : 1.0;\n\n\t\t\ttangents[ v * 4 ] = tmp.x;\n\t\t\ttangents[ v * 4 + 1 ] = tmp.y;\n\t\t\ttangents[ v * 4 + 2 ] = tmp.z;\n\t\t\ttangents[ v * 4 + 3 ] = w;\n\n\t\t}\n\n\t\tfor ( let i = 0, il = groups.length; i < il; ++ i ) {\n\n\t\t\tconst group = groups[ i ];\n\n\t\t\tconst start = group.start;\n\t\t\tconst count = group.count;\n\n\t\t\tfor ( let j = start, jl = start + count; j < jl; j += 3 ) {\n\n\t\t\t\thandleVertex( indices[ j + 0 ] );\n\t\t\t\thandleVertex( indices[ j + 1 ] );\n\t\t\t\thandleVertex( indices[ j + 2 ] );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tcomputeVertexNormals() {\n\n\t\tconst index = this.index;\n\t\tconst positionAttribute = this.getAttribute( 'position' );\n\n\t\tif ( positionAttribute !== undefined ) {\n\n\t\t\tlet normalAttribute = this.getAttribute( 'normal' );\n\n\t\t\tif ( normalAttribute === undefined ) {\n\n\t\t\t\tnormalAttribute = new BufferAttribute( new Float32Array( positionAttribute.count * 3 ), 3 );\n\t\t\t\tthis.setAttribute( 'normal', normalAttribute );\n\n\t\t\t} else {\n\n\t\t\t\t// reset existing normals to zero\n\n\t\t\t\tfor ( let i = 0, il = normalAttribute.count; i < il; i ++ ) {\n\n\t\t\t\t\tnormalAttribute.setXYZ( i, 0, 0, 0 );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tconst pA = new Vector3(), pB = new Vector3(), pC = new Vector3();\n\t\t\tconst nA = new Vector3(), nB = new Vector3(), nC = new Vector3();\n\t\t\tconst cb = new Vector3(), ab = new Vector3();\n\n\t\t\t// indexed elements\n\n\t\t\tif ( index ) {\n\n\t\t\t\tfor ( let i = 0, il = index.count; i < il; i += 3 ) {\n\n\t\t\t\t\tconst vA = index.getX( i + 0 );\n\t\t\t\t\tconst vB = index.getX( i + 1 );\n\t\t\t\t\tconst vC = index.getX( i + 2 );\n\n\t\t\t\t\tpA.fromBufferAttribute( positionAttribute, vA );\n\t\t\t\t\tpB.fromBufferAttribute( positionAttribute, vB );\n\t\t\t\t\tpC.fromBufferAttribute( positionAttribute, vC );\n\n\t\t\t\t\tcb.subVectors( pC, pB );\n\t\t\t\t\tab.subVectors( pA, pB );\n\t\t\t\t\tcb.cross( ab );\n\n\t\t\t\t\tnA.fromBufferAttribute( normalAttribute, vA );\n\t\t\t\t\tnB.fromBufferAttribute( normalAttribute, vB );\n\t\t\t\t\tnC.fromBufferAttribute( normalAttribute, vC );\n\n\t\t\t\t\tnA.add( cb );\n\t\t\t\t\tnB.add( cb );\n\t\t\t\t\tnC.add( cb );\n\n\t\t\t\t\tnormalAttribute.setXYZ( vA, nA.x, nA.y, nA.z );\n\t\t\t\t\tnormalAttribute.setXYZ( vB, nB.x, nB.y, nB.z );\n\t\t\t\t\tnormalAttribute.setXYZ( vC, nC.x, nC.y, nC.z );\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t// non-indexed elements (unconnected triangle soup)\n\n\t\t\t\tfor ( let i = 0, il = positionAttribute.count; i < il; i += 3 ) {\n\n\t\t\t\t\tpA.fromBufferAttribute( positionAttribute, i + 0 );\n\t\t\t\t\tpB.fromBufferAttribute( positionAttribute, i + 1 );\n\t\t\t\t\tpC.fromBufferAttribute( positionAttribute, i + 2 );\n\n\t\t\t\t\tcb.subVectors( pC, pB );\n\t\t\t\t\tab.subVectors( pA, pB );\n\t\t\t\t\tcb.cross( ab );\n\n\t\t\t\t\tnormalAttribute.setXYZ( i + 0, cb.x, cb.y, cb.z );\n\t\t\t\t\tnormalAttribute.setXYZ( i + 1, cb.x, cb.y, cb.z );\n\t\t\t\t\tnormalAttribute.setXYZ( i + 2, cb.x, cb.y, cb.z );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis.normalizeNormals();\n\n\t\t\tnormalAttribute.needsUpdate = true;\n\n\t\t}\n\n\t}\n\n\tmerge( geometry, offset ) {\n\n\t\tif ( ! ( geometry && geometry.isBufferGeometry ) ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometry.merge(): geometry not an instance of THREE.BufferGeometry.', geometry );\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( offset === undefined ) {\n\n\t\t\toffset = 0;\n\n\t\t\tconsole.warn(\n\t\t\t\t'THREE.BufferGeometry.merge(): Overwriting original geometry, starting at offset=0. '\n\t\t\t\t+ 'Use BufferGeometryUtils.mergeBufferGeometries() for lossless merge.'\n\t\t\t);\n\n\t\t}\n\n\t\tconst attributes = this.attributes;\n\n\t\tfor ( const key in attributes ) {\n\n\t\t\tif ( geometry.attributes[ key ] === undefined ) continue;\n\n\t\t\tconst attribute1 = attributes[ key ];\n\t\t\tconst attributeArray1 = attribute1.array;\n\n\t\t\tconst attribute2 = geometry.attributes[ key ];\n\t\t\tconst attributeArray2 = attribute2.array;\n\n\t\t\tconst attributeOffset = attribute2.itemSize * offset;\n\t\t\tconst length = Math.min( attributeArray2.length, attributeArray1.length - attributeOffset );\n\n\t\t\tfor ( let i = 0, j = attributeOffset; i < length; i ++, j ++ ) {\n\n\t\t\t\tattributeArray1[ j ] = attributeArray2[ i ];\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tnormalizeNormals() {\n\n\t\tconst normals = this.attributes.normal;\n\n\t\tfor ( let i = 0, il = normals.count; i < il; i ++ ) {\n\n\t\t\t_vector$8.fromBufferAttribute( normals, i );\n\n\t\t\t_vector$8.normalize();\n\n\t\t\tnormals.setXYZ( i, _vector$8.x, _vector$8.y, _vector$8.z );\n\n\t\t}\n\n\t}\n\n\ttoNonIndexed() {\n\n\t\tfunction convertBufferAttribute( attribute, indices ) {\n\n\t\t\tconst array = attribute.array;\n\t\t\tconst itemSize = attribute.itemSize;\n\t\t\tconst normalized = attribute.normalized;\n\n\t\t\tconst array2 = new array.constructor( indices.length * itemSize );\n\n\t\t\tlet index = 0, index2 = 0;\n\n\t\t\tfor ( let i = 0, l = indices.length; i < l; i ++ ) {\n\n\t\t\t\tif ( attribute.isInterleavedBufferAttribute ) {\n\n\t\t\t\t\tindex = indices[ i ] * attribute.data.stride + attribute.offset;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tindex = indices[ i ] * itemSize;\n\n\t\t\t\t}\n\n\t\t\t\tfor ( let j = 0; j < itemSize; j ++ ) {\n\n\t\t\t\t\tarray2[ index2 ++ ] = array[ index ++ ];\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn new BufferAttribute( array2, itemSize, normalized );\n\n\t\t}\n\n\t\t//\n\n\t\tif ( this.index === null ) {\n\n\t\t\tconsole.warn( 'THREE.BufferGeometry.toNonIndexed(): BufferGeometry is already non-indexed.' );\n\t\t\treturn this;\n\n\t\t}\n\n\t\tconst geometry2 = new BufferGeometry();\n\n\t\tconst indices = this.index.array;\n\t\tconst attributes = this.attributes;\n\n\t\t// attributes\n\n\t\tfor ( const name in attributes ) {\n\n\t\t\tconst attribute = attributes[ name ];\n\n\t\t\tconst newAttribute = convertBufferAttribute( attribute, indices );\n\n\t\t\tgeometry2.setAttribute( name, newAttribute );\n\n\t\t}\n\n\t\t// morph attributes\n\n\t\tconst morphAttributes = this.morphAttributes;\n\n\t\tfor ( const name in morphAttributes ) {\n\n\t\t\tconst morphArray = [];\n\t\t\tconst morphAttribute = morphAttributes[ name ]; // morphAttribute: array of Float32BufferAttributes\n\n\t\t\tfor ( let i = 0, il = morphAttribute.length; i < il; i ++ ) {\n\n\t\t\t\tconst attribute = morphAttribute[ i ];\n\n\t\t\t\tconst newAttribute = convertBufferAttribute( attribute, indices );\n\n\t\t\t\tmorphArray.push( newAttribute );\n\n\t\t\t}\n\n\t\t\tgeometry2.morphAttributes[ name ] = morphArray;\n\n\t\t}\n\n\t\tgeometry2.morphTargetsRelative = this.morphTargetsRelative;\n\n\t\t// groups\n\n\t\tconst groups = this.groups;\n\n\t\tfor ( let i = 0, l = groups.length; i < l; i ++ ) {\n\n\t\t\tconst group = groups[ i ];\n\t\t\tgeometry2.addGroup( group.start, group.count, group.materialIndex );\n\n\t\t}\n\n\t\treturn geometry2;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'BufferGeometry',\n\t\t\t\tgenerator: 'BufferGeometry.toJSON'\n\t\t\t}\n\t\t};\n\n\t\t// standard BufferGeometry serialization\n\n\t\tdata.uuid = this.uuid;\n\t\tdata.type = this.type;\n\t\tif ( this.name !== '' ) data.name = this.name;\n\t\tif ( Object.keys( this.userData ).length > 0 ) data.userData = this.userData;\n\n\t\tif ( this.parameters !== undefined ) {\n\n\t\t\tconst parameters = this.parameters;\n\n\t\t\tfor ( const key in parameters ) {\n\n\t\t\t\tif ( parameters[ key ] !== undefined ) data[ key ] = parameters[ key ];\n\n\t\t\t}\n\n\t\t\treturn data;\n\n\t\t}\n\n\t\t// for simplicity the code assumes attributes are not shared across geometries, see #15811\n\n\t\tdata.data = { attributes: {} };\n\n\t\tconst index = this.index;\n\n\t\tif ( index !== null ) {\n\n\t\t\tdata.data.index = {\n\t\t\t\ttype: index.array.constructor.name,\n\t\t\t\tarray: Array.prototype.slice.call( index.array )\n\t\t\t};\n\n\t\t}\n\n\t\tconst attributes = this.attributes;\n\n\t\tfor ( const key in attributes ) {\n\n\t\t\tconst attribute = attributes[ key ];\n\n\t\t\tdata.data.attributes[ key ] = attribute.toJSON( data.data );\n\n\t\t}\n\n\t\tconst morphAttributes = {};\n\t\tlet hasMorphAttributes = false;\n\n\t\tfor ( const key in this.morphAttributes ) {\n\n\t\t\tconst attributeArray = this.morphAttributes[ key ];\n\n\t\t\tconst array = [];\n\n\t\t\tfor ( let i = 0, il = attributeArray.length; i < il; i ++ ) {\n\n\t\t\t\tconst attribute = attributeArray[ i ];\n\n\t\t\t\tarray.push( attribute.toJSON( data.data ) );\n\n\t\t\t}\n\n\t\t\tif ( array.length > 0 ) {\n\n\t\t\t\tmorphAttributes[ key ] = array;\n\n\t\t\t\thasMorphAttributes = true;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( hasMorphAttributes ) {\n\n\t\t\tdata.data.morphAttributes = morphAttributes;\n\t\t\tdata.data.morphTargetsRelative = this.morphTargetsRelative;\n\n\t\t}\n\n\t\tconst groups = this.groups;\n\n\t\tif ( groups.length > 0 ) {\n\n\t\t\tdata.data.groups = JSON.parse( JSON.stringify( groups ) );\n\n\t\t}\n\n\t\tconst boundingSphere = this.boundingSphere;\n\n\t\tif ( boundingSphere !== null ) {\n\n\t\t\tdata.data.boundingSphere = {\n\t\t\t\tcenter: boundingSphere.center.toArray(),\n\t\t\t\tradius: boundingSphere.radius\n\t\t\t};\n\n\t\t}\n\n\t\treturn data;\n\n\t}\n\n\tclone() {\n\n\t\t return new this.constructor().copy( this );\n\n\t}\n\n\tcopy( source ) {\n\n\t\t// reset\n\n\t\tthis.index = null;\n\t\tthis.attributes = {};\n\t\tthis.morphAttributes = {};\n\t\tthis.groups = [];\n\t\tthis.boundingBox = null;\n\t\tthis.boundingSphere = null;\n\n\t\t// used for storing cloned, shared data\n\n\t\tconst data = {};\n\n\t\t// name\n\n\t\tthis.name = source.name;\n\n\t\t// index\n\n\t\tconst index = source.index;\n\n\t\tif ( index !== null ) {\n\n\t\t\tthis.setIndex( index.clone( data ) );\n\n\t\t}\n\n\t\t// attributes\n\n\t\tconst attributes = source.attributes;\n\n\t\tfor ( const name in attributes ) {\n\n\t\t\tconst attribute = attributes[ name ];\n\t\t\tthis.setAttribute( name, attribute.clone( data ) );\n\n\t\t}\n\n\t\t// morph attributes\n\n\t\tconst morphAttributes = source.morphAttributes;\n\n\t\tfor ( const name in morphAttributes ) {\n\n\t\t\tconst array = [];\n\t\t\tconst morphAttribute = morphAttributes[ name ]; // morphAttribute: array of Float32BufferAttributes\n\n\t\t\tfor ( let i = 0, l = morphAttribute.length; i < l; i ++ ) {\n\n\t\t\t\tarray.push( morphAttribute[ i ].clone( data ) );\n\n\t\t\t}\n\n\t\t\tthis.morphAttributes[ name ] = array;\n\n\t\t}\n\n\t\tthis.morphTargetsRelative = source.morphTargetsRelative;\n\n\t\t// groups\n\n\t\tconst groups = source.groups;\n\n\t\tfor ( let i = 0, l = groups.length; i < l; i ++ ) {\n\n\t\t\tconst group = groups[ i ];\n\t\t\tthis.addGroup( group.start, group.count, group.materialIndex );\n\n\t\t}\n\n\t\t// bounding box\n\n\t\tconst boundingBox = source.boundingBox;\n\n\t\tif ( boundingBox !== null ) {\n\n\t\t\tthis.boundingBox = boundingBox.clone();\n\n\t\t}\n\n\t\t// bounding sphere\n\n\t\tconst boundingSphere = source.boundingSphere;\n\n\t\tif ( boundingSphere !== null ) {\n\n\t\t\tthis.boundingSphere = boundingSphere.clone();\n\n\t\t}\n\n\t\t// draw range\n\n\t\tthis.drawRange.start = source.drawRange.start;\n\t\tthis.drawRange.count = source.drawRange.count;\n\n\t\t// user data\n\n\t\tthis.userData = source.userData;\n\n\t\t// geometry generator parameters\n\n\t\tif ( source.parameters !== undefined ) this.parameters = Object.assign( {}, source.parameters );\n\n\t\treturn this;\n\n\t}\n\n\tdispose() {\n\n\t\tthis.dispatchEvent( { type: 'dispose' } );\n\n\t}\n\n}\n\nconst _inverseMatrix$2 = /*@__PURE__*/ new Matrix4();\nconst _ray$2 = /*@__PURE__*/ new Ray();\nconst _sphere$3 = /*@__PURE__*/ new Sphere();\n\nconst _vA$1 = /*@__PURE__*/ new Vector3();\nconst _vB$1 = /*@__PURE__*/ new Vector3();\nconst _vC$1 = /*@__PURE__*/ new Vector3();\n\nconst _tempA = /*@__PURE__*/ new Vector3();\nconst _tempB = /*@__PURE__*/ new Vector3();\nconst _tempC = /*@__PURE__*/ new Vector3();\n\nconst _morphA = /*@__PURE__*/ new Vector3();\nconst _morphB = /*@__PURE__*/ new Vector3();\nconst _morphC = /*@__PURE__*/ new Vector3();\n\nconst _uvA$1 = /*@__PURE__*/ new Vector2();\nconst _uvB$1 = /*@__PURE__*/ new Vector2();\nconst _uvC$1 = /*@__PURE__*/ new Vector2();\n\nconst _intersectionPoint = /*@__PURE__*/ new Vector3();\nconst _intersectionPointWorld = /*@__PURE__*/ new Vector3();\n\nclass Mesh extends Object3D {\n\n\tconstructor( geometry = new BufferGeometry(), material = new MeshBasicMaterial() ) {\n\n\t\tsuper();\n\n\t\tthis.isMesh = true;\n\n\t\tthis.type = 'Mesh';\n\n\t\tthis.geometry = geometry;\n\t\tthis.material = material;\n\n\t\tthis.updateMorphTargets();\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tif ( source.morphTargetInfluences !== undefined ) {\n\n\t\t\tthis.morphTargetInfluences = source.morphTargetInfluences.slice();\n\n\t\t}\n\n\t\tif ( source.morphTargetDictionary !== undefined ) {\n\n\t\t\tthis.morphTargetDictionary = Object.assign( {}, source.morphTargetDictionary );\n\n\t\t}\n\n\t\tthis.material = source.material;\n\t\tthis.geometry = source.geometry;\n\n\t\treturn this;\n\n\t}\n\n\tupdateMorphTargets() {\n\n\t\tconst geometry = this.geometry;\n\n\t\tconst morphAttributes = geometry.morphAttributes;\n\t\tconst keys = Object.keys( morphAttributes );\n\n\t\tif ( keys.length > 0 ) {\n\n\t\t\tconst morphAttribute = morphAttributes[ keys[ 0 ] ];\n\n\t\t\tif ( morphAttribute !== undefined ) {\n\n\t\t\t\tthis.morphTargetInfluences = [];\n\t\t\t\tthis.morphTargetDictionary = {};\n\n\t\t\t\tfor ( let m = 0, ml = morphAttribute.length; m < ml; m ++ ) {\n\n\t\t\t\t\tconst name = morphAttribute[ m ].name || String( m );\n\n\t\t\t\t\tthis.morphTargetInfluences.push( 0 );\n\t\t\t\t\tthis.morphTargetDictionary[ name ] = m;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\traycast( raycaster, intersects ) {\n\n\t\tconst geometry = this.geometry;\n\t\tconst material = this.material;\n\t\tconst matrixWorld = this.matrixWorld;\n\n\t\tif ( material === undefined ) return;\n\n\t\t// Checking boundingSphere distance to ray\n\n\t\tif ( geometry.boundingSphere === null ) geometry.computeBoundingSphere();\n\n\t\t_sphere$3.copy( geometry.boundingSphere );\n\t\t_sphere$3.applyMatrix4( matrixWorld );\n\n\t\tif ( raycaster.ray.intersectsSphere( _sphere$3 ) === false ) return;\n\n\t\t//\n\n\t\t_inverseMatrix$2.copy( matrixWorld ).invert();\n\t\t_ray$2.copy( raycaster.ray ).applyMatrix4( _inverseMatrix$2 );\n\n\t\t// Check boundingBox before continuing\n\n\t\tif ( geometry.boundingBox !== null ) {\n\n\t\t\tif ( _ray$2.intersectsBox( geometry.boundingBox ) === false ) return;\n\n\t\t}\n\n\t\tlet intersection;\n\n\t\tconst index = geometry.index;\n\t\tconst position = geometry.attributes.position;\n\t\tconst morphPosition = geometry.morphAttributes.position;\n\t\tconst morphTargetsRelative = geometry.morphTargetsRelative;\n\t\tconst uv = geometry.attributes.uv;\n\t\tconst uv2 = geometry.attributes.uv2;\n\t\tconst groups = geometry.groups;\n\t\tconst drawRange = geometry.drawRange;\n\n\t\tif ( index !== null ) {\n\n\t\t\t// indexed buffer geometry\n\n\t\t\tif ( Array.isArray( material ) ) {\n\n\t\t\t\tfor ( let i = 0, il = groups.length; i < il; i ++ ) {\n\n\t\t\t\t\tconst group = groups[ i ];\n\t\t\t\t\tconst groupMaterial = material[ group.materialIndex ];\n\n\t\t\t\t\tconst start = Math.max( group.start, drawRange.start );\n\t\t\t\t\tconst end = Math.min( index.count, Math.min( ( group.start + group.count ), ( drawRange.start + drawRange.count ) ) );\n\n\t\t\t\t\tfor ( let j = start, jl = end; j < jl; j += 3 ) {\n\n\t\t\t\t\t\tconst a = index.getX( j );\n\t\t\t\t\t\tconst b = index.getX( j + 1 );\n\t\t\t\t\t\tconst c = index.getX( j + 2 );\n\n\t\t\t\t\t\tintersection = checkBufferGeometryIntersection( this, groupMaterial, raycaster, _ray$2, position, morphPosition, morphTargetsRelative, uv, uv2, a, b, c );\n\n\t\t\t\t\t\tif ( intersection ) {\n\n\t\t\t\t\t\t\tintersection.faceIndex = Math.floor( j / 3 ); // triangle number in indexed buffer semantics\n\t\t\t\t\t\t\tintersection.face.materialIndex = group.materialIndex;\n\t\t\t\t\t\t\tintersects.push( intersection );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tconst start = Math.max( 0, drawRange.start );\n\t\t\t\tconst end = Math.min( index.count, ( drawRange.start + drawRange.count ) );\n\n\t\t\t\tfor ( let i = start, il = end; i < il; i += 3 ) {\n\n\t\t\t\t\tconst a = index.getX( i );\n\t\t\t\t\tconst b = index.getX( i + 1 );\n\t\t\t\t\tconst c = index.getX( i + 2 );\n\n\t\t\t\t\tintersection = checkBufferGeometryIntersection( this, material, raycaster, _ray$2, position, morphPosition, morphTargetsRelative, uv, uv2, a, b, c );\n\n\t\t\t\t\tif ( intersection ) {\n\n\t\t\t\t\t\tintersection.faceIndex = Math.floor( i / 3 ); // triangle number in indexed buffer semantics\n\t\t\t\t\t\tintersects.push( intersection );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else if ( position !== undefined ) {\n\n\t\t\t// non-indexed buffer geometry\n\n\t\t\tif ( Array.isArray( material ) ) {\n\n\t\t\t\tfor ( let i = 0, il = groups.length; i < il; i ++ ) {\n\n\t\t\t\t\tconst group = groups[ i ];\n\t\t\t\t\tconst groupMaterial = material[ group.materialIndex ];\n\n\t\t\t\t\tconst start = Math.max( group.start, drawRange.start );\n\t\t\t\t\tconst end = Math.min( position.count, Math.min( ( group.start + group.count ), ( drawRange.start + drawRange.count ) ) );\n\n\t\t\t\t\tfor ( let j = start, jl = end; j < jl; j += 3 ) {\n\n\t\t\t\t\t\tconst a = j;\n\t\t\t\t\t\tconst b = j + 1;\n\t\t\t\t\t\tconst c = j + 2;\n\n\t\t\t\t\t\tintersection = checkBufferGeometryIntersection( this, groupMaterial, raycaster, _ray$2, position, morphPosition, morphTargetsRelative, uv, uv2, a, b, c );\n\n\t\t\t\t\t\tif ( intersection ) {\n\n\t\t\t\t\t\t\tintersection.faceIndex = Math.floor( j / 3 ); // triangle number in non-indexed buffer semantics\n\t\t\t\t\t\t\tintersection.face.materialIndex = group.materialIndex;\n\t\t\t\t\t\t\tintersects.push( intersection );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tconst start = Math.max( 0, drawRange.start );\n\t\t\t\tconst end = Math.min( position.count, ( drawRange.start + drawRange.count ) );\n\n\t\t\t\tfor ( let i = start, il = end; i < il; i += 3 ) {\n\n\t\t\t\t\tconst a = i;\n\t\t\t\t\tconst b = i + 1;\n\t\t\t\t\tconst c = i + 2;\n\n\t\t\t\t\tintersection = checkBufferGeometryIntersection( this, material, raycaster, _ray$2, position, morphPosition, morphTargetsRelative, uv, uv2, a, b, c );\n\n\t\t\t\t\tif ( intersection ) {\n\n\t\t\t\t\t\tintersection.faceIndex = Math.floor( i / 3 ); // triangle number in non-indexed buffer semantics\n\t\t\t\t\t\tintersects.push( intersection );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n}\n\nfunction checkIntersection( object, material, raycaster, ray, pA, pB, pC, point ) {\n\n\tlet intersect;\n\n\tif ( material.side === BackSide ) {\n\n\t\tintersect = ray.intersectTriangle( pC, pB, pA, true, point );\n\n\t} else {\n\n\t\tintersect = ray.intersectTriangle( pA, pB, pC, material.side !== DoubleSide, point );\n\n\t}\n\n\tif ( intersect === null ) return null;\n\n\t_intersectionPointWorld.copy( point );\n\t_intersectionPointWorld.applyMatrix4( object.matrixWorld );\n\n\tconst distance = raycaster.ray.origin.distanceTo( _intersectionPointWorld );\n\n\tif ( distance < raycaster.near || distance > raycaster.far ) return null;\n\n\treturn {\n\t\tdistance: distance,\n\t\tpoint: _intersectionPointWorld.clone(),\n\t\tobject: object\n\t};\n\n}\n\nfunction checkBufferGeometryIntersection( object, material, raycaster, ray, position, morphPosition, morphTargetsRelative, uv, uv2, a, b, c ) {\n\n\t_vA$1.fromBufferAttribute( position, a );\n\t_vB$1.fromBufferAttribute( position, b );\n\t_vC$1.fromBufferAttribute( position, c );\n\n\tconst morphInfluences = object.morphTargetInfluences;\n\n\tif ( morphPosition && morphInfluences ) {\n\n\t\t_morphA.set( 0, 0, 0 );\n\t\t_morphB.set( 0, 0, 0 );\n\t\t_morphC.set( 0, 0, 0 );\n\n\t\tfor ( let i = 0, il = morphPosition.length; i < il; i ++ ) {\n\n\t\t\tconst influence = morphInfluences[ i ];\n\t\t\tconst morphAttribute = morphPosition[ i ];\n\n\t\t\tif ( influence === 0 ) continue;\n\n\t\t\t_tempA.fromBufferAttribute( morphAttribute, a );\n\t\t\t_tempB.fromBufferAttribute( morphAttribute, b );\n\t\t\t_tempC.fromBufferAttribute( morphAttribute, c );\n\n\t\t\tif ( morphTargetsRelative ) {\n\n\t\t\t\t_morphA.addScaledVector( _tempA, influence );\n\t\t\t\t_morphB.addScaledVector( _tempB, influence );\n\t\t\t\t_morphC.addScaledVector( _tempC, influence );\n\n\t\t\t} else {\n\n\t\t\t\t_morphA.addScaledVector( _tempA.sub( _vA$1 ), influence );\n\t\t\t\t_morphB.addScaledVector( _tempB.sub( _vB$1 ), influence );\n\t\t\t\t_morphC.addScaledVector( _tempC.sub( _vC$1 ), influence );\n\n\t\t\t}\n\n\t\t}\n\n\t\t_vA$1.add( _morphA );\n\t\t_vB$1.add( _morphB );\n\t\t_vC$1.add( _morphC );\n\n\t}\n\n\tif ( object.isSkinnedMesh ) {\n\n\t\tobject.boneTransform( a, _vA$1 );\n\t\tobject.boneTransform( b, _vB$1 );\n\t\tobject.boneTransform( c, _vC$1 );\n\n\t}\n\n\tconst intersection = checkIntersection( object, material, raycaster, ray, _vA$1, _vB$1, _vC$1, _intersectionPoint );\n\n\tif ( intersection ) {\n\n\t\tif ( uv ) {\n\n\t\t\t_uvA$1.fromBufferAttribute( uv, a );\n\t\t\t_uvB$1.fromBufferAttribute( uv, b );\n\t\t\t_uvC$1.fromBufferAttribute( uv, c );\n\n\t\t\tintersection.uv = Triangle.getUV( _intersectionPoint, _vA$1, _vB$1, _vC$1, _uvA$1, _uvB$1, _uvC$1, new Vector2() );\n\n\t\t}\n\n\t\tif ( uv2 ) {\n\n\t\t\t_uvA$1.fromBufferAttribute( uv2, a );\n\t\t\t_uvB$1.fromBufferAttribute( uv2, b );\n\t\t\t_uvC$1.fromBufferAttribute( uv2, c );\n\n\t\t\tintersection.uv2 = Triangle.getUV( _intersectionPoint, _vA$1, _vB$1, _vC$1, _uvA$1, _uvB$1, _uvC$1, new Vector2() );\n\n\t\t}\n\n\t\tconst face = {\n\t\t\ta: a,\n\t\t\tb: b,\n\t\t\tc: c,\n\t\t\tnormal: new Vector3(),\n\t\t\tmaterialIndex: 0\n\t\t};\n\n\t\tTriangle.getNormal( _vA$1, _vB$1, _vC$1, face.normal );\n\n\t\tintersection.face = face;\n\n\t}\n\n\treturn intersection;\n\n}\n\nclass BoxGeometry extends BufferGeometry {\n\n\tconstructor( width = 1, height = 1, depth = 1, widthSegments = 1, heightSegments = 1, depthSegments = 1 ) {\n\n\t\tsuper();\n\n\t\tthis.type = 'BoxGeometry';\n\n\t\tthis.parameters = {\n\t\t\twidth: width,\n\t\t\theight: height,\n\t\t\tdepth: depth,\n\t\t\twidthSegments: widthSegments,\n\t\t\theightSegments: heightSegments,\n\t\t\tdepthSegments: depthSegments\n\t\t};\n\n\t\tconst scope = this;\n\n\t\t// segments\n\n\t\twidthSegments = Math.floor( widthSegments );\n\t\theightSegments = Math.floor( heightSegments );\n\t\tdepthSegments = Math.floor( depthSegments );\n\n\t\t// buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\n\t\t// helper variables\n\n\t\tlet numberOfVertices = 0;\n\t\tlet groupStart = 0;\n\n\t\t// build each side of the box geometry\n\n\t\tbuildPlane( 'z', 'y', 'x', - 1, - 1, depth, height, width, depthSegments, heightSegments, 0 ); // px\n\t\tbuildPlane( 'z', 'y', 'x', 1, - 1, depth, height, - width, depthSegments, heightSegments, 1 ); // nx\n\t\tbuildPlane( 'x', 'z', 'y', 1, 1, width, depth, height, widthSegments, depthSegments, 2 ); // py\n\t\tbuildPlane( 'x', 'z', 'y', 1, - 1, width, depth, - height, widthSegments, depthSegments, 3 ); // ny\n\t\tbuildPlane( 'x', 'y', 'z', 1, - 1, width, height, depth, widthSegments, heightSegments, 4 ); // pz\n\t\tbuildPlane( 'x', 'y', 'z', - 1, - 1, width, height, - depth, widthSegments, heightSegments, 5 ); // nz\n\n\t\t// build geometry\n\n\t\tthis.setIndex( indices );\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tthis.setAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\t\tfunction buildPlane( u, v, w, udir, vdir, width, height, depth, gridX, gridY, materialIndex ) {\n\n\t\t\tconst segmentWidth = width / gridX;\n\t\t\tconst segmentHeight = height / gridY;\n\n\t\t\tconst widthHalf = width / 2;\n\t\t\tconst heightHalf = height / 2;\n\t\t\tconst depthHalf = depth / 2;\n\n\t\t\tconst gridX1 = gridX + 1;\n\t\t\tconst gridY1 = gridY + 1;\n\n\t\t\tlet vertexCounter = 0;\n\t\t\tlet groupCount = 0;\n\n\t\t\tconst vector = new Vector3();\n\n\t\t\t// generate vertices, normals and uvs\n\n\t\t\tfor ( let iy = 0; iy < gridY1; iy ++ ) {\n\n\t\t\t\tconst y = iy * segmentHeight - heightHalf;\n\n\t\t\t\tfor ( let ix = 0; ix < gridX1; ix ++ ) {\n\n\t\t\t\t\tconst x = ix * segmentWidth - widthHalf;\n\n\t\t\t\t\t// set values to correct vector component\n\n\t\t\t\t\tvector[ u ] = x * udir;\n\t\t\t\t\tvector[ v ] = y * vdir;\n\t\t\t\t\tvector[ w ] = depthHalf;\n\n\t\t\t\t\t// now apply vector to vertex buffer\n\n\t\t\t\t\tvertices.push( vector.x, vector.y, vector.z );\n\n\t\t\t\t\t// set values to correct vector component\n\n\t\t\t\t\tvector[ u ] = 0;\n\t\t\t\t\tvector[ v ] = 0;\n\t\t\t\t\tvector[ w ] = depth > 0 ? 1 : - 1;\n\n\t\t\t\t\t// now apply vector to normal buffer\n\n\t\t\t\t\tnormals.push( vector.x, vector.y, vector.z );\n\n\t\t\t\t\t// uvs\n\n\t\t\t\t\tuvs.push( ix / gridX );\n\t\t\t\t\tuvs.push( 1 - ( iy / gridY ) );\n\n\t\t\t\t\t// counters\n\n\t\t\t\t\tvertexCounter += 1;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// indices\n\n\t\t\t// 1. you need three indices to draw a single face\n\t\t\t// 2. a single segment consists of two faces\n\t\t\t// 3. so we need to generate six (2*3) indices per segment\n\n\t\t\tfor ( let iy = 0; iy < gridY; iy ++ ) {\n\n\t\t\t\tfor ( let ix = 0; ix < gridX; ix ++ ) {\n\n\t\t\t\t\tconst a = numberOfVertices + ix + gridX1 * iy;\n\t\t\t\t\tconst b = numberOfVertices + ix + gridX1 * ( iy + 1 );\n\t\t\t\t\tconst c = numberOfVertices + ( ix + 1 ) + gridX1 * ( iy + 1 );\n\t\t\t\t\tconst d = numberOfVertices + ( ix + 1 ) + gridX1 * iy;\n\n\t\t\t\t\t// faces\n\n\t\t\t\t\tindices.push( a, b, d );\n\t\t\t\t\tindices.push( b, c, d );\n\n\t\t\t\t\t// increase counter\n\n\t\t\t\t\tgroupCount += 6;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// add a group to the geometry. this will ensure multi material support\n\n\t\t\tscope.addGroup( groupStart, groupCount, materialIndex );\n\n\t\t\t// calculate new start value for groups\n\n\t\t\tgroupStart += groupCount;\n\n\t\t\t// update total number of vertices\n\n\t\t\tnumberOfVertices += vertexCounter;\n\n\t\t}\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new BoxGeometry( data.width, data.height, data.depth, data.widthSegments, data.heightSegments, data.depthSegments );\n\n\t}\n\n}\n\n/**\n * Uniform Utilities\n */\n\nfunction cloneUniforms( src ) {\n\n\tconst dst = {};\n\n\tfor ( const u in src ) {\n\n\t\tdst[ u ] = {};\n\n\t\tfor ( const p in src[ u ] ) {\n\n\t\t\tconst property = src[ u ][ p ];\n\n\t\t\tif ( property && ( property.isColor ||\n\t\t\t\tproperty.isMatrix3 || property.isMatrix4 ||\n\t\t\t\tproperty.isVector2 || property.isVector3 || property.isVector4 ||\n\t\t\t\tproperty.isTexture || property.isQuaternion ) ) {\n\n\t\t\t\tdst[ u ][ p ] = property.clone();\n\n\t\t\t} else if ( Array.isArray( property ) ) {\n\n\t\t\t\tdst[ u ][ p ] = property.slice();\n\n\t\t\t} else {\n\n\t\t\t\tdst[ u ][ p ] = property;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\treturn dst;\n\n}\n\nfunction mergeUniforms( uniforms ) {\n\n\tconst merged = {};\n\n\tfor ( let u = 0; u < uniforms.length; u ++ ) {\n\n\t\tconst tmp = cloneUniforms( uniforms[ u ] );\n\n\t\tfor ( const p in tmp ) {\n\n\t\t\tmerged[ p ] = tmp[ p ];\n\n\t\t}\n\n\t}\n\n\treturn merged;\n\n}\n\n// Legacy\n\nconst UniformsUtils = { clone: cloneUniforms, merge: mergeUniforms };\n\nvar default_vertex = \"void main() {\\n\\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\\n}\";\n\nvar default_fragment = \"void main() {\\n\\tgl_FragColor = vec4( 1.0, 0.0, 0.0, 1.0 );\\n}\";\n\nclass ShaderMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isShaderMaterial = true;\n\n\t\tthis.type = 'ShaderMaterial';\n\n\t\tthis.defines = {};\n\t\tthis.uniforms = {};\n\n\t\tthis.vertexShader = default_vertex;\n\t\tthis.fragmentShader = default_fragment;\n\n\t\tthis.linewidth = 1;\n\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\n\t\tthis.fog = false; // set to use scene fog\n\t\tthis.lights = false; // set to use scene lights\n\t\tthis.clipping = false; // set to use user-defined clipping planes\n\n\t\tthis.extensions = {\n\t\t\tderivatives: false, // set to use derivatives\n\t\t\tfragDepth: false, // set to use fragment depth values\n\t\t\tdrawBuffers: false, // set to use draw buffers\n\t\t\tshaderTextureLOD: false // set to use shader texture LOD\n\t\t};\n\n\t\t// When rendered geometry doesn't include these attributes but the material does,\n\t\t// use these default values in WebGL. This avoids errors when buffer data is missing.\n\t\tthis.defaultAttributeValues = {\n\t\t\t'color': [ 1, 1, 1 ],\n\t\t\t'uv': [ 0, 0 ],\n\t\t\t'uv2': [ 0, 0 ]\n\t\t};\n\n\t\tthis.index0AttributeName = undefined;\n\t\tthis.uniformsNeedUpdate = false;\n\n\t\tthis.glslVersion = null;\n\n\t\tif ( parameters !== undefined ) {\n\n\t\t\tif ( parameters.attributes !== undefined ) {\n\n\t\t\t\tconsole.error( 'THREE.ShaderMaterial: attributes should now be defined in THREE.BufferGeometry instead.' );\n\n\t\t\t}\n\n\t\t\tthis.setValues( parameters );\n\n\t\t}\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.fragmentShader = source.fragmentShader;\n\t\tthis.vertexShader = source.vertexShader;\n\n\t\tthis.uniforms = cloneUniforms( source.uniforms );\n\n\t\tthis.defines = Object.assign( {}, source.defines );\n\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\n\t\tthis.fog = source.fog;\n\t\tthis.lights = source.lights;\n\t\tthis.clipping = source.clipping;\n\n\t\tthis.extensions = Object.assign( {}, source.extensions );\n\n\t\tthis.glslVersion = source.glslVersion;\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON( meta ) {\n\n\t\tconst data = super.toJSON( meta );\n\n\t\tdata.glslVersion = this.glslVersion;\n\t\tdata.uniforms = {};\n\n\t\tfor ( const name in this.uniforms ) {\n\n\t\t\tconst uniform = this.uniforms[ name ];\n\t\t\tconst value = uniform.value;\n\n\t\t\tif ( value && value.isTexture ) {\n\n\t\t\t\tdata.uniforms[ name ] = {\n\t\t\t\t\ttype: 't',\n\t\t\t\t\tvalue: value.toJSON( meta ).uuid\n\t\t\t\t};\n\n\t\t\t} else if ( value && value.isColor ) {\n\n\t\t\t\tdata.uniforms[ name ] = {\n\t\t\t\t\ttype: 'c',\n\t\t\t\t\tvalue: value.getHex()\n\t\t\t\t};\n\n\t\t\t} else if ( value && value.isVector2 ) {\n\n\t\t\t\tdata.uniforms[ name ] = {\n\t\t\t\t\ttype: 'v2',\n\t\t\t\t\tvalue: value.toArray()\n\t\t\t\t};\n\n\t\t\t} else if ( value && value.isVector3 ) {\n\n\t\t\t\tdata.uniforms[ name ] = {\n\t\t\t\t\ttype: 'v3',\n\t\t\t\t\tvalue: value.toArray()\n\t\t\t\t};\n\n\t\t\t} else if ( value && value.isVector4 ) {\n\n\t\t\t\tdata.uniforms[ name ] = {\n\t\t\t\t\ttype: 'v4',\n\t\t\t\t\tvalue: value.toArray()\n\t\t\t\t};\n\n\t\t\t} else if ( value && value.isMatrix3 ) {\n\n\t\t\t\tdata.uniforms[ name ] = {\n\t\t\t\t\ttype: 'm3',\n\t\t\t\t\tvalue: value.toArray()\n\t\t\t\t};\n\n\t\t\t} else if ( value && value.isMatrix4 ) {\n\n\t\t\t\tdata.uniforms[ name ] = {\n\t\t\t\t\ttype: 'm4',\n\t\t\t\t\tvalue: value.toArray()\n\t\t\t\t};\n\n\t\t\t} else {\n\n\t\t\t\tdata.uniforms[ name ] = {\n\t\t\t\t\tvalue: value\n\t\t\t\t};\n\n\t\t\t\t// note: the array variants v2v, v3v, v4v, m4v and tv are not supported so far\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( Object.keys( this.defines ).length > 0 ) data.defines = this.defines;\n\n\t\tdata.vertexShader = this.vertexShader;\n\t\tdata.fragmentShader = this.fragmentShader;\n\n\t\tconst extensions = {};\n\n\t\tfor ( const key in this.extensions ) {\n\n\t\t\tif ( this.extensions[ key ] === true ) extensions[ key ] = true;\n\n\t\t}\n\n\t\tif ( Object.keys( extensions ).length > 0 ) data.extensions = extensions;\n\n\t\treturn data;\n\n\t}\n\n}\n\nclass Camera extends Object3D {\n\n\tconstructor() {\n\n\t\tsuper();\n\n\t\tthis.isCamera = true;\n\n\t\tthis.type = 'Camera';\n\n\t\tthis.matrixWorldInverse = new Matrix4();\n\n\t\tthis.projectionMatrix = new Matrix4();\n\t\tthis.projectionMatrixInverse = new Matrix4();\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tthis.matrixWorldInverse.copy( source.matrixWorldInverse );\n\n\t\tthis.projectionMatrix.copy( source.projectionMatrix );\n\t\tthis.projectionMatrixInverse.copy( source.projectionMatrixInverse );\n\n\t\treturn this;\n\n\t}\n\n\tgetWorldDirection( target ) {\n\n\t\tthis.updateWorldMatrix( true, false );\n\n\t\tconst e = this.matrixWorld.elements;\n\n\t\treturn target.set( - e[ 8 ], - e[ 9 ], - e[ 10 ] ).normalize();\n\n\t}\n\n\tupdateMatrixWorld( force ) {\n\n\t\tsuper.updateMatrixWorld( force );\n\n\t\tthis.matrixWorldInverse.copy( this.matrixWorld ).invert();\n\n\t}\n\n\tupdateWorldMatrix( updateParents, updateChildren ) {\n\n\t\tsuper.updateWorldMatrix( updateParents, updateChildren );\n\n\t\tthis.matrixWorldInverse.copy( this.matrixWorld ).invert();\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n}\n\nclass PerspectiveCamera extends Camera {\n\n\tconstructor( fov = 50, aspect = 1, near = 0.1, far = 2000 ) {\n\n\t\tsuper();\n\n\t\tthis.isPerspectiveCamera = true;\n\n\t\tthis.type = 'PerspectiveCamera';\n\n\t\tthis.fov = fov;\n\t\tthis.zoom = 1;\n\n\t\tthis.near = near;\n\t\tthis.far = far;\n\t\tthis.focus = 10;\n\n\t\tthis.aspect = aspect;\n\t\tthis.view = null;\n\n\t\tthis.filmGauge = 35;\t// width of the film (default in millimeters)\n\t\tthis.filmOffset = 0;\t// horizontal film offset (same unit as gauge)\n\n\t\tthis.updateProjectionMatrix();\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tthis.fov = source.fov;\n\t\tthis.zoom = source.zoom;\n\n\t\tthis.near = source.near;\n\t\tthis.far = source.far;\n\t\tthis.focus = source.focus;\n\n\t\tthis.aspect = source.aspect;\n\t\tthis.view = source.view === null ? null : Object.assign( {}, source.view );\n\n\t\tthis.filmGauge = source.filmGauge;\n\t\tthis.filmOffset = source.filmOffset;\n\n\t\treturn this;\n\n\t}\n\n\t/**\n\t * Sets the FOV by focal length in respect to the current .filmGauge.\n\t *\n\t * The default film gauge is 35, so that the focal length can be specified for\n\t * a 35mm (full frame) camera.\n\t *\n\t * Values for focal length and film gauge must have the same unit.\n\t */\n\tsetFocalLength( focalLength ) {\n\n\t\t/** see {@link http://www.bobatkins.com/photography/technical/field_of_view.html} */\n\t\tconst vExtentSlope = 0.5 * this.getFilmHeight() / focalLength;\n\n\t\tthis.fov = RAD2DEG * 2 * Math.atan( vExtentSlope );\n\t\tthis.updateProjectionMatrix();\n\n\t}\n\n\t/**\n\t * Calculates the focal length from the current .fov and .filmGauge.\n\t */\n\tgetFocalLength() {\n\n\t\tconst vExtentSlope = Math.tan( DEG2RAD * 0.5 * this.fov );\n\n\t\treturn 0.5 * this.getFilmHeight() / vExtentSlope;\n\n\t}\n\n\tgetEffectiveFOV() {\n\n\t\treturn RAD2DEG * 2 * Math.atan(\n\t\t\tMath.tan( DEG2RAD * 0.5 * this.fov ) / this.zoom );\n\n\t}\n\n\tgetFilmWidth() {\n\n\t\t// film not completely covered in portrait format (aspect < 1)\n\t\treturn this.filmGauge * Math.min( this.aspect, 1 );\n\n\t}\n\n\tgetFilmHeight() {\n\n\t\t// film not completely covered in landscape format (aspect > 1)\n\t\treturn this.filmGauge / Math.max( this.aspect, 1 );\n\n\t}\n\n\t/**\n\t * Sets an offset in a larger frustum. This is useful for multi-window or\n\t * multi-monitor/multi-machine setups.\n\t *\n\t * For example, if you have 3x2 monitors and each monitor is 1920x1080 and\n\t * the monitors are in grid like this\n\t *\n\t * +---+---+---+\n\t * | A | B | C |\n\t * +---+---+---+\n\t * | D | E | F |\n\t * +---+---+---+\n\t *\n\t * then for each monitor you would call it like this\n\t *\n\t * const w = 1920;\n\t * const h = 1080;\n\t * const fullWidth = w * 3;\n\t * const fullHeight = h * 2;\n\t *\n\t * --A--\n\t * camera.setViewOffset( fullWidth, fullHeight, w * 0, h * 0, w, h );\n\t * --B--\n\t * camera.setViewOffset( fullWidth, fullHeight, w * 1, h * 0, w, h );\n\t * --C--\n\t * camera.setViewOffset( fullWidth, fullHeight, w * 2, h * 0, w, h );\n\t * --D--\n\t * camera.setViewOffset( fullWidth, fullHeight, w * 0, h * 1, w, h );\n\t * --E--\n\t * camera.setViewOffset( fullWidth, fullHeight, w * 1, h * 1, w, h );\n\t * --F--\n\t * camera.setViewOffset( fullWidth, fullHeight, w * 2, h * 1, w, h );\n\t *\n\t * Note there is no reason monitors have to be the same size or in a grid.\n\t */\n\tsetViewOffset( fullWidth, fullHeight, x, y, width, height ) {\n\n\t\tthis.aspect = fullWidth / fullHeight;\n\n\t\tif ( this.view === null ) {\n\n\t\t\tthis.view = {\n\t\t\t\tenabled: true,\n\t\t\t\tfullWidth: 1,\n\t\t\t\tfullHeight: 1,\n\t\t\t\toffsetX: 0,\n\t\t\t\toffsetY: 0,\n\t\t\t\twidth: 1,\n\t\t\t\theight: 1\n\t\t\t};\n\n\t\t}\n\n\t\tthis.view.enabled = true;\n\t\tthis.view.fullWidth = fullWidth;\n\t\tthis.view.fullHeight = fullHeight;\n\t\tthis.view.offsetX = x;\n\t\tthis.view.offsetY = y;\n\t\tthis.view.width = width;\n\t\tthis.view.height = height;\n\n\t\tthis.updateProjectionMatrix();\n\n\t}\n\n\tclearViewOffset() {\n\n\t\tif ( this.view !== null ) {\n\n\t\t\tthis.view.enabled = false;\n\n\t\t}\n\n\t\tthis.updateProjectionMatrix();\n\n\t}\n\n\tupdateProjectionMatrix() {\n\n\t\tconst near = this.near;\n\t\tlet top = near * Math.tan( DEG2RAD * 0.5 * this.fov ) / this.zoom;\n\t\tlet height = 2 * top;\n\t\tlet width = this.aspect * height;\n\t\tlet left = - 0.5 * width;\n\t\tconst view = this.view;\n\n\t\tif ( this.view !== null && this.view.enabled ) {\n\n\t\t\tconst fullWidth = view.fullWidth,\n\t\t\t\tfullHeight = view.fullHeight;\n\n\t\t\tleft += view.offsetX * width / fullWidth;\n\t\t\ttop -= view.offsetY * height / fullHeight;\n\t\t\twidth *= view.width / fullWidth;\n\t\t\theight *= view.height / fullHeight;\n\n\t\t}\n\n\t\tconst skew = this.filmOffset;\n\t\tif ( skew !== 0 ) left += near * skew / this.getFilmWidth();\n\n\t\tthis.projectionMatrix.makePerspective( left, left + width, top, top - height, near, this.far );\n\n\t\tthis.projectionMatrixInverse.copy( this.projectionMatrix ).invert();\n\n\t}\n\n\ttoJSON( meta ) {\n\n\t\tconst data = super.toJSON( meta );\n\n\t\tdata.object.fov = this.fov;\n\t\tdata.object.zoom = this.zoom;\n\n\t\tdata.object.near = this.near;\n\t\tdata.object.far = this.far;\n\t\tdata.object.focus = this.focus;\n\n\t\tdata.object.aspect = this.aspect;\n\n\t\tif ( this.view !== null ) data.object.view = Object.assign( {}, this.view );\n\n\t\tdata.object.filmGauge = this.filmGauge;\n\t\tdata.object.filmOffset = this.filmOffset;\n\n\t\treturn data;\n\n\t}\n\n}\n\nconst fov = 90, aspect = 1;\n\nclass CubeCamera extends Object3D {\n\n\tconstructor( near, far, renderTarget ) {\n\n\t\tsuper();\n\n\t\tthis.type = 'CubeCamera';\n\n\t\tif ( renderTarget.isWebGLCubeRenderTarget !== true ) {\n\n\t\t\tconsole.error( 'THREE.CubeCamera: The constructor now expects an instance of WebGLCubeRenderTarget as third parameter.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tthis.renderTarget = renderTarget;\n\n\t\tconst cameraPX = new PerspectiveCamera( fov, aspect, near, far );\n\t\tcameraPX.layers = this.layers;\n\t\tcameraPX.up.set( 0, - 1, 0 );\n\t\tcameraPX.lookAt( new Vector3( 1, 0, 0 ) );\n\t\tthis.add( cameraPX );\n\n\t\tconst cameraNX = new PerspectiveCamera( fov, aspect, near, far );\n\t\tcameraNX.layers = this.layers;\n\t\tcameraNX.up.set( 0, - 1, 0 );\n\t\tcameraNX.lookAt( new Vector3( - 1, 0, 0 ) );\n\t\tthis.add( cameraNX );\n\n\t\tconst cameraPY = new PerspectiveCamera( fov, aspect, near, far );\n\t\tcameraPY.layers = this.layers;\n\t\tcameraPY.up.set( 0, 0, 1 );\n\t\tcameraPY.lookAt( new Vector3( 0, 1, 0 ) );\n\t\tthis.add( cameraPY );\n\n\t\tconst cameraNY = new PerspectiveCamera( fov, aspect, near, far );\n\t\tcameraNY.layers = this.layers;\n\t\tcameraNY.up.set( 0, 0, - 1 );\n\t\tcameraNY.lookAt( new Vector3( 0, - 1, 0 ) );\n\t\tthis.add( cameraNY );\n\n\t\tconst cameraPZ = new PerspectiveCamera( fov, aspect, near, far );\n\t\tcameraPZ.layers = this.layers;\n\t\tcameraPZ.up.set( 0, - 1, 0 );\n\t\tcameraPZ.lookAt( new Vector3( 0, 0, 1 ) );\n\t\tthis.add( cameraPZ );\n\n\t\tconst cameraNZ = new PerspectiveCamera( fov, aspect, near, far );\n\t\tcameraNZ.layers = this.layers;\n\t\tcameraNZ.up.set( 0, - 1, 0 );\n\t\tcameraNZ.lookAt( new Vector3( 0, 0, - 1 ) );\n\t\tthis.add( cameraNZ );\n\n\t}\n\n\tupdate( renderer, scene ) {\n\n\t\tif ( this.parent === null ) this.updateMatrixWorld();\n\n\t\tconst renderTarget = this.renderTarget;\n\n\t\tconst [ cameraPX, cameraNX, cameraPY, cameraNY, cameraPZ, cameraNZ ] = this.children;\n\n\t\tconst currentRenderTarget = renderer.getRenderTarget();\n\n\t\tconst currentToneMapping = renderer.toneMapping;\n\t\tconst currentXrEnabled = renderer.xr.enabled;\n\n\t\trenderer.toneMapping = NoToneMapping;\n\t\trenderer.xr.enabled = false;\n\n\t\tconst generateMipmaps = renderTarget.texture.generateMipmaps;\n\n\t\trenderTarget.texture.generateMipmaps = false;\n\n\t\trenderer.setRenderTarget( renderTarget, 0 );\n\t\trenderer.render( scene, cameraPX );\n\n\t\trenderer.setRenderTarget( renderTarget, 1 );\n\t\trenderer.render( scene, cameraNX );\n\n\t\trenderer.setRenderTarget( renderTarget, 2 );\n\t\trenderer.render( scene, cameraPY );\n\n\t\trenderer.setRenderTarget( renderTarget, 3 );\n\t\trenderer.render( scene, cameraNY );\n\n\t\trenderer.setRenderTarget( renderTarget, 4 );\n\t\trenderer.render( scene, cameraPZ );\n\n\t\trenderTarget.texture.generateMipmaps = generateMipmaps;\n\n\t\trenderer.setRenderTarget( renderTarget, 5 );\n\t\trenderer.render( scene, cameraNZ );\n\n\t\trenderer.setRenderTarget( currentRenderTarget );\n\n\t\trenderer.toneMapping = currentToneMapping;\n\t\trenderer.xr.enabled = currentXrEnabled;\n\n\t\trenderTarget.texture.needsPMREMUpdate = true;\n\n\t}\n\n}\n\nclass CubeTexture extends Texture {\n\n\tconstructor( images, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding ) {\n\n\t\timages = images !== undefined ? images : [];\n\t\tmapping = mapping !== undefined ? mapping : CubeReflectionMapping;\n\n\t\tsuper( images, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding );\n\n\t\tthis.isCubeTexture = true;\n\n\t\tthis.flipY = false;\n\n\t}\n\n\tget images() {\n\n\t\treturn this.image;\n\n\t}\n\n\tset images( value ) {\n\n\t\tthis.image = value;\n\n\t}\n\n}\n\nclass WebGLCubeRenderTarget extends WebGLRenderTarget {\n\n\tconstructor( size, options = {} ) {\n\n\t\tsuper( size, size, options );\n\n\t\tthis.isWebGLCubeRenderTarget = true;\n\n\t\tconst image = { width: size, height: size, depth: 1 };\n\t\tconst images = [ image, image, image, image, image, image ];\n\n\t\tthis.texture = new CubeTexture( images, options.mapping, options.wrapS, options.wrapT, options.magFilter, options.minFilter, options.format, options.type, options.anisotropy, options.encoding );\n\n\t\t// By convention -- likely based on the RenderMan spec from the 1990's -- cube maps are specified by WebGL (and three.js)\n\t\t// in a coordinate system in which positive-x is to the right when looking up the positive-z axis -- in other words,\n\t\t// in a left-handed coordinate system. By continuing this convention, preexisting cube maps continued to render correctly.\n\n\t\t// three.js uses a right-handed coordinate system. So environment maps used in three.js appear to have px and nx swapped\n\t\t// and the flag isRenderTargetTexture controls this conversion. The flip is not required when using WebGLCubeRenderTarget.texture\n\t\t// as a cube texture (this is detected when isRenderTargetTexture is set to true for cube textures).\n\n\t\tthis.texture.isRenderTargetTexture = true;\n\n\t\tthis.texture.generateMipmaps = options.generateMipmaps !== undefined ? options.generateMipmaps : false;\n\t\tthis.texture.minFilter = options.minFilter !== undefined ? options.minFilter : LinearFilter;\n\n\t}\n\n\tfromEquirectangularTexture( renderer, texture ) {\n\n\t\tthis.texture.type = texture.type;\n\t\tthis.texture.encoding = texture.encoding;\n\n\t\tthis.texture.generateMipmaps = texture.generateMipmaps;\n\t\tthis.texture.minFilter = texture.minFilter;\n\t\tthis.texture.magFilter = texture.magFilter;\n\n\t\tconst shader = {\n\n\t\t\tuniforms: {\n\t\t\t\ttEquirect: { value: null },\n\t\t\t},\n\n\t\t\tvertexShader: /* glsl */`\n\n\t\t\t\tvarying vec3 vWorldDirection;\n\n\t\t\t\tvec3 transformDirection( in vec3 dir, in mat4 matrix ) {\n\n\t\t\t\t\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );\n\n\t\t\t\t}\n\n\t\t\t\tvoid main() {\n\n\t\t\t\t\tvWorldDirection = transformDirection( position, modelMatrix );\n\n\t\t\t\t\t#include \n\t\t\t\t\t#include \n\n\t\t\t\t}\n\t\t\t`,\n\n\t\t\tfragmentShader: /* glsl */`\n\n\t\t\t\tuniform sampler2D tEquirect;\n\n\t\t\t\tvarying vec3 vWorldDirection;\n\n\t\t\t\t#include \n\n\t\t\t\tvoid main() {\n\n\t\t\t\t\tvec3 direction = normalize( vWorldDirection );\n\n\t\t\t\t\tvec2 sampleUV = equirectUv( direction );\n\n\t\t\t\t\tgl_FragColor = texture2D( tEquirect, sampleUV );\n\n\t\t\t\t}\n\t\t\t`\n\t\t};\n\n\t\tconst geometry = new BoxGeometry( 5, 5, 5 );\n\n\t\tconst material = new ShaderMaterial( {\n\n\t\t\tname: 'CubemapFromEquirect',\n\n\t\t\tuniforms: cloneUniforms( shader.uniforms ),\n\t\t\tvertexShader: shader.vertexShader,\n\t\t\tfragmentShader: shader.fragmentShader,\n\t\t\tside: BackSide,\n\t\t\tblending: NoBlending\n\n\t\t} );\n\n\t\tmaterial.uniforms.tEquirect.value = texture;\n\n\t\tconst mesh = new Mesh( geometry, material );\n\n\t\tconst currentMinFilter = texture.minFilter;\n\n\t\t// Avoid blurred poles\n\t\tif ( texture.minFilter === LinearMipmapLinearFilter ) texture.minFilter = LinearFilter;\n\n\t\tconst camera = new CubeCamera( 1, 10, this );\n\t\tcamera.update( renderer, mesh );\n\n\t\ttexture.minFilter = currentMinFilter;\n\n\t\tmesh.geometry.dispose();\n\t\tmesh.material.dispose();\n\n\t\treturn this;\n\n\t}\n\n\tclear( renderer, color, depth, stencil ) {\n\n\t\tconst currentRenderTarget = renderer.getRenderTarget();\n\n\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\trenderer.setRenderTarget( this, i );\n\n\t\t\trenderer.clear( color, depth, stencil );\n\n\t\t}\n\n\t\trenderer.setRenderTarget( currentRenderTarget );\n\n\t}\n\n}\n\nconst _vector1 = /*@__PURE__*/ new Vector3();\nconst _vector2 = /*@__PURE__*/ new Vector3();\nconst _normalMatrix = /*@__PURE__*/ new Matrix3();\n\nclass Plane {\n\n\tconstructor( normal = new Vector3( 1, 0, 0 ), constant = 0 ) {\n\n\t\tthis.isPlane = true;\n\n\t\t// normal is assumed to be normalized\n\n\t\tthis.normal = normal;\n\t\tthis.constant = constant;\n\n\t}\n\n\tset( normal, constant ) {\n\n\t\tthis.normal.copy( normal );\n\t\tthis.constant = constant;\n\n\t\treturn this;\n\n\t}\n\n\tsetComponents( x, y, z, w ) {\n\n\t\tthis.normal.set( x, y, z );\n\t\tthis.constant = w;\n\n\t\treturn this;\n\n\t}\n\n\tsetFromNormalAndCoplanarPoint( normal, point ) {\n\n\t\tthis.normal.copy( normal );\n\t\tthis.constant = - point.dot( this.normal );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromCoplanarPoints( a, b, c ) {\n\n\t\tconst normal = _vector1.subVectors( c, b ).cross( _vector2.subVectors( a, b ) ).normalize();\n\n\t\t// Q: should an error be thrown if normal is zero (e.g. degenerate plane)?\n\n\t\tthis.setFromNormalAndCoplanarPoint( normal, a );\n\n\t\treturn this;\n\n\t}\n\n\tcopy( plane ) {\n\n\t\tthis.normal.copy( plane.normal );\n\t\tthis.constant = plane.constant;\n\n\t\treturn this;\n\n\t}\n\n\tnormalize() {\n\n\t\t// Note: will lead to a divide by zero if the plane is invalid.\n\n\t\tconst inverseNormalLength = 1.0 / this.normal.length();\n\t\tthis.normal.multiplyScalar( inverseNormalLength );\n\t\tthis.constant *= inverseNormalLength;\n\n\t\treturn this;\n\n\t}\n\n\tnegate() {\n\n\t\tthis.constant *= - 1;\n\t\tthis.normal.negate();\n\n\t\treturn this;\n\n\t}\n\n\tdistanceToPoint( point ) {\n\n\t\treturn this.normal.dot( point ) + this.constant;\n\n\t}\n\n\tdistanceToSphere( sphere ) {\n\n\t\treturn this.distanceToPoint( sphere.center ) - sphere.radius;\n\n\t}\n\n\tprojectPoint( point, target ) {\n\n\t\treturn target.copy( this.normal ).multiplyScalar( - this.distanceToPoint( point ) ).add( point );\n\n\t}\n\n\tintersectLine( line, target ) {\n\n\t\tconst direction = line.delta( _vector1 );\n\n\t\tconst denominator = this.normal.dot( direction );\n\n\t\tif ( denominator === 0 ) {\n\n\t\t\t// line is coplanar, return origin\n\t\t\tif ( this.distanceToPoint( line.start ) === 0 ) {\n\n\t\t\t\treturn target.copy( line.start );\n\n\t\t\t}\n\n\t\t\t// Unsure if this is the correct method to handle this case.\n\t\t\treturn null;\n\n\t\t}\n\n\t\tconst t = - ( line.start.dot( this.normal ) + this.constant ) / denominator;\n\n\t\tif ( t < 0 || t > 1 ) {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\treturn target.copy( direction ).multiplyScalar( t ).add( line.start );\n\n\t}\n\n\tintersectsLine( line ) {\n\n\t\t// Note: this tests if a line intersects the plane, not whether it (or its end-points) are coplanar with it.\n\n\t\tconst startSign = this.distanceToPoint( line.start );\n\t\tconst endSign = this.distanceToPoint( line.end );\n\n\t\treturn ( startSign < 0 && endSign > 0 ) || ( endSign < 0 && startSign > 0 );\n\n\t}\n\n\tintersectsBox( box ) {\n\n\t\treturn box.intersectsPlane( this );\n\n\t}\n\n\tintersectsSphere( sphere ) {\n\n\t\treturn sphere.intersectsPlane( this );\n\n\t}\n\n\tcoplanarPoint( target ) {\n\n\t\treturn target.copy( this.normal ).multiplyScalar( - this.constant );\n\n\t}\n\n\tapplyMatrix4( matrix, optionalNormalMatrix ) {\n\n\t\tconst normalMatrix = optionalNormalMatrix || _normalMatrix.getNormalMatrix( matrix );\n\n\t\tconst referencePoint = this.coplanarPoint( _vector1 ).applyMatrix4( matrix );\n\n\t\tconst normal = this.normal.applyMatrix3( normalMatrix ).normalize();\n\n\t\tthis.constant = - referencePoint.dot( normal );\n\n\t\treturn this;\n\n\t}\n\n\ttranslate( offset ) {\n\n\t\tthis.constant -= offset.dot( this.normal );\n\n\t\treturn this;\n\n\t}\n\n\tequals( plane ) {\n\n\t\treturn plane.normal.equals( this.normal ) && ( plane.constant === this.constant );\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n}\n\nconst _sphere$2 = /*@__PURE__*/ new Sphere();\nconst _vector$7 = /*@__PURE__*/ new Vector3();\n\nclass Frustum {\n\n\tconstructor( p0 = new Plane(), p1 = new Plane(), p2 = new Plane(), p3 = new Plane(), p4 = new Plane(), p5 = new Plane() ) {\n\n\t\tthis.planes = [ p0, p1, p2, p3, p4, p5 ];\n\n\t}\n\n\tset( p0, p1, p2, p3, p4, p5 ) {\n\n\t\tconst planes = this.planes;\n\n\t\tplanes[ 0 ].copy( p0 );\n\t\tplanes[ 1 ].copy( p1 );\n\t\tplanes[ 2 ].copy( p2 );\n\t\tplanes[ 3 ].copy( p3 );\n\t\tplanes[ 4 ].copy( p4 );\n\t\tplanes[ 5 ].copy( p5 );\n\n\t\treturn this;\n\n\t}\n\n\tcopy( frustum ) {\n\n\t\tconst planes = this.planes;\n\n\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\tplanes[ i ].copy( frustum.planes[ i ] );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tsetFromProjectionMatrix( m ) {\n\n\t\tconst planes = this.planes;\n\t\tconst me = m.elements;\n\t\tconst me0 = me[ 0 ], me1 = me[ 1 ], me2 = me[ 2 ], me3 = me[ 3 ];\n\t\tconst me4 = me[ 4 ], me5 = me[ 5 ], me6 = me[ 6 ], me7 = me[ 7 ];\n\t\tconst me8 = me[ 8 ], me9 = me[ 9 ], me10 = me[ 10 ], me11 = me[ 11 ];\n\t\tconst me12 = me[ 12 ], me13 = me[ 13 ], me14 = me[ 14 ], me15 = me[ 15 ];\n\n\t\tplanes[ 0 ].setComponents( me3 - me0, me7 - me4, me11 - me8, me15 - me12 ).normalize();\n\t\tplanes[ 1 ].setComponents( me3 + me0, me7 + me4, me11 + me8, me15 + me12 ).normalize();\n\t\tplanes[ 2 ].setComponents( me3 + me1, me7 + me5, me11 + me9, me15 + me13 ).normalize();\n\t\tplanes[ 3 ].setComponents( me3 - me1, me7 - me5, me11 - me9, me15 - me13 ).normalize();\n\t\tplanes[ 4 ].setComponents( me3 - me2, me7 - me6, me11 - me10, me15 - me14 ).normalize();\n\t\tplanes[ 5 ].setComponents( me3 + me2, me7 + me6, me11 + me10, me15 + me14 ).normalize();\n\n\t\treturn this;\n\n\t}\n\n\tintersectsObject( object ) {\n\n\t\tconst geometry = object.geometry;\n\n\t\tif ( geometry.boundingSphere === null ) geometry.computeBoundingSphere();\n\n\t\t_sphere$2.copy( geometry.boundingSphere ).applyMatrix4( object.matrixWorld );\n\n\t\treturn this.intersectsSphere( _sphere$2 );\n\n\t}\n\n\tintersectsSprite( sprite ) {\n\n\t\t_sphere$2.center.set( 0, 0, 0 );\n\t\t_sphere$2.radius = 0.7071067811865476;\n\t\t_sphere$2.applyMatrix4( sprite.matrixWorld );\n\n\t\treturn this.intersectsSphere( _sphere$2 );\n\n\t}\n\n\tintersectsSphere( sphere ) {\n\n\t\tconst planes = this.planes;\n\t\tconst center = sphere.center;\n\t\tconst negRadius = - sphere.radius;\n\n\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\tconst distance = planes[ i ].distanceToPoint( center );\n\n\t\t\tif ( distance < negRadius ) {\n\n\t\t\t\treturn false;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn true;\n\n\t}\n\n\tintersectsBox( box ) {\n\n\t\tconst planes = this.planes;\n\n\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\tconst plane = planes[ i ];\n\n\t\t\t// corner at max distance\n\n\t\t\t_vector$7.x = plane.normal.x > 0 ? box.max.x : box.min.x;\n\t\t\t_vector$7.y = plane.normal.y > 0 ? box.max.y : box.min.y;\n\t\t\t_vector$7.z = plane.normal.z > 0 ? box.max.z : box.min.z;\n\n\t\t\tif ( plane.distanceToPoint( _vector$7 ) < 0 ) {\n\n\t\t\t\treturn false;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn true;\n\n\t}\n\n\tcontainsPoint( point ) {\n\n\t\tconst planes = this.planes;\n\n\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\tif ( planes[ i ].distanceToPoint( point ) < 0 ) {\n\n\t\t\t\treturn false;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn true;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n}\n\nfunction WebGLAnimation() {\n\n\tlet context = null;\n\tlet isAnimating = false;\n\tlet animationLoop = null;\n\tlet requestId = null;\n\n\tfunction onAnimationFrame( time, frame ) {\n\n\t\tanimationLoop( time, frame );\n\n\t\trequestId = context.requestAnimationFrame( onAnimationFrame );\n\n\t}\n\n\treturn {\n\n\t\tstart: function () {\n\n\t\t\tif ( isAnimating === true ) return;\n\t\t\tif ( animationLoop === null ) return;\n\n\t\t\trequestId = context.requestAnimationFrame( onAnimationFrame );\n\n\t\t\tisAnimating = true;\n\n\t\t},\n\n\t\tstop: function () {\n\n\t\t\tcontext.cancelAnimationFrame( requestId );\n\n\t\t\tisAnimating = false;\n\n\t\t},\n\n\t\tsetAnimationLoop: function ( callback ) {\n\n\t\t\tanimationLoop = callback;\n\n\t\t},\n\n\t\tsetContext: function ( value ) {\n\n\t\t\tcontext = value;\n\n\t\t}\n\n\t};\n\n}\n\nfunction WebGLAttributes( gl, capabilities ) {\n\n\tconst isWebGL2 = capabilities.isWebGL2;\n\n\tconst buffers = new WeakMap();\n\n\tfunction createBuffer( attribute, bufferType ) {\n\n\t\tconst array = attribute.array;\n\t\tconst usage = attribute.usage;\n\n\t\tconst buffer = gl.createBuffer();\n\n\t\tgl.bindBuffer( bufferType, buffer );\n\t\tgl.bufferData( bufferType, array, usage );\n\n\t\tattribute.onUploadCallback();\n\n\t\tlet type;\n\n\t\tif ( array instanceof Float32Array ) {\n\n\t\t\ttype = 5126;\n\n\t\t} else if ( array instanceof Uint16Array ) {\n\n\t\t\tif ( attribute.isFloat16BufferAttribute ) {\n\n\t\t\t\tif ( isWebGL2 ) {\n\n\t\t\t\t\ttype = 5131;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthrow new Error( 'THREE.WebGLAttributes: Usage of Float16BufferAttribute requires WebGL2.' );\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\ttype = 5123;\n\n\t\t\t}\n\n\t\t} else if ( array instanceof Int16Array ) {\n\n\t\t\ttype = 5122;\n\n\t\t} else if ( array instanceof Uint32Array ) {\n\n\t\t\ttype = 5125;\n\n\t\t} else if ( array instanceof Int32Array ) {\n\n\t\t\ttype = 5124;\n\n\t\t} else if ( array instanceof Int8Array ) {\n\n\t\t\ttype = 5120;\n\n\t\t} else if ( array instanceof Uint8Array ) {\n\n\t\t\ttype = 5121;\n\n\t\t} else if ( array instanceof Uint8ClampedArray ) {\n\n\t\t\ttype = 5121;\n\n\t\t} else {\n\n\t\t\tthrow new Error( 'THREE.WebGLAttributes: Unsupported buffer data format: ' + array );\n\n\t\t}\n\n\t\treturn {\n\t\t\tbuffer: buffer,\n\t\t\ttype: type,\n\t\t\tbytesPerElement: array.BYTES_PER_ELEMENT,\n\t\t\tversion: attribute.version\n\t\t};\n\n\t}\n\n\tfunction updateBuffer( buffer, attribute, bufferType ) {\n\n\t\tconst array = attribute.array;\n\t\tconst updateRange = attribute.updateRange;\n\n\t\tgl.bindBuffer( bufferType, buffer );\n\n\t\tif ( updateRange.count === - 1 ) {\n\n\t\t\t// Not using update ranges\n\n\t\t\tgl.bufferSubData( bufferType, 0, array );\n\n\t\t} else {\n\n\t\t\tif ( isWebGL2 ) {\n\n\t\t\t\tgl.bufferSubData( bufferType, updateRange.offset * array.BYTES_PER_ELEMENT,\n\t\t\t\t\tarray, updateRange.offset, updateRange.count );\n\n\t\t\t} else {\n\n\t\t\t\tgl.bufferSubData( bufferType, updateRange.offset * array.BYTES_PER_ELEMENT,\n\t\t\t\t\tarray.subarray( updateRange.offset, updateRange.offset + updateRange.count ) );\n\n\t\t\t}\n\n\t\t\tupdateRange.count = - 1; // reset range\n\n\t\t}\n\n\t}\n\n\t//\n\n\tfunction get( attribute ) {\n\n\t\tif ( attribute.isInterleavedBufferAttribute ) attribute = attribute.data;\n\n\t\treturn buffers.get( attribute );\n\n\t}\n\n\tfunction remove( attribute ) {\n\n\t\tif ( attribute.isInterleavedBufferAttribute ) attribute = attribute.data;\n\n\t\tconst data = buffers.get( attribute );\n\n\t\tif ( data ) {\n\n\t\t\tgl.deleteBuffer( data.buffer );\n\n\t\t\tbuffers.delete( attribute );\n\n\t\t}\n\n\t}\n\n\tfunction update( attribute, bufferType ) {\n\n\t\tif ( attribute.isGLBufferAttribute ) {\n\n\t\t\tconst cached = buffers.get( attribute );\n\n\t\t\tif ( ! cached || cached.version < attribute.version ) {\n\n\t\t\t\tbuffers.set( attribute, {\n\t\t\t\t\tbuffer: attribute.buffer,\n\t\t\t\t\ttype: attribute.type,\n\t\t\t\t\tbytesPerElement: attribute.elementSize,\n\t\t\t\t\tversion: attribute.version\n\t\t\t\t} );\n\n\t\t\t}\n\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( attribute.isInterleavedBufferAttribute ) attribute = attribute.data;\n\n\t\tconst data = buffers.get( attribute );\n\n\t\tif ( data === undefined ) {\n\n\t\t\tbuffers.set( attribute, createBuffer( attribute, bufferType ) );\n\n\t\t} else if ( data.version < attribute.version ) {\n\n\t\t\tupdateBuffer( data.buffer, attribute, bufferType );\n\n\t\t\tdata.version = attribute.version;\n\n\t\t}\n\n\t}\n\n\treturn {\n\n\t\tget: get,\n\t\tremove: remove,\n\t\tupdate: update\n\n\t};\n\n}\n\nclass PlaneGeometry extends BufferGeometry {\n\n\tconstructor( width = 1, height = 1, widthSegments = 1, heightSegments = 1 ) {\n\n\t\tsuper();\n\t\tthis.type = 'PlaneGeometry';\n\n\t\tthis.parameters = {\n\t\t\twidth: width,\n\t\t\theight: height,\n\t\t\twidthSegments: widthSegments,\n\t\t\theightSegments: heightSegments\n\t\t};\n\n\t\tconst width_half = width / 2;\n\t\tconst height_half = height / 2;\n\n\t\tconst gridX = Math.floor( widthSegments );\n\t\tconst gridY = Math.floor( heightSegments );\n\n\t\tconst gridX1 = gridX + 1;\n\t\tconst gridY1 = gridY + 1;\n\n\t\tconst segment_width = width / gridX;\n\t\tconst segment_height = height / gridY;\n\n\t\t//\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\n\t\tfor ( let iy = 0; iy < gridY1; iy ++ ) {\n\n\t\t\tconst y = iy * segment_height - height_half;\n\n\t\t\tfor ( let ix = 0; ix < gridX1; ix ++ ) {\n\n\t\t\t\tconst x = ix * segment_width - width_half;\n\n\t\t\t\tvertices.push( x, - y, 0 );\n\n\t\t\t\tnormals.push( 0, 0, 1 );\n\n\t\t\t\tuvs.push( ix / gridX );\n\t\t\t\tuvs.push( 1 - ( iy / gridY ) );\n\n\t\t\t}\n\n\t\t}\n\n\t\tfor ( let iy = 0; iy < gridY; iy ++ ) {\n\n\t\t\tfor ( let ix = 0; ix < gridX; ix ++ ) {\n\n\t\t\t\tconst a = ix + gridX1 * iy;\n\t\t\t\tconst b = ix + gridX1 * ( iy + 1 );\n\t\t\t\tconst c = ( ix + 1 ) + gridX1 * ( iy + 1 );\n\t\t\t\tconst d = ( ix + 1 ) + gridX1 * iy;\n\n\t\t\t\tindices.push( a, b, d );\n\t\t\t\tindices.push( b, c, d );\n\n\t\t\t}\n\n\t\t}\n\n\t\tthis.setIndex( indices );\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tthis.setAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new PlaneGeometry( data.width, data.height, data.widthSegments, data.heightSegments );\n\n\t}\n\n}\n\nvar alphamap_fragment = \"#ifdef USE_ALPHAMAP\\n\\tdiffuseColor.a *= texture2D( alphaMap, vUv ).g;\\n#endif\";\n\nvar alphamap_pars_fragment = \"#ifdef USE_ALPHAMAP\\n\\tuniform sampler2D alphaMap;\\n#endif\";\n\nvar alphatest_fragment = \"#ifdef USE_ALPHATEST\\n\\tif ( diffuseColor.a < alphaTest ) discard;\\n#endif\";\n\nvar alphatest_pars_fragment = \"#ifdef USE_ALPHATEST\\n\\tuniform float alphaTest;\\n#endif\";\n\nvar aomap_fragment = \"#ifdef USE_AOMAP\\n\\tfloat ambientOcclusion = ( texture2D( aoMap, vUv2 ).r - 1.0 ) * aoMapIntensity + 1.0;\\n\\treflectedLight.indirectDiffuse *= ambientOcclusion;\\n\\t#if defined( USE_ENVMAP ) && defined( STANDARD )\\n\\t\\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\\n\\t\\treflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.roughness );\\n\\t#endif\\n#endif\";\n\nvar aomap_pars_fragment = \"#ifdef USE_AOMAP\\n\\tuniform sampler2D aoMap;\\n\\tuniform float aoMapIntensity;\\n#endif\";\n\nvar begin_vertex = \"vec3 transformed = vec3( position );\";\n\nvar beginnormal_vertex = \"vec3 objectNormal = vec3( normal );\\n#ifdef USE_TANGENT\\n\\tvec3 objectTangent = vec3( tangent.xyz );\\n#endif\";\n\nvar bsdfs = \"vec3 BRDF_Lambert( const in vec3 diffuseColor ) {\\n\\treturn RECIPROCAL_PI * diffuseColor;\\n}\\nvec3 F_Schlick( const in vec3 f0, const in float f90, const in float dotVH ) {\\n\\tfloat fresnel = exp2( ( - 5.55473 * dotVH - 6.98316 ) * dotVH );\\n\\treturn f0 * ( 1.0 - fresnel ) + ( f90 * fresnel );\\n}\\nfloat F_Schlick( const in float f0, const in float f90, const in float dotVH ) {\\n\\tfloat fresnel = exp2( ( - 5.55473 * dotVH - 6.98316 ) * dotVH );\\n\\treturn f0 * ( 1.0 - fresnel ) + ( f90 * fresnel );\\n}\\nvec3 Schlick_to_F0( const in vec3 f, const in float f90, const in float dotVH ) {\\n float x = clamp( 1.0 - dotVH, 0.0, 1.0 );\\n float x2 = x * x;\\n float x5 = clamp( x * x2 * x2, 0.0, 0.9999 );\\n return ( f - vec3( f90 ) * x5 ) / ( 1.0 - x5 );\\n}\\nfloat V_GGX_SmithCorrelated( const in float alpha, const in float dotNL, const in float dotNV ) {\\n\\tfloat a2 = pow2( alpha );\\n\\tfloat gv = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\\n\\tfloat gl = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\\n\\treturn 0.5 / max( gv + gl, EPSILON );\\n}\\nfloat D_GGX( const in float alpha, const in float dotNH ) {\\n\\tfloat a2 = pow2( alpha );\\n\\tfloat denom = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0;\\n\\treturn RECIPROCAL_PI * a2 / pow2( denom );\\n}\\nvec3 BRDF_GGX( const in vec3 lightDir, const in vec3 viewDir, const in vec3 normal, const in vec3 f0, const in float f90, const in float roughness ) {\\n\\tfloat alpha = pow2( roughness );\\n\\tvec3 halfDir = normalize( lightDir + viewDir );\\n\\tfloat dotNL = saturate( dot( normal, lightDir ) );\\n\\tfloat dotNV = saturate( dot( normal, viewDir ) );\\n\\tfloat dotNH = saturate( dot( normal, halfDir ) );\\n\\tfloat dotVH = saturate( dot( viewDir, halfDir ) );\\n\\tvec3 F = F_Schlick( f0, f90, dotVH );\\n\\tfloat V = V_GGX_SmithCorrelated( alpha, dotNL, dotNV );\\n\\tfloat D = D_GGX( alpha, dotNH );\\n\\treturn F * ( V * D );\\n}\\n#ifdef USE_IRIDESCENCE\\nvec3 BRDF_GGX_Iridescence( const in vec3 lightDir, const in vec3 viewDir, const in vec3 normal, const in vec3 f0, const in float f90, const in float iridescence, const in vec3 iridescenceFresnel, const in float roughness ) {\\n\\tfloat alpha = pow2( roughness );\\n\\tvec3 halfDir = normalize( lightDir + viewDir );\\n\\tfloat dotNL = saturate( dot( normal, lightDir ) );\\n\\tfloat dotNV = saturate( dot( normal, viewDir ) );\\n\\tfloat dotNH = saturate( dot( normal, halfDir ) );\\n\\tfloat dotVH = saturate( dot( viewDir, halfDir ) );\\n\\tvec3 F = mix(F_Schlick( f0, f90, dotVH ), iridescenceFresnel, iridescence);\\n\\tfloat V = V_GGX_SmithCorrelated( alpha, dotNL, dotNV );\\n\\tfloat D = D_GGX( alpha, dotNH );\\n\\treturn F * ( V * D );\\n}\\n#endif\\nvec2 LTC_Uv( const in vec3 N, const in vec3 V, const in float roughness ) {\\n\\tconst float LUT_SIZE = 64.0;\\n\\tconst float LUT_SCALE = ( LUT_SIZE - 1.0 ) / LUT_SIZE;\\n\\tconst float LUT_BIAS = 0.5 / LUT_SIZE;\\n\\tfloat dotNV = saturate( dot( N, V ) );\\n\\tvec2 uv = vec2( roughness, sqrt( 1.0 - dotNV ) );\\n\\tuv = uv * LUT_SCALE + LUT_BIAS;\\n\\treturn uv;\\n}\\nfloat LTC_ClippedSphereFormFactor( const in vec3 f ) {\\n\\tfloat l = length( f );\\n\\treturn max( ( l * l + f.z ) / ( l + 1.0 ), 0.0 );\\n}\\nvec3 LTC_EdgeVectorFormFactor( const in vec3 v1, const in vec3 v2 ) {\\n\\tfloat x = dot( v1, v2 );\\n\\tfloat y = abs( x );\\n\\tfloat a = 0.8543985 + ( 0.4965155 + 0.0145206 * y ) * y;\\n\\tfloat b = 3.4175940 + ( 4.1616724 + y ) * y;\\n\\tfloat v = a / b;\\n\\tfloat theta_sintheta = ( x > 0.0 ) ? v : 0.5 * inversesqrt( max( 1.0 - x * x, 1e-7 ) ) - v;\\n\\treturn cross( v1, v2 ) * theta_sintheta;\\n}\\nvec3 LTC_Evaluate( const in vec3 N, const in vec3 V, const in vec3 P, const in mat3 mInv, const in vec3 rectCoords[ 4 ] ) {\\n\\tvec3 v1 = rectCoords[ 1 ] - rectCoords[ 0 ];\\n\\tvec3 v2 = rectCoords[ 3 ] - rectCoords[ 0 ];\\n\\tvec3 lightNormal = cross( v1, v2 );\\n\\tif( dot( lightNormal, P - rectCoords[ 0 ] ) < 0.0 ) return vec3( 0.0 );\\n\\tvec3 T1, T2;\\n\\tT1 = normalize( V - N * dot( V, N ) );\\n\\tT2 = - cross( N, T1 );\\n\\tmat3 mat = mInv * transposeMat3( mat3( T1, T2, N ) );\\n\\tvec3 coords[ 4 ];\\n\\tcoords[ 0 ] = mat * ( rectCoords[ 0 ] - P );\\n\\tcoords[ 1 ] = mat * ( rectCoords[ 1 ] - P );\\n\\tcoords[ 2 ] = mat * ( rectCoords[ 2 ] - P );\\n\\tcoords[ 3 ] = mat * ( rectCoords[ 3 ] - P );\\n\\tcoords[ 0 ] = normalize( coords[ 0 ] );\\n\\tcoords[ 1 ] = normalize( coords[ 1 ] );\\n\\tcoords[ 2 ] = normalize( coords[ 2 ] );\\n\\tcoords[ 3 ] = normalize( coords[ 3 ] );\\n\\tvec3 vectorFormFactor = vec3( 0.0 );\\n\\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 0 ], coords[ 1 ] );\\n\\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 1 ], coords[ 2 ] );\\n\\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 2 ], coords[ 3 ] );\\n\\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 3 ], coords[ 0 ] );\\n\\tfloat result = LTC_ClippedSphereFormFactor( vectorFormFactor );\\n\\treturn vec3( result );\\n}\\nfloat G_BlinnPhong_Implicit( ) {\\n\\treturn 0.25;\\n}\\nfloat D_BlinnPhong( const in float shininess, const in float dotNH ) {\\n\\treturn RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow( dotNH, shininess );\\n}\\nvec3 BRDF_BlinnPhong( const in vec3 lightDir, const in vec3 viewDir, const in vec3 normal, const in vec3 specularColor, const in float shininess ) {\\n\\tvec3 halfDir = normalize( lightDir + viewDir );\\n\\tfloat dotNH = saturate( dot( normal, halfDir ) );\\n\\tfloat dotVH = saturate( dot( viewDir, halfDir ) );\\n\\tvec3 F = F_Schlick( specularColor, 1.0, dotVH );\\n\\tfloat G = G_BlinnPhong_Implicit( );\\n\\tfloat D = D_BlinnPhong( shininess, dotNH );\\n\\treturn F * ( G * D );\\n}\\n#if defined( USE_SHEEN )\\nfloat D_Charlie( float roughness, float dotNH ) {\\n\\tfloat alpha = pow2( roughness );\\n\\tfloat invAlpha = 1.0 / alpha;\\n\\tfloat cos2h = dotNH * dotNH;\\n\\tfloat sin2h = max( 1.0 - cos2h, 0.0078125 );\\n\\treturn ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI );\\n}\\nfloat V_Neubelt( float dotNV, float dotNL ) {\\n\\treturn saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) );\\n}\\nvec3 BRDF_Sheen( const in vec3 lightDir, const in vec3 viewDir, const in vec3 normal, vec3 sheenColor, const in float sheenRoughness ) {\\n\\tvec3 halfDir = normalize( lightDir + viewDir );\\n\\tfloat dotNL = saturate( dot( normal, lightDir ) );\\n\\tfloat dotNV = saturate( dot( normal, viewDir ) );\\n\\tfloat dotNH = saturate( dot( normal, halfDir ) );\\n\\tfloat D = D_Charlie( sheenRoughness, dotNH );\\n\\tfloat V = V_Neubelt( dotNV, dotNL );\\n\\treturn sheenColor * ( D * V );\\n}\\n#endif\";\n\nvar iridescence_fragment = \"#ifdef USE_IRIDESCENCE\\nconst mat3 XYZ_TO_REC709 = mat3(\\n 3.2404542, -0.9692660, 0.0556434,\\n -1.5371385, 1.8760108, -0.2040259,\\n -0.4985314, 0.0415560, 1.0572252\\n);\\nvec3 Fresnel0ToIor( vec3 fresnel0 ) {\\n vec3 sqrtF0 = sqrt( fresnel0 );\\n return ( vec3( 1.0 ) + sqrtF0 ) / ( vec3( 1.0 ) - sqrtF0 );\\n}\\nvec3 IorToFresnel0( vec3 transmittedIor, float incidentIor ) {\\n return pow2( ( transmittedIor - vec3( incidentIor ) ) / ( transmittedIor + vec3( incidentIor ) ) );\\n}\\nfloat IorToFresnel0( float transmittedIor, float incidentIor ) {\\n return pow2( ( transmittedIor - incidentIor ) / ( transmittedIor + incidentIor ));\\n}\\nvec3 evalSensitivity( float OPD, vec3 shift ) {\\n float phase = 2.0 * PI * OPD * 1.0e-9;\\n vec3 val = vec3( 5.4856e-13, 4.4201e-13, 5.2481e-13 );\\n vec3 pos = vec3( 1.6810e+06, 1.7953e+06, 2.2084e+06 );\\n vec3 var = vec3( 4.3278e+09, 9.3046e+09, 6.6121e+09 );\\n vec3 xyz = val * sqrt( 2.0 * PI * var ) * cos( pos * phase + shift ) * exp( -pow2( phase ) * var );\\n xyz.x += 9.7470e-14 * sqrt( 2.0 * PI * 4.5282e+09 ) * cos( 2.2399e+06 * phase + shift[0] ) * exp( -4.5282e+09 * pow2( phase ) );\\n xyz /= 1.0685e-7;\\n vec3 srgb = XYZ_TO_REC709 * xyz;\\n return srgb;\\n}\\nvec3 evalIridescence( float outsideIOR, float eta2, float cosTheta1, float thinFilmThickness, vec3 baseF0 ) {\\n vec3 I;\\n float iridescenceIOR = mix( outsideIOR, eta2, smoothstep( 0.0, 0.03, thinFilmThickness ) );\\n float sinTheta2Sq = pow2( outsideIOR / iridescenceIOR ) * ( 1.0 - pow2( cosTheta1 ) );\\n float cosTheta2Sq = 1.0 - sinTheta2Sq;\\n if ( cosTheta2Sq < 0.0 ) {\\n return vec3( 1.0 );\\n }\\n float cosTheta2 = sqrt( cosTheta2Sq );\\n float R0 = IorToFresnel0( iridescenceIOR, outsideIOR );\\n float R12 = F_Schlick( R0, 1.0, cosTheta1 );\\n float R21 = R12;\\n float T121 = 1.0 - R12;\\n float phi12 = 0.0;\\n if ( iridescenceIOR < outsideIOR ) phi12 = PI;\\n float phi21 = PI - phi12;\\n vec3 baseIOR = Fresnel0ToIor( clamp( baseF0, 0.0, 0.9999 ) ); vec3 R1 = IorToFresnel0( baseIOR, iridescenceIOR );\\n vec3 R23 = F_Schlick( R1, 1.0, cosTheta2 );\\n vec3 phi23 = vec3( 0.0 );\\n if ( baseIOR[0] < iridescenceIOR ) phi23[0] = PI;\\n if ( baseIOR[1] < iridescenceIOR ) phi23[1] = PI;\\n if ( baseIOR[2] < iridescenceIOR ) phi23[2] = PI;\\n float OPD = 2.0 * iridescenceIOR * thinFilmThickness * cosTheta2;\\n vec3 phi = vec3( phi21 ) + phi23;\\n vec3 R123 = clamp( R12 * R23, 1e-5, 0.9999 );\\n vec3 r123 = sqrt( R123 );\\n vec3 Rs = pow2( T121 ) * R23 / ( vec3( 1.0 ) - R123 );\\n vec3 C0 = R12 + Rs;\\n I = C0;\\n vec3 Cm = Rs - T121;\\n for ( int m = 1; m <= 2; ++m ) {\\n Cm *= r123;\\n vec3 Sm = 2.0 * evalSensitivity( float( m ) * OPD, float( m ) * phi );\\n I += Cm * Sm;\\n }\\n return max( I, vec3( 0.0 ) );\\n}\\n#endif\";\n\nvar bumpmap_pars_fragment = \"#ifdef USE_BUMPMAP\\n\\tuniform sampler2D bumpMap;\\n\\tuniform float bumpScale;\\n\\tvec2 dHdxy_fwd() {\\n\\t\\tvec2 dSTdx = dFdx( vUv );\\n\\t\\tvec2 dSTdy = dFdy( vUv );\\n\\t\\tfloat Hll = bumpScale * texture2D( bumpMap, vUv ).x;\\n\\t\\tfloat dBx = bumpScale * texture2D( bumpMap, vUv + dSTdx ).x - Hll;\\n\\t\\tfloat dBy = bumpScale * texture2D( bumpMap, vUv + dSTdy ).x - Hll;\\n\\t\\treturn vec2( dBx, dBy );\\n\\t}\\n\\tvec3 perturbNormalArb( vec3 surf_pos, vec3 surf_norm, vec2 dHdxy, float faceDirection ) {\\n\\t\\tvec3 vSigmaX = vec3( dFdx( surf_pos.x ), dFdx( surf_pos.y ), dFdx( surf_pos.z ) );\\n\\t\\tvec3 vSigmaY = vec3( dFdy( surf_pos.x ), dFdy( surf_pos.y ), dFdy( surf_pos.z ) );\\n\\t\\tvec3 vN = surf_norm;\\n\\t\\tvec3 R1 = cross( vSigmaY, vN );\\n\\t\\tvec3 R2 = cross( vN, vSigmaX );\\n\\t\\tfloat fDet = dot( vSigmaX, R1 ) * faceDirection;\\n\\t\\tvec3 vGrad = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 );\\n\\t\\treturn normalize( abs( fDet ) * surf_norm - vGrad );\\n\\t}\\n#endif\";\n\nvar clipping_planes_fragment = \"#if NUM_CLIPPING_PLANES > 0\\n\\tvec4 plane;\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < UNION_CLIPPING_PLANES; i ++ ) {\\n\\t\\tplane = clippingPlanes[ i ];\\n\\t\\tif ( dot( vClipPosition, plane.xyz ) > plane.w ) discard;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#if UNION_CLIPPING_PLANES < NUM_CLIPPING_PLANES\\n\\t\\tbool clipped = true;\\n\\t\\t#pragma unroll_loop_start\\n\\t\\tfor ( int i = UNION_CLIPPING_PLANES; i < NUM_CLIPPING_PLANES; i ++ ) {\\n\\t\\t\\tplane = clippingPlanes[ i ];\\n\\t\\t\\tclipped = ( dot( vClipPosition, plane.xyz ) > plane.w ) && clipped;\\n\\t\\t}\\n\\t\\t#pragma unroll_loop_end\\n\\t\\tif ( clipped ) discard;\\n\\t#endif\\n#endif\";\n\nvar clipping_planes_pars_fragment = \"#if NUM_CLIPPING_PLANES > 0\\n\\tvarying vec3 vClipPosition;\\n\\tuniform vec4 clippingPlanes[ NUM_CLIPPING_PLANES ];\\n#endif\";\n\nvar clipping_planes_pars_vertex = \"#if NUM_CLIPPING_PLANES > 0\\n\\tvarying vec3 vClipPosition;\\n#endif\";\n\nvar clipping_planes_vertex = \"#if NUM_CLIPPING_PLANES > 0\\n\\tvClipPosition = - mvPosition.xyz;\\n#endif\";\n\nvar color_fragment = \"#if defined( USE_COLOR_ALPHA )\\n\\tdiffuseColor *= vColor;\\n#elif defined( USE_COLOR )\\n\\tdiffuseColor.rgb *= vColor;\\n#endif\";\n\nvar color_pars_fragment = \"#if defined( USE_COLOR_ALPHA )\\n\\tvarying vec4 vColor;\\n#elif defined( USE_COLOR )\\n\\tvarying vec3 vColor;\\n#endif\";\n\nvar color_pars_vertex = \"#if defined( USE_COLOR_ALPHA )\\n\\tvarying vec4 vColor;\\n#elif defined( USE_COLOR ) || defined( USE_INSTANCING_COLOR )\\n\\tvarying vec3 vColor;\\n#endif\";\n\nvar color_vertex = \"#if defined( USE_COLOR_ALPHA )\\n\\tvColor = vec4( 1.0 );\\n#elif defined( USE_COLOR ) || defined( USE_INSTANCING_COLOR )\\n\\tvColor = vec3( 1.0 );\\n#endif\\n#ifdef USE_COLOR\\n\\tvColor *= color;\\n#endif\\n#ifdef USE_INSTANCING_COLOR\\n\\tvColor.xyz *= instanceColor.xyz;\\n#endif\";\n\nvar common = \"#define PI 3.141592653589793\\n#define PI2 6.283185307179586\\n#define PI_HALF 1.5707963267948966\\n#define RECIPROCAL_PI 0.3183098861837907\\n#define RECIPROCAL_PI2 0.15915494309189535\\n#define EPSILON 1e-6\\n#ifndef saturate\\n#define saturate( a ) clamp( a, 0.0, 1.0 )\\n#endif\\n#define whiteComplement( a ) ( 1.0 - saturate( a ) )\\nfloat pow2( const in float x ) { return x*x; }\\nvec3 pow2( const in vec3 x ) { return x*x; }\\nfloat pow3( const in float x ) { return x*x*x; }\\nfloat pow4( const in float x ) { float x2 = x*x; return x2*x2; }\\nfloat max3( const in vec3 v ) { return max( max( v.x, v.y ), v.z ); }\\nfloat average( const in vec3 color ) { return dot( color, vec3( 0.3333 ) ); }\\nhighp float rand( const in vec2 uv ) {\\n\\tconst highp float a = 12.9898, b = 78.233, c = 43758.5453;\\n\\thighp float dt = dot( uv.xy, vec2( a,b ) ), sn = mod( dt, PI );\\n\\treturn fract( sin( sn ) * c );\\n}\\n#ifdef HIGH_PRECISION\\n\\tfloat precisionSafeLength( vec3 v ) { return length( v ); }\\n#else\\n\\tfloat precisionSafeLength( vec3 v ) {\\n\\t\\tfloat maxComponent = max3( abs( v ) );\\n\\t\\treturn length( v / maxComponent ) * maxComponent;\\n\\t}\\n#endif\\nstruct IncidentLight {\\n\\tvec3 color;\\n\\tvec3 direction;\\n\\tbool visible;\\n};\\nstruct ReflectedLight {\\n\\tvec3 directDiffuse;\\n\\tvec3 directSpecular;\\n\\tvec3 indirectDiffuse;\\n\\tvec3 indirectSpecular;\\n};\\nstruct GeometricContext {\\n\\tvec3 position;\\n\\tvec3 normal;\\n\\tvec3 viewDir;\\n#ifdef USE_CLEARCOAT\\n\\tvec3 clearcoatNormal;\\n#endif\\n};\\nvec3 transformDirection( in vec3 dir, in mat4 matrix ) {\\n\\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );\\n}\\nvec3 inverseTransformDirection( in vec3 dir, in mat4 matrix ) {\\n\\treturn normalize( ( vec4( dir, 0.0 ) * matrix ).xyz );\\n}\\nmat3 transposeMat3( const in mat3 m ) {\\n\\tmat3 tmp;\\n\\ttmp[ 0 ] = vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x );\\n\\ttmp[ 1 ] = vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y );\\n\\ttmp[ 2 ] = vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z );\\n\\treturn tmp;\\n}\\nfloat linearToRelativeLuminance( const in vec3 color ) {\\n\\tvec3 weights = vec3( 0.2126, 0.7152, 0.0722 );\\n\\treturn dot( weights, color.rgb );\\n}\\nbool isPerspectiveMatrix( mat4 m ) {\\n\\treturn m[ 2 ][ 3 ] == - 1.0;\\n}\\nvec2 equirectUv( in vec3 dir ) {\\n\\tfloat u = atan( dir.z, dir.x ) * RECIPROCAL_PI2 + 0.5;\\n\\tfloat v = asin( clamp( dir.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\\n\\treturn vec2( u, v );\\n}\";\n\nvar cube_uv_reflection_fragment = \"#ifdef ENVMAP_TYPE_CUBE_UV\\n\\t#define cubeUV_minMipLevel 4.0\\n\\t#define cubeUV_minTileSize 16.0\\n\\tfloat getFace( vec3 direction ) {\\n\\t\\tvec3 absDirection = abs( direction );\\n\\t\\tfloat face = - 1.0;\\n\\t\\tif ( absDirection.x > absDirection.z ) {\\n\\t\\t\\tif ( absDirection.x > absDirection.y )\\n\\t\\t\\t\\tface = direction.x > 0.0 ? 0.0 : 3.0;\\n\\t\\t\\telse\\n\\t\\t\\t\\tface = direction.y > 0.0 ? 1.0 : 4.0;\\n\\t\\t} else {\\n\\t\\t\\tif ( absDirection.z > absDirection.y )\\n\\t\\t\\t\\tface = direction.z > 0.0 ? 2.0 : 5.0;\\n\\t\\t\\telse\\n\\t\\t\\t\\tface = direction.y > 0.0 ? 1.0 : 4.0;\\n\\t\\t}\\n\\t\\treturn face;\\n\\t}\\n\\tvec2 getUV( vec3 direction, float face ) {\\n\\t\\tvec2 uv;\\n\\t\\tif ( face == 0.0 ) {\\n\\t\\t\\tuv = vec2( direction.z, direction.y ) / abs( direction.x );\\n\\t\\t} else if ( face == 1.0 ) {\\n\\t\\t\\tuv = vec2( - direction.x, - direction.z ) / abs( direction.y );\\n\\t\\t} else if ( face == 2.0 ) {\\n\\t\\t\\tuv = vec2( - direction.x, direction.y ) / abs( direction.z );\\n\\t\\t} else if ( face == 3.0 ) {\\n\\t\\t\\tuv = vec2( - direction.z, direction.y ) / abs( direction.x );\\n\\t\\t} else if ( face == 4.0 ) {\\n\\t\\t\\tuv = vec2( - direction.x, direction.z ) / abs( direction.y );\\n\\t\\t} else {\\n\\t\\t\\tuv = vec2( direction.x, direction.y ) / abs( direction.z );\\n\\t\\t}\\n\\t\\treturn 0.5 * ( uv + 1.0 );\\n\\t}\\n\\tvec3 bilinearCubeUV( sampler2D envMap, vec3 direction, float mipInt ) {\\n\\t\\tfloat face = getFace( direction );\\n\\t\\tfloat filterInt = max( cubeUV_minMipLevel - mipInt, 0.0 );\\n\\t\\tmipInt = max( mipInt, cubeUV_minMipLevel );\\n\\t\\tfloat faceSize = exp2( mipInt );\\n\\t\\tvec2 uv = getUV( direction, face ) * ( faceSize - 2.0 ) + 1.0;\\n\\t\\tif ( face > 2.0 ) {\\n\\t\\t\\tuv.y += faceSize;\\n\\t\\t\\tface -= 3.0;\\n\\t\\t}\\n\\t\\tuv.x += face * faceSize;\\n\\t\\tuv.x += filterInt * 3.0 * cubeUV_minTileSize;\\n\\t\\tuv.y += 4.0 * ( exp2( CUBEUV_MAX_MIP ) - faceSize );\\n\\t\\tuv.x *= CUBEUV_TEXEL_WIDTH;\\n\\t\\tuv.y *= CUBEUV_TEXEL_HEIGHT;\\n\\t\\t#ifdef texture2DGradEXT\\n\\t\\t\\treturn texture2DGradEXT( envMap, uv, vec2( 0.0 ), vec2( 0.0 ) ).rgb;\\n\\t\\t#else\\n\\t\\t\\treturn texture2D( envMap, uv ).rgb;\\n\\t\\t#endif\\n\\t}\\n\\t#define r0 1.0\\n\\t#define v0 0.339\\n\\t#define m0 - 2.0\\n\\t#define r1 0.8\\n\\t#define v1 0.276\\n\\t#define m1 - 1.0\\n\\t#define r4 0.4\\n\\t#define v4 0.046\\n\\t#define m4 2.0\\n\\t#define r5 0.305\\n\\t#define v5 0.016\\n\\t#define m5 3.0\\n\\t#define r6 0.21\\n\\t#define v6 0.0038\\n\\t#define m6 4.0\\n\\tfloat roughnessToMip( float roughness ) {\\n\\t\\tfloat mip = 0.0;\\n\\t\\tif ( roughness >= r1 ) {\\n\\t\\t\\tmip = ( r0 - roughness ) * ( m1 - m0 ) / ( r0 - r1 ) + m0;\\n\\t\\t} else if ( roughness >= r4 ) {\\n\\t\\t\\tmip = ( r1 - roughness ) * ( m4 - m1 ) / ( r1 - r4 ) + m1;\\n\\t\\t} else if ( roughness >= r5 ) {\\n\\t\\t\\tmip = ( r4 - roughness ) * ( m5 - m4 ) / ( r4 - r5 ) + m4;\\n\\t\\t} else if ( roughness >= r6 ) {\\n\\t\\t\\tmip = ( r5 - roughness ) * ( m6 - m5 ) / ( r5 - r6 ) + m5;\\n\\t\\t} else {\\n\\t\\t\\tmip = - 2.0 * log2( 1.16 * roughness );\\t\\t}\\n\\t\\treturn mip;\\n\\t}\\n\\tvec4 textureCubeUV( sampler2D envMap, vec3 sampleDir, float roughness ) {\\n\\t\\tfloat mip = clamp( roughnessToMip( roughness ), m0, CUBEUV_MAX_MIP );\\n\\t\\tfloat mipF = fract( mip );\\n\\t\\tfloat mipInt = floor( mip );\\n\\t\\tvec3 color0 = bilinearCubeUV( envMap, sampleDir, mipInt );\\n\\t\\tif ( mipF == 0.0 ) {\\n\\t\\t\\treturn vec4( color0, 1.0 );\\n\\t\\t} else {\\n\\t\\t\\tvec3 color1 = bilinearCubeUV( envMap, sampleDir, mipInt + 1.0 );\\n\\t\\t\\treturn vec4( mix( color0, color1, mipF ), 1.0 );\\n\\t\\t}\\n\\t}\\n#endif\";\n\nvar defaultnormal_vertex = \"vec3 transformedNormal = objectNormal;\\n#ifdef USE_INSTANCING\\n\\tmat3 m = mat3( instanceMatrix );\\n\\ttransformedNormal /= vec3( dot( m[ 0 ], m[ 0 ] ), dot( m[ 1 ], m[ 1 ] ), dot( m[ 2 ], m[ 2 ] ) );\\n\\ttransformedNormal = m * transformedNormal;\\n#endif\\ntransformedNormal = normalMatrix * transformedNormal;\\n#ifdef FLIP_SIDED\\n\\ttransformedNormal = - transformedNormal;\\n#endif\\n#ifdef USE_TANGENT\\n\\tvec3 transformedTangent = ( modelViewMatrix * vec4( objectTangent, 0.0 ) ).xyz;\\n\\t#ifdef FLIP_SIDED\\n\\t\\ttransformedTangent = - transformedTangent;\\n\\t#endif\\n#endif\";\n\nvar displacementmap_pars_vertex = \"#ifdef USE_DISPLACEMENTMAP\\n\\tuniform sampler2D displacementMap;\\n\\tuniform float displacementScale;\\n\\tuniform float displacementBias;\\n#endif\";\n\nvar displacementmap_vertex = \"#ifdef USE_DISPLACEMENTMAP\\n\\ttransformed += normalize( objectNormal ) * ( texture2D( displacementMap, vUv ).x * displacementScale + displacementBias );\\n#endif\";\n\nvar emissivemap_fragment = \"#ifdef USE_EMISSIVEMAP\\n\\tvec4 emissiveColor = texture2D( emissiveMap, vUv );\\n\\ttotalEmissiveRadiance *= emissiveColor.rgb;\\n#endif\";\n\nvar emissivemap_pars_fragment = \"#ifdef USE_EMISSIVEMAP\\n\\tuniform sampler2D emissiveMap;\\n#endif\";\n\nvar encodings_fragment = \"gl_FragColor = linearToOutputTexel( gl_FragColor );\";\n\nvar encodings_pars_fragment = \"vec4 LinearToLinear( in vec4 value ) {\\n\\treturn value;\\n}\\nvec4 LinearTosRGB( in vec4 value ) {\\n\\treturn vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a );\\n}\";\n\nvar envmap_fragment = \"#ifdef USE_ENVMAP\\n\\t#ifdef ENV_WORLDPOS\\n\\t\\tvec3 cameraToFrag;\\n\\t\\tif ( isOrthographic ) {\\n\\t\\t\\tcameraToFrag = normalize( vec3( - viewMatrix[ 0 ][ 2 ], - viewMatrix[ 1 ][ 2 ], - viewMatrix[ 2 ][ 2 ] ) );\\n\\t\\t} else {\\n\\t\\t\\tcameraToFrag = normalize( vWorldPosition - cameraPosition );\\n\\t\\t}\\n\\t\\tvec3 worldNormal = inverseTransformDirection( normal, viewMatrix );\\n\\t\\t#ifdef ENVMAP_MODE_REFLECTION\\n\\t\\t\\tvec3 reflectVec = reflect( cameraToFrag, worldNormal );\\n\\t\\t#else\\n\\t\\t\\tvec3 reflectVec = refract( cameraToFrag, worldNormal, refractionRatio );\\n\\t\\t#endif\\n\\t#else\\n\\t\\tvec3 reflectVec = vReflect;\\n\\t#endif\\n\\t#ifdef ENVMAP_TYPE_CUBE\\n\\t\\tvec4 envColor = textureCube( envMap, vec3( flipEnvMap * reflectVec.x, reflectVec.yz ) );\\n\\t#elif defined( ENVMAP_TYPE_CUBE_UV )\\n\\t\\tvec4 envColor = textureCubeUV( envMap, reflectVec, 0.0 );\\n\\t#else\\n\\t\\tvec4 envColor = vec4( 0.0 );\\n\\t#endif\\n\\t#ifdef ENVMAP_BLENDING_MULTIPLY\\n\\t\\toutgoingLight = mix( outgoingLight, outgoingLight * envColor.xyz, specularStrength * reflectivity );\\n\\t#elif defined( ENVMAP_BLENDING_MIX )\\n\\t\\toutgoingLight = mix( outgoingLight, envColor.xyz, specularStrength * reflectivity );\\n\\t#elif defined( ENVMAP_BLENDING_ADD )\\n\\t\\toutgoingLight += envColor.xyz * specularStrength * reflectivity;\\n\\t#endif\\n#endif\";\n\nvar envmap_common_pars_fragment = \"#ifdef USE_ENVMAP\\n\\tuniform float envMapIntensity;\\n\\tuniform float flipEnvMap;\\n\\t#ifdef ENVMAP_TYPE_CUBE\\n\\t\\tuniform samplerCube envMap;\\n\\t#else\\n\\t\\tuniform sampler2D envMap;\\n\\t#endif\\n\\t\\n#endif\";\n\nvar envmap_pars_fragment = \"#ifdef USE_ENVMAP\\n\\tuniform float reflectivity;\\n\\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\\n\\t\\t#define ENV_WORLDPOS\\n\\t#endif\\n\\t#ifdef ENV_WORLDPOS\\n\\t\\tvarying vec3 vWorldPosition;\\n\\t\\tuniform float refractionRatio;\\n\\t#else\\n\\t\\tvarying vec3 vReflect;\\n\\t#endif\\n#endif\";\n\nvar envmap_pars_vertex = \"#ifdef USE_ENVMAP\\n\\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) ||defined( PHONG )\\n\\t\\t#define ENV_WORLDPOS\\n\\t#endif\\n\\t#ifdef ENV_WORLDPOS\\n\\t\\t\\n\\t\\tvarying vec3 vWorldPosition;\\n\\t#else\\n\\t\\tvarying vec3 vReflect;\\n\\t\\tuniform float refractionRatio;\\n\\t#endif\\n#endif\";\n\nvar envmap_vertex = \"#ifdef USE_ENVMAP\\n\\t#ifdef ENV_WORLDPOS\\n\\t\\tvWorldPosition = worldPosition.xyz;\\n\\t#else\\n\\t\\tvec3 cameraToVertex;\\n\\t\\tif ( isOrthographic ) {\\n\\t\\t\\tcameraToVertex = normalize( vec3( - viewMatrix[ 0 ][ 2 ], - viewMatrix[ 1 ][ 2 ], - viewMatrix[ 2 ][ 2 ] ) );\\n\\t\\t} else {\\n\\t\\t\\tcameraToVertex = normalize( worldPosition.xyz - cameraPosition );\\n\\t\\t}\\n\\t\\tvec3 worldNormal = inverseTransformDirection( transformedNormal, viewMatrix );\\n\\t\\t#ifdef ENVMAP_MODE_REFLECTION\\n\\t\\t\\tvReflect = reflect( cameraToVertex, worldNormal );\\n\\t\\t#else\\n\\t\\t\\tvReflect = refract( cameraToVertex, worldNormal, refractionRatio );\\n\\t\\t#endif\\n\\t#endif\\n#endif\";\n\nvar fog_vertex = \"#ifdef USE_FOG\\n\\tvFogDepth = - mvPosition.z;\\n#endif\";\n\nvar fog_pars_vertex = \"#ifdef USE_FOG\\n\\tvarying float vFogDepth;\\n#endif\";\n\nvar fog_fragment = \"#ifdef USE_FOG\\n\\t#ifdef FOG_EXP2\\n\\t\\tfloat fogFactor = 1.0 - exp( - fogDensity * fogDensity * vFogDepth * vFogDepth );\\n\\t#else\\n\\t\\tfloat fogFactor = smoothstep( fogNear, fogFar, vFogDepth );\\n\\t#endif\\n\\tgl_FragColor.rgb = mix( gl_FragColor.rgb, fogColor, fogFactor );\\n#endif\";\n\nvar fog_pars_fragment = \"#ifdef USE_FOG\\n\\tuniform vec3 fogColor;\\n\\tvarying float vFogDepth;\\n\\t#ifdef FOG_EXP2\\n\\t\\tuniform float fogDensity;\\n\\t#else\\n\\t\\tuniform float fogNear;\\n\\t\\tuniform float fogFar;\\n\\t#endif\\n#endif\";\n\nvar gradientmap_pars_fragment = \"#ifdef USE_GRADIENTMAP\\n\\tuniform sampler2D gradientMap;\\n#endif\\nvec3 getGradientIrradiance( vec3 normal, vec3 lightDirection ) {\\n\\tfloat dotNL = dot( normal, lightDirection );\\n\\tvec2 coord = vec2( dotNL * 0.5 + 0.5, 0.0 );\\n\\t#ifdef USE_GRADIENTMAP\\n\\t\\treturn vec3( texture2D( gradientMap, coord ).r );\\n\\t#else\\n\\t\\treturn ( coord.x < 0.7 ) ? vec3( 0.7 ) : vec3( 1.0 );\\n\\t#endif\\n}\";\n\nvar lightmap_fragment = \"#ifdef USE_LIGHTMAP\\n\\tvec4 lightMapTexel = texture2D( lightMap, vUv2 );\\n\\tvec3 lightMapIrradiance = lightMapTexel.rgb * lightMapIntensity;\\n\\treflectedLight.indirectDiffuse += lightMapIrradiance;\\n#endif\";\n\nvar lightmap_pars_fragment = \"#ifdef USE_LIGHTMAP\\n\\tuniform sampler2D lightMap;\\n\\tuniform float lightMapIntensity;\\n#endif\";\n\nvar lights_lambert_vertex = \"vec3 diffuse = vec3( 1.0 );\\nGeometricContext geometry;\\ngeometry.position = mvPosition.xyz;\\ngeometry.normal = normalize( transformedNormal );\\ngeometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( -mvPosition.xyz );\\nGeometricContext backGeometry;\\nbackGeometry.position = geometry.position;\\nbackGeometry.normal = -geometry.normal;\\nbackGeometry.viewDir = geometry.viewDir;\\nvLightFront = vec3( 0.0 );\\nvIndirectFront = vec3( 0.0 );\\n#ifdef DOUBLE_SIDED\\n\\tvLightBack = vec3( 0.0 );\\n\\tvIndirectBack = vec3( 0.0 );\\n#endif\\nIncidentLight directLight;\\nfloat dotNL;\\nvec3 directLightColor_Diffuse;\\nvIndirectFront += getAmbientLightIrradiance( ambientLightColor );\\nvIndirectFront += getLightProbeIrradiance( lightProbe, geometry.normal );\\n#ifdef DOUBLE_SIDED\\n\\tvIndirectBack += getAmbientLightIrradiance( ambientLightColor );\\n\\tvIndirectBack += getLightProbeIrradiance( lightProbe, backGeometry.normal );\\n#endif\\n#if NUM_POINT_LIGHTS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\\n\\t\\tgetPointLightInfo( pointLights[ i ], geometry, directLight );\\n\\t\\tdotNL = dot( geometry.normal, directLight.direction );\\n\\t\\tdirectLightColor_Diffuse = directLight.color;\\n\\t\\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\tvLightBack += saturate( - dotNL ) * directLightColor_Diffuse;\\n\\t\\t#endif\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if NUM_SPOT_LIGHTS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\\n\\t\\tgetSpotLightInfo( spotLights[ i ], geometry, directLight );\\n\\t\\tdotNL = dot( geometry.normal, directLight.direction );\\n\\t\\tdirectLightColor_Diffuse = directLight.color;\\n\\t\\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\tvLightBack += saturate( - dotNL ) * directLightColor_Diffuse;\\n\\t\\t#endif\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if NUM_DIR_LIGHTS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\\n\\t\\tgetDirectionalLightInfo( directionalLights[ i ], geometry, directLight );\\n\\t\\tdotNL = dot( geometry.normal, directLight.direction );\\n\\t\\tdirectLightColor_Diffuse = directLight.color;\\n\\t\\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\tvLightBack += saturate( - dotNL ) * directLightColor_Diffuse;\\n\\t\\t#endif\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if NUM_HEMI_LIGHTS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\\n\\t\\tvIndirectFront += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry.normal );\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\tvIndirectBack += getHemisphereLightIrradiance( hemisphereLights[ i ], backGeometry.normal );\\n\\t\\t#endif\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\";\n\nvar lights_pars_begin = \"uniform bool receiveShadow;\\nuniform vec3 ambientLightColor;\\nuniform vec3 lightProbe[ 9 ];\\nvec3 shGetIrradianceAt( in vec3 normal, in vec3 shCoefficients[ 9 ] ) {\\n\\tfloat x = normal.x, y = normal.y, z = normal.z;\\n\\tvec3 result = shCoefficients[ 0 ] * 0.886227;\\n\\tresult += shCoefficients[ 1 ] * 2.0 * 0.511664 * y;\\n\\tresult += shCoefficients[ 2 ] * 2.0 * 0.511664 * z;\\n\\tresult += shCoefficients[ 3 ] * 2.0 * 0.511664 * x;\\n\\tresult += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;\\n\\tresult += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;\\n\\tresult += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );\\n\\tresult += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;\\n\\tresult += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );\\n\\treturn result;\\n}\\nvec3 getLightProbeIrradiance( const in vec3 lightProbe[ 9 ], const in vec3 normal ) {\\n\\tvec3 worldNormal = inverseTransformDirection( normal, viewMatrix );\\n\\tvec3 irradiance = shGetIrradianceAt( worldNormal, lightProbe );\\n\\treturn irradiance;\\n}\\nvec3 getAmbientLightIrradiance( const in vec3 ambientLightColor ) {\\n\\tvec3 irradiance = ambientLightColor;\\n\\treturn irradiance;\\n}\\nfloat getDistanceAttenuation( const in float lightDistance, const in float cutoffDistance, const in float decayExponent ) {\\n\\t#if defined ( PHYSICALLY_CORRECT_LIGHTS )\\n\\t\\tfloat distanceFalloff = 1.0 / max( pow( lightDistance, decayExponent ), 0.01 );\\n\\t\\tif ( cutoffDistance > 0.0 ) {\\n\\t\\t\\tdistanceFalloff *= pow2( saturate( 1.0 - pow4( lightDistance / cutoffDistance ) ) );\\n\\t\\t}\\n\\t\\treturn distanceFalloff;\\n\\t#else\\n\\t\\tif ( cutoffDistance > 0.0 && decayExponent > 0.0 ) {\\n\\t\\t\\treturn pow( saturate( - lightDistance / cutoffDistance + 1.0 ), decayExponent );\\n\\t\\t}\\n\\t\\treturn 1.0;\\n\\t#endif\\n}\\nfloat getSpotAttenuation( const in float coneCosine, const in float penumbraCosine, const in float angleCosine ) {\\n\\treturn smoothstep( coneCosine, penumbraCosine, angleCosine );\\n}\\n#if NUM_DIR_LIGHTS > 0\\n\\tstruct DirectionalLight {\\n\\t\\tvec3 direction;\\n\\t\\tvec3 color;\\n\\t};\\n\\tuniform DirectionalLight directionalLights[ NUM_DIR_LIGHTS ];\\n\\tvoid getDirectionalLightInfo( const in DirectionalLight directionalLight, const in GeometricContext geometry, out IncidentLight light ) {\\n\\t\\tlight.color = directionalLight.color;\\n\\t\\tlight.direction = directionalLight.direction;\\n\\t\\tlight.visible = true;\\n\\t}\\n#endif\\n#if NUM_POINT_LIGHTS > 0\\n\\tstruct PointLight {\\n\\t\\tvec3 position;\\n\\t\\tvec3 color;\\n\\t\\tfloat distance;\\n\\t\\tfloat decay;\\n\\t};\\n\\tuniform PointLight pointLights[ NUM_POINT_LIGHTS ];\\n\\tvoid getPointLightInfo( const in PointLight pointLight, const in GeometricContext geometry, out IncidentLight light ) {\\n\\t\\tvec3 lVector = pointLight.position - geometry.position;\\n\\t\\tlight.direction = normalize( lVector );\\n\\t\\tfloat lightDistance = length( lVector );\\n\\t\\tlight.color = pointLight.color;\\n\\t\\tlight.color *= getDistanceAttenuation( lightDistance, pointLight.distance, pointLight.decay );\\n\\t\\tlight.visible = ( light.color != vec3( 0.0 ) );\\n\\t}\\n#endif\\n#if NUM_SPOT_LIGHTS > 0\\n\\tstruct SpotLight {\\n\\t\\tvec3 position;\\n\\t\\tvec3 direction;\\n\\t\\tvec3 color;\\n\\t\\tfloat distance;\\n\\t\\tfloat decay;\\n\\t\\tfloat coneCos;\\n\\t\\tfloat penumbraCos;\\n\\t};\\n\\tuniform SpotLight spotLights[ NUM_SPOT_LIGHTS ];\\n\\tvoid getSpotLightInfo( const in SpotLight spotLight, const in GeometricContext geometry, out IncidentLight light ) {\\n\\t\\tvec3 lVector = spotLight.position - geometry.position;\\n\\t\\tlight.direction = normalize( lVector );\\n\\t\\tfloat angleCos = dot( light.direction, spotLight.direction );\\n\\t\\tfloat spotAttenuation = getSpotAttenuation( spotLight.coneCos, spotLight.penumbraCos, angleCos );\\n\\t\\tif ( spotAttenuation > 0.0 ) {\\n\\t\\t\\tfloat lightDistance = length( lVector );\\n\\t\\t\\tlight.color = spotLight.color * spotAttenuation;\\n\\t\\t\\tlight.color *= getDistanceAttenuation( lightDistance, spotLight.distance, spotLight.decay );\\n\\t\\t\\tlight.visible = ( light.color != vec3( 0.0 ) );\\n\\t\\t} else {\\n\\t\\t\\tlight.color = vec3( 0.0 );\\n\\t\\t\\tlight.visible = false;\\n\\t\\t}\\n\\t}\\n#endif\\n#if NUM_RECT_AREA_LIGHTS > 0\\n\\tstruct RectAreaLight {\\n\\t\\tvec3 color;\\n\\t\\tvec3 position;\\n\\t\\tvec3 halfWidth;\\n\\t\\tvec3 halfHeight;\\n\\t};\\n\\tuniform sampler2D ltc_1;\\tuniform sampler2D ltc_2;\\n\\tuniform RectAreaLight rectAreaLights[ NUM_RECT_AREA_LIGHTS ];\\n#endif\\n#if NUM_HEMI_LIGHTS > 0\\n\\tstruct HemisphereLight {\\n\\t\\tvec3 direction;\\n\\t\\tvec3 skyColor;\\n\\t\\tvec3 groundColor;\\n\\t};\\n\\tuniform HemisphereLight hemisphereLights[ NUM_HEMI_LIGHTS ];\\n\\tvec3 getHemisphereLightIrradiance( const in HemisphereLight hemiLight, const in vec3 normal ) {\\n\\t\\tfloat dotNL = dot( normal, hemiLight.direction );\\n\\t\\tfloat hemiDiffuseWeight = 0.5 * dotNL + 0.5;\\n\\t\\tvec3 irradiance = mix( hemiLight.groundColor, hemiLight.skyColor, hemiDiffuseWeight );\\n\\t\\treturn irradiance;\\n\\t}\\n#endif\";\n\nvar envmap_physical_pars_fragment = \"#if defined( USE_ENVMAP )\\n\\tvec3 getIBLIrradiance( const in vec3 normal ) {\\n\\t\\t#if defined( ENVMAP_TYPE_CUBE_UV )\\n\\t\\t\\tvec3 worldNormal = inverseTransformDirection( normal, viewMatrix );\\n\\t\\t\\tvec4 envMapColor = textureCubeUV( envMap, worldNormal, 1.0 );\\n\\t\\t\\treturn PI * envMapColor.rgb * envMapIntensity;\\n\\t\\t#else\\n\\t\\t\\treturn vec3( 0.0 );\\n\\t\\t#endif\\n\\t}\\n\\tvec3 getIBLRadiance( const in vec3 viewDir, const in vec3 normal, const in float roughness ) {\\n\\t\\t#if defined( ENVMAP_TYPE_CUBE_UV )\\n\\t\\t\\tvec3 reflectVec = reflect( - viewDir, normal );\\n\\t\\t\\treflectVec = normalize( mix( reflectVec, normal, roughness * roughness) );\\n\\t\\t\\treflectVec = inverseTransformDirection( reflectVec, viewMatrix );\\n\\t\\t\\tvec4 envMapColor = textureCubeUV( envMap, reflectVec, roughness );\\n\\t\\t\\treturn envMapColor.rgb * envMapIntensity;\\n\\t\\t#else\\n\\t\\t\\treturn vec3( 0.0 );\\n\\t\\t#endif\\n\\t}\\n#endif\";\n\nvar lights_toon_fragment = \"ToonMaterial material;\\nmaterial.diffuseColor = diffuseColor.rgb;\";\n\nvar lights_toon_pars_fragment = \"varying vec3 vViewPosition;\\nstruct ToonMaterial {\\n\\tvec3 diffuseColor;\\n};\\nvoid RE_Direct_Toon( const in IncidentLight directLight, const in GeometricContext geometry, const in ToonMaterial material, inout ReflectedLight reflectedLight ) {\\n\\tvec3 irradiance = getGradientIrradiance( geometry.normal, directLight.direction ) * directLight.color;\\n\\treflectedLight.directDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\\n}\\nvoid RE_IndirectDiffuse_Toon( const in vec3 irradiance, const in GeometricContext geometry, const in ToonMaterial material, inout ReflectedLight reflectedLight ) {\\n\\treflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\\n}\\n#define RE_Direct\\t\\t\\t\\tRE_Direct_Toon\\n#define RE_IndirectDiffuse\\t\\tRE_IndirectDiffuse_Toon\\n#define Material_LightProbeLOD( material )\\t(0)\";\n\nvar lights_phong_fragment = \"BlinnPhongMaterial material;\\nmaterial.diffuseColor = diffuseColor.rgb;\\nmaterial.specularColor = specular;\\nmaterial.specularShininess = shininess;\\nmaterial.specularStrength = specularStrength;\";\n\nvar lights_phong_pars_fragment = \"varying vec3 vViewPosition;\\nstruct BlinnPhongMaterial {\\n\\tvec3 diffuseColor;\\n\\tvec3 specularColor;\\n\\tfloat specularShininess;\\n\\tfloat specularStrength;\\n};\\nvoid RE_Direct_BlinnPhong( const in IncidentLight directLight, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\\n\\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\\n\\tvec3 irradiance = dotNL * directLight.color;\\n\\treflectedLight.directDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\\n\\treflectedLight.directSpecular += irradiance * BRDF_BlinnPhong( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularShininess ) * material.specularStrength;\\n}\\nvoid RE_IndirectDiffuse_BlinnPhong( const in vec3 irradiance, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\\n\\treflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\\n}\\n#define RE_Direct\\t\\t\\t\\tRE_Direct_BlinnPhong\\n#define RE_IndirectDiffuse\\t\\tRE_IndirectDiffuse_BlinnPhong\\n#define Material_LightProbeLOD( material )\\t(0)\";\n\nvar lights_physical_fragment = \"PhysicalMaterial material;\\nmaterial.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor );\\nvec3 dxy = max( abs( dFdx( geometryNormal ) ), abs( dFdy( geometryNormal ) ) );\\nfloat geometryRoughness = max( max( dxy.x, dxy.y ), dxy.z );\\nmaterial.roughness = max( roughnessFactor, 0.0525 );material.roughness += geometryRoughness;\\nmaterial.roughness = min( material.roughness, 1.0 );\\n#ifdef IOR\\n\\t#ifdef SPECULAR\\n\\t\\tfloat specularIntensityFactor = specularIntensity;\\n\\t\\tvec3 specularColorFactor = specularColor;\\n\\t\\t#ifdef USE_SPECULARINTENSITYMAP\\n\\t\\t\\tspecularIntensityFactor *= texture2D( specularIntensityMap, vUv ).a;\\n\\t\\t#endif\\n\\t\\t#ifdef USE_SPECULARCOLORMAP\\n\\t\\t\\tspecularColorFactor *= texture2D( specularColorMap, vUv ).rgb;\\n\\t\\t#endif\\n\\t\\tmaterial.specularF90 = mix( specularIntensityFactor, 1.0, metalnessFactor );\\n\\t#else\\n\\t\\tfloat specularIntensityFactor = 1.0;\\n\\t\\tvec3 specularColorFactor = vec3( 1.0 );\\n\\t\\tmaterial.specularF90 = 1.0;\\n\\t#endif\\n\\tmaterial.specularColor = mix( min( pow2( ( ior - 1.0 ) / ( ior + 1.0 ) ) * specularColorFactor, vec3( 1.0 ) ) * specularIntensityFactor, diffuseColor.rgb, metalnessFactor );\\n#else\\n\\tmaterial.specularColor = mix( vec3( 0.04 ), diffuseColor.rgb, metalnessFactor );\\n\\tmaterial.specularF90 = 1.0;\\n#endif\\n#ifdef USE_CLEARCOAT\\n\\tmaterial.clearcoat = clearcoat;\\n\\tmaterial.clearcoatRoughness = clearcoatRoughness;\\n\\tmaterial.clearcoatF0 = vec3( 0.04 );\\n\\tmaterial.clearcoatF90 = 1.0;\\n\\t#ifdef USE_CLEARCOATMAP\\n\\t\\tmaterial.clearcoat *= texture2D( clearcoatMap, vUv ).x;\\n\\t#endif\\n\\t#ifdef USE_CLEARCOAT_ROUGHNESSMAP\\n\\t\\tmaterial.clearcoatRoughness *= texture2D( clearcoatRoughnessMap, vUv ).y;\\n\\t#endif\\n\\tmaterial.clearcoat = saturate( material.clearcoat );\\tmaterial.clearcoatRoughness = max( material.clearcoatRoughness, 0.0525 );\\n\\tmaterial.clearcoatRoughness += geometryRoughness;\\n\\tmaterial.clearcoatRoughness = min( material.clearcoatRoughness, 1.0 );\\n#endif\\n#ifdef USE_IRIDESCENCE\\n\\tmaterial.iridescence = iridescence;\\n\\tmaterial.iridescenceIOR = iridescenceIOR;\\n\\t#ifdef USE_IRIDESCENCEMAP\\n\\t\\tmaterial.iridescence *= texture2D( iridescenceMap, vUv ).r;\\n\\t#endif\\n\\t#ifdef USE_IRIDESCENCE_THICKNESSMAP\\n\\t\\tmaterial.iridescenceThickness = (iridescenceThicknessMaximum - iridescenceThicknessMinimum) * texture2D( iridescenceThicknessMap, vUv ).g + iridescenceThicknessMinimum;\\n\\t#else\\n\\t\\tmaterial.iridescenceThickness = iridescenceThicknessMaximum;\\n\\t#endif\\n#endif\\n#ifdef USE_SHEEN\\n\\tmaterial.sheenColor = sheenColor;\\n\\t#ifdef USE_SHEENCOLORMAP\\n\\t\\tmaterial.sheenColor *= texture2D( sheenColorMap, vUv ).rgb;\\n\\t#endif\\n\\tmaterial.sheenRoughness = clamp( sheenRoughness, 0.07, 1.0 );\\n\\t#ifdef USE_SHEENROUGHNESSMAP\\n\\t\\tmaterial.sheenRoughness *= texture2D( sheenRoughnessMap, vUv ).a;\\n\\t#endif\\n#endif\";\n\nvar lights_physical_pars_fragment = \"struct PhysicalMaterial {\\n\\tvec3 diffuseColor;\\n\\tfloat roughness;\\n\\tvec3 specularColor;\\n\\tfloat specularF90;\\n\\t#ifdef USE_CLEARCOAT\\n\\t\\tfloat clearcoat;\\n\\t\\tfloat clearcoatRoughness;\\n\\t\\tvec3 clearcoatF0;\\n\\t\\tfloat clearcoatF90;\\n\\t#endif\\n\\t#ifdef USE_IRIDESCENCE\\n\\t\\tfloat iridescence;\\n\\t\\tfloat iridescenceIOR;\\n\\t\\tfloat iridescenceThickness;\\n\\t\\tvec3 iridescenceFresnel;\\n\\t\\tvec3 iridescenceF0;\\n\\t#endif\\n\\t#ifdef USE_SHEEN\\n\\t\\tvec3 sheenColor;\\n\\t\\tfloat sheenRoughness;\\n\\t#endif\\n};\\nvec3 clearcoatSpecular = vec3( 0.0 );\\nvec3 sheenSpecular = vec3( 0.0 );\\nfloat IBLSheenBRDF( const in vec3 normal, const in vec3 viewDir, const in float roughness) {\\n\\tfloat dotNV = saturate( dot( normal, viewDir ) );\\n\\tfloat r2 = roughness * roughness;\\n\\tfloat a = roughness < 0.25 ? -339.2 * r2 + 161.4 * roughness - 25.9 : -8.48 * r2 + 14.3 * roughness - 9.95;\\n\\tfloat b = roughness < 0.25 ? 44.0 * r2 - 23.7 * roughness + 3.26 : 1.97 * r2 - 3.27 * roughness + 0.72;\\n\\tfloat DG = exp( a * dotNV + b ) + ( roughness < 0.25 ? 0.0 : 0.1 * ( roughness - 0.25 ) );\\n\\treturn saturate( DG * RECIPROCAL_PI );\\n}\\nvec2 DFGApprox( const in vec3 normal, const in vec3 viewDir, const in float roughness ) {\\n\\tfloat dotNV = saturate( dot( normal, viewDir ) );\\n\\tconst vec4 c0 = vec4( - 1, - 0.0275, - 0.572, 0.022 );\\n\\tconst vec4 c1 = vec4( 1, 0.0425, 1.04, - 0.04 );\\n\\tvec4 r = roughness * c0 + c1;\\n\\tfloat a004 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\\n\\tvec2 fab = vec2( - 1.04, 1.04 ) * a004 + r.zw;\\n\\treturn fab;\\n}\\nvec3 EnvironmentBRDF( const in vec3 normal, const in vec3 viewDir, const in vec3 specularColor, const in float specularF90, const in float roughness ) {\\n\\tvec2 fab = DFGApprox( normal, viewDir, roughness );\\n\\treturn specularColor * fab.x + specularF90 * fab.y;\\n}\\n#ifdef USE_IRIDESCENCE\\nvoid computeMultiscatteringIridescence( const in vec3 normal, const in vec3 viewDir, const in vec3 specularColor, const in float specularF90, const in float iridescence, const in vec3 iridescenceF0, const in float roughness, inout vec3 singleScatter, inout vec3 multiScatter ) {\\n#else\\nvoid computeMultiscattering( const in vec3 normal, const in vec3 viewDir, const in vec3 specularColor, const in float specularF90, const in float roughness, inout vec3 singleScatter, inout vec3 multiScatter ) {\\n#endif\\n\\tvec2 fab = DFGApprox( normal, viewDir, roughness );\\n\\t#ifdef USE_IRIDESCENCE\\n\\t\\tvec3 Fr = mix( specularColor, iridescenceF0, iridescence );\\n\\t#else\\n\\t\\tvec3 Fr = specularColor;\\n\\t#endif\\n\\tvec3 FssEss = Fr * fab.x + specularF90 * fab.y;\\n\\tfloat Ess = fab.x + fab.y;\\n\\tfloat Ems = 1.0 - Ess;\\n\\tvec3 Favg = Fr + ( 1.0 - Fr ) * 0.047619;\\tvec3 Fms = FssEss * Favg / ( 1.0 - Ems * Favg );\\n\\tsingleScatter += FssEss;\\n\\tmultiScatter += Fms * Ems;\\n}\\n#if NUM_RECT_AREA_LIGHTS > 0\\n\\tvoid RE_Direct_RectArea_Physical( const in RectAreaLight rectAreaLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\\n\\t\\tvec3 normal = geometry.normal;\\n\\t\\tvec3 viewDir = geometry.viewDir;\\n\\t\\tvec3 position = geometry.position;\\n\\t\\tvec3 lightPos = rectAreaLight.position;\\n\\t\\tvec3 halfWidth = rectAreaLight.halfWidth;\\n\\t\\tvec3 halfHeight = rectAreaLight.halfHeight;\\n\\t\\tvec3 lightColor = rectAreaLight.color;\\n\\t\\tfloat roughness = material.roughness;\\n\\t\\tvec3 rectCoords[ 4 ];\\n\\t\\trectCoords[ 0 ] = lightPos + halfWidth - halfHeight;\\t\\trectCoords[ 1 ] = lightPos - halfWidth - halfHeight;\\n\\t\\trectCoords[ 2 ] = lightPos - halfWidth + halfHeight;\\n\\t\\trectCoords[ 3 ] = lightPos + halfWidth + halfHeight;\\n\\t\\tvec2 uv = LTC_Uv( normal, viewDir, roughness );\\n\\t\\tvec4 t1 = texture2D( ltc_1, uv );\\n\\t\\tvec4 t2 = texture2D( ltc_2, uv );\\n\\t\\tmat3 mInv = mat3(\\n\\t\\t\\tvec3( t1.x, 0, t1.y ),\\n\\t\\t\\tvec3( 0, 1, 0 ),\\n\\t\\t\\tvec3( t1.z, 0, t1.w )\\n\\t\\t);\\n\\t\\tvec3 fresnel = ( material.specularColor * t2.x + ( vec3( 1.0 ) - material.specularColor ) * t2.y );\\n\\t\\treflectedLight.directSpecular += lightColor * fresnel * LTC_Evaluate( normal, viewDir, position, mInv, rectCoords );\\n\\t\\treflectedLight.directDiffuse += lightColor * material.diffuseColor * LTC_Evaluate( normal, viewDir, position, mat3( 1.0 ), rectCoords );\\n\\t}\\n#endif\\nvoid RE_Direct_Physical( const in IncidentLight directLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\\n\\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\\n\\tvec3 irradiance = dotNL * directLight.color;\\n\\t#ifdef USE_CLEARCOAT\\n\\t\\tfloat dotNLcc = saturate( dot( geometry.clearcoatNormal, directLight.direction ) );\\n\\t\\tvec3 ccIrradiance = dotNLcc * directLight.color;\\n\\t\\tclearcoatSpecular += ccIrradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.clearcoatNormal, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness );\\n\\t#endif\\n\\t#ifdef USE_SHEEN\\n\\t\\tsheenSpecular += irradiance * BRDF_Sheen( directLight.direction, geometry.viewDir, geometry.normal, material.sheenColor, material.sheenRoughness );\\n\\t#endif\\n\\t#ifdef USE_IRIDESCENCE\\n\\t\\treflectedLight.directSpecular += irradiance * BRDF_GGX_Iridescence( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness );\\n\\t#else\\n\\t\\treflectedLight.directSpecular += irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.roughness );\\n\\t#endif\\n\\treflectedLight.directDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\\n}\\nvoid RE_IndirectDiffuse_Physical( const in vec3 irradiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\\n\\treflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\\n}\\nvoid RE_IndirectSpecular_Physical( const in vec3 radiance, const in vec3 irradiance, const in vec3 clearcoatRadiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight) {\\n\\t#ifdef USE_CLEARCOAT\\n\\t\\tclearcoatSpecular += clearcoatRadiance * EnvironmentBRDF( geometry.clearcoatNormal, geometry.viewDir, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness );\\n\\t#endif\\n\\t#ifdef USE_SHEEN\\n\\t\\tsheenSpecular += irradiance * material.sheenColor * IBLSheenBRDF( geometry.normal, geometry.viewDir, material.sheenRoughness );\\n\\t#endif\\n\\tvec3 singleScattering = vec3( 0.0 );\\n\\tvec3 multiScattering = vec3( 0.0 );\\n\\tvec3 cosineWeightedIrradiance = irradiance * RECIPROCAL_PI;\\n\\t#ifdef USE_IRIDESCENCE\\n\\t\\tcomputeMultiscatteringIridescence( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness, singleScattering, multiScattering );\\n\\t#else\\n\\t\\tcomputeMultiscattering( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.roughness, singleScattering, multiScattering );\\n\\t#endif\\n\\tvec3 totalScattering = singleScattering + multiScattering;\\n\\tvec3 diffuse = material.diffuseColor * ( 1.0 - max( max( totalScattering.r, totalScattering.g ), totalScattering.b ) );\\n\\treflectedLight.indirectSpecular += radiance * singleScattering;\\n\\treflectedLight.indirectSpecular += multiScattering * cosineWeightedIrradiance;\\n\\treflectedLight.indirectDiffuse += diffuse * cosineWeightedIrradiance;\\n}\\n#define RE_Direct\\t\\t\\t\\tRE_Direct_Physical\\n#define RE_Direct_RectArea\\t\\tRE_Direct_RectArea_Physical\\n#define RE_IndirectDiffuse\\t\\tRE_IndirectDiffuse_Physical\\n#define RE_IndirectSpecular\\t\\tRE_IndirectSpecular_Physical\\nfloat computeSpecularOcclusion( const in float dotNV, const in float ambientOcclusion, const in float roughness ) {\\n\\treturn saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion );\\n}\";\n\nvar lights_fragment_begin = \"\\nGeometricContext geometry;\\ngeometry.position = - vViewPosition;\\ngeometry.normal = normal;\\ngeometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( vViewPosition );\\n#ifdef USE_CLEARCOAT\\n\\tgeometry.clearcoatNormal = clearcoatNormal;\\n#endif\\n#ifdef USE_IRIDESCENCE\\nfloat dotNVi = saturate( dot( normal, geometry.viewDir ) );\\nif ( material.iridescenceThickness == 0.0 ) {\\n\\tmaterial.iridescence = 0.0;\\n} else {\\n\\tmaterial.iridescence = saturate( material.iridescence );\\n}\\nif ( material.iridescence > 0.0 ) {\\n\\tmaterial.iridescenceFresnel = evalIridescence( 1.0, material.iridescenceIOR, dotNVi, material.iridescenceThickness, material.specularColor );\\n\\tmaterial.iridescenceF0 = Schlick_to_F0( material.iridescenceFresnel, 1.0, dotNVi );\\n}\\n#endif\\nIncidentLight directLight;\\n#if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )\\n\\tPointLight pointLight;\\n\\t#if defined( USE_SHADOWMAP ) && NUM_POINT_LIGHT_SHADOWS > 0\\n\\tPointLightShadow pointLightShadow;\\n\\t#endif\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\\n\\t\\tpointLight = pointLights[ i ];\\n\\t\\tgetPointLightInfo( pointLight, geometry, directLight );\\n\\t\\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_POINT_LIGHT_SHADOWS )\\n\\t\\tpointLightShadow = pointLightShadows[ i ];\\n\\t\\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getPointShadow( pointShadowMap[ i ], pointLightShadow.shadowMapSize, pointLightShadow.shadowBias, pointLightShadow.shadowRadius, vPointShadowCoord[ i ], pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar ) : 1.0;\\n\\t\\t#endif\\n\\t\\tRE_Direct( directLight, geometry, material, reflectedLight );\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )\\n\\tSpotLight spotLight;\\n\\t#if defined( USE_SHADOWMAP ) && NUM_SPOT_LIGHT_SHADOWS > 0\\n\\tSpotLightShadow spotLightShadow;\\n\\t#endif\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\\n\\t\\tspotLight = spotLights[ i ];\\n\\t\\tgetSpotLightInfo( spotLight, geometry, directLight );\\n\\t\\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_SPOT_LIGHT_SHADOWS )\\n\\t\\tspotLightShadow = spotLightShadows[ i ];\\n\\t\\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( spotShadowMap[ i ], spotLightShadow.shadowMapSize, spotLightShadow.shadowBias, spotLightShadow.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\\n\\t\\t#endif\\n\\t\\tRE_Direct( directLight, geometry, material, reflectedLight );\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct )\\n\\tDirectionalLight directionalLight;\\n\\t#if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\\n\\tDirectionalLightShadow directionalLightShadow;\\n\\t#endif\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\\n\\t\\tdirectionalLight = directionalLights[ i ];\\n\\t\\tgetDirectionalLightInfo( directionalLight, geometry, directLight );\\n\\t\\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )\\n\\t\\tdirectionalLightShadow = directionalLightShadows[ i ];\\n\\t\\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\\n\\t\\t#endif\\n\\t\\tRE_Direct( directLight, geometry, material, reflectedLight );\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )\\n\\tRectAreaLight rectAreaLight;\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {\\n\\t\\trectAreaLight = rectAreaLights[ i ];\\n\\t\\tRE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );\\n\\t}\\n\\t#pragma unroll_loop_end\\n#endif\\n#if defined( RE_IndirectDiffuse )\\n\\tvec3 iblIrradiance = vec3( 0.0 );\\n\\tvec3 irradiance = getAmbientLightIrradiance( ambientLightColor );\\n\\tirradiance += getLightProbeIrradiance( lightProbe, geometry.normal );\\n\\t#if ( NUM_HEMI_LIGHTS > 0 )\\n\\t\\t#pragma unroll_loop_start\\n\\t\\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\\n\\t\\t\\tirradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry.normal );\\n\\t\\t}\\n\\t\\t#pragma unroll_loop_end\\n\\t#endif\\n#endif\\n#if defined( RE_IndirectSpecular )\\n\\tvec3 radiance = vec3( 0.0 );\\n\\tvec3 clearcoatRadiance = vec3( 0.0 );\\n#endif\";\n\nvar lights_fragment_maps = \"#if defined( RE_IndirectDiffuse )\\n\\t#ifdef USE_LIGHTMAP\\n\\t\\tvec4 lightMapTexel = texture2D( lightMap, vUv2 );\\n\\t\\tvec3 lightMapIrradiance = lightMapTexel.rgb * lightMapIntensity;\\n\\t\\tirradiance += lightMapIrradiance;\\n\\t#endif\\n\\t#if defined( USE_ENVMAP ) && defined( STANDARD ) && defined( ENVMAP_TYPE_CUBE_UV )\\n\\t\\tiblIrradiance += getIBLIrradiance( geometry.normal );\\n\\t#endif\\n#endif\\n#if defined( USE_ENVMAP ) && defined( RE_IndirectSpecular )\\n\\tradiance += getIBLRadiance( geometry.viewDir, geometry.normal, material.roughness );\\n\\t#ifdef USE_CLEARCOAT\\n\\t\\tclearcoatRadiance += getIBLRadiance( geometry.viewDir, geometry.clearcoatNormal, material.clearcoatRoughness );\\n\\t#endif\\n#endif\";\n\nvar lights_fragment_end = \"#if defined( RE_IndirectDiffuse )\\n\\tRE_IndirectDiffuse( irradiance, geometry, material, reflectedLight );\\n#endif\\n#if defined( RE_IndirectSpecular )\\n\\tRE_IndirectSpecular( radiance, iblIrradiance, clearcoatRadiance, geometry, material, reflectedLight );\\n#endif\";\n\nvar logdepthbuf_fragment = \"#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\\n\\tgl_FragDepthEXT = vIsPerspective == 0.0 ? gl_FragCoord.z : log2( vFragDepth ) * logDepthBufFC * 0.5;\\n#endif\";\n\nvar logdepthbuf_pars_fragment = \"#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\\n\\tuniform float logDepthBufFC;\\n\\tvarying float vFragDepth;\\n\\tvarying float vIsPerspective;\\n#endif\";\n\nvar logdepthbuf_pars_vertex = \"#ifdef USE_LOGDEPTHBUF\\n\\t#ifdef USE_LOGDEPTHBUF_EXT\\n\\t\\tvarying float vFragDepth;\\n\\t\\tvarying float vIsPerspective;\\n\\t#else\\n\\t\\tuniform float logDepthBufFC;\\n\\t#endif\\n#endif\";\n\nvar logdepthbuf_vertex = \"#ifdef USE_LOGDEPTHBUF\\n\\t#ifdef USE_LOGDEPTHBUF_EXT\\n\\t\\tvFragDepth = 1.0 + gl_Position.w;\\n\\t\\tvIsPerspective = float( isPerspectiveMatrix( projectionMatrix ) );\\n\\t#else\\n\\t\\tif ( isPerspectiveMatrix( projectionMatrix ) ) {\\n\\t\\t\\tgl_Position.z = log2( max( EPSILON, gl_Position.w + 1.0 ) ) * logDepthBufFC - 1.0;\\n\\t\\t\\tgl_Position.z *= gl_Position.w;\\n\\t\\t}\\n\\t#endif\\n#endif\";\n\nvar map_fragment = \"#ifdef USE_MAP\\n\\tvec4 sampledDiffuseColor = texture2D( map, vUv );\\n\\t#ifdef DECODE_VIDEO_TEXTURE\\n\\t\\tsampledDiffuseColor = vec4( mix( pow( sampledDiffuseColor.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), sampledDiffuseColor.rgb * 0.0773993808, vec3( lessThanEqual( sampledDiffuseColor.rgb, vec3( 0.04045 ) ) ) ), sampledDiffuseColor.w );\\n\\t#endif\\n\\tdiffuseColor *= sampledDiffuseColor;\\n#endif\";\n\nvar map_pars_fragment = \"#ifdef USE_MAP\\n\\tuniform sampler2D map;\\n#endif\";\n\nvar map_particle_fragment = \"#if defined( USE_MAP ) || defined( USE_ALPHAMAP )\\n\\tvec2 uv = ( uvTransform * vec3( gl_PointCoord.x, 1.0 - gl_PointCoord.y, 1 ) ).xy;\\n#endif\\n#ifdef USE_MAP\\n\\tdiffuseColor *= texture2D( map, uv );\\n#endif\\n#ifdef USE_ALPHAMAP\\n\\tdiffuseColor.a *= texture2D( alphaMap, uv ).g;\\n#endif\";\n\nvar map_particle_pars_fragment = \"#if defined( USE_MAP ) || defined( USE_ALPHAMAP )\\n\\tuniform mat3 uvTransform;\\n#endif\\n#ifdef USE_MAP\\n\\tuniform sampler2D map;\\n#endif\\n#ifdef USE_ALPHAMAP\\n\\tuniform sampler2D alphaMap;\\n#endif\";\n\nvar metalnessmap_fragment = \"float metalnessFactor = metalness;\\n#ifdef USE_METALNESSMAP\\n\\tvec4 texelMetalness = texture2D( metalnessMap, vUv );\\n\\tmetalnessFactor *= texelMetalness.b;\\n#endif\";\n\nvar metalnessmap_pars_fragment = \"#ifdef USE_METALNESSMAP\\n\\tuniform sampler2D metalnessMap;\\n#endif\";\n\nvar morphcolor_vertex = \"#if defined( USE_MORPHCOLORS ) && defined( MORPHTARGETS_TEXTURE )\\n\\tvColor *= morphTargetBaseInfluence;\\n\\tfor ( int i = 0; i < MORPHTARGETS_COUNT; i ++ ) {\\n\\t\\t#if defined( USE_COLOR_ALPHA )\\n\\t\\t\\tif ( morphTargetInfluences[ i ] != 0.0 ) vColor += getMorph( gl_VertexID, i, 2 ) * morphTargetInfluences[ i ];\\n\\t\\t#elif defined( USE_COLOR )\\n\\t\\t\\tif ( morphTargetInfluences[ i ] != 0.0 ) vColor += getMorph( gl_VertexID, i, 2 ).rgb * morphTargetInfluences[ i ];\\n\\t\\t#endif\\n\\t}\\n#endif\";\n\nvar morphnormal_vertex = \"#ifdef USE_MORPHNORMALS\\n\\tobjectNormal *= morphTargetBaseInfluence;\\n\\t#ifdef MORPHTARGETS_TEXTURE\\n\\t\\tfor ( int i = 0; i < MORPHTARGETS_COUNT; i ++ ) {\\n\\t\\t\\tif ( morphTargetInfluences[ i ] != 0.0 ) objectNormal += getMorph( gl_VertexID, i, 1 ).xyz * morphTargetInfluences[ i ];\\n\\t\\t}\\n\\t#else\\n\\t\\tobjectNormal += morphNormal0 * morphTargetInfluences[ 0 ];\\n\\t\\tobjectNormal += morphNormal1 * morphTargetInfluences[ 1 ];\\n\\t\\tobjectNormal += morphNormal2 * morphTargetInfluences[ 2 ];\\n\\t\\tobjectNormal += morphNormal3 * morphTargetInfluences[ 3 ];\\n\\t#endif\\n#endif\";\n\nvar morphtarget_pars_vertex = \"#ifdef USE_MORPHTARGETS\\n\\tuniform float morphTargetBaseInfluence;\\n\\t#ifdef MORPHTARGETS_TEXTURE\\n\\t\\tuniform float morphTargetInfluences[ MORPHTARGETS_COUNT ];\\n\\t\\tuniform sampler2DArray morphTargetsTexture;\\n\\t\\tuniform ivec2 morphTargetsTextureSize;\\n\\t\\tvec4 getMorph( const in int vertexIndex, const in int morphTargetIndex, const in int offset ) {\\n\\t\\t\\tint texelIndex = vertexIndex * MORPHTARGETS_TEXTURE_STRIDE + offset;\\n\\t\\t\\tint y = texelIndex / morphTargetsTextureSize.x;\\n\\t\\t\\tint x = texelIndex - y * morphTargetsTextureSize.x;\\n\\t\\t\\tivec3 morphUV = ivec3( x, y, morphTargetIndex );\\n\\t\\t\\treturn texelFetch( morphTargetsTexture, morphUV, 0 );\\n\\t\\t}\\n\\t#else\\n\\t\\t#ifndef USE_MORPHNORMALS\\n\\t\\t\\tuniform float morphTargetInfluences[ 8 ];\\n\\t\\t#else\\n\\t\\t\\tuniform float morphTargetInfluences[ 4 ];\\n\\t\\t#endif\\n\\t#endif\\n#endif\";\n\nvar morphtarget_vertex = \"#ifdef USE_MORPHTARGETS\\n\\ttransformed *= morphTargetBaseInfluence;\\n\\t#ifdef MORPHTARGETS_TEXTURE\\n\\t\\tfor ( int i = 0; i < MORPHTARGETS_COUNT; i ++ ) {\\n\\t\\t\\tif ( morphTargetInfluences[ i ] != 0.0 ) transformed += getMorph( gl_VertexID, i, 0 ).xyz * morphTargetInfluences[ i ];\\n\\t\\t}\\n\\t#else\\n\\t\\ttransformed += morphTarget0 * morphTargetInfluences[ 0 ];\\n\\t\\ttransformed += morphTarget1 * morphTargetInfluences[ 1 ];\\n\\t\\ttransformed += morphTarget2 * morphTargetInfluences[ 2 ];\\n\\t\\ttransformed += morphTarget3 * morphTargetInfluences[ 3 ];\\n\\t\\t#ifndef USE_MORPHNORMALS\\n\\t\\t\\ttransformed += morphTarget4 * morphTargetInfluences[ 4 ];\\n\\t\\t\\ttransformed += morphTarget5 * morphTargetInfluences[ 5 ];\\n\\t\\t\\ttransformed += morphTarget6 * morphTargetInfluences[ 6 ];\\n\\t\\t\\ttransformed += morphTarget7 * morphTargetInfluences[ 7 ];\\n\\t\\t#endif\\n\\t#endif\\n#endif\";\n\nvar normal_fragment_begin = \"float faceDirection = gl_FrontFacing ? 1.0 : - 1.0;\\n#ifdef FLAT_SHADED\\n\\tvec3 fdx = vec3( dFdx( vViewPosition.x ), dFdx( vViewPosition.y ), dFdx( vViewPosition.z ) );\\n\\tvec3 fdy = vec3( dFdy( vViewPosition.x ), dFdy( vViewPosition.y ), dFdy( vViewPosition.z ) );\\n\\tvec3 normal = normalize( cross( fdx, fdy ) );\\n#else\\n\\tvec3 normal = normalize( vNormal );\\n\\t#ifdef DOUBLE_SIDED\\n\\t\\tnormal = normal * faceDirection;\\n\\t#endif\\n\\t#ifdef USE_TANGENT\\n\\t\\tvec3 tangent = normalize( vTangent );\\n\\t\\tvec3 bitangent = normalize( vBitangent );\\n\\t\\t#ifdef DOUBLE_SIDED\\n\\t\\t\\ttangent = tangent * faceDirection;\\n\\t\\t\\tbitangent = bitangent * faceDirection;\\n\\t\\t#endif\\n\\t\\t#if defined( TANGENTSPACE_NORMALMAP ) || defined( USE_CLEARCOAT_NORMALMAP )\\n\\t\\t\\tmat3 vTBN = mat3( tangent, bitangent, normal );\\n\\t\\t#endif\\n\\t#endif\\n#endif\\nvec3 geometryNormal = normal;\";\n\nvar normal_fragment_maps = \"#ifdef OBJECTSPACE_NORMALMAP\\n\\tnormal = texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\\n\\t#ifdef FLIP_SIDED\\n\\t\\tnormal = - normal;\\n\\t#endif\\n\\t#ifdef DOUBLE_SIDED\\n\\t\\tnormal = normal * faceDirection;\\n\\t#endif\\n\\tnormal = normalize( normalMatrix * normal );\\n#elif defined( TANGENTSPACE_NORMALMAP )\\n\\tvec3 mapN = texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\\n\\tmapN.xy *= normalScale;\\n\\t#ifdef USE_TANGENT\\n\\t\\tnormal = normalize( vTBN * mapN );\\n\\t#else\\n\\t\\tnormal = perturbNormal2Arb( - vViewPosition, normal, mapN, faceDirection );\\n\\t#endif\\n#elif defined( USE_BUMPMAP )\\n\\tnormal = perturbNormalArb( - vViewPosition, normal, dHdxy_fwd(), faceDirection );\\n#endif\";\n\nvar normal_pars_fragment = \"#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n\\t#ifdef USE_TANGENT\\n\\t\\tvarying vec3 vTangent;\\n\\t\\tvarying vec3 vBitangent;\\n\\t#endif\\n#endif\";\n\nvar normal_pars_vertex = \"#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n\\t#ifdef USE_TANGENT\\n\\t\\tvarying vec3 vTangent;\\n\\t\\tvarying vec3 vBitangent;\\n\\t#endif\\n#endif\";\n\nvar normal_vertex = \"#ifndef FLAT_SHADED\\n\\tvNormal = normalize( transformedNormal );\\n\\t#ifdef USE_TANGENT\\n\\t\\tvTangent = normalize( transformedTangent );\\n\\t\\tvBitangent = normalize( cross( vNormal, vTangent ) * tangent.w );\\n\\t#endif\\n#endif\";\n\nvar normalmap_pars_fragment = \"#ifdef USE_NORMALMAP\\n\\tuniform sampler2D normalMap;\\n\\tuniform vec2 normalScale;\\n#endif\\n#ifdef OBJECTSPACE_NORMALMAP\\n\\tuniform mat3 normalMatrix;\\n#endif\\n#if ! defined ( USE_TANGENT ) && ( defined ( TANGENTSPACE_NORMALMAP ) || defined ( USE_CLEARCOAT_NORMALMAP ) )\\n\\tvec3 perturbNormal2Arb( vec3 eye_pos, vec3 surf_norm, vec3 mapN, float faceDirection ) {\\n\\t\\tvec3 q0 = vec3( dFdx( eye_pos.x ), dFdx( eye_pos.y ), dFdx( eye_pos.z ) );\\n\\t\\tvec3 q1 = vec3( dFdy( eye_pos.x ), dFdy( eye_pos.y ), dFdy( eye_pos.z ) );\\n\\t\\tvec2 st0 = dFdx( vUv.st );\\n\\t\\tvec2 st1 = dFdy( vUv.st );\\n\\t\\tvec3 N = surf_norm;\\n\\t\\tvec3 q1perp = cross( q1, N );\\n\\t\\tvec3 q0perp = cross( N, q0 );\\n\\t\\tvec3 T = q1perp * st0.x + q0perp * st1.x;\\n\\t\\tvec3 B = q1perp * st0.y + q0perp * st1.y;\\n\\t\\tfloat det = max( dot( T, T ), dot( B, B ) );\\n\\t\\tfloat scale = ( det == 0.0 ) ? 0.0 : faceDirection * inversesqrt( det );\\n\\t\\treturn normalize( T * ( mapN.x * scale ) + B * ( mapN.y * scale ) + N * mapN.z );\\n\\t}\\n#endif\";\n\nvar clearcoat_normal_fragment_begin = \"#ifdef USE_CLEARCOAT\\n\\tvec3 clearcoatNormal = geometryNormal;\\n#endif\";\n\nvar clearcoat_normal_fragment_maps = \"#ifdef USE_CLEARCOAT_NORMALMAP\\n\\tvec3 clearcoatMapN = texture2D( clearcoatNormalMap, vUv ).xyz * 2.0 - 1.0;\\n\\tclearcoatMapN.xy *= clearcoatNormalScale;\\n\\t#ifdef USE_TANGENT\\n\\t\\tclearcoatNormal = normalize( vTBN * clearcoatMapN );\\n\\t#else\\n\\t\\tclearcoatNormal = perturbNormal2Arb( - vViewPosition, clearcoatNormal, clearcoatMapN, faceDirection );\\n\\t#endif\\n#endif\";\n\nvar clearcoat_pars_fragment = \"#ifdef USE_CLEARCOATMAP\\n\\tuniform sampler2D clearcoatMap;\\n#endif\\n#ifdef USE_CLEARCOAT_ROUGHNESSMAP\\n\\tuniform sampler2D clearcoatRoughnessMap;\\n#endif\\n#ifdef USE_CLEARCOAT_NORMALMAP\\n\\tuniform sampler2D clearcoatNormalMap;\\n\\tuniform vec2 clearcoatNormalScale;\\n#endif\";\n\nvar iridescence_pars_fragment = \"#ifdef USE_IRIDESCENCEMAP\\n\\tuniform sampler2D iridescenceMap;\\n#endif\\n#ifdef USE_IRIDESCENCE_THICKNESSMAP\\n\\tuniform sampler2D iridescenceThicknessMap;\\n#endif\";\n\nvar output_fragment = \"#ifdef OPAQUE\\ndiffuseColor.a = 1.0;\\n#endif\\n#ifdef USE_TRANSMISSION\\ndiffuseColor.a *= transmissionAlpha + 0.1;\\n#endif\\ngl_FragColor = vec4( outgoingLight, diffuseColor.a );\";\n\nvar packing = \"vec3 packNormalToRGB( const in vec3 normal ) {\\n\\treturn normalize( normal ) * 0.5 + 0.5;\\n}\\nvec3 unpackRGBToNormal( const in vec3 rgb ) {\\n\\treturn 2.0 * rgb.xyz - 1.0;\\n}\\nconst float PackUpscale = 256. / 255.;const float UnpackDownscale = 255. / 256.;\\nconst vec3 PackFactors = vec3( 256. * 256. * 256., 256. * 256., 256. );\\nconst vec4 UnpackFactors = UnpackDownscale / vec4( PackFactors, 1. );\\nconst float ShiftRight8 = 1. / 256.;\\nvec4 packDepthToRGBA( const in float v ) {\\n\\tvec4 r = vec4( fract( v * PackFactors ), v );\\n\\tr.yzw -= r.xyz * ShiftRight8;\\treturn r * PackUpscale;\\n}\\nfloat unpackRGBAToDepth( const in vec4 v ) {\\n\\treturn dot( v, UnpackFactors );\\n}\\nvec4 pack2HalfToRGBA( vec2 v ) {\\n\\tvec4 r = vec4( v.x, fract( v.x * 255.0 ), v.y, fract( v.y * 255.0 ) );\\n\\treturn vec4( r.x - r.y / 255.0, r.y, r.z - r.w / 255.0, r.w );\\n}\\nvec2 unpackRGBATo2Half( vec4 v ) {\\n\\treturn vec2( v.x + ( v.y / 255.0 ), v.z + ( v.w / 255.0 ) );\\n}\\nfloat viewZToOrthographicDepth( const in float viewZ, const in float near, const in float far ) {\\n\\treturn ( viewZ + near ) / ( near - far );\\n}\\nfloat orthographicDepthToViewZ( const in float linearClipZ, const in float near, const in float far ) {\\n\\treturn linearClipZ * ( near - far ) - near;\\n}\\nfloat viewZToPerspectiveDepth( const in float viewZ, const in float near, const in float far ) {\\n\\treturn ( ( near + viewZ ) * far ) / ( ( far - near ) * viewZ );\\n}\\nfloat perspectiveDepthToViewZ( const in float invClipZ, const in float near, const in float far ) {\\n\\treturn ( near * far ) / ( ( far - near ) * invClipZ - far );\\n}\";\n\nvar premultiplied_alpha_fragment = \"#ifdef PREMULTIPLIED_ALPHA\\n\\tgl_FragColor.rgb *= gl_FragColor.a;\\n#endif\";\n\nvar project_vertex = \"vec4 mvPosition = vec4( transformed, 1.0 );\\n#ifdef USE_INSTANCING\\n\\tmvPosition = instanceMatrix * mvPosition;\\n#endif\\nmvPosition = modelViewMatrix * mvPosition;\\ngl_Position = projectionMatrix * mvPosition;\";\n\nvar dithering_fragment = \"#ifdef DITHERING\\n\\tgl_FragColor.rgb = dithering( gl_FragColor.rgb );\\n#endif\";\n\nvar dithering_pars_fragment = \"#ifdef DITHERING\\n\\tvec3 dithering( vec3 color ) {\\n\\t\\tfloat grid_position = rand( gl_FragCoord.xy );\\n\\t\\tvec3 dither_shift_RGB = vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 );\\n\\t\\tdither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position );\\n\\t\\treturn color + dither_shift_RGB;\\n\\t}\\n#endif\";\n\nvar roughnessmap_fragment = \"float roughnessFactor = roughness;\\n#ifdef USE_ROUGHNESSMAP\\n\\tvec4 texelRoughness = texture2D( roughnessMap, vUv );\\n\\troughnessFactor *= texelRoughness.g;\\n#endif\";\n\nvar roughnessmap_pars_fragment = \"#ifdef USE_ROUGHNESSMAP\\n\\tuniform sampler2D roughnessMap;\\n#endif\";\n\nvar shadowmap_pars_fragment = \"#ifdef USE_SHADOWMAP\\n\\t#if NUM_DIR_LIGHT_SHADOWS > 0\\n\\t\\tuniform sampler2D directionalShadowMap[ NUM_DIR_LIGHT_SHADOWS ];\\n\\t\\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHT_SHADOWS ];\\n\\t\\tstruct DirectionalLightShadow {\\n\\t\\t\\tfloat shadowBias;\\n\\t\\t\\tfloat shadowNormalBias;\\n\\t\\t\\tfloat shadowRadius;\\n\\t\\t\\tvec2 shadowMapSize;\\n\\t\\t};\\n\\t\\tuniform DirectionalLightShadow directionalLightShadows[ NUM_DIR_LIGHT_SHADOWS ];\\n\\t#endif\\n\\t#if NUM_SPOT_LIGHT_SHADOWS > 0\\n\\t\\tuniform sampler2D spotShadowMap[ NUM_SPOT_LIGHT_SHADOWS ];\\n\\t\\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHT_SHADOWS ];\\n\\t\\tstruct SpotLightShadow {\\n\\t\\t\\tfloat shadowBias;\\n\\t\\t\\tfloat shadowNormalBias;\\n\\t\\t\\tfloat shadowRadius;\\n\\t\\t\\tvec2 shadowMapSize;\\n\\t\\t};\\n\\t\\tuniform SpotLightShadow spotLightShadows[ NUM_SPOT_LIGHT_SHADOWS ];\\n\\t#endif\\n\\t#if NUM_POINT_LIGHT_SHADOWS > 0\\n\\t\\tuniform sampler2D pointShadowMap[ NUM_POINT_LIGHT_SHADOWS ];\\n\\t\\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHT_SHADOWS ];\\n\\t\\tstruct PointLightShadow {\\n\\t\\t\\tfloat shadowBias;\\n\\t\\t\\tfloat shadowNormalBias;\\n\\t\\t\\tfloat shadowRadius;\\n\\t\\t\\tvec2 shadowMapSize;\\n\\t\\t\\tfloat shadowCameraNear;\\n\\t\\t\\tfloat shadowCameraFar;\\n\\t\\t};\\n\\t\\tuniform PointLightShadow pointLightShadows[ NUM_POINT_LIGHT_SHADOWS ];\\n\\t#endif\\n\\tfloat texture2DCompare( sampler2D depths, vec2 uv, float compare ) {\\n\\t\\treturn step( compare, unpackRGBAToDepth( texture2D( depths, uv ) ) );\\n\\t}\\n\\tvec2 texture2DDistribution( sampler2D shadow, vec2 uv ) {\\n\\t\\treturn unpackRGBATo2Half( texture2D( shadow, uv ) );\\n\\t}\\n\\tfloat VSMShadow (sampler2D shadow, vec2 uv, float compare ){\\n\\t\\tfloat occlusion = 1.0;\\n\\t\\tvec2 distribution = texture2DDistribution( shadow, uv );\\n\\t\\tfloat hard_shadow = step( compare , distribution.x );\\n\\t\\tif (hard_shadow != 1.0 ) {\\n\\t\\t\\tfloat distance = compare - distribution.x ;\\n\\t\\t\\tfloat variance = max( 0.00000, distribution.y * distribution.y );\\n\\t\\t\\tfloat softness_probability = variance / (variance + distance * distance );\\t\\t\\tsoftness_probability = clamp( ( softness_probability - 0.3 ) / ( 0.95 - 0.3 ), 0.0, 1.0 );\\t\\t\\tocclusion = clamp( max( hard_shadow, softness_probability ), 0.0, 1.0 );\\n\\t\\t}\\n\\t\\treturn occlusion;\\n\\t}\\n\\tfloat getShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord ) {\\n\\t\\tfloat shadow = 1.0;\\n\\t\\tshadowCoord.xyz /= shadowCoord.w;\\n\\t\\tshadowCoord.z += shadowBias;\\n\\t\\tbvec4 inFrustumVec = bvec4 ( shadowCoord.x >= 0.0, shadowCoord.x <= 1.0, shadowCoord.y >= 0.0, shadowCoord.y <= 1.0 );\\n\\t\\tbool inFrustum = all( inFrustumVec );\\n\\t\\tbvec2 frustumTestVec = bvec2( inFrustum, shadowCoord.z <= 1.0 );\\n\\t\\tbool frustumTest = all( frustumTestVec );\\n\\t\\tif ( frustumTest ) {\\n\\t\\t#if defined( SHADOWMAP_TYPE_PCF )\\n\\t\\t\\tvec2 texelSize = vec2( 1.0 ) / shadowMapSize;\\n\\t\\t\\tfloat dx0 = - texelSize.x * shadowRadius;\\n\\t\\t\\tfloat dy0 = - texelSize.y * shadowRadius;\\n\\t\\t\\tfloat dx1 = + texelSize.x * shadowRadius;\\n\\t\\t\\tfloat dy1 = + texelSize.y * shadowRadius;\\n\\t\\t\\tfloat dx2 = dx0 / 2.0;\\n\\t\\t\\tfloat dy2 = dy0 / 2.0;\\n\\t\\t\\tfloat dx3 = dx1 / 2.0;\\n\\t\\t\\tfloat dy3 = dy1 / 2.0;\\n\\t\\t\\tshadow = (\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, dy2 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy2 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, dy2 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, dy3 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy3 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, dy3 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\\n\\t\\t\\t) * ( 1.0 / 17.0 );\\n\\t\\t#elif defined( SHADOWMAP_TYPE_PCF_SOFT )\\n\\t\\t\\tvec2 texelSize = vec2( 1.0 ) / shadowMapSize;\\n\\t\\t\\tfloat dx = texelSize.x;\\n\\t\\t\\tfloat dy = texelSize.y;\\n\\t\\t\\tvec2 uv = shadowCoord.xy;\\n\\t\\t\\tvec2 f = fract( uv * shadowMapSize + 0.5 );\\n\\t\\t\\tuv -= f * texelSize;\\n\\t\\t\\tshadow = (\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, uv, shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, uv + vec2( dx, 0.0 ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, uv + vec2( 0.0, dy ), shadowCoord.z ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, uv + texelSize, shadowCoord.z ) +\\n\\t\\t\\t\\tmix( texture2DCompare( shadowMap, uv + vec2( -dx, 0.0 ), shadowCoord.z ), \\n\\t\\t\\t\\t\\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, 0.0 ), shadowCoord.z ),\\n\\t\\t\\t\\t\\t f.x ) +\\n\\t\\t\\t\\tmix( texture2DCompare( shadowMap, uv + vec2( -dx, dy ), shadowCoord.z ), \\n\\t\\t\\t\\t\\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, dy ), shadowCoord.z ),\\n\\t\\t\\t\\t\\t f.x ) +\\n\\t\\t\\t\\tmix( texture2DCompare( shadowMap, uv + vec2( 0.0, -dy ), shadowCoord.z ), \\n\\t\\t\\t\\t\\t texture2DCompare( shadowMap, uv + vec2( 0.0, 2.0 * dy ), shadowCoord.z ),\\n\\t\\t\\t\\t\\t f.y ) +\\n\\t\\t\\t\\tmix( texture2DCompare( shadowMap, uv + vec2( dx, -dy ), shadowCoord.z ), \\n\\t\\t\\t\\t\\t texture2DCompare( shadowMap, uv + vec2( dx, 2.0 * dy ), shadowCoord.z ),\\n\\t\\t\\t\\t\\t f.y ) +\\n\\t\\t\\t\\tmix( mix( texture2DCompare( shadowMap, uv + vec2( -dx, -dy ), shadowCoord.z ), \\n\\t\\t\\t\\t\\t\\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, -dy ), shadowCoord.z ),\\n\\t\\t\\t\\t\\t\\t f.x ),\\n\\t\\t\\t\\t\\t mix( texture2DCompare( shadowMap, uv + vec2( -dx, 2.0 * dy ), shadowCoord.z ), \\n\\t\\t\\t\\t\\t\\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, 2.0 * dy ), shadowCoord.z ),\\n\\t\\t\\t\\t\\t\\t f.x ),\\n\\t\\t\\t\\t\\t f.y )\\n\\t\\t\\t) * ( 1.0 / 9.0 );\\n\\t\\t#elif defined( SHADOWMAP_TYPE_VSM )\\n\\t\\t\\tshadow = VSMShadow( shadowMap, shadowCoord.xy, shadowCoord.z );\\n\\t\\t#else\\n\\t\\t\\tshadow = texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z );\\n\\t\\t#endif\\n\\t\\t}\\n\\t\\treturn shadow;\\n\\t}\\n\\tvec2 cubeToUV( vec3 v, float texelSizeY ) {\\n\\t\\tvec3 absV = abs( v );\\n\\t\\tfloat scaleToCube = 1.0 / max( absV.x, max( absV.y, absV.z ) );\\n\\t\\tabsV *= scaleToCube;\\n\\t\\tv *= scaleToCube * ( 1.0 - 2.0 * texelSizeY );\\n\\t\\tvec2 planar = v.xy;\\n\\t\\tfloat almostATexel = 1.5 * texelSizeY;\\n\\t\\tfloat almostOne = 1.0 - almostATexel;\\n\\t\\tif ( absV.z >= almostOne ) {\\n\\t\\t\\tif ( v.z > 0.0 )\\n\\t\\t\\t\\tplanar.x = 4.0 - v.x;\\n\\t\\t} else if ( absV.x >= almostOne ) {\\n\\t\\t\\tfloat signX = sign( v.x );\\n\\t\\t\\tplanar.x = v.z * signX + 2.0 * signX;\\n\\t\\t} else if ( absV.y >= almostOne ) {\\n\\t\\t\\tfloat signY = sign( v.y );\\n\\t\\t\\tplanar.x = v.x + 2.0 * signY + 2.0;\\n\\t\\t\\tplanar.y = v.z * signY - 2.0;\\n\\t\\t}\\n\\t\\treturn vec2( 0.125, 0.25 ) * planar + vec2( 0.375, 0.75 );\\n\\t}\\n\\tfloat getPointShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord, float shadowCameraNear, float shadowCameraFar ) {\\n\\t\\tvec2 texelSize = vec2( 1.0 ) / ( shadowMapSize * vec2( 4.0, 2.0 ) );\\n\\t\\tvec3 lightToPosition = shadowCoord.xyz;\\n\\t\\tfloat dp = ( length( lightToPosition ) - shadowCameraNear ) / ( shadowCameraFar - shadowCameraNear );\\t\\tdp += shadowBias;\\n\\t\\tvec3 bd3D = normalize( lightToPosition );\\n\\t\\t#if defined( SHADOWMAP_TYPE_PCF ) || defined( SHADOWMAP_TYPE_PCF_SOFT ) || defined( SHADOWMAP_TYPE_VSM )\\n\\t\\t\\tvec2 offset = vec2( - 1, 1 ) * shadowRadius * texelSize.y;\\n\\t\\t\\treturn (\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyy, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyy, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyx, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyx, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxy, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxy, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxx, texelSize.y ), dp ) +\\n\\t\\t\\t\\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxx, texelSize.y ), dp )\\n\\t\\t\\t) * ( 1.0 / 9.0 );\\n\\t\\t#else\\n\\t\\t\\treturn texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp );\\n\\t\\t#endif\\n\\t}\\n#endif\";\n\nvar shadowmap_pars_vertex = \"#ifdef USE_SHADOWMAP\\n\\t#if NUM_DIR_LIGHT_SHADOWS > 0\\n\\t\\tuniform mat4 directionalShadowMatrix[ NUM_DIR_LIGHT_SHADOWS ];\\n\\t\\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHT_SHADOWS ];\\n\\t\\tstruct DirectionalLightShadow {\\n\\t\\t\\tfloat shadowBias;\\n\\t\\t\\tfloat shadowNormalBias;\\n\\t\\t\\tfloat shadowRadius;\\n\\t\\t\\tvec2 shadowMapSize;\\n\\t\\t};\\n\\t\\tuniform DirectionalLightShadow directionalLightShadows[ NUM_DIR_LIGHT_SHADOWS ];\\n\\t#endif\\n\\t#if NUM_SPOT_LIGHT_SHADOWS > 0\\n\\t\\tuniform mat4 spotShadowMatrix[ NUM_SPOT_LIGHT_SHADOWS ];\\n\\t\\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHT_SHADOWS ];\\n\\t\\tstruct SpotLightShadow {\\n\\t\\t\\tfloat shadowBias;\\n\\t\\t\\tfloat shadowNormalBias;\\n\\t\\t\\tfloat shadowRadius;\\n\\t\\t\\tvec2 shadowMapSize;\\n\\t\\t};\\n\\t\\tuniform SpotLightShadow spotLightShadows[ NUM_SPOT_LIGHT_SHADOWS ];\\n\\t#endif\\n\\t#if NUM_POINT_LIGHT_SHADOWS > 0\\n\\t\\tuniform mat4 pointShadowMatrix[ NUM_POINT_LIGHT_SHADOWS ];\\n\\t\\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHT_SHADOWS ];\\n\\t\\tstruct PointLightShadow {\\n\\t\\t\\tfloat shadowBias;\\n\\t\\t\\tfloat shadowNormalBias;\\n\\t\\t\\tfloat shadowRadius;\\n\\t\\t\\tvec2 shadowMapSize;\\n\\t\\t\\tfloat shadowCameraNear;\\n\\t\\t\\tfloat shadowCameraFar;\\n\\t\\t};\\n\\t\\tuniform PointLightShadow pointLightShadows[ NUM_POINT_LIGHT_SHADOWS ];\\n\\t#endif\\n#endif\";\n\nvar shadowmap_vertex = \"#ifdef USE_SHADOWMAP\\n\\t#if NUM_DIR_LIGHT_SHADOWS > 0 || NUM_SPOT_LIGHT_SHADOWS > 0 || NUM_POINT_LIGHT_SHADOWS > 0\\n\\t\\tvec3 shadowWorldNormal = inverseTransformDirection( transformedNormal, viewMatrix );\\n\\t\\tvec4 shadowWorldPosition;\\n\\t#endif\\n\\t#if NUM_DIR_LIGHT_SHADOWS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_DIR_LIGHT_SHADOWS; i ++ ) {\\n\\t\\tshadowWorldPosition = worldPosition + vec4( shadowWorldNormal * directionalLightShadows[ i ].shadowNormalBias, 0 );\\n\\t\\tvDirectionalShadowCoord[ i ] = directionalShadowMatrix[ i ] * shadowWorldPosition;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#endif\\n\\t#if NUM_SPOT_LIGHT_SHADOWS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_SPOT_LIGHT_SHADOWS; i ++ ) {\\n\\t\\tshadowWorldPosition = worldPosition + vec4( shadowWorldNormal * spotLightShadows[ i ].shadowNormalBias, 0 );\\n\\t\\tvSpotShadowCoord[ i ] = spotShadowMatrix[ i ] * shadowWorldPosition;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#endif\\n\\t#if NUM_POINT_LIGHT_SHADOWS > 0\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_POINT_LIGHT_SHADOWS; i ++ ) {\\n\\t\\tshadowWorldPosition = worldPosition + vec4( shadowWorldNormal * pointLightShadows[ i ].shadowNormalBias, 0 );\\n\\t\\tvPointShadowCoord[ i ] = pointShadowMatrix[ i ] * shadowWorldPosition;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#endif\\n#endif\";\n\nvar shadowmask_pars_fragment = \"float getShadowMask() {\\n\\tfloat shadow = 1.0;\\n\\t#ifdef USE_SHADOWMAP\\n\\t#if NUM_DIR_LIGHT_SHADOWS > 0\\n\\tDirectionalLightShadow directionalLight;\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_DIR_LIGHT_SHADOWS; i ++ ) {\\n\\t\\tdirectionalLight = directionalLightShadows[ i ];\\n\\t\\tshadow *= receiveShadow ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#endif\\n\\t#if NUM_SPOT_LIGHT_SHADOWS > 0\\n\\tSpotLightShadow spotLight;\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_SPOT_LIGHT_SHADOWS; i ++ ) {\\n\\t\\tspotLight = spotLightShadows[ i ];\\n\\t\\tshadow *= receiveShadow ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#endif\\n\\t#if NUM_POINT_LIGHT_SHADOWS > 0\\n\\tPointLightShadow pointLight;\\n\\t#pragma unroll_loop_start\\n\\tfor ( int i = 0; i < NUM_POINT_LIGHT_SHADOWS; i ++ ) {\\n\\t\\tpointLight = pointLightShadows[ i ];\\n\\t\\tshadow *= receiveShadow ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0;\\n\\t}\\n\\t#pragma unroll_loop_end\\n\\t#endif\\n\\t#endif\\n\\treturn shadow;\\n}\";\n\nvar skinbase_vertex = \"#ifdef USE_SKINNING\\n\\tmat4 boneMatX = getBoneMatrix( skinIndex.x );\\n\\tmat4 boneMatY = getBoneMatrix( skinIndex.y );\\n\\tmat4 boneMatZ = getBoneMatrix( skinIndex.z );\\n\\tmat4 boneMatW = getBoneMatrix( skinIndex.w );\\n#endif\";\n\nvar skinning_pars_vertex = \"#ifdef USE_SKINNING\\n\\tuniform mat4 bindMatrix;\\n\\tuniform mat4 bindMatrixInverse;\\n\\tuniform highp sampler2D boneTexture;\\n\\tuniform int boneTextureSize;\\n\\tmat4 getBoneMatrix( const in float i ) {\\n\\t\\tfloat j = i * 4.0;\\n\\t\\tfloat x = mod( j, float( boneTextureSize ) );\\n\\t\\tfloat y = floor( j / float( boneTextureSize ) );\\n\\t\\tfloat dx = 1.0 / float( boneTextureSize );\\n\\t\\tfloat dy = 1.0 / float( boneTextureSize );\\n\\t\\ty = dy * ( y + 0.5 );\\n\\t\\tvec4 v1 = texture2D( boneTexture, vec2( dx * ( x + 0.5 ), y ) );\\n\\t\\tvec4 v2 = texture2D( boneTexture, vec2( dx * ( x + 1.5 ), y ) );\\n\\t\\tvec4 v3 = texture2D( boneTexture, vec2( dx * ( x + 2.5 ), y ) );\\n\\t\\tvec4 v4 = texture2D( boneTexture, vec2( dx * ( x + 3.5 ), y ) );\\n\\t\\tmat4 bone = mat4( v1, v2, v3, v4 );\\n\\t\\treturn bone;\\n\\t}\\n#endif\";\n\nvar skinning_vertex = \"#ifdef USE_SKINNING\\n\\tvec4 skinVertex = bindMatrix * vec4( transformed, 1.0 );\\n\\tvec4 skinned = vec4( 0.0 );\\n\\tskinned += boneMatX * skinVertex * skinWeight.x;\\n\\tskinned += boneMatY * skinVertex * skinWeight.y;\\n\\tskinned += boneMatZ * skinVertex * skinWeight.z;\\n\\tskinned += boneMatW * skinVertex * skinWeight.w;\\n\\ttransformed = ( bindMatrixInverse * skinned ).xyz;\\n#endif\";\n\nvar skinnormal_vertex = \"#ifdef USE_SKINNING\\n\\tmat4 skinMatrix = mat4( 0.0 );\\n\\tskinMatrix += skinWeight.x * boneMatX;\\n\\tskinMatrix += skinWeight.y * boneMatY;\\n\\tskinMatrix += skinWeight.z * boneMatZ;\\n\\tskinMatrix += skinWeight.w * boneMatW;\\n\\tskinMatrix = bindMatrixInverse * skinMatrix * bindMatrix;\\n\\tobjectNormal = vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz;\\n\\t#ifdef USE_TANGENT\\n\\t\\tobjectTangent = vec4( skinMatrix * vec4( objectTangent, 0.0 ) ).xyz;\\n\\t#endif\\n#endif\";\n\nvar specularmap_fragment = \"float specularStrength;\\n#ifdef USE_SPECULARMAP\\n\\tvec4 texelSpecular = texture2D( specularMap, vUv );\\n\\tspecularStrength = texelSpecular.r;\\n#else\\n\\tspecularStrength = 1.0;\\n#endif\";\n\nvar specularmap_pars_fragment = \"#ifdef USE_SPECULARMAP\\n\\tuniform sampler2D specularMap;\\n#endif\";\n\nvar tonemapping_fragment = \"#if defined( TONE_MAPPING )\\n\\tgl_FragColor.rgb = toneMapping( gl_FragColor.rgb );\\n#endif\";\n\nvar tonemapping_pars_fragment = \"#ifndef saturate\\n#define saturate( a ) clamp( a, 0.0, 1.0 )\\n#endif\\nuniform float toneMappingExposure;\\nvec3 LinearToneMapping( vec3 color ) {\\n\\treturn toneMappingExposure * color;\\n}\\nvec3 ReinhardToneMapping( vec3 color ) {\\n\\tcolor *= toneMappingExposure;\\n\\treturn saturate( color / ( vec3( 1.0 ) + color ) );\\n}\\nvec3 OptimizedCineonToneMapping( vec3 color ) {\\n\\tcolor *= toneMappingExposure;\\n\\tcolor = max( vec3( 0.0 ), color - 0.004 );\\n\\treturn pow( ( color * ( 6.2 * color + 0.5 ) ) / ( color * ( 6.2 * color + 1.7 ) + 0.06 ), vec3( 2.2 ) );\\n}\\nvec3 RRTAndODTFit( vec3 v ) {\\n\\tvec3 a = v * ( v + 0.0245786 ) - 0.000090537;\\n\\tvec3 b = v * ( 0.983729 * v + 0.4329510 ) + 0.238081;\\n\\treturn a / b;\\n}\\nvec3 ACESFilmicToneMapping( vec3 color ) {\\n\\tconst mat3 ACESInputMat = mat3(\\n\\t\\tvec3( 0.59719, 0.07600, 0.02840 ),\\t\\tvec3( 0.35458, 0.90834, 0.13383 ),\\n\\t\\tvec3( 0.04823, 0.01566, 0.83777 )\\n\\t);\\n\\tconst mat3 ACESOutputMat = mat3(\\n\\t\\tvec3( 1.60475, -0.10208, -0.00327 ),\\t\\tvec3( -0.53108, 1.10813, -0.07276 ),\\n\\t\\tvec3( -0.07367, -0.00605, 1.07602 )\\n\\t);\\n\\tcolor *= toneMappingExposure / 0.6;\\n\\tcolor = ACESInputMat * color;\\n\\tcolor = RRTAndODTFit( color );\\n\\tcolor = ACESOutputMat * color;\\n\\treturn saturate( color );\\n}\\nvec3 CustomToneMapping( vec3 color ) { return color; }\";\n\nvar transmission_fragment = \"#ifdef USE_TRANSMISSION\\n\\tfloat transmissionAlpha = 1.0;\\n\\tfloat transmissionFactor = transmission;\\n\\tfloat thicknessFactor = thickness;\\n\\t#ifdef USE_TRANSMISSIONMAP\\n\\t\\ttransmissionFactor *= texture2D( transmissionMap, vUv ).r;\\n\\t#endif\\n\\t#ifdef USE_THICKNESSMAP\\n\\t\\tthicknessFactor *= texture2D( thicknessMap, vUv ).g;\\n\\t#endif\\n\\tvec3 pos = vWorldPosition;\\n\\tvec3 v = normalize( cameraPosition - pos );\\n\\tvec3 n = inverseTransformDirection( normal, viewMatrix );\\n\\tvec4 transmission = getIBLVolumeRefraction(\\n\\t\\tn, v, roughnessFactor, material.diffuseColor, material.specularColor, material.specularF90,\\n\\t\\tpos, modelMatrix, viewMatrix, projectionMatrix, ior, thicknessFactor,\\n\\t\\tattenuationColor, attenuationDistance );\\n\\ttotalDiffuse = mix( totalDiffuse, transmission.rgb, transmissionFactor );\\n\\ttransmissionAlpha = mix( transmissionAlpha, transmission.a, transmissionFactor );\\n#endif\";\n\nvar transmission_pars_fragment = \"#ifdef USE_TRANSMISSION\\n\\tuniform float transmission;\\n\\tuniform float thickness;\\n\\tuniform float attenuationDistance;\\n\\tuniform vec3 attenuationColor;\\n\\t#ifdef USE_TRANSMISSIONMAP\\n\\t\\tuniform sampler2D transmissionMap;\\n\\t#endif\\n\\t#ifdef USE_THICKNESSMAP\\n\\t\\tuniform sampler2D thicknessMap;\\n\\t#endif\\n\\tuniform vec2 transmissionSamplerSize;\\n\\tuniform sampler2D transmissionSamplerMap;\\n\\tuniform mat4 modelMatrix;\\n\\tuniform mat4 projectionMatrix;\\n\\tvarying vec3 vWorldPosition;\\n\\tvec3 getVolumeTransmissionRay( const in vec3 n, const in vec3 v, const in float thickness, const in float ior, const in mat4 modelMatrix ) {\\n\\t\\tvec3 refractionVector = refract( - v, normalize( n ), 1.0 / ior );\\n\\t\\tvec3 modelScale;\\n\\t\\tmodelScale.x = length( vec3( modelMatrix[ 0 ].xyz ) );\\n\\t\\tmodelScale.y = length( vec3( modelMatrix[ 1 ].xyz ) );\\n\\t\\tmodelScale.z = length( vec3( modelMatrix[ 2 ].xyz ) );\\n\\t\\treturn normalize( refractionVector ) * thickness * modelScale;\\n\\t}\\n\\tfloat applyIorToRoughness( const in float roughness, const in float ior ) {\\n\\t\\treturn roughness * clamp( ior * 2.0 - 2.0, 0.0, 1.0 );\\n\\t}\\n\\tvec4 getTransmissionSample( const in vec2 fragCoord, const in float roughness, const in float ior ) {\\n\\t\\tfloat framebufferLod = log2( transmissionSamplerSize.x ) * applyIorToRoughness( roughness, ior );\\n\\t\\t#ifdef texture2DLodEXT\\n\\t\\t\\treturn texture2DLodEXT( transmissionSamplerMap, fragCoord.xy, framebufferLod );\\n\\t\\t#else\\n\\t\\t\\treturn texture2D( transmissionSamplerMap, fragCoord.xy, framebufferLod );\\n\\t\\t#endif\\n\\t}\\n\\tvec3 applyVolumeAttenuation( const in vec3 radiance, const in float transmissionDistance, const in vec3 attenuationColor, const in float attenuationDistance ) {\\n\\t\\tif ( attenuationDistance == 0.0 ) {\\n\\t\\t\\treturn radiance;\\n\\t\\t} else {\\n\\t\\t\\tvec3 attenuationCoefficient = -log( attenuationColor ) / attenuationDistance;\\n\\t\\t\\tvec3 transmittance = exp( - attenuationCoefficient * transmissionDistance );\\t\\t\\treturn transmittance * radiance;\\n\\t\\t}\\n\\t}\\n\\tvec4 getIBLVolumeRefraction( const in vec3 n, const in vec3 v, const in float roughness, const in vec3 diffuseColor,\\n\\t\\tconst in vec3 specularColor, const in float specularF90, const in vec3 position, const in mat4 modelMatrix,\\n\\t\\tconst in mat4 viewMatrix, const in mat4 projMatrix, const in float ior, const in float thickness,\\n\\t\\tconst in vec3 attenuationColor, const in float attenuationDistance ) {\\n\\t\\tvec3 transmissionRay = getVolumeTransmissionRay( n, v, thickness, ior, modelMatrix );\\n\\t\\tvec3 refractedRayExit = position + transmissionRay;\\n\\t\\tvec4 ndcPos = projMatrix * viewMatrix * vec4( refractedRayExit, 1.0 );\\n\\t\\tvec2 refractionCoords = ndcPos.xy / ndcPos.w;\\n\\t\\trefractionCoords += 1.0;\\n\\t\\trefractionCoords /= 2.0;\\n\\t\\tvec4 transmittedLight = getTransmissionSample( refractionCoords, roughness, ior );\\n\\t\\tvec3 attenuatedColor = applyVolumeAttenuation( transmittedLight.rgb, length( transmissionRay ), attenuationColor, attenuationDistance );\\n\\t\\tvec3 F = EnvironmentBRDF( n, v, specularColor, specularF90, roughness );\\n\\t\\treturn vec4( ( 1.0 - F ) * attenuatedColor * diffuseColor, transmittedLight.a );\\n\\t}\\n#endif\";\n\nvar uv_pars_fragment = \"#if ( defined( USE_UV ) && ! defined( UVS_VERTEX_ONLY ) )\\n\\tvarying vec2 vUv;\\n#endif\";\n\nvar uv_pars_vertex = \"#ifdef USE_UV\\n\\t#ifdef UVS_VERTEX_ONLY\\n\\t\\tvec2 vUv;\\n\\t#else\\n\\t\\tvarying vec2 vUv;\\n\\t#endif\\n\\tuniform mat3 uvTransform;\\n#endif\";\n\nvar uv_vertex = \"#ifdef USE_UV\\n\\tvUv = ( uvTransform * vec3( uv, 1 ) ).xy;\\n#endif\";\n\nvar uv2_pars_fragment = \"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\\n\\tvarying vec2 vUv2;\\n#endif\";\n\nvar uv2_pars_vertex = \"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\\n\\tattribute vec2 uv2;\\n\\tvarying vec2 vUv2;\\n\\tuniform mat3 uv2Transform;\\n#endif\";\n\nvar uv2_vertex = \"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\\n\\tvUv2 = ( uv2Transform * vec3( uv2, 1 ) ).xy;\\n#endif\";\n\nvar worldpos_vertex = \"#if defined( USE_ENVMAP ) || defined( DISTANCE ) || defined ( USE_SHADOWMAP ) || defined ( USE_TRANSMISSION )\\n\\tvec4 worldPosition = vec4( transformed, 1.0 );\\n\\t#ifdef USE_INSTANCING\\n\\t\\tworldPosition = instanceMatrix * worldPosition;\\n\\t#endif\\n\\tworldPosition = modelMatrix * worldPosition;\\n#endif\";\n\nconst vertex$g = \"varying vec2 vUv;\\nuniform mat3 uvTransform;\\nvoid main() {\\n\\tvUv = ( uvTransform * vec3( uv, 1 ) ).xy;\\n\\tgl_Position = vec4( position.xy, 1.0, 1.0 );\\n}\";\n\nconst fragment$g = \"uniform sampler2D t2D;\\nvarying vec2 vUv;\\nvoid main() {\\n\\tgl_FragColor = texture2D( t2D, vUv );\\n\\t#ifdef DECODE_VIDEO_TEXTURE\\n\\t\\tgl_FragColor = vec4( mix( pow( gl_FragColor.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), gl_FragColor.rgb * 0.0773993808, vec3( lessThanEqual( gl_FragColor.rgb, vec3( 0.04045 ) ) ) ), gl_FragColor.w );\\n\\t#endif\\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$f = \"varying vec3 vWorldDirection;\\n#include \\nvoid main() {\\n\\tvWorldDirection = transformDirection( position, modelMatrix );\\n\\t#include \\n\\t#include \\n\\tgl_Position.z = gl_Position.w;\\n}\";\n\nconst fragment$f = \"#include \\nuniform float opacity;\\nvarying vec3 vWorldDirection;\\n#include \\nvoid main() {\\n\\tvec3 vReflect = vWorldDirection;\\n\\t#include \\n\\tgl_FragColor = envColor;\\n\\tgl_FragColor.a *= opacity;\\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$e = \"#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvarying vec2 vHighPrecisionZW;\\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#ifdef USE_DISPLACEMENTMAP\\n\\t\\t#include \\n\\t\\t#include \\n\\t\\t#include \\n\\t#endif\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvHighPrecisionZW = gl_Position.zw;\\n}\";\n\nconst fragment$e = \"#if DEPTH_PACKING == 3200\\n\\tuniform float opacity;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvarying vec2 vHighPrecisionZW;\\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( 1.0 );\\n\\t#if DEPTH_PACKING == 3200\\n\\t\\tdiffuseColor.a = opacity;\\n\\t#endif\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tfloat fragCoordZ = 0.5 * vHighPrecisionZW[0] / vHighPrecisionZW[1] + 0.5;\\n\\t#if DEPTH_PACKING == 3200\\n\\t\\tgl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity );\\n\\t#elif DEPTH_PACKING == 3201\\n\\t\\tgl_FragColor = packDepthToRGBA( fragCoordZ );\\n\\t#endif\\n}\";\n\nconst vertex$d = \"#define DISTANCE\\nvarying vec3 vWorldPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#ifdef USE_DISPLACEMENTMAP\\n\\t\\t#include \\n\\t\\t#include \\n\\t\\t#include \\n\\t#endif\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvWorldPosition = worldPosition.xyz;\\n}\";\n\nconst fragment$d = \"#define DISTANCE\\nuniform vec3 referencePosition;\\nuniform float nearDistance;\\nuniform float farDistance;\\nvarying vec3 vWorldPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main () {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( 1.0 );\\n\\t#include \\n\\t#include \\n\\t#include \\n\\tfloat dist = length( vWorldPosition - referencePosition );\\n\\tdist = ( dist - nearDistance ) / ( farDistance - nearDistance );\\n\\tdist = saturate( dist );\\n\\tgl_FragColor = packDepthToRGBA( dist );\\n}\";\n\nconst vertex$c = \"varying vec3 vWorldDirection;\\n#include \\nvoid main() {\\n\\tvWorldDirection = transformDirection( position, modelMatrix );\\n\\t#include \\n\\t#include \\n}\";\n\nconst fragment$c = \"uniform sampler2D tEquirect;\\nvarying vec3 vWorldDirection;\\n#include \\nvoid main() {\\n\\tvec3 direction = normalize( vWorldDirection );\\n\\tvec2 sampleUV = equirectUv( direction );\\n\\tgl_FragColor = texture2D( tEquirect, sampleUV );\\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$b = \"uniform float scale;\\nattribute float lineDistance;\\nvarying float vLineDistance;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\tvLineDistance = scale * lineDistance;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst fragment$b = \"uniform vec3 diffuse;\\nuniform float opacity;\\nuniform float dashSize;\\nuniform float totalSize;\\nvarying float vLineDistance;\\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tif ( mod( vLineDistance, totalSize ) > dashSize ) {\\n\\t\\tdiscard;\\n\\t}\\n\\tvec3 outgoingLight = vec3( 0.0 );\\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include \\n\\t#include \\n\\toutgoingLight = diffuseColor.rgb;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$a = \"#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#if defined ( USE_ENVMAP ) || defined ( USE_SKINNING )\\n\\t\\t#include \\n\\t\\t#include \\n\\t\\t#include \\n\\t\\t#include \\n\\t\\t#include \\n\\t#endif\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst fragment$a = \"uniform vec3 diffuse;\\nuniform float opacity;\\n#ifndef FLAT_SHADED\\n\\tvarying vec3 vNormal;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\t#ifdef USE_LIGHTMAP\\n\\t\\tvec4 lightMapTexel = texture2D( lightMap, vUv2 );\\n\\t\\treflectedLight.indirectDiffuse += lightMapTexel.rgb * lightMapIntensity * RECIPROCAL_PI;\\n\\t#else\\n\\t\\treflectedLight.indirectDiffuse += vec3( 1.0 );\\n\\t#endif\\n\\t#include \\n\\treflectedLight.indirectDiffuse *= diffuseColor.rgb;\\n\\tvec3 outgoingLight = reflectedLight.indirectDiffuse;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$9 = \"#define LAMBERT\\nvarying vec3 vLightFront;\\nvarying vec3 vIndirectFront;\\n#ifdef DOUBLE_SIDED\\n\\tvarying vec3 vLightBack;\\n\\tvarying vec3 vIndirectBack;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst fragment$9 = \"uniform vec3 diffuse;\\nuniform vec3 emissive;\\nuniform float opacity;\\nvarying vec3 vLightFront;\\nvarying vec3 vIndirectFront;\\n#ifdef DOUBLE_SIDED\\n\\tvarying vec3 vLightBack;\\n\\tvarying vec3 vIndirectBack;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\tvec3 totalEmissiveRadiance = emissive;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#ifdef DOUBLE_SIDED\\n\\t\\treflectedLight.indirectDiffuse += ( gl_FrontFacing ) ? vIndirectFront : vIndirectBack;\\n\\t#else\\n\\t\\treflectedLight.indirectDiffuse += vIndirectFront;\\n\\t#endif\\n\\t#include \\n\\treflectedLight.indirectDiffuse *= BRDF_Lambert( diffuseColor.rgb );\\n\\t#ifdef DOUBLE_SIDED\\n\\t\\treflectedLight.directDiffuse = ( gl_FrontFacing ) ? vLightFront : vLightBack;\\n\\t#else\\n\\t\\treflectedLight.directDiffuse = vLightFront;\\n\\t#endif\\n\\treflectedLight.directDiffuse *= BRDF_Lambert( diffuseColor.rgb ) * getShadowMask();\\n\\t#include \\n\\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$8 = \"#define MATCAP\\nvarying vec3 vViewPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvViewPosition = - mvPosition.xyz;\\n}\";\n\nconst fragment$8 = \"#define MATCAP\\nuniform vec3 diffuse;\\nuniform float opacity;\\nuniform sampler2D matcap;\\nvarying vec3 vViewPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvec3 viewDir = normalize( vViewPosition );\\n\\tvec3 x = normalize( vec3( viewDir.z, 0.0, - viewDir.x ) );\\n\\tvec3 y = cross( viewDir, x );\\n\\tvec2 uv = vec2( dot( x, normal ), dot( y, normal ) ) * 0.495 + 0.5;\\n\\t#ifdef USE_MATCAP\\n\\t\\tvec4 matcapColor = texture2D( matcap, uv );\\n\\t#else\\n\\t\\tvec4 matcapColor = vec4( vec3( mix( 0.2, 0.8, uv.y ) ), 1.0 );\\n\\t#endif\\n\\tvec3 outgoingLight = diffuseColor.rgb * matcapColor.rgb;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$7 = \"#define NORMAL\\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\\n\\tvarying vec3 vViewPosition;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\\n\\tvViewPosition = - mvPosition.xyz;\\n#endif\\n}\";\n\nconst fragment$7 = \"#define NORMAL\\nuniform float opacity;\\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\\n\\tvarying vec3 vViewPosition;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tgl_FragColor = vec4( packNormalToRGB( normal ), opacity );\\n\\t#ifdef OPAQUE\\n\\t\\tgl_FragColor.a = 1.0;\\n\\t#endif\\n}\";\n\nconst vertex$6 = \"#define PHONG\\nvarying vec3 vViewPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvViewPosition = - mvPosition.xyz;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst fragment$6 = \"#define PHONG\\nuniform vec3 diffuse;\\nuniform vec3 emissive;\\nuniform vec3 specular;\\nuniform float shininess;\\nuniform float opacity;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\tvec3 totalEmissiveRadiance = emissive;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$5 = \"#define STANDARD\\nvarying vec3 vViewPosition;\\n#ifdef USE_TRANSMISSION\\n\\tvarying vec3 vWorldPosition;\\n#endif\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvViewPosition = - mvPosition.xyz;\\n\\t#include \\n\\t#include \\n\\t#include \\n#ifdef USE_TRANSMISSION\\n\\tvWorldPosition = worldPosition.xyz;\\n#endif\\n}\";\n\nconst fragment$5 = \"#define STANDARD\\n#ifdef PHYSICAL\\n\\t#define IOR\\n\\t#define SPECULAR\\n#endif\\nuniform vec3 diffuse;\\nuniform vec3 emissive;\\nuniform float roughness;\\nuniform float metalness;\\nuniform float opacity;\\n#ifdef IOR\\n\\tuniform float ior;\\n#endif\\n#ifdef SPECULAR\\n\\tuniform float specularIntensity;\\n\\tuniform vec3 specularColor;\\n\\t#ifdef USE_SPECULARINTENSITYMAP\\n\\t\\tuniform sampler2D specularIntensityMap;\\n\\t#endif\\n\\t#ifdef USE_SPECULARCOLORMAP\\n\\t\\tuniform sampler2D specularColorMap;\\n\\t#endif\\n#endif\\n#ifdef USE_CLEARCOAT\\n\\tuniform float clearcoat;\\n\\tuniform float clearcoatRoughness;\\n#endif\\n#ifdef USE_IRIDESCENCE\\n\\tuniform float iridescence;\\n\\tuniform float iridescenceIOR;\\n\\tuniform float iridescenceThicknessMinimum;\\n\\tuniform float iridescenceThicknessMaximum;\\n#endif\\n#ifdef USE_SHEEN\\n\\tuniform vec3 sheenColor;\\n\\tuniform float sheenRoughness;\\n\\t#ifdef USE_SHEENCOLORMAP\\n\\t\\tuniform sampler2D sheenColorMap;\\n\\t#endif\\n\\t#ifdef USE_SHEENROUGHNESSMAP\\n\\t\\tuniform sampler2D sheenRoughnessMap;\\n\\t#endif\\n#endif\\nvarying vec3 vViewPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\tvec3 totalEmissiveRadiance = emissive;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvec3 totalDiffuse = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse;\\n\\tvec3 totalSpecular = reflectedLight.directSpecular + reflectedLight.indirectSpecular;\\n\\t#include \\n\\tvec3 outgoingLight = totalDiffuse + totalSpecular + totalEmissiveRadiance;\\n\\t#ifdef USE_SHEEN\\n\\t\\tfloat sheenEnergyComp = 1.0 - 0.157 * max3( material.sheenColor );\\n\\t\\toutgoingLight = outgoingLight * sheenEnergyComp + sheenSpecular;\\n\\t#endif\\n\\t#ifdef USE_CLEARCOAT\\n\\t\\tfloat dotNVcc = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) );\\n\\t\\tvec3 Fcc = F_Schlick( material.clearcoatF0, material.clearcoatF90, dotNVcc );\\n\\t\\toutgoingLight = outgoingLight * ( 1.0 - material.clearcoat * Fcc ) + clearcoatSpecular * material.clearcoat;\\n\\t#endif\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$4 = \"#define TOON\\nvarying vec3 vViewPosition;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvViewPosition = - mvPosition.xyz;\\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst fragment$4 = \"#define TOON\\nuniform vec3 diffuse;\\nuniform vec3 emissive;\\nuniform float opacity;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\\n\\tvec3 totalEmissiveRadiance = emissive;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$3 = \"uniform float size;\\nuniform float scale;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\tgl_PointSize = size;\\n\\t#ifdef USE_SIZEATTENUATION\\n\\t\\tbool isPerspective = isPerspectiveMatrix( projectionMatrix );\\n\\t\\tif ( isPerspective ) gl_PointSize *= ( scale / - mvPosition.z );\\n\\t#endif\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst fragment$3 = \"uniform vec3 diffuse;\\nuniform float opacity;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec3 outgoingLight = vec3( 0.0 );\\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\toutgoingLight = diffuseColor.rgb;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$2 = \"#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst fragment$2 = \"uniform vec3 color;\\nuniform float opacity;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\tgl_FragColor = vec4( color, opacity * ( 1.0 - getShadowMask() ) );\\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst vertex$1 = \"uniform float rotation;\\nuniform vec2 center;\\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec4 mvPosition = modelViewMatrix * vec4( 0.0, 0.0, 0.0, 1.0 );\\n\\tvec2 scale;\\n\\tscale.x = length( vec3( modelMatrix[ 0 ].x, modelMatrix[ 0 ].y, modelMatrix[ 0 ].z ) );\\n\\tscale.y = length( vec3( modelMatrix[ 1 ].x, modelMatrix[ 1 ].y, modelMatrix[ 1 ].z ) );\\n\\t#ifndef USE_SIZEATTENUATION\\n\\t\\tbool isPerspective = isPerspectiveMatrix( projectionMatrix );\\n\\t\\tif ( isPerspective ) scale *= - mvPosition.z;\\n\\t#endif\\n\\tvec2 alignedPosition = ( position.xy - ( center - vec2( 0.5 ) ) ) * scale;\\n\\tvec2 rotatedPosition;\\n\\trotatedPosition.x = cos( rotation ) * alignedPosition.x - sin( rotation ) * alignedPosition.y;\\n\\trotatedPosition.y = sin( rotation ) * alignedPosition.x + cos( rotation ) * alignedPosition.y;\\n\\tmvPosition.xy += rotatedPosition;\\n\\tgl_Position = projectionMatrix * mvPosition;\\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst fragment$1 = \"uniform vec3 diffuse;\\nuniform float opacity;\\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\n#include \\nvoid main() {\\n\\t#include \\n\\tvec3 outgoingLight = vec3( 0.0 );\\n\\tvec4 diffuseColor = vec4( diffuse, opacity );\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n\\toutgoingLight = diffuseColor.rgb;\\n\\t#include \\n\\t#include \\n\\t#include \\n\\t#include \\n}\";\n\nconst ShaderChunk = {\n\talphamap_fragment: alphamap_fragment,\n\talphamap_pars_fragment: alphamap_pars_fragment,\n\talphatest_fragment: alphatest_fragment,\n\talphatest_pars_fragment: alphatest_pars_fragment,\n\taomap_fragment: aomap_fragment,\n\taomap_pars_fragment: aomap_pars_fragment,\n\tbegin_vertex: begin_vertex,\n\tbeginnormal_vertex: beginnormal_vertex,\n\tbsdfs: bsdfs,\n\tiridescence_fragment: iridescence_fragment,\n\tbumpmap_pars_fragment: bumpmap_pars_fragment,\n\tclipping_planes_fragment: clipping_planes_fragment,\n\tclipping_planes_pars_fragment: clipping_planes_pars_fragment,\n\tclipping_planes_pars_vertex: clipping_planes_pars_vertex,\n\tclipping_planes_vertex: clipping_planes_vertex,\n\tcolor_fragment: color_fragment,\n\tcolor_pars_fragment: color_pars_fragment,\n\tcolor_pars_vertex: color_pars_vertex,\n\tcolor_vertex: color_vertex,\n\tcommon: common,\n\tcube_uv_reflection_fragment: cube_uv_reflection_fragment,\n\tdefaultnormal_vertex: defaultnormal_vertex,\n\tdisplacementmap_pars_vertex: displacementmap_pars_vertex,\n\tdisplacementmap_vertex: displacementmap_vertex,\n\temissivemap_fragment: emissivemap_fragment,\n\temissivemap_pars_fragment: emissivemap_pars_fragment,\n\tencodings_fragment: encodings_fragment,\n\tencodings_pars_fragment: encodings_pars_fragment,\n\tenvmap_fragment: envmap_fragment,\n\tenvmap_common_pars_fragment: envmap_common_pars_fragment,\n\tenvmap_pars_fragment: envmap_pars_fragment,\n\tenvmap_pars_vertex: envmap_pars_vertex,\n\tenvmap_physical_pars_fragment: envmap_physical_pars_fragment,\n\tenvmap_vertex: envmap_vertex,\n\tfog_vertex: fog_vertex,\n\tfog_pars_vertex: fog_pars_vertex,\n\tfog_fragment: fog_fragment,\n\tfog_pars_fragment: fog_pars_fragment,\n\tgradientmap_pars_fragment: gradientmap_pars_fragment,\n\tlightmap_fragment: lightmap_fragment,\n\tlightmap_pars_fragment: lightmap_pars_fragment,\n\tlights_lambert_vertex: lights_lambert_vertex,\n\tlights_pars_begin: lights_pars_begin,\n\tlights_toon_fragment: lights_toon_fragment,\n\tlights_toon_pars_fragment: lights_toon_pars_fragment,\n\tlights_phong_fragment: lights_phong_fragment,\n\tlights_phong_pars_fragment: lights_phong_pars_fragment,\n\tlights_physical_fragment: lights_physical_fragment,\n\tlights_physical_pars_fragment: lights_physical_pars_fragment,\n\tlights_fragment_begin: lights_fragment_begin,\n\tlights_fragment_maps: lights_fragment_maps,\n\tlights_fragment_end: lights_fragment_end,\n\tlogdepthbuf_fragment: logdepthbuf_fragment,\n\tlogdepthbuf_pars_fragment: logdepthbuf_pars_fragment,\n\tlogdepthbuf_pars_vertex: logdepthbuf_pars_vertex,\n\tlogdepthbuf_vertex: logdepthbuf_vertex,\n\tmap_fragment: map_fragment,\n\tmap_pars_fragment: map_pars_fragment,\n\tmap_particle_fragment: map_particle_fragment,\n\tmap_particle_pars_fragment: map_particle_pars_fragment,\n\tmetalnessmap_fragment: metalnessmap_fragment,\n\tmetalnessmap_pars_fragment: metalnessmap_pars_fragment,\n\tmorphcolor_vertex: morphcolor_vertex,\n\tmorphnormal_vertex: morphnormal_vertex,\n\tmorphtarget_pars_vertex: morphtarget_pars_vertex,\n\tmorphtarget_vertex: morphtarget_vertex,\n\tnormal_fragment_begin: normal_fragment_begin,\n\tnormal_fragment_maps: normal_fragment_maps,\n\tnormal_pars_fragment: normal_pars_fragment,\n\tnormal_pars_vertex: normal_pars_vertex,\n\tnormal_vertex: normal_vertex,\n\tnormalmap_pars_fragment: normalmap_pars_fragment,\n\tclearcoat_normal_fragment_begin: clearcoat_normal_fragment_begin,\n\tclearcoat_normal_fragment_maps: clearcoat_normal_fragment_maps,\n\tclearcoat_pars_fragment: clearcoat_pars_fragment,\n\tiridescence_pars_fragment: iridescence_pars_fragment,\n\toutput_fragment: output_fragment,\n\tpacking: packing,\n\tpremultiplied_alpha_fragment: premultiplied_alpha_fragment,\n\tproject_vertex: project_vertex,\n\tdithering_fragment: dithering_fragment,\n\tdithering_pars_fragment: dithering_pars_fragment,\n\troughnessmap_fragment: roughnessmap_fragment,\n\troughnessmap_pars_fragment: roughnessmap_pars_fragment,\n\tshadowmap_pars_fragment: shadowmap_pars_fragment,\n\tshadowmap_pars_vertex: shadowmap_pars_vertex,\n\tshadowmap_vertex: shadowmap_vertex,\n\tshadowmask_pars_fragment: shadowmask_pars_fragment,\n\tskinbase_vertex: skinbase_vertex,\n\tskinning_pars_vertex: skinning_pars_vertex,\n\tskinning_vertex: skinning_vertex,\n\tskinnormal_vertex: skinnormal_vertex,\n\tspecularmap_fragment: specularmap_fragment,\n\tspecularmap_pars_fragment: specularmap_pars_fragment,\n\ttonemapping_fragment: tonemapping_fragment,\n\ttonemapping_pars_fragment: tonemapping_pars_fragment,\n\ttransmission_fragment: transmission_fragment,\n\ttransmission_pars_fragment: transmission_pars_fragment,\n\tuv_pars_fragment: uv_pars_fragment,\n\tuv_pars_vertex: uv_pars_vertex,\n\tuv_vertex: uv_vertex,\n\tuv2_pars_fragment: uv2_pars_fragment,\n\tuv2_pars_vertex: uv2_pars_vertex,\n\tuv2_vertex: uv2_vertex,\n\tworldpos_vertex: worldpos_vertex,\n\n\tbackground_vert: vertex$g,\n\tbackground_frag: fragment$g,\n\tcube_vert: vertex$f,\n\tcube_frag: fragment$f,\n\tdepth_vert: vertex$e,\n\tdepth_frag: fragment$e,\n\tdistanceRGBA_vert: vertex$d,\n\tdistanceRGBA_frag: fragment$d,\n\tequirect_vert: vertex$c,\n\tequirect_frag: fragment$c,\n\tlinedashed_vert: vertex$b,\n\tlinedashed_frag: fragment$b,\n\tmeshbasic_vert: vertex$a,\n\tmeshbasic_frag: fragment$a,\n\tmeshlambert_vert: vertex$9,\n\tmeshlambert_frag: fragment$9,\n\tmeshmatcap_vert: vertex$8,\n\tmeshmatcap_frag: fragment$8,\n\tmeshnormal_vert: vertex$7,\n\tmeshnormal_frag: fragment$7,\n\tmeshphong_vert: vertex$6,\n\tmeshphong_frag: fragment$6,\n\tmeshphysical_vert: vertex$5,\n\tmeshphysical_frag: fragment$5,\n\tmeshtoon_vert: vertex$4,\n\tmeshtoon_frag: fragment$4,\n\tpoints_vert: vertex$3,\n\tpoints_frag: fragment$3,\n\tshadow_vert: vertex$2,\n\tshadow_frag: fragment$2,\n\tsprite_vert: vertex$1,\n\tsprite_frag: fragment$1\n};\n\n/**\n * Uniforms library for shared webgl shaders\n */\n\nconst UniformsLib = {\n\n\tcommon: {\n\n\t\tdiffuse: { value: new Color( 0xffffff ) },\n\t\topacity: { value: 1.0 },\n\n\t\tmap: { value: null },\n\t\tuvTransform: { value: new Matrix3() },\n\t\tuv2Transform: { value: new Matrix3() },\n\n\t\talphaMap: { value: null },\n\t\talphaTest: { value: 0 }\n\n\t},\n\n\tspecularmap: {\n\n\t\tspecularMap: { value: null },\n\n\t},\n\n\tenvmap: {\n\n\t\tenvMap: { value: null },\n\t\tflipEnvMap: { value: - 1 },\n\t\treflectivity: { value: 1.0 }, // basic, lambert, phong\n\t\tior: { value: 1.5 }, // physical\n\t\trefractionRatio: { value: 0.98 } // basic, lambert, phong\n\n\t},\n\n\taomap: {\n\n\t\taoMap: { value: null },\n\t\taoMapIntensity: { value: 1 }\n\n\t},\n\n\tlightmap: {\n\n\t\tlightMap: { value: null },\n\t\tlightMapIntensity: { value: 1 }\n\n\t},\n\n\temissivemap: {\n\n\t\temissiveMap: { value: null }\n\n\t},\n\n\tbumpmap: {\n\n\t\tbumpMap: { value: null },\n\t\tbumpScale: { value: 1 }\n\n\t},\n\n\tnormalmap: {\n\n\t\tnormalMap: { value: null },\n\t\tnormalScale: { value: new Vector2( 1, 1 ) }\n\n\t},\n\n\tdisplacementmap: {\n\n\t\tdisplacementMap: { value: null },\n\t\tdisplacementScale: { value: 1 },\n\t\tdisplacementBias: { value: 0 }\n\n\t},\n\n\troughnessmap: {\n\n\t\troughnessMap: { value: null }\n\n\t},\n\n\tmetalnessmap: {\n\n\t\tmetalnessMap: { value: null }\n\n\t},\n\n\tgradientmap: {\n\n\t\tgradientMap: { value: null }\n\n\t},\n\n\tfog: {\n\n\t\tfogDensity: { value: 0.00025 },\n\t\tfogNear: { value: 1 },\n\t\tfogFar: { value: 2000 },\n\t\tfogColor: { value: new Color( 0xffffff ) }\n\n\t},\n\n\tlights: {\n\n\t\tambientLightColor: { value: [] },\n\n\t\tlightProbe: { value: [] },\n\n\t\tdirectionalLights: { value: [], properties: {\n\t\t\tdirection: {},\n\t\t\tcolor: {}\n\t\t} },\n\n\t\tdirectionalLightShadows: { value: [], properties: {\n\t\t\tshadowBias: {},\n\t\t\tshadowNormalBias: {},\n\t\t\tshadowRadius: {},\n\t\t\tshadowMapSize: {}\n\t\t} },\n\n\t\tdirectionalShadowMap: { value: [] },\n\t\tdirectionalShadowMatrix: { value: [] },\n\n\t\tspotLights: { value: [], properties: {\n\t\t\tcolor: {},\n\t\t\tposition: {},\n\t\t\tdirection: {},\n\t\t\tdistance: {},\n\t\t\tconeCos: {},\n\t\t\tpenumbraCos: {},\n\t\t\tdecay: {}\n\t\t} },\n\n\t\tspotLightShadows: { value: [], properties: {\n\t\t\tshadowBias: {},\n\t\t\tshadowNormalBias: {},\n\t\t\tshadowRadius: {},\n\t\t\tshadowMapSize: {}\n\t\t} },\n\n\t\tspotShadowMap: { value: [] },\n\t\tspotShadowMatrix: { value: [] },\n\n\t\tpointLights: { value: [], properties: {\n\t\t\tcolor: {},\n\t\t\tposition: {},\n\t\t\tdecay: {},\n\t\t\tdistance: {}\n\t\t} },\n\n\t\tpointLightShadows: { value: [], properties: {\n\t\t\tshadowBias: {},\n\t\t\tshadowNormalBias: {},\n\t\t\tshadowRadius: {},\n\t\t\tshadowMapSize: {},\n\t\t\tshadowCameraNear: {},\n\t\t\tshadowCameraFar: {}\n\t\t} },\n\n\t\tpointShadowMap: { value: [] },\n\t\tpointShadowMatrix: { value: [] },\n\n\t\themisphereLights: { value: [], properties: {\n\t\t\tdirection: {},\n\t\t\tskyColor: {},\n\t\t\tgroundColor: {}\n\t\t} },\n\n\t\t// TODO (abelnation): RectAreaLight BRDF data needs to be moved from example to main src\n\t\trectAreaLights: { value: [], properties: {\n\t\t\tcolor: {},\n\t\t\tposition: {},\n\t\t\twidth: {},\n\t\t\theight: {}\n\t\t} },\n\n\t\tltc_1: { value: null },\n\t\tltc_2: { value: null }\n\n\t},\n\n\tpoints: {\n\n\t\tdiffuse: { value: new Color( 0xffffff ) },\n\t\topacity: { value: 1.0 },\n\t\tsize: { value: 1.0 },\n\t\tscale: { value: 1.0 },\n\t\tmap: { value: null },\n\t\talphaMap: { value: null },\n\t\talphaTest: { value: 0 },\n\t\tuvTransform: { value: new Matrix3() }\n\n\t},\n\n\tsprite: {\n\n\t\tdiffuse: { value: new Color( 0xffffff ) },\n\t\topacity: { value: 1.0 },\n\t\tcenter: { value: new Vector2( 0.5, 0.5 ) },\n\t\trotation: { value: 0.0 },\n\t\tmap: { value: null },\n\t\talphaMap: { value: null },\n\t\talphaTest: { value: 0 },\n\t\tuvTransform: { value: new Matrix3() }\n\n\t}\n\n};\n\nconst ShaderLib = {\n\n\tbasic: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.specularmap,\n\t\t\tUniformsLib.envmap,\n\t\t\tUniformsLib.aomap,\n\t\t\tUniformsLib.lightmap,\n\t\t\tUniformsLib.fog\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.meshbasic_vert,\n\t\tfragmentShader: ShaderChunk.meshbasic_frag\n\n\t},\n\n\tlambert: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.specularmap,\n\t\t\tUniformsLib.envmap,\n\t\t\tUniformsLib.aomap,\n\t\t\tUniformsLib.lightmap,\n\t\t\tUniformsLib.emissivemap,\n\t\t\tUniformsLib.fog,\n\t\t\tUniformsLib.lights,\n\t\t\t{\n\t\t\t\temissive: { value: new Color( 0x000000 ) }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.meshlambert_vert,\n\t\tfragmentShader: ShaderChunk.meshlambert_frag\n\n\t},\n\n\tphong: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.specularmap,\n\t\t\tUniformsLib.envmap,\n\t\t\tUniformsLib.aomap,\n\t\t\tUniformsLib.lightmap,\n\t\t\tUniformsLib.emissivemap,\n\t\t\tUniformsLib.bumpmap,\n\t\t\tUniformsLib.normalmap,\n\t\t\tUniformsLib.displacementmap,\n\t\t\tUniformsLib.fog,\n\t\t\tUniformsLib.lights,\n\t\t\t{\n\t\t\t\temissive: { value: new Color( 0x000000 ) },\n\t\t\t\tspecular: { value: new Color( 0x111111 ) },\n\t\t\t\tshininess: { value: 30 }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.meshphong_vert,\n\t\tfragmentShader: ShaderChunk.meshphong_frag\n\n\t},\n\n\tstandard: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.envmap,\n\t\t\tUniformsLib.aomap,\n\t\t\tUniformsLib.lightmap,\n\t\t\tUniformsLib.emissivemap,\n\t\t\tUniformsLib.bumpmap,\n\t\t\tUniformsLib.normalmap,\n\t\t\tUniformsLib.displacementmap,\n\t\t\tUniformsLib.roughnessmap,\n\t\t\tUniformsLib.metalnessmap,\n\t\t\tUniformsLib.fog,\n\t\t\tUniformsLib.lights,\n\t\t\t{\n\t\t\t\temissive: { value: new Color( 0x000000 ) },\n\t\t\t\troughness: { value: 1.0 },\n\t\t\t\tmetalness: { value: 0.0 },\n\t\t\t\tenvMapIntensity: { value: 1 } // temporary\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.meshphysical_vert,\n\t\tfragmentShader: ShaderChunk.meshphysical_frag\n\n\t},\n\n\ttoon: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.aomap,\n\t\t\tUniformsLib.lightmap,\n\t\t\tUniformsLib.emissivemap,\n\t\t\tUniformsLib.bumpmap,\n\t\t\tUniformsLib.normalmap,\n\t\t\tUniformsLib.displacementmap,\n\t\t\tUniformsLib.gradientmap,\n\t\t\tUniformsLib.fog,\n\t\t\tUniformsLib.lights,\n\t\t\t{\n\t\t\t\temissive: { value: new Color( 0x000000 ) }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.meshtoon_vert,\n\t\tfragmentShader: ShaderChunk.meshtoon_frag\n\n\t},\n\n\tmatcap: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.bumpmap,\n\t\t\tUniformsLib.normalmap,\n\t\t\tUniformsLib.displacementmap,\n\t\t\tUniformsLib.fog,\n\t\t\t{\n\t\t\t\tmatcap: { value: null }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.meshmatcap_vert,\n\t\tfragmentShader: ShaderChunk.meshmatcap_frag\n\n\t},\n\n\tpoints: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.points,\n\t\t\tUniformsLib.fog\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.points_vert,\n\t\tfragmentShader: ShaderChunk.points_frag\n\n\t},\n\n\tdashed: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.fog,\n\t\t\t{\n\t\t\t\tscale: { value: 1 },\n\t\t\t\tdashSize: { value: 1 },\n\t\t\t\ttotalSize: { value: 2 }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.linedashed_vert,\n\t\tfragmentShader: ShaderChunk.linedashed_frag\n\n\t},\n\n\tdepth: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.displacementmap\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.depth_vert,\n\t\tfragmentShader: ShaderChunk.depth_frag\n\n\t},\n\n\tnormal: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.bumpmap,\n\t\t\tUniformsLib.normalmap,\n\t\t\tUniformsLib.displacementmap,\n\t\t\t{\n\t\t\t\topacity: { value: 1.0 }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.meshnormal_vert,\n\t\tfragmentShader: ShaderChunk.meshnormal_frag\n\n\t},\n\n\tsprite: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.sprite,\n\t\t\tUniformsLib.fog\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.sprite_vert,\n\t\tfragmentShader: ShaderChunk.sprite_frag\n\n\t},\n\n\tbackground: {\n\n\t\tuniforms: {\n\t\t\tuvTransform: { value: new Matrix3() },\n\t\t\tt2D: { value: null },\n\t\t},\n\n\t\tvertexShader: ShaderChunk.background_vert,\n\t\tfragmentShader: ShaderChunk.background_frag\n\n\t},\n\t/* -------------------------------------------------------------------------\n\t//\tCube map shader\n\t ------------------------------------------------------------------------- */\n\n\tcube: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.envmap,\n\t\t\t{\n\t\t\t\topacity: { value: 1.0 }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.cube_vert,\n\t\tfragmentShader: ShaderChunk.cube_frag\n\n\t},\n\n\tequirect: {\n\n\t\tuniforms: {\n\t\t\ttEquirect: { value: null },\n\t\t},\n\n\t\tvertexShader: ShaderChunk.equirect_vert,\n\t\tfragmentShader: ShaderChunk.equirect_frag\n\n\t},\n\n\tdistanceRGBA: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.common,\n\t\t\tUniformsLib.displacementmap,\n\t\t\t{\n\t\t\t\treferencePosition: { value: new Vector3() },\n\t\t\t\tnearDistance: { value: 1 },\n\t\t\t\tfarDistance: { value: 1000 }\n\t\t\t}\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.distanceRGBA_vert,\n\t\tfragmentShader: ShaderChunk.distanceRGBA_frag\n\n\t},\n\n\tshadow: {\n\n\t\tuniforms: mergeUniforms( [\n\t\t\tUniformsLib.lights,\n\t\t\tUniformsLib.fog,\n\t\t\t{\n\t\t\t\tcolor: { value: new Color( 0x00000 ) },\n\t\t\t\topacity: { value: 1.0 }\n\t\t\t},\n\t\t] ),\n\n\t\tvertexShader: ShaderChunk.shadow_vert,\n\t\tfragmentShader: ShaderChunk.shadow_frag\n\n\t}\n\n};\n\nShaderLib.physical = {\n\n\tuniforms: mergeUniforms( [\n\t\tShaderLib.standard.uniforms,\n\t\t{\n\t\t\tclearcoat: { value: 0 },\n\t\t\tclearcoatMap: { value: null },\n\t\t\tclearcoatRoughness: { value: 0 },\n\t\t\tclearcoatRoughnessMap: { value: null },\n\t\t\tclearcoatNormalScale: { value: new Vector2( 1, 1 ) },\n\t\t\tclearcoatNormalMap: { value: null },\n\t\t\tiridescence: { value: 0 },\n\t\t\tiridescenceMap: { value: null },\n\t\t\tiridescenceIOR: { value: 1.3 },\n\t\t\tiridescenceThicknessMinimum: { value: 100 },\n\t\t\tiridescenceThicknessMaximum: { value: 400 },\n\t\t\tiridescenceThicknessMap: { value: null },\n\t\t\tsheen: { value: 0 },\n\t\t\tsheenColor: { value: new Color( 0x000000 ) },\n\t\t\tsheenColorMap: { value: null },\n\t\t\tsheenRoughness: { value: 1 },\n\t\t\tsheenRoughnessMap: { value: null },\n\t\t\ttransmission: { value: 0 },\n\t\t\ttransmissionMap: { value: null },\n\t\t\ttransmissionSamplerSize: { value: new Vector2() },\n\t\t\ttransmissionSamplerMap: { value: null },\n\t\t\tthickness: { value: 0 },\n\t\t\tthicknessMap: { value: null },\n\t\t\tattenuationDistance: { value: 0 },\n\t\t\tattenuationColor: { value: new Color( 0x000000 ) },\n\t\t\tspecularIntensity: { value: 1 },\n\t\t\tspecularIntensityMap: { value: null },\n\t\t\tspecularColor: { value: new Color( 1, 1, 1 ) },\n\t\t\tspecularColorMap: { value: null },\n\t\t}\n\t] ),\n\n\tvertexShader: ShaderChunk.meshphysical_vert,\n\tfragmentShader: ShaderChunk.meshphysical_frag\n\n};\n\nfunction WebGLBackground( renderer, cubemaps, state, objects, alpha, premultipliedAlpha ) {\n\n\tconst clearColor = new Color( 0x000000 );\n\tlet clearAlpha = alpha === true ? 0 : 1;\n\n\tlet planeMesh;\n\tlet boxMesh;\n\n\tlet currentBackground = null;\n\tlet currentBackgroundVersion = 0;\n\tlet currentTonemapping = null;\n\n\tfunction render( renderList, scene ) {\n\n\t\tlet forceClear = false;\n\t\tlet background = scene.isScene === true ? scene.background : null;\n\n\t\tif ( background && background.isTexture ) {\n\n\t\t\tbackground = cubemaps.get( background );\n\n\t\t}\n\n\t\t// Ignore background in AR\n\t\t// TODO: Reconsider this.\n\n\t\tconst xr = renderer.xr;\n\t\tconst session = xr.getSession && xr.getSession();\n\n\t\tif ( session && session.environmentBlendMode === 'additive' ) {\n\n\t\t\tbackground = null;\n\n\t\t}\n\n\t\tif ( background === null ) {\n\n\t\t\tsetClear( clearColor, clearAlpha );\n\n\t\t} else if ( background && background.isColor ) {\n\n\t\t\tsetClear( background, 1 );\n\t\t\tforceClear = true;\n\n\t\t}\n\n\t\tif ( renderer.autoClear || forceClear ) {\n\n\t\t\trenderer.clear( renderer.autoClearColor, renderer.autoClearDepth, renderer.autoClearStencil );\n\n\t\t}\n\n\t\tif ( background && ( background.isCubeTexture || background.mapping === CubeUVReflectionMapping ) ) {\n\n\t\t\tif ( boxMesh === undefined ) {\n\n\t\t\t\tboxMesh = new Mesh(\n\t\t\t\t\tnew BoxGeometry( 1, 1, 1 ),\n\t\t\t\t\tnew ShaderMaterial( {\n\t\t\t\t\t\tname: 'BackgroundCubeMaterial',\n\t\t\t\t\t\tuniforms: cloneUniforms( ShaderLib.cube.uniforms ),\n\t\t\t\t\t\tvertexShader: ShaderLib.cube.vertexShader,\n\t\t\t\t\t\tfragmentShader: ShaderLib.cube.fragmentShader,\n\t\t\t\t\t\tside: BackSide,\n\t\t\t\t\t\tdepthTest: false,\n\t\t\t\t\t\tdepthWrite: false,\n\t\t\t\t\t\tfog: false\n\t\t\t\t\t} )\n\t\t\t\t);\n\n\t\t\t\tboxMesh.geometry.deleteAttribute( 'normal' );\n\t\t\t\tboxMesh.geometry.deleteAttribute( 'uv' );\n\n\t\t\t\tboxMesh.onBeforeRender = function ( renderer, scene, camera ) {\n\n\t\t\t\t\tthis.matrixWorld.copyPosition( camera.matrixWorld );\n\n\t\t\t\t};\n\n\t\t\t\t// enable code injection for non-built-in material\n\t\t\t\tObject.defineProperty( boxMesh.material, 'envMap', {\n\n\t\t\t\t\tget: function () {\n\n\t\t\t\t\t\treturn this.uniforms.envMap.value;\n\n\t\t\t\t\t}\n\n\t\t\t\t} );\n\n\t\t\t\tobjects.update( boxMesh );\n\n\t\t\t}\n\n\t\t\tboxMesh.material.uniforms.envMap.value = background;\n\t\t\tboxMesh.material.uniforms.flipEnvMap.value = ( background.isCubeTexture && background.isRenderTargetTexture === false ) ? - 1 : 1;\n\n\t\t\tif ( currentBackground !== background ||\n\t\t\t\tcurrentBackgroundVersion !== background.version ||\n\t\t\t\tcurrentTonemapping !== renderer.toneMapping ) {\n\n\t\t\t\tboxMesh.material.needsUpdate = true;\n\n\t\t\t\tcurrentBackground = background;\n\t\t\t\tcurrentBackgroundVersion = background.version;\n\t\t\t\tcurrentTonemapping = renderer.toneMapping;\n\n\t\t\t}\n\n\t\t\tboxMesh.layers.enableAll();\n\n\t\t\t// push to the pre-sorted opaque render list\n\t\t\trenderList.unshift( boxMesh, boxMesh.geometry, boxMesh.material, 0, 0, null );\n\n\t\t} else if ( background && background.isTexture ) {\n\n\t\t\tif ( planeMesh === undefined ) {\n\n\t\t\t\tplaneMesh = new Mesh(\n\t\t\t\t\tnew PlaneGeometry( 2, 2 ),\n\t\t\t\t\tnew ShaderMaterial( {\n\t\t\t\t\t\tname: 'BackgroundMaterial',\n\t\t\t\t\t\tuniforms: cloneUniforms( ShaderLib.background.uniforms ),\n\t\t\t\t\t\tvertexShader: ShaderLib.background.vertexShader,\n\t\t\t\t\t\tfragmentShader: ShaderLib.background.fragmentShader,\n\t\t\t\t\t\tside: FrontSide,\n\t\t\t\t\t\tdepthTest: false,\n\t\t\t\t\t\tdepthWrite: false,\n\t\t\t\t\t\tfog: false\n\t\t\t\t\t} )\n\t\t\t\t);\n\n\t\t\t\tplaneMesh.geometry.deleteAttribute( 'normal' );\n\n\t\t\t\t// enable code injection for non-built-in material\n\t\t\t\tObject.defineProperty( planeMesh.material, 'map', {\n\n\t\t\t\t\tget: function () {\n\n\t\t\t\t\t\treturn this.uniforms.t2D.value;\n\n\t\t\t\t\t}\n\n\t\t\t\t} );\n\n\t\t\t\tobjects.update( planeMesh );\n\n\t\t\t}\n\n\t\t\tplaneMesh.material.uniforms.t2D.value = background;\n\n\t\t\tif ( background.matrixAutoUpdate === true ) {\n\n\t\t\t\tbackground.updateMatrix();\n\n\t\t\t}\n\n\t\t\tplaneMesh.material.uniforms.uvTransform.value.copy( background.matrix );\n\n\t\t\tif ( currentBackground !== background ||\n\t\t\t\tcurrentBackgroundVersion !== background.version ||\n\t\t\t\tcurrentTonemapping !== renderer.toneMapping ) {\n\n\t\t\t\tplaneMesh.material.needsUpdate = true;\n\n\t\t\t\tcurrentBackground = background;\n\t\t\t\tcurrentBackgroundVersion = background.version;\n\t\t\t\tcurrentTonemapping = renderer.toneMapping;\n\n\t\t\t}\n\n\t\t\tplaneMesh.layers.enableAll();\n\n\t\t\t// push to the pre-sorted opaque render list\n\t\t\trenderList.unshift( planeMesh, planeMesh.geometry, planeMesh.material, 0, 0, null );\n\n\t\t}\n\n\t}\n\n\tfunction setClear( color, alpha ) {\n\n\t\tstate.buffers.color.setClear( color.r, color.g, color.b, alpha, premultipliedAlpha );\n\n\t}\n\n\treturn {\n\n\t\tgetClearColor: function () {\n\n\t\t\treturn clearColor;\n\n\t\t},\n\t\tsetClearColor: function ( color, alpha = 1 ) {\n\n\t\t\tclearColor.set( color );\n\t\t\tclearAlpha = alpha;\n\t\t\tsetClear( clearColor, clearAlpha );\n\n\t\t},\n\t\tgetClearAlpha: function () {\n\n\t\t\treturn clearAlpha;\n\n\t\t},\n\t\tsetClearAlpha: function ( alpha ) {\n\n\t\t\tclearAlpha = alpha;\n\t\t\tsetClear( clearColor, clearAlpha );\n\n\t\t},\n\t\trender: render\n\n\t};\n\n}\n\nfunction WebGLBindingStates( gl, extensions, attributes, capabilities ) {\n\n\tconst maxVertexAttributes = gl.getParameter( 34921 );\n\n\tconst extension = capabilities.isWebGL2 ? null : extensions.get( 'OES_vertex_array_object' );\n\tconst vaoAvailable = capabilities.isWebGL2 || extension !== null;\n\n\tconst bindingStates = {};\n\n\tconst defaultState = createBindingState( null );\n\tlet currentState = defaultState;\n\tlet forceUpdate = false;\n\n\tfunction setup( object, material, program, geometry, index ) {\n\n\t\tlet updateBuffers = false;\n\n\t\tif ( vaoAvailable ) {\n\n\t\t\tconst state = getBindingState( geometry, program, material );\n\n\t\t\tif ( currentState !== state ) {\n\n\t\t\t\tcurrentState = state;\n\t\t\t\tbindVertexArrayObject( currentState.object );\n\n\t\t\t}\n\n\t\t\tupdateBuffers = needsUpdate( object, geometry, program, index );\n\n\t\t\tif ( updateBuffers ) saveCache( object, geometry, program, index );\n\n\t\t} else {\n\n\t\t\tconst wireframe = ( material.wireframe === true );\n\n\t\t\tif ( currentState.geometry !== geometry.id ||\n\t\t\t\tcurrentState.program !== program.id ||\n\t\t\t\tcurrentState.wireframe !== wireframe ) {\n\n\t\t\t\tcurrentState.geometry = geometry.id;\n\t\t\t\tcurrentState.program = program.id;\n\t\t\t\tcurrentState.wireframe = wireframe;\n\n\t\t\t\tupdateBuffers = true;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( index !== null ) {\n\n\t\t\tattributes.update( index, 34963 );\n\n\t\t}\n\n\t\tif ( updateBuffers || forceUpdate ) {\n\n\t\t\tforceUpdate = false;\n\n\t\t\tsetupVertexAttributes( object, material, program, geometry );\n\n\t\t\tif ( index !== null ) {\n\n\t\t\t\tgl.bindBuffer( 34963, attributes.get( index ).buffer );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction createVertexArrayObject() {\n\n\t\tif ( capabilities.isWebGL2 ) return gl.createVertexArray();\n\n\t\treturn extension.createVertexArrayOES();\n\n\t}\n\n\tfunction bindVertexArrayObject( vao ) {\n\n\t\tif ( capabilities.isWebGL2 ) return gl.bindVertexArray( vao );\n\n\t\treturn extension.bindVertexArrayOES( vao );\n\n\t}\n\n\tfunction deleteVertexArrayObject( vao ) {\n\n\t\tif ( capabilities.isWebGL2 ) return gl.deleteVertexArray( vao );\n\n\t\treturn extension.deleteVertexArrayOES( vao );\n\n\t}\n\n\tfunction getBindingState( geometry, program, material ) {\n\n\t\tconst wireframe = ( material.wireframe === true );\n\n\t\tlet programMap = bindingStates[ geometry.id ];\n\n\t\tif ( programMap === undefined ) {\n\n\t\t\tprogramMap = {};\n\t\t\tbindingStates[ geometry.id ] = programMap;\n\n\t\t}\n\n\t\tlet stateMap = programMap[ program.id ];\n\n\t\tif ( stateMap === undefined ) {\n\n\t\t\tstateMap = {};\n\t\t\tprogramMap[ program.id ] = stateMap;\n\n\t\t}\n\n\t\tlet state = stateMap[ wireframe ];\n\n\t\tif ( state === undefined ) {\n\n\t\t\tstate = createBindingState( createVertexArrayObject() );\n\t\t\tstateMap[ wireframe ] = state;\n\n\t\t}\n\n\t\treturn state;\n\n\t}\n\n\tfunction createBindingState( vao ) {\n\n\t\tconst newAttributes = [];\n\t\tconst enabledAttributes = [];\n\t\tconst attributeDivisors = [];\n\n\t\tfor ( let i = 0; i < maxVertexAttributes; i ++ ) {\n\n\t\t\tnewAttributes[ i ] = 0;\n\t\t\tenabledAttributes[ i ] = 0;\n\t\t\tattributeDivisors[ i ] = 0;\n\n\t\t}\n\n\t\treturn {\n\n\t\t\t// for backward compatibility on non-VAO support browser\n\t\t\tgeometry: null,\n\t\t\tprogram: null,\n\t\t\twireframe: false,\n\n\t\t\tnewAttributes: newAttributes,\n\t\t\tenabledAttributes: enabledAttributes,\n\t\t\tattributeDivisors: attributeDivisors,\n\t\t\tobject: vao,\n\t\t\tattributes: {},\n\t\t\tindex: null\n\n\t\t};\n\n\t}\n\n\tfunction needsUpdate( object, geometry, program, index ) {\n\n\t\tconst cachedAttributes = currentState.attributes;\n\t\tconst geometryAttributes = geometry.attributes;\n\n\t\tlet attributesNum = 0;\n\n\t\tconst programAttributes = program.getAttributes();\n\n\t\tfor ( const name in programAttributes ) {\n\n\t\t\tconst programAttribute = programAttributes[ name ];\n\n\t\t\tif ( programAttribute.location >= 0 ) {\n\n\t\t\t\tconst cachedAttribute = cachedAttributes[ name ];\n\t\t\t\tlet geometryAttribute = geometryAttributes[ name ];\n\n\t\t\t\tif ( geometryAttribute === undefined ) {\n\n\t\t\t\t\tif ( name === 'instanceMatrix' && object.instanceMatrix ) geometryAttribute = object.instanceMatrix;\n\t\t\t\t\tif ( name === 'instanceColor' && object.instanceColor ) geometryAttribute = object.instanceColor;\n\n\t\t\t\t}\n\n\t\t\t\tif ( cachedAttribute === undefined ) return true;\n\n\t\t\t\tif ( cachedAttribute.attribute !== geometryAttribute ) return true;\n\n\t\t\t\tif ( geometryAttribute && cachedAttribute.data !== geometryAttribute.data ) return true;\n\n\t\t\t\tattributesNum ++;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( currentState.attributesNum !== attributesNum ) return true;\n\n\t\tif ( currentState.index !== index ) return true;\n\n\t\treturn false;\n\n\t}\n\n\tfunction saveCache( object, geometry, program, index ) {\n\n\t\tconst cache = {};\n\t\tconst attributes = geometry.attributes;\n\t\tlet attributesNum = 0;\n\n\t\tconst programAttributes = program.getAttributes();\n\n\t\tfor ( const name in programAttributes ) {\n\n\t\t\tconst programAttribute = programAttributes[ name ];\n\n\t\t\tif ( programAttribute.location >= 0 ) {\n\n\t\t\t\tlet attribute = attributes[ name ];\n\n\t\t\t\tif ( attribute === undefined ) {\n\n\t\t\t\t\tif ( name === 'instanceMatrix' && object.instanceMatrix ) attribute = object.instanceMatrix;\n\t\t\t\t\tif ( name === 'instanceColor' && object.instanceColor ) attribute = object.instanceColor;\n\n\t\t\t\t}\n\n\t\t\t\tconst data = {};\n\t\t\t\tdata.attribute = attribute;\n\n\t\t\t\tif ( attribute && attribute.data ) {\n\n\t\t\t\t\tdata.data = attribute.data;\n\n\t\t\t\t}\n\n\t\t\t\tcache[ name ] = data;\n\n\t\t\t\tattributesNum ++;\n\n\t\t\t}\n\n\t\t}\n\n\t\tcurrentState.attributes = cache;\n\t\tcurrentState.attributesNum = attributesNum;\n\n\t\tcurrentState.index = index;\n\n\t}\n\n\tfunction initAttributes() {\n\n\t\tconst newAttributes = currentState.newAttributes;\n\n\t\tfor ( let i = 0, il = newAttributes.length; i < il; i ++ ) {\n\n\t\t\tnewAttributes[ i ] = 0;\n\n\t\t}\n\n\t}\n\n\tfunction enableAttribute( attribute ) {\n\n\t\tenableAttributeAndDivisor( attribute, 0 );\n\n\t}\n\n\tfunction enableAttributeAndDivisor( attribute, meshPerAttribute ) {\n\n\t\tconst newAttributes = currentState.newAttributes;\n\t\tconst enabledAttributes = currentState.enabledAttributes;\n\t\tconst attributeDivisors = currentState.attributeDivisors;\n\n\t\tnewAttributes[ attribute ] = 1;\n\n\t\tif ( enabledAttributes[ attribute ] === 0 ) {\n\n\t\t\tgl.enableVertexAttribArray( attribute );\n\t\t\tenabledAttributes[ attribute ] = 1;\n\n\t\t}\n\n\t\tif ( attributeDivisors[ attribute ] !== meshPerAttribute ) {\n\n\t\t\tconst extension = capabilities.isWebGL2 ? gl : extensions.get( 'ANGLE_instanced_arrays' );\n\n\t\t\textension[ capabilities.isWebGL2 ? 'vertexAttribDivisor' : 'vertexAttribDivisorANGLE' ]( attribute, meshPerAttribute );\n\t\t\tattributeDivisors[ attribute ] = meshPerAttribute;\n\n\t\t}\n\n\t}\n\n\tfunction disableUnusedAttributes() {\n\n\t\tconst newAttributes = currentState.newAttributes;\n\t\tconst enabledAttributes = currentState.enabledAttributes;\n\n\t\tfor ( let i = 0, il = enabledAttributes.length; i < il; i ++ ) {\n\n\t\t\tif ( enabledAttributes[ i ] !== newAttributes[ i ] ) {\n\n\t\t\t\tgl.disableVertexAttribArray( i );\n\t\t\t\tenabledAttributes[ i ] = 0;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction vertexAttribPointer( index, size, type, normalized, stride, offset ) {\n\n\t\tif ( capabilities.isWebGL2 === true && ( type === 5124 || type === 5125 ) ) {\n\n\t\t\tgl.vertexAttribIPointer( index, size, type, stride, offset );\n\n\t\t} else {\n\n\t\t\tgl.vertexAttribPointer( index, size, type, normalized, stride, offset );\n\n\t\t}\n\n\t}\n\n\tfunction setupVertexAttributes( object, material, program, geometry ) {\n\n\t\tif ( capabilities.isWebGL2 === false && ( object.isInstancedMesh || geometry.isInstancedBufferGeometry ) ) {\n\n\t\t\tif ( extensions.get( 'ANGLE_instanced_arrays' ) === null ) return;\n\n\t\t}\n\n\t\tinitAttributes();\n\n\t\tconst geometryAttributes = geometry.attributes;\n\n\t\tconst programAttributes = program.getAttributes();\n\n\t\tconst materialDefaultAttributeValues = material.defaultAttributeValues;\n\n\t\tfor ( const name in programAttributes ) {\n\n\t\t\tconst programAttribute = programAttributes[ name ];\n\n\t\t\tif ( programAttribute.location >= 0 ) {\n\n\t\t\t\tlet geometryAttribute = geometryAttributes[ name ];\n\n\t\t\t\tif ( geometryAttribute === undefined ) {\n\n\t\t\t\t\tif ( name === 'instanceMatrix' && object.instanceMatrix ) geometryAttribute = object.instanceMatrix;\n\t\t\t\t\tif ( name === 'instanceColor' && object.instanceColor ) geometryAttribute = object.instanceColor;\n\n\t\t\t\t}\n\n\t\t\t\tif ( geometryAttribute !== undefined ) {\n\n\t\t\t\t\tconst normalized = geometryAttribute.normalized;\n\t\t\t\t\tconst size = geometryAttribute.itemSize;\n\n\t\t\t\t\tconst attribute = attributes.get( geometryAttribute );\n\n\t\t\t\t\t// TODO Attribute may not be available on context restore\n\n\t\t\t\t\tif ( attribute === undefined ) continue;\n\n\t\t\t\t\tconst buffer = attribute.buffer;\n\t\t\t\t\tconst type = attribute.type;\n\t\t\t\t\tconst bytesPerElement = attribute.bytesPerElement;\n\n\t\t\t\t\tif ( geometryAttribute.isInterleavedBufferAttribute ) {\n\n\t\t\t\t\t\tconst data = geometryAttribute.data;\n\t\t\t\t\t\tconst stride = data.stride;\n\t\t\t\t\t\tconst offset = geometryAttribute.offset;\n\n\t\t\t\t\t\tif ( data.isInstancedInterleavedBuffer ) {\n\n\t\t\t\t\t\t\tfor ( let i = 0; i < programAttribute.locationSize; i ++ ) {\n\n\t\t\t\t\t\t\t\tenableAttributeAndDivisor( programAttribute.location + i, data.meshPerAttribute );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif ( object.isInstancedMesh !== true && geometry._maxInstanceCount === undefined ) {\n\n\t\t\t\t\t\t\t\tgeometry._maxInstanceCount = data.meshPerAttribute * data.count;\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tfor ( let i = 0; i < programAttribute.locationSize; i ++ ) {\n\n\t\t\t\t\t\t\t\tenableAttribute( programAttribute.location + i );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tgl.bindBuffer( 34962, buffer );\n\n\t\t\t\t\t\tfor ( let i = 0; i < programAttribute.locationSize; i ++ ) {\n\n\t\t\t\t\t\t\tvertexAttribPointer(\n\t\t\t\t\t\t\t\tprogramAttribute.location + i,\n\t\t\t\t\t\t\t\tsize / programAttribute.locationSize,\n\t\t\t\t\t\t\t\ttype,\n\t\t\t\t\t\t\t\tnormalized,\n\t\t\t\t\t\t\t\tstride * bytesPerElement,\n\t\t\t\t\t\t\t\t( offset + ( size / programAttribute.locationSize ) * i ) * bytesPerElement\n\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tif ( geometryAttribute.isInstancedBufferAttribute ) {\n\n\t\t\t\t\t\t\tfor ( let i = 0; i < programAttribute.locationSize; i ++ ) {\n\n\t\t\t\t\t\t\t\tenableAttributeAndDivisor( programAttribute.location + i, geometryAttribute.meshPerAttribute );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif ( object.isInstancedMesh !== true && geometry._maxInstanceCount === undefined ) {\n\n\t\t\t\t\t\t\t\tgeometry._maxInstanceCount = geometryAttribute.meshPerAttribute * geometryAttribute.count;\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tfor ( let i = 0; i < programAttribute.locationSize; i ++ ) {\n\n\t\t\t\t\t\t\t\tenableAttribute( programAttribute.location + i );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tgl.bindBuffer( 34962, buffer );\n\n\t\t\t\t\t\tfor ( let i = 0; i < programAttribute.locationSize; i ++ ) {\n\n\t\t\t\t\t\t\tvertexAttribPointer(\n\t\t\t\t\t\t\t\tprogramAttribute.location + i,\n\t\t\t\t\t\t\t\tsize / programAttribute.locationSize,\n\t\t\t\t\t\t\t\ttype,\n\t\t\t\t\t\t\t\tnormalized,\n\t\t\t\t\t\t\t\tsize * bytesPerElement,\n\t\t\t\t\t\t\t\t( size / programAttribute.locationSize ) * i * bytesPerElement\n\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t} else if ( materialDefaultAttributeValues !== undefined ) {\n\n\t\t\t\t\tconst value = materialDefaultAttributeValues[ name ];\n\n\t\t\t\t\tif ( value !== undefined ) {\n\n\t\t\t\t\t\tswitch ( value.length ) {\n\n\t\t\t\t\t\t\tcase 2:\n\t\t\t\t\t\t\t\tgl.vertexAttrib2fv( programAttribute.location, value );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase 3:\n\t\t\t\t\t\t\t\tgl.vertexAttrib3fv( programAttribute.location, value );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase 4:\n\t\t\t\t\t\t\t\tgl.vertexAttrib4fv( programAttribute.location, value );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\tgl.vertexAttrib1fv( programAttribute.location, value );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tdisableUnusedAttributes();\n\n\t}\n\n\tfunction dispose() {\n\n\t\treset();\n\n\t\tfor ( const geometryId in bindingStates ) {\n\n\t\t\tconst programMap = bindingStates[ geometryId ];\n\n\t\t\tfor ( const programId in programMap ) {\n\n\t\t\t\tconst stateMap = programMap[ programId ];\n\n\t\t\t\tfor ( const wireframe in stateMap ) {\n\n\t\t\t\t\tdeleteVertexArrayObject( stateMap[ wireframe ].object );\n\n\t\t\t\t\tdelete stateMap[ wireframe ];\n\n\t\t\t\t}\n\n\t\t\t\tdelete programMap[ programId ];\n\n\t\t\t}\n\n\t\t\tdelete bindingStates[ geometryId ];\n\n\t\t}\n\n\t}\n\n\tfunction releaseStatesOfGeometry( geometry ) {\n\n\t\tif ( bindingStates[ geometry.id ] === undefined ) return;\n\n\t\tconst programMap = bindingStates[ geometry.id ];\n\n\t\tfor ( const programId in programMap ) {\n\n\t\t\tconst stateMap = programMap[ programId ];\n\n\t\t\tfor ( const wireframe in stateMap ) {\n\n\t\t\t\tdeleteVertexArrayObject( stateMap[ wireframe ].object );\n\n\t\t\t\tdelete stateMap[ wireframe ];\n\n\t\t\t}\n\n\t\t\tdelete programMap[ programId ];\n\n\t\t}\n\n\t\tdelete bindingStates[ geometry.id ];\n\n\t}\n\n\tfunction releaseStatesOfProgram( program ) {\n\n\t\tfor ( const geometryId in bindingStates ) {\n\n\t\t\tconst programMap = bindingStates[ geometryId ];\n\n\t\t\tif ( programMap[ program.id ] === undefined ) continue;\n\n\t\t\tconst stateMap = programMap[ program.id ];\n\n\t\t\tfor ( const wireframe in stateMap ) {\n\n\t\t\t\tdeleteVertexArrayObject( stateMap[ wireframe ].object );\n\n\t\t\t\tdelete stateMap[ wireframe ];\n\n\t\t\t}\n\n\t\t\tdelete programMap[ program.id ];\n\n\t\t}\n\n\t}\n\n\tfunction reset() {\n\n\t\tresetDefaultState();\n\t\tforceUpdate = true;\n\n\t\tif ( currentState === defaultState ) return;\n\n\t\tcurrentState = defaultState;\n\t\tbindVertexArrayObject( currentState.object );\n\n\t}\n\n\t// for backward-compatibility\n\n\tfunction resetDefaultState() {\n\n\t\tdefaultState.geometry = null;\n\t\tdefaultState.program = null;\n\t\tdefaultState.wireframe = false;\n\n\t}\n\n\treturn {\n\n\t\tsetup: setup,\n\t\treset: reset,\n\t\tresetDefaultState: resetDefaultState,\n\t\tdispose: dispose,\n\t\treleaseStatesOfGeometry: releaseStatesOfGeometry,\n\t\treleaseStatesOfProgram: releaseStatesOfProgram,\n\n\t\tinitAttributes: initAttributes,\n\t\tenableAttribute: enableAttribute,\n\t\tdisableUnusedAttributes: disableUnusedAttributes\n\n\t};\n\n}\n\nfunction WebGLBufferRenderer( gl, extensions, info, capabilities ) {\n\n\tconst isWebGL2 = capabilities.isWebGL2;\n\n\tlet mode;\n\n\tfunction setMode( value ) {\n\n\t\tmode = value;\n\n\t}\n\n\tfunction render( start, count ) {\n\n\t\tgl.drawArrays( mode, start, count );\n\n\t\tinfo.update( count, mode, 1 );\n\n\t}\n\n\tfunction renderInstances( start, count, primcount ) {\n\n\t\tif ( primcount === 0 ) return;\n\n\t\tlet extension, methodName;\n\n\t\tif ( isWebGL2 ) {\n\n\t\t\textension = gl;\n\t\t\tmethodName = 'drawArraysInstanced';\n\n\t\t} else {\n\n\t\t\textension = extensions.get( 'ANGLE_instanced_arrays' );\n\t\t\tmethodName = 'drawArraysInstancedANGLE';\n\n\t\t\tif ( extension === null ) {\n\n\t\t\t\tconsole.error( 'THREE.WebGLBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.' );\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t}\n\n\t\textension[ methodName ]( mode, start, count, primcount );\n\n\t\tinfo.update( count, mode, primcount );\n\n\t}\n\n\t//\n\n\tthis.setMode = setMode;\n\tthis.render = render;\n\tthis.renderInstances = renderInstances;\n\n}\n\nfunction WebGLCapabilities( gl, extensions, parameters ) {\n\n\tlet maxAnisotropy;\n\n\tfunction getMaxAnisotropy() {\n\n\t\tif ( maxAnisotropy !== undefined ) return maxAnisotropy;\n\n\t\tif ( extensions.has( 'EXT_texture_filter_anisotropic' ) === true ) {\n\n\t\t\tconst extension = extensions.get( 'EXT_texture_filter_anisotropic' );\n\n\t\t\tmaxAnisotropy = gl.getParameter( extension.MAX_TEXTURE_MAX_ANISOTROPY_EXT );\n\n\t\t} else {\n\n\t\t\tmaxAnisotropy = 0;\n\n\t\t}\n\n\t\treturn maxAnisotropy;\n\n\t}\n\n\tfunction getMaxPrecision( precision ) {\n\n\t\tif ( precision === 'highp' ) {\n\n\t\t\tif ( gl.getShaderPrecisionFormat( 35633, 36338 ).precision > 0 &&\n\t\t\t\tgl.getShaderPrecisionFormat( 35632, 36338 ).precision > 0 ) {\n\n\t\t\t\treturn 'highp';\n\n\t\t\t}\n\n\t\t\tprecision = 'mediump';\n\n\t\t}\n\n\t\tif ( precision === 'mediump' ) {\n\n\t\t\tif ( gl.getShaderPrecisionFormat( 35633, 36337 ).precision > 0 &&\n\t\t\t\tgl.getShaderPrecisionFormat( 35632, 36337 ).precision > 0 ) {\n\n\t\t\t\treturn 'mediump';\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn 'lowp';\n\n\t}\n\n\tconst isWebGL2 = ( typeof WebGL2RenderingContext !== 'undefined' && gl instanceof WebGL2RenderingContext ) ||\n\t\t( typeof WebGL2ComputeRenderingContext !== 'undefined' && gl instanceof WebGL2ComputeRenderingContext );\n\n\tlet precision = parameters.precision !== undefined ? parameters.precision : 'highp';\n\tconst maxPrecision = getMaxPrecision( precision );\n\n\tif ( maxPrecision !== precision ) {\n\n\t\tconsole.warn( 'THREE.WebGLRenderer:', precision, 'not supported, using', maxPrecision, 'instead.' );\n\t\tprecision = maxPrecision;\n\n\t}\n\n\tconst drawBuffers = isWebGL2 || extensions.has( 'WEBGL_draw_buffers' );\n\n\tconst logarithmicDepthBuffer = parameters.logarithmicDepthBuffer === true;\n\n\tconst maxTextures = gl.getParameter( 34930 );\n\tconst maxVertexTextures = gl.getParameter( 35660 );\n\tconst maxTextureSize = gl.getParameter( 3379 );\n\tconst maxCubemapSize = gl.getParameter( 34076 );\n\n\tconst maxAttributes = gl.getParameter( 34921 );\n\tconst maxVertexUniforms = gl.getParameter( 36347 );\n\tconst maxVaryings = gl.getParameter( 36348 );\n\tconst maxFragmentUniforms = gl.getParameter( 36349 );\n\n\tconst vertexTextures = maxVertexTextures > 0;\n\tconst floatFragmentTextures = isWebGL2 || extensions.has( 'OES_texture_float' );\n\tconst floatVertexTextures = vertexTextures && floatFragmentTextures;\n\n\tconst maxSamples = isWebGL2 ? gl.getParameter( 36183 ) : 0;\n\n\treturn {\n\n\t\tisWebGL2: isWebGL2,\n\n\t\tdrawBuffers: drawBuffers,\n\n\t\tgetMaxAnisotropy: getMaxAnisotropy,\n\t\tgetMaxPrecision: getMaxPrecision,\n\n\t\tprecision: precision,\n\t\tlogarithmicDepthBuffer: logarithmicDepthBuffer,\n\n\t\tmaxTextures: maxTextures,\n\t\tmaxVertexTextures: maxVertexTextures,\n\t\tmaxTextureSize: maxTextureSize,\n\t\tmaxCubemapSize: maxCubemapSize,\n\n\t\tmaxAttributes: maxAttributes,\n\t\tmaxVertexUniforms: maxVertexUniforms,\n\t\tmaxVaryings: maxVaryings,\n\t\tmaxFragmentUniforms: maxFragmentUniforms,\n\n\t\tvertexTextures: vertexTextures,\n\t\tfloatFragmentTextures: floatFragmentTextures,\n\t\tfloatVertexTextures: floatVertexTextures,\n\n\t\tmaxSamples: maxSamples\n\n\t};\n\n}\n\nfunction WebGLClipping( properties ) {\n\n\tconst scope = this;\n\n\tlet globalState = null,\n\t\tnumGlobalPlanes = 0,\n\t\tlocalClippingEnabled = false,\n\t\trenderingShadows = false;\n\n\tconst plane = new Plane(),\n\t\tviewNormalMatrix = new Matrix3(),\n\n\t\tuniform = { value: null, needsUpdate: false };\n\n\tthis.uniform = uniform;\n\tthis.numPlanes = 0;\n\tthis.numIntersection = 0;\n\n\tthis.init = function ( planes, enableLocalClipping, camera ) {\n\n\t\tconst enabled =\n\t\t\tplanes.length !== 0 ||\n\t\t\tenableLocalClipping ||\n\t\t\t// enable state of previous frame - the clipping code has to\n\t\t\t// run another frame in order to reset the state:\n\t\t\tnumGlobalPlanes !== 0 ||\n\t\t\tlocalClippingEnabled;\n\n\t\tlocalClippingEnabled = enableLocalClipping;\n\n\t\tglobalState = projectPlanes( planes, camera, 0 );\n\t\tnumGlobalPlanes = planes.length;\n\n\t\treturn enabled;\n\n\t};\n\n\tthis.beginShadows = function () {\n\n\t\trenderingShadows = true;\n\t\tprojectPlanes( null );\n\n\t};\n\n\tthis.endShadows = function () {\n\n\t\trenderingShadows = false;\n\t\tresetGlobalState();\n\n\t};\n\n\tthis.setState = function ( material, camera, useCache ) {\n\n\t\tconst planes = material.clippingPlanes,\n\t\t\tclipIntersection = material.clipIntersection,\n\t\t\tclipShadows = material.clipShadows;\n\n\t\tconst materialProperties = properties.get( material );\n\n\t\tif ( ! localClippingEnabled || planes === null || planes.length === 0 || renderingShadows && ! clipShadows ) {\n\n\t\t\t// there's no local clipping\n\n\t\t\tif ( renderingShadows ) {\n\n\t\t\t\t// there's no global clipping\n\n\t\t\t\tprojectPlanes( null );\n\n\t\t\t} else {\n\n\t\t\t\tresetGlobalState();\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tconst nGlobal = renderingShadows ? 0 : numGlobalPlanes,\n\t\t\t\tlGlobal = nGlobal * 4;\n\n\t\t\tlet dstArray = materialProperties.clippingState || null;\n\n\t\t\tuniform.value = dstArray; // ensure unique state\n\n\t\t\tdstArray = projectPlanes( planes, camera, lGlobal, useCache );\n\n\t\t\tfor ( let i = 0; i !== lGlobal; ++ i ) {\n\n\t\t\t\tdstArray[ i ] = globalState[ i ];\n\n\t\t\t}\n\n\t\t\tmaterialProperties.clippingState = dstArray;\n\t\t\tthis.numIntersection = clipIntersection ? this.numPlanes : 0;\n\t\t\tthis.numPlanes += nGlobal;\n\n\t\t}\n\n\n\t};\n\n\tfunction resetGlobalState() {\n\n\t\tif ( uniform.value !== globalState ) {\n\n\t\t\tuniform.value = globalState;\n\t\t\tuniform.needsUpdate = numGlobalPlanes > 0;\n\n\t\t}\n\n\t\tscope.numPlanes = numGlobalPlanes;\n\t\tscope.numIntersection = 0;\n\n\t}\n\n\tfunction projectPlanes( planes, camera, dstOffset, skipTransform ) {\n\n\t\tconst nPlanes = planes !== null ? planes.length : 0;\n\t\tlet dstArray = null;\n\n\t\tif ( nPlanes !== 0 ) {\n\n\t\t\tdstArray = uniform.value;\n\n\t\t\tif ( skipTransform !== true || dstArray === null ) {\n\n\t\t\t\tconst flatSize = dstOffset + nPlanes * 4,\n\t\t\t\t\tviewMatrix = camera.matrixWorldInverse;\n\n\t\t\t\tviewNormalMatrix.getNormalMatrix( viewMatrix );\n\n\t\t\t\tif ( dstArray === null || dstArray.length < flatSize ) {\n\n\t\t\t\t\tdstArray = new Float32Array( flatSize );\n\n\t\t\t\t}\n\n\t\t\t\tfor ( let i = 0, i4 = dstOffset; i !== nPlanes; ++ i, i4 += 4 ) {\n\n\t\t\t\t\tplane.copy( planes[ i ] ).applyMatrix4( viewMatrix, viewNormalMatrix );\n\n\t\t\t\t\tplane.normal.toArray( dstArray, i4 );\n\t\t\t\t\tdstArray[ i4 + 3 ] = plane.constant;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tuniform.value = dstArray;\n\t\t\tuniform.needsUpdate = true;\n\n\t\t}\n\n\t\tscope.numPlanes = nPlanes;\n\t\tscope.numIntersection = 0;\n\n\t\treturn dstArray;\n\n\t}\n\n}\n\nfunction WebGLCubeMaps( renderer ) {\n\n\tlet cubemaps = new WeakMap();\n\n\tfunction mapTextureMapping( texture, mapping ) {\n\n\t\tif ( mapping === EquirectangularReflectionMapping ) {\n\n\t\t\ttexture.mapping = CubeReflectionMapping;\n\n\t\t} else if ( mapping === EquirectangularRefractionMapping ) {\n\n\t\t\ttexture.mapping = CubeRefractionMapping;\n\n\t\t}\n\n\t\treturn texture;\n\n\t}\n\n\tfunction get( texture ) {\n\n\t\tif ( texture && texture.isTexture && texture.isRenderTargetTexture === false ) {\n\n\t\t\tconst mapping = texture.mapping;\n\n\t\t\tif ( mapping === EquirectangularReflectionMapping || mapping === EquirectangularRefractionMapping ) {\n\n\t\t\t\tif ( cubemaps.has( texture ) ) {\n\n\t\t\t\t\tconst cubemap = cubemaps.get( texture ).texture;\n\t\t\t\t\treturn mapTextureMapping( cubemap, texture.mapping );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconst image = texture.image;\n\n\t\t\t\t\tif ( image && image.height > 0 ) {\n\n\t\t\t\t\t\tconst renderTarget = new WebGLCubeRenderTarget( image.height / 2 );\n\t\t\t\t\t\trenderTarget.fromEquirectangularTexture( renderer, texture );\n\t\t\t\t\t\tcubemaps.set( texture, renderTarget );\n\n\t\t\t\t\t\ttexture.addEventListener( 'dispose', onTextureDispose );\n\n\t\t\t\t\t\treturn mapTextureMapping( renderTarget.texture, texture.mapping );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// image not yet ready. try the conversion next frame\n\n\t\t\t\t\t\treturn null;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn texture;\n\n\t}\n\n\tfunction onTextureDispose( event ) {\n\n\t\tconst texture = event.target;\n\n\t\ttexture.removeEventListener( 'dispose', onTextureDispose );\n\n\t\tconst cubemap = cubemaps.get( texture );\n\n\t\tif ( cubemap !== undefined ) {\n\n\t\t\tcubemaps.delete( texture );\n\t\t\tcubemap.dispose();\n\n\t\t}\n\n\t}\n\n\tfunction dispose() {\n\n\t\tcubemaps = new WeakMap();\n\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tdispose: dispose\n\t};\n\n}\n\nclass OrthographicCamera extends Camera {\n\n\tconstructor( left = - 1, right = 1, top = 1, bottom = - 1, near = 0.1, far = 2000 ) {\n\n\t\tsuper();\n\n\t\tthis.isOrthographicCamera = true;\n\n\t\tthis.type = 'OrthographicCamera';\n\n\t\tthis.zoom = 1;\n\t\tthis.view = null;\n\n\t\tthis.left = left;\n\t\tthis.right = right;\n\t\tthis.top = top;\n\t\tthis.bottom = bottom;\n\n\t\tthis.near = near;\n\t\tthis.far = far;\n\n\t\tthis.updateProjectionMatrix();\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tthis.left = source.left;\n\t\tthis.right = source.right;\n\t\tthis.top = source.top;\n\t\tthis.bottom = source.bottom;\n\t\tthis.near = source.near;\n\t\tthis.far = source.far;\n\n\t\tthis.zoom = source.zoom;\n\t\tthis.view = source.view === null ? null : Object.assign( {}, source.view );\n\n\t\treturn this;\n\n\t}\n\n\tsetViewOffset( fullWidth, fullHeight, x, y, width, height ) {\n\n\t\tif ( this.view === null ) {\n\n\t\t\tthis.view = {\n\t\t\t\tenabled: true,\n\t\t\t\tfullWidth: 1,\n\t\t\t\tfullHeight: 1,\n\t\t\t\toffsetX: 0,\n\t\t\t\toffsetY: 0,\n\t\t\t\twidth: 1,\n\t\t\t\theight: 1\n\t\t\t};\n\n\t\t}\n\n\t\tthis.view.enabled = true;\n\t\tthis.view.fullWidth = fullWidth;\n\t\tthis.view.fullHeight = fullHeight;\n\t\tthis.view.offsetX = x;\n\t\tthis.view.offsetY = y;\n\t\tthis.view.width = width;\n\t\tthis.view.height = height;\n\n\t\tthis.updateProjectionMatrix();\n\n\t}\n\n\tclearViewOffset() {\n\n\t\tif ( this.view !== null ) {\n\n\t\t\tthis.view.enabled = false;\n\n\t\t}\n\n\t\tthis.updateProjectionMatrix();\n\n\t}\n\n\tupdateProjectionMatrix() {\n\n\t\tconst dx = ( this.right - this.left ) / ( 2 * this.zoom );\n\t\tconst dy = ( this.top - this.bottom ) / ( 2 * this.zoom );\n\t\tconst cx = ( this.right + this.left ) / 2;\n\t\tconst cy = ( this.top + this.bottom ) / 2;\n\n\t\tlet left = cx - dx;\n\t\tlet right = cx + dx;\n\t\tlet top = cy + dy;\n\t\tlet bottom = cy - dy;\n\n\t\tif ( this.view !== null && this.view.enabled ) {\n\n\t\t\tconst scaleW = ( this.right - this.left ) / this.view.fullWidth / this.zoom;\n\t\t\tconst scaleH = ( this.top - this.bottom ) / this.view.fullHeight / this.zoom;\n\n\t\t\tleft += scaleW * this.view.offsetX;\n\t\t\tright = left + scaleW * this.view.width;\n\t\t\ttop -= scaleH * this.view.offsetY;\n\t\t\tbottom = top - scaleH * this.view.height;\n\n\t\t}\n\n\t\tthis.projectionMatrix.makeOrthographic( left, right, top, bottom, this.near, this.far );\n\n\t\tthis.projectionMatrixInverse.copy( this.projectionMatrix ).invert();\n\n\t}\n\n\ttoJSON( meta ) {\n\n\t\tconst data = super.toJSON( meta );\n\n\t\tdata.object.zoom = this.zoom;\n\t\tdata.object.left = this.left;\n\t\tdata.object.right = this.right;\n\t\tdata.object.top = this.top;\n\t\tdata.object.bottom = this.bottom;\n\t\tdata.object.near = this.near;\n\t\tdata.object.far = this.far;\n\n\t\tif ( this.view !== null ) data.object.view = Object.assign( {}, this.view );\n\n\t\treturn data;\n\n\t}\n\n}\n\nconst LOD_MIN = 4;\n\n// The standard deviations (radians) associated with the extra mips. These are\n// chosen to approximate a Trowbridge-Reitz distribution function times the\n// geometric shadowing function. These sigma values squared must match the\n// variance #defines in cube_uv_reflection_fragment.glsl.js.\nconst EXTRA_LOD_SIGMA = [ 0.125, 0.215, 0.35, 0.446, 0.526, 0.582 ];\n\n// The maximum length of the blur for loop. Smaller sigmas will use fewer\n// samples and exit early, but not recompile the shader.\nconst MAX_SAMPLES = 20;\n\nconst _flatCamera = /*@__PURE__*/ new OrthographicCamera();\nconst _clearColor = /*@__PURE__*/ new Color();\nlet _oldTarget = null;\n\n// Golden Ratio\nconst PHI = ( 1 + Math.sqrt( 5 ) ) / 2;\nconst INV_PHI = 1 / PHI;\n\n// Vertices of a dodecahedron (except the opposites, which represent the\n// same axis), used as axis directions evenly spread on a sphere.\nconst _axisDirections = [\n\t/*@__PURE__*/ new Vector3( 1, 1, 1 ),\n\t/*@__PURE__*/ new Vector3( - 1, 1, 1 ),\n\t/*@__PURE__*/ new Vector3( 1, 1, - 1 ),\n\t/*@__PURE__*/ new Vector3( - 1, 1, - 1 ),\n\t/*@__PURE__*/ new Vector3( 0, PHI, INV_PHI ),\n\t/*@__PURE__*/ new Vector3( 0, PHI, - INV_PHI ),\n\t/*@__PURE__*/ new Vector3( INV_PHI, 0, PHI ),\n\t/*@__PURE__*/ new Vector3( - INV_PHI, 0, PHI ),\n\t/*@__PURE__*/ new Vector3( PHI, INV_PHI, 0 ),\n\t/*@__PURE__*/ new Vector3( - PHI, INV_PHI, 0 ) ];\n\n/**\n * This class generates a Prefiltered, Mipmapped Radiance Environment Map\n * (PMREM) from a cubeMap environment texture. This allows different levels of\n * blur to be quickly accessed based on material roughness. It is packed into a\n * special CubeUV format that allows us to perform custom interpolation so that\n * we can support nonlinear formats such as RGBE. Unlike a traditional mipmap\n * chain, it only goes down to the LOD_MIN level (above), and then creates extra\n * even more filtered 'mips' at the same LOD_MIN resolution, associated with\n * higher roughness levels. In this way we maintain resolution to smoothly\n * interpolate diffuse lighting while limiting sampling computation.\n *\n * Paper: Fast, Accurate Image-Based Lighting\n * https://drive.google.com/file/d/15y8r_UpKlU9SvV4ILb0C3qCPecS8pvLz/view\n*/\n\nclass PMREMGenerator {\n\n\tconstructor( renderer ) {\n\n\t\tthis._renderer = renderer;\n\t\tthis._pingPongRenderTarget = null;\n\n\t\tthis._lodMax = 0;\n\t\tthis._cubeSize = 0;\n\t\tthis._lodPlanes = [];\n\t\tthis._sizeLods = [];\n\t\tthis._sigmas = [];\n\n\t\tthis._blurMaterial = null;\n\t\tthis._cubemapMaterial = null;\n\t\tthis._equirectMaterial = null;\n\n\t\tthis._compileMaterial( this._blurMaterial );\n\n\t}\n\n\t/**\n\t * Generates a PMREM from a supplied Scene, which can be faster than using an\n\t * image if networking bandwidth is low. Optional sigma specifies a blur radius\n\t * in radians to be applied to the scene before PMREM generation. Optional near\n\t * and far planes ensure the scene is rendered in its entirety (the cubeCamera\n\t * is placed at the origin).\n\t */\n\tfromScene( scene, sigma = 0, near = 0.1, far = 100 ) {\n\n\t\t_oldTarget = this._renderer.getRenderTarget();\n\n\t\tthis._setSize( 256 );\n\n\t\tconst cubeUVRenderTarget = this._allocateTargets();\n\t\tcubeUVRenderTarget.depthBuffer = true;\n\n\t\tthis._sceneToCubeUV( scene, near, far, cubeUVRenderTarget );\n\n\t\tif ( sigma > 0 ) {\n\n\t\t\tthis._blur( cubeUVRenderTarget, 0, 0, sigma );\n\n\t\t}\n\n\t\tthis._applyPMREM( cubeUVRenderTarget );\n\t\tthis._cleanup( cubeUVRenderTarget );\n\n\t\treturn cubeUVRenderTarget;\n\n\t}\n\n\t/**\n\t * Generates a PMREM from an equirectangular texture, which can be either LDR\n\t * or HDR. The ideal input image size is 1k (1024 x 512),\n\t * as this matches best with the 256 x 256 cubemap output.\n\t */\n\tfromEquirectangular( equirectangular, renderTarget = null ) {\n\n\t\treturn this._fromTexture( equirectangular, renderTarget );\n\n\t}\n\n\t/**\n\t * Generates a PMREM from an cubemap texture, which can be either LDR\n\t * or HDR. The ideal input cube size is 256 x 256,\n\t * as this matches best with the 256 x 256 cubemap output.\n\t */\n\tfromCubemap( cubemap, renderTarget = null ) {\n\n\t\treturn this._fromTexture( cubemap, renderTarget );\n\n\t}\n\n\t/**\n\t * Pre-compiles the cubemap shader. You can get faster start-up by invoking this method during\n\t * your texture's network fetch for increased concurrency.\n\t */\n\tcompileCubemapShader() {\n\n\t\tif ( this._cubemapMaterial === null ) {\n\n\t\t\tthis._cubemapMaterial = _getCubemapMaterial();\n\t\t\tthis._compileMaterial( this._cubemapMaterial );\n\n\t\t}\n\n\t}\n\n\t/**\n\t * Pre-compiles the equirectangular shader. You can get faster start-up by invoking this method during\n\t * your texture's network fetch for increased concurrency.\n\t */\n\tcompileEquirectangularShader() {\n\n\t\tif ( this._equirectMaterial === null ) {\n\n\t\t\tthis._equirectMaterial = _getEquirectMaterial();\n\t\t\tthis._compileMaterial( this._equirectMaterial );\n\n\t\t}\n\n\t}\n\n\t/**\n\t * Disposes of the PMREMGenerator's internal memory. Note that PMREMGenerator is a static class,\n\t * so you should not need more than one PMREMGenerator object. If you do, calling dispose() on\n\t * one of them will cause any others to also become unusable.\n\t */\n\tdispose() {\n\n\t\tthis._dispose();\n\n\t\tif ( this._cubemapMaterial !== null ) this._cubemapMaterial.dispose();\n\t\tif ( this._equirectMaterial !== null ) this._equirectMaterial.dispose();\n\n\t}\n\n\t// private interface\n\n\t_setSize( cubeSize ) {\n\n\t\tthis._lodMax = Math.floor( Math.log2( cubeSize ) );\n\t\tthis._cubeSize = Math.pow( 2, this._lodMax );\n\n\t}\n\n\t_dispose() {\n\n\t\tif ( this._blurMaterial !== null ) this._blurMaterial.dispose();\n\n\t\tif ( this._pingPongRenderTarget !== null ) this._pingPongRenderTarget.dispose();\n\n\t\tfor ( let i = 0; i < this._lodPlanes.length; i ++ ) {\n\n\t\t\tthis._lodPlanes[ i ].dispose();\n\n\t\t}\n\n\t}\n\n\t_cleanup( outputTarget ) {\n\n\t\tthis._renderer.setRenderTarget( _oldTarget );\n\t\toutputTarget.scissorTest = false;\n\t\t_setViewport( outputTarget, 0, 0, outputTarget.width, outputTarget.height );\n\n\t}\n\n\t_fromTexture( texture, renderTarget ) {\n\n\t\tif ( texture.mapping === CubeReflectionMapping || texture.mapping === CubeRefractionMapping ) {\n\n\t\t\tthis._setSize( texture.image.length === 0 ? 16 : ( texture.image[ 0 ].width || texture.image[ 0 ].image.width ) );\n\n\t\t} else { // Equirectangular\n\n\t\t\tthis._setSize( texture.image.width / 4 );\n\n\t\t}\n\n\t\t_oldTarget = this._renderer.getRenderTarget();\n\n\t\tconst cubeUVRenderTarget = renderTarget || this._allocateTargets();\n\t\tthis._textureToCubeUV( texture, cubeUVRenderTarget );\n\t\tthis._applyPMREM( cubeUVRenderTarget );\n\t\tthis._cleanup( cubeUVRenderTarget );\n\n\t\treturn cubeUVRenderTarget;\n\n\t}\n\n\t_allocateTargets() {\n\n\t\tconst width = 3 * Math.max( this._cubeSize, 16 * 7 );\n\t\tconst height = 4 * this._cubeSize;\n\n\t\tconst params = {\n\t\t\tmagFilter: LinearFilter,\n\t\t\tminFilter: LinearFilter,\n\t\t\tgenerateMipmaps: false,\n\t\t\ttype: HalfFloatType,\n\t\t\tformat: RGBAFormat,\n\t\t\tencoding: LinearEncoding,\n\t\t\tdepthBuffer: false\n\t\t};\n\n\t\tconst cubeUVRenderTarget = _createRenderTarget( width, height, params );\n\n\t\tif ( this._pingPongRenderTarget === null || this._pingPongRenderTarget.width !== width ) {\n\n\t\t\tif ( this._pingPongRenderTarget !== null ) {\n\n\t\t\t\tthis._dispose();\n\n\t\t\t}\n\n\t\t\tthis._pingPongRenderTarget = _createRenderTarget( width, height, params );\n\n\t\t\tconst { _lodMax } = this;\n\t\t\t( { sizeLods: this._sizeLods, lodPlanes: this._lodPlanes, sigmas: this._sigmas } = _createPlanes( _lodMax ) );\n\n\t\t\tthis._blurMaterial = _getBlurShader( _lodMax, width, height );\n\n\t\t}\n\n\t\treturn cubeUVRenderTarget;\n\n\t}\n\n\t_compileMaterial( material ) {\n\n\t\tconst tmpMesh = new Mesh( this._lodPlanes[ 0 ], material );\n\t\tthis._renderer.compile( tmpMesh, _flatCamera );\n\n\t}\n\n\t_sceneToCubeUV( scene, near, far, cubeUVRenderTarget ) {\n\n\t\tconst fov = 90;\n\t\tconst aspect = 1;\n\t\tconst cubeCamera = new PerspectiveCamera( fov, aspect, near, far );\n\t\tconst upSign = [ 1, - 1, 1, 1, 1, 1 ];\n\t\tconst forwardSign = [ 1, 1, 1, - 1, - 1, - 1 ];\n\t\tconst renderer = this._renderer;\n\n\t\tconst originalAutoClear = renderer.autoClear;\n\t\tconst toneMapping = renderer.toneMapping;\n\t\trenderer.getClearColor( _clearColor );\n\n\t\trenderer.toneMapping = NoToneMapping;\n\t\trenderer.autoClear = false;\n\n\t\tconst backgroundMaterial = new MeshBasicMaterial( {\n\t\t\tname: 'PMREM.Background',\n\t\t\tside: BackSide,\n\t\t\tdepthWrite: false,\n\t\t\tdepthTest: false,\n\t\t} );\n\n\t\tconst backgroundBox = new Mesh( new BoxGeometry(), backgroundMaterial );\n\n\t\tlet useSolidColor = false;\n\t\tconst background = scene.background;\n\n\t\tif ( background ) {\n\n\t\t\tif ( background.isColor ) {\n\n\t\t\t\tbackgroundMaterial.color.copy( background );\n\t\t\t\tscene.background = null;\n\t\t\t\tuseSolidColor = true;\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tbackgroundMaterial.color.copy( _clearColor );\n\t\t\tuseSolidColor = true;\n\n\t\t}\n\n\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\tconst col = i % 3;\n\n\t\t\tif ( col === 0 ) {\n\n\t\t\t\tcubeCamera.up.set( 0, upSign[ i ], 0 );\n\t\t\t\tcubeCamera.lookAt( forwardSign[ i ], 0, 0 );\n\n\t\t\t} else if ( col === 1 ) {\n\n\t\t\t\tcubeCamera.up.set( 0, 0, upSign[ i ] );\n\t\t\t\tcubeCamera.lookAt( 0, forwardSign[ i ], 0 );\n\n\t\t\t} else {\n\n\t\t\t\tcubeCamera.up.set( 0, upSign[ i ], 0 );\n\t\t\t\tcubeCamera.lookAt( 0, 0, forwardSign[ i ] );\n\n\t\t\t}\n\n\t\t\tconst size = this._cubeSize;\n\n\t\t\t_setViewport( cubeUVRenderTarget, col * size, i > 2 ? size : 0, size, size );\n\n\t\t\trenderer.setRenderTarget( cubeUVRenderTarget );\n\n\t\t\tif ( useSolidColor ) {\n\n\t\t\t\trenderer.render( backgroundBox, cubeCamera );\n\n\t\t\t}\n\n\t\t\trenderer.render( scene, cubeCamera );\n\n\t\t}\n\n\t\tbackgroundBox.geometry.dispose();\n\t\tbackgroundBox.material.dispose();\n\n\t\trenderer.toneMapping = toneMapping;\n\t\trenderer.autoClear = originalAutoClear;\n\t\tscene.background = background;\n\n\t}\n\n\t_textureToCubeUV( texture, cubeUVRenderTarget ) {\n\n\t\tconst renderer = this._renderer;\n\n\t\tconst isCubeTexture = ( texture.mapping === CubeReflectionMapping || texture.mapping === CubeRefractionMapping );\n\n\t\tif ( isCubeTexture ) {\n\n\t\t\tif ( this._cubemapMaterial === null ) {\n\n\t\t\t\tthis._cubemapMaterial = _getCubemapMaterial();\n\n\t\t\t}\n\n\t\t\tthis._cubemapMaterial.uniforms.flipEnvMap.value = ( texture.isRenderTargetTexture === false ) ? - 1 : 1;\n\n\t\t} else {\n\n\t\t\tif ( this._equirectMaterial === null ) {\n\n\t\t\t\tthis._equirectMaterial = _getEquirectMaterial();\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst material = isCubeTexture ? this._cubemapMaterial : this._equirectMaterial;\n\t\tconst mesh = new Mesh( this._lodPlanes[ 0 ], material );\n\n\t\tconst uniforms = material.uniforms;\n\n\t\tuniforms[ 'envMap' ].value = texture;\n\n\t\tconst size = this._cubeSize;\n\n\t\t_setViewport( cubeUVRenderTarget, 0, 0, 3 * size, 2 * size );\n\n\t\trenderer.setRenderTarget( cubeUVRenderTarget );\n\t\trenderer.render( mesh, _flatCamera );\n\n\t}\n\n\t_applyPMREM( cubeUVRenderTarget ) {\n\n\t\tconst renderer = this._renderer;\n\t\tconst autoClear = renderer.autoClear;\n\t\trenderer.autoClear = false;\n\n\t\tfor ( let i = 1; i < this._lodPlanes.length; i ++ ) {\n\n\t\t\tconst sigma = Math.sqrt( this._sigmas[ i ] * this._sigmas[ i ] - this._sigmas[ i - 1 ] * this._sigmas[ i - 1 ] );\n\n\t\t\tconst poleAxis = _axisDirections[ ( i - 1 ) % _axisDirections.length ];\n\n\t\t\tthis._blur( cubeUVRenderTarget, i - 1, i, sigma, poleAxis );\n\n\t\t}\n\n\t\trenderer.autoClear = autoClear;\n\n\t}\n\n\t/**\n\t * This is a two-pass Gaussian blur for a cubemap. Normally this is done\n\t * vertically and horizontally, but this breaks down on a cube. Here we apply\n\t * the blur latitudinally (around the poles), and then longitudinally (towards\n\t * the poles) to approximate the orthogonally-separable blur. It is least\n\t * accurate at the poles, but still does a decent job.\n\t */\n\t_blur( cubeUVRenderTarget, lodIn, lodOut, sigma, poleAxis ) {\n\n\t\tconst pingPongRenderTarget = this._pingPongRenderTarget;\n\n\t\tthis._halfBlur(\n\t\t\tcubeUVRenderTarget,\n\t\t\tpingPongRenderTarget,\n\t\t\tlodIn,\n\t\t\tlodOut,\n\t\t\tsigma,\n\t\t\t'latitudinal',\n\t\t\tpoleAxis );\n\n\t\tthis._halfBlur(\n\t\t\tpingPongRenderTarget,\n\t\t\tcubeUVRenderTarget,\n\t\t\tlodOut,\n\t\t\tlodOut,\n\t\t\tsigma,\n\t\t\t'longitudinal',\n\t\t\tpoleAxis );\n\n\t}\n\n\t_halfBlur( targetIn, targetOut, lodIn, lodOut, sigmaRadians, direction, poleAxis ) {\n\n\t\tconst renderer = this._renderer;\n\t\tconst blurMaterial = this._blurMaterial;\n\n\t\tif ( direction !== 'latitudinal' && direction !== 'longitudinal' ) {\n\n\t\t\tconsole.error(\n\t\t\t\t'blur direction must be either latitudinal or longitudinal!' );\n\n\t\t}\n\n\t\t// Number of standard deviations at which to cut off the discrete approximation.\n\t\tconst STANDARD_DEVIATIONS = 3;\n\n\t\tconst blurMesh = new Mesh( this._lodPlanes[ lodOut ], blurMaterial );\n\t\tconst blurUniforms = blurMaterial.uniforms;\n\n\t\tconst pixels = this._sizeLods[ lodIn ] - 1;\n\t\tconst radiansPerPixel = isFinite( sigmaRadians ) ? Math.PI / ( 2 * pixels ) : 2 * Math.PI / ( 2 * MAX_SAMPLES - 1 );\n\t\tconst sigmaPixels = sigmaRadians / radiansPerPixel;\n\t\tconst samples = isFinite( sigmaRadians ) ? 1 + Math.floor( STANDARD_DEVIATIONS * sigmaPixels ) : MAX_SAMPLES;\n\n\t\tif ( samples > MAX_SAMPLES ) {\n\n\t\t\tconsole.warn( `sigmaRadians, ${\n\t\t\t\tsigmaRadians}, is too large and will clip, as it requested ${\n\t\t\t\tsamples} samples when the maximum is set to ${MAX_SAMPLES}` );\n\n\t\t}\n\n\t\tconst weights = [];\n\t\tlet sum = 0;\n\n\t\tfor ( let i = 0; i < MAX_SAMPLES; ++ i ) {\n\n\t\t\tconst x = i / sigmaPixels;\n\t\t\tconst weight = Math.exp( - x * x / 2 );\n\t\t\tweights.push( weight );\n\n\t\t\tif ( i === 0 ) {\n\n\t\t\t\tsum += weight;\n\n\t\t\t} else if ( i < samples ) {\n\n\t\t\t\tsum += 2 * weight;\n\n\t\t\t}\n\n\t\t}\n\n\t\tfor ( let i = 0; i < weights.length; i ++ ) {\n\n\t\t\tweights[ i ] = weights[ i ] / sum;\n\n\t\t}\n\n\t\tblurUniforms[ 'envMap' ].value = targetIn.texture;\n\t\tblurUniforms[ 'samples' ].value = samples;\n\t\tblurUniforms[ 'weights' ].value = weights;\n\t\tblurUniforms[ 'latitudinal' ].value = direction === 'latitudinal';\n\n\t\tif ( poleAxis ) {\n\n\t\t\tblurUniforms[ 'poleAxis' ].value = poleAxis;\n\n\t\t}\n\n\t\tconst { _lodMax } = this;\n\t\tblurUniforms[ 'dTheta' ].value = radiansPerPixel;\n\t\tblurUniforms[ 'mipInt' ].value = _lodMax - lodIn;\n\n\t\tconst outputSize = this._sizeLods[ lodOut ];\n\t\tconst x = 3 * outputSize * ( lodOut > _lodMax - LOD_MIN ? lodOut - _lodMax + LOD_MIN : 0 );\n\t\tconst y = 4 * ( this._cubeSize - outputSize );\n\n\t\t_setViewport( targetOut, x, y, 3 * outputSize, 2 * outputSize );\n\t\trenderer.setRenderTarget( targetOut );\n\t\trenderer.render( blurMesh, _flatCamera );\n\n\t}\n\n}\n\n\n\nfunction _createPlanes( lodMax ) {\n\n\tconst lodPlanes = [];\n\tconst sizeLods = [];\n\tconst sigmas = [];\n\n\tlet lod = lodMax;\n\n\tconst totalLods = lodMax - LOD_MIN + 1 + EXTRA_LOD_SIGMA.length;\n\n\tfor ( let i = 0; i < totalLods; i ++ ) {\n\n\t\tconst sizeLod = Math.pow( 2, lod );\n\t\tsizeLods.push( sizeLod );\n\t\tlet sigma = 1.0 / sizeLod;\n\n\t\tif ( i > lodMax - LOD_MIN ) {\n\n\t\t\tsigma = EXTRA_LOD_SIGMA[ i - lodMax + LOD_MIN - 1 ];\n\n\t\t} else if ( i === 0 ) {\n\n\t\t\tsigma = 0;\n\n\t\t}\n\n\t\tsigmas.push( sigma );\n\n\t\tconst texelSize = 1.0 / ( sizeLod - 2 );\n\t\tconst min = - texelSize;\n\t\tconst max = 1 + texelSize;\n\t\tconst uv1 = [ min, min, max, min, max, max, min, min, max, max, min, max ];\n\n\t\tconst cubeFaces = 6;\n\t\tconst vertices = 6;\n\t\tconst positionSize = 3;\n\t\tconst uvSize = 2;\n\t\tconst faceIndexSize = 1;\n\n\t\tconst position = new Float32Array( positionSize * vertices * cubeFaces );\n\t\tconst uv = new Float32Array( uvSize * vertices * cubeFaces );\n\t\tconst faceIndex = new Float32Array( faceIndexSize * vertices * cubeFaces );\n\n\t\tfor ( let face = 0; face < cubeFaces; face ++ ) {\n\n\t\t\tconst x = ( face % 3 ) * 2 / 3 - 1;\n\t\t\tconst y = face > 2 ? 0 : - 1;\n\t\t\tconst coordinates = [\n\t\t\t\tx, y, 0,\n\t\t\t\tx + 2 / 3, y, 0,\n\t\t\t\tx + 2 / 3, y + 1, 0,\n\t\t\t\tx, y, 0,\n\t\t\t\tx + 2 / 3, y + 1, 0,\n\t\t\t\tx, y + 1, 0\n\t\t\t];\n\t\t\tposition.set( coordinates, positionSize * vertices * face );\n\t\t\tuv.set( uv1, uvSize * vertices * face );\n\t\t\tconst fill = [ face, face, face, face, face, face ];\n\t\t\tfaceIndex.set( fill, faceIndexSize * vertices * face );\n\n\t\t}\n\n\t\tconst planes = new BufferGeometry();\n\t\tplanes.setAttribute( 'position', new BufferAttribute( position, positionSize ) );\n\t\tplanes.setAttribute( 'uv', new BufferAttribute( uv, uvSize ) );\n\t\tplanes.setAttribute( 'faceIndex', new BufferAttribute( faceIndex, faceIndexSize ) );\n\t\tlodPlanes.push( planes );\n\n\t\tif ( lod > LOD_MIN ) {\n\n\t\t\tlod --;\n\n\t\t}\n\n\t}\n\n\treturn { lodPlanes, sizeLods, sigmas };\n\n}\n\nfunction _createRenderTarget( width, height, params ) {\n\n\tconst cubeUVRenderTarget = new WebGLRenderTarget( width, height, params );\n\tcubeUVRenderTarget.texture.mapping = CubeUVReflectionMapping;\n\tcubeUVRenderTarget.texture.name = 'PMREM.cubeUv';\n\tcubeUVRenderTarget.scissorTest = true;\n\treturn cubeUVRenderTarget;\n\n}\n\nfunction _setViewport( target, x, y, width, height ) {\n\n\ttarget.viewport.set( x, y, width, height );\n\ttarget.scissor.set( x, y, width, height );\n\n}\n\nfunction _getBlurShader( lodMax, width, height ) {\n\n\tconst weights = new Float32Array( MAX_SAMPLES );\n\tconst poleAxis = new Vector3( 0, 1, 0 );\n\tconst shaderMaterial = new ShaderMaterial( {\n\n\t\tname: 'SphericalGaussianBlur',\n\n\t\tdefines: {\n\t\t\t'n': MAX_SAMPLES,\n\t\t\t'CUBEUV_TEXEL_WIDTH': 1.0 / width,\n\t\t\t'CUBEUV_TEXEL_HEIGHT': 1.0 / height,\n\t\t\t'CUBEUV_MAX_MIP': `${lodMax}.0`,\n\t\t},\n\n\t\tuniforms: {\n\t\t\t'envMap': { value: null },\n\t\t\t'samples': { value: 1 },\n\t\t\t'weights': { value: weights },\n\t\t\t'latitudinal': { value: false },\n\t\t\t'dTheta': { value: 0 },\n\t\t\t'mipInt': { value: 0 },\n\t\t\t'poleAxis': { value: poleAxis }\n\t\t},\n\n\t\tvertexShader: _getCommonVertexShader(),\n\n\t\tfragmentShader: /* glsl */`\n\n\t\t\tprecision mediump float;\n\t\t\tprecision mediump int;\n\n\t\t\tvarying vec3 vOutputDirection;\n\n\t\t\tuniform sampler2D envMap;\n\t\t\tuniform int samples;\n\t\t\tuniform float weights[ n ];\n\t\t\tuniform bool latitudinal;\n\t\t\tuniform float dTheta;\n\t\t\tuniform float mipInt;\n\t\t\tuniform vec3 poleAxis;\n\n\t\t\t#define ENVMAP_TYPE_CUBE_UV\n\t\t\t#include \n\n\t\t\tvec3 getSample( float theta, vec3 axis ) {\n\n\t\t\t\tfloat cosTheta = cos( theta );\n\t\t\t\t// Rodrigues' axis-angle rotation\n\t\t\t\tvec3 sampleDirection = vOutputDirection * cosTheta\n\t\t\t\t\t+ cross( axis, vOutputDirection ) * sin( theta )\n\t\t\t\t\t+ axis * dot( axis, vOutputDirection ) * ( 1.0 - cosTheta );\n\n\t\t\t\treturn bilinearCubeUV( envMap, sampleDirection, mipInt );\n\n\t\t\t}\n\n\t\t\tvoid main() {\n\n\t\t\t\tvec3 axis = latitudinal ? poleAxis : cross( poleAxis, vOutputDirection );\n\n\t\t\t\tif ( all( equal( axis, vec3( 0.0 ) ) ) ) {\n\n\t\t\t\t\taxis = vec3( vOutputDirection.z, 0.0, - vOutputDirection.x );\n\n\t\t\t\t}\n\n\t\t\t\taxis = normalize( axis );\n\n\t\t\t\tgl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 );\n\t\t\t\tgl_FragColor.rgb += weights[ 0 ] * getSample( 0.0, axis );\n\n\t\t\t\tfor ( int i = 1; i < n; i++ ) {\n\n\t\t\t\t\tif ( i >= samples ) {\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tfloat theta = dTheta * float( i );\n\t\t\t\t\tgl_FragColor.rgb += weights[ i ] * getSample( -1.0 * theta, axis );\n\t\t\t\t\tgl_FragColor.rgb += weights[ i ] * getSample( theta, axis );\n\n\t\t\t\t}\n\n\t\t\t}\n\t\t`,\n\n\t\tblending: NoBlending,\n\t\tdepthTest: false,\n\t\tdepthWrite: false\n\n\t} );\n\n\treturn shaderMaterial;\n\n}\n\nfunction _getEquirectMaterial() {\n\n\treturn new ShaderMaterial( {\n\n\t\tname: 'EquirectangularToCubeUV',\n\n\t\tuniforms: {\n\t\t\t'envMap': { value: null }\n\t\t},\n\n\t\tvertexShader: _getCommonVertexShader(),\n\n\t\tfragmentShader: /* glsl */`\n\n\t\t\tprecision mediump float;\n\t\t\tprecision mediump int;\n\n\t\t\tvarying vec3 vOutputDirection;\n\n\t\t\tuniform sampler2D envMap;\n\n\t\t\t#include \n\n\t\t\tvoid main() {\n\n\t\t\t\tvec3 outputDirection = normalize( vOutputDirection );\n\t\t\t\tvec2 uv = equirectUv( outputDirection );\n\n\t\t\t\tgl_FragColor = vec4( texture2D ( envMap, uv ).rgb, 1.0 );\n\n\t\t\t}\n\t\t`,\n\n\t\tblending: NoBlending,\n\t\tdepthTest: false,\n\t\tdepthWrite: false\n\n\t} );\n\n}\n\nfunction _getCubemapMaterial() {\n\n\treturn new ShaderMaterial( {\n\n\t\tname: 'CubemapToCubeUV',\n\n\t\tuniforms: {\n\t\t\t'envMap': { value: null },\n\t\t\t'flipEnvMap': { value: - 1 }\n\t\t},\n\n\t\tvertexShader: _getCommonVertexShader(),\n\n\t\tfragmentShader: /* glsl */`\n\n\t\t\tprecision mediump float;\n\t\t\tprecision mediump int;\n\n\t\t\tuniform float flipEnvMap;\n\n\t\t\tvarying vec3 vOutputDirection;\n\n\t\t\tuniform samplerCube envMap;\n\n\t\t\tvoid main() {\n\n\t\t\t\tgl_FragColor = textureCube( envMap, vec3( flipEnvMap * vOutputDirection.x, vOutputDirection.yz ) );\n\n\t\t\t}\n\t\t`,\n\n\t\tblending: NoBlending,\n\t\tdepthTest: false,\n\t\tdepthWrite: false\n\n\t} );\n\n}\n\nfunction _getCommonVertexShader() {\n\n\treturn /* glsl */`\n\n\t\tprecision mediump float;\n\t\tprecision mediump int;\n\n\t\tattribute float faceIndex;\n\n\t\tvarying vec3 vOutputDirection;\n\n\t\t// RH coordinate system; PMREM face-indexing convention\n\t\tvec3 getDirection( vec2 uv, float face ) {\n\n\t\t\tuv = 2.0 * uv - 1.0;\n\n\t\t\tvec3 direction = vec3( uv, 1.0 );\n\n\t\t\tif ( face == 0.0 ) {\n\n\t\t\t\tdirection = direction.zyx; // ( 1, v, u ) pos x\n\n\t\t\t} else if ( face == 1.0 ) {\n\n\t\t\t\tdirection = direction.xzy;\n\t\t\t\tdirection.xz *= -1.0; // ( -u, 1, -v ) pos y\n\n\t\t\t} else if ( face == 2.0 ) {\n\n\t\t\t\tdirection.x *= -1.0; // ( -u, v, 1 ) pos z\n\n\t\t\t} else if ( face == 3.0 ) {\n\n\t\t\t\tdirection = direction.zyx;\n\t\t\t\tdirection.xz *= -1.0; // ( -1, v, -u ) neg x\n\n\t\t\t} else if ( face == 4.0 ) {\n\n\t\t\t\tdirection = direction.xzy;\n\t\t\t\tdirection.xy *= -1.0; // ( -u, -1, v ) neg y\n\n\t\t\t} else if ( face == 5.0 ) {\n\n\t\t\t\tdirection.z *= -1.0; // ( u, v, -1 ) neg z\n\n\t\t\t}\n\n\t\t\treturn direction;\n\n\t\t}\n\n\t\tvoid main() {\n\n\t\t\tvOutputDirection = getDirection( uv, faceIndex );\n\t\t\tgl_Position = vec4( position, 1.0 );\n\n\t\t}\n\t`;\n\n}\n\nfunction WebGLCubeUVMaps( renderer ) {\n\n\tlet cubeUVmaps = new WeakMap();\n\n\tlet pmremGenerator = null;\n\n\tfunction get( texture ) {\n\n\t\tif ( texture && texture.isTexture ) {\n\n\t\t\tconst mapping = texture.mapping;\n\n\t\t\tconst isEquirectMap = ( mapping === EquirectangularReflectionMapping || mapping === EquirectangularRefractionMapping );\n\t\t\tconst isCubeMap = ( mapping === CubeReflectionMapping || mapping === CubeRefractionMapping );\n\n\t\t\t// equirect/cube map to cubeUV conversion\n\n\t\t\tif ( isEquirectMap || isCubeMap ) {\n\n\t\t\t\tif ( texture.isRenderTargetTexture && texture.needsPMREMUpdate === true ) {\n\n\t\t\t\t\ttexture.needsPMREMUpdate = false;\n\n\t\t\t\t\tlet renderTarget = cubeUVmaps.get( texture );\n\n\t\t\t\t\tif ( pmremGenerator === null ) pmremGenerator = new PMREMGenerator( renderer );\n\n\t\t\t\t\trenderTarget = isEquirectMap ? pmremGenerator.fromEquirectangular( texture, renderTarget ) : pmremGenerator.fromCubemap( texture, renderTarget );\n\t\t\t\t\tcubeUVmaps.set( texture, renderTarget );\n\n\t\t\t\t\treturn renderTarget.texture;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tif ( cubeUVmaps.has( texture ) ) {\n\n\t\t\t\t\t\treturn cubeUVmaps.get( texture ).texture;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tconst image = texture.image;\n\n\t\t\t\t\t\tif ( ( isEquirectMap && image && image.height > 0 ) || ( isCubeMap && image && isCubeTextureComplete( image ) ) ) {\n\n\t\t\t\t\t\t\tif ( pmremGenerator === null ) pmremGenerator = new PMREMGenerator( renderer );\n\n\t\t\t\t\t\t\tconst renderTarget = isEquirectMap ? pmremGenerator.fromEquirectangular( texture ) : pmremGenerator.fromCubemap( texture );\n\t\t\t\t\t\t\tcubeUVmaps.set( texture, renderTarget );\n\n\t\t\t\t\t\t\ttexture.addEventListener( 'dispose', onTextureDispose );\n\n\t\t\t\t\t\t\treturn renderTarget.texture;\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t// image not yet ready. try the conversion next frame\n\n\t\t\t\t\t\t\treturn null;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn texture;\n\n\t}\n\n\tfunction isCubeTextureComplete( image ) {\n\n\t\tlet count = 0;\n\t\tconst length = 6;\n\n\t\tfor ( let i = 0; i < length; i ++ ) {\n\n\t\t\tif ( image[ i ] !== undefined ) count ++;\n\n\t\t}\n\n\t\treturn count === length;\n\n\n\t}\n\n\tfunction onTextureDispose( event ) {\n\n\t\tconst texture = event.target;\n\n\t\ttexture.removeEventListener( 'dispose', onTextureDispose );\n\n\t\tconst cubemapUV = cubeUVmaps.get( texture );\n\n\t\tif ( cubemapUV !== undefined ) {\n\n\t\t\tcubeUVmaps.delete( texture );\n\t\t\tcubemapUV.dispose();\n\n\t\t}\n\n\t}\n\n\tfunction dispose() {\n\n\t\tcubeUVmaps = new WeakMap();\n\n\t\tif ( pmremGenerator !== null ) {\n\n\t\t\tpmremGenerator.dispose();\n\t\t\tpmremGenerator = null;\n\n\t\t}\n\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tdispose: dispose\n\t};\n\n}\n\nfunction WebGLExtensions( gl ) {\n\n\tconst extensions = {};\n\n\tfunction getExtension( name ) {\n\n\t\tif ( extensions[ name ] !== undefined ) {\n\n\t\t\treturn extensions[ name ];\n\n\t\t}\n\n\t\tlet extension;\n\n\t\tswitch ( name ) {\n\n\t\t\tcase 'WEBGL_depth_texture':\n\t\t\t\textension = gl.getExtension( 'WEBGL_depth_texture' ) || gl.getExtension( 'MOZ_WEBGL_depth_texture' ) || gl.getExtension( 'WEBKIT_WEBGL_depth_texture' );\n\t\t\t\tbreak;\n\n\t\t\tcase 'EXT_texture_filter_anisotropic':\n\t\t\t\textension = gl.getExtension( 'EXT_texture_filter_anisotropic' ) || gl.getExtension( 'MOZ_EXT_texture_filter_anisotropic' ) || gl.getExtension( 'WEBKIT_EXT_texture_filter_anisotropic' );\n\t\t\t\tbreak;\n\n\t\t\tcase 'WEBGL_compressed_texture_s3tc':\n\t\t\t\textension = gl.getExtension( 'WEBGL_compressed_texture_s3tc' ) || gl.getExtension( 'MOZ_WEBGL_compressed_texture_s3tc' ) || gl.getExtension( 'WEBKIT_WEBGL_compressed_texture_s3tc' );\n\t\t\t\tbreak;\n\n\t\t\tcase 'WEBGL_compressed_texture_pvrtc':\n\t\t\t\textension = gl.getExtension( 'WEBGL_compressed_texture_pvrtc' ) || gl.getExtension( 'WEBKIT_WEBGL_compressed_texture_pvrtc' );\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\textension = gl.getExtension( name );\n\n\t\t}\n\n\t\textensions[ name ] = extension;\n\n\t\treturn extension;\n\n\t}\n\n\treturn {\n\n\t\thas: function ( name ) {\n\n\t\t\treturn getExtension( name ) !== null;\n\n\t\t},\n\n\t\tinit: function ( capabilities ) {\n\n\t\t\tif ( capabilities.isWebGL2 ) {\n\n\t\t\t\tgetExtension( 'EXT_color_buffer_float' );\n\n\t\t\t} else {\n\n\t\t\t\tgetExtension( 'WEBGL_depth_texture' );\n\t\t\t\tgetExtension( 'OES_texture_float' );\n\t\t\t\tgetExtension( 'OES_texture_half_float' );\n\t\t\t\tgetExtension( 'OES_texture_half_float_linear' );\n\t\t\t\tgetExtension( 'OES_standard_derivatives' );\n\t\t\t\tgetExtension( 'OES_element_index_uint' );\n\t\t\t\tgetExtension( 'OES_vertex_array_object' );\n\t\t\t\tgetExtension( 'ANGLE_instanced_arrays' );\n\n\t\t\t}\n\n\t\t\tgetExtension( 'OES_texture_float_linear' );\n\t\t\tgetExtension( 'EXT_color_buffer_half_float' );\n\t\t\tgetExtension( 'WEBGL_multisampled_render_to_texture' );\n\n\t\t},\n\n\t\tget: function ( name ) {\n\n\t\t\tconst extension = getExtension( name );\n\n\t\t\tif ( extension === null ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: ' + name + ' extension not supported.' );\n\n\t\t\t}\n\n\t\t\treturn extension;\n\n\t\t}\n\n\t};\n\n}\n\nfunction WebGLGeometries( gl, attributes, info, bindingStates ) {\n\n\tconst geometries = {};\n\tconst wireframeAttributes = new WeakMap();\n\n\tfunction onGeometryDispose( event ) {\n\n\t\tconst geometry = event.target;\n\n\t\tif ( geometry.index !== null ) {\n\n\t\t\tattributes.remove( geometry.index );\n\n\t\t}\n\n\t\tfor ( const name in geometry.attributes ) {\n\n\t\t\tattributes.remove( geometry.attributes[ name ] );\n\n\t\t}\n\n\t\tgeometry.removeEventListener( 'dispose', onGeometryDispose );\n\n\t\tdelete geometries[ geometry.id ];\n\n\t\tconst attribute = wireframeAttributes.get( geometry );\n\n\t\tif ( attribute ) {\n\n\t\t\tattributes.remove( attribute );\n\t\t\twireframeAttributes.delete( geometry );\n\n\t\t}\n\n\t\tbindingStates.releaseStatesOfGeometry( geometry );\n\n\t\tif ( geometry.isInstancedBufferGeometry === true ) {\n\n\t\t\tdelete geometry._maxInstanceCount;\n\n\t\t}\n\n\t\t//\n\n\t\tinfo.memory.geometries --;\n\n\t}\n\n\tfunction get( object, geometry ) {\n\n\t\tif ( geometries[ geometry.id ] === true ) return geometry;\n\n\t\tgeometry.addEventListener( 'dispose', onGeometryDispose );\n\n\t\tgeometries[ geometry.id ] = true;\n\n\t\tinfo.memory.geometries ++;\n\n\t\treturn geometry;\n\n\t}\n\n\tfunction update( geometry ) {\n\n\t\tconst geometryAttributes = geometry.attributes;\n\n\t\t// Updating index buffer in VAO now. See WebGLBindingStates.\n\n\t\tfor ( const name in geometryAttributes ) {\n\n\t\t\tattributes.update( geometryAttributes[ name ], 34962 );\n\n\t\t}\n\n\t\t// morph targets\n\n\t\tconst morphAttributes = geometry.morphAttributes;\n\n\t\tfor ( const name in morphAttributes ) {\n\n\t\t\tconst array = morphAttributes[ name ];\n\n\t\t\tfor ( let i = 0, l = array.length; i < l; i ++ ) {\n\n\t\t\t\tattributes.update( array[ i ], 34962 );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction updateWireframeAttribute( geometry ) {\n\n\t\tconst indices = [];\n\n\t\tconst geometryIndex = geometry.index;\n\t\tconst geometryPosition = geometry.attributes.position;\n\t\tlet version = 0;\n\n\t\tif ( geometryIndex !== null ) {\n\n\t\t\tconst array = geometryIndex.array;\n\t\t\tversion = geometryIndex.version;\n\n\t\t\tfor ( let i = 0, l = array.length; i < l; i += 3 ) {\n\n\t\t\t\tconst a = array[ i + 0 ];\n\t\t\t\tconst b = array[ i + 1 ];\n\t\t\t\tconst c = array[ i + 2 ];\n\n\t\t\t\tindices.push( a, b, b, c, c, a );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tconst array = geometryPosition.array;\n\t\t\tversion = geometryPosition.version;\n\n\t\t\tfor ( let i = 0, l = ( array.length / 3 ) - 1; i < l; i += 3 ) {\n\n\t\t\t\tconst a = i + 0;\n\t\t\t\tconst b = i + 1;\n\t\t\t\tconst c = i + 2;\n\n\t\t\t\tindices.push( a, b, b, c, c, a );\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst attribute = new ( arrayNeedsUint32( indices ) ? Uint32BufferAttribute : Uint16BufferAttribute )( indices, 1 );\n\t\tattribute.version = version;\n\n\t\t// Updating index buffer in VAO now. See WebGLBindingStates\n\n\t\t//\n\n\t\tconst previousAttribute = wireframeAttributes.get( geometry );\n\n\t\tif ( previousAttribute ) attributes.remove( previousAttribute );\n\n\t\t//\n\n\t\twireframeAttributes.set( geometry, attribute );\n\n\t}\n\n\tfunction getWireframeAttribute( geometry ) {\n\n\t\tconst currentAttribute = wireframeAttributes.get( geometry );\n\n\t\tif ( currentAttribute ) {\n\n\t\t\tconst geometryIndex = geometry.index;\n\n\t\t\tif ( geometryIndex !== null ) {\n\n\t\t\t\t// if the attribute is obsolete, create a new one\n\n\t\t\t\tif ( currentAttribute.version < geometryIndex.version ) {\n\n\t\t\t\t\tupdateWireframeAttribute( geometry );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tupdateWireframeAttribute( geometry );\n\n\t\t}\n\n\t\treturn wireframeAttributes.get( geometry );\n\n\t}\n\n\treturn {\n\n\t\tget: get,\n\t\tupdate: update,\n\n\t\tgetWireframeAttribute: getWireframeAttribute\n\n\t};\n\n}\n\nfunction WebGLIndexedBufferRenderer( gl, extensions, info, capabilities ) {\n\n\tconst isWebGL2 = capabilities.isWebGL2;\n\n\tlet mode;\n\n\tfunction setMode( value ) {\n\n\t\tmode = value;\n\n\t}\n\n\tlet type, bytesPerElement;\n\n\tfunction setIndex( value ) {\n\n\t\ttype = value.type;\n\t\tbytesPerElement = value.bytesPerElement;\n\n\t}\n\n\tfunction render( start, count ) {\n\n\t\tgl.drawElements( mode, count, type, start * bytesPerElement );\n\n\t\tinfo.update( count, mode, 1 );\n\n\t}\n\n\tfunction renderInstances( start, count, primcount ) {\n\n\t\tif ( primcount === 0 ) return;\n\n\t\tlet extension, methodName;\n\n\t\tif ( isWebGL2 ) {\n\n\t\t\textension = gl;\n\t\t\tmethodName = 'drawElementsInstanced';\n\n\t\t} else {\n\n\t\t\textension = extensions.get( 'ANGLE_instanced_arrays' );\n\t\t\tmethodName = 'drawElementsInstancedANGLE';\n\n\t\t\tif ( extension === null ) {\n\n\t\t\t\tconsole.error( 'THREE.WebGLIndexedBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.' );\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t}\n\n\t\textension[ methodName ]( mode, count, type, start * bytesPerElement, primcount );\n\n\t\tinfo.update( count, mode, primcount );\n\n\t}\n\n\t//\n\n\tthis.setMode = setMode;\n\tthis.setIndex = setIndex;\n\tthis.render = render;\n\tthis.renderInstances = renderInstances;\n\n}\n\nfunction WebGLInfo( gl ) {\n\n\tconst memory = {\n\t\tgeometries: 0,\n\t\ttextures: 0\n\t};\n\n\tconst render = {\n\t\tframe: 0,\n\t\tcalls: 0,\n\t\ttriangles: 0,\n\t\tpoints: 0,\n\t\tlines: 0\n\t};\n\n\tfunction update( count, mode, instanceCount ) {\n\n\t\trender.calls ++;\n\n\t\tswitch ( mode ) {\n\n\t\t\tcase 4:\n\t\t\t\trender.triangles += instanceCount * ( count / 3 );\n\t\t\t\tbreak;\n\n\t\t\tcase 1:\n\t\t\t\trender.lines += instanceCount * ( count / 2 );\n\t\t\t\tbreak;\n\n\t\t\tcase 3:\n\t\t\t\trender.lines += instanceCount * ( count - 1 );\n\t\t\t\tbreak;\n\n\t\t\tcase 2:\n\t\t\t\trender.lines += instanceCount * count;\n\t\t\t\tbreak;\n\n\t\t\tcase 0:\n\t\t\t\trender.points += instanceCount * count;\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tconsole.error( 'THREE.WebGLInfo: Unknown draw mode:', mode );\n\t\t\t\tbreak;\n\n\t\t}\n\n\t}\n\n\tfunction reset() {\n\n\t\trender.frame ++;\n\t\trender.calls = 0;\n\t\trender.triangles = 0;\n\t\trender.points = 0;\n\t\trender.lines = 0;\n\n\t}\n\n\treturn {\n\t\tmemory: memory,\n\t\trender: render,\n\t\tprograms: null,\n\t\tautoReset: true,\n\t\treset: reset,\n\t\tupdate: update\n\t};\n\n}\n\nfunction numericalSort( a, b ) {\n\n\treturn a[ 0 ] - b[ 0 ];\n\n}\n\nfunction absNumericalSort( a, b ) {\n\n\treturn Math.abs( b[ 1 ] ) - Math.abs( a[ 1 ] );\n\n}\n\nfunction denormalize( morph, attribute ) {\n\n\tlet denominator = 1;\n\tconst array = attribute.isInterleavedBufferAttribute ? attribute.data.array : attribute.array;\n\n\tif ( array instanceof Int8Array ) denominator = 127;\n\telse if ( array instanceof Int16Array ) denominator = 32767;\n\telse if ( array instanceof Int32Array ) denominator = 2147483647;\n\telse console.error( 'THREE.WebGLMorphtargets: Unsupported morph attribute data type: ', array );\n\n\tmorph.divideScalar( denominator );\n\n}\n\nfunction WebGLMorphtargets( gl, capabilities, textures ) {\n\n\tconst influencesList = {};\n\tconst morphInfluences = new Float32Array( 8 );\n\tconst morphTextures = new WeakMap();\n\tconst morph = new Vector4();\n\n\tconst workInfluences = [];\n\n\tfor ( let i = 0; i < 8; i ++ ) {\n\n\t\tworkInfluences[ i ] = [ i, 0 ];\n\n\t}\n\n\tfunction update( object, geometry, material, program ) {\n\n\t\tconst objectInfluences = object.morphTargetInfluences;\n\n\t\tif ( capabilities.isWebGL2 === true ) {\n\n\t\t\t// instead of using attributes, the WebGL 2 code path encodes morph targets\n\t\t\t// into an array of data textures. Each layer represents a single morph target.\n\n\t\t\tconst morphAttribute = geometry.morphAttributes.position || geometry.morphAttributes.normal || geometry.morphAttributes.color;\n\t\t\tconst morphTargetsCount = ( morphAttribute !== undefined ) ? morphAttribute.length : 0;\n\n\t\t\tlet entry = morphTextures.get( geometry );\n\n\t\t\tif ( entry === undefined || entry.count !== morphTargetsCount ) {\n\n\t\t\t\tif ( entry !== undefined ) entry.texture.dispose();\n\n\t\t\t\tconst hasMorphPosition = geometry.morphAttributes.position !== undefined;\n\t\t\t\tconst hasMorphNormals = geometry.morphAttributes.normal !== undefined;\n\t\t\t\tconst hasMorphColors = geometry.morphAttributes.color !== undefined;\n\n\t\t\t\tconst morphTargets = geometry.morphAttributes.position || [];\n\t\t\t\tconst morphNormals = geometry.morphAttributes.normal || [];\n\t\t\t\tconst morphColors = geometry.morphAttributes.color || [];\n\n\t\t\t\tlet vertexDataCount = 0;\n\n\t\t\t\tif ( hasMorphPosition === true ) vertexDataCount = 1;\n\t\t\t\tif ( hasMorphNormals === true ) vertexDataCount = 2;\n\t\t\t\tif ( hasMorphColors === true ) vertexDataCount = 3;\n\n\t\t\t\tlet width = geometry.attributes.position.count * vertexDataCount;\n\t\t\t\tlet height = 1;\n\n\t\t\t\tif ( width > capabilities.maxTextureSize ) {\n\n\t\t\t\t\theight = Math.ceil( width / capabilities.maxTextureSize );\n\t\t\t\t\twidth = capabilities.maxTextureSize;\n\n\t\t\t\t}\n\n\t\t\t\tconst buffer = new Float32Array( width * height * 4 * morphTargetsCount );\n\n\t\t\t\tconst texture = new DataArrayTexture( buffer, width, height, morphTargetsCount );\n\t\t\t\ttexture.type = FloatType;\n\t\t\t\ttexture.needsUpdate = true;\n\n\t\t\t\t// fill buffer\n\n\t\t\t\tconst vertexDataStride = vertexDataCount * 4;\n\n\t\t\t\tfor ( let i = 0; i < morphTargetsCount; i ++ ) {\n\n\t\t\t\t\tconst morphTarget = morphTargets[ i ];\n\t\t\t\t\tconst morphNormal = morphNormals[ i ];\n\t\t\t\t\tconst morphColor = morphColors[ i ];\n\n\t\t\t\t\tconst offset = width * height * 4 * i;\n\n\t\t\t\t\tfor ( let j = 0; j < morphTarget.count; j ++ ) {\n\n\t\t\t\t\t\tconst stride = j * vertexDataStride;\n\n\t\t\t\t\t\tif ( hasMorphPosition === true ) {\n\n\t\t\t\t\t\t\tmorph.fromBufferAttribute( morphTarget, j );\n\n\t\t\t\t\t\t\tif ( morphTarget.normalized === true ) denormalize( morph, morphTarget );\n\n\t\t\t\t\t\t\tbuffer[ offset + stride + 0 ] = morph.x;\n\t\t\t\t\t\t\tbuffer[ offset + stride + 1 ] = morph.y;\n\t\t\t\t\t\t\tbuffer[ offset + stride + 2 ] = morph.z;\n\t\t\t\t\t\t\tbuffer[ offset + stride + 3 ] = 0;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif ( hasMorphNormals === true ) {\n\n\t\t\t\t\t\t\tmorph.fromBufferAttribute( morphNormal, j );\n\n\t\t\t\t\t\t\tif ( morphNormal.normalized === true ) denormalize( morph, morphNormal );\n\n\t\t\t\t\t\t\tbuffer[ offset + stride + 4 ] = morph.x;\n\t\t\t\t\t\t\tbuffer[ offset + stride + 5 ] = morph.y;\n\t\t\t\t\t\t\tbuffer[ offset + stride + 6 ] = morph.z;\n\t\t\t\t\t\t\tbuffer[ offset + stride + 7 ] = 0;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif ( hasMorphColors === true ) {\n\n\t\t\t\t\t\t\tmorph.fromBufferAttribute( morphColor, j );\n\n\t\t\t\t\t\t\tif ( morphColor.normalized === true ) denormalize( morph, morphColor );\n\n\t\t\t\t\t\t\tbuffer[ offset + stride + 8 ] = morph.x;\n\t\t\t\t\t\t\tbuffer[ offset + stride + 9 ] = morph.y;\n\t\t\t\t\t\t\tbuffer[ offset + stride + 10 ] = morph.z;\n\t\t\t\t\t\t\tbuffer[ offset + stride + 11 ] = ( morphColor.itemSize === 4 ) ? morph.w : 1;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tentry = {\n\t\t\t\t\tcount: morphTargetsCount,\n\t\t\t\t\ttexture: texture,\n\t\t\t\t\tsize: new Vector2( width, height )\n\t\t\t\t};\n\n\t\t\t\tmorphTextures.set( geometry, entry );\n\n\t\t\t\tfunction disposeTexture() {\n\n\t\t\t\t\ttexture.dispose();\n\n\t\t\t\t\tmorphTextures.delete( geometry );\n\n\t\t\t\t\tgeometry.removeEventListener( 'dispose', disposeTexture );\n\n\t\t\t\t}\n\n\t\t\t\tgeometry.addEventListener( 'dispose', disposeTexture );\n\n\t\t\t}\n\n\t\t\t//\n\n\t\t\tlet morphInfluencesSum = 0;\n\n\t\t\tfor ( let i = 0; i < objectInfluences.length; i ++ ) {\n\n\t\t\t\tmorphInfluencesSum += objectInfluences[ i ];\n\n\t\t\t}\n\n\t\t\tconst morphBaseInfluence = geometry.morphTargetsRelative ? 1 : 1 - morphInfluencesSum;\n\n\t\t\tprogram.getUniforms().setValue( gl, 'morphTargetBaseInfluence', morphBaseInfluence );\n\t\t\tprogram.getUniforms().setValue( gl, 'morphTargetInfluences', objectInfluences );\n\n\t\t\tprogram.getUniforms().setValue( gl, 'morphTargetsTexture', entry.texture, textures );\n\t\t\tprogram.getUniforms().setValue( gl, 'morphTargetsTextureSize', entry.size );\n\n\n\t\t} else {\n\n\t\t\t// When object doesn't have morph target influences defined, we treat it as a 0-length array\n\t\t\t// This is important to make sure we set up morphTargetBaseInfluence / morphTargetInfluences\n\n\t\t\tconst length = objectInfluences === undefined ? 0 : objectInfluences.length;\n\n\t\t\tlet influences = influencesList[ geometry.id ];\n\n\t\t\tif ( influences === undefined || influences.length !== length ) {\n\n\t\t\t\t// initialise list\n\n\t\t\t\tinfluences = [];\n\n\t\t\t\tfor ( let i = 0; i < length; i ++ ) {\n\n\t\t\t\t\tinfluences[ i ] = [ i, 0 ];\n\n\t\t\t\t}\n\n\t\t\t\tinfluencesList[ geometry.id ] = influences;\n\n\t\t\t}\n\n\t\t\t// Collect influences\n\n\t\t\tfor ( let i = 0; i < length; i ++ ) {\n\n\t\t\t\tconst influence = influences[ i ];\n\n\t\t\t\tinfluence[ 0 ] = i;\n\t\t\t\tinfluence[ 1 ] = objectInfluences[ i ];\n\n\t\t\t}\n\n\t\t\tinfluences.sort( absNumericalSort );\n\n\t\t\tfor ( let i = 0; i < 8; i ++ ) {\n\n\t\t\t\tif ( i < length && influences[ i ][ 1 ] ) {\n\n\t\t\t\t\tworkInfluences[ i ][ 0 ] = influences[ i ][ 0 ];\n\t\t\t\t\tworkInfluences[ i ][ 1 ] = influences[ i ][ 1 ];\n\n\t\t\t\t} else {\n\n\t\t\t\t\tworkInfluences[ i ][ 0 ] = Number.MAX_SAFE_INTEGER;\n\t\t\t\t\tworkInfluences[ i ][ 1 ] = 0;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tworkInfluences.sort( numericalSort );\n\n\t\t\tconst morphTargets = geometry.morphAttributes.position;\n\t\t\tconst morphNormals = geometry.morphAttributes.normal;\n\n\t\t\tlet morphInfluencesSum = 0;\n\n\t\t\tfor ( let i = 0; i < 8; i ++ ) {\n\n\t\t\t\tconst influence = workInfluences[ i ];\n\t\t\t\tconst index = influence[ 0 ];\n\t\t\t\tconst value = influence[ 1 ];\n\n\t\t\t\tif ( index !== Number.MAX_SAFE_INTEGER && value ) {\n\n\t\t\t\t\tif ( morphTargets && geometry.getAttribute( 'morphTarget' + i ) !== morphTargets[ index ] ) {\n\n\t\t\t\t\t\tgeometry.setAttribute( 'morphTarget' + i, morphTargets[ index ] );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( morphNormals && geometry.getAttribute( 'morphNormal' + i ) !== morphNormals[ index ] ) {\n\n\t\t\t\t\t\tgeometry.setAttribute( 'morphNormal' + i, morphNormals[ index ] );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tmorphInfluences[ i ] = value;\n\t\t\t\t\tmorphInfluencesSum += value;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tif ( morphTargets && geometry.hasAttribute( 'morphTarget' + i ) === true ) {\n\n\t\t\t\t\t\tgeometry.deleteAttribute( 'morphTarget' + i );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( morphNormals && geometry.hasAttribute( 'morphNormal' + i ) === true ) {\n\n\t\t\t\t\t\tgeometry.deleteAttribute( 'morphNormal' + i );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tmorphInfluences[ i ] = 0;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// GLSL shader uses formula baseinfluence * base + sum(target * influence)\n\t\t\t// This allows us to switch between absolute morphs and relative morphs without changing shader code\n\t\t\t// When baseinfluence = 1 - sum(influence), the above is equivalent to sum((target - base) * influence)\n\t\t\tconst morphBaseInfluence = geometry.morphTargetsRelative ? 1 : 1 - morphInfluencesSum;\n\n\t\t\tprogram.getUniforms().setValue( gl, 'morphTargetBaseInfluence', morphBaseInfluence );\n\t\t\tprogram.getUniforms().setValue( gl, 'morphTargetInfluences', morphInfluences );\n\n\t\t}\n\n\t}\n\n\treturn {\n\n\t\tupdate: update\n\n\t};\n\n}\n\nfunction WebGLObjects( gl, geometries, attributes, info ) {\n\n\tlet updateMap = new WeakMap();\n\n\tfunction update( object ) {\n\n\t\tconst frame = info.render.frame;\n\n\t\tconst geometry = object.geometry;\n\t\tconst buffergeometry = geometries.get( object, geometry );\n\n\t\t// Update once per frame\n\n\t\tif ( updateMap.get( buffergeometry ) !== frame ) {\n\n\t\t\tgeometries.update( buffergeometry );\n\n\t\t\tupdateMap.set( buffergeometry, frame );\n\n\t\t}\n\n\t\tif ( object.isInstancedMesh ) {\n\n\t\t\tif ( object.hasEventListener( 'dispose', onInstancedMeshDispose ) === false ) {\n\n\t\t\t\tobject.addEventListener( 'dispose', onInstancedMeshDispose );\n\n\t\t\t}\n\n\t\t\tattributes.update( object.instanceMatrix, 34962 );\n\n\t\t\tif ( object.instanceColor !== null ) {\n\n\t\t\t\tattributes.update( object.instanceColor, 34962 );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn buffergeometry;\n\n\t}\n\n\tfunction dispose() {\n\n\t\tupdateMap = new WeakMap();\n\n\t}\n\n\tfunction onInstancedMeshDispose( event ) {\n\n\t\tconst instancedMesh = event.target;\n\n\t\tinstancedMesh.removeEventListener( 'dispose', onInstancedMeshDispose );\n\n\t\tattributes.remove( instancedMesh.instanceMatrix );\n\n\t\tif ( instancedMesh.instanceColor !== null ) attributes.remove( instancedMesh.instanceColor );\n\n\t}\n\n\treturn {\n\n\t\tupdate: update,\n\t\tdispose: dispose\n\n\t};\n\n}\n\n/**\n * Uniforms of a program.\n * Those form a tree structure with a special top-level container for the root,\n * which you get by calling 'new WebGLUniforms( gl, program )'.\n *\n *\n * Properties of inner nodes including the top-level container:\n *\n * .seq - array of nested uniforms\n * .map - nested uniforms by name\n *\n *\n * Methods of all nodes except the top-level container:\n *\n * .setValue( gl, value, [textures] )\n *\n * \t\tuploads a uniform value(s)\n * \tthe 'textures' parameter is needed for sampler uniforms\n *\n *\n * Static methods of the top-level container (textures factorizations):\n *\n * .upload( gl, seq, values, textures )\n *\n * \t\tsets uniforms in 'seq' to 'values[id].value'\n *\n * .seqWithValue( seq, values ) : filteredSeq\n *\n * \t\tfilters 'seq' entries with corresponding entry in values\n *\n *\n * Methods of the top-level container (textures factorizations):\n *\n * .setValue( gl, name, value, textures )\n *\n * \t\tsets uniform with name 'name' to 'value'\n *\n * .setOptional( gl, obj, prop )\n *\n * \t\tlike .set for an optional property of the object\n *\n */\n\nconst emptyTexture = new Texture();\nconst emptyArrayTexture = new DataArrayTexture();\nconst empty3dTexture = new Data3DTexture();\nconst emptyCubeTexture = new CubeTexture();\n\n// --- Utilities ---\n\n// Array Caches (provide typed arrays for temporary by size)\n\nconst arrayCacheF32 = [];\nconst arrayCacheI32 = [];\n\n// Float32Array caches used for uploading Matrix uniforms\n\nconst mat4array = new Float32Array( 16 );\nconst mat3array = new Float32Array( 9 );\nconst mat2array = new Float32Array( 4 );\n\n// Flattening for arrays of vectors and matrices\n\nfunction flatten( array, nBlocks, blockSize ) {\n\n\tconst firstElem = array[ 0 ];\n\n\tif ( firstElem <= 0 || firstElem > 0 ) return array;\n\t// unoptimized: ! isNaN( firstElem )\n\t// see http://jacksondunstan.com/articles/983\n\n\tconst n = nBlocks * blockSize;\n\tlet r = arrayCacheF32[ n ];\n\n\tif ( r === undefined ) {\n\n\t\tr = new Float32Array( n );\n\t\tarrayCacheF32[ n ] = r;\n\n\t}\n\n\tif ( nBlocks !== 0 ) {\n\n\t\tfirstElem.toArray( r, 0 );\n\n\t\tfor ( let i = 1, offset = 0; i !== nBlocks; ++ i ) {\n\n\t\t\toffset += blockSize;\n\t\t\tarray[ i ].toArray( r, offset );\n\n\t\t}\n\n\t}\n\n\treturn r;\n\n}\n\nfunction arraysEqual( a, b ) {\n\n\tif ( a.length !== b.length ) return false;\n\n\tfor ( let i = 0, l = a.length; i < l; i ++ ) {\n\n\t\tif ( a[ i ] !== b[ i ] ) return false;\n\n\t}\n\n\treturn true;\n\n}\n\nfunction copyArray( a, b ) {\n\n\tfor ( let i = 0, l = b.length; i < l; i ++ ) {\n\n\t\ta[ i ] = b[ i ];\n\n\t}\n\n}\n\n// Texture unit allocation\n\nfunction allocTexUnits( textures, n ) {\n\n\tlet r = arrayCacheI32[ n ];\n\n\tif ( r === undefined ) {\n\n\t\tr = new Int32Array( n );\n\t\tarrayCacheI32[ n ] = r;\n\n\t}\n\n\tfor ( let i = 0; i !== n; ++ i ) {\n\n\t\tr[ i ] = textures.allocateTextureUnit();\n\n\t}\n\n\treturn r;\n\n}\n\n// --- Setters ---\n\n// Note: Defining these methods externally, because they come in a bunch\n// and this way their names minify.\n\n// Single scalar\n\nfunction setValueV1f( gl, v ) {\n\n\tconst cache = this.cache;\n\n\tif ( cache[ 0 ] === v ) return;\n\n\tgl.uniform1f( this.addr, v );\n\n\tcache[ 0 ] = v;\n\n}\n\n// Single float vector (from flat array or THREE.VectorN)\n\nfunction setValueV2f( gl, v ) {\n\n\tconst cache = this.cache;\n\n\tif ( v.x !== undefined ) {\n\n\t\tif ( cache[ 0 ] !== v.x || cache[ 1 ] !== v.y ) {\n\n\t\t\tgl.uniform2f( this.addr, v.x, v.y );\n\n\t\t\tcache[ 0 ] = v.x;\n\t\t\tcache[ 1 ] = v.y;\n\n\t\t}\n\n\t} else {\n\n\t\tif ( arraysEqual( cache, v ) ) return;\n\n\t\tgl.uniform2fv( this.addr, v );\n\n\t\tcopyArray( cache, v );\n\n\t}\n\n}\n\nfunction setValueV3f( gl, v ) {\n\n\tconst cache = this.cache;\n\n\tif ( v.x !== undefined ) {\n\n\t\tif ( cache[ 0 ] !== v.x || cache[ 1 ] !== v.y || cache[ 2 ] !== v.z ) {\n\n\t\t\tgl.uniform3f( this.addr, v.x, v.y, v.z );\n\n\t\t\tcache[ 0 ] = v.x;\n\t\t\tcache[ 1 ] = v.y;\n\t\t\tcache[ 2 ] = v.z;\n\n\t\t}\n\n\t} else if ( v.r !== undefined ) {\n\n\t\tif ( cache[ 0 ] !== v.r || cache[ 1 ] !== v.g || cache[ 2 ] !== v.b ) {\n\n\t\t\tgl.uniform3f( this.addr, v.r, v.g, v.b );\n\n\t\t\tcache[ 0 ] = v.r;\n\t\t\tcache[ 1 ] = v.g;\n\t\t\tcache[ 2 ] = v.b;\n\n\t\t}\n\n\t} else {\n\n\t\tif ( arraysEqual( cache, v ) ) return;\n\n\t\tgl.uniform3fv( this.addr, v );\n\n\t\tcopyArray( cache, v );\n\n\t}\n\n}\n\nfunction setValueV4f( gl, v ) {\n\n\tconst cache = this.cache;\n\n\tif ( v.x !== undefined ) {\n\n\t\tif ( cache[ 0 ] !== v.x || cache[ 1 ] !== v.y || cache[ 2 ] !== v.z || cache[ 3 ] !== v.w ) {\n\n\t\t\tgl.uniform4f( this.addr, v.x, v.y, v.z, v.w );\n\n\t\t\tcache[ 0 ] = v.x;\n\t\t\tcache[ 1 ] = v.y;\n\t\t\tcache[ 2 ] = v.z;\n\t\t\tcache[ 3 ] = v.w;\n\n\t\t}\n\n\t} else {\n\n\t\tif ( arraysEqual( cache, v ) ) return;\n\n\t\tgl.uniform4fv( this.addr, v );\n\n\t\tcopyArray( cache, v );\n\n\t}\n\n}\n\n// Single matrix (from flat array or THREE.MatrixN)\n\nfunction setValueM2( gl, v ) {\n\n\tconst cache = this.cache;\n\tconst elements = v.elements;\n\n\tif ( elements === undefined ) {\n\n\t\tif ( arraysEqual( cache, v ) ) return;\n\n\t\tgl.uniformMatrix2fv( this.addr, false, v );\n\n\t\tcopyArray( cache, v );\n\n\t} else {\n\n\t\tif ( arraysEqual( cache, elements ) ) return;\n\n\t\tmat2array.set( elements );\n\n\t\tgl.uniformMatrix2fv( this.addr, false, mat2array );\n\n\t\tcopyArray( cache, elements );\n\n\t}\n\n}\n\nfunction setValueM3( gl, v ) {\n\n\tconst cache = this.cache;\n\tconst elements = v.elements;\n\n\tif ( elements === undefined ) {\n\n\t\tif ( arraysEqual( cache, v ) ) return;\n\n\t\tgl.uniformMatrix3fv( this.addr, false, v );\n\n\t\tcopyArray( cache, v );\n\n\t} else {\n\n\t\tif ( arraysEqual( cache, elements ) ) return;\n\n\t\tmat3array.set( elements );\n\n\t\tgl.uniformMatrix3fv( this.addr, false, mat3array );\n\n\t\tcopyArray( cache, elements );\n\n\t}\n\n}\n\nfunction setValueM4( gl, v ) {\n\n\tconst cache = this.cache;\n\tconst elements = v.elements;\n\n\tif ( elements === undefined ) {\n\n\t\tif ( arraysEqual( cache, v ) ) return;\n\n\t\tgl.uniformMatrix4fv( this.addr, false, v );\n\n\t\tcopyArray( cache, v );\n\n\t} else {\n\n\t\tif ( arraysEqual( cache, elements ) ) return;\n\n\t\tmat4array.set( elements );\n\n\t\tgl.uniformMatrix4fv( this.addr, false, mat4array );\n\n\t\tcopyArray( cache, elements );\n\n\t}\n\n}\n\n// Single integer / boolean\n\nfunction setValueV1i( gl, v ) {\n\n\tconst cache = this.cache;\n\n\tif ( cache[ 0 ] === v ) return;\n\n\tgl.uniform1i( this.addr, v );\n\n\tcache[ 0 ] = v;\n\n}\n\n// Single integer / boolean vector (from flat array)\n\nfunction setValueV2i( gl, v ) {\n\n\tconst cache = this.cache;\n\n\tif ( arraysEqual( cache, v ) ) return;\n\n\tgl.uniform2iv( this.addr, v );\n\n\tcopyArray( cache, v );\n\n}\n\nfunction setValueV3i( gl, v ) {\n\n\tconst cache = this.cache;\n\n\tif ( arraysEqual( cache, v ) ) return;\n\n\tgl.uniform3iv( this.addr, v );\n\n\tcopyArray( cache, v );\n\n}\n\nfunction setValueV4i( gl, v ) {\n\n\tconst cache = this.cache;\n\n\tif ( arraysEqual( cache, v ) ) return;\n\n\tgl.uniform4iv( this.addr, v );\n\n\tcopyArray( cache, v );\n\n}\n\n// Single unsigned integer\n\nfunction setValueV1ui( gl, v ) {\n\n\tconst cache = this.cache;\n\n\tif ( cache[ 0 ] === v ) return;\n\n\tgl.uniform1ui( this.addr, v );\n\n\tcache[ 0 ] = v;\n\n}\n\n// Single unsigned integer vector (from flat array)\n\nfunction setValueV2ui( gl, v ) {\n\n\tconst cache = this.cache;\n\n\tif ( arraysEqual( cache, v ) ) return;\n\n\tgl.uniform2uiv( this.addr, v );\n\n\tcopyArray( cache, v );\n\n}\n\nfunction setValueV3ui( gl, v ) {\n\n\tconst cache = this.cache;\n\n\tif ( arraysEqual( cache, v ) ) return;\n\n\tgl.uniform3uiv( this.addr, v );\n\n\tcopyArray( cache, v );\n\n}\n\nfunction setValueV4ui( gl, v ) {\n\n\tconst cache = this.cache;\n\n\tif ( arraysEqual( cache, v ) ) return;\n\n\tgl.uniform4uiv( this.addr, v );\n\n\tcopyArray( cache, v );\n\n}\n\n\n// Single texture (2D / Cube)\n\nfunction setValueT1( gl, v, textures ) {\n\n\tconst cache = this.cache;\n\tconst unit = textures.allocateTextureUnit();\n\n\tif ( cache[ 0 ] !== unit ) {\n\n\t\tgl.uniform1i( this.addr, unit );\n\t\tcache[ 0 ] = unit;\n\n\t}\n\n\ttextures.setTexture2D( v || emptyTexture, unit );\n\n}\n\nfunction setValueT3D1( gl, v, textures ) {\n\n\tconst cache = this.cache;\n\tconst unit = textures.allocateTextureUnit();\n\n\tif ( cache[ 0 ] !== unit ) {\n\n\t\tgl.uniform1i( this.addr, unit );\n\t\tcache[ 0 ] = unit;\n\n\t}\n\n\ttextures.setTexture3D( v || empty3dTexture, unit );\n\n}\n\nfunction setValueT6( gl, v, textures ) {\n\n\tconst cache = this.cache;\n\tconst unit = textures.allocateTextureUnit();\n\n\tif ( cache[ 0 ] !== unit ) {\n\n\t\tgl.uniform1i( this.addr, unit );\n\t\tcache[ 0 ] = unit;\n\n\t}\n\n\ttextures.setTextureCube( v || emptyCubeTexture, unit );\n\n}\n\nfunction setValueT2DArray1( gl, v, textures ) {\n\n\tconst cache = this.cache;\n\tconst unit = textures.allocateTextureUnit();\n\n\tif ( cache[ 0 ] !== unit ) {\n\n\t\tgl.uniform1i( this.addr, unit );\n\t\tcache[ 0 ] = unit;\n\n\t}\n\n\ttextures.setTexture2DArray( v || emptyArrayTexture, unit );\n\n}\n\n// Helper to pick the right setter for the singular case\n\nfunction getSingularSetter( type ) {\n\n\tswitch ( type ) {\n\n\t\tcase 0x1406: return setValueV1f; // FLOAT\n\t\tcase 0x8b50: return setValueV2f; // _VEC2\n\t\tcase 0x8b51: return setValueV3f; // _VEC3\n\t\tcase 0x8b52: return setValueV4f; // _VEC4\n\n\t\tcase 0x8b5a: return setValueM2; // _MAT2\n\t\tcase 0x8b5b: return setValueM3; // _MAT3\n\t\tcase 0x8b5c: return setValueM4; // _MAT4\n\n\t\tcase 0x1404: case 0x8b56: return setValueV1i; // INT, BOOL\n\t\tcase 0x8b53: case 0x8b57: return setValueV2i; // _VEC2\n\t\tcase 0x8b54: case 0x8b58: return setValueV3i; // _VEC3\n\t\tcase 0x8b55: case 0x8b59: return setValueV4i; // _VEC4\n\n\t\tcase 0x1405: return setValueV1ui; // UINT\n\t\tcase 0x8dc6: return setValueV2ui; // _VEC2\n\t\tcase 0x8dc7: return setValueV3ui; // _VEC3\n\t\tcase 0x8dc8: return setValueV4ui; // _VEC4\n\n\t\tcase 0x8b5e: // SAMPLER_2D\n\t\tcase 0x8d66: // SAMPLER_EXTERNAL_OES\n\t\tcase 0x8dca: // INT_SAMPLER_2D\n\t\tcase 0x8dd2: // UNSIGNED_INT_SAMPLER_2D\n\t\tcase 0x8b62: // SAMPLER_2D_SHADOW\n\t\t\treturn setValueT1;\n\n\t\tcase 0x8b5f: // SAMPLER_3D\n\t\tcase 0x8dcb: // INT_SAMPLER_3D\n\t\tcase 0x8dd3: // UNSIGNED_INT_SAMPLER_3D\n\t\t\treturn setValueT3D1;\n\n\t\tcase 0x8b60: // SAMPLER_CUBE\n\t\tcase 0x8dcc: // INT_SAMPLER_CUBE\n\t\tcase 0x8dd4: // UNSIGNED_INT_SAMPLER_CUBE\n\t\tcase 0x8dc5: // SAMPLER_CUBE_SHADOW\n\t\t\treturn setValueT6;\n\n\t\tcase 0x8dc1: // SAMPLER_2D_ARRAY\n\t\tcase 0x8dcf: // INT_SAMPLER_2D_ARRAY\n\t\tcase 0x8dd7: // UNSIGNED_INT_SAMPLER_2D_ARRAY\n\t\tcase 0x8dc4: // SAMPLER_2D_ARRAY_SHADOW\n\t\t\treturn setValueT2DArray1;\n\n\t}\n\n}\n\n\n// Array of scalars\n\nfunction setValueV1fArray( gl, v ) {\n\n\tgl.uniform1fv( this.addr, v );\n\n}\n\n// Array of vectors (from flat array or array of THREE.VectorN)\n\nfunction setValueV2fArray( gl, v ) {\n\n\tconst data = flatten( v, this.size, 2 );\n\n\tgl.uniform2fv( this.addr, data );\n\n}\n\nfunction setValueV3fArray( gl, v ) {\n\n\tconst data = flatten( v, this.size, 3 );\n\n\tgl.uniform3fv( this.addr, data );\n\n}\n\nfunction setValueV4fArray( gl, v ) {\n\n\tconst data = flatten( v, this.size, 4 );\n\n\tgl.uniform4fv( this.addr, data );\n\n}\n\n// Array of matrices (from flat array or array of THREE.MatrixN)\n\nfunction setValueM2Array( gl, v ) {\n\n\tconst data = flatten( v, this.size, 4 );\n\n\tgl.uniformMatrix2fv( this.addr, false, data );\n\n}\n\nfunction setValueM3Array( gl, v ) {\n\n\tconst data = flatten( v, this.size, 9 );\n\n\tgl.uniformMatrix3fv( this.addr, false, data );\n\n}\n\nfunction setValueM4Array( gl, v ) {\n\n\tconst data = flatten( v, this.size, 16 );\n\n\tgl.uniformMatrix4fv( this.addr, false, data );\n\n}\n\n// Array of integer / boolean\n\nfunction setValueV1iArray( gl, v ) {\n\n\tgl.uniform1iv( this.addr, v );\n\n}\n\n// Array of integer / boolean vectors (from flat array)\n\nfunction setValueV2iArray( gl, v ) {\n\n\tgl.uniform2iv( this.addr, v );\n\n}\n\nfunction setValueV3iArray( gl, v ) {\n\n\tgl.uniform3iv( this.addr, v );\n\n}\n\nfunction setValueV4iArray( gl, v ) {\n\n\tgl.uniform4iv( this.addr, v );\n\n}\n\n// Array of unsigned integer\n\nfunction setValueV1uiArray( gl, v ) {\n\n\tgl.uniform1uiv( this.addr, v );\n\n}\n\n// Array of unsigned integer vectors (from flat array)\n\nfunction setValueV2uiArray( gl, v ) {\n\n\tgl.uniform2uiv( this.addr, v );\n\n}\n\nfunction setValueV3uiArray( gl, v ) {\n\n\tgl.uniform3uiv( this.addr, v );\n\n}\n\nfunction setValueV4uiArray( gl, v ) {\n\n\tgl.uniform4uiv( this.addr, v );\n\n}\n\n\n// Array of textures (2D / 3D / Cube / 2DArray)\n\nfunction setValueT1Array( gl, v, textures ) {\n\n\tconst n = v.length;\n\n\tconst units = allocTexUnits( textures, n );\n\n\tgl.uniform1iv( this.addr, units );\n\n\tfor ( let i = 0; i !== n; ++ i ) {\n\n\t\ttextures.setTexture2D( v[ i ] || emptyTexture, units[ i ] );\n\n\t}\n\n}\n\nfunction setValueT3DArray( gl, v, textures ) {\n\n\tconst n = v.length;\n\n\tconst units = allocTexUnits( textures, n );\n\n\tgl.uniform1iv( this.addr, units );\n\n\tfor ( let i = 0; i !== n; ++ i ) {\n\n\t\ttextures.setTexture3D( v[ i ] || empty3dTexture, units[ i ] );\n\n\t}\n\n}\n\nfunction setValueT6Array( gl, v, textures ) {\n\n\tconst n = v.length;\n\n\tconst units = allocTexUnits( textures, n );\n\n\tgl.uniform1iv( this.addr, units );\n\n\tfor ( let i = 0; i !== n; ++ i ) {\n\n\t\ttextures.setTextureCube( v[ i ] || emptyCubeTexture, units[ i ] );\n\n\t}\n\n}\n\nfunction setValueT2DArrayArray( gl, v, textures ) {\n\n\tconst n = v.length;\n\n\tconst units = allocTexUnits( textures, n );\n\n\tgl.uniform1iv( this.addr, units );\n\n\tfor ( let i = 0; i !== n; ++ i ) {\n\n\t\ttextures.setTexture2DArray( v[ i ] || emptyArrayTexture, units[ i ] );\n\n\t}\n\n}\n\n\n// Helper to pick the right setter for a pure (bottom-level) array\n\nfunction getPureArraySetter( type ) {\n\n\tswitch ( type ) {\n\n\t\tcase 0x1406: return setValueV1fArray; // FLOAT\n\t\tcase 0x8b50: return setValueV2fArray; // _VEC2\n\t\tcase 0x8b51: return setValueV3fArray; // _VEC3\n\t\tcase 0x8b52: return setValueV4fArray; // _VEC4\n\n\t\tcase 0x8b5a: return setValueM2Array; // _MAT2\n\t\tcase 0x8b5b: return setValueM3Array; // _MAT3\n\t\tcase 0x8b5c: return setValueM4Array; // _MAT4\n\n\t\tcase 0x1404: case 0x8b56: return setValueV1iArray; // INT, BOOL\n\t\tcase 0x8b53: case 0x8b57: return setValueV2iArray; // _VEC2\n\t\tcase 0x8b54: case 0x8b58: return setValueV3iArray; // _VEC3\n\t\tcase 0x8b55: case 0x8b59: return setValueV4iArray; // _VEC4\n\n\t\tcase 0x1405: return setValueV1uiArray; // UINT\n\t\tcase 0x8dc6: return setValueV2uiArray; // _VEC2\n\t\tcase 0x8dc7: return setValueV3uiArray; // _VEC3\n\t\tcase 0x8dc8: return setValueV4uiArray; // _VEC4\n\n\t\tcase 0x8b5e: // SAMPLER_2D\n\t\tcase 0x8d66: // SAMPLER_EXTERNAL_OES\n\t\tcase 0x8dca: // INT_SAMPLER_2D\n\t\tcase 0x8dd2: // UNSIGNED_INT_SAMPLER_2D\n\t\tcase 0x8b62: // SAMPLER_2D_SHADOW\n\t\t\treturn setValueT1Array;\n\n\t\tcase 0x8b5f: // SAMPLER_3D\n\t\tcase 0x8dcb: // INT_SAMPLER_3D\n\t\tcase 0x8dd3: // UNSIGNED_INT_SAMPLER_3D\n\t\t\treturn setValueT3DArray;\n\n\t\tcase 0x8b60: // SAMPLER_CUBE\n\t\tcase 0x8dcc: // INT_SAMPLER_CUBE\n\t\tcase 0x8dd4: // UNSIGNED_INT_SAMPLER_CUBE\n\t\tcase 0x8dc5: // SAMPLER_CUBE_SHADOW\n\t\t\treturn setValueT6Array;\n\n\t\tcase 0x8dc1: // SAMPLER_2D_ARRAY\n\t\tcase 0x8dcf: // INT_SAMPLER_2D_ARRAY\n\t\tcase 0x8dd7: // UNSIGNED_INT_SAMPLER_2D_ARRAY\n\t\tcase 0x8dc4: // SAMPLER_2D_ARRAY_SHADOW\n\t\t\treturn setValueT2DArrayArray;\n\n\t}\n\n}\n\n// --- Uniform Classes ---\n\nclass SingleUniform {\n\n\tconstructor( id, activeInfo, addr ) {\n\n\t\tthis.id = id;\n\t\tthis.addr = addr;\n\t\tthis.cache = [];\n\t\tthis.setValue = getSingularSetter( activeInfo.type );\n\n\t\t// this.path = activeInfo.name; // DEBUG\n\n\t}\n\n}\n\nclass PureArrayUniform {\n\n\tconstructor( id, activeInfo, addr ) {\n\n\t\tthis.id = id;\n\t\tthis.addr = addr;\n\t\tthis.cache = [];\n\t\tthis.size = activeInfo.size;\n\t\tthis.setValue = getPureArraySetter( activeInfo.type );\n\n\t\t// this.path = activeInfo.name; // DEBUG\n\n\t}\n\n}\n\nclass StructuredUniform {\n\n\tconstructor( id ) {\n\n\t\tthis.id = id;\n\n\t\tthis.seq = [];\n\t\tthis.map = {};\n\n\t}\n\n\tsetValue( gl, value, textures ) {\n\n\t\tconst seq = this.seq;\n\n\t\tfor ( let i = 0, n = seq.length; i !== n; ++ i ) {\n\n\t\t\tconst u = seq[ i ];\n\t\t\tu.setValue( gl, value[ u.id ], textures );\n\n\t\t}\n\n\t}\n\n}\n\n// --- Top-level ---\n\n// Parser - builds up the property tree from the path strings\n\nconst RePathPart = /(\\w+)(\\])?(\\[|\\.)?/g;\n\n// extracts\n// \t- the identifier (member name or array index)\n// - followed by an optional right bracket (found when array index)\n// - followed by an optional left bracket or dot (type of subscript)\n//\n// Note: These portions can be read in a non-overlapping fashion and\n// allow straightforward parsing of the hierarchy that WebGL encodes\n// in the uniform names.\n\nfunction addUniform( container, uniformObject ) {\n\n\tcontainer.seq.push( uniformObject );\n\tcontainer.map[ uniformObject.id ] = uniformObject;\n\n}\n\nfunction parseUniform( activeInfo, addr, container ) {\n\n\tconst path = activeInfo.name,\n\t\tpathLength = path.length;\n\n\t// reset RegExp object, because of the early exit of a previous run\n\tRePathPart.lastIndex = 0;\n\n\twhile ( true ) {\n\n\t\tconst match = RePathPart.exec( path ),\n\t\t\tmatchEnd = RePathPart.lastIndex;\n\n\t\tlet id = match[ 1 ];\n\t\tconst idIsIndex = match[ 2 ] === ']',\n\t\t\tsubscript = match[ 3 ];\n\n\t\tif ( idIsIndex ) id = id | 0; // convert to integer\n\n\t\tif ( subscript === undefined || subscript === '[' && matchEnd + 2 === pathLength ) {\n\n\t\t\t// bare name or \"pure\" bottom-level array \"[0]\" suffix\n\n\t\t\taddUniform( container, subscript === undefined ?\n\t\t\t\tnew SingleUniform( id, activeInfo, addr ) :\n\t\t\t\tnew PureArrayUniform( id, activeInfo, addr ) );\n\n\t\t\tbreak;\n\n\t\t} else {\n\n\t\t\t// step into inner node / create it in case it doesn't exist\n\n\t\t\tconst map = container.map;\n\t\t\tlet next = map[ id ];\n\n\t\t\tif ( next === undefined ) {\n\n\t\t\t\tnext = new StructuredUniform( id );\n\t\t\t\taddUniform( container, next );\n\n\t\t\t}\n\n\t\t\tcontainer = next;\n\n\t\t}\n\n\t}\n\n}\n\n// Root Container\n\nclass WebGLUniforms {\n\n\tconstructor( gl, program ) {\n\n\t\tthis.seq = [];\n\t\tthis.map = {};\n\n\t\tconst n = gl.getProgramParameter( program, 35718 );\n\n\t\tfor ( let i = 0; i < n; ++ i ) {\n\n\t\t\tconst info = gl.getActiveUniform( program, i ),\n\t\t\t\taddr = gl.getUniformLocation( program, info.name );\n\n\t\t\tparseUniform( info, addr, this );\n\n\t\t}\n\n\t}\n\n\tsetValue( gl, name, value, textures ) {\n\n\t\tconst u = this.map[ name ];\n\n\t\tif ( u !== undefined ) u.setValue( gl, value, textures );\n\n\t}\n\n\tsetOptional( gl, object, name ) {\n\n\t\tconst v = object[ name ];\n\n\t\tif ( v !== undefined ) this.setValue( gl, name, v );\n\n\t}\n\n\tstatic upload( gl, seq, values, textures ) {\n\n\t\tfor ( let i = 0, n = seq.length; i !== n; ++ i ) {\n\n\t\t\tconst u = seq[ i ],\n\t\t\t\tv = values[ u.id ];\n\n\t\t\tif ( v.needsUpdate !== false ) {\n\n\t\t\t\t// note: always updating when .needsUpdate is undefined\n\t\t\t\tu.setValue( gl, v.value, textures );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tstatic seqWithValue( seq, values ) {\n\n\t\tconst r = [];\n\n\t\tfor ( let i = 0, n = seq.length; i !== n; ++ i ) {\n\n\t\t\tconst u = seq[ i ];\n\t\t\tif ( u.id in values ) r.push( u );\n\n\t\t}\n\n\t\treturn r;\n\n\t}\n\n}\n\nfunction WebGLShader( gl, type, string ) {\n\n\tconst shader = gl.createShader( type );\n\n\tgl.shaderSource( shader, string );\n\tgl.compileShader( shader );\n\n\treturn shader;\n\n}\n\nlet programIdCount = 0;\n\nfunction handleSource( string, errorLine ) {\n\n\tconst lines = string.split( '\\n' );\n\tconst lines2 = [];\n\n\tconst from = Math.max( errorLine - 6, 0 );\n\tconst to = Math.min( errorLine + 6, lines.length );\n\n\tfor ( let i = from; i < to; i ++ ) {\n\n\t\tconst line = i + 1;\n\t\tlines2.push( `${line === errorLine ? '>' : ' '} ${line}: ${lines[ i ]}` );\n\n\t}\n\n\treturn lines2.join( '\\n' );\n\n}\n\nfunction getEncodingComponents( encoding ) {\n\n\tswitch ( encoding ) {\n\n\t\tcase LinearEncoding:\n\t\t\treturn [ 'Linear', '( value )' ];\n\t\tcase sRGBEncoding:\n\t\t\treturn [ 'sRGB', '( value )' ];\n\t\tdefault:\n\t\t\tconsole.warn( 'THREE.WebGLProgram: Unsupported encoding:', encoding );\n\t\t\treturn [ 'Linear', '( value )' ];\n\n\t}\n\n}\n\nfunction getShaderErrors( gl, shader, type ) {\n\n\tconst status = gl.getShaderParameter( shader, 35713 );\n\tconst errors = gl.getShaderInfoLog( shader ).trim();\n\n\tif ( status && errors === '' ) return '';\n\n\tconst errorMatches = /ERROR: 0:(\\d+)/.exec( errors );\n\tif ( errorMatches ) {\n\n\t\t// --enable-privileged-webgl-extension\n\t\t// console.log( '**' + type + '**', gl.getExtension( 'WEBGL_debug_shaders' ).getTranslatedShaderSource( shader ) );\n\n\t\tconst errorLine = parseInt( errorMatches[ 1 ] );\n\t\treturn type.toUpperCase() + '\\n\\n' + errors + '\\n\\n' + handleSource( gl.getShaderSource( shader ), errorLine );\n\n\t} else {\n\n\t\treturn errors;\n\n\t}\n\n}\n\nfunction getTexelEncodingFunction( functionName, encoding ) {\n\n\tconst components = getEncodingComponents( encoding );\n\treturn 'vec4 ' + functionName + '( vec4 value ) { return LinearTo' + components[ 0 ] + components[ 1 ] + '; }';\n\n}\n\nfunction getToneMappingFunction( functionName, toneMapping ) {\n\n\tlet toneMappingName;\n\n\tswitch ( toneMapping ) {\n\n\t\tcase LinearToneMapping:\n\t\t\ttoneMappingName = 'Linear';\n\t\t\tbreak;\n\n\t\tcase ReinhardToneMapping:\n\t\t\ttoneMappingName = 'Reinhard';\n\t\t\tbreak;\n\n\t\tcase CineonToneMapping:\n\t\t\ttoneMappingName = 'OptimizedCineon';\n\t\t\tbreak;\n\n\t\tcase ACESFilmicToneMapping:\n\t\t\ttoneMappingName = 'ACESFilmic';\n\t\t\tbreak;\n\n\t\tcase CustomToneMapping:\n\t\t\ttoneMappingName = 'Custom';\n\t\t\tbreak;\n\n\t\tdefault:\n\t\t\tconsole.warn( 'THREE.WebGLProgram: Unsupported toneMapping:', toneMapping );\n\t\t\ttoneMappingName = 'Linear';\n\n\t}\n\n\treturn 'vec3 ' + functionName + '( vec3 color ) { return ' + toneMappingName + 'ToneMapping( color ); }';\n\n}\n\nfunction generateExtensions( parameters ) {\n\n\tconst chunks = [\n\t\t( parameters.extensionDerivatives || !! parameters.envMapCubeUVHeight || parameters.bumpMap || parameters.tangentSpaceNormalMap || parameters.clearcoatNormalMap || parameters.flatShading || parameters.shaderID === 'physical' ) ? '#extension GL_OES_standard_derivatives : enable' : '',\n\t\t( parameters.extensionFragDepth || parameters.logarithmicDepthBuffer ) && parameters.rendererExtensionFragDepth ? '#extension GL_EXT_frag_depth : enable' : '',\n\t\t( parameters.extensionDrawBuffers && parameters.rendererExtensionDrawBuffers ) ? '#extension GL_EXT_draw_buffers : require' : '',\n\t\t( parameters.extensionShaderTextureLOD || parameters.envMap || parameters.transmission ) && parameters.rendererExtensionShaderTextureLod ? '#extension GL_EXT_shader_texture_lod : enable' : ''\n\t];\n\n\treturn chunks.filter( filterEmptyLine ).join( '\\n' );\n\n}\n\nfunction generateDefines( defines ) {\n\n\tconst chunks = [];\n\n\tfor ( const name in defines ) {\n\n\t\tconst value = defines[ name ];\n\n\t\tif ( value === false ) continue;\n\n\t\tchunks.push( '#define ' + name + ' ' + value );\n\n\t}\n\n\treturn chunks.join( '\\n' );\n\n}\n\nfunction fetchAttributeLocations( gl, program ) {\n\n\tconst attributes = {};\n\n\tconst n = gl.getProgramParameter( program, 35721 );\n\n\tfor ( let i = 0; i < n; i ++ ) {\n\n\t\tconst info = gl.getActiveAttrib( program, i );\n\t\tconst name = info.name;\n\n\t\tlet locationSize = 1;\n\t\tif ( info.type === 35674 ) locationSize = 2;\n\t\tif ( info.type === 35675 ) locationSize = 3;\n\t\tif ( info.type === 35676 ) locationSize = 4;\n\n\t\t// console.log( 'THREE.WebGLProgram: ACTIVE VERTEX ATTRIBUTE:', name, i );\n\n\t\tattributes[ name ] = {\n\t\t\ttype: info.type,\n\t\t\tlocation: gl.getAttribLocation( program, name ),\n\t\t\tlocationSize: locationSize\n\t\t};\n\n\t}\n\n\treturn attributes;\n\n}\n\nfunction filterEmptyLine( string ) {\n\n\treturn string !== '';\n\n}\n\nfunction replaceLightNums( string, parameters ) {\n\n\treturn string\n\t\t.replace( /NUM_DIR_LIGHTS/g, parameters.numDirLights )\n\t\t.replace( /NUM_SPOT_LIGHTS/g, parameters.numSpotLights )\n\t\t.replace( /NUM_RECT_AREA_LIGHTS/g, parameters.numRectAreaLights )\n\t\t.replace( /NUM_POINT_LIGHTS/g, parameters.numPointLights )\n\t\t.replace( /NUM_HEMI_LIGHTS/g, parameters.numHemiLights )\n\t\t.replace( /NUM_DIR_LIGHT_SHADOWS/g, parameters.numDirLightShadows )\n\t\t.replace( /NUM_SPOT_LIGHT_SHADOWS/g, parameters.numSpotLightShadows )\n\t\t.replace( /NUM_POINT_LIGHT_SHADOWS/g, parameters.numPointLightShadows );\n\n}\n\nfunction replaceClippingPlaneNums( string, parameters ) {\n\n\treturn string\n\t\t.replace( /NUM_CLIPPING_PLANES/g, parameters.numClippingPlanes )\n\t\t.replace( /UNION_CLIPPING_PLANES/g, ( parameters.numClippingPlanes - parameters.numClipIntersection ) );\n\n}\n\n// Resolve Includes\n\nconst includePattern = /^[ \\t]*#include +<([\\w\\d./]+)>/gm;\n\nfunction resolveIncludes( string ) {\n\n\treturn string.replace( includePattern, includeReplacer );\n\n}\n\nfunction includeReplacer( match, include ) {\n\n\tconst string = ShaderChunk[ include ];\n\n\tif ( string === undefined ) {\n\n\t\tthrow new Error( 'Can not resolve #include <' + include + '>' );\n\n\t}\n\n\treturn resolveIncludes( string );\n\n}\n\n// Unroll Loops\n\nconst deprecatedUnrollLoopPattern = /#pragma unroll_loop[\\s]+?for \\( int i \\= (\\d+)\\; i < (\\d+)\\; i \\+\\+ \\) \\{([\\s\\S]+?)(?=\\})\\}/g;\nconst unrollLoopPattern = /#pragma unroll_loop_start\\s+for\\s*\\(\\s*int\\s+i\\s*=\\s*(\\d+)\\s*;\\s*i\\s*<\\s*(\\d+)\\s*;\\s*i\\s*\\+\\+\\s*\\)\\s*{([\\s\\S]+?)}\\s+#pragma unroll_loop_end/g;\n\nfunction unrollLoops( string ) {\n\n\treturn string\n\t\t.replace( unrollLoopPattern, loopReplacer )\n\t\t.replace( deprecatedUnrollLoopPattern, deprecatedLoopReplacer );\n\n}\n\nfunction deprecatedLoopReplacer( match, start, end, snippet ) {\n\n\tconsole.warn( 'WebGLProgram: #pragma unroll_loop shader syntax is deprecated. Please use #pragma unroll_loop_start syntax instead.' );\n\treturn loopReplacer( match, start, end, snippet );\n\n}\n\nfunction loopReplacer( match, start, end, snippet ) {\n\n\tlet string = '';\n\n\tfor ( let i = parseInt( start ); i < parseInt( end ); i ++ ) {\n\n\t\tstring += snippet\n\t\t\t.replace( /\\[\\s*i\\s*\\]/g, '[ ' + i + ' ]' )\n\t\t\t.replace( /UNROLLED_LOOP_INDEX/g, i );\n\n\t}\n\n\treturn string;\n\n}\n\n//\n\nfunction generatePrecision( parameters ) {\n\n\tlet precisionstring = 'precision ' + parameters.precision + ' float;\\nprecision ' + parameters.precision + ' int;';\n\n\tif ( parameters.precision === 'highp' ) {\n\n\t\tprecisionstring += '\\n#define HIGH_PRECISION';\n\n\t} else if ( parameters.precision === 'mediump' ) {\n\n\t\tprecisionstring += '\\n#define MEDIUM_PRECISION';\n\n\t} else if ( parameters.precision === 'lowp' ) {\n\n\t\tprecisionstring += '\\n#define LOW_PRECISION';\n\n\t}\n\n\treturn precisionstring;\n\n}\n\nfunction generateShadowMapTypeDefine( parameters ) {\n\n\tlet shadowMapTypeDefine = 'SHADOWMAP_TYPE_BASIC';\n\n\tif ( parameters.shadowMapType === PCFShadowMap ) {\n\n\t\tshadowMapTypeDefine = 'SHADOWMAP_TYPE_PCF';\n\n\t} else if ( parameters.shadowMapType === PCFSoftShadowMap ) {\n\n\t\tshadowMapTypeDefine = 'SHADOWMAP_TYPE_PCF_SOFT';\n\n\t} else if ( parameters.shadowMapType === VSMShadowMap ) {\n\n\t\tshadowMapTypeDefine = 'SHADOWMAP_TYPE_VSM';\n\n\t}\n\n\treturn shadowMapTypeDefine;\n\n}\n\nfunction generateEnvMapTypeDefine( parameters ) {\n\n\tlet envMapTypeDefine = 'ENVMAP_TYPE_CUBE';\n\n\tif ( parameters.envMap ) {\n\n\t\tswitch ( parameters.envMapMode ) {\n\n\t\t\tcase CubeReflectionMapping:\n\t\t\tcase CubeRefractionMapping:\n\t\t\t\tenvMapTypeDefine = 'ENVMAP_TYPE_CUBE';\n\t\t\t\tbreak;\n\n\t\t\tcase CubeUVReflectionMapping:\n\t\t\t\tenvMapTypeDefine = 'ENVMAP_TYPE_CUBE_UV';\n\t\t\t\tbreak;\n\n\t\t}\n\n\t}\n\n\treturn envMapTypeDefine;\n\n}\n\nfunction generateEnvMapModeDefine( parameters ) {\n\n\tlet envMapModeDefine = 'ENVMAP_MODE_REFLECTION';\n\n\tif ( parameters.envMap ) {\n\n\t\tswitch ( parameters.envMapMode ) {\n\n\t\t\tcase CubeRefractionMapping:\n\n\t\t\t\tenvMapModeDefine = 'ENVMAP_MODE_REFRACTION';\n\t\t\t\tbreak;\n\n\t\t}\n\n\t}\n\n\treturn envMapModeDefine;\n\n}\n\nfunction generateEnvMapBlendingDefine( parameters ) {\n\n\tlet envMapBlendingDefine = 'ENVMAP_BLENDING_NONE';\n\n\tif ( parameters.envMap ) {\n\n\t\tswitch ( parameters.combine ) {\n\n\t\t\tcase MultiplyOperation:\n\t\t\t\tenvMapBlendingDefine = 'ENVMAP_BLENDING_MULTIPLY';\n\t\t\t\tbreak;\n\n\t\t\tcase MixOperation:\n\t\t\t\tenvMapBlendingDefine = 'ENVMAP_BLENDING_MIX';\n\t\t\t\tbreak;\n\n\t\t\tcase AddOperation:\n\t\t\t\tenvMapBlendingDefine = 'ENVMAP_BLENDING_ADD';\n\t\t\t\tbreak;\n\n\t\t}\n\n\t}\n\n\treturn envMapBlendingDefine;\n\n}\n\nfunction generateCubeUVSize( parameters ) {\n\n\tconst imageHeight = parameters.envMapCubeUVHeight;\n\n\tif ( imageHeight === null ) return null;\n\n\tconst maxMip = Math.log2( imageHeight ) - 2;\n\n\tconst texelHeight = 1.0 / imageHeight;\n\n\tconst texelWidth = 1.0 / ( 3 * Math.max( Math.pow( 2, maxMip ), 7 * 16 ) );\n\n\treturn { texelWidth, texelHeight, maxMip };\n\n}\n\nfunction WebGLProgram( renderer, cacheKey, parameters, bindingStates ) {\n\n\t// TODO Send this event to Three.js DevTools\n\t// console.log( 'WebGLProgram', cacheKey );\n\n\tconst gl = renderer.getContext();\n\n\tconst defines = parameters.defines;\n\n\tlet vertexShader = parameters.vertexShader;\n\tlet fragmentShader = parameters.fragmentShader;\n\n\tconst shadowMapTypeDefine = generateShadowMapTypeDefine( parameters );\n\tconst envMapTypeDefine = generateEnvMapTypeDefine( parameters );\n\tconst envMapModeDefine = generateEnvMapModeDefine( parameters );\n\tconst envMapBlendingDefine = generateEnvMapBlendingDefine( parameters );\n\tconst envMapCubeUVSize = generateCubeUVSize( parameters );\n\n\tconst customExtensions = parameters.isWebGL2 ? '' : generateExtensions( parameters );\n\n\tconst customDefines = generateDefines( defines );\n\n\tconst program = gl.createProgram();\n\n\tlet prefixVertex, prefixFragment;\n\tlet versionString = parameters.glslVersion ? '#version ' + parameters.glslVersion + '\\n' : '';\n\n\tif ( parameters.isRawShaderMaterial ) {\n\n\t\tprefixVertex = [\n\n\t\t\tcustomDefines\n\n\t\t].filter( filterEmptyLine ).join( '\\n' );\n\n\t\tif ( prefixVertex.length > 0 ) {\n\n\t\t\tprefixVertex += '\\n';\n\n\t\t}\n\n\t\tprefixFragment = [\n\n\t\t\tcustomExtensions,\n\t\t\tcustomDefines\n\n\t\t].filter( filterEmptyLine ).join( '\\n' );\n\n\t\tif ( prefixFragment.length > 0 ) {\n\n\t\t\tprefixFragment += '\\n';\n\n\t\t}\n\n\t} else {\n\n\t\tprefixVertex = [\n\n\t\t\tgeneratePrecision( parameters ),\n\n\t\t\t'#define SHADER_NAME ' + parameters.shaderName,\n\n\t\t\tcustomDefines,\n\n\t\t\tparameters.instancing ? '#define USE_INSTANCING' : '',\n\t\t\tparameters.instancingColor ? '#define USE_INSTANCING_COLOR' : '',\n\n\t\t\tparameters.supportsVertexTextures ? '#define VERTEX_TEXTURES' : '',\n\n\t\t\t( parameters.useFog && parameters.fog ) ? '#define USE_FOG' : '',\n\t\t\t( parameters.useFog && parameters.fogExp2 ) ? '#define FOG_EXP2' : '',\n\n\t\t\tparameters.map ? '#define USE_MAP' : '',\n\t\t\tparameters.envMap ? '#define USE_ENVMAP' : '',\n\t\t\tparameters.envMap ? '#define ' + envMapModeDefine : '',\n\t\t\tparameters.lightMap ? '#define USE_LIGHTMAP' : '',\n\t\t\tparameters.aoMap ? '#define USE_AOMAP' : '',\n\t\t\tparameters.emissiveMap ? '#define USE_EMISSIVEMAP' : '',\n\t\t\tparameters.bumpMap ? '#define USE_BUMPMAP' : '',\n\t\t\tparameters.normalMap ? '#define USE_NORMALMAP' : '',\n\t\t\t( parameters.normalMap && parameters.objectSpaceNormalMap ) ? '#define OBJECTSPACE_NORMALMAP' : '',\n\t\t\t( parameters.normalMap && parameters.tangentSpaceNormalMap ) ? '#define TANGENTSPACE_NORMALMAP' : '',\n\n\t\t\tparameters.clearcoatMap ? '#define USE_CLEARCOATMAP' : '',\n\t\t\tparameters.clearcoatRoughnessMap ? '#define USE_CLEARCOAT_ROUGHNESSMAP' : '',\n\t\t\tparameters.clearcoatNormalMap ? '#define USE_CLEARCOAT_NORMALMAP' : '',\n\n\t\t\tparameters.iridescenceMap ? '#define USE_IRIDESCENCEMAP' : '',\n\t\t\tparameters.iridescenceThicknessMap ? '#define USE_IRIDESCENCE_THICKNESSMAP' : '',\n\n\t\t\tparameters.displacementMap && parameters.supportsVertexTextures ? '#define USE_DISPLACEMENTMAP' : '',\n\n\t\t\tparameters.specularMap ? '#define USE_SPECULARMAP' : '',\n\t\t\tparameters.specularIntensityMap ? '#define USE_SPECULARINTENSITYMAP' : '',\n\t\t\tparameters.specularColorMap ? '#define USE_SPECULARCOLORMAP' : '',\n\n\t\t\tparameters.roughnessMap ? '#define USE_ROUGHNESSMAP' : '',\n\t\t\tparameters.metalnessMap ? '#define USE_METALNESSMAP' : '',\n\t\t\tparameters.alphaMap ? '#define USE_ALPHAMAP' : '',\n\n\t\t\tparameters.transmission ? '#define USE_TRANSMISSION' : '',\n\t\t\tparameters.transmissionMap ? '#define USE_TRANSMISSIONMAP' : '',\n\t\t\tparameters.thicknessMap ? '#define USE_THICKNESSMAP' : '',\n\n\t\t\tparameters.sheenColorMap ? '#define USE_SHEENCOLORMAP' : '',\n\t\t\tparameters.sheenRoughnessMap ? '#define USE_SHEENROUGHNESSMAP' : '',\n\n\t\t\tparameters.vertexTangents ? '#define USE_TANGENT' : '',\n\t\t\tparameters.vertexColors ? '#define USE_COLOR' : '',\n\t\t\tparameters.vertexAlphas ? '#define USE_COLOR_ALPHA' : '',\n\t\t\tparameters.vertexUvs ? '#define USE_UV' : '',\n\t\t\tparameters.uvsVertexOnly ? '#define UVS_VERTEX_ONLY' : '',\n\n\t\t\tparameters.flatShading ? '#define FLAT_SHADED' : '',\n\n\t\t\tparameters.skinning ? '#define USE_SKINNING' : '',\n\n\t\t\tparameters.morphTargets ? '#define USE_MORPHTARGETS' : '',\n\t\t\tparameters.morphNormals && parameters.flatShading === false ? '#define USE_MORPHNORMALS' : '',\n\t\t\t( parameters.morphColors && parameters.isWebGL2 ) ? '#define USE_MORPHCOLORS' : '',\n\t\t\t( parameters.morphTargetsCount > 0 && parameters.isWebGL2 ) ? '#define MORPHTARGETS_TEXTURE' : '',\n\t\t\t( parameters.morphTargetsCount > 0 && parameters.isWebGL2 ) ? '#define MORPHTARGETS_TEXTURE_STRIDE ' + parameters.morphTextureStride : '',\n\t\t\t( parameters.morphTargetsCount > 0 && parameters.isWebGL2 ) ? '#define MORPHTARGETS_COUNT ' + parameters.morphTargetsCount : '',\n\t\t\tparameters.doubleSided ? '#define DOUBLE_SIDED' : '',\n\t\t\tparameters.flipSided ? '#define FLIP_SIDED' : '',\n\n\t\t\tparameters.shadowMapEnabled ? '#define USE_SHADOWMAP' : '',\n\t\t\tparameters.shadowMapEnabled ? '#define ' + shadowMapTypeDefine : '',\n\n\t\t\tparameters.sizeAttenuation ? '#define USE_SIZEATTENUATION' : '',\n\n\t\t\tparameters.logarithmicDepthBuffer ? '#define USE_LOGDEPTHBUF' : '',\n\t\t\t( parameters.logarithmicDepthBuffer && parameters.rendererExtensionFragDepth ) ? '#define USE_LOGDEPTHBUF_EXT' : '',\n\n\t\t\t'uniform mat4 modelMatrix;',\n\t\t\t'uniform mat4 modelViewMatrix;',\n\t\t\t'uniform mat4 projectionMatrix;',\n\t\t\t'uniform mat4 viewMatrix;',\n\t\t\t'uniform mat3 normalMatrix;',\n\t\t\t'uniform vec3 cameraPosition;',\n\t\t\t'uniform bool isOrthographic;',\n\n\t\t\t'#ifdef USE_INSTANCING',\n\n\t\t\t'\tattribute mat4 instanceMatrix;',\n\n\t\t\t'#endif',\n\n\t\t\t'#ifdef USE_INSTANCING_COLOR',\n\n\t\t\t'\tattribute vec3 instanceColor;',\n\n\t\t\t'#endif',\n\n\t\t\t'attribute vec3 position;',\n\t\t\t'attribute vec3 normal;',\n\t\t\t'attribute vec2 uv;',\n\n\t\t\t'#ifdef USE_TANGENT',\n\n\t\t\t'\tattribute vec4 tangent;',\n\n\t\t\t'#endif',\n\n\t\t\t'#if defined( USE_COLOR_ALPHA )',\n\n\t\t\t'\tattribute vec4 color;',\n\n\t\t\t'#elif defined( USE_COLOR )',\n\n\t\t\t'\tattribute vec3 color;',\n\n\t\t\t'#endif',\n\n\t\t\t'#if ( defined( USE_MORPHTARGETS ) && ! defined( MORPHTARGETS_TEXTURE ) )',\n\n\t\t\t'\tattribute vec3 morphTarget0;',\n\t\t\t'\tattribute vec3 morphTarget1;',\n\t\t\t'\tattribute vec3 morphTarget2;',\n\t\t\t'\tattribute vec3 morphTarget3;',\n\n\t\t\t'\t#ifdef USE_MORPHNORMALS',\n\n\t\t\t'\t\tattribute vec3 morphNormal0;',\n\t\t\t'\t\tattribute vec3 morphNormal1;',\n\t\t\t'\t\tattribute vec3 morphNormal2;',\n\t\t\t'\t\tattribute vec3 morphNormal3;',\n\n\t\t\t'\t#else',\n\n\t\t\t'\t\tattribute vec3 morphTarget4;',\n\t\t\t'\t\tattribute vec3 morphTarget5;',\n\t\t\t'\t\tattribute vec3 morphTarget6;',\n\t\t\t'\t\tattribute vec3 morphTarget7;',\n\n\t\t\t'\t#endif',\n\n\t\t\t'#endif',\n\n\t\t\t'#ifdef USE_SKINNING',\n\n\t\t\t'\tattribute vec4 skinIndex;',\n\t\t\t'\tattribute vec4 skinWeight;',\n\n\t\t\t'#endif',\n\n\t\t\t'\\n'\n\n\t\t].filter( filterEmptyLine ).join( '\\n' );\n\n\t\tprefixFragment = [\n\n\t\t\tcustomExtensions,\n\n\t\t\tgeneratePrecision( parameters ),\n\n\t\t\t'#define SHADER_NAME ' + parameters.shaderName,\n\n\t\t\tcustomDefines,\n\n\t\t\t( parameters.useFog && parameters.fog ) ? '#define USE_FOG' : '',\n\t\t\t( parameters.useFog && parameters.fogExp2 ) ? '#define FOG_EXP2' : '',\n\n\t\t\tparameters.map ? '#define USE_MAP' : '',\n\t\t\tparameters.matcap ? '#define USE_MATCAP' : '',\n\t\t\tparameters.envMap ? '#define USE_ENVMAP' : '',\n\t\t\tparameters.envMap ? '#define ' + envMapTypeDefine : '',\n\t\t\tparameters.envMap ? '#define ' + envMapModeDefine : '',\n\t\t\tparameters.envMap ? '#define ' + envMapBlendingDefine : '',\n\t\t\tenvMapCubeUVSize ? '#define CUBEUV_TEXEL_WIDTH ' + envMapCubeUVSize.texelWidth : '',\n\t\t\tenvMapCubeUVSize ? '#define CUBEUV_TEXEL_HEIGHT ' + envMapCubeUVSize.texelHeight : '',\n\t\t\tenvMapCubeUVSize ? '#define CUBEUV_MAX_MIP ' + envMapCubeUVSize.maxMip + '.0' : '',\n\t\t\tparameters.lightMap ? '#define USE_LIGHTMAP' : '',\n\t\t\tparameters.aoMap ? '#define USE_AOMAP' : '',\n\t\t\tparameters.emissiveMap ? '#define USE_EMISSIVEMAP' : '',\n\t\t\tparameters.bumpMap ? '#define USE_BUMPMAP' : '',\n\t\t\tparameters.normalMap ? '#define USE_NORMALMAP' : '',\n\t\t\t( parameters.normalMap && parameters.objectSpaceNormalMap ) ? '#define OBJECTSPACE_NORMALMAP' : '',\n\t\t\t( parameters.normalMap && parameters.tangentSpaceNormalMap ) ? '#define TANGENTSPACE_NORMALMAP' : '',\n\n\t\t\tparameters.clearcoat ? '#define USE_CLEARCOAT' : '',\n\t\t\tparameters.clearcoatMap ? '#define USE_CLEARCOATMAP' : '',\n\t\t\tparameters.clearcoatRoughnessMap ? '#define USE_CLEARCOAT_ROUGHNESSMAP' : '',\n\t\t\tparameters.clearcoatNormalMap ? '#define USE_CLEARCOAT_NORMALMAP' : '',\n\n\t\t\tparameters.iridescence ? '#define USE_IRIDESCENCE' : '',\n\t\t\tparameters.iridescenceMap ? '#define USE_IRIDESCENCEMAP' : '',\n\t\t\tparameters.iridescenceThicknessMap ? '#define USE_IRIDESCENCE_THICKNESSMAP' : '',\n\n\t\t\tparameters.specularMap ? '#define USE_SPECULARMAP' : '',\n\t\t\tparameters.specularIntensityMap ? '#define USE_SPECULARINTENSITYMAP' : '',\n\t\t\tparameters.specularColorMap ? '#define USE_SPECULARCOLORMAP' : '',\n\t\t\tparameters.roughnessMap ? '#define USE_ROUGHNESSMAP' : '',\n\t\t\tparameters.metalnessMap ? '#define USE_METALNESSMAP' : '',\n\n\t\t\tparameters.alphaMap ? '#define USE_ALPHAMAP' : '',\n\t\t\tparameters.alphaTest ? '#define USE_ALPHATEST' : '',\n\n\t\t\tparameters.sheen ? '#define USE_SHEEN' : '',\n\t\t\tparameters.sheenColorMap ? '#define USE_SHEENCOLORMAP' : '',\n\t\t\tparameters.sheenRoughnessMap ? '#define USE_SHEENROUGHNESSMAP' : '',\n\n\t\t\tparameters.transmission ? '#define USE_TRANSMISSION' : '',\n\t\t\tparameters.transmissionMap ? '#define USE_TRANSMISSIONMAP' : '',\n\t\t\tparameters.thicknessMap ? '#define USE_THICKNESSMAP' : '',\n\n\t\t\tparameters.decodeVideoTexture ? '#define DECODE_VIDEO_TEXTURE' : '',\n\n\t\t\tparameters.vertexTangents ? '#define USE_TANGENT' : '',\n\t\t\tparameters.vertexColors || parameters.instancingColor ? '#define USE_COLOR' : '',\n\t\t\tparameters.vertexAlphas ? '#define USE_COLOR_ALPHA' : '',\n\t\t\tparameters.vertexUvs ? '#define USE_UV' : '',\n\t\t\tparameters.uvsVertexOnly ? '#define UVS_VERTEX_ONLY' : '',\n\n\t\t\tparameters.gradientMap ? '#define USE_GRADIENTMAP' : '',\n\n\t\t\tparameters.flatShading ? '#define FLAT_SHADED' : '',\n\n\t\t\tparameters.doubleSided ? '#define DOUBLE_SIDED' : '',\n\t\t\tparameters.flipSided ? '#define FLIP_SIDED' : '',\n\n\t\t\tparameters.shadowMapEnabled ? '#define USE_SHADOWMAP' : '',\n\t\t\tparameters.shadowMapEnabled ? '#define ' + shadowMapTypeDefine : '',\n\n\t\t\tparameters.premultipliedAlpha ? '#define PREMULTIPLIED_ALPHA' : '',\n\n\t\t\tparameters.physicallyCorrectLights ? '#define PHYSICALLY_CORRECT_LIGHTS' : '',\n\n\t\t\tparameters.logarithmicDepthBuffer ? '#define USE_LOGDEPTHBUF' : '',\n\t\t\t( parameters.logarithmicDepthBuffer && parameters.rendererExtensionFragDepth ) ? '#define USE_LOGDEPTHBUF_EXT' : '',\n\n\t\t\t'uniform mat4 viewMatrix;',\n\t\t\t'uniform vec3 cameraPosition;',\n\t\t\t'uniform bool isOrthographic;',\n\n\t\t\t( parameters.toneMapping !== NoToneMapping ) ? '#define TONE_MAPPING' : '',\n\t\t\t( parameters.toneMapping !== NoToneMapping ) ? ShaderChunk[ 'tonemapping_pars_fragment' ] : '', // this code is required here because it is used by the toneMapping() function defined below\n\t\t\t( parameters.toneMapping !== NoToneMapping ) ? getToneMappingFunction( 'toneMapping', parameters.toneMapping ) : '',\n\n\t\t\tparameters.dithering ? '#define DITHERING' : '',\n\t\t\tparameters.opaque ? '#define OPAQUE' : '',\n\n\t\t\tShaderChunk[ 'encodings_pars_fragment' ], // this code is required here because it is used by the various encoding/decoding function defined below\n\t\t\tgetTexelEncodingFunction( 'linearToOutputTexel', parameters.outputEncoding ),\n\n\t\t\tparameters.useDepthPacking ? '#define DEPTH_PACKING ' + parameters.depthPacking : '',\n\n\t\t\t'\\n'\n\n\t\t].filter( filterEmptyLine ).join( '\\n' );\n\n\t}\n\n\tvertexShader = resolveIncludes( vertexShader );\n\tvertexShader = replaceLightNums( vertexShader, parameters );\n\tvertexShader = replaceClippingPlaneNums( vertexShader, parameters );\n\n\tfragmentShader = resolveIncludes( fragmentShader );\n\tfragmentShader = replaceLightNums( fragmentShader, parameters );\n\tfragmentShader = replaceClippingPlaneNums( fragmentShader, parameters );\n\n\tvertexShader = unrollLoops( vertexShader );\n\tfragmentShader = unrollLoops( fragmentShader );\n\n\tif ( parameters.isWebGL2 && parameters.isRawShaderMaterial !== true ) {\n\n\t\t// GLSL 3.0 conversion for built-in materials and ShaderMaterial\n\n\t\tversionString = '#version 300 es\\n';\n\n\t\tprefixVertex = [\n\t\t\t'precision mediump sampler2DArray;',\n\t\t\t'#define attribute in',\n\t\t\t'#define varying out',\n\t\t\t'#define texture2D texture'\n\t\t].join( '\\n' ) + '\\n' + prefixVertex;\n\n\t\tprefixFragment = [\n\t\t\t'#define varying in',\n\t\t\t( parameters.glslVersion === GLSL3 ) ? '' : 'layout(location = 0) out highp vec4 pc_fragColor;',\n\t\t\t( parameters.glslVersion === GLSL3 ) ? '' : '#define gl_FragColor pc_fragColor',\n\t\t\t'#define gl_FragDepthEXT gl_FragDepth',\n\t\t\t'#define texture2D texture',\n\t\t\t'#define textureCube texture',\n\t\t\t'#define texture2DProj textureProj',\n\t\t\t'#define texture2DLodEXT textureLod',\n\t\t\t'#define texture2DProjLodEXT textureProjLod',\n\t\t\t'#define textureCubeLodEXT textureLod',\n\t\t\t'#define texture2DGradEXT textureGrad',\n\t\t\t'#define texture2DProjGradEXT textureProjGrad',\n\t\t\t'#define textureCubeGradEXT textureGrad'\n\t\t].join( '\\n' ) + '\\n' + prefixFragment;\n\n\t}\n\n\tconst vertexGlsl = versionString + prefixVertex + vertexShader;\n\tconst fragmentGlsl = versionString + prefixFragment + fragmentShader;\n\n\t// console.log( '*VERTEX*', vertexGlsl );\n\t// console.log( '*FRAGMENT*', fragmentGlsl );\n\n\tconst glVertexShader = WebGLShader( gl, 35633, vertexGlsl );\n\tconst glFragmentShader = WebGLShader( gl, 35632, fragmentGlsl );\n\n\tgl.attachShader( program, glVertexShader );\n\tgl.attachShader( program, glFragmentShader );\n\n\t// Force a particular attribute to index 0.\n\n\tif ( parameters.index0AttributeName !== undefined ) {\n\n\t\tgl.bindAttribLocation( program, 0, parameters.index0AttributeName );\n\n\t} else if ( parameters.morphTargets === true ) {\n\n\t\t// programs with morphTargets displace position out of attribute 0\n\t\tgl.bindAttribLocation( program, 0, 'position' );\n\n\t}\n\n\tgl.linkProgram( program );\n\n\t// check for link errors\n\tif ( renderer.debug.checkShaderErrors ) {\n\n\t\tconst programLog = gl.getProgramInfoLog( program ).trim();\n\t\tconst vertexLog = gl.getShaderInfoLog( glVertexShader ).trim();\n\t\tconst fragmentLog = gl.getShaderInfoLog( glFragmentShader ).trim();\n\n\t\tlet runnable = true;\n\t\tlet haveDiagnostics = true;\n\n\t\tif ( gl.getProgramParameter( program, 35714 ) === false ) {\n\n\t\t\trunnable = false;\n\n\t\t\tconst vertexErrors = getShaderErrors( gl, glVertexShader, 'vertex' );\n\t\t\tconst fragmentErrors = getShaderErrors( gl, glFragmentShader, 'fragment' );\n\n\t\t\tconsole.error(\n\t\t\t\t'THREE.WebGLProgram: Shader Error ' + gl.getError() + ' - ' +\n\t\t\t\t'VALIDATE_STATUS ' + gl.getProgramParameter( program, 35715 ) + '\\n\\n' +\n\t\t\t\t'Program Info Log: ' + programLog + '\\n' +\n\t\t\t\tvertexErrors + '\\n' +\n\t\t\t\tfragmentErrors\n\t\t\t);\n\n\t\t} else if ( programLog !== '' ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLProgram: Program Info Log:', programLog );\n\n\t\t} else if ( vertexLog === '' || fragmentLog === '' ) {\n\n\t\t\thaveDiagnostics = false;\n\n\t\t}\n\n\t\tif ( haveDiagnostics ) {\n\n\t\t\tthis.diagnostics = {\n\n\t\t\t\trunnable: runnable,\n\n\t\t\t\tprogramLog: programLog,\n\n\t\t\t\tvertexShader: {\n\n\t\t\t\t\tlog: vertexLog,\n\t\t\t\t\tprefix: prefixVertex\n\n\t\t\t\t},\n\n\t\t\t\tfragmentShader: {\n\n\t\t\t\t\tlog: fragmentLog,\n\t\t\t\t\tprefix: prefixFragment\n\n\t\t\t\t}\n\n\t\t\t};\n\n\t\t}\n\n\t}\n\n\t// Clean up\n\n\t// Crashes in iOS9 and iOS10. #18402\n\t// gl.detachShader( program, glVertexShader );\n\t// gl.detachShader( program, glFragmentShader );\n\n\tgl.deleteShader( glVertexShader );\n\tgl.deleteShader( glFragmentShader );\n\n\t// set up caching for uniform locations\n\n\tlet cachedUniforms;\n\n\tthis.getUniforms = function () {\n\n\t\tif ( cachedUniforms === undefined ) {\n\n\t\t\tcachedUniforms = new WebGLUniforms( gl, program );\n\n\t\t}\n\n\t\treturn cachedUniforms;\n\n\t};\n\n\t// set up caching for attribute locations\n\n\tlet cachedAttributes;\n\n\tthis.getAttributes = function () {\n\n\t\tif ( cachedAttributes === undefined ) {\n\n\t\t\tcachedAttributes = fetchAttributeLocations( gl, program );\n\n\t\t}\n\n\t\treturn cachedAttributes;\n\n\t};\n\n\t// free resource\n\n\tthis.destroy = function () {\n\n\t\tbindingStates.releaseStatesOfProgram( this );\n\n\t\tgl.deleteProgram( program );\n\t\tthis.program = undefined;\n\n\t};\n\n\t//\n\n\tthis.name = parameters.shaderName;\n\tthis.id = programIdCount ++;\n\tthis.cacheKey = cacheKey;\n\tthis.usedTimes = 1;\n\tthis.program = program;\n\tthis.vertexShader = glVertexShader;\n\tthis.fragmentShader = glFragmentShader;\n\n\treturn this;\n\n}\n\nlet _id = 0;\n\nclass WebGLShaderCache {\n\n\tconstructor() {\n\n\t\tthis.shaderCache = new Map();\n\t\tthis.materialCache = new Map();\n\n\t}\n\n\tupdate( material ) {\n\n\t\tconst vertexShader = material.vertexShader;\n\t\tconst fragmentShader = material.fragmentShader;\n\n\t\tconst vertexShaderStage = this._getShaderStage( vertexShader );\n\t\tconst fragmentShaderStage = this._getShaderStage( fragmentShader );\n\n\t\tconst materialShaders = this._getShaderCacheForMaterial( material );\n\n\t\tif ( materialShaders.has( vertexShaderStage ) === false ) {\n\n\t\t\tmaterialShaders.add( vertexShaderStage );\n\t\t\tvertexShaderStage.usedTimes ++;\n\n\t\t}\n\n\t\tif ( materialShaders.has( fragmentShaderStage ) === false ) {\n\n\t\t\tmaterialShaders.add( fragmentShaderStage );\n\t\t\tfragmentShaderStage.usedTimes ++;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tremove( material ) {\n\n\t\tconst materialShaders = this.materialCache.get( material );\n\n\t\tfor ( const shaderStage of materialShaders ) {\n\n\t\t\tshaderStage.usedTimes --;\n\n\t\t\tif ( shaderStage.usedTimes === 0 ) this.shaderCache.delete( shaderStage.code );\n\n\t\t}\n\n\t\tthis.materialCache.delete( material );\n\n\t\treturn this;\n\n\t}\n\n\tgetVertexShaderID( material ) {\n\n\t\treturn this._getShaderStage( material.vertexShader ).id;\n\n\t}\n\n\tgetFragmentShaderID( material ) {\n\n\t\treturn this._getShaderStage( material.fragmentShader ).id;\n\n\t}\n\n\tdispose() {\n\n\t\tthis.shaderCache.clear();\n\t\tthis.materialCache.clear();\n\n\t}\n\n\t_getShaderCacheForMaterial( material ) {\n\n\t\tconst cache = this.materialCache;\n\n\t\tif ( cache.has( material ) === false ) {\n\n\t\t\tcache.set( material, new Set() );\n\n\t\t}\n\n\t\treturn cache.get( material );\n\n\t}\n\n\t_getShaderStage( code ) {\n\n\t\tconst cache = this.shaderCache;\n\n\t\tif ( cache.has( code ) === false ) {\n\n\t\t\tconst stage = new WebGLShaderStage( code );\n\t\t\tcache.set( code, stage );\n\n\t\t}\n\n\t\treturn cache.get( code );\n\n\t}\n\n}\n\nclass WebGLShaderStage {\n\n\tconstructor( code ) {\n\n\t\tthis.id = _id ++;\n\n\t\tthis.code = code;\n\t\tthis.usedTimes = 0;\n\n\t}\n\n}\n\nfunction WebGLPrograms( renderer, cubemaps, cubeuvmaps, extensions, capabilities, bindingStates, clipping ) {\n\n\tconst _programLayers = new Layers();\n\tconst _customShaders = new WebGLShaderCache();\n\tconst programs = [];\n\n\tconst isWebGL2 = capabilities.isWebGL2;\n\tconst logarithmicDepthBuffer = capabilities.logarithmicDepthBuffer;\n\tconst vertexTextures = capabilities.vertexTextures;\n\tlet precision = capabilities.precision;\n\n\tconst shaderIDs = {\n\t\tMeshDepthMaterial: 'depth',\n\t\tMeshDistanceMaterial: 'distanceRGBA',\n\t\tMeshNormalMaterial: 'normal',\n\t\tMeshBasicMaterial: 'basic',\n\t\tMeshLambertMaterial: 'lambert',\n\t\tMeshPhongMaterial: 'phong',\n\t\tMeshToonMaterial: 'toon',\n\t\tMeshStandardMaterial: 'physical',\n\t\tMeshPhysicalMaterial: 'physical',\n\t\tMeshMatcapMaterial: 'matcap',\n\t\tLineBasicMaterial: 'basic',\n\t\tLineDashedMaterial: 'dashed',\n\t\tPointsMaterial: 'points',\n\t\tShadowMaterial: 'shadow',\n\t\tSpriteMaterial: 'sprite'\n\t};\n\n\tfunction getParameters( material, lights, shadows, scene, object ) {\n\n\t\tconst fog = scene.fog;\n\t\tconst geometry = object.geometry;\n\t\tconst environment = material.isMeshStandardMaterial ? scene.environment : null;\n\n\t\tconst envMap = ( material.isMeshStandardMaterial ? cubeuvmaps : cubemaps ).get( material.envMap || environment );\n\t\tconst envMapCubeUVHeight = ( !! envMap ) && ( envMap.mapping === CubeUVReflectionMapping ) ? envMap.image.height : null;\n\n\t\tconst shaderID = shaderIDs[ material.type ];\n\n\t\t// heuristics to create shader parameters according to lights in the scene\n\t\t// (not to blow over maxLights budget)\n\n\t\tif ( material.precision !== null ) {\n\n\t\t\tprecision = capabilities.getMaxPrecision( material.precision );\n\n\t\t\tif ( precision !== material.precision ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLProgram.getParameters:', material.precision, 'not supported, using', precision, 'instead.' );\n\n\t\t\t}\n\n\t\t}\n\n\t\t//\n\n\t\tconst morphAttribute = geometry.morphAttributes.position || geometry.morphAttributes.normal || geometry.morphAttributes.color;\n\t\tconst morphTargetsCount = ( morphAttribute !== undefined ) ? morphAttribute.length : 0;\n\n\t\tlet morphTextureStride = 0;\n\n\t\tif ( geometry.morphAttributes.position !== undefined ) morphTextureStride = 1;\n\t\tif ( geometry.morphAttributes.normal !== undefined ) morphTextureStride = 2;\n\t\tif ( geometry.morphAttributes.color !== undefined ) morphTextureStride = 3;\n\n\t\t//\n\n\t\tlet vertexShader, fragmentShader;\n\t\tlet customVertexShaderID, customFragmentShaderID;\n\n\t\tif ( shaderID ) {\n\n\t\t\tconst shader = ShaderLib[ shaderID ];\n\n\t\t\tvertexShader = shader.vertexShader;\n\t\t\tfragmentShader = shader.fragmentShader;\n\n\t\t} else {\n\n\t\t\tvertexShader = material.vertexShader;\n\t\t\tfragmentShader = material.fragmentShader;\n\n\t\t\t_customShaders.update( material );\n\n\t\t\tcustomVertexShaderID = _customShaders.getVertexShaderID( material );\n\t\t\tcustomFragmentShaderID = _customShaders.getFragmentShaderID( material );\n\n\t\t}\n\n\t\tconst currentRenderTarget = renderer.getRenderTarget();\n\n\t\tconst useAlphaTest = material.alphaTest > 0;\n\t\tconst useClearcoat = material.clearcoat > 0;\n\t\tconst useIridescence = material.iridescence > 0;\n\n\t\tconst parameters = {\n\n\t\t\tisWebGL2: isWebGL2,\n\n\t\t\tshaderID: shaderID,\n\t\t\tshaderName: material.type,\n\n\t\t\tvertexShader: vertexShader,\n\t\t\tfragmentShader: fragmentShader,\n\t\t\tdefines: material.defines,\n\n\t\t\tcustomVertexShaderID: customVertexShaderID,\n\t\t\tcustomFragmentShaderID: customFragmentShaderID,\n\n\t\t\tisRawShaderMaterial: material.isRawShaderMaterial === true,\n\t\t\tglslVersion: material.glslVersion,\n\n\t\t\tprecision: precision,\n\n\t\t\tinstancing: object.isInstancedMesh === true,\n\t\t\tinstancingColor: object.isInstancedMesh === true && object.instanceColor !== null,\n\n\t\t\tsupportsVertexTextures: vertexTextures,\n\t\t\toutputEncoding: ( currentRenderTarget === null ) ? renderer.outputEncoding : ( currentRenderTarget.isXRRenderTarget === true ? currentRenderTarget.texture.encoding : LinearEncoding ),\n\t\t\tmap: !! material.map,\n\t\t\tmatcap: !! material.matcap,\n\t\t\tenvMap: !! envMap,\n\t\t\tenvMapMode: envMap && envMap.mapping,\n\t\t\tenvMapCubeUVHeight: envMapCubeUVHeight,\n\t\t\tlightMap: !! material.lightMap,\n\t\t\taoMap: !! material.aoMap,\n\t\t\temissiveMap: !! material.emissiveMap,\n\t\t\tbumpMap: !! material.bumpMap,\n\t\t\tnormalMap: !! material.normalMap,\n\t\t\tobjectSpaceNormalMap: material.normalMapType === ObjectSpaceNormalMap,\n\t\t\ttangentSpaceNormalMap: material.normalMapType === TangentSpaceNormalMap,\n\n\t\t\tdecodeVideoTexture: !! material.map && ( material.map.isVideoTexture === true ) && ( material.map.encoding === sRGBEncoding ),\n\n\t\t\tclearcoat: useClearcoat,\n\t\t\tclearcoatMap: useClearcoat && !! material.clearcoatMap,\n\t\t\tclearcoatRoughnessMap: useClearcoat && !! material.clearcoatRoughnessMap,\n\t\t\tclearcoatNormalMap: useClearcoat && !! material.clearcoatNormalMap,\n\n\t\t\tiridescence: useIridescence,\n\t\t\tiridescenceMap: useIridescence && !! material.iridescenceMap,\n\t\t\tiridescenceThicknessMap: useIridescence && !! material.iridescenceThicknessMap,\n\n\t\t\tdisplacementMap: !! material.displacementMap,\n\t\t\troughnessMap: !! material.roughnessMap,\n\t\t\tmetalnessMap: !! material.metalnessMap,\n\t\t\tspecularMap: !! material.specularMap,\n\t\t\tspecularIntensityMap: !! material.specularIntensityMap,\n\t\t\tspecularColorMap: !! material.specularColorMap,\n\n\t\t\topaque: material.transparent === false && material.blending === NormalBlending,\n\n\t\t\talphaMap: !! material.alphaMap,\n\t\t\talphaTest: useAlphaTest,\n\n\t\t\tgradientMap: !! material.gradientMap,\n\n\t\t\tsheen: material.sheen > 0,\n\t\t\tsheenColorMap: !! material.sheenColorMap,\n\t\t\tsheenRoughnessMap: !! material.sheenRoughnessMap,\n\n\t\t\ttransmission: material.transmission > 0,\n\t\t\ttransmissionMap: !! material.transmissionMap,\n\t\t\tthicknessMap: !! material.thicknessMap,\n\n\t\t\tcombine: material.combine,\n\n\t\t\tvertexTangents: ( !! material.normalMap && !! geometry.attributes.tangent ),\n\t\t\tvertexColors: material.vertexColors,\n\t\t\tvertexAlphas: material.vertexColors === true && !! geometry.attributes.color && geometry.attributes.color.itemSize === 4,\n\t\t\tvertexUvs: !! material.map || !! material.bumpMap || !! material.normalMap || !! material.specularMap || !! material.alphaMap || !! material.emissiveMap || !! material.roughnessMap || !! material.metalnessMap || !! material.clearcoatMap || !! material.clearcoatRoughnessMap || !! material.clearcoatNormalMap || !! material.iridescenceMap || !! material.iridescenceThicknessMap || !! material.displacementMap || !! material.transmissionMap || !! material.thicknessMap || !! material.specularIntensityMap || !! material.specularColorMap || !! material.sheenColorMap || !! material.sheenRoughnessMap,\n\t\t\tuvsVertexOnly: ! ( !! material.map || !! material.bumpMap || !! material.normalMap || !! material.specularMap || !! material.alphaMap || !! material.emissiveMap || !! material.roughnessMap || !! material.metalnessMap || !! material.clearcoatNormalMap || !! material.iridescenceMap || !! material.iridescenceThicknessMap || material.transmission > 0 || !! material.transmissionMap || !! material.thicknessMap || !! material.specularIntensityMap || !! material.specularColorMap || material.sheen > 0 || !! material.sheenColorMap || !! material.sheenRoughnessMap ) && !! material.displacementMap,\n\n\t\t\tfog: !! fog,\n\t\t\tuseFog: material.fog === true,\n\t\t\tfogExp2: ( fog && fog.isFogExp2 ),\n\n\t\t\tflatShading: !! material.flatShading,\n\n\t\t\tsizeAttenuation: material.sizeAttenuation,\n\t\t\tlogarithmicDepthBuffer: logarithmicDepthBuffer,\n\n\t\t\tskinning: object.isSkinnedMesh === true,\n\n\t\t\tmorphTargets: geometry.morphAttributes.position !== undefined,\n\t\t\tmorphNormals: geometry.morphAttributes.normal !== undefined,\n\t\t\tmorphColors: geometry.morphAttributes.color !== undefined,\n\t\t\tmorphTargetsCount: morphTargetsCount,\n\t\t\tmorphTextureStride: morphTextureStride,\n\n\t\t\tnumDirLights: lights.directional.length,\n\t\t\tnumPointLights: lights.point.length,\n\t\t\tnumSpotLights: lights.spot.length,\n\t\t\tnumRectAreaLights: lights.rectArea.length,\n\t\t\tnumHemiLights: lights.hemi.length,\n\n\t\t\tnumDirLightShadows: lights.directionalShadowMap.length,\n\t\t\tnumPointLightShadows: lights.pointShadowMap.length,\n\t\t\tnumSpotLightShadows: lights.spotShadowMap.length,\n\n\t\t\tnumClippingPlanes: clipping.numPlanes,\n\t\t\tnumClipIntersection: clipping.numIntersection,\n\n\t\t\tdithering: material.dithering,\n\n\t\t\tshadowMapEnabled: renderer.shadowMap.enabled && shadows.length > 0,\n\t\t\tshadowMapType: renderer.shadowMap.type,\n\n\t\t\ttoneMapping: material.toneMapped ? renderer.toneMapping : NoToneMapping,\n\t\t\tphysicallyCorrectLights: renderer.physicallyCorrectLights,\n\n\t\t\tpremultipliedAlpha: material.premultipliedAlpha,\n\n\t\t\tdoubleSided: material.side === DoubleSide,\n\t\t\tflipSided: material.side === BackSide,\n\n\t\t\tuseDepthPacking: !! material.depthPacking,\n\t\t\tdepthPacking: material.depthPacking || 0,\n\n\t\t\tindex0AttributeName: material.index0AttributeName,\n\n\t\t\textensionDerivatives: material.extensions && material.extensions.derivatives,\n\t\t\textensionFragDepth: material.extensions && material.extensions.fragDepth,\n\t\t\textensionDrawBuffers: material.extensions && material.extensions.drawBuffers,\n\t\t\textensionShaderTextureLOD: material.extensions && material.extensions.shaderTextureLOD,\n\n\t\t\trendererExtensionFragDepth: isWebGL2 || extensions.has( 'EXT_frag_depth' ),\n\t\t\trendererExtensionDrawBuffers: isWebGL2 || extensions.has( 'WEBGL_draw_buffers' ),\n\t\t\trendererExtensionShaderTextureLod: isWebGL2 || extensions.has( 'EXT_shader_texture_lod' ),\n\n\t\t\tcustomProgramCacheKey: material.customProgramCacheKey()\n\n\t\t};\n\n\t\treturn parameters;\n\n\t}\n\n\tfunction getProgramCacheKey( parameters ) {\n\n\t\tconst array = [];\n\n\t\tif ( parameters.shaderID ) {\n\n\t\t\tarray.push( parameters.shaderID );\n\n\t\t} else {\n\n\t\t\tarray.push( parameters.customVertexShaderID );\n\t\t\tarray.push( parameters.customFragmentShaderID );\n\n\t\t}\n\n\t\tif ( parameters.defines !== undefined ) {\n\n\t\t\tfor ( const name in parameters.defines ) {\n\n\t\t\t\tarray.push( name );\n\t\t\t\tarray.push( parameters.defines[ name ] );\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( parameters.isRawShaderMaterial === false ) {\n\n\t\t\tgetProgramCacheKeyParameters( array, parameters );\n\t\t\tgetProgramCacheKeyBooleans( array, parameters );\n\t\t\tarray.push( renderer.outputEncoding );\n\n\t\t}\n\n\t\tarray.push( parameters.customProgramCacheKey );\n\n\t\treturn array.join();\n\n\t}\n\n\tfunction getProgramCacheKeyParameters( array, parameters ) {\n\n\t\tarray.push( parameters.precision );\n\t\tarray.push( parameters.outputEncoding );\n\t\tarray.push( parameters.envMapMode );\n\t\tarray.push( parameters.envMapCubeUVHeight );\n\t\tarray.push( parameters.combine );\n\t\tarray.push( parameters.vertexUvs );\n\t\tarray.push( parameters.fogExp2 );\n\t\tarray.push( parameters.sizeAttenuation );\n\t\tarray.push( parameters.morphTargetsCount );\n\t\tarray.push( parameters.morphAttributeCount );\n\t\tarray.push( parameters.numDirLights );\n\t\tarray.push( parameters.numPointLights );\n\t\tarray.push( parameters.numSpotLights );\n\t\tarray.push( parameters.numHemiLights );\n\t\tarray.push( parameters.numRectAreaLights );\n\t\tarray.push( parameters.numDirLightShadows );\n\t\tarray.push( parameters.numPointLightShadows );\n\t\tarray.push( parameters.numSpotLightShadows );\n\t\tarray.push( parameters.shadowMapType );\n\t\tarray.push( parameters.toneMapping );\n\t\tarray.push( parameters.numClippingPlanes );\n\t\tarray.push( parameters.numClipIntersection );\n\t\tarray.push( parameters.depthPacking );\n\n\t}\n\n\tfunction getProgramCacheKeyBooleans( array, parameters ) {\n\n\t\t_programLayers.disableAll();\n\n\t\tif ( parameters.isWebGL2 )\n\t\t\t_programLayers.enable( 0 );\n\t\tif ( parameters.supportsVertexTextures )\n\t\t\t_programLayers.enable( 1 );\n\t\tif ( parameters.instancing )\n\t\t\t_programLayers.enable( 2 );\n\t\tif ( parameters.instancingColor )\n\t\t\t_programLayers.enable( 3 );\n\t\tif ( parameters.map )\n\t\t\t_programLayers.enable( 4 );\n\t\tif ( parameters.matcap )\n\t\t\t_programLayers.enable( 5 );\n\t\tif ( parameters.envMap )\n\t\t\t_programLayers.enable( 6 );\n\t\tif ( parameters.lightMap )\n\t\t\t_programLayers.enable( 7 );\n\t\tif ( parameters.aoMap )\n\t\t\t_programLayers.enable( 8 );\n\t\tif ( parameters.emissiveMap )\n\t\t\t_programLayers.enable( 9 );\n\t\tif ( parameters.bumpMap )\n\t\t\t_programLayers.enable( 10 );\n\t\tif ( parameters.normalMap )\n\t\t\t_programLayers.enable( 11 );\n\t\tif ( parameters.objectSpaceNormalMap )\n\t\t\t_programLayers.enable( 12 );\n\t\tif ( parameters.tangentSpaceNormalMap )\n\t\t\t_programLayers.enable( 13 );\n\t\tif ( parameters.clearcoat )\n\t\t\t_programLayers.enable( 14 );\n\t\tif ( parameters.clearcoatMap )\n\t\t\t_programLayers.enable( 15 );\n\t\tif ( parameters.clearcoatRoughnessMap )\n\t\t\t_programLayers.enable( 16 );\n\t\tif ( parameters.clearcoatNormalMap )\n\t\t\t_programLayers.enable( 17 );\n\t\tif ( parameters.iridescence )\n\t\t\t_programLayers.enable( 18 );\n\t\tif ( parameters.iridescenceMap )\n\t\t\t_programLayers.enable( 19 );\n\t\tif ( parameters.iridescenceThicknessMap )\n\t\t\t_programLayers.enable( 20 );\n\t\tif ( parameters.displacementMap )\n\t\t\t_programLayers.enable( 21 );\n\t\tif ( parameters.specularMap )\n\t\t\t_programLayers.enable( 22 );\n\t\tif ( parameters.roughnessMap )\n\t\t\t_programLayers.enable( 23 );\n\t\tif ( parameters.metalnessMap )\n\t\t\t_programLayers.enable( 24 );\n\t\tif ( parameters.gradientMap )\n\t\t\t_programLayers.enable( 25 );\n\t\tif ( parameters.alphaMap )\n\t\t\t_programLayers.enable( 26 );\n\t\tif ( parameters.alphaTest )\n\t\t\t_programLayers.enable( 27 );\n\t\tif ( parameters.vertexColors )\n\t\t\t_programLayers.enable( 28 );\n\t\tif ( parameters.vertexAlphas )\n\t\t\t_programLayers.enable( 29 );\n\t\tif ( parameters.vertexUvs )\n\t\t\t_programLayers.enable( 30 );\n\t\tif ( parameters.vertexTangents )\n\t\t\t_programLayers.enable( 31 );\n\t\tif ( parameters.uvsVertexOnly )\n\t\t\t_programLayers.enable( 32 );\n\t\tif ( parameters.fog )\n\t\t\t_programLayers.enable( 33 );\n\n\t\tarray.push( _programLayers.mask );\n\t\t_programLayers.disableAll();\n\n\t\tif ( parameters.useFog )\n\t\t\t_programLayers.enable( 0 );\n\t\tif ( parameters.flatShading )\n\t\t\t_programLayers.enable( 1 );\n\t\tif ( parameters.logarithmicDepthBuffer )\n\t\t\t_programLayers.enable( 2 );\n\t\tif ( parameters.skinning )\n\t\t\t_programLayers.enable( 3 );\n\t\tif ( parameters.morphTargets )\n\t\t\t_programLayers.enable( 4 );\n\t\tif ( parameters.morphNormals )\n\t\t\t_programLayers.enable( 5 );\n\t\tif ( parameters.morphColors )\n\t\t\t_programLayers.enable( 6 );\n\t\tif ( parameters.premultipliedAlpha )\n\t\t\t_programLayers.enable( 7 );\n\t\tif ( parameters.shadowMapEnabled )\n\t\t\t_programLayers.enable( 8 );\n\t\tif ( parameters.physicallyCorrectLights )\n\t\t\t_programLayers.enable( 9 );\n\t\tif ( parameters.doubleSided )\n\t\t\t_programLayers.enable( 10 );\n\t\tif ( parameters.flipSided )\n\t\t\t_programLayers.enable( 11 );\n\t\tif ( parameters.useDepthPacking )\n\t\t\t_programLayers.enable( 12 );\n\t\tif ( parameters.dithering )\n\t\t\t_programLayers.enable( 13 );\n\t\tif ( parameters.specularIntensityMap )\n\t\t\t_programLayers.enable( 14 );\n\t\tif ( parameters.specularColorMap )\n\t\t\t_programLayers.enable( 15 );\n\t\tif ( parameters.transmission )\n\t\t\t_programLayers.enable( 16 );\n\t\tif ( parameters.transmissionMap )\n\t\t\t_programLayers.enable( 17 );\n\t\tif ( parameters.thicknessMap )\n\t\t\t_programLayers.enable( 18 );\n\t\tif ( parameters.sheen )\n\t\t\t_programLayers.enable( 19 );\n\t\tif ( parameters.sheenColorMap )\n\t\t\t_programLayers.enable( 20 );\n\t\tif ( parameters.sheenRoughnessMap )\n\t\t\t_programLayers.enable( 21 );\n\t\tif ( parameters.decodeVideoTexture )\n\t\t\t_programLayers.enable( 22 );\n\t\tif ( parameters.opaque )\n\t\t\t_programLayers.enable( 23 );\n\n\t\tarray.push( _programLayers.mask );\n\n\t}\n\n\tfunction getUniforms( material ) {\n\n\t\tconst shaderID = shaderIDs[ material.type ];\n\t\tlet uniforms;\n\n\t\tif ( shaderID ) {\n\n\t\t\tconst shader = ShaderLib[ shaderID ];\n\t\t\tuniforms = UniformsUtils.clone( shader.uniforms );\n\n\t\t} else {\n\n\t\t\tuniforms = material.uniforms;\n\n\t\t}\n\n\t\treturn uniforms;\n\n\t}\n\n\tfunction acquireProgram( parameters, cacheKey ) {\n\n\t\tlet program;\n\n\t\t// Check if code has been already compiled\n\t\tfor ( let p = 0, pl = programs.length; p < pl; p ++ ) {\n\n\t\t\tconst preexistingProgram = programs[ p ];\n\n\t\t\tif ( preexistingProgram.cacheKey === cacheKey ) {\n\n\t\t\t\tprogram = preexistingProgram;\n\t\t\t\t++ program.usedTimes;\n\n\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( program === undefined ) {\n\n\t\t\tprogram = new WebGLProgram( renderer, cacheKey, parameters, bindingStates );\n\t\t\tprograms.push( program );\n\n\t\t}\n\n\t\treturn program;\n\n\t}\n\n\tfunction releaseProgram( program ) {\n\n\t\tif ( -- program.usedTimes === 0 ) {\n\n\t\t\t// Remove from unordered set\n\t\t\tconst i = programs.indexOf( program );\n\t\t\tprograms[ i ] = programs[ programs.length - 1 ];\n\t\t\tprograms.pop();\n\n\t\t\t// Free WebGL resources\n\t\t\tprogram.destroy();\n\n\t\t}\n\n\t}\n\n\tfunction releaseShaderCache( material ) {\n\n\t\t_customShaders.remove( material );\n\n\t}\n\n\tfunction dispose() {\n\n\t\t_customShaders.dispose();\n\n\t}\n\n\treturn {\n\t\tgetParameters: getParameters,\n\t\tgetProgramCacheKey: getProgramCacheKey,\n\t\tgetUniforms: getUniforms,\n\t\tacquireProgram: acquireProgram,\n\t\treleaseProgram: releaseProgram,\n\t\treleaseShaderCache: releaseShaderCache,\n\t\t// Exposed for resource monitoring & error feedback via renderer.info:\n\t\tprograms: programs,\n\t\tdispose: dispose\n\t};\n\n}\n\nfunction WebGLProperties() {\n\n\tlet properties = new WeakMap();\n\n\tfunction get( object ) {\n\n\t\tlet map = properties.get( object );\n\n\t\tif ( map === undefined ) {\n\n\t\t\tmap = {};\n\t\t\tproperties.set( object, map );\n\n\t\t}\n\n\t\treturn map;\n\n\t}\n\n\tfunction remove( object ) {\n\n\t\tproperties.delete( object );\n\n\t}\n\n\tfunction update( object, key, value ) {\n\n\t\tproperties.get( object )[ key ] = value;\n\n\t}\n\n\tfunction dispose() {\n\n\t\tproperties = new WeakMap();\n\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tremove: remove,\n\t\tupdate: update,\n\t\tdispose: dispose\n\t};\n\n}\n\nfunction painterSortStable( a, b ) {\n\n\tif ( a.groupOrder !== b.groupOrder ) {\n\n\t\treturn a.groupOrder - b.groupOrder;\n\n\t} else if ( a.renderOrder !== b.renderOrder ) {\n\n\t\treturn a.renderOrder - b.renderOrder;\n\n\t} else if ( a.material.id !== b.material.id ) {\n\n\t\treturn a.material.id - b.material.id;\n\n\t} else if ( a.z !== b.z ) {\n\n\t\treturn a.z - b.z;\n\n\t} else {\n\n\t\treturn a.id - b.id;\n\n\t}\n\n}\n\nfunction reversePainterSortStable( a, b ) {\n\n\tif ( a.groupOrder !== b.groupOrder ) {\n\n\t\treturn a.groupOrder - b.groupOrder;\n\n\t} else if ( a.renderOrder !== b.renderOrder ) {\n\n\t\treturn a.renderOrder - b.renderOrder;\n\n\t} else if ( a.z !== b.z ) {\n\n\t\treturn b.z - a.z;\n\n\t} else {\n\n\t\treturn a.id - b.id;\n\n\t}\n\n}\n\n\nfunction WebGLRenderList() {\n\n\tconst renderItems = [];\n\tlet renderItemsIndex = 0;\n\n\tconst opaque = [];\n\tconst transmissive = [];\n\tconst transparent = [];\n\n\tfunction init() {\n\n\t\trenderItemsIndex = 0;\n\n\t\topaque.length = 0;\n\t\ttransmissive.length = 0;\n\t\ttransparent.length = 0;\n\n\t}\n\n\tfunction getNextRenderItem( object, geometry, material, groupOrder, z, group ) {\n\n\t\tlet renderItem = renderItems[ renderItemsIndex ];\n\n\t\tif ( renderItem === undefined ) {\n\n\t\t\trenderItem = {\n\t\t\t\tid: object.id,\n\t\t\t\tobject: object,\n\t\t\t\tgeometry: geometry,\n\t\t\t\tmaterial: material,\n\t\t\t\tgroupOrder: groupOrder,\n\t\t\t\trenderOrder: object.renderOrder,\n\t\t\t\tz: z,\n\t\t\t\tgroup: group\n\t\t\t};\n\n\t\t\trenderItems[ renderItemsIndex ] = renderItem;\n\n\t\t} else {\n\n\t\t\trenderItem.id = object.id;\n\t\t\trenderItem.object = object;\n\t\t\trenderItem.geometry = geometry;\n\t\t\trenderItem.material = material;\n\t\t\trenderItem.groupOrder = groupOrder;\n\t\t\trenderItem.renderOrder = object.renderOrder;\n\t\t\trenderItem.z = z;\n\t\t\trenderItem.group = group;\n\n\t\t}\n\n\t\trenderItemsIndex ++;\n\n\t\treturn renderItem;\n\n\t}\n\n\tfunction push( object, geometry, material, groupOrder, z, group ) {\n\n\t\tconst renderItem = getNextRenderItem( object, geometry, material, groupOrder, z, group );\n\n\t\tif ( material.transmission > 0.0 ) {\n\n\t\t\ttransmissive.push( renderItem );\n\n\t\t} else if ( material.transparent === true ) {\n\n\t\t\ttransparent.push( renderItem );\n\n\t\t} else {\n\n\t\t\topaque.push( renderItem );\n\n\t\t}\n\n\t}\n\n\tfunction unshift( object, geometry, material, groupOrder, z, group ) {\n\n\t\tconst renderItem = getNextRenderItem( object, geometry, material, groupOrder, z, group );\n\n\t\tif ( material.transmission > 0.0 ) {\n\n\t\t\ttransmissive.unshift( renderItem );\n\n\t\t} else if ( material.transparent === true ) {\n\n\t\t\ttransparent.unshift( renderItem );\n\n\t\t} else {\n\n\t\t\topaque.unshift( renderItem );\n\n\t\t}\n\n\t}\n\n\tfunction sort( customOpaqueSort, customTransparentSort ) {\n\n\t\tif ( opaque.length > 1 ) opaque.sort( customOpaqueSort || painterSortStable );\n\t\tif ( transmissive.length > 1 ) transmissive.sort( customTransparentSort || reversePainterSortStable );\n\t\tif ( transparent.length > 1 ) transparent.sort( customTransparentSort || reversePainterSortStable );\n\n\t}\n\n\tfunction finish() {\n\n\t\t// Clear references from inactive renderItems in the list\n\n\t\tfor ( let i = renderItemsIndex, il = renderItems.length; i < il; i ++ ) {\n\n\t\t\tconst renderItem = renderItems[ i ];\n\n\t\t\tif ( renderItem.id === null ) break;\n\n\t\t\trenderItem.id = null;\n\t\t\trenderItem.object = null;\n\t\t\trenderItem.geometry = null;\n\t\t\trenderItem.material = null;\n\t\t\trenderItem.group = null;\n\n\t\t}\n\n\t}\n\n\treturn {\n\n\t\topaque: opaque,\n\t\ttransmissive: transmissive,\n\t\ttransparent: transparent,\n\n\t\tinit: init,\n\t\tpush: push,\n\t\tunshift: unshift,\n\t\tfinish: finish,\n\n\t\tsort: sort\n\t};\n\n}\n\nfunction WebGLRenderLists() {\n\n\tlet lists = new WeakMap();\n\n\tfunction get( scene, renderCallDepth ) {\n\n\t\tlet list;\n\n\t\tif ( lists.has( scene ) === false ) {\n\n\t\t\tlist = new WebGLRenderList();\n\t\t\tlists.set( scene, [ list ] );\n\n\t\t} else {\n\n\t\t\tif ( renderCallDepth >= lists.get( scene ).length ) {\n\n\t\t\t\tlist = new WebGLRenderList();\n\t\t\t\tlists.get( scene ).push( list );\n\n\t\t\t} else {\n\n\t\t\t\tlist = lists.get( scene )[ renderCallDepth ];\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn list;\n\n\t}\n\n\tfunction dispose() {\n\n\t\tlists = new WeakMap();\n\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tdispose: dispose\n\t};\n\n}\n\nfunction UniformsCache() {\n\n\tconst lights = {};\n\n\treturn {\n\n\t\tget: function ( light ) {\n\n\t\t\tif ( lights[ light.id ] !== undefined ) {\n\n\t\t\t\treturn lights[ light.id ];\n\n\t\t\t}\n\n\t\t\tlet uniforms;\n\n\t\t\tswitch ( light.type ) {\n\n\t\t\t\tcase 'DirectionalLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tdirection: new Vector3(),\n\t\t\t\t\t\tcolor: new Color()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'SpotLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tposition: new Vector3(),\n\t\t\t\t\t\tdirection: new Vector3(),\n\t\t\t\t\t\tcolor: new Color(),\n\t\t\t\t\t\tdistance: 0,\n\t\t\t\t\t\tconeCos: 0,\n\t\t\t\t\t\tpenumbraCos: 0,\n\t\t\t\t\t\tdecay: 0\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'PointLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tposition: new Vector3(),\n\t\t\t\t\t\tcolor: new Color(),\n\t\t\t\t\t\tdistance: 0,\n\t\t\t\t\t\tdecay: 0\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'HemisphereLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tdirection: new Vector3(),\n\t\t\t\t\t\tskyColor: new Color(),\n\t\t\t\t\t\tgroundColor: new Color()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'RectAreaLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tcolor: new Color(),\n\t\t\t\t\t\tposition: new Vector3(),\n\t\t\t\t\t\thalfWidth: new Vector3(),\n\t\t\t\t\t\thalfHeight: new Vector3()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t\tlights[ light.id ] = uniforms;\n\n\t\t\treturn uniforms;\n\n\t\t}\n\n\t};\n\n}\n\nfunction ShadowUniformsCache() {\n\n\tconst lights = {};\n\n\treturn {\n\n\t\tget: function ( light ) {\n\n\t\t\tif ( lights[ light.id ] !== undefined ) {\n\n\t\t\t\treturn lights[ light.id ];\n\n\t\t\t}\n\n\t\t\tlet uniforms;\n\n\t\t\tswitch ( light.type ) {\n\n\t\t\t\tcase 'DirectionalLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tshadowBias: 0,\n\t\t\t\t\t\tshadowNormalBias: 0,\n\t\t\t\t\t\tshadowRadius: 1,\n\t\t\t\t\t\tshadowMapSize: new Vector2()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'SpotLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tshadowBias: 0,\n\t\t\t\t\t\tshadowNormalBias: 0,\n\t\t\t\t\t\tshadowRadius: 1,\n\t\t\t\t\t\tshadowMapSize: new Vector2()\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'PointLight':\n\t\t\t\t\tuniforms = {\n\t\t\t\t\t\tshadowBias: 0,\n\t\t\t\t\t\tshadowNormalBias: 0,\n\t\t\t\t\t\tshadowRadius: 1,\n\t\t\t\t\t\tshadowMapSize: new Vector2(),\n\t\t\t\t\t\tshadowCameraNear: 1,\n\t\t\t\t\t\tshadowCameraFar: 1000\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\t// TODO (abelnation): set RectAreaLight shadow uniforms\n\n\t\t\t}\n\n\t\t\tlights[ light.id ] = uniforms;\n\n\t\t\treturn uniforms;\n\n\t\t}\n\n\t};\n\n}\n\n\n\nlet nextVersion = 0;\n\nfunction shadowCastingLightsFirst( lightA, lightB ) {\n\n\treturn ( lightB.castShadow ? 1 : 0 ) - ( lightA.castShadow ? 1 : 0 );\n\n}\n\nfunction WebGLLights( extensions, capabilities ) {\n\n\tconst cache = new UniformsCache();\n\n\tconst shadowCache = ShadowUniformsCache();\n\n\tconst state = {\n\n\t\tversion: 0,\n\n\t\thash: {\n\t\t\tdirectionalLength: - 1,\n\t\t\tpointLength: - 1,\n\t\t\tspotLength: - 1,\n\t\t\trectAreaLength: - 1,\n\t\t\themiLength: - 1,\n\n\t\t\tnumDirectionalShadows: - 1,\n\t\t\tnumPointShadows: - 1,\n\t\t\tnumSpotShadows: - 1\n\t\t},\n\n\t\tambient: [ 0, 0, 0 ],\n\t\tprobe: [],\n\t\tdirectional: [],\n\t\tdirectionalShadow: [],\n\t\tdirectionalShadowMap: [],\n\t\tdirectionalShadowMatrix: [],\n\t\tspot: [],\n\t\tspotShadow: [],\n\t\tspotShadowMap: [],\n\t\tspotShadowMatrix: [],\n\t\trectArea: [],\n\t\trectAreaLTC1: null,\n\t\trectAreaLTC2: null,\n\t\tpoint: [],\n\t\tpointShadow: [],\n\t\tpointShadowMap: [],\n\t\tpointShadowMatrix: [],\n\t\themi: []\n\n\t};\n\n\tfor ( let i = 0; i < 9; i ++ ) state.probe.push( new Vector3() );\n\n\tconst vector3 = new Vector3();\n\tconst matrix4 = new Matrix4();\n\tconst matrix42 = new Matrix4();\n\n\tfunction setup( lights, physicallyCorrectLights ) {\n\n\t\tlet r = 0, g = 0, b = 0;\n\n\t\tfor ( let i = 0; i < 9; i ++ ) state.probe[ i ].set( 0, 0, 0 );\n\n\t\tlet directionalLength = 0;\n\t\tlet pointLength = 0;\n\t\tlet spotLength = 0;\n\t\tlet rectAreaLength = 0;\n\t\tlet hemiLength = 0;\n\n\t\tlet numDirectionalShadows = 0;\n\t\tlet numPointShadows = 0;\n\t\tlet numSpotShadows = 0;\n\n\t\tlights.sort( shadowCastingLightsFirst );\n\n\t\t// artist-friendly light intensity scaling factor\n\t\tconst scaleFactor = ( physicallyCorrectLights !== true ) ? Math.PI : 1;\n\n\t\tfor ( let i = 0, l = lights.length; i < l; i ++ ) {\n\n\t\t\tconst light = lights[ i ];\n\n\t\t\tconst color = light.color;\n\t\t\tconst intensity = light.intensity;\n\t\t\tconst distance = light.distance;\n\n\t\t\tconst shadowMap = ( light.shadow && light.shadow.map ) ? light.shadow.map.texture : null;\n\n\t\t\tif ( light.isAmbientLight ) {\n\n\t\t\t\tr += color.r * intensity * scaleFactor;\n\t\t\t\tg += color.g * intensity * scaleFactor;\n\t\t\t\tb += color.b * intensity * scaleFactor;\n\n\t\t\t} else if ( light.isLightProbe ) {\n\n\t\t\t\tfor ( let j = 0; j < 9; j ++ ) {\n\n\t\t\t\t\tstate.probe[ j ].addScaledVector( light.sh.coefficients[ j ], intensity );\n\n\t\t\t\t}\n\n\t\t\t} else if ( light.isDirectionalLight ) {\n\n\t\t\t\tconst uniforms = cache.get( light );\n\n\t\t\t\tuniforms.color.copy( light.color ).multiplyScalar( light.intensity * scaleFactor );\n\n\t\t\t\tif ( light.castShadow ) {\n\n\t\t\t\t\tconst shadow = light.shadow;\n\n\t\t\t\t\tconst shadowUniforms = shadowCache.get( light );\n\n\t\t\t\t\tshadowUniforms.shadowBias = shadow.bias;\n\t\t\t\t\tshadowUniforms.shadowNormalBias = shadow.normalBias;\n\t\t\t\t\tshadowUniforms.shadowRadius = shadow.radius;\n\t\t\t\t\tshadowUniforms.shadowMapSize = shadow.mapSize;\n\n\t\t\t\t\tstate.directionalShadow[ directionalLength ] = shadowUniforms;\n\t\t\t\t\tstate.directionalShadowMap[ directionalLength ] = shadowMap;\n\t\t\t\t\tstate.directionalShadowMatrix[ directionalLength ] = light.shadow.matrix;\n\n\t\t\t\t\tnumDirectionalShadows ++;\n\n\t\t\t\t}\n\n\t\t\t\tstate.directional[ directionalLength ] = uniforms;\n\n\t\t\t\tdirectionalLength ++;\n\n\t\t\t} else if ( light.isSpotLight ) {\n\n\t\t\t\tconst uniforms = cache.get( light );\n\n\t\t\t\tuniforms.position.setFromMatrixPosition( light.matrixWorld );\n\n\t\t\t\tuniforms.color.copy( color ).multiplyScalar( intensity * scaleFactor );\n\t\t\t\tuniforms.distance = distance;\n\n\t\t\t\tuniforms.coneCos = Math.cos( light.angle );\n\t\t\t\tuniforms.penumbraCos = Math.cos( light.angle * ( 1 - light.penumbra ) );\n\t\t\t\tuniforms.decay = light.decay;\n\n\t\t\t\tif ( light.castShadow ) {\n\n\t\t\t\t\tconst shadow = light.shadow;\n\n\t\t\t\t\tconst shadowUniforms = shadowCache.get( light );\n\n\t\t\t\t\tshadowUniforms.shadowBias = shadow.bias;\n\t\t\t\t\tshadowUniforms.shadowNormalBias = shadow.normalBias;\n\t\t\t\t\tshadowUniforms.shadowRadius = shadow.radius;\n\t\t\t\t\tshadowUniforms.shadowMapSize = shadow.mapSize;\n\n\t\t\t\t\tstate.spotShadow[ spotLength ] = shadowUniforms;\n\t\t\t\t\tstate.spotShadowMap[ spotLength ] = shadowMap;\n\t\t\t\t\tstate.spotShadowMatrix[ spotLength ] = light.shadow.matrix;\n\n\t\t\t\t\tnumSpotShadows ++;\n\n\t\t\t\t}\n\n\t\t\t\tstate.spot[ spotLength ] = uniforms;\n\n\t\t\t\tspotLength ++;\n\n\t\t\t} else if ( light.isRectAreaLight ) {\n\n\t\t\t\tconst uniforms = cache.get( light );\n\n\t\t\t\t// (a) intensity is the total visible light emitted\n\t\t\t\t//uniforms.color.copy( color ).multiplyScalar( intensity / ( light.width * light.height * Math.PI ) );\n\n\t\t\t\t// (b) intensity is the brightness of the light\n\t\t\t\tuniforms.color.copy( color ).multiplyScalar( intensity );\n\n\t\t\t\tuniforms.halfWidth.set( light.width * 0.5, 0.0, 0.0 );\n\t\t\t\tuniforms.halfHeight.set( 0.0, light.height * 0.5, 0.0 );\n\n\t\t\t\tstate.rectArea[ rectAreaLength ] = uniforms;\n\n\t\t\t\trectAreaLength ++;\n\n\t\t\t} else if ( light.isPointLight ) {\n\n\t\t\t\tconst uniforms = cache.get( light );\n\n\t\t\t\tuniforms.color.copy( light.color ).multiplyScalar( light.intensity * scaleFactor );\n\t\t\t\tuniforms.distance = light.distance;\n\t\t\t\tuniforms.decay = light.decay;\n\n\t\t\t\tif ( light.castShadow ) {\n\n\t\t\t\t\tconst shadow = light.shadow;\n\n\t\t\t\t\tconst shadowUniforms = shadowCache.get( light );\n\n\t\t\t\t\tshadowUniforms.shadowBias = shadow.bias;\n\t\t\t\t\tshadowUniforms.shadowNormalBias = shadow.normalBias;\n\t\t\t\t\tshadowUniforms.shadowRadius = shadow.radius;\n\t\t\t\t\tshadowUniforms.shadowMapSize = shadow.mapSize;\n\t\t\t\t\tshadowUniforms.shadowCameraNear = shadow.camera.near;\n\t\t\t\t\tshadowUniforms.shadowCameraFar = shadow.camera.far;\n\n\t\t\t\t\tstate.pointShadow[ pointLength ] = shadowUniforms;\n\t\t\t\t\tstate.pointShadowMap[ pointLength ] = shadowMap;\n\t\t\t\t\tstate.pointShadowMatrix[ pointLength ] = light.shadow.matrix;\n\n\t\t\t\t\tnumPointShadows ++;\n\n\t\t\t\t}\n\n\t\t\t\tstate.point[ pointLength ] = uniforms;\n\n\t\t\t\tpointLength ++;\n\n\t\t\t} else if ( light.isHemisphereLight ) {\n\n\t\t\t\tconst uniforms = cache.get( light );\n\n\t\t\t\tuniforms.skyColor.copy( light.color ).multiplyScalar( intensity * scaleFactor );\n\t\t\t\tuniforms.groundColor.copy( light.groundColor ).multiplyScalar( intensity * scaleFactor );\n\n\t\t\t\tstate.hemi[ hemiLength ] = uniforms;\n\n\t\t\t\themiLength ++;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( rectAreaLength > 0 ) {\n\n\t\t\tif ( capabilities.isWebGL2 ) {\n\n\t\t\t\t// WebGL 2\n\n\t\t\t\tstate.rectAreaLTC1 = UniformsLib.LTC_FLOAT_1;\n\t\t\t\tstate.rectAreaLTC2 = UniformsLib.LTC_FLOAT_2;\n\n\t\t\t} else {\n\n\t\t\t\t// WebGL 1\n\n\t\t\t\tif ( extensions.has( 'OES_texture_float_linear' ) === true ) {\n\n\t\t\t\t\tstate.rectAreaLTC1 = UniformsLib.LTC_FLOAT_1;\n\t\t\t\t\tstate.rectAreaLTC2 = UniformsLib.LTC_FLOAT_2;\n\n\t\t\t\t} else if ( extensions.has( 'OES_texture_half_float_linear' ) === true ) {\n\n\t\t\t\t\tstate.rectAreaLTC1 = UniformsLib.LTC_HALF_1;\n\t\t\t\t\tstate.rectAreaLTC2 = UniformsLib.LTC_HALF_2;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.error( 'THREE.WebGLRenderer: Unable to use RectAreaLight. Missing WebGL extensions.' );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tstate.ambient[ 0 ] = r;\n\t\tstate.ambient[ 1 ] = g;\n\t\tstate.ambient[ 2 ] = b;\n\n\t\tconst hash = state.hash;\n\n\t\tif ( hash.directionalLength !== directionalLength ||\n\t\t\thash.pointLength !== pointLength ||\n\t\t\thash.spotLength !== spotLength ||\n\t\t\thash.rectAreaLength !== rectAreaLength ||\n\t\t\thash.hemiLength !== hemiLength ||\n\t\t\thash.numDirectionalShadows !== numDirectionalShadows ||\n\t\t\thash.numPointShadows !== numPointShadows ||\n\t\t\thash.numSpotShadows !== numSpotShadows ) {\n\n\t\t\tstate.directional.length = directionalLength;\n\t\t\tstate.spot.length = spotLength;\n\t\t\tstate.rectArea.length = rectAreaLength;\n\t\t\tstate.point.length = pointLength;\n\t\t\tstate.hemi.length = hemiLength;\n\n\t\t\tstate.directionalShadow.length = numDirectionalShadows;\n\t\t\tstate.directionalShadowMap.length = numDirectionalShadows;\n\t\t\tstate.pointShadow.length = numPointShadows;\n\t\t\tstate.pointShadowMap.length = numPointShadows;\n\t\t\tstate.spotShadow.length = numSpotShadows;\n\t\t\tstate.spotShadowMap.length = numSpotShadows;\n\t\t\tstate.directionalShadowMatrix.length = numDirectionalShadows;\n\t\t\tstate.pointShadowMatrix.length = numPointShadows;\n\t\t\tstate.spotShadowMatrix.length = numSpotShadows;\n\n\t\t\thash.directionalLength = directionalLength;\n\t\t\thash.pointLength = pointLength;\n\t\t\thash.spotLength = spotLength;\n\t\t\thash.rectAreaLength = rectAreaLength;\n\t\t\thash.hemiLength = hemiLength;\n\n\t\t\thash.numDirectionalShadows = numDirectionalShadows;\n\t\t\thash.numPointShadows = numPointShadows;\n\t\t\thash.numSpotShadows = numSpotShadows;\n\n\t\t\tstate.version = nextVersion ++;\n\n\t\t}\n\n\t}\n\n\tfunction setupView( lights, camera ) {\n\n\t\tlet directionalLength = 0;\n\t\tlet pointLength = 0;\n\t\tlet spotLength = 0;\n\t\tlet rectAreaLength = 0;\n\t\tlet hemiLength = 0;\n\n\t\tconst viewMatrix = camera.matrixWorldInverse;\n\n\t\tfor ( let i = 0, l = lights.length; i < l; i ++ ) {\n\n\t\t\tconst light = lights[ i ];\n\n\t\t\tif ( light.isDirectionalLight ) {\n\n\t\t\t\tconst uniforms = state.directional[ directionalLength ];\n\n\t\t\t\tuniforms.direction.setFromMatrixPosition( light.matrixWorld );\n\t\t\t\tvector3.setFromMatrixPosition( light.target.matrixWorld );\n\t\t\t\tuniforms.direction.sub( vector3 );\n\t\t\t\tuniforms.direction.transformDirection( viewMatrix );\n\n\t\t\t\tdirectionalLength ++;\n\n\t\t\t} else if ( light.isSpotLight ) {\n\n\t\t\t\tconst uniforms = state.spot[ spotLength ];\n\n\t\t\t\tuniforms.position.setFromMatrixPosition( light.matrixWorld );\n\t\t\t\tuniforms.position.applyMatrix4( viewMatrix );\n\n\t\t\t\tuniforms.direction.setFromMatrixPosition( light.matrixWorld );\n\t\t\t\tvector3.setFromMatrixPosition( light.target.matrixWorld );\n\t\t\t\tuniforms.direction.sub( vector3 );\n\t\t\t\tuniforms.direction.transformDirection( viewMatrix );\n\n\t\t\t\tspotLength ++;\n\n\t\t\t} else if ( light.isRectAreaLight ) {\n\n\t\t\t\tconst uniforms = state.rectArea[ rectAreaLength ];\n\n\t\t\t\tuniforms.position.setFromMatrixPosition( light.matrixWorld );\n\t\t\t\tuniforms.position.applyMatrix4( viewMatrix );\n\n\t\t\t\t// extract local rotation of light to derive width/height half vectors\n\t\t\t\tmatrix42.identity();\n\t\t\t\tmatrix4.copy( light.matrixWorld );\n\t\t\t\tmatrix4.premultiply( viewMatrix );\n\t\t\t\tmatrix42.extractRotation( matrix4 );\n\n\t\t\t\tuniforms.halfWidth.set( light.width * 0.5, 0.0, 0.0 );\n\t\t\t\tuniforms.halfHeight.set( 0.0, light.height * 0.5, 0.0 );\n\n\t\t\t\tuniforms.halfWidth.applyMatrix4( matrix42 );\n\t\t\t\tuniforms.halfHeight.applyMatrix4( matrix42 );\n\n\t\t\t\trectAreaLength ++;\n\n\t\t\t} else if ( light.isPointLight ) {\n\n\t\t\t\tconst uniforms = state.point[ pointLength ];\n\n\t\t\t\tuniforms.position.setFromMatrixPosition( light.matrixWorld );\n\t\t\t\tuniforms.position.applyMatrix4( viewMatrix );\n\n\t\t\t\tpointLength ++;\n\n\t\t\t} else if ( light.isHemisphereLight ) {\n\n\t\t\t\tconst uniforms = state.hemi[ hemiLength ];\n\n\t\t\t\tuniforms.direction.setFromMatrixPosition( light.matrixWorld );\n\t\t\t\tuniforms.direction.transformDirection( viewMatrix );\n\n\t\t\t\themiLength ++;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\treturn {\n\t\tsetup: setup,\n\t\tsetupView: setupView,\n\t\tstate: state\n\t};\n\n}\n\nfunction WebGLRenderState( extensions, capabilities ) {\n\n\tconst lights = new WebGLLights( extensions, capabilities );\n\n\tconst lightsArray = [];\n\tconst shadowsArray = [];\n\n\tfunction init() {\n\n\t\tlightsArray.length = 0;\n\t\tshadowsArray.length = 0;\n\n\t}\n\n\tfunction pushLight( light ) {\n\n\t\tlightsArray.push( light );\n\n\t}\n\n\tfunction pushShadow( shadowLight ) {\n\n\t\tshadowsArray.push( shadowLight );\n\n\t}\n\n\tfunction setupLights( physicallyCorrectLights ) {\n\n\t\tlights.setup( lightsArray, physicallyCorrectLights );\n\n\t}\n\n\tfunction setupLightsView( camera ) {\n\n\t\tlights.setupView( lightsArray, camera );\n\n\t}\n\n\tconst state = {\n\t\tlightsArray: lightsArray,\n\t\tshadowsArray: shadowsArray,\n\n\t\tlights: lights\n\t};\n\n\treturn {\n\t\tinit: init,\n\t\tstate: state,\n\t\tsetupLights: setupLights,\n\t\tsetupLightsView: setupLightsView,\n\n\t\tpushLight: pushLight,\n\t\tpushShadow: pushShadow\n\t};\n\n}\n\nfunction WebGLRenderStates( extensions, capabilities ) {\n\n\tlet renderStates = new WeakMap();\n\n\tfunction get( scene, renderCallDepth = 0 ) {\n\n\t\tlet renderState;\n\n\t\tif ( renderStates.has( scene ) === false ) {\n\n\t\t\trenderState = new WebGLRenderState( extensions, capabilities );\n\t\t\trenderStates.set( scene, [ renderState ] );\n\n\t\t} else {\n\n\t\t\tif ( renderCallDepth >= renderStates.get( scene ).length ) {\n\n\t\t\t\trenderState = new WebGLRenderState( extensions, capabilities );\n\t\t\t\trenderStates.get( scene ).push( renderState );\n\n\t\t\t} else {\n\n\t\t\t\trenderState = renderStates.get( scene )[ renderCallDepth ];\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn renderState;\n\n\t}\n\n\tfunction dispose() {\n\n\t\trenderStates = new WeakMap();\n\n\t}\n\n\treturn {\n\t\tget: get,\n\t\tdispose: dispose\n\t};\n\n}\n\nclass MeshDepthMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isMeshDepthMaterial = true;\n\n\t\tthis.type = 'MeshDepthMaterial';\n\n\t\tthis.depthPacking = BasicDepthPacking;\n\n\t\tthis.map = null;\n\n\t\tthis.alphaMap = null;\n\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.depthPacking = source.depthPacking;\n\n\t\tthis.map = source.map;\n\n\t\tthis.alphaMap = source.alphaMap;\n\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass MeshDistanceMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isMeshDistanceMaterial = true;\n\n\t\tthis.type = 'MeshDistanceMaterial';\n\n\t\tthis.referencePosition = new Vector3();\n\t\tthis.nearDistance = 1;\n\t\tthis.farDistance = 1000;\n\n\t\tthis.map = null;\n\n\t\tthis.alphaMap = null;\n\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.referencePosition.copy( source.referencePosition );\n\t\tthis.nearDistance = source.nearDistance;\n\t\tthis.farDistance = source.farDistance;\n\n\t\tthis.map = source.map;\n\n\t\tthis.alphaMap = source.alphaMap;\n\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\n\t\treturn this;\n\n\t}\n\n}\n\nconst vertex = \"void main() {\\n\\tgl_Position = vec4( position, 1.0 );\\n}\";\n\nconst fragment = \"uniform sampler2D shadow_pass;\\nuniform vec2 resolution;\\nuniform float radius;\\n#include \\nvoid main() {\\n\\tconst float samples = float( VSM_SAMPLES );\\n\\tfloat mean = 0.0;\\n\\tfloat squared_mean = 0.0;\\n\\tfloat uvStride = samples <= 1.0 ? 0.0 : 2.0 / ( samples - 1.0 );\\n\\tfloat uvStart = samples <= 1.0 ? 0.0 : - 1.0;\\n\\tfor ( float i = 0.0; i < samples; i ++ ) {\\n\\t\\tfloat uvOffset = uvStart + i * uvStride;\\n\\t\\t#ifdef HORIZONTAL_PASS\\n\\t\\t\\tvec2 distribution = unpackRGBATo2Half( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( uvOffset, 0.0 ) * radius ) / resolution ) );\\n\\t\\t\\tmean += distribution.x;\\n\\t\\t\\tsquared_mean += distribution.y * distribution.y + distribution.x * distribution.x;\\n\\t\\t#else\\n\\t\\t\\tfloat depth = unpackRGBAToDepth( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( 0.0, uvOffset ) * radius ) / resolution ) );\\n\\t\\t\\tmean += depth;\\n\\t\\t\\tsquared_mean += depth * depth;\\n\\t\\t#endif\\n\\t}\\n\\tmean = mean / samples;\\n\\tsquared_mean = squared_mean / samples;\\n\\tfloat std_dev = sqrt( squared_mean - mean * mean );\\n\\tgl_FragColor = pack2HalfToRGBA( vec2( mean, std_dev ) );\\n}\";\n\nfunction WebGLShadowMap( _renderer, _objects, _capabilities ) {\n\n\tlet _frustum = new Frustum();\n\n\tconst _shadowMapSize = new Vector2(),\n\t\t_viewportSize = new Vector2(),\n\n\t\t_viewport = new Vector4(),\n\n\t\t_depthMaterial = new MeshDepthMaterial( { depthPacking: RGBADepthPacking } ),\n\t\t_distanceMaterial = new MeshDistanceMaterial(),\n\n\t\t_materialCache = {},\n\n\t\t_maxTextureSize = _capabilities.maxTextureSize;\n\n\tconst shadowSide = { 0: BackSide, 1: FrontSide, 2: DoubleSide };\n\n\tconst shadowMaterialVertical = new ShaderMaterial( {\n\t\tdefines: {\n\t\t\tVSM_SAMPLES: 8\n\t\t},\n\t\tuniforms: {\n\t\t\tshadow_pass: { value: null },\n\t\t\tresolution: { value: new Vector2() },\n\t\t\tradius: { value: 4.0 }\n\t\t},\n\n\t\tvertexShader: vertex,\n\t\tfragmentShader: fragment\n\n\t} );\n\n\tconst shadowMaterialHorizontal = shadowMaterialVertical.clone();\n\tshadowMaterialHorizontal.defines.HORIZONTAL_PASS = 1;\n\n\tconst fullScreenTri = new BufferGeometry();\n\tfullScreenTri.setAttribute(\n\t\t'position',\n\t\tnew BufferAttribute(\n\t\t\tnew Float32Array( [ - 1, - 1, 0.5, 3, - 1, 0.5, - 1, 3, 0.5 ] ),\n\t\t\t3\n\t\t)\n\t);\n\n\tconst fullScreenMesh = new Mesh( fullScreenTri, shadowMaterialVertical );\n\n\tconst scope = this;\n\n\tthis.enabled = false;\n\n\tthis.autoUpdate = true;\n\tthis.needsUpdate = false;\n\n\tthis.type = PCFShadowMap;\n\n\tthis.render = function ( lights, scene, camera ) {\n\n\t\tif ( scope.enabled === false ) return;\n\t\tif ( scope.autoUpdate === false && scope.needsUpdate === false ) return;\n\n\t\tif ( lights.length === 0 ) return;\n\n\t\tconst currentRenderTarget = _renderer.getRenderTarget();\n\t\tconst activeCubeFace = _renderer.getActiveCubeFace();\n\t\tconst activeMipmapLevel = _renderer.getActiveMipmapLevel();\n\n\t\tconst _state = _renderer.state;\n\n\t\t// Set GL state for depth map.\n\t\t_state.setBlending( NoBlending );\n\t\t_state.buffers.color.setClear( 1, 1, 1, 1 );\n\t\t_state.buffers.depth.setTest( true );\n\t\t_state.setScissorTest( false );\n\n\t\t// render depth map\n\n\t\tfor ( let i = 0, il = lights.length; i < il; i ++ ) {\n\n\t\t\tconst light = lights[ i ];\n\t\t\tconst shadow = light.shadow;\n\n\t\t\tif ( shadow === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLShadowMap:', light, 'has no shadow.' );\n\t\t\t\tcontinue;\n\n\t\t\t}\n\n\t\t\tif ( shadow.autoUpdate === false && shadow.needsUpdate === false ) continue;\n\n\t\t\t_shadowMapSize.copy( shadow.mapSize );\n\n\t\t\tconst shadowFrameExtents = shadow.getFrameExtents();\n\n\t\t\t_shadowMapSize.multiply( shadowFrameExtents );\n\n\t\t\t_viewportSize.copy( shadow.mapSize );\n\n\t\t\tif ( _shadowMapSize.x > _maxTextureSize || _shadowMapSize.y > _maxTextureSize ) {\n\n\t\t\t\tif ( _shadowMapSize.x > _maxTextureSize ) {\n\n\t\t\t\t\t_viewportSize.x = Math.floor( _maxTextureSize / shadowFrameExtents.x );\n\t\t\t\t\t_shadowMapSize.x = _viewportSize.x * shadowFrameExtents.x;\n\t\t\t\t\tshadow.mapSize.x = _viewportSize.x;\n\n\t\t\t\t}\n\n\t\t\t\tif ( _shadowMapSize.y > _maxTextureSize ) {\n\n\t\t\t\t\t_viewportSize.y = Math.floor( _maxTextureSize / shadowFrameExtents.y );\n\t\t\t\t\t_shadowMapSize.y = _viewportSize.y * shadowFrameExtents.y;\n\t\t\t\t\tshadow.mapSize.y = _viewportSize.y;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( shadow.map === null && ! shadow.isPointLightShadow && this.type === VSMShadowMap ) {\n\n\t\t\t\tshadow.map = new WebGLRenderTarget( _shadowMapSize.x, _shadowMapSize.y );\n\t\t\t\tshadow.map.texture.name = light.name + '.shadowMap';\n\n\t\t\t\tshadow.mapPass = new WebGLRenderTarget( _shadowMapSize.x, _shadowMapSize.y );\n\n\t\t\t\tshadow.camera.updateProjectionMatrix();\n\n\t\t\t}\n\n\t\t\tif ( shadow.map === null ) {\n\n\t\t\t\tconst pars = { minFilter: NearestFilter, magFilter: NearestFilter, format: RGBAFormat };\n\n\t\t\t\tshadow.map = new WebGLRenderTarget( _shadowMapSize.x, _shadowMapSize.y, pars );\n\t\t\t\tshadow.map.texture.name = light.name + '.shadowMap';\n\n\t\t\t\tshadow.camera.updateProjectionMatrix();\n\n\t\t\t}\n\n\t\t\t_renderer.setRenderTarget( shadow.map );\n\t\t\t_renderer.clear();\n\n\t\t\tconst viewportCount = shadow.getViewportCount();\n\n\t\t\tfor ( let vp = 0; vp < viewportCount; vp ++ ) {\n\n\t\t\t\tconst viewport = shadow.getViewport( vp );\n\n\t\t\t\t_viewport.set(\n\t\t\t\t\t_viewportSize.x * viewport.x,\n\t\t\t\t\t_viewportSize.y * viewport.y,\n\t\t\t\t\t_viewportSize.x * viewport.z,\n\t\t\t\t\t_viewportSize.y * viewport.w\n\t\t\t\t);\n\n\t\t\t\t_state.viewport( _viewport );\n\n\t\t\t\tshadow.updateMatrices( light, vp );\n\n\t\t\t\t_frustum = shadow.getFrustum();\n\n\t\t\t\trenderObject( scene, camera, shadow.camera, light, this.type );\n\n\t\t\t}\n\n\t\t\t// do blur pass for VSM\n\n\t\t\tif ( ! shadow.isPointLightShadow && this.type === VSMShadowMap ) {\n\n\t\t\t\tVSMPass( shadow, camera );\n\n\t\t\t}\n\n\t\t\tshadow.needsUpdate = false;\n\n\t\t}\n\n\t\tscope.needsUpdate = false;\n\n\t\t_renderer.setRenderTarget( currentRenderTarget, activeCubeFace, activeMipmapLevel );\n\n\t};\n\n\tfunction VSMPass( shadow, camera ) {\n\n\t\tconst geometry = _objects.update( fullScreenMesh );\n\n\t\tif ( shadowMaterialVertical.defines.VSM_SAMPLES !== shadow.blurSamples ) {\n\n\t\t\tshadowMaterialVertical.defines.VSM_SAMPLES = shadow.blurSamples;\n\t\t\tshadowMaterialHorizontal.defines.VSM_SAMPLES = shadow.blurSamples;\n\n\t\t\tshadowMaterialVertical.needsUpdate = true;\n\t\t\tshadowMaterialHorizontal.needsUpdate = true;\n\n\t\t}\n\n\t\t// vertical pass\n\n\t\tshadowMaterialVertical.uniforms.shadow_pass.value = shadow.map.texture;\n\t\tshadowMaterialVertical.uniforms.resolution.value = shadow.mapSize;\n\t\tshadowMaterialVertical.uniforms.radius.value = shadow.radius;\n\t\t_renderer.setRenderTarget( shadow.mapPass );\n\t\t_renderer.clear();\n\t\t_renderer.renderBufferDirect( camera, null, geometry, shadowMaterialVertical, fullScreenMesh, null );\n\n\t\t// horizontal pass\n\n\t\tshadowMaterialHorizontal.uniforms.shadow_pass.value = shadow.mapPass.texture;\n\t\tshadowMaterialHorizontal.uniforms.resolution.value = shadow.mapSize;\n\t\tshadowMaterialHorizontal.uniforms.radius.value = shadow.radius;\n\t\t_renderer.setRenderTarget( shadow.map );\n\t\t_renderer.clear();\n\t\t_renderer.renderBufferDirect( camera, null, geometry, shadowMaterialHorizontal, fullScreenMesh, null );\n\n\t}\n\n\tfunction getDepthMaterial( object, material, light, shadowCameraNear, shadowCameraFar, type ) {\n\n\t\tlet result = null;\n\n\t\tconst customMaterial = ( light.isPointLight === true ) ? object.customDistanceMaterial : object.customDepthMaterial;\n\n\t\tif ( customMaterial !== undefined ) {\n\n\t\t\tresult = customMaterial;\n\n\t\t} else {\n\n\t\t\tresult = ( light.isPointLight === true ) ? _distanceMaterial : _depthMaterial;\n\n\t\t}\n\n\t\tif ( ( _renderer.localClippingEnabled && material.clipShadows === true && material.clippingPlanes.length !== 0 ) ||\n\t\t\t( material.displacementMap && material.displacementScale !== 0 ) ||\n\t\t\t( material.alphaMap && material.alphaTest > 0 ) ) {\n\n\t\t\t// in this case we need a unique material instance reflecting the\n\t\t\t// appropriate state\n\n\t\t\tconst keyA = result.uuid, keyB = material.uuid;\n\n\t\t\tlet materialsForVariant = _materialCache[ keyA ];\n\n\t\t\tif ( materialsForVariant === undefined ) {\n\n\t\t\t\tmaterialsForVariant = {};\n\t\t\t\t_materialCache[ keyA ] = materialsForVariant;\n\n\t\t\t}\n\n\t\t\tlet cachedMaterial = materialsForVariant[ keyB ];\n\n\t\t\tif ( cachedMaterial === undefined ) {\n\n\t\t\t\tcachedMaterial = result.clone();\n\t\t\t\tmaterialsForVariant[ keyB ] = cachedMaterial;\n\n\t\t\t}\n\n\t\t\tresult = cachedMaterial;\n\n\t\t}\n\n\t\tresult.visible = material.visible;\n\t\tresult.wireframe = material.wireframe;\n\n\t\tif ( type === VSMShadowMap ) {\n\n\t\t\tresult.side = ( material.shadowSide !== null ) ? material.shadowSide : material.side;\n\n\t\t} else {\n\n\t\t\tresult.side = ( material.shadowSide !== null ) ? material.shadowSide : shadowSide[ material.side ];\n\n\t\t}\n\n\t\tresult.alphaMap = material.alphaMap;\n\t\tresult.alphaTest = material.alphaTest;\n\n\t\tresult.clipShadows = material.clipShadows;\n\t\tresult.clippingPlanes = material.clippingPlanes;\n\t\tresult.clipIntersection = material.clipIntersection;\n\n\t\tresult.displacementMap = material.displacementMap;\n\t\tresult.displacementScale = material.displacementScale;\n\t\tresult.displacementBias = material.displacementBias;\n\n\t\tresult.wireframeLinewidth = material.wireframeLinewidth;\n\t\tresult.linewidth = material.linewidth;\n\n\t\tif ( light.isPointLight === true && result.isMeshDistanceMaterial === true ) {\n\n\t\t\tresult.referencePosition.setFromMatrixPosition( light.matrixWorld );\n\t\t\tresult.nearDistance = shadowCameraNear;\n\t\t\tresult.farDistance = shadowCameraFar;\n\n\t\t}\n\n\t\treturn result;\n\n\t}\n\n\tfunction renderObject( object, camera, shadowCamera, light, type ) {\n\n\t\tif ( object.visible === false ) return;\n\n\t\tconst visible = object.layers.test( camera.layers );\n\n\t\tif ( visible && ( object.isMesh || object.isLine || object.isPoints ) ) {\n\n\t\t\tif ( ( object.castShadow || ( object.receiveShadow && type === VSMShadowMap ) ) && ( ! object.frustumCulled || _frustum.intersectsObject( object ) ) ) {\n\n\t\t\t\tobject.modelViewMatrix.multiplyMatrices( shadowCamera.matrixWorldInverse, object.matrixWorld );\n\n\t\t\t\tconst geometry = _objects.update( object );\n\t\t\t\tconst material = object.material;\n\n\t\t\t\tif ( Array.isArray( material ) ) {\n\n\t\t\t\t\tconst groups = geometry.groups;\n\n\t\t\t\t\tfor ( let k = 0, kl = groups.length; k < kl; k ++ ) {\n\n\t\t\t\t\t\tconst group = groups[ k ];\n\t\t\t\t\t\tconst groupMaterial = material[ group.materialIndex ];\n\n\t\t\t\t\t\tif ( groupMaterial && groupMaterial.visible ) {\n\n\t\t\t\t\t\t\tconst depthMaterial = getDepthMaterial( object, groupMaterial, light, shadowCamera.near, shadowCamera.far, type );\n\n\t\t\t\t\t\t\t_renderer.renderBufferDirect( shadowCamera, null, geometry, depthMaterial, object, group );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t} else if ( material.visible ) {\n\n\t\t\t\t\tconst depthMaterial = getDepthMaterial( object, material, light, shadowCamera.near, shadowCamera.far, type );\n\n\t\t\t\t\t_renderer.renderBufferDirect( shadowCamera, null, geometry, depthMaterial, object, null );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst children = object.children;\n\n\t\tfor ( let i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\trenderObject( children[ i ], camera, shadowCamera, light, type );\n\n\t\t}\n\n\t}\n\n}\n\nfunction WebGLState( gl, extensions, capabilities ) {\n\n\tconst isWebGL2 = capabilities.isWebGL2;\n\n\tfunction ColorBuffer() {\n\n\t\tlet locked = false;\n\n\t\tconst color = new Vector4();\n\t\tlet currentColorMask = null;\n\t\tconst currentColorClear = new Vector4( 0, 0, 0, 0 );\n\n\t\treturn {\n\n\t\t\tsetMask: function ( colorMask ) {\n\n\t\t\t\tif ( currentColorMask !== colorMask && ! locked ) {\n\n\t\t\t\t\tgl.colorMask( colorMask, colorMask, colorMask, colorMask );\n\t\t\t\t\tcurrentColorMask = colorMask;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetLocked: function ( lock ) {\n\n\t\t\t\tlocked = lock;\n\n\t\t\t},\n\n\t\t\tsetClear: function ( r, g, b, a, premultipliedAlpha ) {\n\n\t\t\t\tif ( premultipliedAlpha === true ) {\n\n\t\t\t\t\tr *= a; g *= a; b *= a;\n\n\t\t\t\t}\n\n\t\t\t\tcolor.set( r, g, b, a );\n\n\t\t\t\tif ( currentColorClear.equals( color ) === false ) {\n\n\t\t\t\t\tgl.clearColor( r, g, b, a );\n\t\t\t\t\tcurrentColorClear.copy( color );\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\treset: function () {\n\n\t\t\t\tlocked = false;\n\n\t\t\t\tcurrentColorMask = null;\n\t\t\t\tcurrentColorClear.set( - 1, 0, 0, 0 ); // set to invalid state\n\n\t\t\t}\n\n\t\t};\n\n\t}\n\n\tfunction DepthBuffer() {\n\n\t\tlet locked = false;\n\n\t\tlet currentDepthMask = null;\n\t\tlet currentDepthFunc = null;\n\t\tlet currentDepthClear = null;\n\n\t\treturn {\n\n\t\t\tsetTest: function ( depthTest ) {\n\n\t\t\t\tif ( depthTest ) {\n\n\t\t\t\t\tenable( 2929 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tdisable( 2929 );\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetMask: function ( depthMask ) {\n\n\t\t\t\tif ( currentDepthMask !== depthMask && ! locked ) {\n\n\t\t\t\t\tgl.depthMask( depthMask );\n\t\t\t\t\tcurrentDepthMask = depthMask;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetFunc: function ( depthFunc ) {\n\n\t\t\t\tif ( currentDepthFunc !== depthFunc ) {\n\n\t\t\t\t\tif ( depthFunc ) {\n\n\t\t\t\t\t\tswitch ( depthFunc ) {\n\n\t\t\t\t\t\t\tcase NeverDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( 512 );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase AlwaysDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( 519 );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase LessDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( 513 );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase LessEqualDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( 515 );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase EqualDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( 514 );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase GreaterEqualDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( 518 );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase GreaterDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( 516 );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase NotEqualDepth:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( 517 );\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tdefault:\n\n\t\t\t\t\t\t\t\tgl.depthFunc( 515 );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tgl.depthFunc( 515 );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tcurrentDepthFunc = depthFunc;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetLocked: function ( lock ) {\n\n\t\t\t\tlocked = lock;\n\n\t\t\t},\n\n\t\t\tsetClear: function ( depth ) {\n\n\t\t\t\tif ( currentDepthClear !== depth ) {\n\n\t\t\t\t\tgl.clearDepth( depth );\n\t\t\t\t\tcurrentDepthClear = depth;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\treset: function () {\n\n\t\t\t\tlocked = false;\n\n\t\t\t\tcurrentDepthMask = null;\n\t\t\t\tcurrentDepthFunc = null;\n\t\t\t\tcurrentDepthClear = null;\n\n\t\t\t}\n\n\t\t};\n\n\t}\n\n\tfunction StencilBuffer() {\n\n\t\tlet locked = false;\n\n\t\tlet currentStencilMask = null;\n\t\tlet currentStencilFunc = null;\n\t\tlet currentStencilRef = null;\n\t\tlet currentStencilFuncMask = null;\n\t\tlet currentStencilFail = null;\n\t\tlet currentStencilZFail = null;\n\t\tlet currentStencilZPass = null;\n\t\tlet currentStencilClear = null;\n\n\t\treturn {\n\n\t\t\tsetTest: function ( stencilTest ) {\n\n\t\t\t\tif ( ! locked ) {\n\n\t\t\t\t\tif ( stencilTest ) {\n\n\t\t\t\t\t\tenable( 2960 );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tdisable( 2960 );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetMask: function ( stencilMask ) {\n\n\t\t\t\tif ( currentStencilMask !== stencilMask && ! locked ) {\n\n\t\t\t\t\tgl.stencilMask( stencilMask );\n\t\t\t\t\tcurrentStencilMask = stencilMask;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetFunc: function ( stencilFunc, stencilRef, stencilMask ) {\n\n\t\t\t\tif ( currentStencilFunc !== stencilFunc ||\n\t\t\t\t currentStencilRef !== stencilRef ||\n\t\t\t\t currentStencilFuncMask !== stencilMask ) {\n\n\t\t\t\t\tgl.stencilFunc( stencilFunc, stencilRef, stencilMask );\n\n\t\t\t\t\tcurrentStencilFunc = stencilFunc;\n\t\t\t\t\tcurrentStencilRef = stencilRef;\n\t\t\t\t\tcurrentStencilFuncMask = stencilMask;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetOp: function ( stencilFail, stencilZFail, stencilZPass ) {\n\n\t\t\t\tif ( currentStencilFail !== stencilFail ||\n\t\t\t\t currentStencilZFail !== stencilZFail ||\n\t\t\t\t currentStencilZPass !== stencilZPass ) {\n\n\t\t\t\t\tgl.stencilOp( stencilFail, stencilZFail, stencilZPass );\n\n\t\t\t\t\tcurrentStencilFail = stencilFail;\n\t\t\t\t\tcurrentStencilZFail = stencilZFail;\n\t\t\t\t\tcurrentStencilZPass = stencilZPass;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\tsetLocked: function ( lock ) {\n\n\t\t\t\tlocked = lock;\n\n\t\t\t},\n\n\t\t\tsetClear: function ( stencil ) {\n\n\t\t\t\tif ( currentStencilClear !== stencil ) {\n\n\t\t\t\t\tgl.clearStencil( stencil );\n\t\t\t\t\tcurrentStencilClear = stencil;\n\n\t\t\t\t}\n\n\t\t\t},\n\n\t\t\treset: function () {\n\n\t\t\t\tlocked = false;\n\n\t\t\t\tcurrentStencilMask = null;\n\t\t\t\tcurrentStencilFunc = null;\n\t\t\t\tcurrentStencilRef = null;\n\t\t\t\tcurrentStencilFuncMask = null;\n\t\t\t\tcurrentStencilFail = null;\n\t\t\t\tcurrentStencilZFail = null;\n\t\t\t\tcurrentStencilZPass = null;\n\t\t\t\tcurrentStencilClear = null;\n\n\t\t\t}\n\n\t\t};\n\n\t}\n\n\t//\n\n\tconst colorBuffer = new ColorBuffer();\n\tconst depthBuffer = new DepthBuffer();\n\tconst stencilBuffer = new StencilBuffer();\n\n\tlet enabledCapabilities = {};\n\n\tlet currentBoundFramebuffers = {};\n\tlet currentDrawbuffers = new WeakMap();\n\tlet defaultDrawbuffers = [];\n\n\tlet currentProgram = null;\n\n\tlet currentBlendingEnabled = false;\n\tlet currentBlending = null;\n\tlet currentBlendEquation = null;\n\tlet currentBlendSrc = null;\n\tlet currentBlendDst = null;\n\tlet currentBlendEquationAlpha = null;\n\tlet currentBlendSrcAlpha = null;\n\tlet currentBlendDstAlpha = null;\n\tlet currentPremultipledAlpha = false;\n\n\tlet currentFlipSided = null;\n\tlet currentCullFace = null;\n\n\tlet currentLineWidth = null;\n\n\tlet currentPolygonOffsetFactor = null;\n\tlet currentPolygonOffsetUnits = null;\n\n\tconst maxTextures = gl.getParameter( 35661 );\n\n\tlet lineWidthAvailable = false;\n\tlet version = 0;\n\tconst glVersion = gl.getParameter( 7938 );\n\n\tif ( glVersion.indexOf( 'WebGL' ) !== - 1 ) {\n\n\t\tversion = parseFloat( /^WebGL (\\d)/.exec( glVersion )[ 1 ] );\n\t\tlineWidthAvailable = ( version >= 1.0 );\n\n\t} else if ( glVersion.indexOf( 'OpenGL ES' ) !== - 1 ) {\n\n\t\tversion = parseFloat( /^OpenGL ES (\\d)/.exec( glVersion )[ 1 ] );\n\t\tlineWidthAvailable = ( version >= 2.0 );\n\n\t}\n\n\tlet currentTextureSlot = null;\n\tlet currentBoundTextures = {};\n\n\tconst scissorParam = gl.getParameter( 3088 );\n\tconst viewportParam = gl.getParameter( 2978 );\n\n\tconst currentScissor = new Vector4().fromArray( scissorParam );\n\tconst currentViewport = new Vector4().fromArray( viewportParam );\n\n\tfunction createTexture( type, target, count ) {\n\n\t\tconst data = new Uint8Array( 4 ); // 4 is required to match default unpack alignment of 4.\n\t\tconst texture = gl.createTexture();\n\n\t\tgl.bindTexture( type, texture );\n\t\tgl.texParameteri( type, 10241, 9728 );\n\t\tgl.texParameteri( type, 10240, 9728 );\n\n\t\tfor ( let i = 0; i < count; i ++ ) {\n\n\t\t\tgl.texImage2D( target + i, 0, 6408, 1, 1, 0, 6408, 5121, data );\n\n\t\t}\n\n\t\treturn texture;\n\n\t}\n\n\tconst emptyTextures = {};\n\temptyTextures[ 3553 ] = createTexture( 3553, 3553, 1 );\n\temptyTextures[ 34067 ] = createTexture( 34067, 34069, 6 );\n\n\t// init\n\n\tcolorBuffer.setClear( 0, 0, 0, 1 );\n\tdepthBuffer.setClear( 1 );\n\tstencilBuffer.setClear( 0 );\n\n\tenable( 2929 );\n\tdepthBuffer.setFunc( LessEqualDepth );\n\n\tsetFlipSided( false );\n\tsetCullFace( CullFaceBack );\n\tenable( 2884 );\n\n\tsetBlending( NoBlending );\n\n\t//\n\n\tfunction enable( id ) {\n\n\t\tif ( enabledCapabilities[ id ] !== true ) {\n\n\t\t\tgl.enable( id );\n\t\t\tenabledCapabilities[ id ] = true;\n\n\t\t}\n\n\t}\n\n\tfunction disable( id ) {\n\n\t\tif ( enabledCapabilities[ id ] !== false ) {\n\n\t\t\tgl.disable( id );\n\t\t\tenabledCapabilities[ id ] = false;\n\n\t\t}\n\n\t}\n\n\tfunction bindFramebuffer( target, framebuffer ) {\n\n\t\tif ( currentBoundFramebuffers[ target ] !== framebuffer ) {\n\n\t\t\tgl.bindFramebuffer( target, framebuffer );\n\n\t\t\tcurrentBoundFramebuffers[ target ] = framebuffer;\n\n\t\t\tif ( isWebGL2 ) {\n\n\t\t\t\t// 36009 is equivalent to 36160\n\n\t\t\t\tif ( target === 36009 ) {\n\n\t\t\t\t\tcurrentBoundFramebuffers[ 36160 ] = framebuffer;\n\n\t\t\t\t}\n\n\t\t\t\tif ( target === 36160 ) {\n\n\t\t\t\t\tcurrentBoundFramebuffers[ 36009 ] = framebuffer;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn true;\n\n\t\t}\n\n\t\treturn false;\n\n\t}\n\n\tfunction drawBuffers( renderTarget, framebuffer ) {\n\n\t\tlet drawBuffers = defaultDrawbuffers;\n\n\t\tlet needsUpdate = false;\n\n\t\tif ( renderTarget ) {\n\n\t\t\tdrawBuffers = currentDrawbuffers.get( framebuffer );\n\n\t\t\tif ( drawBuffers === undefined ) {\n\n\t\t\t\tdrawBuffers = [];\n\t\t\t\tcurrentDrawbuffers.set( framebuffer, drawBuffers );\n\n\t\t\t}\n\n\t\t\tif ( renderTarget.isWebGLMultipleRenderTargets ) {\n\n\t\t\t\tconst textures = renderTarget.texture;\n\n\t\t\t\tif ( drawBuffers.length !== textures.length || drawBuffers[ 0 ] !== 36064 ) {\n\n\t\t\t\t\tfor ( let i = 0, il = textures.length; i < il; i ++ ) {\n\n\t\t\t\t\t\tdrawBuffers[ i ] = 36064 + i;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tdrawBuffers.length = textures.length;\n\n\t\t\t\t\tneedsUpdate = true;\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tif ( drawBuffers[ 0 ] !== 36064 ) {\n\n\t\t\t\t\tdrawBuffers[ 0 ] = 36064;\n\n\t\t\t\t\tneedsUpdate = true;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tif ( drawBuffers[ 0 ] !== 1029 ) {\n\n\t\t\t\tdrawBuffers[ 0 ] = 1029;\n\n\t\t\t\tneedsUpdate = true;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( needsUpdate ) {\n\n\t\t\tif ( capabilities.isWebGL2 ) {\n\n\t\t\t\tgl.drawBuffers( drawBuffers );\n\n\t\t\t} else {\n\n\t\t\t\textensions.get( 'WEBGL_draw_buffers' ).drawBuffersWEBGL( drawBuffers );\n\n\t\t\t}\n\n\t\t}\n\n\n\t}\n\n\tfunction useProgram( program ) {\n\n\t\tif ( currentProgram !== program ) {\n\n\t\t\tgl.useProgram( program );\n\n\t\t\tcurrentProgram = program;\n\n\t\t\treturn true;\n\n\t\t}\n\n\t\treturn false;\n\n\t}\n\n\tconst equationToGL = {\n\t\t[ AddEquation ]: 32774,\n\t\t[ SubtractEquation ]: 32778,\n\t\t[ ReverseSubtractEquation ]: 32779\n\t};\n\n\tif ( isWebGL2 ) {\n\n\t\tequationToGL[ MinEquation ] = 32775;\n\t\tequationToGL[ MaxEquation ] = 32776;\n\n\t} else {\n\n\t\tconst extension = extensions.get( 'EXT_blend_minmax' );\n\n\t\tif ( extension !== null ) {\n\n\t\t\tequationToGL[ MinEquation ] = extension.MIN_EXT;\n\t\t\tequationToGL[ MaxEquation ] = extension.MAX_EXT;\n\n\t\t}\n\n\t}\n\n\tconst factorToGL = {\n\t\t[ ZeroFactor ]: 0,\n\t\t[ OneFactor ]: 1,\n\t\t[ SrcColorFactor ]: 768,\n\t\t[ SrcAlphaFactor ]: 770,\n\t\t[ SrcAlphaSaturateFactor ]: 776,\n\t\t[ DstColorFactor ]: 774,\n\t\t[ DstAlphaFactor ]: 772,\n\t\t[ OneMinusSrcColorFactor ]: 769,\n\t\t[ OneMinusSrcAlphaFactor ]: 771,\n\t\t[ OneMinusDstColorFactor ]: 775,\n\t\t[ OneMinusDstAlphaFactor ]: 773\n\t};\n\n\tfunction setBlending( blending, blendEquation, blendSrc, blendDst, blendEquationAlpha, blendSrcAlpha, blendDstAlpha, premultipliedAlpha ) {\n\n\t\tif ( blending === NoBlending ) {\n\n\t\t\tif ( currentBlendingEnabled === true ) {\n\n\t\t\t\tdisable( 3042 );\n\t\t\t\tcurrentBlendingEnabled = false;\n\n\t\t\t}\n\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( currentBlendingEnabled === false ) {\n\n\t\t\tenable( 3042 );\n\t\t\tcurrentBlendingEnabled = true;\n\n\t\t}\n\n\t\tif ( blending !== CustomBlending ) {\n\n\t\t\tif ( blending !== currentBlending || premultipliedAlpha !== currentPremultipledAlpha ) {\n\n\t\t\t\tif ( currentBlendEquation !== AddEquation || currentBlendEquationAlpha !== AddEquation ) {\n\n\t\t\t\t\tgl.blendEquation( 32774 );\n\n\t\t\t\t\tcurrentBlendEquation = AddEquation;\n\t\t\t\t\tcurrentBlendEquationAlpha = AddEquation;\n\n\t\t\t\t}\n\n\t\t\t\tif ( premultipliedAlpha ) {\n\n\t\t\t\t\tswitch ( blending ) {\n\n\t\t\t\t\t\tcase NormalBlending:\n\t\t\t\t\t\t\tgl.blendFuncSeparate( 1, 771, 1, 771 );\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase AdditiveBlending:\n\t\t\t\t\t\t\tgl.blendFunc( 1, 1 );\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase SubtractiveBlending:\n\t\t\t\t\t\t\tgl.blendFuncSeparate( 0, 769, 0, 1 );\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase MultiplyBlending:\n\t\t\t\t\t\t\tgl.blendFuncSeparate( 0, 768, 0, 770 );\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tconsole.error( 'THREE.WebGLState: Invalid blending: ', blending );\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tswitch ( blending ) {\n\n\t\t\t\t\t\tcase NormalBlending:\n\t\t\t\t\t\t\tgl.blendFuncSeparate( 770, 771, 1, 771 );\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase AdditiveBlending:\n\t\t\t\t\t\t\tgl.blendFunc( 770, 1 );\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase SubtractiveBlending:\n\t\t\t\t\t\t\tgl.blendFuncSeparate( 0, 769, 0, 1 );\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase MultiplyBlending:\n\t\t\t\t\t\t\tgl.blendFunc( 0, 768 );\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tconsole.error( 'THREE.WebGLState: Invalid blending: ', blending );\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tcurrentBlendSrc = null;\n\t\t\t\tcurrentBlendDst = null;\n\t\t\t\tcurrentBlendSrcAlpha = null;\n\t\t\t\tcurrentBlendDstAlpha = null;\n\n\t\t\t\tcurrentBlending = blending;\n\t\t\t\tcurrentPremultipledAlpha = premultipliedAlpha;\n\n\t\t\t}\n\n\t\t\treturn;\n\n\t\t}\n\n\t\t// custom blending\n\n\t\tblendEquationAlpha = blendEquationAlpha || blendEquation;\n\t\tblendSrcAlpha = blendSrcAlpha || blendSrc;\n\t\tblendDstAlpha = blendDstAlpha || blendDst;\n\n\t\tif ( blendEquation !== currentBlendEquation || blendEquationAlpha !== currentBlendEquationAlpha ) {\n\n\t\t\tgl.blendEquationSeparate( equationToGL[ blendEquation ], equationToGL[ blendEquationAlpha ] );\n\n\t\t\tcurrentBlendEquation = blendEquation;\n\t\t\tcurrentBlendEquationAlpha = blendEquationAlpha;\n\n\t\t}\n\n\t\tif ( blendSrc !== currentBlendSrc || blendDst !== currentBlendDst || blendSrcAlpha !== currentBlendSrcAlpha || blendDstAlpha !== currentBlendDstAlpha ) {\n\n\t\t\tgl.blendFuncSeparate( factorToGL[ blendSrc ], factorToGL[ blendDst ], factorToGL[ blendSrcAlpha ], factorToGL[ blendDstAlpha ] );\n\n\t\t\tcurrentBlendSrc = blendSrc;\n\t\t\tcurrentBlendDst = blendDst;\n\t\t\tcurrentBlendSrcAlpha = blendSrcAlpha;\n\t\t\tcurrentBlendDstAlpha = blendDstAlpha;\n\n\t\t}\n\n\t\tcurrentBlending = blending;\n\t\tcurrentPremultipledAlpha = null;\n\n\t}\n\n\tfunction setMaterial( material, frontFaceCW ) {\n\n\t\tmaterial.side === DoubleSide\n\t\t\t? disable( 2884 )\n\t\t\t: enable( 2884 );\n\n\t\tlet flipSided = ( material.side === BackSide );\n\t\tif ( frontFaceCW ) flipSided = ! flipSided;\n\n\t\tsetFlipSided( flipSided );\n\n\t\t( material.blending === NormalBlending && material.transparent === false )\n\t\t\t? setBlending( NoBlending )\n\t\t\t: setBlending( material.blending, material.blendEquation, material.blendSrc, material.blendDst, material.blendEquationAlpha, material.blendSrcAlpha, material.blendDstAlpha, material.premultipliedAlpha );\n\n\t\tdepthBuffer.setFunc( material.depthFunc );\n\t\tdepthBuffer.setTest( material.depthTest );\n\t\tdepthBuffer.setMask( material.depthWrite );\n\t\tcolorBuffer.setMask( material.colorWrite );\n\n\t\tconst stencilWrite = material.stencilWrite;\n\t\tstencilBuffer.setTest( stencilWrite );\n\t\tif ( stencilWrite ) {\n\n\t\t\tstencilBuffer.setMask( material.stencilWriteMask );\n\t\t\tstencilBuffer.setFunc( material.stencilFunc, material.stencilRef, material.stencilFuncMask );\n\t\t\tstencilBuffer.setOp( material.stencilFail, material.stencilZFail, material.stencilZPass );\n\n\t\t}\n\n\t\tsetPolygonOffset( material.polygonOffset, material.polygonOffsetFactor, material.polygonOffsetUnits );\n\n\t\tmaterial.alphaToCoverage === true\n\t\t\t? enable( 32926 )\n\t\t\t: disable( 32926 );\n\n\t}\n\n\t//\n\n\tfunction setFlipSided( flipSided ) {\n\n\t\tif ( currentFlipSided !== flipSided ) {\n\n\t\t\tif ( flipSided ) {\n\n\t\t\t\tgl.frontFace( 2304 );\n\n\t\t\t} else {\n\n\t\t\t\tgl.frontFace( 2305 );\n\n\t\t\t}\n\n\t\t\tcurrentFlipSided = flipSided;\n\n\t\t}\n\n\t}\n\n\tfunction setCullFace( cullFace ) {\n\n\t\tif ( cullFace !== CullFaceNone ) {\n\n\t\t\tenable( 2884 );\n\n\t\t\tif ( cullFace !== currentCullFace ) {\n\n\t\t\t\tif ( cullFace === CullFaceBack ) {\n\n\t\t\t\t\tgl.cullFace( 1029 );\n\n\t\t\t\t} else if ( cullFace === CullFaceFront ) {\n\n\t\t\t\t\tgl.cullFace( 1028 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tgl.cullFace( 1032 );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tdisable( 2884 );\n\n\t\t}\n\n\t\tcurrentCullFace = cullFace;\n\n\t}\n\n\tfunction setLineWidth( width ) {\n\n\t\tif ( width !== currentLineWidth ) {\n\n\t\t\tif ( lineWidthAvailable ) gl.lineWidth( width );\n\n\t\t\tcurrentLineWidth = width;\n\n\t\t}\n\n\t}\n\n\tfunction setPolygonOffset( polygonOffset, factor, units ) {\n\n\t\tif ( polygonOffset ) {\n\n\t\t\tenable( 32823 );\n\n\t\t\tif ( currentPolygonOffsetFactor !== factor || currentPolygonOffsetUnits !== units ) {\n\n\t\t\t\tgl.polygonOffset( factor, units );\n\n\t\t\t\tcurrentPolygonOffsetFactor = factor;\n\t\t\t\tcurrentPolygonOffsetUnits = units;\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tdisable( 32823 );\n\n\t\t}\n\n\t}\n\n\tfunction setScissorTest( scissorTest ) {\n\n\t\tif ( scissorTest ) {\n\n\t\t\tenable( 3089 );\n\n\t\t} else {\n\n\t\t\tdisable( 3089 );\n\n\t\t}\n\n\t}\n\n\t// texture\n\n\tfunction activeTexture( webglSlot ) {\n\n\t\tif ( webglSlot === undefined ) webglSlot = 33984 + maxTextures - 1;\n\n\t\tif ( currentTextureSlot !== webglSlot ) {\n\n\t\t\tgl.activeTexture( webglSlot );\n\t\t\tcurrentTextureSlot = webglSlot;\n\n\t\t}\n\n\t}\n\n\tfunction bindTexture( webglType, webglTexture ) {\n\n\t\tif ( currentTextureSlot === null ) {\n\n\t\t\tactiveTexture();\n\n\t\t}\n\n\t\tlet boundTexture = currentBoundTextures[ currentTextureSlot ];\n\n\t\tif ( boundTexture === undefined ) {\n\n\t\t\tboundTexture = { type: undefined, texture: undefined };\n\t\t\tcurrentBoundTextures[ currentTextureSlot ] = boundTexture;\n\n\t\t}\n\n\t\tif ( boundTexture.type !== webglType || boundTexture.texture !== webglTexture ) {\n\n\t\t\tgl.bindTexture( webglType, webglTexture || emptyTextures[ webglType ] );\n\n\t\t\tboundTexture.type = webglType;\n\t\t\tboundTexture.texture = webglTexture;\n\n\t\t}\n\n\t}\n\n\tfunction unbindTexture() {\n\n\t\tconst boundTexture = currentBoundTextures[ currentTextureSlot ];\n\n\t\tif ( boundTexture !== undefined && boundTexture.type !== undefined ) {\n\n\t\t\tgl.bindTexture( boundTexture.type, null );\n\n\t\t\tboundTexture.type = undefined;\n\t\t\tboundTexture.texture = undefined;\n\n\t\t}\n\n\t}\n\n\tfunction compressedTexImage2D() {\n\n\t\ttry {\n\n\t\t\tgl.compressedTexImage2D.apply( gl, arguments );\n\n\t\t} catch ( error ) {\n\n\t\t\tconsole.error( 'THREE.WebGLState:', error );\n\n\t\t}\n\n\t}\n\n\tfunction texSubImage2D() {\n\n\t\ttry {\n\n\t\t\tgl.texSubImage2D.apply( gl, arguments );\n\n\t\t} catch ( error ) {\n\n\t\t\tconsole.error( 'THREE.WebGLState:', error );\n\n\t\t}\n\n\t}\n\n\tfunction texSubImage3D() {\n\n\t\ttry {\n\n\t\t\tgl.texSubImage3D.apply( gl, arguments );\n\n\t\t} catch ( error ) {\n\n\t\t\tconsole.error( 'THREE.WebGLState:', error );\n\n\t\t}\n\n\t}\n\n\tfunction compressedTexSubImage2D() {\n\n\t\ttry {\n\n\t\t\tgl.compressedTexSubImage2D.apply( gl, arguments );\n\n\t\t} catch ( error ) {\n\n\t\t\tconsole.error( 'THREE.WebGLState:', error );\n\n\t\t}\n\n\t}\n\n\tfunction texStorage2D() {\n\n\t\ttry {\n\n\t\t\tgl.texStorage2D.apply( gl, arguments );\n\n\t\t} catch ( error ) {\n\n\t\t\tconsole.error( 'THREE.WebGLState:', error );\n\n\t\t}\n\n\t}\n\n\tfunction texStorage3D() {\n\n\t\ttry {\n\n\t\t\tgl.texStorage3D.apply( gl, arguments );\n\n\t\t} catch ( error ) {\n\n\t\t\tconsole.error( 'THREE.WebGLState:', error );\n\n\t\t}\n\n\t}\n\n\tfunction texImage2D() {\n\n\t\ttry {\n\n\t\t\tgl.texImage2D.apply( gl, arguments );\n\n\t\t} catch ( error ) {\n\n\t\t\tconsole.error( 'THREE.WebGLState:', error );\n\n\t\t}\n\n\t}\n\n\tfunction texImage3D() {\n\n\t\ttry {\n\n\t\t\tgl.texImage3D.apply( gl, arguments );\n\n\t\t} catch ( error ) {\n\n\t\t\tconsole.error( 'THREE.WebGLState:', error );\n\n\t\t}\n\n\t}\n\n\t//\n\n\tfunction scissor( scissor ) {\n\n\t\tif ( currentScissor.equals( scissor ) === false ) {\n\n\t\t\tgl.scissor( scissor.x, scissor.y, scissor.z, scissor.w );\n\t\t\tcurrentScissor.copy( scissor );\n\n\t\t}\n\n\t}\n\n\tfunction viewport( viewport ) {\n\n\t\tif ( currentViewport.equals( viewport ) === false ) {\n\n\t\t\tgl.viewport( viewport.x, viewport.y, viewport.z, viewport.w );\n\t\t\tcurrentViewport.copy( viewport );\n\n\t\t}\n\n\t}\n\n\t//\n\n\tfunction reset() {\n\n\t\t// reset state\n\n\t\tgl.disable( 3042 );\n\t\tgl.disable( 2884 );\n\t\tgl.disable( 2929 );\n\t\tgl.disable( 32823 );\n\t\tgl.disable( 3089 );\n\t\tgl.disable( 2960 );\n\t\tgl.disable( 32926 );\n\n\t\tgl.blendEquation( 32774 );\n\t\tgl.blendFunc( 1, 0 );\n\t\tgl.blendFuncSeparate( 1, 0, 1, 0 );\n\n\t\tgl.colorMask( true, true, true, true );\n\t\tgl.clearColor( 0, 0, 0, 0 );\n\n\t\tgl.depthMask( true );\n\t\tgl.depthFunc( 513 );\n\t\tgl.clearDepth( 1 );\n\n\t\tgl.stencilMask( 0xffffffff );\n\t\tgl.stencilFunc( 519, 0, 0xffffffff );\n\t\tgl.stencilOp( 7680, 7680, 7680 );\n\t\tgl.clearStencil( 0 );\n\n\t\tgl.cullFace( 1029 );\n\t\tgl.frontFace( 2305 );\n\n\t\tgl.polygonOffset( 0, 0 );\n\n\t\tgl.activeTexture( 33984 );\n\n\t\tgl.bindFramebuffer( 36160, null );\n\n\t\tif ( isWebGL2 === true ) {\n\n\t\t\tgl.bindFramebuffer( 36009, null );\n\t\t\tgl.bindFramebuffer( 36008, null );\n\n\t\t}\n\n\t\tgl.useProgram( null );\n\n\t\tgl.lineWidth( 1 );\n\n\t\tgl.scissor( 0, 0, gl.canvas.width, gl.canvas.height );\n\t\tgl.viewport( 0, 0, gl.canvas.width, gl.canvas.height );\n\n\t\t// reset internals\n\n\t\tenabledCapabilities = {};\n\n\t\tcurrentTextureSlot = null;\n\t\tcurrentBoundTextures = {};\n\n\t\tcurrentBoundFramebuffers = {};\n\t\tcurrentDrawbuffers = new WeakMap();\n\t\tdefaultDrawbuffers = [];\n\n\t\tcurrentProgram = null;\n\n\t\tcurrentBlendingEnabled = false;\n\t\tcurrentBlending = null;\n\t\tcurrentBlendEquation = null;\n\t\tcurrentBlendSrc = null;\n\t\tcurrentBlendDst = null;\n\t\tcurrentBlendEquationAlpha = null;\n\t\tcurrentBlendSrcAlpha = null;\n\t\tcurrentBlendDstAlpha = null;\n\t\tcurrentPremultipledAlpha = false;\n\n\t\tcurrentFlipSided = null;\n\t\tcurrentCullFace = null;\n\n\t\tcurrentLineWidth = null;\n\n\t\tcurrentPolygonOffsetFactor = null;\n\t\tcurrentPolygonOffsetUnits = null;\n\n\t\tcurrentScissor.set( 0, 0, gl.canvas.width, gl.canvas.height );\n\t\tcurrentViewport.set( 0, 0, gl.canvas.width, gl.canvas.height );\n\n\t\tcolorBuffer.reset();\n\t\tdepthBuffer.reset();\n\t\tstencilBuffer.reset();\n\n\t}\n\n\treturn {\n\n\t\tbuffers: {\n\t\t\tcolor: colorBuffer,\n\t\t\tdepth: depthBuffer,\n\t\t\tstencil: stencilBuffer\n\t\t},\n\n\t\tenable: enable,\n\t\tdisable: disable,\n\n\t\tbindFramebuffer: bindFramebuffer,\n\t\tdrawBuffers: drawBuffers,\n\n\t\tuseProgram: useProgram,\n\n\t\tsetBlending: setBlending,\n\t\tsetMaterial: setMaterial,\n\n\t\tsetFlipSided: setFlipSided,\n\t\tsetCullFace: setCullFace,\n\n\t\tsetLineWidth: setLineWidth,\n\t\tsetPolygonOffset: setPolygonOffset,\n\n\t\tsetScissorTest: setScissorTest,\n\n\t\tactiveTexture: activeTexture,\n\t\tbindTexture: bindTexture,\n\t\tunbindTexture: unbindTexture,\n\t\tcompressedTexImage2D: compressedTexImage2D,\n\t\ttexImage2D: texImage2D,\n\t\ttexImage3D: texImage3D,\n\n\t\ttexStorage2D: texStorage2D,\n\t\ttexStorage3D: texStorage3D,\n\t\ttexSubImage2D: texSubImage2D,\n\t\ttexSubImage3D: texSubImage3D,\n\t\tcompressedTexSubImage2D: compressedTexSubImage2D,\n\n\t\tscissor: scissor,\n\t\tviewport: viewport,\n\n\t\treset: reset\n\n\t};\n\n}\n\nfunction WebGLTextures( _gl, extensions, state, properties, capabilities, utils, info ) {\n\n\tconst isWebGL2 = capabilities.isWebGL2;\n\tconst maxTextures = capabilities.maxTextures;\n\tconst maxCubemapSize = capabilities.maxCubemapSize;\n\tconst maxTextureSize = capabilities.maxTextureSize;\n\tconst maxSamples = capabilities.maxSamples;\n\tconst multisampledRTTExt = extensions.has( 'WEBGL_multisampled_render_to_texture' ) ? extensions.get( 'WEBGL_multisampled_render_to_texture' ) : null;\n\tconst supportsInvalidateFramebuffer = /OculusBrowser/g.test( navigator.userAgent );\n\n\tconst _videoTextures = new WeakMap();\n\tlet _canvas;\n\n\tconst _sources = new WeakMap(); // maps WebglTexture objects to instances of Source\n\n\t// cordova iOS (as of 5.0) still uses UIWebView, which provides OffscreenCanvas,\n\t// also OffscreenCanvas.getContext(\"webgl\"), but not OffscreenCanvas.getContext(\"2d\")!\n\t// Some implementations may only implement OffscreenCanvas partially (e.g. lacking 2d).\n\n\tlet useOffscreenCanvas = false;\n\n\ttry {\n\n\t\tuseOffscreenCanvas = typeof OffscreenCanvas !== 'undefined'\n\t\t\t// eslint-disable-next-line compat/compat\n\t\t\t&& ( new OffscreenCanvas( 1, 1 ).getContext( '2d' ) ) !== null;\n\n\t} catch ( err ) {\n\n\t\t// Ignore any errors\n\n\t}\n\n\tfunction createCanvas( width, height ) {\n\n\t\t// Use OffscreenCanvas when available. Specially needed in web workers\n\n\t\treturn useOffscreenCanvas ?\n\t\t\t// eslint-disable-next-line compat/compat\n\t\t\tnew OffscreenCanvas( width, height ) : createElementNS( 'canvas' );\n\n\t}\n\n\tfunction resizeImage( image, needsPowerOfTwo, needsNewCanvas, maxSize ) {\n\n\t\tlet scale = 1;\n\n\t\t// handle case if texture exceeds max size\n\n\t\tif ( image.width > maxSize || image.height > maxSize ) {\n\n\t\t\tscale = maxSize / Math.max( image.width, image.height );\n\n\t\t}\n\n\t\t// only perform resize if necessary\n\n\t\tif ( scale < 1 || needsPowerOfTwo === true ) {\n\n\t\t\t// only perform resize for certain image types\n\n\t\t\tif ( ( typeof HTMLImageElement !== 'undefined' && image instanceof HTMLImageElement ) ||\n\t\t\t\t( typeof HTMLCanvasElement !== 'undefined' && image instanceof HTMLCanvasElement ) ||\n\t\t\t\t( typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap ) ) {\n\n\t\t\t\tconst floor = needsPowerOfTwo ? floorPowerOfTwo : Math.floor;\n\n\t\t\t\tconst width = floor( scale * image.width );\n\t\t\t\tconst height = floor( scale * image.height );\n\n\t\t\t\tif ( _canvas === undefined ) _canvas = createCanvas( width, height );\n\n\t\t\t\t// cube textures can't reuse the same canvas\n\n\t\t\t\tconst canvas = needsNewCanvas ? createCanvas( width, height ) : _canvas;\n\n\t\t\t\tcanvas.width = width;\n\t\t\t\tcanvas.height = height;\n\n\t\t\t\tconst context = canvas.getContext( '2d' );\n\t\t\t\tcontext.drawImage( image, 0, 0, width, height );\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Texture has been resized from (' + image.width + 'x' + image.height + ') to (' + width + 'x' + height + ').' );\n\n\t\t\t\treturn canvas;\n\n\t\t\t} else {\n\n\t\t\t\tif ( 'data' in image ) {\n\n\t\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Image in DataTexture is too big (' + image.width + 'x' + image.height + ').' );\n\n\t\t\t\t}\n\n\t\t\t\treturn image;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn image;\n\n\t}\n\n\tfunction isPowerOfTwo$1( image ) {\n\n\t\treturn isPowerOfTwo( image.width ) && isPowerOfTwo( image.height );\n\n\t}\n\n\tfunction textureNeedsPowerOfTwo( texture ) {\n\n\t\tif ( isWebGL2 ) return false;\n\n\t\treturn ( texture.wrapS !== ClampToEdgeWrapping || texture.wrapT !== ClampToEdgeWrapping ) ||\n\t\t\t( texture.minFilter !== NearestFilter && texture.minFilter !== LinearFilter );\n\n\t}\n\n\tfunction textureNeedsGenerateMipmaps( texture, supportsMips ) {\n\n\t\treturn texture.generateMipmaps && supportsMips &&\n\t\t\ttexture.minFilter !== NearestFilter && texture.minFilter !== LinearFilter;\n\n\t}\n\n\tfunction generateMipmap( target ) {\n\n\t\t_gl.generateMipmap( target );\n\n\t}\n\n\tfunction getInternalFormat( internalFormatName, glFormat, glType, encoding, isVideoTexture = false ) {\n\n\t\tif ( isWebGL2 === false ) return glFormat;\n\n\t\tif ( internalFormatName !== null ) {\n\n\t\t\tif ( _gl[ internalFormatName ] !== undefined ) return _gl[ internalFormatName ];\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: Attempt to use non-existing WebGL internal format \\'' + internalFormatName + '\\'' );\n\n\t\t}\n\n\t\tlet internalFormat = glFormat;\n\n\t\tif ( glFormat === 6403 ) {\n\n\t\t\tif ( glType === 5126 ) internalFormat = 33326;\n\t\t\tif ( glType === 5131 ) internalFormat = 33325;\n\t\t\tif ( glType === 5121 ) internalFormat = 33321;\n\n\t\t}\n\n\t\tif ( glFormat === 33319 ) {\n\n\t\t\tif ( glType === 5126 ) internalFormat = 33328;\n\t\t\tif ( glType === 5131 ) internalFormat = 33327;\n\t\t\tif ( glType === 5121 ) internalFormat = 33323;\n\n\t\t}\n\n\t\tif ( glFormat === 6408 ) {\n\n\t\t\tif ( glType === 5126 ) internalFormat = 34836;\n\t\t\tif ( glType === 5131 ) internalFormat = 34842;\n\t\t\tif ( glType === 5121 ) internalFormat = ( encoding === sRGBEncoding && isVideoTexture === false ) ? 35907 : 32856;\n\t\t\tif ( glType === 32819 ) internalFormat = 32854;\n\t\t\tif ( glType === 32820 ) internalFormat = 32855;\n\n\t\t}\n\n\t\tif ( internalFormat === 33325 || internalFormat === 33326 ||\n\t\t\tinternalFormat === 33327 || internalFormat === 33328 ||\n\t\t\tinternalFormat === 34842 || internalFormat === 34836 ) {\n\n\t\t\textensions.get( 'EXT_color_buffer_float' );\n\n\t\t}\n\n\t\treturn internalFormat;\n\n\t}\n\n\tfunction getMipLevels( texture, image, supportsMips ) {\n\n\t\tif ( textureNeedsGenerateMipmaps( texture, supportsMips ) === true || ( texture.isFramebufferTexture && texture.minFilter !== NearestFilter && texture.minFilter !== LinearFilter ) ) {\n\n\t\t\treturn Math.log2( Math.max( image.width, image.height ) ) + 1;\n\n\t\t} else if ( texture.mipmaps !== undefined && texture.mipmaps.length > 0 ) {\n\n\t\t\t// user-defined mipmaps\n\n\t\t\treturn texture.mipmaps.length;\n\n\t\t} else if ( texture.isCompressedTexture && Array.isArray( texture.image ) ) {\n\n\t\t\treturn image.mipmaps.length;\n\n\t\t} else {\n\n\t\t\t// texture without mipmaps (only base level)\n\n\t\t\treturn 1;\n\n\t\t}\n\n\t}\n\n\t// Fallback filters for non-power-of-2 textures\n\n\tfunction filterFallback( f ) {\n\n\t\tif ( f === NearestFilter || f === NearestMipmapNearestFilter || f === NearestMipmapLinearFilter ) {\n\n\t\t\treturn 9728;\n\n\t\t}\n\n\t\treturn 9729;\n\n\t}\n\n\t//\n\n\tfunction onTextureDispose( event ) {\n\n\t\tconst texture = event.target;\n\n\t\ttexture.removeEventListener( 'dispose', onTextureDispose );\n\n\t\tdeallocateTexture( texture );\n\n\t\tif ( texture.isVideoTexture ) {\n\n\t\t\t_videoTextures.delete( texture );\n\n\t\t}\n\n\t}\n\n\tfunction onRenderTargetDispose( event ) {\n\n\t\tconst renderTarget = event.target;\n\n\t\trenderTarget.removeEventListener( 'dispose', onRenderTargetDispose );\n\n\t\tdeallocateRenderTarget( renderTarget );\n\n\t}\n\n\t//\n\n\tfunction deallocateTexture( texture ) {\n\n\t\tconst textureProperties = properties.get( texture );\n\n\t\tif ( textureProperties.__webglInit === undefined ) return;\n\n\t\t// check if it's necessary to remove the WebGLTexture object\n\n\t\tconst source = texture.source;\n\t\tconst webglTextures = _sources.get( source );\n\n\t\tif ( webglTextures ) {\n\n\t\t\tconst webglTexture = webglTextures[ textureProperties.__cacheKey ];\n\t\t\twebglTexture.usedTimes --;\n\n\t\t\t// the WebGLTexture object is not used anymore, remove it\n\n\t\t\tif ( webglTexture.usedTimes === 0 ) {\n\n\t\t\t\tdeleteTexture( texture );\n\n\t\t\t}\n\n\t\t\t// remove the weak map entry if no WebGLTexture uses the source anymore\n\n\t\t\tif ( Object.keys( webglTextures ).length === 0 ) {\n\n\t\t\t\t_sources.delete( source );\n\n\t\t\t}\n\n\t\t}\n\n\t\tproperties.remove( texture );\n\n\t}\n\n\tfunction deleteTexture( texture ) {\n\n\t\tconst textureProperties = properties.get( texture );\n\t\t_gl.deleteTexture( textureProperties.__webglTexture );\n\n\t\tconst source = texture.source;\n\t\tconst webglTextures = _sources.get( source );\n\t\tdelete webglTextures[ textureProperties.__cacheKey ];\n\n\t\tinfo.memory.textures --;\n\n\t}\n\n\tfunction deallocateRenderTarget( renderTarget ) {\n\n\t\tconst texture = renderTarget.texture;\n\n\t\tconst renderTargetProperties = properties.get( renderTarget );\n\t\tconst textureProperties = properties.get( texture );\n\n\t\tif ( textureProperties.__webglTexture !== undefined ) {\n\n\t\t\t_gl.deleteTexture( textureProperties.__webglTexture );\n\n\t\t\tinfo.memory.textures --;\n\n\t\t}\n\n\t\tif ( renderTarget.depthTexture ) {\n\n\t\t\trenderTarget.depthTexture.dispose();\n\n\t\t}\n\n\t\tif ( renderTarget.isWebGLCubeRenderTarget ) {\n\n\t\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\t\t_gl.deleteFramebuffer( renderTargetProperties.__webglFramebuffer[ i ] );\n\t\t\t\tif ( renderTargetProperties.__webglDepthbuffer ) _gl.deleteRenderbuffer( renderTargetProperties.__webglDepthbuffer[ i ] );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t_gl.deleteFramebuffer( renderTargetProperties.__webglFramebuffer );\n\t\t\tif ( renderTargetProperties.__webglDepthbuffer ) _gl.deleteRenderbuffer( renderTargetProperties.__webglDepthbuffer );\n\t\t\tif ( renderTargetProperties.__webglMultisampledFramebuffer ) _gl.deleteFramebuffer( renderTargetProperties.__webglMultisampledFramebuffer );\n\n\t\t\tif ( renderTargetProperties.__webglColorRenderbuffer ) {\n\n\t\t\t\tfor ( let i = 0; i < renderTargetProperties.__webglColorRenderbuffer.length; i ++ ) {\n\n\t\t\t\t\tif ( renderTargetProperties.__webglColorRenderbuffer[ i ] ) _gl.deleteRenderbuffer( renderTargetProperties.__webglColorRenderbuffer[ i ] );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( renderTargetProperties.__webglDepthRenderbuffer ) _gl.deleteRenderbuffer( renderTargetProperties.__webglDepthRenderbuffer );\n\n\t\t}\n\n\t\tif ( renderTarget.isWebGLMultipleRenderTargets ) {\n\n\t\t\tfor ( let i = 0, il = texture.length; i < il; i ++ ) {\n\n\t\t\t\tconst attachmentProperties = properties.get( texture[ i ] );\n\n\t\t\t\tif ( attachmentProperties.__webglTexture ) {\n\n\t\t\t\t\t_gl.deleteTexture( attachmentProperties.__webglTexture );\n\n\t\t\t\t\tinfo.memory.textures --;\n\n\t\t\t\t}\n\n\t\t\t\tproperties.remove( texture[ i ] );\n\n\t\t\t}\n\n\t\t}\n\n\t\tproperties.remove( texture );\n\t\tproperties.remove( renderTarget );\n\n\t}\n\n\t//\n\n\tlet textureUnits = 0;\n\n\tfunction resetTextureUnits() {\n\n\t\ttextureUnits = 0;\n\n\t}\n\n\tfunction allocateTextureUnit() {\n\n\t\tconst textureUnit = textureUnits;\n\n\t\tif ( textureUnit >= maxTextures ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLTextures: Trying to use ' + textureUnit + ' texture units while this GPU supports only ' + maxTextures );\n\n\t\t}\n\n\t\ttextureUnits += 1;\n\n\t\treturn textureUnit;\n\n\t}\n\n\tfunction getTextureCacheKey( texture ) {\n\n\t\tconst array = [];\n\n\t\tarray.push( texture.wrapS );\n\t\tarray.push( texture.wrapT );\n\t\tarray.push( texture.magFilter );\n\t\tarray.push( texture.minFilter );\n\t\tarray.push( texture.anisotropy );\n\t\tarray.push( texture.internalFormat );\n\t\tarray.push( texture.format );\n\t\tarray.push( texture.type );\n\t\tarray.push( texture.generateMipmaps );\n\t\tarray.push( texture.premultiplyAlpha );\n\t\tarray.push( texture.flipY );\n\t\tarray.push( texture.unpackAlignment );\n\t\tarray.push( texture.encoding );\n\n\t\treturn array.join();\n\n\t}\n\n\t//\n\n\tfunction setTexture2D( texture, slot ) {\n\n\t\tconst textureProperties = properties.get( texture );\n\n\t\tif ( texture.isVideoTexture ) updateVideoTexture( texture );\n\n\t\tif ( texture.isRenderTargetTexture === false && texture.version > 0 && textureProperties.__version !== texture.version ) {\n\n\t\t\tconst image = texture.image;\n\n\t\t\tif ( image === null ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Texture marked for update but no image data found.' );\n\n\t\t\t} else if ( image.complete === false ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Texture marked for update but image is incomplete' );\n\n\t\t\t} else {\n\n\t\t\t\tuploadTexture( textureProperties, texture, slot );\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t}\n\n\t\tstate.activeTexture( 33984 + slot );\n\t\tstate.bindTexture( 3553, textureProperties.__webglTexture );\n\n\t}\n\n\tfunction setTexture2DArray( texture, slot ) {\n\n\t\tconst textureProperties = properties.get( texture );\n\n\t\tif ( texture.version > 0 && textureProperties.__version !== texture.version ) {\n\n\t\t\tuploadTexture( textureProperties, texture, slot );\n\t\t\treturn;\n\n\t\t}\n\n\t\tstate.activeTexture( 33984 + slot );\n\t\tstate.bindTexture( 35866, textureProperties.__webglTexture );\n\n\t}\n\n\tfunction setTexture3D( texture, slot ) {\n\n\t\tconst textureProperties = properties.get( texture );\n\n\t\tif ( texture.version > 0 && textureProperties.__version !== texture.version ) {\n\n\t\t\tuploadTexture( textureProperties, texture, slot );\n\t\t\treturn;\n\n\t\t}\n\n\t\tstate.activeTexture( 33984 + slot );\n\t\tstate.bindTexture( 32879, textureProperties.__webglTexture );\n\n\t}\n\n\tfunction setTextureCube( texture, slot ) {\n\n\t\tconst textureProperties = properties.get( texture );\n\n\t\tif ( texture.version > 0 && textureProperties.__version !== texture.version ) {\n\n\t\t\tuploadCubeTexture( textureProperties, texture, slot );\n\t\t\treturn;\n\n\t\t}\n\n\t\tstate.activeTexture( 33984 + slot );\n\t\tstate.bindTexture( 34067, textureProperties.__webglTexture );\n\n\t}\n\n\tconst wrappingToGL = {\n\t\t[ RepeatWrapping ]: 10497,\n\t\t[ ClampToEdgeWrapping ]: 33071,\n\t\t[ MirroredRepeatWrapping ]: 33648\n\t};\n\n\tconst filterToGL = {\n\t\t[ NearestFilter ]: 9728,\n\t\t[ NearestMipmapNearestFilter ]: 9984,\n\t\t[ NearestMipmapLinearFilter ]: 9986,\n\n\t\t[ LinearFilter ]: 9729,\n\t\t[ LinearMipmapNearestFilter ]: 9985,\n\t\t[ LinearMipmapLinearFilter ]: 9987\n\t};\n\n\tfunction setTextureParameters( textureType, texture, supportsMips ) {\n\n\t\tif ( supportsMips ) {\n\n\t\t\t_gl.texParameteri( textureType, 10242, wrappingToGL[ texture.wrapS ] );\n\t\t\t_gl.texParameteri( textureType, 10243, wrappingToGL[ texture.wrapT ] );\n\n\t\t\tif ( textureType === 32879 || textureType === 35866 ) {\n\n\t\t\t\t_gl.texParameteri( textureType, 32882, wrappingToGL[ texture.wrapR ] );\n\n\t\t\t}\n\n\t\t\t_gl.texParameteri( textureType, 10240, filterToGL[ texture.magFilter ] );\n\t\t\t_gl.texParameteri( textureType, 10241, filterToGL[ texture.minFilter ] );\n\n\t\t} else {\n\n\t\t\t_gl.texParameteri( textureType, 10242, 33071 );\n\t\t\t_gl.texParameteri( textureType, 10243, 33071 );\n\n\t\t\tif ( textureType === 32879 || textureType === 35866 ) {\n\n\t\t\t\t_gl.texParameteri( textureType, 32882, 33071 );\n\n\t\t\t}\n\n\t\t\tif ( texture.wrapS !== ClampToEdgeWrapping || texture.wrapT !== ClampToEdgeWrapping ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Texture is not power of two. Texture.wrapS and Texture.wrapT should be set to THREE.ClampToEdgeWrapping.' );\n\n\t\t\t}\n\n\t\t\t_gl.texParameteri( textureType, 10240, filterFallback( texture.magFilter ) );\n\t\t\t_gl.texParameteri( textureType, 10241, filterFallback( texture.minFilter ) );\n\n\t\t\tif ( texture.minFilter !== NearestFilter && texture.minFilter !== LinearFilter ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Texture is not power of two. Texture.minFilter should be set to THREE.NearestFilter or THREE.LinearFilter.' );\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( extensions.has( 'EXT_texture_filter_anisotropic' ) === true ) {\n\n\t\t\tconst extension = extensions.get( 'EXT_texture_filter_anisotropic' );\n\n\t\t\tif ( texture.type === FloatType && extensions.has( 'OES_texture_float_linear' ) === false ) return; // verify extension for WebGL 1 and WebGL 2\n\t\t\tif ( isWebGL2 === false && ( texture.type === HalfFloatType && extensions.has( 'OES_texture_half_float_linear' ) === false ) ) return; // verify extension for WebGL 1 only\n\n\t\t\tif ( texture.anisotropy > 1 || properties.get( texture ).__currentAnisotropy ) {\n\n\t\t\t\t_gl.texParameterf( textureType, extension.TEXTURE_MAX_ANISOTROPY_EXT, Math.min( texture.anisotropy, capabilities.getMaxAnisotropy() ) );\n\t\t\t\tproperties.get( texture ).__currentAnisotropy = texture.anisotropy;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction initTexture( textureProperties, texture ) {\n\n\t\tlet forceUpload = false;\n\n\t\tif ( textureProperties.__webglInit === undefined ) {\n\n\t\t\ttextureProperties.__webglInit = true;\n\n\t\t\ttexture.addEventListener( 'dispose', onTextureDispose );\n\n\t\t}\n\n\t\t// create Source <-> WebGLTextures mapping if necessary\n\n\t\tconst source = texture.source;\n\t\tlet webglTextures = _sources.get( source );\n\n\t\tif ( webglTextures === undefined ) {\n\n\t\t\twebglTextures = {};\n\t\t\t_sources.set( source, webglTextures );\n\n\t\t}\n\n\t\t// check if there is already a WebGLTexture object for the given texture parameters\n\n\t\tconst textureCacheKey = getTextureCacheKey( texture );\n\n\t\tif ( textureCacheKey !== textureProperties.__cacheKey ) {\n\n\t\t\t// if not, create a new instance of WebGLTexture\n\n\t\t\tif ( webglTextures[ textureCacheKey ] === undefined ) {\n\n\t\t\t\t// create new entry\n\n\t\t\t\twebglTextures[ textureCacheKey ] = {\n\t\t\t\t\ttexture: _gl.createTexture(),\n\t\t\t\t\tusedTimes: 0\n\t\t\t\t};\n\n\t\t\t\tinfo.memory.textures ++;\n\n\t\t\t\t// when a new instance of WebGLTexture was created, a texture upload is required\n\t\t\t\t// even if the image contents are identical\n\n\t\t\t\tforceUpload = true;\n\n\t\t\t}\n\n\t\t\twebglTextures[ textureCacheKey ].usedTimes ++;\n\n\t\t\t// every time the texture cache key changes, it's necessary to check if an instance of\n\t\t\t// WebGLTexture can be deleted in order to avoid a memory leak.\n\n\t\t\tconst webglTexture = webglTextures[ textureProperties.__cacheKey ];\n\n\t\t\tif ( webglTexture !== undefined ) {\n\n\t\t\t\twebglTextures[ textureProperties.__cacheKey ].usedTimes --;\n\n\t\t\t\tif ( webglTexture.usedTimes === 0 ) {\n\n\t\t\t\t\tdeleteTexture( texture );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// store references to cache key and WebGLTexture object\n\n\t\t\ttextureProperties.__cacheKey = textureCacheKey;\n\t\t\ttextureProperties.__webglTexture = webglTextures[ textureCacheKey ].texture;\n\n\t\t}\n\n\t\treturn forceUpload;\n\n\t}\n\n\tfunction uploadTexture( textureProperties, texture, slot ) {\n\n\t\tlet textureType = 3553;\n\n\t\tif ( texture.isDataArrayTexture ) textureType = 35866;\n\t\tif ( texture.isData3DTexture ) textureType = 32879;\n\n\t\tconst forceUpload = initTexture( textureProperties, texture );\n\t\tconst source = texture.source;\n\n\t\tstate.activeTexture( 33984 + slot );\n\t\tstate.bindTexture( textureType, textureProperties.__webglTexture );\n\n\t\tif ( source.version !== source.__currentVersion || forceUpload === true ) {\n\n\t\t\t_gl.pixelStorei( 37440, texture.flipY );\n\t\t\t_gl.pixelStorei( 37441, texture.premultiplyAlpha );\n\t\t\t_gl.pixelStorei( 3317, texture.unpackAlignment );\n\t\t\t_gl.pixelStorei( 37443, 0 );\n\n\t\t\tconst needsPowerOfTwo = textureNeedsPowerOfTwo( texture ) && isPowerOfTwo$1( texture.image ) === false;\n\t\t\tlet image = resizeImage( texture.image, needsPowerOfTwo, false, maxTextureSize );\n\t\t\timage = verifyColorSpace( texture, image );\n\n\t\t\tconst supportsMips = isPowerOfTwo$1( image ) || isWebGL2,\n\t\t\t\tglFormat = utils.convert( texture.format, texture.encoding );\n\n\t\t\tlet glType = utils.convert( texture.type ),\n\t\t\t\tglInternalFormat = getInternalFormat( texture.internalFormat, glFormat, glType, texture.encoding, texture.isVideoTexture );\n\n\t\t\tsetTextureParameters( textureType, texture, supportsMips );\n\n\t\t\tlet mipmap;\n\t\t\tconst mipmaps = texture.mipmaps;\n\n\t\t\tconst useTexStorage = ( isWebGL2 && texture.isVideoTexture !== true );\n\t\t\tconst allocateMemory = ( source.__currentVersion === undefined ) || ( forceUpload === true );\n\t\t\tconst levels = getMipLevels( texture, image, supportsMips );\n\n\t\t\tif ( texture.isDepthTexture ) {\n\n\t\t\t\t// populate depth texture with dummy data\n\n\t\t\t\tglInternalFormat = 6402;\n\n\t\t\t\tif ( isWebGL2 ) {\n\n\t\t\t\t\tif ( texture.type === FloatType ) {\n\n\t\t\t\t\t\tglInternalFormat = 36012;\n\n\t\t\t\t\t} else if ( texture.type === UnsignedIntType ) {\n\n\t\t\t\t\t\tglInternalFormat = 33190;\n\n\t\t\t\t\t} else if ( texture.type === UnsignedInt248Type ) {\n\n\t\t\t\t\t\tglInternalFormat = 35056;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tglInternalFormat = 33189; // WebGL2 requires sized internalformat for glTexImage2D\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tif ( texture.type === FloatType ) {\n\n\t\t\t\t\t\tconsole.error( 'WebGLRenderer: Floating point depth texture requires WebGL2.' );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\t// validation checks for WebGL 1\n\n\t\t\t\tif ( texture.format === DepthFormat && glInternalFormat === 6402 ) {\n\n\t\t\t\t\t// The error INVALID_OPERATION is generated by texImage2D if format and internalformat are\n\t\t\t\t\t// DEPTH_COMPONENT and type is not UNSIGNED_SHORT or UNSIGNED_INT\n\t\t\t\t\t// (https://www.khronos.org/registry/webgl/extensions/WEBGL_depth_texture/)\n\t\t\t\t\tif ( texture.type !== UnsignedShortType && texture.type !== UnsignedIntType ) {\n\n\t\t\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Use UnsignedShortType or UnsignedIntType for DepthFormat DepthTexture.' );\n\n\t\t\t\t\t\ttexture.type = UnsignedIntType;\n\t\t\t\t\t\tglType = utils.convert( texture.type );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tif ( texture.format === DepthStencilFormat && glInternalFormat === 6402 ) {\n\n\t\t\t\t\t// Depth stencil textures need the DEPTH_STENCIL internal format\n\t\t\t\t\t// (https://www.khronos.org/registry/webgl/extensions/WEBGL_depth_texture/)\n\t\t\t\t\tglInternalFormat = 34041;\n\n\t\t\t\t\t// The error INVALID_OPERATION is generated by texImage2D if format and internalformat are\n\t\t\t\t\t// DEPTH_STENCIL and type is not UNSIGNED_INT_24_8_WEBGL.\n\t\t\t\t\t// (https://www.khronos.org/registry/webgl/extensions/WEBGL_depth_texture/)\n\t\t\t\t\tif ( texture.type !== UnsignedInt248Type ) {\n\n\t\t\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Use UnsignedInt248Type for DepthStencilFormat DepthTexture.' );\n\n\t\t\t\t\t\ttexture.type = UnsignedInt248Type;\n\t\t\t\t\t\tglType = utils.convert( texture.type );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\t//\n\n\t\t\t\tif ( allocateMemory ) {\n\n\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\tstate.texStorage2D( 3553, 1, glInternalFormat, image.width, image.height );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tstate.texImage2D( 3553, 0, glInternalFormat, image.width, image.height, 0, glFormat, glType, null );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else if ( texture.isDataTexture ) {\n\n\t\t\t\t// use manually created mipmaps if available\n\t\t\t\t// if there are no manual mipmaps\n\t\t\t\t// set 0 level mipmap and then use GL to generate other mipmap levels\n\n\t\t\t\tif ( mipmaps.length > 0 && supportsMips ) {\n\n\t\t\t\t\tif ( useTexStorage && allocateMemory ) {\n\n\t\t\t\t\t\tstate.texStorage2D( 3553, levels, glInternalFormat, mipmaps[ 0 ].width, mipmaps[ 0 ].height );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tfor ( let i = 0, il = mipmaps.length; i < il; i ++ ) {\n\n\t\t\t\t\t\tmipmap = mipmaps[ i ];\n\n\t\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\t\tstate.texSubImage2D( 3553, i, 0, 0, mipmap.width, mipmap.height, glFormat, glType, mipmap.data );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tstate.texImage2D( 3553, i, glInternalFormat, mipmap.width, mipmap.height, 0, glFormat, glType, mipmap.data );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\ttexture.generateMipmaps = false;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\tif ( allocateMemory ) {\n\n\t\t\t\t\t\t\tstate.texStorage2D( 3553, levels, glInternalFormat, image.width, image.height );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tstate.texSubImage2D( 3553, 0, 0, 0, image.width, image.height, glFormat, glType, image.data );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tstate.texImage2D( 3553, 0, glInternalFormat, image.width, image.height, 0, glFormat, glType, image.data );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else if ( texture.isCompressedTexture ) {\n\n\t\t\t\tif ( useTexStorage && allocateMemory ) {\n\n\t\t\t\t\tstate.texStorage2D( 3553, levels, glInternalFormat, mipmaps[ 0 ].width, mipmaps[ 0 ].height );\n\n\t\t\t\t}\n\n\t\t\t\tfor ( let i = 0, il = mipmaps.length; i < il; i ++ ) {\n\n\t\t\t\t\tmipmap = mipmaps[ i ];\n\n\t\t\t\t\tif ( texture.format !== RGBAFormat ) {\n\n\t\t\t\t\t\tif ( glFormat !== null ) {\n\n\t\t\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\t\t\tstate.compressedTexSubImage2D( 3553, i, 0, 0, mipmap.width, mipmap.height, glFormat, mipmap.data );\n\n\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\tstate.compressedTexImage2D( 3553, i, glInternalFormat, mipmap.width, mipmap.height, 0, mipmap.data );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .uploadTexture()' );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\t\tstate.texSubImage2D( 3553, i, 0, 0, mipmap.width, mipmap.height, glFormat, glType, mipmap.data );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tstate.texImage2D( 3553, i, glInternalFormat, mipmap.width, mipmap.height, 0, glFormat, glType, mipmap.data );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else if ( texture.isDataArrayTexture ) {\n\n\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\tif ( allocateMemory ) {\n\n\t\t\t\t\t\tstate.texStorage3D( 35866, levels, glInternalFormat, image.width, image.height, image.depth );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tstate.texSubImage3D( 35866, 0, 0, 0, 0, image.width, image.height, image.depth, glFormat, glType, image.data );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tstate.texImage3D( 35866, 0, glInternalFormat, image.width, image.height, image.depth, 0, glFormat, glType, image.data );\n\n\t\t\t\t}\n\n\t\t\t} else if ( texture.isData3DTexture ) {\n\n\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\tif ( allocateMemory ) {\n\n\t\t\t\t\t\tstate.texStorage3D( 32879, levels, glInternalFormat, image.width, image.height, image.depth );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tstate.texSubImage3D( 32879, 0, 0, 0, 0, image.width, image.height, image.depth, glFormat, glType, image.data );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tstate.texImage3D( 32879, 0, glInternalFormat, image.width, image.height, image.depth, 0, glFormat, glType, image.data );\n\n\t\t\t\t}\n\n\t\t\t} else if ( texture.isFramebufferTexture ) {\n\n\t\t\t\tif ( allocateMemory ) {\n\n\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\tstate.texStorage2D( 3553, levels, glInternalFormat, image.width, image.height );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tlet width = image.width, height = image.height;\n\n\t\t\t\t\t\tfor ( let i = 0; i < levels; i ++ ) {\n\n\t\t\t\t\t\t\tstate.texImage2D( 3553, i, glInternalFormat, width, height, 0, glFormat, glType, null );\n\n\t\t\t\t\t\t\twidth >>= 1;\n\t\t\t\t\t\t\theight >>= 1;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t// regular Texture (image, video, canvas)\n\n\t\t\t\t// use manually created mipmaps if available\n\t\t\t\t// if there are no manual mipmaps\n\t\t\t\t// set 0 level mipmap and then use GL to generate other mipmap levels\n\n\t\t\t\tif ( mipmaps.length > 0 && supportsMips ) {\n\n\t\t\t\t\tif ( useTexStorage && allocateMemory ) {\n\n\t\t\t\t\t\tstate.texStorage2D( 3553, levels, glInternalFormat, mipmaps[ 0 ].width, mipmaps[ 0 ].height );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tfor ( let i = 0, il = mipmaps.length; i < il; i ++ ) {\n\n\t\t\t\t\t\tmipmap = mipmaps[ i ];\n\n\t\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\t\tstate.texSubImage2D( 3553, i, 0, 0, glFormat, glType, mipmap );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tstate.texImage2D( 3553, i, glInternalFormat, glFormat, glType, mipmap );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\ttexture.generateMipmaps = false;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\tif ( allocateMemory ) {\n\n\t\t\t\t\t\t\tstate.texStorage2D( 3553, levels, glInternalFormat, image.width, image.height );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tstate.texSubImage2D( 3553, 0, 0, 0, glFormat, glType, image );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tstate.texImage2D( 3553, 0, glInternalFormat, glFormat, glType, image );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( textureNeedsGenerateMipmaps( texture, supportsMips ) ) {\n\n\t\t\t\tgenerateMipmap( textureType );\n\n\t\t\t}\n\n\t\t\tsource.__currentVersion = source.version;\n\n\t\t\tif ( texture.onUpdate ) texture.onUpdate( texture );\n\n\t\t}\n\n\t\ttextureProperties.__version = texture.version;\n\n\t}\n\n\tfunction uploadCubeTexture( textureProperties, texture, slot ) {\n\n\t\tif ( texture.image.length !== 6 ) return;\n\n\t\tconst forceUpload = initTexture( textureProperties, texture );\n\t\tconst source = texture.source;\n\n\t\tstate.activeTexture( 33984 + slot );\n\t\tstate.bindTexture( 34067, textureProperties.__webglTexture );\n\n\t\tif ( source.version !== source.__currentVersion || forceUpload === true ) {\n\n\t\t\t_gl.pixelStorei( 37440, texture.flipY );\n\t\t\t_gl.pixelStorei( 37441, texture.premultiplyAlpha );\n\t\t\t_gl.pixelStorei( 3317, texture.unpackAlignment );\n\t\t\t_gl.pixelStorei( 37443, 0 );\n\n\t\t\tconst isCompressed = ( texture.isCompressedTexture || texture.image[ 0 ].isCompressedTexture );\n\t\t\tconst isDataTexture = ( texture.image[ 0 ] && texture.image[ 0 ].isDataTexture );\n\n\t\t\tconst cubeImage = [];\n\n\t\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\t\tif ( ! isCompressed && ! isDataTexture ) {\n\n\t\t\t\t\tcubeImage[ i ] = resizeImage( texture.image[ i ], false, true, maxCubemapSize );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tcubeImage[ i ] = isDataTexture ? texture.image[ i ].image : texture.image[ i ];\n\n\t\t\t\t}\n\n\t\t\t\tcubeImage[ i ] = verifyColorSpace( texture, cubeImage[ i ] );\n\n\t\t\t}\n\n\t\t\tconst image = cubeImage[ 0 ],\n\t\t\t\tsupportsMips = isPowerOfTwo$1( image ) || isWebGL2,\n\t\t\t\tglFormat = utils.convert( texture.format, texture.encoding ),\n\t\t\t\tglType = utils.convert( texture.type ),\n\t\t\t\tglInternalFormat = getInternalFormat( texture.internalFormat, glFormat, glType, texture.encoding );\n\n\t\t\tconst useTexStorage = ( isWebGL2 && texture.isVideoTexture !== true );\n\t\t\tconst allocateMemory = ( source.__currentVersion === undefined ) || ( forceUpload === true );\n\t\t\tlet levels = getMipLevels( texture, image, supportsMips );\n\n\t\t\tsetTextureParameters( 34067, texture, supportsMips );\n\n\t\t\tlet mipmaps;\n\n\t\t\tif ( isCompressed ) {\n\n\t\t\t\tif ( useTexStorage && allocateMemory ) {\n\n\t\t\t\t\tstate.texStorage2D( 34067, levels, glInternalFormat, image.width, image.height );\n\n\t\t\t\t}\n\n\t\t\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\t\t\tmipmaps = cubeImage[ i ].mipmaps;\n\n\t\t\t\t\tfor ( let j = 0; j < mipmaps.length; j ++ ) {\n\n\t\t\t\t\t\tconst mipmap = mipmaps[ j ];\n\n\t\t\t\t\t\tif ( texture.format !== RGBAFormat ) {\n\n\t\t\t\t\t\t\tif ( glFormat !== null ) {\n\n\t\t\t\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\t\t\t\tstate.compressedTexSubImage2D( 34069 + i, j, 0, 0, mipmap.width, mipmap.height, glFormat, mipmap.data );\n\n\t\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\t\tstate.compressedTexImage2D( 34069 + i, j, glInternalFormat, mipmap.width, mipmap.height, 0, mipmap.data );\n\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .setTextureCube()' );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\t\t\tstate.texSubImage2D( 34069 + i, j, 0, 0, mipmap.width, mipmap.height, glFormat, glType, mipmap.data );\n\n\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\tstate.texImage2D( 34069 + i, j, glInternalFormat, mipmap.width, mipmap.height, 0, glFormat, glType, mipmap.data );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tmipmaps = texture.mipmaps;\n\n\t\t\t\tif ( useTexStorage && allocateMemory ) {\n\n\t\t\t\t\t// TODO: Uniformly handle mipmap definitions\n\t\t\t\t\t// Normal textures and compressed cube textures define base level + mips with their mipmap array\n\t\t\t\t\t// Uncompressed cube textures use their mipmap array only for mips (no base level)\n\n\t\t\t\t\tif ( mipmaps.length > 0 ) levels ++;\n\n\t\t\t\t\tstate.texStorage2D( 34067, levels, glInternalFormat, cubeImage[ 0 ].width, cubeImage[ 0 ].height );\n\n\t\t\t\t}\n\n\t\t\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\t\t\tif ( isDataTexture ) {\n\n\t\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\t\tstate.texSubImage2D( 34069 + i, 0, 0, 0, cubeImage[ i ].width, cubeImage[ i ].height, glFormat, glType, cubeImage[ i ].data );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tstate.texImage2D( 34069 + i, 0, glInternalFormat, cubeImage[ i ].width, cubeImage[ i ].height, 0, glFormat, glType, cubeImage[ i ].data );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tfor ( let j = 0; j < mipmaps.length; j ++ ) {\n\n\t\t\t\t\t\t\tconst mipmap = mipmaps[ j ];\n\t\t\t\t\t\t\tconst mipmapImage = mipmap.image[ i ].image;\n\n\t\t\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\t\t\tstate.texSubImage2D( 34069 + i, j + 1, 0, 0, mipmapImage.width, mipmapImage.height, glFormat, glType, mipmapImage.data );\n\n\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\tstate.texImage2D( 34069 + i, j + 1, glInternalFormat, mipmapImage.width, mipmapImage.height, 0, glFormat, glType, mipmapImage.data );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\t\tstate.texSubImage2D( 34069 + i, 0, 0, 0, glFormat, glType, cubeImage[ i ] );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tstate.texImage2D( 34069 + i, 0, glInternalFormat, glFormat, glType, cubeImage[ i ] );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tfor ( let j = 0; j < mipmaps.length; j ++ ) {\n\n\t\t\t\t\t\t\tconst mipmap = mipmaps[ j ];\n\n\t\t\t\t\t\t\tif ( useTexStorage ) {\n\n\t\t\t\t\t\t\t\tstate.texSubImage2D( 34069 + i, j + 1, 0, 0, glFormat, glType, mipmap.image[ i ] );\n\n\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\tstate.texImage2D( 34069 + i, j + 1, glInternalFormat, glFormat, glType, mipmap.image[ i ] );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( textureNeedsGenerateMipmaps( texture, supportsMips ) ) {\n\n\t\t\t\t// We assume images for cube map have the same size.\n\t\t\t\tgenerateMipmap( 34067 );\n\n\t\t\t}\n\n\t\t\tsource.__currentVersion = source.version;\n\n\t\t\tif ( texture.onUpdate ) texture.onUpdate( texture );\n\n\t\t}\n\n\t\ttextureProperties.__version = texture.version;\n\n\t}\n\n\t// Render targets\n\n\t// Setup storage for target texture and bind it to correct framebuffer\n\tfunction setupFrameBufferTexture( framebuffer, renderTarget, texture, attachment, textureTarget ) {\n\n\t\tconst glFormat = utils.convert( texture.format, texture.encoding );\n\t\tconst glType = utils.convert( texture.type );\n\t\tconst glInternalFormat = getInternalFormat( texture.internalFormat, glFormat, glType, texture.encoding );\n\t\tconst renderTargetProperties = properties.get( renderTarget );\n\n\t\tif ( ! renderTargetProperties.__hasExternalTextures ) {\n\n\t\t\tif ( textureTarget === 32879 || textureTarget === 35866 ) {\n\n\t\t\t\tstate.texImage3D( textureTarget, 0, glInternalFormat, renderTarget.width, renderTarget.height, renderTarget.depth, 0, glFormat, glType, null );\n\n\t\t\t} else {\n\n\t\t\t\tstate.texImage2D( textureTarget, 0, glInternalFormat, renderTarget.width, renderTarget.height, 0, glFormat, glType, null );\n\n\t\t\t}\n\n\t\t}\n\n\t\tstate.bindFramebuffer( 36160, framebuffer );\n\n\t\tif ( useMultisampledRTT( renderTarget ) ) {\n\n\t\t\tmultisampledRTTExt.framebufferTexture2DMultisampleEXT( 36160, attachment, textureTarget, properties.get( texture ).__webglTexture, 0, getRenderTargetSamples( renderTarget ) );\n\n\t\t} else {\n\n\t\t\t_gl.framebufferTexture2D( 36160, attachment, textureTarget, properties.get( texture ).__webglTexture, 0 );\n\n\t\t}\n\n\t\tstate.bindFramebuffer( 36160, null );\n\n\t}\n\n\n\t// Setup storage for internal depth/stencil buffers and bind to correct framebuffer\n\tfunction setupRenderBufferStorage( renderbuffer, renderTarget, isMultisample ) {\n\n\t\t_gl.bindRenderbuffer( 36161, renderbuffer );\n\n\t\tif ( renderTarget.depthBuffer && ! renderTarget.stencilBuffer ) {\n\n\t\t\tlet glInternalFormat = 33189;\n\n\t\t\tif ( isMultisample || useMultisampledRTT( renderTarget ) ) {\n\n\t\t\t\tconst depthTexture = renderTarget.depthTexture;\n\n\t\t\t\tif ( depthTexture && depthTexture.isDepthTexture ) {\n\n\t\t\t\t\tif ( depthTexture.type === FloatType ) {\n\n\t\t\t\t\t\tglInternalFormat = 36012;\n\n\t\t\t\t\t} else if ( depthTexture.type === UnsignedIntType ) {\n\n\t\t\t\t\t\tglInternalFormat = 33190;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tconst samples = getRenderTargetSamples( renderTarget );\n\n\t\t\t\tif ( useMultisampledRTT( renderTarget ) ) {\n\n\t\t\t\t\tmultisampledRTTExt.renderbufferStorageMultisampleEXT( 36161, samples, glInternalFormat, renderTarget.width, renderTarget.height );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t_gl.renderbufferStorageMultisample( 36161, samples, glInternalFormat, renderTarget.width, renderTarget.height );\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t_gl.renderbufferStorage( 36161, glInternalFormat, renderTarget.width, renderTarget.height );\n\n\t\t\t}\n\n\t\t\t_gl.framebufferRenderbuffer( 36160, 36096, 36161, renderbuffer );\n\n\t\t} else if ( renderTarget.depthBuffer && renderTarget.stencilBuffer ) {\n\n\t\t\tconst samples = getRenderTargetSamples( renderTarget );\n\n\t\t\tif ( isMultisample && useMultisampledRTT( renderTarget ) === false ) {\n\n\t\t\t\t_gl.renderbufferStorageMultisample( 36161, samples, 35056, renderTarget.width, renderTarget.height );\n\n\t\t\t} else if ( useMultisampledRTT( renderTarget ) ) {\n\n\t\t\t\tmultisampledRTTExt.renderbufferStorageMultisampleEXT( 36161, samples, 35056, renderTarget.width, renderTarget.height );\n\n\t\t\t} else {\n\n\t\t\t\t_gl.renderbufferStorage( 36161, 34041, renderTarget.width, renderTarget.height );\n\n\t\t\t}\n\n\n\t\t\t_gl.framebufferRenderbuffer( 36160, 33306, 36161, renderbuffer );\n\n\t\t} else {\n\n\t\t\tconst textures = renderTarget.isWebGLMultipleRenderTargets === true ? renderTarget.texture : [ renderTarget.texture ];\n\n\t\t\tfor ( let i = 0; i < textures.length; i ++ ) {\n\n\t\t\t\tconst texture = textures[ i ];\n\n\t\t\t\tconst glFormat = utils.convert( texture.format, texture.encoding );\n\t\t\t\tconst glType = utils.convert( texture.type );\n\t\t\t\tconst glInternalFormat = getInternalFormat( texture.internalFormat, glFormat, glType, texture.encoding );\n\t\t\t\tconst samples = getRenderTargetSamples( renderTarget );\n\n\t\t\t\tif ( isMultisample && useMultisampledRTT( renderTarget ) === false ) {\n\n\t\t\t\t\t_gl.renderbufferStorageMultisample( 36161, samples, glInternalFormat, renderTarget.width, renderTarget.height );\n\n\t\t\t\t} else if ( useMultisampledRTT( renderTarget ) ) {\n\n\t\t\t\t\tmultisampledRTTExt.renderbufferStorageMultisampleEXT( 36161, samples, glInternalFormat, renderTarget.width, renderTarget.height );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t_gl.renderbufferStorage( 36161, glInternalFormat, renderTarget.width, renderTarget.height );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\t_gl.bindRenderbuffer( 36161, null );\n\n\t}\n\n\t// Setup resources for a Depth Texture for a FBO (needs an extension)\n\tfunction setupDepthTexture( framebuffer, renderTarget ) {\n\n\t\tconst isCube = ( renderTarget && renderTarget.isWebGLCubeRenderTarget );\n\t\tif ( isCube ) throw new Error( 'Depth Texture with cube render targets is not supported' );\n\n\t\tstate.bindFramebuffer( 36160, framebuffer );\n\n\t\tif ( ! ( renderTarget.depthTexture && renderTarget.depthTexture.isDepthTexture ) ) {\n\n\t\t\tthrow new Error( 'renderTarget.depthTexture must be an instance of THREE.DepthTexture' );\n\n\t\t}\n\n\t\t// upload an empty depth texture with framebuffer size\n\t\tif ( ! properties.get( renderTarget.depthTexture ).__webglTexture ||\n\t\t\t\trenderTarget.depthTexture.image.width !== renderTarget.width ||\n\t\t\t\trenderTarget.depthTexture.image.height !== renderTarget.height ) {\n\n\t\t\trenderTarget.depthTexture.image.width = renderTarget.width;\n\t\t\trenderTarget.depthTexture.image.height = renderTarget.height;\n\t\t\trenderTarget.depthTexture.needsUpdate = true;\n\n\t\t}\n\n\t\tsetTexture2D( renderTarget.depthTexture, 0 );\n\n\t\tconst webglDepthTexture = properties.get( renderTarget.depthTexture ).__webglTexture;\n\t\tconst samples = getRenderTargetSamples( renderTarget );\n\n\t\tif ( renderTarget.depthTexture.format === DepthFormat ) {\n\n\t\t\tif ( useMultisampledRTT( renderTarget ) ) {\n\n\t\t\t\tmultisampledRTTExt.framebufferTexture2DMultisampleEXT( 36160, 36096, 3553, webglDepthTexture, 0, samples );\n\n\t\t\t} else {\n\n\t\t\t\t_gl.framebufferTexture2D( 36160, 36096, 3553, webglDepthTexture, 0 );\n\n\t\t\t}\n\n\t\t} else if ( renderTarget.depthTexture.format === DepthStencilFormat ) {\n\n\t\t\tif ( useMultisampledRTT( renderTarget ) ) {\n\n\t\t\t\tmultisampledRTTExt.framebufferTexture2DMultisampleEXT( 36160, 33306, 3553, webglDepthTexture, 0, samples );\n\n\t\t\t} else {\n\n\t\t\t\t_gl.framebufferTexture2D( 36160, 33306, 3553, webglDepthTexture, 0 );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tthrow new Error( 'Unknown depthTexture format' );\n\n\t\t}\n\n\t}\n\n\t// Setup GL resources for a non-texture depth buffer\n\tfunction setupDepthRenderbuffer( renderTarget ) {\n\n\t\tconst renderTargetProperties = properties.get( renderTarget );\n\t\tconst isCube = ( renderTarget.isWebGLCubeRenderTarget === true );\n\n\t\tif ( renderTarget.depthTexture && ! renderTargetProperties.__autoAllocateDepthBuffer ) {\n\n\t\t\tif ( isCube ) throw new Error( 'target.depthTexture not supported in Cube render targets' );\n\n\t\t\tsetupDepthTexture( renderTargetProperties.__webglFramebuffer, renderTarget );\n\n\t\t} else {\n\n\t\t\tif ( isCube ) {\n\n\t\t\t\trenderTargetProperties.__webglDepthbuffer = [];\n\n\t\t\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\t\t\tstate.bindFramebuffer( 36160, renderTargetProperties.__webglFramebuffer[ i ] );\n\t\t\t\t\trenderTargetProperties.__webglDepthbuffer[ i ] = _gl.createRenderbuffer();\n\t\t\t\t\tsetupRenderBufferStorage( renderTargetProperties.__webglDepthbuffer[ i ], renderTarget, false );\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tstate.bindFramebuffer( 36160, renderTargetProperties.__webglFramebuffer );\n\t\t\t\trenderTargetProperties.__webglDepthbuffer = _gl.createRenderbuffer();\n\t\t\t\tsetupRenderBufferStorage( renderTargetProperties.__webglDepthbuffer, renderTarget, false );\n\n\t\t\t}\n\n\t\t}\n\n\t\tstate.bindFramebuffer( 36160, null );\n\n\t}\n\n\t// rebind framebuffer with external textures\n\tfunction rebindTextures( renderTarget, colorTexture, depthTexture ) {\n\n\t\tconst renderTargetProperties = properties.get( renderTarget );\n\n\t\tif ( colorTexture !== undefined ) {\n\n\t\t\tsetupFrameBufferTexture( renderTargetProperties.__webglFramebuffer, renderTarget, renderTarget.texture, 36064, 3553 );\n\n\t\t}\n\n\t\tif ( depthTexture !== undefined ) {\n\n\t\t\tsetupDepthRenderbuffer( renderTarget );\n\n\t\t}\n\n\t}\n\n\t// Set up GL resources for the render target\n\tfunction setupRenderTarget( renderTarget ) {\n\n\t\tconst texture = renderTarget.texture;\n\n\t\tconst renderTargetProperties = properties.get( renderTarget );\n\t\tconst textureProperties = properties.get( texture );\n\n\t\trenderTarget.addEventListener( 'dispose', onRenderTargetDispose );\n\n\t\tif ( renderTarget.isWebGLMultipleRenderTargets !== true ) {\n\n\t\t\tif ( textureProperties.__webglTexture === undefined ) {\n\n\t\t\t\ttextureProperties.__webglTexture = _gl.createTexture();\n\n\t\t\t}\n\n\t\t\ttextureProperties.__version = texture.version;\n\t\t\tinfo.memory.textures ++;\n\n\t\t}\n\n\t\tconst isCube = ( renderTarget.isWebGLCubeRenderTarget === true );\n\t\tconst isMultipleRenderTargets = ( renderTarget.isWebGLMultipleRenderTargets === true );\n\t\tconst supportsMips = isPowerOfTwo$1( renderTarget ) || isWebGL2;\n\n\t\t// Setup framebuffer\n\n\t\tif ( isCube ) {\n\n\t\t\trenderTargetProperties.__webglFramebuffer = [];\n\n\t\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\t\trenderTargetProperties.__webglFramebuffer[ i ] = _gl.createFramebuffer();\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\trenderTargetProperties.__webglFramebuffer = _gl.createFramebuffer();\n\n\t\t\tif ( isMultipleRenderTargets ) {\n\n\t\t\t\tif ( capabilities.drawBuffers ) {\n\n\t\t\t\t\tconst textures = renderTarget.texture;\n\n\t\t\t\t\tfor ( let i = 0, il = textures.length; i < il; i ++ ) {\n\n\t\t\t\t\t\tconst attachmentProperties = properties.get( textures[ i ] );\n\n\t\t\t\t\t\tif ( attachmentProperties.__webglTexture === undefined ) {\n\n\t\t\t\t\t\t\tattachmentProperties.__webglTexture = _gl.createTexture();\n\n\t\t\t\t\t\t\tinfo.memory.textures ++;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: WebGLMultipleRenderTargets can only be used with WebGL2 or WEBGL_draw_buffers extension.' );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( ( isWebGL2 && renderTarget.samples > 0 ) && useMultisampledRTT( renderTarget ) === false ) {\n\n\t\t\t\tconst textures = isMultipleRenderTargets ? texture : [ texture ];\n\n\t\t\t\trenderTargetProperties.__webglMultisampledFramebuffer = _gl.createFramebuffer();\n\t\t\t\trenderTargetProperties.__webglColorRenderbuffer = [];\n\n\t\t\t\tstate.bindFramebuffer( 36160, renderTargetProperties.__webglMultisampledFramebuffer );\n\n\t\t\t\tfor ( let i = 0; i < textures.length; i ++ ) {\n\n\t\t\t\t\tconst texture = textures[ i ];\n\t\t\t\t\trenderTargetProperties.__webglColorRenderbuffer[ i ] = _gl.createRenderbuffer();\n\n\t\t\t\t\t_gl.bindRenderbuffer( 36161, renderTargetProperties.__webglColorRenderbuffer[ i ] );\n\n\t\t\t\t\tconst glFormat = utils.convert( texture.format, texture.encoding );\n\t\t\t\t\tconst glType = utils.convert( texture.type );\n\t\t\t\t\tconst glInternalFormat = getInternalFormat( texture.internalFormat, glFormat, glType, texture.encoding );\n\t\t\t\t\tconst samples = getRenderTargetSamples( renderTarget );\n\t\t\t\t\t_gl.renderbufferStorageMultisample( 36161, samples, glInternalFormat, renderTarget.width, renderTarget.height );\n\n\t\t\t\t\t_gl.framebufferRenderbuffer( 36160, 36064 + i, 36161, renderTargetProperties.__webglColorRenderbuffer[ i ] );\n\n\t\t\t\t}\n\n\t\t\t\t_gl.bindRenderbuffer( 36161, null );\n\n\t\t\t\tif ( renderTarget.depthBuffer ) {\n\n\t\t\t\t\trenderTargetProperties.__webglDepthRenderbuffer = _gl.createRenderbuffer();\n\t\t\t\t\tsetupRenderBufferStorage( renderTargetProperties.__webglDepthRenderbuffer, renderTarget, true );\n\n\t\t\t\t}\n\n\t\t\t\tstate.bindFramebuffer( 36160, null );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// Setup color buffer\n\n\t\tif ( isCube ) {\n\n\t\t\tstate.bindTexture( 34067, textureProperties.__webglTexture );\n\t\t\tsetTextureParameters( 34067, texture, supportsMips );\n\n\t\t\tfor ( let i = 0; i < 6; i ++ ) {\n\n\t\t\t\tsetupFrameBufferTexture( renderTargetProperties.__webglFramebuffer[ i ], renderTarget, texture, 36064, 34069 + i );\n\n\t\t\t}\n\n\t\t\tif ( textureNeedsGenerateMipmaps( texture, supportsMips ) ) {\n\n\t\t\t\tgenerateMipmap( 34067 );\n\n\t\t\t}\n\n\t\t\tstate.unbindTexture();\n\n\t\t} else if ( isMultipleRenderTargets ) {\n\n\t\t\tconst textures = renderTarget.texture;\n\n\t\t\tfor ( let i = 0, il = textures.length; i < il; i ++ ) {\n\n\t\t\t\tconst attachment = textures[ i ];\n\t\t\t\tconst attachmentProperties = properties.get( attachment );\n\n\t\t\t\tstate.bindTexture( 3553, attachmentProperties.__webglTexture );\n\t\t\t\tsetTextureParameters( 3553, attachment, supportsMips );\n\t\t\t\tsetupFrameBufferTexture( renderTargetProperties.__webglFramebuffer, renderTarget, attachment, 36064 + i, 3553 );\n\n\t\t\t\tif ( textureNeedsGenerateMipmaps( attachment, supportsMips ) ) {\n\n\t\t\t\t\tgenerateMipmap( 3553 );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tstate.unbindTexture();\n\n\t\t} else {\n\n\t\t\tlet glTextureType = 3553;\n\n\t\t\tif ( renderTarget.isWebGL3DRenderTarget || renderTarget.isWebGLArrayRenderTarget ) {\n\n\t\t\t\tif ( isWebGL2 ) {\n\n\t\t\t\t\tglTextureType = renderTarget.isWebGL3DRenderTarget ? 32879 : 35866;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.error( 'THREE.WebGLTextures: THREE.Data3DTexture and THREE.DataArrayTexture only supported with WebGL2.' );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tstate.bindTexture( glTextureType, textureProperties.__webglTexture );\n\t\t\tsetTextureParameters( glTextureType, texture, supportsMips );\n\t\t\tsetupFrameBufferTexture( renderTargetProperties.__webglFramebuffer, renderTarget, texture, 36064, glTextureType );\n\n\t\t\tif ( textureNeedsGenerateMipmaps( texture, supportsMips ) ) {\n\n\t\t\t\tgenerateMipmap( glTextureType );\n\n\t\t\t}\n\n\t\t\tstate.unbindTexture();\n\n\t\t}\n\n\t\t// Setup depth and stencil buffers\n\n\t\tif ( renderTarget.depthBuffer ) {\n\n\t\t\tsetupDepthRenderbuffer( renderTarget );\n\n\t\t}\n\n\t}\n\n\tfunction updateRenderTargetMipmap( renderTarget ) {\n\n\t\tconst supportsMips = isPowerOfTwo$1( renderTarget ) || isWebGL2;\n\n\t\tconst textures = renderTarget.isWebGLMultipleRenderTargets === true ? renderTarget.texture : [ renderTarget.texture ];\n\n\t\tfor ( let i = 0, il = textures.length; i < il; i ++ ) {\n\n\t\t\tconst texture = textures[ i ];\n\n\t\t\tif ( textureNeedsGenerateMipmaps( texture, supportsMips ) ) {\n\n\t\t\t\tconst target = renderTarget.isWebGLCubeRenderTarget ? 34067 : 3553;\n\t\t\t\tconst webglTexture = properties.get( texture ).__webglTexture;\n\n\t\t\t\tstate.bindTexture( target, webglTexture );\n\t\t\t\tgenerateMipmap( target );\n\t\t\t\tstate.unbindTexture();\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction updateMultisampleRenderTarget( renderTarget ) {\n\n\t\tif ( ( isWebGL2 && renderTarget.samples > 0 ) && useMultisampledRTT( renderTarget ) === false ) {\n\n\t\t\tconst textures = renderTarget.isWebGLMultipleRenderTargets ? renderTarget.texture : [ renderTarget.texture ];\n\t\t\tconst width = renderTarget.width;\n\t\t\tconst height = renderTarget.height;\n\t\t\tlet mask = 16384;\n\t\t\tconst invalidationArray = [];\n\t\t\tconst depthStyle = renderTarget.stencilBuffer ? 33306 : 36096;\n\t\t\tconst renderTargetProperties = properties.get( renderTarget );\n\t\t\tconst isMultipleRenderTargets = ( renderTarget.isWebGLMultipleRenderTargets === true );\n\n\t\t\t// If MRT we need to remove FBO attachments\n\t\t\tif ( isMultipleRenderTargets ) {\n\n\t\t\t\tfor ( let i = 0; i < textures.length; i ++ ) {\n\n\t\t\t\t\tstate.bindFramebuffer( 36160, renderTargetProperties.__webglMultisampledFramebuffer );\n\t\t\t\t\t_gl.framebufferRenderbuffer( 36160, 36064 + i, 36161, null );\n\n\t\t\t\t\tstate.bindFramebuffer( 36160, renderTargetProperties.__webglFramebuffer );\n\t\t\t\t\t_gl.framebufferTexture2D( 36009, 36064 + i, 3553, null, 0 );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tstate.bindFramebuffer( 36008, renderTargetProperties.__webglMultisampledFramebuffer );\n\t\t\tstate.bindFramebuffer( 36009, renderTargetProperties.__webglFramebuffer );\n\n\t\t\tfor ( let i = 0; i < textures.length; i ++ ) {\n\n\t\t\t\tinvalidationArray.push( 36064 + i );\n\n\t\t\t\tif ( renderTarget.depthBuffer ) {\n\n\t\t\t\t\tinvalidationArray.push( depthStyle );\n\n\t\t\t\t}\n\n\t\t\t\tconst ignoreDepthValues = ( renderTargetProperties.__ignoreDepthValues !== undefined ) ? renderTargetProperties.__ignoreDepthValues : false;\n\n\t\t\t\tif ( ignoreDepthValues === false ) {\n\n\t\t\t\t\tif ( renderTarget.depthBuffer ) mask |= 256;\n\t\t\t\t\tif ( renderTarget.stencilBuffer ) mask |= 1024;\n\n\t\t\t\t}\n\n\t\t\t\tif ( isMultipleRenderTargets ) {\n\n\t\t\t\t\t_gl.framebufferRenderbuffer( 36008, 36064, 36161, renderTargetProperties.__webglColorRenderbuffer[ i ] );\n\n\t\t\t\t}\n\n\t\t\t\tif ( ignoreDepthValues === true ) {\n\n\t\t\t\t\t_gl.invalidateFramebuffer( 36008, [ depthStyle ] );\n\t\t\t\t\t_gl.invalidateFramebuffer( 36009, [ depthStyle ] );\n\n\t\t\t\t}\n\n\t\t\t\tif ( isMultipleRenderTargets ) {\n\n\t\t\t\t\tconst webglTexture = properties.get( textures[ i ] ).__webglTexture;\n\t\t\t\t\t_gl.framebufferTexture2D( 36009, 36064, 3553, webglTexture, 0 );\n\n\t\t\t\t}\n\n\t\t\t\t_gl.blitFramebuffer( 0, 0, width, height, 0, 0, width, height, mask, 9728 );\n\n\t\t\t\tif ( supportsInvalidateFramebuffer ) {\n\n\t\t\t\t\t_gl.invalidateFramebuffer( 36008, invalidationArray );\n\n\t\t\t\t}\n\n\n\t\t\t}\n\n\t\t\tstate.bindFramebuffer( 36008, null );\n\t\t\tstate.bindFramebuffer( 36009, null );\n\n\t\t\t// If MRT since pre-blit we removed the FBO we need to reconstruct the attachments\n\t\t\tif ( isMultipleRenderTargets ) {\n\n\t\t\t\tfor ( let i = 0; i < textures.length; i ++ ) {\n\n\t\t\t\t\tstate.bindFramebuffer( 36160, renderTargetProperties.__webglMultisampledFramebuffer );\n\t\t\t\t\t_gl.framebufferRenderbuffer( 36160, 36064 + i, 36161, renderTargetProperties.__webglColorRenderbuffer[ i ] );\n\n\t\t\t\t\tconst webglTexture = properties.get( textures[ i ] ).__webglTexture;\n\n\t\t\t\t\tstate.bindFramebuffer( 36160, renderTargetProperties.__webglFramebuffer );\n\t\t\t\t\t_gl.framebufferTexture2D( 36009, 36064 + i, 3553, webglTexture, 0 );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tstate.bindFramebuffer( 36009, renderTargetProperties.__webglMultisampledFramebuffer );\n\n\t\t}\n\n\t}\n\n\tfunction getRenderTargetSamples( renderTarget ) {\n\n\t\treturn Math.min( maxSamples, renderTarget.samples );\n\n\t}\n\n\tfunction useMultisampledRTT( renderTarget ) {\n\n\t\tconst renderTargetProperties = properties.get( renderTarget );\n\n\t\treturn isWebGL2 && renderTarget.samples > 0 && extensions.has( 'WEBGL_multisampled_render_to_texture' ) === true && renderTargetProperties.__useRenderToTexture !== false;\n\n\t}\n\n\tfunction updateVideoTexture( texture ) {\n\n\t\tconst frame = info.render.frame;\n\n\t\t// Check the last frame we updated the VideoTexture\n\n\t\tif ( _videoTextures.get( texture ) !== frame ) {\n\n\t\t\t_videoTextures.set( texture, frame );\n\t\t\ttexture.update();\n\n\t\t}\n\n\t}\n\n\tfunction verifyColorSpace( texture, image ) {\n\n\t\tconst encoding = texture.encoding;\n\t\tconst format = texture.format;\n\t\tconst type = texture.type;\n\n\t\tif ( texture.isCompressedTexture === true || texture.isVideoTexture === true || texture.format === _SRGBAFormat ) return image;\n\n\t\tif ( encoding !== LinearEncoding ) {\n\n\t\t\t// sRGB\n\n\t\t\tif ( encoding === sRGBEncoding ) {\n\n\t\t\t\tif ( isWebGL2 === false ) {\n\n\t\t\t\t\t// in WebGL 1, try to use EXT_sRGB extension and unsized formats\n\n\t\t\t\t\tif ( extensions.has( 'EXT_sRGB' ) === true && format === RGBAFormat ) {\n\n\t\t\t\t\t\ttexture.format = _SRGBAFormat;\n\n\t\t\t\t\t\t// it's not possible to generate mips in WebGL 1 with this extension\n\n\t\t\t\t\t\ttexture.minFilter = LinearFilter;\n\t\t\t\t\t\ttexture.generateMipmaps = false;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// slow fallback (CPU decode)\n\n\t\t\t\t\t\timage = ImageUtils.sRGBToLinear( image );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// in WebGL 2 uncompressed textures can only be sRGB encoded if they have the RGBA8 format\n\n\t\t\t\t\tif ( format !== RGBAFormat || type !== UnsignedByteType ) {\n\n\t\t\t\t\t\tconsole.warn( 'THREE.WebGLTextures: sRGB encoded textures have to use RGBAFormat and UnsignedByteType.' );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tconsole.error( 'THREE.WebGLTextures: Unsupported texture encoding:', encoding );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn image;\n\n\t}\n\n\t//\n\n\tthis.allocateTextureUnit = allocateTextureUnit;\n\tthis.resetTextureUnits = resetTextureUnits;\n\n\tthis.setTexture2D = setTexture2D;\n\tthis.setTexture2DArray = setTexture2DArray;\n\tthis.setTexture3D = setTexture3D;\n\tthis.setTextureCube = setTextureCube;\n\tthis.rebindTextures = rebindTextures;\n\tthis.setupRenderTarget = setupRenderTarget;\n\tthis.updateRenderTargetMipmap = updateRenderTargetMipmap;\n\tthis.updateMultisampleRenderTarget = updateMultisampleRenderTarget;\n\tthis.setupDepthRenderbuffer = setupDepthRenderbuffer;\n\tthis.setupFrameBufferTexture = setupFrameBufferTexture;\n\tthis.useMultisampledRTT = useMultisampledRTT;\n\n}\n\nfunction WebGLUtils( gl, extensions, capabilities ) {\n\n\tconst isWebGL2 = capabilities.isWebGL2;\n\n\tfunction convert( p, encoding = null ) {\n\n\t\tlet extension;\n\n\t\tif ( p === UnsignedByteType ) return 5121;\n\t\tif ( p === UnsignedShort4444Type ) return 32819;\n\t\tif ( p === UnsignedShort5551Type ) return 32820;\n\n\t\tif ( p === ByteType ) return 5120;\n\t\tif ( p === ShortType ) return 5122;\n\t\tif ( p === UnsignedShortType ) return 5123;\n\t\tif ( p === IntType ) return 5124;\n\t\tif ( p === UnsignedIntType ) return 5125;\n\t\tif ( p === FloatType ) return 5126;\n\n\t\tif ( p === HalfFloatType ) {\n\n\t\t\tif ( isWebGL2 ) return 5131;\n\n\t\t\textension = extensions.get( 'OES_texture_half_float' );\n\n\t\t\tif ( extension !== null ) {\n\n\t\t\t\treturn extension.HALF_FLOAT_OES;\n\n\t\t\t} else {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( p === AlphaFormat ) return 6406;\n\t\tif ( p === RGBAFormat ) return 6408;\n\t\tif ( p === LuminanceFormat ) return 6409;\n\t\tif ( p === LuminanceAlphaFormat ) return 6410;\n\t\tif ( p === DepthFormat ) return 6402;\n\t\tif ( p === DepthStencilFormat ) return 34041;\n\t\tif ( p === RedFormat ) return 6403;\n\n\t\tif ( p === RGBFormat ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: THREE.RGBFormat has been removed. Use THREE.RGBAFormat instead. https://github.com/mrdoob/three.js/pull/23228' );\n\t\t\treturn 6408;\n\n\t\t}\n\n\t\t// WebGL 1 sRGB fallback\n\n\t\tif ( p === _SRGBAFormat ) {\n\n\t\t\textension = extensions.get( 'EXT_sRGB' );\n\n\t\t\tif ( extension !== null ) {\n\n\t\t\t\treturn extension.SRGB_ALPHA_EXT;\n\n\t\t\t} else {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// WebGL2 formats.\n\n\t\tif ( p === RedIntegerFormat ) return 36244;\n\t\tif ( p === RGFormat ) return 33319;\n\t\tif ( p === RGIntegerFormat ) return 33320;\n\t\tif ( p === RGBAIntegerFormat ) return 36249;\n\n\t\t// S3TC\n\n\t\tif ( p === RGB_S3TC_DXT1_Format || p === RGBA_S3TC_DXT1_Format || p === RGBA_S3TC_DXT3_Format || p === RGBA_S3TC_DXT5_Format ) {\n\n\t\t\tif ( encoding === sRGBEncoding ) {\n\n\t\t\t\textension = extensions.get( 'WEBGL_compressed_texture_s3tc_srgb' );\n\n\t\t\t\tif ( extension !== null ) {\n\n\t\t\t\t\tif ( p === RGB_S3TC_DXT1_Format ) return extension.COMPRESSED_SRGB_S3TC_DXT1_EXT;\n\t\t\t\t\tif ( p === RGBA_S3TC_DXT1_Format ) return extension.COMPRESSED_SRGB_ALPHA_S3TC_DXT1_EXT;\n\t\t\t\t\tif ( p === RGBA_S3TC_DXT3_Format ) return extension.COMPRESSED_SRGB_ALPHA_S3TC_DXT3_EXT;\n\t\t\t\t\tif ( p === RGBA_S3TC_DXT5_Format ) return extension.COMPRESSED_SRGB_ALPHA_S3TC_DXT5_EXT;\n\n\t\t\t\t} else {\n\n\t\t\t\t\treturn null;\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\textension = extensions.get( 'WEBGL_compressed_texture_s3tc' );\n\n\t\t\t\tif ( extension !== null ) {\n\n\t\t\t\t\tif ( p === RGB_S3TC_DXT1_Format ) return extension.COMPRESSED_RGB_S3TC_DXT1_EXT;\n\t\t\t\t\tif ( p === RGBA_S3TC_DXT1_Format ) return extension.COMPRESSED_RGBA_S3TC_DXT1_EXT;\n\t\t\t\t\tif ( p === RGBA_S3TC_DXT3_Format ) return extension.COMPRESSED_RGBA_S3TC_DXT3_EXT;\n\t\t\t\t\tif ( p === RGBA_S3TC_DXT5_Format ) return extension.COMPRESSED_RGBA_S3TC_DXT5_EXT;\n\n\t\t\t\t} else {\n\n\t\t\t\t\treturn null;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\t// PVRTC\n\n\t\tif ( p === RGB_PVRTC_4BPPV1_Format || p === RGB_PVRTC_2BPPV1_Format || p === RGBA_PVRTC_4BPPV1_Format || p === RGBA_PVRTC_2BPPV1_Format ) {\n\n\t\t\textension = extensions.get( 'WEBGL_compressed_texture_pvrtc' );\n\n\t\t\tif ( extension !== null ) {\n\n\t\t\t\tif ( p === RGB_PVRTC_4BPPV1_Format ) return extension.COMPRESSED_RGB_PVRTC_4BPPV1_IMG;\n\t\t\t\tif ( p === RGB_PVRTC_2BPPV1_Format ) return extension.COMPRESSED_RGB_PVRTC_2BPPV1_IMG;\n\t\t\t\tif ( p === RGBA_PVRTC_4BPPV1_Format ) return extension.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG;\n\t\t\t\tif ( p === RGBA_PVRTC_2BPPV1_Format ) return extension.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG;\n\n\t\t\t} else {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// ETC1\n\n\t\tif ( p === RGB_ETC1_Format ) {\n\n\t\t\textension = extensions.get( 'WEBGL_compressed_texture_etc1' );\n\n\t\t\tif ( extension !== null ) {\n\n\t\t\t\treturn extension.COMPRESSED_RGB_ETC1_WEBGL;\n\n\t\t\t} else {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// ETC2\n\n\t\tif ( p === RGB_ETC2_Format || p === RGBA_ETC2_EAC_Format ) {\n\n\t\t\textension = extensions.get( 'WEBGL_compressed_texture_etc' );\n\n\t\t\tif ( extension !== null ) {\n\n\t\t\t\tif ( p === RGB_ETC2_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ETC2 : extension.COMPRESSED_RGB8_ETC2;\n\t\t\t\tif ( p === RGBA_ETC2_EAC_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ETC2_EAC : extension.COMPRESSED_RGBA8_ETC2_EAC;\n\n\t\t\t} else {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// ASTC\n\n\t\tif ( p === RGBA_ASTC_4x4_Format || p === RGBA_ASTC_5x4_Format || p === RGBA_ASTC_5x5_Format ||\n\t\t\tp === RGBA_ASTC_6x5_Format || p === RGBA_ASTC_6x6_Format || p === RGBA_ASTC_8x5_Format ||\n\t\t\tp === RGBA_ASTC_8x6_Format || p === RGBA_ASTC_8x8_Format || p === RGBA_ASTC_10x5_Format ||\n\t\t\tp === RGBA_ASTC_10x6_Format || p === RGBA_ASTC_10x8_Format || p === RGBA_ASTC_10x10_Format ||\n\t\t\tp === RGBA_ASTC_12x10_Format || p === RGBA_ASTC_12x12_Format ) {\n\n\t\t\textension = extensions.get( 'WEBGL_compressed_texture_astc' );\n\n\t\t\tif ( extension !== null ) {\n\n\t\t\t\tif ( p === RGBA_ASTC_4x4_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_4x4_KHR : extension.COMPRESSED_RGBA_ASTC_4x4_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_5x4_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_5x4_KHR : extension.COMPRESSED_RGBA_ASTC_5x4_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_5x5_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_5x5_KHR : extension.COMPRESSED_RGBA_ASTC_5x5_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_6x5_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_6x5_KHR : extension.COMPRESSED_RGBA_ASTC_6x5_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_6x6_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_6x6_KHR : extension.COMPRESSED_RGBA_ASTC_6x6_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_8x5_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_8x5_KHR : extension.COMPRESSED_RGBA_ASTC_8x5_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_8x6_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_8x6_KHR : extension.COMPRESSED_RGBA_ASTC_8x6_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_8x8_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_8x8_KHR : extension.COMPRESSED_RGBA_ASTC_8x8_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_10x5_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_10x5_KHR : extension.COMPRESSED_RGBA_ASTC_10x5_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_10x6_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_10x6_KHR : extension.COMPRESSED_RGBA_ASTC_10x6_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_10x8_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_10x8_KHR : extension.COMPRESSED_RGBA_ASTC_10x8_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_10x10_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_10x10_KHR : extension.COMPRESSED_RGBA_ASTC_10x10_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_12x10_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_12x10_KHR : extension.COMPRESSED_RGBA_ASTC_12x10_KHR;\n\t\t\t\tif ( p === RGBA_ASTC_12x12_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB8_ALPHA8_ASTC_12x12_KHR : extension.COMPRESSED_RGBA_ASTC_12x12_KHR;\n\n\t\t\t} else {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// BPTC\n\n\t\tif ( p === RGBA_BPTC_Format ) {\n\n\t\t\textension = extensions.get( 'EXT_texture_compression_bptc' );\n\n\t\t\tif ( extension !== null ) {\n\n\t\t\t\tif ( p === RGBA_BPTC_Format ) return ( encoding === sRGBEncoding ) ? extension.COMPRESSED_SRGB_ALPHA_BPTC_UNORM_EXT : extension.COMPRESSED_RGBA_BPTC_UNORM_EXT;\n\n\t\t\t} else {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t}\n\n\t\t//\n\n\t\tif ( p === UnsignedInt248Type ) {\n\n\t\t\tif ( isWebGL2 ) return 34042;\n\n\t\t\textension = extensions.get( 'WEBGL_depth_texture' );\n\n\t\t\tif ( extension !== null ) {\n\n\t\t\t\treturn extension.UNSIGNED_INT_24_8_WEBGL;\n\n\t\t\t} else {\n\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// if \"p\" can't be resolved, assume the user defines a WebGL constant as a string (fallback/workaround for packed RGB formats)\n\n\t\treturn ( gl[ p ] !== undefined ) ? gl[ p ] : null;\n\n\t}\n\n\treturn { convert: convert };\n\n}\n\nclass ArrayCamera extends PerspectiveCamera {\n\n\tconstructor( array = [] ) {\n\n\t\tsuper();\n\n\t\tthis.isArrayCamera = true;\n\n\t\tthis.cameras = array;\n\n\t}\n\n}\n\nclass Group extends Object3D {\n\n\tconstructor() {\n\n\t\tsuper();\n\n\t\tthis.isGroup = true;\n\n\t\tthis.type = 'Group';\n\n\t}\n\n}\n\nconst _moveEvent = { type: 'move' };\n\nclass WebXRController {\n\n\tconstructor() {\n\n\t\tthis._targetRay = null;\n\t\tthis._grip = null;\n\t\tthis._hand = null;\n\n\t}\n\n\tgetHandSpace() {\n\n\t\tif ( this._hand === null ) {\n\n\t\t\tthis._hand = new Group();\n\t\t\tthis._hand.matrixAutoUpdate = false;\n\t\t\tthis._hand.visible = false;\n\n\t\t\tthis._hand.joints = {};\n\t\t\tthis._hand.inputState = { pinching: false };\n\n\t\t}\n\n\t\treturn this._hand;\n\n\t}\n\n\tgetTargetRaySpace() {\n\n\t\tif ( this._targetRay === null ) {\n\n\t\t\tthis._targetRay = new Group();\n\t\t\tthis._targetRay.matrixAutoUpdate = false;\n\t\t\tthis._targetRay.visible = false;\n\t\t\tthis._targetRay.hasLinearVelocity = false;\n\t\t\tthis._targetRay.linearVelocity = new Vector3();\n\t\t\tthis._targetRay.hasAngularVelocity = false;\n\t\t\tthis._targetRay.angularVelocity = new Vector3();\n\n\t\t}\n\n\t\treturn this._targetRay;\n\n\t}\n\n\tgetGripSpace() {\n\n\t\tif ( this._grip === null ) {\n\n\t\t\tthis._grip = new Group();\n\t\t\tthis._grip.matrixAutoUpdate = false;\n\t\t\tthis._grip.visible = false;\n\t\t\tthis._grip.hasLinearVelocity = false;\n\t\t\tthis._grip.linearVelocity = new Vector3();\n\t\t\tthis._grip.hasAngularVelocity = false;\n\t\t\tthis._grip.angularVelocity = new Vector3();\n\n\t\t}\n\n\t\treturn this._grip;\n\n\t}\n\n\tdispatchEvent( event ) {\n\n\t\tif ( this._targetRay !== null ) {\n\n\t\t\tthis._targetRay.dispatchEvent( event );\n\n\t\t}\n\n\t\tif ( this._grip !== null ) {\n\n\t\t\tthis._grip.dispatchEvent( event );\n\n\t\t}\n\n\t\tif ( this._hand !== null ) {\n\n\t\t\tthis._hand.dispatchEvent( event );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tdisconnect( inputSource ) {\n\n\t\tthis.dispatchEvent( { type: 'disconnected', data: inputSource } );\n\n\t\tif ( this._targetRay !== null ) {\n\n\t\t\tthis._targetRay.visible = false;\n\n\t\t}\n\n\t\tif ( this._grip !== null ) {\n\n\t\t\tthis._grip.visible = false;\n\n\t\t}\n\n\t\tif ( this._hand !== null ) {\n\n\t\t\tthis._hand.visible = false;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tupdate( inputSource, frame, referenceSpace ) {\n\n\t\tlet inputPose = null;\n\t\tlet gripPose = null;\n\t\tlet handPose = null;\n\n\t\tconst targetRay = this._targetRay;\n\t\tconst grip = this._grip;\n\t\tconst hand = this._hand;\n\n\t\tif ( inputSource && frame.session.visibilityState !== 'visible-blurred' ) {\n\n\t\t\tif ( targetRay !== null ) {\n\n\t\t\t\tinputPose = frame.getPose( inputSource.targetRaySpace, referenceSpace );\n\n\t\t\t\tif ( inputPose !== null ) {\n\n\t\t\t\t\ttargetRay.matrix.fromArray( inputPose.transform.matrix );\n\t\t\t\t\ttargetRay.matrix.decompose( targetRay.position, targetRay.rotation, targetRay.scale );\n\n\t\t\t\t\tif ( inputPose.linearVelocity ) {\n\n\t\t\t\t\t\ttargetRay.hasLinearVelocity = true;\n\t\t\t\t\t\ttargetRay.linearVelocity.copy( inputPose.linearVelocity );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\ttargetRay.hasLinearVelocity = false;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( inputPose.angularVelocity ) {\n\n\t\t\t\t\t\ttargetRay.hasAngularVelocity = true;\n\t\t\t\t\t\ttargetRay.angularVelocity.copy( inputPose.angularVelocity );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\ttargetRay.hasAngularVelocity = false;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.dispatchEvent( _moveEvent );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( hand && inputSource.hand ) {\n\n\t\t\t\thandPose = true;\n\n\t\t\t\tfor ( const inputjoint of inputSource.hand.values() ) {\n\n\t\t\t\t\t// Update the joints groups with the XRJoint poses\n\t\t\t\t\tconst jointPose = frame.getJointPose( inputjoint, referenceSpace );\n\n\t\t\t\t\tif ( hand.joints[ inputjoint.jointName ] === undefined ) {\n\n\t\t\t\t\t\t// The transform of this joint will be updated with the joint pose on each frame\n\t\t\t\t\t\tconst joint = new Group();\n\t\t\t\t\t\tjoint.matrixAutoUpdate = false;\n\t\t\t\t\t\tjoint.visible = false;\n\t\t\t\t\t\thand.joints[ inputjoint.jointName ] = joint;\n\t\t\t\t\t\t// ??\n\t\t\t\t\t\thand.add( joint );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tconst joint = hand.joints[ inputjoint.jointName ];\n\n\t\t\t\t\tif ( jointPose !== null ) {\n\n\t\t\t\t\t\tjoint.matrix.fromArray( jointPose.transform.matrix );\n\t\t\t\t\t\tjoint.matrix.decompose( joint.position, joint.rotation, joint.scale );\n\t\t\t\t\t\tjoint.jointRadius = jointPose.radius;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tjoint.visible = jointPose !== null;\n\n\t\t\t\t}\n\n\t\t\t\t// Custom events\n\n\t\t\t\t// Check pinchz\n\t\t\t\tconst indexTip = hand.joints[ 'index-finger-tip' ];\n\t\t\t\tconst thumbTip = hand.joints[ 'thumb-tip' ];\n\t\t\t\tconst distance = indexTip.position.distanceTo( thumbTip.position );\n\n\t\t\t\tconst distanceToPinch = 0.02;\n\t\t\t\tconst threshold = 0.005;\n\n\t\t\t\tif ( hand.inputState.pinching && distance > distanceToPinch + threshold ) {\n\n\t\t\t\t\thand.inputState.pinching = false;\n\t\t\t\t\tthis.dispatchEvent( {\n\t\t\t\t\t\ttype: 'pinchend',\n\t\t\t\t\t\thandedness: inputSource.handedness,\n\t\t\t\t\t\ttarget: this\n\t\t\t\t\t} );\n\n\t\t\t\t} else if ( ! hand.inputState.pinching && distance <= distanceToPinch - threshold ) {\n\n\t\t\t\t\thand.inputState.pinching = true;\n\t\t\t\t\tthis.dispatchEvent( {\n\t\t\t\t\t\ttype: 'pinchstart',\n\t\t\t\t\t\thandedness: inputSource.handedness,\n\t\t\t\t\t\ttarget: this\n\t\t\t\t\t} );\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tif ( grip !== null && inputSource.gripSpace ) {\n\n\t\t\t\t\tgripPose = frame.getPose( inputSource.gripSpace, referenceSpace );\n\n\t\t\t\t\tif ( gripPose !== null ) {\n\n\t\t\t\t\t\tgrip.matrix.fromArray( gripPose.transform.matrix );\n\t\t\t\t\t\tgrip.matrix.decompose( grip.position, grip.rotation, grip.scale );\n\n\t\t\t\t\t\tif ( gripPose.linearVelocity ) {\n\n\t\t\t\t\t\t\tgrip.hasLinearVelocity = true;\n\t\t\t\t\t\t\tgrip.linearVelocity.copy( gripPose.linearVelocity );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tgrip.hasLinearVelocity = false;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif ( gripPose.angularVelocity ) {\n\n\t\t\t\t\t\t\tgrip.hasAngularVelocity = true;\n\t\t\t\t\t\t\tgrip.angularVelocity.copy( gripPose.angularVelocity );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tgrip.hasAngularVelocity = false;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( targetRay !== null ) {\n\n\t\t\ttargetRay.visible = ( inputPose !== null );\n\n\t\t}\n\n\t\tif ( grip !== null ) {\n\n\t\t\tgrip.visible = ( gripPose !== null );\n\n\t\t}\n\n\t\tif ( hand !== null ) {\n\n\t\t\thand.visible = ( handPose !== null );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass DepthTexture extends Texture {\n\n\tconstructor( width, height, type, mapping, wrapS, wrapT, magFilter, minFilter, anisotropy, format ) {\n\n\t\tformat = format !== undefined ? format : DepthFormat;\n\n\t\tif ( format !== DepthFormat && format !== DepthStencilFormat ) {\n\n\t\t\tthrow new Error( 'DepthTexture format must be either THREE.DepthFormat or THREE.DepthStencilFormat' );\n\n\t\t}\n\n\t\tif ( type === undefined && format === DepthFormat ) type = UnsignedIntType;\n\t\tif ( type === undefined && format === DepthStencilFormat ) type = UnsignedInt248Type;\n\n\t\tsuper( null, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy );\n\n\t\tthis.isDepthTexture = true;\n\n\t\tthis.image = { width: width, height: height };\n\n\t\tthis.magFilter = magFilter !== undefined ? magFilter : NearestFilter;\n\t\tthis.minFilter = minFilter !== undefined ? minFilter : NearestFilter;\n\n\t\tthis.flipY = false;\n\t\tthis.generateMipmaps = false;\n\n\t}\n\n\n}\n\nclass WebXRManager extends EventDispatcher {\n\n\tconstructor( renderer, gl ) {\n\n\t\tsuper();\n\n\t\tconst scope = this;\n\n\t\tlet session = null;\n\t\tlet framebufferScaleFactor = 1.0;\n\n\t\tlet referenceSpace = null;\n\t\tlet referenceSpaceType = 'local-floor';\n\t\tlet customReferenceSpace = null;\n\n\t\tlet pose = null;\n\t\tlet glBinding = null;\n\t\tlet glProjLayer = null;\n\t\tlet glBaseLayer = null;\n\t\tlet xrFrame = null;\n\t\tconst attributes = gl.getContextAttributes();\n\t\tlet initialRenderTarget = null;\n\t\tlet newRenderTarget = null;\n\n\t\tconst controllers = [];\n\t\tconst inputSourcesMap = new Map();\n\n\t\t//\n\n\t\tconst cameraL = new PerspectiveCamera();\n\t\tcameraL.layers.enable( 1 );\n\t\tcameraL.viewport = new Vector4();\n\n\t\tconst cameraR = new PerspectiveCamera();\n\t\tcameraR.layers.enable( 2 );\n\t\tcameraR.viewport = new Vector4();\n\n\t\tconst cameras = [ cameraL, cameraR ];\n\n\t\tconst cameraVR = new ArrayCamera();\n\t\tcameraVR.layers.enable( 1 );\n\t\tcameraVR.layers.enable( 2 );\n\n\t\tlet _currentDepthNear = null;\n\t\tlet _currentDepthFar = null;\n\n\t\t//\n\n\t\tthis.cameraAutoUpdate = true;\n\t\tthis.enabled = false;\n\n\t\tthis.isPresenting = false;\n\n\t\tthis.getController = function ( index ) {\n\n\t\t\tlet controller = controllers[ index ];\n\n\t\t\tif ( controller === undefined ) {\n\n\t\t\t\tcontroller = new WebXRController();\n\t\t\t\tcontrollers[ index ] = controller;\n\n\t\t\t}\n\n\t\t\treturn controller.getTargetRaySpace();\n\n\t\t};\n\n\t\tthis.getControllerGrip = function ( index ) {\n\n\t\t\tlet controller = controllers[ index ];\n\n\t\t\tif ( controller === undefined ) {\n\n\t\t\t\tcontroller = new WebXRController();\n\t\t\t\tcontrollers[ index ] = controller;\n\n\t\t\t}\n\n\t\t\treturn controller.getGripSpace();\n\n\t\t};\n\n\t\tthis.getHand = function ( index ) {\n\n\t\t\tlet controller = controllers[ index ];\n\n\t\t\tif ( controller === undefined ) {\n\n\t\t\t\tcontroller = new WebXRController();\n\t\t\t\tcontrollers[ index ] = controller;\n\n\t\t\t}\n\n\t\t\treturn controller.getHandSpace();\n\n\t\t};\n\n\t\t//\n\n\t\tfunction onSessionEvent( event ) {\n\n\t\t\tconst controller = inputSourcesMap.get( event.inputSource );\n\n\t\t\tif ( controller !== undefined ) {\n\n\t\t\t\tcontroller.dispatchEvent( { type: event.type, data: event.inputSource } );\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction onSessionEnd() {\n\n\t\t\tsession.removeEventListener( 'select', onSessionEvent );\n\t\t\tsession.removeEventListener( 'selectstart', onSessionEvent );\n\t\t\tsession.removeEventListener( 'selectend', onSessionEvent );\n\t\t\tsession.removeEventListener( 'squeeze', onSessionEvent );\n\t\t\tsession.removeEventListener( 'squeezestart', onSessionEvent );\n\t\t\tsession.removeEventListener( 'squeezeend', onSessionEvent );\n\t\t\tsession.removeEventListener( 'end', onSessionEnd );\n\t\t\tsession.removeEventListener( 'inputsourceschange', onInputSourcesChange );\n\n\t\t\tinputSourcesMap.forEach( function ( controller, inputSource ) {\n\n\t\t\t\tif ( controller !== undefined ) {\n\n\t\t\t\t\tcontroller.disconnect( inputSource );\n\n\t\t\t\t}\n\n\t\t\t} );\n\n\t\t\tinputSourcesMap.clear();\n\n\t\t\t_currentDepthNear = null;\n\t\t\t_currentDepthFar = null;\n\n\t\t\t// restore framebuffer/rendering state\n\n\t\t\trenderer.setRenderTarget( initialRenderTarget );\n\n\t\t\tglBaseLayer = null;\n\t\t\tglProjLayer = null;\n\t\t\tglBinding = null;\n\t\t\tsession = null;\n\t\t\tnewRenderTarget = null;\n\n\t\t\t//\n\n\t\t\tanimation.stop();\n\n\t\t\tscope.isPresenting = false;\n\n\t\t\tscope.dispatchEvent( { type: 'sessionend' } );\n\n\t\t}\n\n\t\tthis.setFramebufferScaleFactor = function ( value ) {\n\n\t\t\tframebufferScaleFactor = value;\n\n\t\t\tif ( scope.isPresenting === true ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebXRManager: Cannot change framebuffer scale while presenting.' );\n\n\t\t\t}\n\n\t\t};\n\n\t\tthis.setReferenceSpaceType = function ( value ) {\n\n\t\t\treferenceSpaceType = value;\n\n\t\t\tif ( scope.isPresenting === true ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebXRManager: Cannot change reference space type while presenting.' );\n\n\t\t\t}\n\n\t\t};\n\n\t\tthis.getReferenceSpace = function () {\n\n\t\t\treturn customReferenceSpace || referenceSpace;\n\n\t\t};\n\n\t\tthis.setReferenceSpace = function ( space ) {\n\n\t\t\tcustomReferenceSpace = space;\n\n\t\t};\n\n\t\tthis.getBaseLayer = function () {\n\n\t\t\treturn glProjLayer !== null ? glProjLayer : glBaseLayer;\n\n\t\t};\n\n\t\tthis.getBinding = function () {\n\n\t\t\treturn glBinding;\n\n\t\t};\n\n\t\tthis.getFrame = function () {\n\n\t\t\treturn xrFrame;\n\n\t\t};\n\n\t\tthis.getSession = function () {\n\n\t\t\treturn session;\n\n\t\t};\n\n\t\tthis.setSession = async function ( value ) {\n\n\t\t\tsession = value;\n\n\t\t\tif ( session !== null ) {\n\n\t\t\t\tinitialRenderTarget = renderer.getRenderTarget();\n\n\t\t\t\tsession.addEventListener( 'select', onSessionEvent );\n\t\t\t\tsession.addEventListener( 'selectstart', onSessionEvent );\n\t\t\t\tsession.addEventListener( 'selectend', onSessionEvent );\n\t\t\t\tsession.addEventListener( 'squeeze', onSessionEvent );\n\t\t\t\tsession.addEventListener( 'squeezestart', onSessionEvent );\n\t\t\t\tsession.addEventListener( 'squeezeend', onSessionEvent );\n\t\t\t\tsession.addEventListener( 'end', onSessionEnd );\n\t\t\t\tsession.addEventListener( 'inputsourceschange', onInputSourcesChange );\n\n\t\t\t\tif ( attributes.xrCompatible !== true ) {\n\n\t\t\t\t\tawait gl.makeXRCompatible();\n\n\t\t\t\t}\n\n\t\t\t\tif ( ( session.renderState.layers === undefined ) || ( renderer.capabilities.isWebGL2 === false ) ) {\n\n\t\t\t\t\tconst layerInit = {\n\t\t\t\t\t\tantialias: ( session.renderState.layers === undefined ) ? attributes.antialias : true,\n\t\t\t\t\t\talpha: attributes.alpha,\n\t\t\t\t\t\tdepth: attributes.depth,\n\t\t\t\t\t\tstencil: attributes.stencil,\n\t\t\t\t\t\tframebufferScaleFactor: framebufferScaleFactor\n\t\t\t\t\t};\n\n\t\t\t\t\tglBaseLayer = new XRWebGLLayer( session, gl, layerInit );\n\n\t\t\t\t\tsession.updateRenderState( { baseLayer: glBaseLayer } );\n\n\t\t\t\t\tnewRenderTarget = new WebGLRenderTarget(\n\t\t\t\t\t\tglBaseLayer.framebufferWidth,\n\t\t\t\t\t\tglBaseLayer.framebufferHeight,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tformat: RGBAFormat,\n\t\t\t\t\t\t\ttype: UnsignedByteType,\n\t\t\t\t\t\t\tencoding: renderer.outputEncoding\n\t\t\t\t\t\t}\n\t\t\t\t\t);\n\n\t\t\t\t} else {\n\n\t\t\t\t\tlet depthFormat = null;\n\t\t\t\t\tlet depthType = null;\n\t\t\t\t\tlet glDepthFormat = null;\n\n\t\t\t\t\tif ( attributes.depth ) {\n\n\t\t\t\t\t\tglDepthFormat = attributes.stencil ? 35056 : 33190;\n\t\t\t\t\t\tdepthFormat = attributes.stencil ? DepthStencilFormat : DepthFormat;\n\t\t\t\t\t\tdepthType = attributes.stencil ? UnsignedInt248Type : UnsignedIntType;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tconst projectionlayerInit = {\n\t\t\t\t\t\tcolorFormat: ( renderer.outputEncoding === sRGBEncoding ) ? 35907 : 32856,\n\t\t\t\t\t\tdepthFormat: glDepthFormat,\n\t\t\t\t\t\tscaleFactor: framebufferScaleFactor\n\t\t\t\t\t};\n\n\t\t\t\t\tglBinding = new XRWebGLBinding( session, gl );\n\n\t\t\t\t\tglProjLayer = glBinding.createProjectionLayer( projectionlayerInit );\n\n\t\t\t\t\tsession.updateRenderState( { layers: [ glProjLayer ] } );\n\n\t\t\t\t\tnewRenderTarget = new WebGLRenderTarget(\n\t\t\t\t\t\tglProjLayer.textureWidth,\n\t\t\t\t\t\tglProjLayer.textureHeight,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tformat: RGBAFormat,\n\t\t\t\t\t\t\ttype: UnsignedByteType,\n\t\t\t\t\t\t\tdepthTexture: new DepthTexture( glProjLayer.textureWidth, glProjLayer.textureHeight, depthType, undefined, undefined, undefined, undefined, undefined, undefined, depthFormat ),\n\t\t\t\t\t\t\tstencilBuffer: attributes.stencil,\n\t\t\t\t\t\t\tencoding: renderer.outputEncoding,\n\t\t\t\t\t\t\tsamples: attributes.antialias ? 4 : 0\n\t\t\t\t\t\t} );\n\n\t\t\t\t\tconst renderTargetProperties = renderer.properties.get( newRenderTarget );\n\t\t\t\t\trenderTargetProperties.__ignoreDepthValues = glProjLayer.ignoreDepthValues;\n\n\t\t\t\t}\n\n\t\t\t\tnewRenderTarget.isXRRenderTarget = true; // TODO Remove this when possible, see #23278\n\n\t\t\t\t// Set foveation to maximum.\n\t\t\t\tthis.setFoveation( 1.0 );\n\n\t\t\t\tcustomReferenceSpace = null;\n\t\t\t\treferenceSpace = await session.requestReferenceSpace( referenceSpaceType );\n\n\t\t\t\tanimation.setContext( session );\n\t\t\t\tanimation.start();\n\n\t\t\t\tscope.isPresenting = true;\n\n\t\t\t\tscope.dispatchEvent( { type: 'sessionstart' } );\n\n\t\t\t}\n\n\t\t};\n\n\t\tfunction onInputSourcesChange( event ) {\n\n\t\t\tconst inputSources = session.inputSources;\n\n\t\t\t// Assign controllers to available inputSources\n\n\t\t\tfor ( let i = 0; i < inputSources.length; i ++ ) {\n\n\t\t\t\tconst index = inputSources[ i ].handedness === 'right' ? 1 : 0;\n\t\t\t\tinputSourcesMap.set( inputSources[ i ], controllers[ index ] );\n\n\t\t\t}\n\n\t\t\t// Notify disconnected\n\n\t\t\tfor ( let i = 0; i < event.removed.length; i ++ ) {\n\n\t\t\t\tconst inputSource = event.removed[ i ];\n\t\t\t\tconst controller = inputSourcesMap.get( inputSource );\n\n\t\t\t\tif ( controller ) {\n\n\t\t\t\t\tcontroller.dispatchEvent( { type: 'disconnected', data: inputSource } );\n\t\t\t\t\tinputSourcesMap.delete( inputSource );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// Notify connected\n\n\t\t\tfor ( let i = 0; i < event.added.length; i ++ ) {\n\n\t\t\t\tconst inputSource = event.added[ i ];\n\t\t\t\tconst controller = inputSourcesMap.get( inputSource );\n\n\t\t\t\tif ( controller ) {\n\n\t\t\t\t\tcontroller.dispatchEvent( { type: 'connected', data: inputSource } );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\t//\n\n\t\tconst cameraLPos = new Vector3();\n\t\tconst cameraRPos = new Vector3();\n\n\t\t/**\n\t\t * Assumes 2 cameras that are parallel and share an X-axis, and that\n\t\t * the cameras' projection and world matrices have already been set.\n\t\t * And that near and far planes are identical for both cameras.\n\t\t * Visualization of this technique: https://computergraphics.stackexchange.com/a/4765\n\t\t */\n\t\tfunction setProjectionFromUnion( camera, cameraL, cameraR ) {\n\n\t\t\tcameraLPos.setFromMatrixPosition( cameraL.matrixWorld );\n\t\t\tcameraRPos.setFromMatrixPosition( cameraR.matrixWorld );\n\n\t\t\tconst ipd = cameraLPos.distanceTo( cameraRPos );\n\n\t\t\tconst projL = cameraL.projectionMatrix.elements;\n\t\t\tconst projR = cameraR.projectionMatrix.elements;\n\n\t\t\t// VR systems will have identical far and near planes, and\n\t\t\t// most likely identical top and bottom frustum extents.\n\t\t\t// Use the left camera for these values.\n\t\t\tconst near = projL[ 14 ] / ( projL[ 10 ] - 1 );\n\t\t\tconst far = projL[ 14 ] / ( projL[ 10 ] + 1 );\n\t\t\tconst topFov = ( projL[ 9 ] + 1 ) / projL[ 5 ];\n\t\t\tconst bottomFov = ( projL[ 9 ] - 1 ) / projL[ 5 ];\n\n\t\t\tconst leftFov = ( projL[ 8 ] - 1 ) / projL[ 0 ];\n\t\t\tconst rightFov = ( projR[ 8 ] + 1 ) / projR[ 0 ];\n\t\t\tconst left = near * leftFov;\n\t\t\tconst right = near * rightFov;\n\n\t\t\t// Calculate the new camera's position offset from the\n\t\t\t// left camera. xOffset should be roughly half `ipd`.\n\t\t\tconst zOffset = ipd / ( - leftFov + rightFov );\n\t\t\tconst xOffset = zOffset * - leftFov;\n\n\t\t\t// TODO: Better way to apply this offset?\n\t\t\tcameraL.matrixWorld.decompose( camera.position, camera.quaternion, camera.scale );\n\t\t\tcamera.translateX( xOffset );\n\t\t\tcamera.translateZ( zOffset );\n\t\t\tcamera.matrixWorld.compose( camera.position, camera.quaternion, camera.scale );\n\t\t\tcamera.matrixWorldInverse.copy( camera.matrixWorld ).invert();\n\n\t\t\t// Find the union of the frustum values of the cameras and scale\n\t\t\t// the values so that the near plane's position does not change in world space,\n\t\t\t// although must now be relative to the new union camera.\n\t\t\tconst near2 = near + zOffset;\n\t\t\tconst far2 = far + zOffset;\n\t\t\tconst left2 = left - xOffset;\n\t\t\tconst right2 = right + ( ipd - xOffset );\n\t\t\tconst top2 = topFov * far / far2 * near2;\n\t\t\tconst bottom2 = bottomFov * far / far2 * near2;\n\n\t\t\tcamera.projectionMatrix.makePerspective( left2, right2, top2, bottom2, near2, far2 );\n\n\t\t}\n\n\t\tfunction updateCamera( camera, parent ) {\n\n\t\t\tif ( parent === null ) {\n\n\t\t\t\tcamera.matrixWorld.copy( camera.matrix );\n\n\t\t\t} else {\n\n\t\t\t\tcamera.matrixWorld.multiplyMatrices( parent.matrixWorld, camera.matrix );\n\n\t\t\t}\n\n\t\t\tcamera.matrixWorldInverse.copy( camera.matrixWorld ).invert();\n\n\t\t}\n\n\t\tthis.updateCamera = function ( camera ) {\n\n\t\t\tif ( session === null ) return;\n\n\t\t\tcameraVR.near = cameraR.near = cameraL.near = camera.near;\n\t\t\tcameraVR.far = cameraR.far = cameraL.far = camera.far;\n\n\t\t\tif ( _currentDepthNear !== cameraVR.near || _currentDepthFar !== cameraVR.far ) {\n\n\t\t\t\t// Note that the new renderState won't apply until the next frame. See #18320\n\n\t\t\t\tsession.updateRenderState( {\n\t\t\t\t\tdepthNear: cameraVR.near,\n\t\t\t\t\tdepthFar: cameraVR.far\n\t\t\t\t} );\n\n\t\t\t\t_currentDepthNear = cameraVR.near;\n\t\t\t\t_currentDepthFar = cameraVR.far;\n\n\t\t\t}\n\n\t\t\tconst parent = camera.parent;\n\t\t\tconst cameras = cameraVR.cameras;\n\n\t\t\tupdateCamera( cameraVR, parent );\n\n\t\t\tfor ( let i = 0; i < cameras.length; i ++ ) {\n\n\t\t\t\tupdateCamera( cameras[ i ], parent );\n\n\t\t\t}\n\n\t\t\tcameraVR.matrixWorld.decompose( cameraVR.position, cameraVR.quaternion, cameraVR.scale );\n\n\t\t\t// update user camera and its children\n\n\t\t\tcamera.position.copy( cameraVR.position );\n\t\t\tcamera.quaternion.copy( cameraVR.quaternion );\n\t\t\tcamera.scale.copy( cameraVR.scale );\n\t\t\tcamera.matrix.copy( cameraVR.matrix );\n\t\t\tcamera.matrixWorld.copy( cameraVR.matrixWorld );\n\n\t\t\tconst children = camera.children;\n\n\t\t\tfor ( let i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\t\tchildren[ i ].updateMatrixWorld( true );\n\n\t\t\t}\n\n\t\t\t// update projection matrix for proper view frustum culling\n\n\t\t\tif ( cameras.length === 2 ) {\n\n\t\t\t\tsetProjectionFromUnion( cameraVR, cameraL, cameraR );\n\n\t\t\t} else {\n\n\t\t\t\t// assume single camera setup (AR)\n\n\t\t\t\tcameraVR.projectionMatrix.copy( cameraL.projectionMatrix );\n\n\t\t\t}\n\n\t\t};\n\n\t\tthis.getCamera = function () {\n\n\t\t\treturn cameraVR;\n\n\t\t};\n\n\t\tthis.getFoveation = function () {\n\n\t\t\tif ( glProjLayer !== null ) {\n\n\t\t\t\treturn glProjLayer.fixedFoveation;\n\n\t\t\t}\n\n\t\t\tif ( glBaseLayer !== null ) {\n\n\t\t\t\treturn glBaseLayer.fixedFoveation;\n\n\t\t\t}\n\n\t\t\treturn undefined;\n\n\t\t};\n\n\t\tthis.setFoveation = function ( foveation ) {\n\n\t\t\t// 0 = no foveation = full resolution\n\t\t\t// 1 = maximum foveation = the edges render at lower resolution\n\n\t\t\tif ( glProjLayer !== null ) {\n\n\t\t\t\tglProjLayer.fixedFoveation = foveation;\n\n\t\t\t}\n\n\t\t\tif ( glBaseLayer !== null && glBaseLayer.fixedFoveation !== undefined ) {\n\n\t\t\t\tglBaseLayer.fixedFoveation = foveation;\n\n\t\t\t}\n\n\t\t};\n\n\t\t// Animation Loop\n\n\t\tlet onAnimationFrameCallback = null;\n\n\t\tfunction onAnimationFrame( time, frame ) {\n\n\t\t\tpose = frame.getViewerPose( customReferenceSpace || referenceSpace );\n\t\t\txrFrame = frame;\n\n\t\t\tif ( pose !== null ) {\n\n\t\t\t\tconst views = pose.views;\n\n\t\t\t\tif ( glBaseLayer !== null ) {\n\n\t\t\t\t\trenderer.setRenderTargetFramebuffer( newRenderTarget, glBaseLayer.framebuffer );\n\t\t\t\t\trenderer.setRenderTarget( newRenderTarget );\n\n\t\t\t\t}\n\n\t\t\t\tlet cameraVRNeedsUpdate = false;\n\n\t\t\t\t// check if it's necessary to rebuild cameraVR's camera list\n\n\t\t\t\tif ( views.length !== cameraVR.cameras.length ) {\n\n\t\t\t\t\tcameraVR.cameras.length = 0;\n\t\t\t\t\tcameraVRNeedsUpdate = true;\n\n\t\t\t\t}\n\n\t\t\t\tfor ( let i = 0; i < views.length; i ++ ) {\n\n\t\t\t\t\tconst view = views[ i ];\n\n\t\t\t\t\tlet viewport = null;\n\n\t\t\t\t\tif ( glBaseLayer !== null ) {\n\n\t\t\t\t\t\tviewport = glBaseLayer.getViewport( view );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tconst glSubImage = glBinding.getViewSubImage( glProjLayer, view );\n\t\t\t\t\t\tviewport = glSubImage.viewport;\n\n\t\t\t\t\t\t// For side-by-side projection, we only produce a single texture for both eyes.\n\t\t\t\t\t\tif ( i === 0 ) {\n\n\t\t\t\t\t\t\trenderer.setRenderTargetTextures(\n\t\t\t\t\t\t\t\tnewRenderTarget,\n\t\t\t\t\t\t\t\tglSubImage.colorTexture,\n\t\t\t\t\t\t\t\tglProjLayer.ignoreDepthValues ? undefined : glSubImage.depthStencilTexture );\n\n\t\t\t\t\t\t\trenderer.setRenderTarget( newRenderTarget );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\tlet camera = cameras[ i ];\n\n\t\t\t\t\tif ( camera === undefined ) {\n\n\t\t\t\t\t\tcamera = new PerspectiveCamera();\n\t\t\t\t\t\tcamera.layers.enable( i );\n\t\t\t\t\t\tcamera.viewport = new Vector4();\n\t\t\t\t\t\tcameras[ i ] = camera;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tcamera.matrix.fromArray( view.transform.matrix );\n\t\t\t\t\tcamera.projectionMatrix.fromArray( view.projectionMatrix );\n\t\t\t\t\tcamera.viewport.set( viewport.x, viewport.y, viewport.width, viewport.height );\n\n\t\t\t\t\tif ( i === 0 ) {\n\n\t\t\t\t\t\tcameraVR.matrix.copy( camera.matrix );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( cameraVRNeedsUpdate === true ) {\n\n\t\t\t\t\t\tcameraVR.cameras.push( camera );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t//\n\n\t\t\tconst inputSources = session.inputSources;\n\n\t\t\tfor ( let i = 0; i < controllers.length; i ++ ) {\n\n\t\t\t\tconst inputSource = inputSources[ i ];\n\t\t\t\tconst controller = inputSourcesMap.get( inputSource );\n\n\t\t\t\tif ( controller !== undefined ) {\n\n\t\t\t\t\tcontroller.update( inputSource, frame, customReferenceSpace || referenceSpace );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( onAnimationFrameCallback ) onAnimationFrameCallback( time, frame );\n\n\t\t\txrFrame = null;\n\n\t\t}\n\n\t\tconst animation = new WebGLAnimation();\n\n\t\tanimation.setAnimationLoop( onAnimationFrame );\n\n\t\tthis.setAnimationLoop = function ( callback ) {\n\n\t\t\tonAnimationFrameCallback = callback;\n\n\t\t};\n\n\t\tthis.dispose = function () {};\n\n\t}\n\n}\n\nfunction WebGLMaterials( renderer, properties ) {\n\n\tfunction refreshFogUniforms( uniforms, fog ) {\n\n\t\tuniforms.fogColor.value.copy( fog.color );\n\n\t\tif ( fog.isFog ) {\n\n\t\t\tuniforms.fogNear.value = fog.near;\n\t\t\tuniforms.fogFar.value = fog.far;\n\n\t\t} else if ( fog.isFogExp2 ) {\n\n\t\t\tuniforms.fogDensity.value = fog.density;\n\n\t\t}\n\n\t}\n\n\tfunction refreshMaterialUniforms( uniforms, material, pixelRatio, height, transmissionRenderTarget ) {\n\n\t\tif ( material.isMeshBasicMaterial ) {\n\n\t\t\trefreshUniformsCommon( uniforms, material );\n\n\t\t} else if ( material.isMeshLambertMaterial ) {\n\n\t\t\trefreshUniformsCommon( uniforms, material );\n\n\t\t} else if ( material.isMeshToonMaterial ) {\n\n\t\t\trefreshUniformsCommon( uniforms, material );\n\t\t\trefreshUniformsToon( uniforms, material );\n\n\t\t} else if ( material.isMeshPhongMaterial ) {\n\n\t\t\trefreshUniformsCommon( uniforms, material );\n\t\t\trefreshUniformsPhong( uniforms, material );\n\n\t\t} else if ( material.isMeshStandardMaterial ) {\n\n\t\t\trefreshUniformsCommon( uniforms, material );\n\t\t\trefreshUniformsStandard( uniforms, material );\n\n\t\t\tif ( material.isMeshPhysicalMaterial ) {\n\n\t\t\t\trefreshUniformsPhysical( uniforms, material, transmissionRenderTarget );\n\n\t\t\t}\n\n\t\t} else if ( material.isMeshMatcapMaterial ) {\n\n\t\t\trefreshUniformsCommon( uniforms, material );\n\t\t\trefreshUniformsMatcap( uniforms, material );\n\n\t\t} else if ( material.isMeshDepthMaterial ) {\n\n\t\t\trefreshUniformsCommon( uniforms, material );\n\n\t\t} else if ( material.isMeshDistanceMaterial ) {\n\n\t\t\trefreshUniformsCommon( uniforms, material );\n\t\t\trefreshUniformsDistance( uniforms, material );\n\n\t\t} else if ( material.isMeshNormalMaterial ) {\n\n\t\t\trefreshUniformsCommon( uniforms, material );\n\n\t\t} else if ( material.isLineBasicMaterial ) {\n\n\t\t\trefreshUniformsLine( uniforms, material );\n\n\t\t\tif ( material.isLineDashedMaterial ) {\n\n\t\t\t\trefreshUniformsDash( uniforms, material );\n\n\t\t\t}\n\n\t\t} else if ( material.isPointsMaterial ) {\n\n\t\t\trefreshUniformsPoints( uniforms, material, pixelRatio, height );\n\n\t\t} else if ( material.isSpriteMaterial ) {\n\n\t\t\trefreshUniformsSprites( uniforms, material );\n\n\t\t} else if ( material.isShadowMaterial ) {\n\n\t\t\tuniforms.color.value.copy( material.color );\n\t\t\tuniforms.opacity.value = material.opacity;\n\n\t\t} else if ( material.isShaderMaterial ) {\n\n\t\t\tmaterial.uniformsNeedUpdate = false; // #15581\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsCommon( uniforms, material ) {\n\n\t\tuniforms.opacity.value = material.opacity;\n\n\t\tif ( material.color ) {\n\n\t\t\tuniforms.diffuse.value.copy( material.color );\n\n\t\t}\n\n\t\tif ( material.emissive ) {\n\n\t\t\tuniforms.emissive.value.copy( material.emissive ).multiplyScalar( material.emissiveIntensity );\n\n\t\t}\n\n\t\tif ( material.map ) {\n\n\t\t\tuniforms.map.value = material.map;\n\n\t\t}\n\n\t\tif ( material.alphaMap ) {\n\n\t\t\tuniforms.alphaMap.value = material.alphaMap;\n\n\t\t}\n\n\t\tif ( material.bumpMap ) {\n\n\t\t\tuniforms.bumpMap.value = material.bumpMap;\n\t\t\tuniforms.bumpScale.value = material.bumpScale;\n\t\t\tif ( material.side === BackSide ) uniforms.bumpScale.value *= - 1;\n\n\t\t}\n\n\t\tif ( material.displacementMap ) {\n\n\t\t\tuniforms.displacementMap.value = material.displacementMap;\n\t\t\tuniforms.displacementScale.value = material.displacementScale;\n\t\t\tuniforms.displacementBias.value = material.displacementBias;\n\n\t\t}\n\n\t\tif ( material.emissiveMap ) {\n\n\t\t\tuniforms.emissiveMap.value = material.emissiveMap;\n\n\t\t}\n\n\t\tif ( material.normalMap ) {\n\n\t\t\tuniforms.normalMap.value = material.normalMap;\n\t\t\tuniforms.normalScale.value.copy( material.normalScale );\n\t\t\tif ( material.side === BackSide ) uniforms.normalScale.value.negate();\n\n\t\t}\n\n\t\tif ( material.specularMap ) {\n\n\t\t\tuniforms.specularMap.value = material.specularMap;\n\n\t\t}\n\n\t\tif ( material.alphaTest > 0 ) {\n\n\t\t\tuniforms.alphaTest.value = material.alphaTest;\n\n\t\t}\n\n\t\tconst envMap = properties.get( material ).envMap;\n\n\t\tif ( envMap ) {\n\n\t\t\tuniforms.envMap.value = envMap;\n\n\t\t\tuniforms.flipEnvMap.value = ( envMap.isCubeTexture && envMap.isRenderTargetTexture === false ) ? - 1 : 1;\n\n\t\t\tuniforms.reflectivity.value = material.reflectivity;\n\t\t\tuniforms.ior.value = material.ior;\n\t\t\tuniforms.refractionRatio.value = material.refractionRatio;\n\n\t\t}\n\n\t\tif ( material.lightMap ) {\n\n\t\t\tuniforms.lightMap.value = material.lightMap;\n\n\t\t\t// artist-friendly light intensity scaling factor\n\t\t\tconst scaleFactor = ( renderer.physicallyCorrectLights !== true ) ? Math.PI : 1;\n\n\t\t\tuniforms.lightMapIntensity.value = material.lightMapIntensity * scaleFactor;\n\n\t\t}\n\n\t\tif ( material.aoMap ) {\n\n\t\t\tuniforms.aoMap.value = material.aoMap;\n\t\t\tuniforms.aoMapIntensity.value = material.aoMapIntensity;\n\n\t\t}\n\n\t\t// uv repeat and offset setting priorities\n\t\t// 1. color map\n\t\t// 2. specular map\n\t\t// 3. displacementMap map\n\t\t// 4. normal map\n\t\t// 5. bump map\n\t\t// 6. roughnessMap map\n\t\t// 7. metalnessMap map\n\t\t// 8. alphaMap map\n\t\t// 9. emissiveMap map\n\t\t// 10. clearcoat map\n\t\t// 11. clearcoat normal map\n\t\t// 12. clearcoat roughnessMap map\n\t\t// 13. iridescence map\n\t\t// 14. iridescence thickness map\n\t\t// 15. specular intensity map\n\t\t// 16. specular tint map\n\t\t// 17. transmission map\n\t\t// 18. thickness map\n\n\t\tlet uvScaleMap;\n\n\t\tif ( material.map ) {\n\n\t\t\tuvScaleMap = material.map;\n\n\t\t} else if ( material.specularMap ) {\n\n\t\t\tuvScaleMap = material.specularMap;\n\n\t\t} else if ( material.displacementMap ) {\n\n\t\t\tuvScaleMap = material.displacementMap;\n\n\t\t} else if ( material.normalMap ) {\n\n\t\t\tuvScaleMap = material.normalMap;\n\n\t\t} else if ( material.bumpMap ) {\n\n\t\t\tuvScaleMap = material.bumpMap;\n\n\t\t} else if ( material.roughnessMap ) {\n\n\t\t\tuvScaleMap = material.roughnessMap;\n\n\t\t} else if ( material.metalnessMap ) {\n\n\t\t\tuvScaleMap = material.metalnessMap;\n\n\t\t} else if ( material.alphaMap ) {\n\n\t\t\tuvScaleMap = material.alphaMap;\n\n\t\t} else if ( material.emissiveMap ) {\n\n\t\t\tuvScaleMap = material.emissiveMap;\n\n\t\t} else if ( material.clearcoatMap ) {\n\n\t\t\tuvScaleMap = material.clearcoatMap;\n\n\t\t} else if ( material.clearcoatNormalMap ) {\n\n\t\t\tuvScaleMap = material.clearcoatNormalMap;\n\n\t\t} else if ( material.clearcoatRoughnessMap ) {\n\n\t\t\tuvScaleMap = material.clearcoatRoughnessMap;\n\n\t\t} else if ( material.iridescenceMap ) {\n\n\t\t\tuvScaleMap = material.iridescenceMap;\n\n\t\t} else if ( material.iridescenceThicknessMap ) {\n\n\t\t\tuvScaleMap = material.iridescenceThicknessMap;\n\n\t\t} else if ( material.specularIntensityMap ) {\n\n\t\t\tuvScaleMap = material.specularIntensityMap;\n\n\t\t} else if ( material.specularColorMap ) {\n\n\t\t\tuvScaleMap = material.specularColorMap;\n\n\t\t} else if ( material.transmissionMap ) {\n\n\t\t\tuvScaleMap = material.transmissionMap;\n\n\t\t} else if ( material.thicknessMap ) {\n\n\t\t\tuvScaleMap = material.thicknessMap;\n\n\t\t} else if ( material.sheenColorMap ) {\n\n\t\t\tuvScaleMap = material.sheenColorMap;\n\n\t\t} else if ( material.sheenRoughnessMap ) {\n\n\t\t\tuvScaleMap = material.sheenRoughnessMap;\n\n\t\t}\n\n\t\tif ( uvScaleMap !== undefined ) {\n\n\t\t\t// backwards compatibility\n\t\t\tif ( uvScaleMap.isWebGLRenderTarget ) {\n\n\t\t\t\tuvScaleMap = uvScaleMap.texture;\n\n\t\t\t}\n\n\t\t\tif ( uvScaleMap.matrixAutoUpdate === true ) {\n\n\t\t\t\tuvScaleMap.updateMatrix();\n\n\t\t\t}\n\n\t\t\tuniforms.uvTransform.value.copy( uvScaleMap.matrix );\n\n\t\t}\n\n\t\t// uv repeat and offset setting priorities for uv2\n\t\t// 1. ao map\n\t\t// 2. light map\n\n\t\tlet uv2ScaleMap;\n\n\t\tif ( material.aoMap ) {\n\n\t\t\tuv2ScaleMap = material.aoMap;\n\n\t\t} else if ( material.lightMap ) {\n\n\t\t\tuv2ScaleMap = material.lightMap;\n\n\t\t}\n\n\t\tif ( uv2ScaleMap !== undefined ) {\n\n\t\t\t// backwards compatibility\n\t\t\tif ( uv2ScaleMap.isWebGLRenderTarget ) {\n\n\t\t\t\tuv2ScaleMap = uv2ScaleMap.texture;\n\n\t\t\t}\n\n\t\t\tif ( uv2ScaleMap.matrixAutoUpdate === true ) {\n\n\t\t\t\tuv2ScaleMap.updateMatrix();\n\n\t\t\t}\n\n\t\t\tuniforms.uv2Transform.value.copy( uv2ScaleMap.matrix );\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsLine( uniforms, material ) {\n\n\t\tuniforms.diffuse.value.copy( material.color );\n\t\tuniforms.opacity.value = material.opacity;\n\n\t}\n\n\tfunction refreshUniformsDash( uniforms, material ) {\n\n\t\tuniforms.dashSize.value = material.dashSize;\n\t\tuniforms.totalSize.value = material.dashSize + material.gapSize;\n\t\tuniforms.scale.value = material.scale;\n\n\t}\n\n\tfunction refreshUniformsPoints( uniforms, material, pixelRatio, height ) {\n\n\t\tuniforms.diffuse.value.copy( material.color );\n\t\tuniforms.opacity.value = material.opacity;\n\t\tuniforms.size.value = material.size * pixelRatio;\n\t\tuniforms.scale.value = height * 0.5;\n\n\t\tif ( material.map ) {\n\n\t\t\tuniforms.map.value = material.map;\n\n\t\t}\n\n\t\tif ( material.alphaMap ) {\n\n\t\t\tuniforms.alphaMap.value = material.alphaMap;\n\n\t\t}\n\n\t\tif ( material.alphaTest > 0 ) {\n\n\t\t\tuniforms.alphaTest.value = material.alphaTest;\n\n\t\t}\n\n\t\t// uv repeat and offset setting priorities\n\t\t// 1. color map\n\t\t// 2. alpha map\n\n\t\tlet uvScaleMap;\n\n\t\tif ( material.map ) {\n\n\t\t\tuvScaleMap = material.map;\n\n\t\t} else if ( material.alphaMap ) {\n\n\t\t\tuvScaleMap = material.alphaMap;\n\n\t\t}\n\n\t\tif ( uvScaleMap !== undefined ) {\n\n\t\t\tif ( uvScaleMap.matrixAutoUpdate === true ) {\n\n\t\t\t\tuvScaleMap.updateMatrix();\n\n\t\t\t}\n\n\t\t\tuniforms.uvTransform.value.copy( uvScaleMap.matrix );\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsSprites( uniforms, material ) {\n\n\t\tuniforms.diffuse.value.copy( material.color );\n\t\tuniforms.opacity.value = material.opacity;\n\t\tuniforms.rotation.value = material.rotation;\n\n\t\tif ( material.map ) {\n\n\t\t\tuniforms.map.value = material.map;\n\n\t\t}\n\n\t\tif ( material.alphaMap ) {\n\n\t\t\tuniforms.alphaMap.value = material.alphaMap;\n\n\t\t}\n\n\t\tif ( material.alphaTest > 0 ) {\n\n\t\t\tuniforms.alphaTest.value = material.alphaTest;\n\n\t\t}\n\n\t\t// uv repeat and offset setting priorities\n\t\t// 1. color map\n\t\t// 2. alpha map\n\n\t\tlet uvScaleMap;\n\n\t\tif ( material.map ) {\n\n\t\t\tuvScaleMap = material.map;\n\n\t\t} else if ( material.alphaMap ) {\n\n\t\t\tuvScaleMap = material.alphaMap;\n\n\t\t}\n\n\t\tif ( uvScaleMap !== undefined ) {\n\n\t\t\tif ( uvScaleMap.matrixAutoUpdate === true ) {\n\n\t\t\t\tuvScaleMap.updateMatrix();\n\n\t\t\t}\n\n\t\t\tuniforms.uvTransform.value.copy( uvScaleMap.matrix );\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsPhong( uniforms, material ) {\n\n\t\tuniforms.specular.value.copy( material.specular );\n\t\tuniforms.shininess.value = Math.max( material.shininess, 1e-4 ); // to prevent pow( 0.0, 0.0 )\n\n\t}\n\n\tfunction refreshUniformsToon( uniforms, material ) {\n\n\t\tif ( material.gradientMap ) {\n\n\t\t\tuniforms.gradientMap.value = material.gradientMap;\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsStandard( uniforms, material ) {\n\n\t\tuniforms.roughness.value = material.roughness;\n\t\tuniforms.metalness.value = material.metalness;\n\n\t\tif ( material.roughnessMap ) {\n\n\t\t\tuniforms.roughnessMap.value = material.roughnessMap;\n\n\t\t}\n\n\t\tif ( material.metalnessMap ) {\n\n\t\t\tuniforms.metalnessMap.value = material.metalnessMap;\n\n\t\t}\n\n\t\tconst envMap = properties.get( material ).envMap;\n\n\t\tif ( envMap ) {\n\n\t\t\t//uniforms.envMap.value = material.envMap; // part of uniforms common\n\t\t\tuniforms.envMapIntensity.value = material.envMapIntensity;\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsPhysical( uniforms, material, transmissionRenderTarget ) {\n\n\t\tuniforms.ior.value = material.ior; // also part of uniforms common\n\n\t\tif ( material.sheen > 0 ) {\n\n\t\t\tuniforms.sheenColor.value.copy( material.sheenColor ).multiplyScalar( material.sheen );\n\n\t\t\tuniforms.sheenRoughness.value = material.sheenRoughness;\n\n\t\t\tif ( material.sheenColorMap ) {\n\n\t\t\t\tuniforms.sheenColorMap.value = material.sheenColorMap;\n\n\t\t\t}\n\n\t\t\tif ( material.sheenRoughnessMap ) {\n\n\t\t\t\tuniforms.sheenRoughnessMap.value = material.sheenRoughnessMap;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( material.clearcoat > 0 ) {\n\n\t\t\tuniforms.clearcoat.value = material.clearcoat;\n\t\t\tuniforms.clearcoatRoughness.value = material.clearcoatRoughness;\n\n\t\t\tif ( material.clearcoatMap ) {\n\n\t\t\t\tuniforms.clearcoatMap.value = material.clearcoatMap;\n\n\t\t\t}\n\n\t\t\tif ( material.clearcoatRoughnessMap ) {\n\n\t\t\t\tuniforms.clearcoatRoughnessMap.value = material.clearcoatRoughnessMap;\n\n\t\t\t}\n\n\t\t\tif ( material.clearcoatNormalMap ) {\n\n\t\t\t\tuniforms.clearcoatNormalScale.value.copy( material.clearcoatNormalScale );\n\t\t\t\tuniforms.clearcoatNormalMap.value = material.clearcoatNormalMap;\n\n\t\t\t\tif ( material.side === BackSide ) {\n\n\t\t\t\t\tuniforms.clearcoatNormalScale.value.negate();\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( material.iridescence > 0 ) {\n\n\t\t\tuniforms.iridescence.value = material.iridescence;\n\t\t\tuniforms.iridescenceIOR.value = material.iridescenceIOR;\n\t\t\tuniforms.iridescenceThicknessMinimum.value = material.iridescenceThicknessRange[ 0 ];\n\t\t\tuniforms.iridescenceThicknessMaximum.value = material.iridescenceThicknessRange[ 1 ];\n\n\t\t\tif ( material.iridescenceMap ) {\n\n\t\t\t\tuniforms.iridescenceMap.value = material.iridescenceMap;\n\n\t\t\t}\n\n\t\t\tif ( material.iridescenceThicknessMap ) {\n\n\t\t\t\tuniforms.iridescenceThicknessMap.value = material.iridescenceThicknessMap;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( material.transmission > 0 ) {\n\n\t\t\tuniforms.transmission.value = material.transmission;\n\t\t\tuniforms.transmissionSamplerMap.value = transmissionRenderTarget.texture;\n\t\t\tuniforms.transmissionSamplerSize.value.set( transmissionRenderTarget.width, transmissionRenderTarget.height );\n\n\t\t\tif ( material.transmissionMap ) {\n\n\t\t\t\tuniforms.transmissionMap.value = material.transmissionMap;\n\n\t\t\t}\n\n\t\t\tuniforms.thickness.value = material.thickness;\n\n\t\t\tif ( material.thicknessMap ) {\n\n\t\t\t\tuniforms.thicknessMap.value = material.thicknessMap;\n\n\t\t\t}\n\n\t\t\tuniforms.attenuationDistance.value = material.attenuationDistance;\n\t\t\tuniforms.attenuationColor.value.copy( material.attenuationColor );\n\n\t\t}\n\n\t\tuniforms.specularIntensity.value = material.specularIntensity;\n\t\tuniforms.specularColor.value.copy( material.specularColor );\n\n\t\tif ( material.specularIntensityMap ) {\n\n\t\t\tuniforms.specularIntensityMap.value = material.specularIntensityMap;\n\n\t\t}\n\n\t\tif ( material.specularColorMap ) {\n\n\t\t\tuniforms.specularColorMap.value = material.specularColorMap;\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsMatcap( uniforms, material ) {\n\n\t\tif ( material.matcap ) {\n\n\t\t\tuniforms.matcap.value = material.matcap;\n\n\t\t}\n\n\t}\n\n\tfunction refreshUniformsDistance( uniforms, material ) {\n\n\t\tuniforms.referencePosition.value.copy( material.referencePosition );\n\t\tuniforms.nearDistance.value = material.nearDistance;\n\t\tuniforms.farDistance.value = material.farDistance;\n\n\t}\n\n\treturn {\n\t\trefreshFogUniforms: refreshFogUniforms,\n\t\trefreshMaterialUniforms: refreshMaterialUniforms\n\t};\n\n}\n\nfunction createCanvasElement() {\n\n\tconst canvas = createElementNS( 'canvas' );\n\tcanvas.style.display = 'block';\n\treturn canvas;\n\n}\n\nfunction WebGLRenderer( parameters = {} ) {\n\n\tthis.isWebGLRenderer = true;\n\n\tconst _canvas = parameters.canvas !== undefined ? parameters.canvas : createCanvasElement(),\n\t\t_context = parameters.context !== undefined ? parameters.context : null,\n\n\t\t_depth = parameters.depth !== undefined ? parameters.depth : true,\n\t\t_stencil = parameters.stencil !== undefined ? parameters.stencil : true,\n\t\t_antialias = parameters.antialias !== undefined ? parameters.antialias : false,\n\t\t_premultipliedAlpha = parameters.premultipliedAlpha !== undefined ? parameters.premultipliedAlpha : true,\n\t\t_preserveDrawingBuffer = parameters.preserveDrawingBuffer !== undefined ? parameters.preserveDrawingBuffer : false,\n\t\t_powerPreference = parameters.powerPreference !== undefined ? parameters.powerPreference : 'default',\n\t\t_failIfMajorPerformanceCaveat = parameters.failIfMajorPerformanceCaveat !== undefined ? parameters.failIfMajorPerformanceCaveat : false;\n\n\tlet _alpha;\n\n\tif ( _context !== null ) {\n\n\t\t_alpha = _context.getContextAttributes().alpha;\n\n\t} else {\n\n\t\t_alpha = parameters.alpha !== undefined ? parameters.alpha : false;\n\n\t}\n\n\tlet currentRenderList = null;\n\tlet currentRenderState = null;\n\n\t// render() can be called from within a callback triggered by another render.\n\t// We track this so that the nested render call gets its list and state isolated from the parent render call.\n\n\tconst renderListStack = [];\n\tconst renderStateStack = [];\n\n\t// public properties\n\n\tthis.domElement = _canvas;\n\n\t// Debug configuration container\n\tthis.debug = {\n\n\t\t/**\n\t\t * Enables error checking and reporting when shader programs are being compiled\n\t\t * @type {boolean}\n\t\t */\n\t\tcheckShaderErrors: true\n\t};\n\n\t// clearing\n\n\tthis.autoClear = true;\n\tthis.autoClearColor = true;\n\tthis.autoClearDepth = true;\n\tthis.autoClearStencil = true;\n\n\t// scene graph\n\n\tthis.sortObjects = true;\n\n\t// user-defined clipping\n\n\tthis.clippingPlanes = [];\n\tthis.localClippingEnabled = false;\n\n\t// physically based shading\n\n\tthis.outputEncoding = LinearEncoding;\n\n\t// physical lights\n\n\tthis.physicallyCorrectLights = false;\n\n\t// tone mapping\n\n\tthis.toneMapping = NoToneMapping;\n\tthis.toneMappingExposure = 1.0;\n\n\t//\n\n\tObject.defineProperties( this, {\n\n\t\t// @deprecated since r136, 0e21088102b4de7e0a0a33140620b7a3424b9e6d\n\n\t\tgammaFactor: {\n\t\t\tget: function () {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: .gammaFactor has been removed.' );\n\t\t\t\treturn 2;\n\n\t\t\t},\n\t\t\tset: function () {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: .gammaFactor has been removed.' );\n\n\t\t\t}\n\t\t}\n\n\t} );\n\n\t// internal properties\n\n\tconst _this = this;\n\n\tlet _isContextLost = false;\n\n\t// internal state cache\n\n\tlet _currentActiveCubeFace = 0;\n\tlet _currentActiveMipmapLevel = 0;\n\tlet _currentRenderTarget = null;\n\tlet _currentMaterialId = - 1;\n\n\tlet _currentCamera = null;\n\n\tconst _currentViewport = new Vector4();\n\tconst _currentScissor = new Vector4();\n\tlet _currentScissorTest = null;\n\n\t//\n\n\tlet _width = _canvas.width;\n\tlet _height = _canvas.height;\n\n\tlet _pixelRatio = 1;\n\tlet _opaqueSort = null;\n\tlet _transparentSort = null;\n\n\tconst _viewport = new Vector4( 0, 0, _width, _height );\n\tconst _scissor = new Vector4( 0, 0, _width, _height );\n\tlet _scissorTest = false;\n\n\t// frustum\n\n\tconst _frustum = new Frustum();\n\n\t// clipping\n\n\tlet _clippingEnabled = false;\n\tlet _localClippingEnabled = false;\n\n\t// transmission\n\n\tlet _transmissionRenderTarget = null;\n\n\t// camera matrices cache\n\n\tconst _projScreenMatrix = new Matrix4();\n\n\tconst _vector2 = new Vector2();\n\tconst _vector3 = new Vector3();\n\n\tconst _emptyScene = { background: null, fog: null, environment: null, overrideMaterial: null, isScene: true };\n\n\tfunction getTargetPixelRatio() {\n\n\t\treturn _currentRenderTarget === null ? _pixelRatio : 1;\n\n\t}\n\n\t// initialize\n\n\tlet _gl = _context;\n\n\tfunction getContext( contextNames, contextAttributes ) {\n\n\t\tfor ( let i = 0; i < contextNames.length; i ++ ) {\n\n\t\t\tconst contextName = contextNames[ i ];\n\t\t\tconst context = _canvas.getContext( contextName, contextAttributes );\n\t\t\tif ( context !== null ) return context;\n\n\t\t}\n\n\t\treturn null;\n\n\t}\n\n\ttry {\n\n\t\tconst contextAttributes = {\n\t\t\talpha: true,\n\t\t\tdepth: _depth,\n\t\t\tstencil: _stencil,\n\t\t\tantialias: _antialias,\n\t\t\tpremultipliedAlpha: _premultipliedAlpha,\n\t\t\tpreserveDrawingBuffer: _preserveDrawingBuffer,\n\t\t\tpowerPreference: _powerPreference,\n\t\t\tfailIfMajorPerformanceCaveat: _failIfMajorPerformanceCaveat\n\t\t};\n\n\t\t// OffscreenCanvas does not have setAttribute, see #22811\n\t\tif ( 'setAttribute' in _canvas ) _canvas.setAttribute( 'data-engine', `three.js r${REVISION}` );\n\n\t\t// event listeners must be registered before WebGL context is created, see #12753\n\t\t_canvas.addEventListener( 'webglcontextlost', onContextLost, false );\n\t\t_canvas.addEventListener( 'webglcontextrestored', onContextRestore, false );\n\t\t_canvas.addEventListener( 'webglcontextcreationerror', onContextCreationError, false );\n\n\t\tif ( _gl === null ) {\n\n\t\t\tconst contextNames = [ 'webgl2', 'webgl', 'experimental-webgl' ];\n\n\t\t\tif ( _this.isWebGL1Renderer === true ) {\n\n\t\t\t\tcontextNames.shift();\n\n\t\t\t}\n\n\t\t\t_gl = getContext( contextNames, contextAttributes );\n\n\t\t\tif ( _gl === null ) {\n\n\t\t\t\tif ( getContext( contextNames ) ) {\n\n\t\t\t\t\tthrow new Error( 'Error creating WebGL context with your selected attributes.' );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthrow new Error( 'Error creating WebGL context.' );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\t// Some experimental-webgl implementations do not have getShaderPrecisionFormat\n\n\t\tif ( _gl.getShaderPrecisionFormat === undefined ) {\n\n\t\t\t_gl.getShaderPrecisionFormat = function () {\n\n\t\t\t\treturn { 'rangeMin': 1, 'rangeMax': 1, 'precision': 1 };\n\n\t\t\t};\n\n\t\t}\n\n\t} catch ( error ) {\n\n\t\tconsole.error( 'THREE.WebGLRenderer: ' + error.message );\n\t\tthrow error;\n\n\t}\n\n\tlet extensions, capabilities, state, info;\n\tlet properties, textures, cubemaps, cubeuvmaps, attributes, geometries, objects;\n\tlet programCache, materials, renderLists, renderStates, clipping, shadowMap;\n\n\tlet background, morphtargets, bufferRenderer, indexedBufferRenderer;\n\n\tlet utils, bindingStates;\n\n\tfunction initGLContext() {\n\n\t\textensions = new WebGLExtensions( _gl );\n\n\t\tcapabilities = new WebGLCapabilities( _gl, extensions, parameters );\n\n\t\textensions.init( capabilities );\n\n\t\tutils = new WebGLUtils( _gl, extensions, capabilities );\n\n\t\tstate = new WebGLState( _gl, extensions, capabilities );\n\n\t\tinfo = new WebGLInfo( _gl );\n\t\tproperties = new WebGLProperties();\n\t\ttextures = new WebGLTextures( _gl, extensions, state, properties, capabilities, utils, info );\n\t\tcubemaps = new WebGLCubeMaps( _this );\n\t\tcubeuvmaps = new WebGLCubeUVMaps( _this );\n\t\tattributes = new WebGLAttributes( _gl, capabilities );\n\t\tbindingStates = new WebGLBindingStates( _gl, extensions, attributes, capabilities );\n\t\tgeometries = new WebGLGeometries( _gl, attributes, info, bindingStates );\n\t\tobjects = new WebGLObjects( _gl, geometries, attributes, info );\n\t\tmorphtargets = new WebGLMorphtargets( _gl, capabilities, textures );\n\t\tclipping = new WebGLClipping( properties );\n\t\tprogramCache = new WebGLPrograms( _this, cubemaps, cubeuvmaps, extensions, capabilities, bindingStates, clipping );\n\t\tmaterials = new WebGLMaterials( _this, properties );\n\t\trenderLists = new WebGLRenderLists();\n\t\trenderStates = new WebGLRenderStates( extensions, capabilities );\n\t\tbackground = new WebGLBackground( _this, cubemaps, state, objects, _alpha, _premultipliedAlpha );\n\t\tshadowMap = new WebGLShadowMap( _this, objects, capabilities );\n\n\t\tbufferRenderer = new WebGLBufferRenderer( _gl, extensions, info, capabilities );\n\t\tindexedBufferRenderer = new WebGLIndexedBufferRenderer( _gl, extensions, info, capabilities );\n\n\t\tinfo.programs = programCache.programs;\n\n\t\t_this.capabilities = capabilities;\n\t\t_this.extensions = extensions;\n\t\t_this.properties = properties;\n\t\t_this.renderLists = renderLists;\n\t\t_this.shadowMap = shadowMap;\n\t\t_this.state = state;\n\t\t_this.info = info;\n\n\t}\n\n\tinitGLContext();\n\n\t// xr\n\n\tconst xr = new WebXRManager( _this, _gl );\n\n\tthis.xr = xr;\n\n\t// API\n\n\tthis.getContext = function () {\n\n\t\treturn _gl;\n\n\t};\n\n\tthis.getContextAttributes = function () {\n\n\t\treturn _gl.getContextAttributes();\n\n\t};\n\n\tthis.forceContextLoss = function () {\n\n\t\tconst extension = extensions.get( 'WEBGL_lose_context' );\n\t\tif ( extension ) extension.loseContext();\n\n\t};\n\n\tthis.forceContextRestore = function () {\n\n\t\tconst extension = extensions.get( 'WEBGL_lose_context' );\n\t\tif ( extension ) extension.restoreContext();\n\n\t};\n\n\tthis.getPixelRatio = function () {\n\n\t\treturn _pixelRatio;\n\n\t};\n\n\tthis.setPixelRatio = function ( value ) {\n\n\t\tif ( value === undefined ) return;\n\n\t\t_pixelRatio = value;\n\n\t\tthis.setSize( _width, _height, false );\n\n\t};\n\n\tthis.getSize = function ( target ) {\n\n\t\treturn target.set( _width, _height );\n\n\t};\n\n\tthis.setSize = function ( width, height, updateStyle ) {\n\n\t\tif ( xr.isPresenting ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer: Can\\'t change size while VR device is presenting.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\t_width = width;\n\t\t_height = height;\n\n\t\t_canvas.width = Math.floor( width * _pixelRatio );\n\t\t_canvas.height = Math.floor( height * _pixelRatio );\n\n\t\tif ( updateStyle !== false ) {\n\n\t\t\t_canvas.style.width = width + 'px';\n\t\t\t_canvas.style.height = height + 'px';\n\n\t\t}\n\n\t\tthis.setViewport( 0, 0, width, height );\n\n\t};\n\n\tthis.getDrawingBufferSize = function ( target ) {\n\n\t\treturn target.set( _width * _pixelRatio, _height * _pixelRatio ).floor();\n\n\t};\n\n\tthis.setDrawingBufferSize = function ( width, height, pixelRatio ) {\n\n\t\t_width = width;\n\t\t_height = height;\n\n\t\t_pixelRatio = pixelRatio;\n\n\t\t_canvas.width = Math.floor( width * pixelRatio );\n\t\t_canvas.height = Math.floor( height * pixelRatio );\n\n\t\tthis.setViewport( 0, 0, width, height );\n\n\t};\n\n\tthis.getCurrentViewport = function ( target ) {\n\n\t\treturn target.copy( _currentViewport );\n\n\t};\n\n\tthis.getViewport = function ( target ) {\n\n\t\treturn target.copy( _viewport );\n\n\t};\n\n\tthis.setViewport = function ( x, y, width, height ) {\n\n\t\tif ( x.isVector4 ) {\n\n\t\t\t_viewport.set( x.x, x.y, x.z, x.w );\n\n\t\t} else {\n\n\t\t\t_viewport.set( x, y, width, height );\n\n\t\t}\n\n\t\tstate.viewport( _currentViewport.copy( _viewport ).multiplyScalar( _pixelRatio ).floor() );\n\n\t};\n\n\tthis.getScissor = function ( target ) {\n\n\t\treturn target.copy( _scissor );\n\n\t};\n\n\tthis.setScissor = function ( x, y, width, height ) {\n\n\t\tif ( x.isVector4 ) {\n\n\t\t\t_scissor.set( x.x, x.y, x.z, x.w );\n\n\t\t} else {\n\n\t\t\t_scissor.set( x, y, width, height );\n\n\t\t}\n\n\t\tstate.scissor( _currentScissor.copy( _scissor ).multiplyScalar( _pixelRatio ).floor() );\n\n\t};\n\n\tthis.getScissorTest = function () {\n\n\t\treturn _scissorTest;\n\n\t};\n\n\tthis.setScissorTest = function ( boolean ) {\n\n\t\tstate.setScissorTest( _scissorTest = boolean );\n\n\t};\n\n\tthis.setOpaqueSort = function ( method ) {\n\n\t\t_opaqueSort = method;\n\n\t};\n\n\tthis.setTransparentSort = function ( method ) {\n\n\t\t_transparentSort = method;\n\n\t};\n\n\t// Clearing\n\n\tthis.getClearColor = function ( target ) {\n\n\t\treturn target.copy( background.getClearColor() );\n\n\t};\n\n\tthis.setClearColor = function () {\n\n\t\tbackground.setClearColor.apply( background, arguments );\n\n\t};\n\n\tthis.getClearAlpha = function () {\n\n\t\treturn background.getClearAlpha();\n\n\t};\n\n\tthis.setClearAlpha = function () {\n\n\t\tbackground.setClearAlpha.apply( background, arguments );\n\n\t};\n\n\tthis.clear = function ( color = true, depth = true, stencil = true ) {\n\n\t\tlet bits = 0;\n\n\t\tif ( color ) bits |= 16384;\n\t\tif ( depth ) bits |= 256;\n\t\tif ( stencil ) bits |= 1024;\n\n\t\t_gl.clear( bits );\n\n\t};\n\n\tthis.clearColor = function () {\n\n\t\tthis.clear( true, false, false );\n\n\t};\n\n\tthis.clearDepth = function () {\n\n\t\tthis.clear( false, true, false );\n\n\t};\n\n\tthis.clearStencil = function () {\n\n\t\tthis.clear( false, false, true );\n\n\t};\n\n\t//\n\n\tthis.dispose = function () {\n\n\t\t_canvas.removeEventListener( 'webglcontextlost', onContextLost, false );\n\t\t_canvas.removeEventListener( 'webglcontextrestored', onContextRestore, false );\n\t\t_canvas.removeEventListener( 'webglcontextcreationerror', onContextCreationError, false );\n\n\t\trenderLists.dispose();\n\t\trenderStates.dispose();\n\t\tproperties.dispose();\n\t\tcubemaps.dispose();\n\t\tcubeuvmaps.dispose();\n\t\tobjects.dispose();\n\t\tbindingStates.dispose();\n\t\tprogramCache.dispose();\n\n\t\txr.dispose();\n\n\t\txr.removeEventListener( 'sessionstart', onXRSessionStart );\n\t\txr.removeEventListener( 'sessionend', onXRSessionEnd );\n\n\t\tif ( _transmissionRenderTarget ) {\n\n\t\t\t_transmissionRenderTarget.dispose();\n\t\t\t_transmissionRenderTarget = null;\n\n\t\t}\n\n\t\tanimation.stop();\n\n\t};\n\n\t// Events\n\n\tfunction onContextLost( event ) {\n\n\t\tevent.preventDefault();\n\n\t\tconsole.log( 'THREE.WebGLRenderer: Context Lost.' );\n\n\t\t_isContextLost = true;\n\n\t}\n\n\tfunction onContextRestore( /* event */ ) {\n\n\t\tconsole.log( 'THREE.WebGLRenderer: Context Restored.' );\n\n\t\t_isContextLost = false;\n\n\t\tconst infoAutoReset = info.autoReset;\n\t\tconst shadowMapEnabled = shadowMap.enabled;\n\t\tconst shadowMapAutoUpdate = shadowMap.autoUpdate;\n\t\tconst shadowMapNeedsUpdate = shadowMap.needsUpdate;\n\t\tconst shadowMapType = shadowMap.type;\n\n\t\tinitGLContext();\n\n\t\tinfo.autoReset = infoAutoReset;\n\t\tshadowMap.enabled = shadowMapEnabled;\n\t\tshadowMap.autoUpdate = shadowMapAutoUpdate;\n\t\tshadowMap.needsUpdate = shadowMapNeedsUpdate;\n\t\tshadowMap.type = shadowMapType;\n\n\t}\n\n\tfunction onContextCreationError( event ) {\n\n\t\tconsole.error( 'THREE.WebGLRenderer: A WebGL context could not be created. Reason: ', event.statusMessage );\n\n\t}\n\n\tfunction onMaterialDispose( event ) {\n\n\t\tconst material = event.target;\n\n\t\tmaterial.removeEventListener( 'dispose', onMaterialDispose );\n\n\t\tdeallocateMaterial( material );\n\n\t}\n\n\t// Buffer deallocation\n\n\tfunction deallocateMaterial( material ) {\n\n\t\treleaseMaterialProgramReferences( material );\n\n\t\tproperties.remove( material );\n\n\t}\n\n\n\tfunction releaseMaterialProgramReferences( material ) {\n\n\t\tconst programs = properties.get( material ).programs;\n\n\t\tif ( programs !== undefined ) {\n\n\t\t\tprograms.forEach( function ( program ) {\n\n\t\t\t\tprogramCache.releaseProgram( program );\n\n\t\t\t} );\n\n\t\t\tif ( material.isShaderMaterial ) {\n\n\t\t\t\tprogramCache.releaseShaderCache( material );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\t// Buffer rendering\n\n\tthis.renderBufferDirect = function ( camera, scene, geometry, material, object, group ) {\n\n\t\tif ( scene === null ) scene = _emptyScene; // renderBufferDirect second parameter used to be fog (could be null)\n\n\t\tconst frontFaceCW = ( object.isMesh && object.matrixWorld.determinant() < 0 );\n\n\t\tconst program = setProgram( camera, scene, geometry, material, object );\n\n\t\tstate.setMaterial( material, frontFaceCW );\n\n\t\t//\n\n\t\tlet index = geometry.index;\n\t\tconst position = geometry.attributes.position;\n\n\t\t//\n\n\t\tif ( index === null ) {\n\n\t\t\tif ( position === undefined || position.count === 0 ) return;\n\n\t\t} else if ( index.count === 0 ) {\n\n\t\t\treturn;\n\n\t\t}\n\n\t\t//\n\n\t\tlet rangeFactor = 1;\n\n\t\tif ( material.wireframe === true ) {\n\n\t\t\tindex = geometries.getWireframeAttribute( geometry );\n\t\t\trangeFactor = 2;\n\n\t\t}\n\n\t\tbindingStates.setup( object, material, program, geometry, index );\n\n\t\tlet attribute;\n\t\tlet renderer = bufferRenderer;\n\n\t\tif ( index !== null ) {\n\n\t\t\tattribute = attributes.get( index );\n\n\t\t\trenderer = indexedBufferRenderer;\n\t\t\trenderer.setIndex( attribute );\n\n\t\t}\n\n\t\t//\n\n\t\tconst dataCount = ( index !== null ) ? index.count : position.count;\n\n\t\tconst rangeStart = geometry.drawRange.start * rangeFactor;\n\t\tconst rangeCount = geometry.drawRange.count * rangeFactor;\n\n\t\tconst groupStart = group !== null ? group.start * rangeFactor : 0;\n\t\tconst groupCount = group !== null ? group.count * rangeFactor : Infinity;\n\n\t\tconst drawStart = Math.max( rangeStart, groupStart );\n\t\tconst drawEnd = Math.min( dataCount, rangeStart + rangeCount, groupStart + groupCount ) - 1;\n\n\t\tconst drawCount = Math.max( 0, drawEnd - drawStart + 1 );\n\n\t\tif ( drawCount === 0 ) return;\n\n\t\t//\n\n\t\tif ( object.isMesh ) {\n\n\t\t\tif ( material.wireframe === true ) {\n\n\t\t\t\tstate.setLineWidth( material.wireframeLinewidth * getTargetPixelRatio() );\n\t\t\t\trenderer.setMode( 1 );\n\n\t\t\t} else {\n\n\t\t\t\trenderer.setMode( 4 );\n\n\t\t\t}\n\n\t\t} else if ( object.isLine ) {\n\n\t\t\tlet lineWidth = material.linewidth;\n\n\t\t\tif ( lineWidth === undefined ) lineWidth = 1; // Not using Line*Material\n\n\t\t\tstate.setLineWidth( lineWidth * getTargetPixelRatio() );\n\n\t\t\tif ( object.isLineSegments ) {\n\n\t\t\t\trenderer.setMode( 1 );\n\n\t\t\t} else if ( object.isLineLoop ) {\n\n\t\t\t\trenderer.setMode( 2 );\n\n\t\t\t} else {\n\n\t\t\t\trenderer.setMode( 3 );\n\n\t\t\t}\n\n\t\t} else if ( object.isPoints ) {\n\n\t\t\trenderer.setMode( 0 );\n\n\t\t} else if ( object.isSprite ) {\n\n\t\t\trenderer.setMode( 4 );\n\n\t\t}\n\n\t\tif ( object.isInstancedMesh ) {\n\n\t\t\trenderer.renderInstances( drawStart, drawCount, object.count );\n\n\t\t} else if ( geometry.isInstancedBufferGeometry ) {\n\n\t\t\tconst instanceCount = Math.min( geometry.instanceCount, geometry._maxInstanceCount );\n\n\t\t\trenderer.renderInstances( drawStart, drawCount, instanceCount );\n\n\t\t} else {\n\n\t\t\trenderer.render( drawStart, drawCount );\n\n\t\t}\n\n\t};\n\n\t// Compile\n\n\tthis.compile = function ( scene, camera ) {\n\n\t\tcurrentRenderState = renderStates.get( scene );\n\t\tcurrentRenderState.init();\n\n\t\trenderStateStack.push( currentRenderState );\n\n\t\tscene.traverseVisible( function ( object ) {\n\n\t\t\tif ( object.isLight && object.layers.test( camera.layers ) ) {\n\n\t\t\t\tcurrentRenderState.pushLight( object );\n\n\t\t\t\tif ( object.castShadow ) {\n\n\t\t\t\t\tcurrentRenderState.pushShadow( object );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} );\n\n\t\tcurrentRenderState.setupLights( _this.physicallyCorrectLights );\n\n\t\tscene.traverse( function ( object ) {\n\n\t\t\tconst material = object.material;\n\n\t\t\tif ( material ) {\n\n\t\t\t\tif ( Array.isArray( material ) ) {\n\n\t\t\t\t\tfor ( let i = 0; i < material.length; i ++ ) {\n\n\t\t\t\t\t\tconst material2 = material[ i ];\n\n\t\t\t\t\t\tgetProgram( material2, scene, object );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tgetProgram( material, scene, object );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} );\n\n\t\trenderStateStack.pop();\n\t\tcurrentRenderState = null;\n\n\t};\n\n\t// Animation Loop\n\n\tlet onAnimationFrameCallback = null;\n\n\tfunction onAnimationFrame( time ) {\n\n\t\tif ( onAnimationFrameCallback ) onAnimationFrameCallback( time );\n\n\t}\n\n\tfunction onXRSessionStart() {\n\n\t\tanimation.stop();\n\n\t}\n\n\tfunction onXRSessionEnd() {\n\n\t\tanimation.start();\n\n\t}\n\n\tconst animation = new WebGLAnimation();\n\tanimation.setAnimationLoop( onAnimationFrame );\n\n\tif ( typeof self !== 'undefined' ) animation.setContext( self );\n\n\tthis.setAnimationLoop = function ( callback ) {\n\n\t\tonAnimationFrameCallback = callback;\n\t\txr.setAnimationLoop( callback );\n\n\t\t( callback === null ) ? animation.stop() : animation.start();\n\n\t};\n\n\txr.addEventListener( 'sessionstart', onXRSessionStart );\n\txr.addEventListener( 'sessionend', onXRSessionEnd );\n\n\t// Rendering\n\n\tthis.render = function ( scene, camera ) {\n\n\t\tif ( camera !== undefined && camera.isCamera !== true ) {\n\n\t\t\tconsole.error( 'THREE.WebGLRenderer.render: camera is not an instance of THREE.Camera.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( _isContextLost === true ) return;\n\n\t\t// update scene graph\n\n\t\tif ( scene.autoUpdate === true ) scene.updateMatrixWorld();\n\n\t\t// update camera matrices and frustum\n\n\t\tif ( camera.parent === null ) camera.updateMatrixWorld();\n\n\t\tif ( xr.enabled === true && xr.isPresenting === true ) {\n\n\t\t\tif ( xr.cameraAutoUpdate === true ) xr.updateCamera( camera );\n\n\t\t\tcamera = xr.getCamera(); // use XR camera for rendering\n\n\t\t}\n\n\t\t//\n\t\tif ( scene.isScene === true ) scene.onBeforeRender( _this, scene, camera, _currentRenderTarget );\n\n\t\tcurrentRenderState = renderStates.get( scene, renderStateStack.length );\n\t\tcurrentRenderState.init();\n\n\t\trenderStateStack.push( currentRenderState );\n\n\t\t_projScreenMatrix.multiplyMatrices( camera.projectionMatrix, camera.matrixWorldInverse );\n\t\t_frustum.setFromProjectionMatrix( _projScreenMatrix );\n\n\t\t_localClippingEnabled = this.localClippingEnabled;\n\t\t_clippingEnabled = clipping.init( this.clippingPlanes, _localClippingEnabled, camera );\n\n\t\tcurrentRenderList = renderLists.get( scene, renderListStack.length );\n\t\tcurrentRenderList.init();\n\n\t\trenderListStack.push( currentRenderList );\n\n\t\tprojectObject( scene, camera, 0, _this.sortObjects );\n\n\t\tcurrentRenderList.finish();\n\n\t\tif ( _this.sortObjects === true ) {\n\n\t\t\tcurrentRenderList.sort( _opaqueSort, _transparentSort );\n\n\t\t}\n\n\t\t//\n\n\t\tif ( _clippingEnabled === true ) clipping.beginShadows();\n\n\t\tconst shadowsArray = currentRenderState.state.shadowsArray;\n\n\t\tshadowMap.render( shadowsArray, scene, camera );\n\n\t\tif ( _clippingEnabled === true ) clipping.endShadows();\n\n\t\t//\n\n\t\tif ( this.info.autoReset === true ) this.info.reset();\n\n\t\t//\n\n\t\tbackground.render( currentRenderList, scene );\n\n\t\t// render scene\n\n\t\tcurrentRenderState.setupLights( _this.physicallyCorrectLights );\n\n\t\tif ( camera.isArrayCamera ) {\n\n\t\t\tconst cameras = camera.cameras;\n\n\t\t\tfor ( let i = 0, l = cameras.length; i < l; i ++ ) {\n\n\t\t\t\tconst camera2 = cameras[ i ];\n\n\t\t\t\trenderScene( currentRenderList, scene, camera2, camera2.viewport );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\trenderScene( currentRenderList, scene, camera );\n\n\t\t}\n\n\t\t//\n\n\t\tif ( _currentRenderTarget !== null ) {\n\n\t\t\t// resolve multisample renderbuffers to a single-sample texture if necessary\n\n\t\t\ttextures.updateMultisampleRenderTarget( _currentRenderTarget );\n\n\t\t\t// Generate mipmap if we're using any kind of mipmap filtering\n\n\t\t\ttextures.updateRenderTargetMipmap( _currentRenderTarget );\n\n\t\t}\n\n\t\t//\n\n\t\tif ( scene.isScene === true ) scene.onAfterRender( _this, scene, camera );\n\n\t\t// _gl.finish();\n\n\t\tbindingStates.resetDefaultState();\n\t\t_currentMaterialId = - 1;\n\t\t_currentCamera = null;\n\n\t\trenderStateStack.pop();\n\n\t\tif ( renderStateStack.length > 0 ) {\n\n\t\t\tcurrentRenderState = renderStateStack[ renderStateStack.length - 1 ];\n\n\t\t} else {\n\n\t\t\tcurrentRenderState = null;\n\n\t\t}\n\n\t\trenderListStack.pop();\n\n\t\tif ( renderListStack.length > 0 ) {\n\n\t\t\tcurrentRenderList = renderListStack[ renderListStack.length - 1 ];\n\n\t\t} else {\n\n\t\t\tcurrentRenderList = null;\n\n\t\t}\n\n\t};\n\n\tfunction projectObject( object, camera, groupOrder, sortObjects ) {\n\n\t\tif ( object.visible === false ) return;\n\n\t\tconst visible = object.layers.test( camera.layers );\n\n\t\tif ( visible ) {\n\n\t\t\tif ( object.isGroup ) {\n\n\t\t\t\tgroupOrder = object.renderOrder;\n\n\t\t\t} else if ( object.isLOD ) {\n\n\t\t\t\tif ( object.autoUpdate === true ) object.update( camera );\n\n\t\t\t} else if ( object.isLight ) {\n\n\t\t\t\tcurrentRenderState.pushLight( object );\n\n\t\t\t\tif ( object.castShadow ) {\n\n\t\t\t\t\tcurrentRenderState.pushShadow( object );\n\n\t\t\t\t}\n\n\t\t\t} else if ( object.isSprite ) {\n\n\t\t\t\tif ( ! object.frustumCulled || _frustum.intersectsSprite( object ) ) {\n\n\t\t\t\t\tif ( sortObjects ) {\n\n\t\t\t\t\t\t_vector3.setFromMatrixPosition( object.matrixWorld )\n\t\t\t\t\t\t\t.applyMatrix4( _projScreenMatrix );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tconst geometry = objects.update( object );\n\t\t\t\t\tconst material = object.material;\n\n\t\t\t\t\tif ( material.visible ) {\n\n\t\t\t\t\t\tcurrentRenderList.push( object, geometry, material, groupOrder, _vector3.z, null );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else if ( object.isMesh || object.isLine || object.isPoints ) {\n\n\t\t\t\tif ( object.isSkinnedMesh ) {\n\n\t\t\t\t\t// update skeleton only once in a frame\n\n\t\t\t\t\tif ( object.skeleton.frame !== info.render.frame ) {\n\n\t\t\t\t\t\tobject.skeleton.update();\n\t\t\t\t\t\tobject.skeleton.frame = info.render.frame;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tif ( ! object.frustumCulled || _frustum.intersectsObject( object ) ) {\n\n\t\t\t\t\tif ( sortObjects ) {\n\n\t\t\t\t\t\t_vector3.setFromMatrixPosition( object.matrixWorld )\n\t\t\t\t\t\t\t.applyMatrix4( _projScreenMatrix );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tconst geometry = objects.update( object );\n\t\t\t\t\tconst material = object.material;\n\n\t\t\t\t\tif ( Array.isArray( material ) ) {\n\n\t\t\t\t\t\tconst groups = geometry.groups;\n\n\t\t\t\t\t\tfor ( let i = 0, l = groups.length; i < l; i ++ ) {\n\n\t\t\t\t\t\t\tconst group = groups[ i ];\n\t\t\t\t\t\t\tconst groupMaterial = material[ group.materialIndex ];\n\n\t\t\t\t\t\t\tif ( groupMaterial && groupMaterial.visible ) {\n\n\t\t\t\t\t\t\t\tcurrentRenderList.push( object, geometry, groupMaterial, groupOrder, _vector3.z, group );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} else if ( material.visible ) {\n\n\t\t\t\t\t\tcurrentRenderList.push( object, geometry, material, groupOrder, _vector3.z, null );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst children = object.children;\n\n\t\tfor ( let i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\tprojectObject( children[ i ], camera, groupOrder, sortObjects );\n\n\t\t}\n\n\t}\n\n\tfunction renderScene( currentRenderList, scene, camera, viewport ) {\n\n\t\tconst opaqueObjects = currentRenderList.opaque;\n\t\tconst transmissiveObjects = currentRenderList.transmissive;\n\t\tconst transparentObjects = currentRenderList.transparent;\n\n\t\tcurrentRenderState.setupLightsView( camera );\n\n\t\tif ( transmissiveObjects.length > 0 ) renderTransmissionPass( opaqueObjects, scene, camera );\n\n\t\tif ( viewport ) state.viewport( _currentViewport.copy( viewport ) );\n\n\t\tif ( opaqueObjects.length > 0 ) renderObjects( opaqueObjects, scene, camera );\n\t\tif ( transmissiveObjects.length > 0 ) renderObjects( transmissiveObjects, scene, camera );\n\t\tif ( transparentObjects.length > 0 ) renderObjects( transparentObjects, scene, camera );\n\n\t\t// Ensure depth buffer writing is enabled so it can be cleared on next render\n\n\t\tstate.buffers.depth.setTest( true );\n\t\tstate.buffers.depth.setMask( true );\n\t\tstate.buffers.color.setMask( true );\n\n\t\tstate.setPolygonOffset( false );\n\n\t}\n\n\tfunction renderTransmissionPass( opaqueObjects, scene, camera ) {\n\n\t\tconst isWebGL2 = capabilities.isWebGL2;\n\n\t\tif ( _transmissionRenderTarget === null ) {\n\n\t\t\t_transmissionRenderTarget = new WebGLRenderTarget( 1, 1, {\n\t\t\t\tgenerateMipmaps: true,\n\t\t\t\ttype: extensions.has( 'EXT_color_buffer_half_float' ) ? HalfFloatType : UnsignedByteType,\n\t\t\t\tminFilter: LinearMipmapLinearFilter,\n\t\t\t\tsamples: ( isWebGL2 && _antialias === true ) ? 4 : 0\n\t\t\t} );\n\n\t\t}\n\n\t\t_this.getDrawingBufferSize( _vector2 );\n\n\t\tif ( isWebGL2 ) {\n\n\t\t\t_transmissionRenderTarget.setSize( _vector2.x, _vector2.y );\n\n\t\t} else {\n\n\t\t\t_transmissionRenderTarget.setSize( floorPowerOfTwo( _vector2.x ), floorPowerOfTwo( _vector2.y ) );\n\n\t\t}\n\n\t\t//\n\n\t\tconst currentRenderTarget = _this.getRenderTarget();\n\t\t_this.setRenderTarget( _transmissionRenderTarget );\n\t\t_this.clear();\n\n\t\t// Turn off the features which can affect the frag color for opaque objects pass.\n\t\t// Otherwise they are applied twice in opaque objects pass and transmission objects pass.\n\t\tconst currentToneMapping = _this.toneMapping;\n\t\t_this.toneMapping = NoToneMapping;\n\n\t\trenderObjects( opaqueObjects, scene, camera );\n\n\t\t_this.toneMapping = currentToneMapping;\n\n\t\ttextures.updateMultisampleRenderTarget( _transmissionRenderTarget );\n\t\ttextures.updateRenderTargetMipmap( _transmissionRenderTarget );\n\n\t\t_this.setRenderTarget( currentRenderTarget );\n\n\t}\n\n\tfunction renderObjects( renderList, scene, camera ) {\n\n\t\tconst overrideMaterial = scene.isScene === true ? scene.overrideMaterial : null;\n\n\t\tfor ( let i = 0, l = renderList.length; i < l; i ++ ) {\n\n\t\t\tconst renderItem = renderList[ i ];\n\n\t\t\tconst object = renderItem.object;\n\t\t\tconst geometry = renderItem.geometry;\n\t\t\tconst material = overrideMaterial === null ? renderItem.material : overrideMaterial;\n\t\t\tconst group = renderItem.group;\n\n\t\t\tif ( object.layers.test( camera.layers ) ) {\n\n\t\t\t\trenderObject( object, scene, camera, geometry, material, group );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tfunction renderObject( object, scene, camera, geometry, material, group ) {\n\n\t\tobject.onBeforeRender( _this, scene, camera, geometry, material, group );\n\n\t\tobject.modelViewMatrix.multiplyMatrices( camera.matrixWorldInverse, object.matrixWorld );\n\t\tobject.normalMatrix.getNormalMatrix( object.modelViewMatrix );\n\n\t\tmaterial.onBeforeRender( _this, scene, camera, geometry, object, group );\n\n\t\tif ( material.transparent === true && material.side === DoubleSide ) {\n\n\t\t\tmaterial.side = BackSide;\n\t\t\tmaterial.needsUpdate = true;\n\t\t\t_this.renderBufferDirect( camera, scene, geometry, material, object, group );\n\n\t\t\tmaterial.side = FrontSide;\n\t\t\tmaterial.needsUpdate = true;\n\t\t\t_this.renderBufferDirect( camera, scene, geometry, material, object, group );\n\n\t\t\tmaterial.side = DoubleSide;\n\n\t\t} else {\n\n\t\t\t_this.renderBufferDirect( camera, scene, geometry, material, object, group );\n\n\t\t}\n\n\t\tobject.onAfterRender( _this, scene, camera, geometry, material, group );\n\n\t}\n\n\tfunction getProgram( material, scene, object ) {\n\n\t\tif ( scene.isScene !== true ) scene = _emptyScene; // scene could be a Mesh, Line, Points, ...\n\n\t\tconst materialProperties = properties.get( material );\n\n\t\tconst lights = currentRenderState.state.lights;\n\t\tconst shadowsArray = currentRenderState.state.shadowsArray;\n\n\t\tconst lightsStateVersion = lights.state.version;\n\n\t\tconst parameters = programCache.getParameters( material, lights.state, shadowsArray, scene, object );\n\t\tconst programCacheKey = programCache.getProgramCacheKey( parameters );\n\n\t\tlet programs = materialProperties.programs;\n\n\t\t// always update environment and fog - changing these trigger an getProgram call, but it's possible that the program doesn't change\n\n\t\tmaterialProperties.environment = material.isMeshStandardMaterial ? scene.environment : null;\n\t\tmaterialProperties.fog = scene.fog;\n\t\tmaterialProperties.envMap = ( material.isMeshStandardMaterial ? cubeuvmaps : cubemaps ).get( material.envMap || materialProperties.environment );\n\n\t\tif ( programs === undefined ) {\n\n\t\t\t// new material\n\n\t\t\tmaterial.addEventListener( 'dispose', onMaterialDispose );\n\n\t\t\tprograms = new Map();\n\t\t\tmaterialProperties.programs = programs;\n\n\t\t}\n\n\t\tlet program = programs.get( programCacheKey );\n\n\t\tif ( program !== undefined ) {\n\n\t\t\t// early out if program and light state is identical\n\n\t\t\tif ( materialProperties.currentProgram === program && materialProperties.lightsStateVersion === lightsStateVersion ) {\n\n\t\t\t\tupdateCommonMaterialProperties( material, parameters );\n\n\t\t\t\treturn program;\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tparameters.uniforms = programCache.getUniforms( material );\n\n\t\t\tmaterial.onBuild( object, parameters, _this );\n\n\t\t\tmaterial.onBeforeCompile( parameters, _this );\n\n\t\t\tprogram = programCache.acquireProgram( parameters, programCacheKey );\n\t\t\tprograms.set( programCacheKey, program );\n\n\t\t\tmaterialProperties.uniforms = parameters.uniforms;\n\n\t\t}\n\n\t\tconst uniforms = materialProperties.uniforms;\n\n\t\tif ( ( ! material.isShaderMaterial && ! material.isRawShaderMaterial ) || material.clipping === true ) {\n\n\t\t\tuniforms.clippingPlanes = clipping.uniform;\n\n\t\t}\n\n\t\tupdateCommonMaterialProperties( material, parameters );\n\n\t\t// store the light setup it was created for\n\n\t\tmaterialProperties.needsLights = materialNeedsLights( material );\n\t\tmaterialProperties.lightsStateVersion = lightsStateVersion;\n\n\t\tif ( materialProperties.needsLights ) {\n\n\t\t\t// wire up the material to this renderer's lighting state\n\n\t\t\tuniforms.ambientLightColor.value = lights.state.ambient;\n\t\t\tuniforms.lightProbe.value = lights.state.probe;\n\t\t\tuniforms.directionalLights.value = lights.state.directional;\n\t\t\tuniforms.directionalLightShadows.value = lights.state.directionalShadow;\n\t\t\tuniforms.spotLights.value = lights.state.spot;\n\t\t\tuniforms.spotLightShadows.value = lights.state.spotShadow;\n\t\t\tuniforms.rectAreaLights.value = lights.state.rectArea;\n\t\t\tuniforms.ltc_1.value = lights.state.rectAreaLTC1;\n\t\t\tuniforms.ltc_2.value = lights.state.rectAreaLTC2;\n\t\t\tuniforms.pointLights.value = lights.state.point;\n\t\t\tuniforms.pointLightShadows.value = lights.state.pointShadow;\n\t\t\tuniforms.hemisphereLights.value = lights.state.hemi;\n\n\t\t\tuniforms.directionalShadowMap.value = lights.state.directionalShadowMap;\n\t\t\tuniforms.directionalShadowMatrix.value = lights.state.directionalShadowMatrix;\n\t\t\tuniforms.spotShadowMap.value = lights.state.spotShadowMap;\n\t\t\tuniforms.spotShadowMatrix.value = lights.state.spotShadowMatrix;\n\t\t\tuniforms.pointShadowMap.value = lights.state.pointShadowMap;\n\t\t\tuniforms.pointShadowMatrix.value = lights.state.pointShadowMatrix;\n\t\t\t// TODO (abelnation): add area lights shadow info to uniforms\n\n\t\t}\n\n\t\tconst progUniforms = program.getUniforms();\n\t\tconst uniformsList = WebGLUniforms.seqWithValue( progUniforms.seq, uniforms );\n\n\t\tmaterialProperties.currentProgram = program;\n\t\tmaterialProperties.uniformsList = uniformsList;\n\n\t\treturn program;\n\n\t}\n\n\tfunction updateCommonMaterialProperties( material, parameters ) {\n\n\t\tconst materialProperties = properties.get( material );\n\n\t\tmaterialProperties.outputEncoding = parameters.outputEncoding;\n\t\tmaterialProperties.instancing = parameters.instancing;\n\t\tmaterialProperties.skinning = parameters.skinning;\n\t\tmaterialProperties.morphTargets = parameters.morphTargets;\n\t\tmaterialProperties.morphNormals = parameters.morphNormals;\n\t\tmaterialProperties.morphColors = parameters.morphColors;\n\t\tmaterialProperties.morphTargetsCount = parameters.morphTargetsCount;\n\t\tmaterialProperties.numClippingPlanes = parameters.numClippingPlanes;\n\t\tmaterialProperties.numIntersection = parameters.numClipIntersection;\n\t\tmaterialProperties.vertexAlphas = parameters.vertexAlphas;\n\t\tmaterialProperties.vertexTangents = parameters.vertexTangents;\n\t\tmaterialProperties.toneMapping = parameters.toneMapping;\n\n\t}\n\n\tfunction setProgram( camera, scene, geometry, material, object ) {\n\n\t\tif ( scene.isScene !== true ) scene = _emptyScene; // scene could be a Mesh, Line, Points, ...\n\n\t\ttextures.resetTextureUnits();\n\n\t\tconst fog = scene.fog;\n\t\tconst environment = material.isMeshStandardMaterial ? scene.environment : null;\n\t\tconst encoding = ( _currentRenderTarget === null ) ? _this.outputEncoding : ( _currentRenderTarget.isXRRenderTarget === true ? _currentRenderTarget.texture.encoding : LinearEncoding );\n\t\tconst envMap = ( material.isMeshStandardMaterial ? cubeuvmaps : cubemaps ).get( material.envMap || environment );\n\t\tconst vertexAlphas = material.vertexColors === true && !! geometry.attributes.color && geometry.attributes.color.itemSize === 4;\n\t\tconst vertexTangents = !! material.normalMap && !! geometry.attributes.tangent;\n\t\tconst morphTargets = !! geometry.morphAttributes.position;\n\t\tconst morphNormals = !! geometry.morphAttributes.normal;\n\t\tconst morphColors = !! geometry.morphAttributes.color;\n\t\tconst toneMapping = material.toneMapped ? _this.toneMapping : NoToneMapping;\n\n\t\tconst morphAttribute = geometry.morphAttributes.position || geometry.morphAttributes.normal || geometry.morphAttributes.color;\n\t\tconst morphTargetsCount = ( morphAttribute !== undefined ) ? morphAttribute.length : 0;\n\n\t\tconst materialProperties = properties.get( material );\n\t\tconst lights = currentRenderState.state.lights;\n\n\t\tif ( _clippingEnabled === true ) {\n\n\t\t\tif ( _localClippingEnabled === true || camera !== _currentCamera ) {\n\n\t\t\t\tconst useCache =\n\t\t\t\t\tcamera === _currentCamera &&\n\t\t\t\t\tmaterial.id === _currentMaterialId;\n\n\t\t\t\t// we might want to call this function with some ClippingGroup\n\t\t\t\t// object instead of the material, once it becomes feasible\n\t\t\t\t// (#8465, #8379)\n\t\t\t\tclipping.setState( material, camera, useCache );\n\n\t\t\t}\n\n\t\t}\n\n\t\t//\n\n\t\tlet needsProgramChange = false;\n\n\t\tif ( material.version === materialProperties.__version ) {\n\n\t\t\tif ( materialProperties.needsLights && ( materialProperties.lightsStateVersion !== lights.state.version ) ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( materialProperties.outputEncoding !== encoding ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( object.isInstancedMesh && materialProperties.instancing === false ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( ! object.isInstancedMesh && materialProperties.instancing === true ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( object.isSkinnedMesh && materialProperties.skinning === false ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( ! object.isSkinnedMesh && materialProperties.skinning === true ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( materialProperties.envMap !== envMap ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( material.fog === true && materialProperties.fog !== fog ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( materialProperties.numClippingPlanes !== undefined &&\n\t\t\t\t( materialProperties.numClippingPlanes !== clipping.numPlanes ||\n\t\t\t\tmaterialProperties.numIntersection !== clipping.numIntersection ) ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( materialProperties.vertexAlphas !== vertexAlphas ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( materialProperties.vertexTangents !== vertexTangents ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( materialProperties.morphTargets !== morphTargets ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( materialProperties.morphNormals !== morphNormals ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( materialProperties.morphColors !== morphColors ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( materialProperties.toneMapping !== toneMapping ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t} else if ( capabilities.isWebGL2 === true && materialProperties.morphTargetsCount !== morphTargetsCount ) {\n\n\t\t\t\tneedsProgramChange = true;\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tneedsProgramChange = true;\n\t\t\tmaterialProperties.__version = material.version;\n\n\t\t}\n\n\t\t//\n\n\t\tlet program = materialProperties.currentProgram;\n\n\t\tif ( needsProgramChange === true ) {\n\n\t\t\tprogram = getProgram( material, scene, object );\n\n\t\t}\n\n\t\tlet refreshProgram = false;\n\t\tlet refreshMaterial = false;\n\t\tlet refreshLights = false;\n\n\t\tconst p_uniforms = program.getUniforms(),\n\t\t\tm_uniforms = materialProperties.uniforms;\n\n\t\tif ( state.useProgram( program.program ) ) {\n\n\t\t\trefreshProgram = true;\n\t\t\trefreshMaterial = true;\n\t\t\trefreshLights = true;\n\n\t\t}\n\n\t\tif ( material.id !== _currentMaterialId ) {\n\n\t\t\t_currentMaterialId = material.id;\n\n\t\t\trefreshMaterial = true;\n\n\t\t}\n\n\t\tif ( refreshProgram || _currentCamera !== camera ) {\n\n\t\t\tp_uniforms.setValue( _gl, 'projectionMatrix', camera.projectionMatrix );\n\n\t\t\tif ( capabilities.logarithmicDepthBuffer ) {\n\n\t\t\t\tp_uniforms.setValue( _gl, 'logDepthBufFC',\n\t\t\t\t\t2.0 / ( Math.log( camera.far + 1.0 ) / Math.LN2 ) );\n\n\t\t\t}\n\n\t\t\tif ( _currentCamera !== camera ) {\n\n\t\t\t\t_currentCamera = camera;\n\n\t\t\t\t// lighting uniforms depend on the camera so enforce an update\n\t\t\t\t// now, in case this material supports lights - or later, when\n\t\t\t\t// the next material that does gets activated:\n\n\t\t\t\trefreshMaterial = true;\t\t// set to true on material change\n\t\t\t\trefreshLights = true;\t\t// remains set until update done\n\n\t\t\t}\n\n\t\t\t// load material specific uniforms\n\t\t\t// (shader material also gets them for the sake of genericity)\n\n\t\t\tif ( material.isShaderMaterial ||\n\t\t\t\tmaterial.isMeshPhongMaterial ||\n\t\t\t\tmaterial.isMeshToonMaterial ||\n\t\t\t\tmaterial.isMeshStandardMaterial ||\n\t\t\t\tmaterial.envMap ) {\n\n\t\t\t\tconst uCamPos = p_uniforms.map.cameraPosition;\n\n\t\t\t\tif ( uCamPos !== undefined ) {\n\n\t\t\t\t\tuCamPos.setValue( _gl,\n\t\t\t\t\t\t_vector3.setFromMatrixPosition( camera.matrixWorld ) );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( material.isMeshPhongMaterial ||\n\t\t\t\tmaterial.isMeshToonMaterial ||\n\t\t\t\tmaterial.isMeshLambertMaterial ||\n\t\t\t\tmaterial.isMeshBasicMaterial ||\n\t\t\t\tmaterial.isMeshStandardMaterial ||\n\t\t\t\tmaterial.isShaderMaterial ) {\n\n\t\t\t\tp_uniforms.setValue( _gl, 'isOrthographic', camera.isOrthographicCamera === true );\n\n\t\t\t}\n\n\t\t\tif ( material.isMeshPhongMaterial ||\n\t\t\t\tmaterial.isMeshToonMaterial ||\n\t\t\t\tmaterial.isMeshLambertMaterial ||\n\t\t\t\tmaterial.isMeshBasicMaterial ||\n\t\t\t\tmaterial.isMeshStandardMaterial ||\n\t\t\t\tmaterial.isShaderMaterial ||\n\t\t\t\tmaterial.isShadowMaterial ||\n\t\t\t\tobject.isSkinnedMesh ) {\n\n\t\t\t\tp_uniforms.setValue( _gl, 'viewMatrix', camera.matrixWorldInverse );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// skinning and morph target uniforms must be set even if material didn't change\n\t\t// auto-setting of texture unit for bone and morph texture must go before other textures\n\t\t// otherwise textures used for skinning and morphing can take over texture units reserved for other material textures\n\n\t\tif ( object.isSkinnedMesh ) {\n\n\t\t\tp_uniforms.setOptional( _gl, object, 'bindMatrix' );\n\t\t\tp_uniforms.setOptional( _gl, object, 'bindMatrixInverse' );\n\n\t\t\tconst skeleton = object.skeleton;\n\n\t\t\tif ( skeleton ) {\n\n\t\t\t\tif ( capabilities.floatVertexTextures ) {\n\n\t\t\t\t\tif ( skeleton.boneTexture === null ) skeleton.computeBoneTexture();\n\n\t\t\t\t\tp_uniforms.setValue( _gl, 'boneTexture', skeleton.boneTexture, textures );\n\t\t\t\t\tp_uniforms.setValue( _gl, 'boneTextureSize', skeleton.boneTextureSize );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: SkinnedMesh can only be used with WebGL 2. With WebGL 1 OES_texture_float and vertex textures support is required.' );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst morphAttributes = geometry.morphAttributes;\n\n\t\tif ( morphAttributes.position !== undefined || morphAttributes.normal !== undefined || ( morphAttributes.color !== undefined && capabilities.isWebGL2 === true ) ) {\n\n\t\t\tmorphtargets.update( object, geometry, material, program );\n\n\t\t}\n\n\n\t\tif ( refreshMaterial || materialProperties.receiveShadow !== object.receiveShadow ) {\n\n\t\t\tmaterialProperties.receiveShadow = object.receiveShadow;\n\t\t\tp_uniforms.setValue( _gl, 'receiveShadow', object.receiveShadow );\n\n\t\t}\n\n\t\tif ( refreshMaterial ) {\n\n\t\t\tp_uniforms.setValue( _gl, 'toneMappingExposure', _this.toneMappingExposure );\n\n\t\t\tif ( materialProperties.needsLights ) {\n\n\t\t\t\t// the current material requires lighting info\n\n\t\t\t\t// note: all lighting uniforms are always set correctly\n\t\t\t\t// they simply reference the renderer's state for their\n\t\t\t\t// values\n\t\t\t\t//\n\t\t\t\t// use the current material's .needsUpdate flags to set\n\t\t\t\t// the GL state when required\n\n\t\t\t\tmarkUniformsLightsNeedsUpdate( m_uniforms, refreshLights );\n\n\t\t\t}\n\n\t\t\t// refresh uniforms common to several materials\n\n\t\t\tif ( fog && material.fog === true ) {\n\n\t\t\t\tmaterials.refreshFogUniforms( m_uniforms, fog );\n\n\t\t\t}\n\n\t\t\tmaterials.refreshMaterialUniforms( m_uniforms, material, _pixelRatio, _height, _transmissionRenderTarget );\n\n\t\t\tWebGLUniforms.upload( _gl, materialProperties.uniformsList, m_uniforms, textures );\n\n\t\t}\n\n\t\tif ( material.isShaderMaterial && material.uniformsNeedUpdate === true ) {\n\n\t\t\tWebGLUniforms.upload( _gl, materialProperties.uniformsList, m_uniforms, textures );\n\t\t\tmaterial.uniformsNeedUpdate = false;\n\n\t\t}\n\n\t\tif ( material.isSpriteMaterial ) {\n\n\t\t\tp_uniforms.setValue( _gl, 'center', object.center );\n\n\t\t}\n\n\t\t// common matrices\n\n\t\tp_uniforms.setValue( _gl, 'modelViewMatrix', object.modelViewMatrix );\n\t\tp_uniforms.setValue( _gl, 'normalMatrix', object.normalMatrix );\n\t\tp_uniforms.setValue( _gl, 'modelMatrix', object.matrixWorld );\n\n\t\treturn program;\n\n\t}\n\n\t// If uniforms are marked as clean, they don't need to be loaded to the GPU.\n\n\tfunction markUniformsLightsNeedsUpdate( uniforms, value ) {\n\n\t\tuniforms.ambientLightColor.needsUpdate = value;\n\t\tuniforms.lightProbe.needsUpdate = value;\n\n\t\tuniforms.directionalLights.needsUpdate = value;\n\t\tuniforms.directionalLightShadows.needsUpdate = value;\n\t\tuniforms.pointLights.needsUpdate = value;\n\t\tuniforms.pointLightShadows.needsUpdate = value;\n\t\tuniforms.spotLights.needsUpdate = value;\n\t\tuniforms.spotLightShadows.needsUpdate = value;\n\t\tuniforms.rectAreaLights.needsUpdate = value;\n\t\tuniforms.hemisphereLights.needsUpdate = value;\n\n\t}\n\n\tfunction materialNeedsLights( material ) {\n\n\t\treturn material.isMeshLambertMaterial || material.isMeshToonMaterial || material.isMeshPhongMaterial ||\n\t\t\tmaterial.isMeshStandardMaterial || material.isShadowMaterial ||\n\t\t\t( material.isShaderMaterial && material.lights === true );\n\n\t}\n\n\tthis.getActiveCubeFace = function () {\n\n\t\treturn _currentActiveCubeFace;\n\n\t};\n\n\tthis.getActiveMipmapLevel = function () {\n\n\t\treturn _currentActiveMipmapLevel;\n\n\t};\n\n\tthis.getRenderTarget = function () {\n\n\t\treturn _currentRenderTarget;\n\n\t};\n\n\tthis.setRenderTargetTextures = function ( renderTarget, colorTexture, depthTexture ) {\n\n\t\tproperties.get( renderTarget.texture ).__webglTexture = colorTexture;\n\t\tproperties.get( renderTarget.depthTexture ).__webglTexture = depthTexture;\n\n\t\tconst renderTargetProperties = properties.get( renderTarget );\n\t\trenderTargetProperties.__hasExternalTextures = true;\n\n\t\tif ( renderTargetProperties.__hasExternalTextures ) {\n\n\t\t\trenderTargetProperties.__autoAllocateDepthBuffer = depthTexture === undefined;\n\n\t\t\tif ( ! renderTargetProperties.__autoAllocateDepthBuffer ) {\n\n\t\t\t\t// The multisample_render_to_texture extension doesn't work properly if there\n\t\t\t\t// are midframe flushes and an external depth buffer. Disable use of the extension.\n\t\t\t\tif ( extensions.has( 'WEBGL_multisampled_render_to_texture' ) === true ) {\n\n\t\t\t\t\tconsole.warn( 'THREE.WebGLRenderer: Render-to-texture extension was disabled because an external texture was provided' );\n\t\t\t\t\trenderTargetProperties.__useRenderToTexture = false;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t};\n\n\tthis.setRenderTargetFramebuffer = function ( renderTarget, defaultFramebuffer ) {\n\n\t\tconst renderTargetProperties = properties.get( renderTarget );\n\t\trenderTargetProperties.__webglFramebuffer = defaultFramebuffer;\n\t\trenderTargetProperties.__useDefaultFramebuffer = defaultFramebuffer === undefined;\n\n\t};\n\n\tthis.setRenderTarget = function ( renderTarget, activeCubeFace = 0, activeMipmapLevel = 0 ) {\n\n\t\t_currentRenderTarget = renderTarget;\n\t\t_currentActiveCubeFace = activeCubeFace;\n\t\t_currentActiveMipmapLevel = activeMipmapLevel;\n\n\t\tlet useDefaultFramebuffer = true;\n\n\t\tif ( renderTarget ) {\n\n\t\t\tconst renderTargetProperties = properties.get( renderTarget );\n\n\t\t\tif ( renderTargetProperties.__useDefaultFramebuffer !== undefined ) {\n\n\t\t\t\t// We need to make sure to rebind the framebuffer.\n\t\t\t\tstate.bindFramebuffer( 36160, null );\n\t\t\t\tuseDefaultFramebuffer = false;\n\n\t\t\t} else if ( renderTargetProperties.__webglFramebuffer === undefined ) {\n\n\t\t\t\ttextures.setupRenderTarget( renderTarget );\n\n\t\t\t} else if ( renderTargetProperties.__hasExternalTextures ) {\n\n\t\t\t\t// Color and depth texture must be rebound in order for the swapchain to update.\n\t\t\t\ttextures.rebindTextures( renderTarget, properties.get( renderTarget.texture ).__webglTexture, properties.get( renderTarget.depthTexture ).__webglTexture );\n\n\t\t\t}\n\n\t\t}\n\n\t\tlet framebuffer = null;\n\t\tlet isCube = false;\n\t\tlet isRenderTarget3D = false;\n\n\t\tif ( renderTarget ) {\n\n\t\t\tconst texture = renderTarget.texture;\n\n\t\t\tif ( texture.isData3DTexture || texture.isDataArrayTexture ) {\n\n\t\t\t\tisRenderTarget3D = true;\n\n\t\t\t}\n\n\t\t\tconst __webglFramebuffer = properties.get( renderTarget ).__webglFramebuffer;\n\n\t\t\tif ( renderTarget.isWebGLCubeRenderTarget ) {\n\n\t\t\t\tframebuffer = __webglFramebuffer[ activeCubeFace ];\n\t\t\t\tisCube = true;\n\n\t\t\t} else if ( ( capabilities.isWebGL2 && renderTarget.samples > 0 ) && textures.useMultisampledRTT( renderTarget ) === false ) {\n\n\t\t\t\tframebuffer = properties.get( renderTarget ).__webglMultisampledFramebuffer;\n\n\t\t\t} else {\n\n\t\t\t\tframebuffer = __webglFramebuffer;\n\n\t\t\t}\n\n\t\t\t_currentViewport.copy( renderTarget.viewport );\n\t\t\t_currentScissor.copy( renderTarget.scissor );\n\t\t\t_currentScissorTest = renderTarget.scissorTest;\n\n\t\t} else {\n\n\t\t\t_currentViewport.copy( _viewport ).multiplyScalar( _pixelRatio ).floor();\n\t\t\t_currentScissor.copy( _scissor ).multiplyScalar( _pixelRatio ).floor();\n\t\t\t_currentScissorTest = _scissorTest;\n\n\t\t}\n\n\t\tconst framebufferBound = state.bindFramebuffer( 36160, framebuffer );\n\n\t\tif ( framebufferBound && capabilities.drawBuffers && useDefaultFramebuffer ) {\n\n\t\t\tstate.drawBuffers( renderTarget, framebuffer );\n\n\t\t}\n\n\t\tstate.viewport( _currentViewport );\n\t\tstate.scissor( _currentScissor );\n\t\tstate.setScissorTest( _currentScissorTest );\n\n\t\tif ( isCube ) {\n\n\t\t\tconst textureProperties = properties.get( renderTarget.texture );\n\t\t\t_gl.framebufferTexture2D( 36160, 36064, 34069 + activeCubeFace, textureProperties.__webglTexture, activeMipmapLevel );\n\n\t\t} else if ( isRenderTarget3D ) {\n\n\t\t\tconst textureProperties = properties.get( renderTarget.texture );\n\t\t\tconst layer = activeCubeFace || 0;\n\t\t\t_gl.framebufferTextureLayer( 36160, 36064, textureProperties.__webglTexture, activeMipmapLevel || 0, layer );\n\n\t\t}\n\n\t\t_currentMaterialId = - 1; // reset current material to ensure correct uniform bindings\n\n\t};\n\n\tthis.readRenderTargetPixels = function ( renderTarget, x, y, width, height, buffer, activeCubeFaceIndex ) {\n\n\t\tif ( ! ( renderTarget && renderTarget.isWebGLRenderTarget ) ) {\n\n\t\t\tconsole.error( 'THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not THREE.WebGLRenderTarget.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tlet framebuffer = properties.get( renderTarget ).__webglFramebuffer;\n\n\t\tif ( renderTarget.isWebGLCubeRenderTarget && activeCubeFaceIndex !== undefined ) {\n\n\t\t\tframebuffer = framebuffer[ activeCubeFaceIndex ];\n\n\t\t}\n\n\t\tif ( framebuffer ) {\n\n\t\t\tstate.bindFramebuffer( 36160, framebuffer );\n\n\t\t\ttry {\n\n\t\t\t\tconst texture = renderTarget.texture;\n\t\t\t\tconst textureFormat = texture.format;\n\t\t\t\tconst textureType = texture.type;\n\n\t\t\t\tif ( textureFormat !== RGBAFormat && utils.convert( textureFormat ) !== _gl.getParameter( 35739 ) ) {\n\n\t\t\t\t\tconsole.error( 'THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in RGBA or implementation defined format.' );\n\t\t\t\t\treturn;\n\n\t\t\t\t}\n\n\t\t\t\tconst halfFloatSupportedByExt = ( textureType === HalfFloatType ) && ( extensions.has( 'EXT_color_buffer_half_float' ) || ( capabilities.isWebGL2 && extensions.has( 'EXT_color_buffer_float' ) ) );\n\n\t\t\t\tif ( textureType !== UnsignedByteType && utils.convert( textureType ) !== _gl.getParameter( 35738 ) && // Edge and Chrome Mac < 52 (#9513)\n\t\t\t\t\t! ( textureType === FloatType && ( capabilities.isWebGL2 || extensions.has( 'OES_texture_float' ) || extensions.has( 'WEBGL_color_buffer_float' ) ) ) && // Chrome Mac >= 52 and Firefox\n\t\t\t\t\t! halfFloatSupportedByExt ) {\n\n\t\t\t\t\tconsole.error( 'THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in UnsignedByteType or implementation defined type.' );\n\t\t\t\t\treturn;\n\n\t\t\t\t}\n\n\t\t\t\t// the following if statement ensures valid read requests (no out-of-bounds pixels, see #8604)\n\n\t\t\t\tif ( ( x >= 0 && x <= ( renderTarget.width - width ) ) && ( y >= 0 && y <= ( renderTarget.height - height ) ) ) {\n\n\t\t\t\t\t_gl.readPixels( x, y, width, height, utils.convert( textureFormat ), utils.convert( textureType ), buffer );\n\n\t\t\t\t}\n\n\t\t\t} finally {\n\n\t\t\t\t// restore framebuffer of current render target if necessary\n\n\t\t\t\tconst framebuffer = ( _currentRenderTarget !== null ) ? properties.get( _currentRenderTarget ).__webglFramebuffer : null;\n\t\t\t\tstate.bindFramebuffer( 36160, framebuffer );\n\n\t\t\t}\n\n\t\t}\n\n\t};\n\n\tthis.copyFramebufferToTexture = function ( position, texture, level = 0 ) {\n\n\t\tconst levelScale = Math.pow( 2, - level );\n\t\tconst width = Math.floor( texture.image.width * levelScale );\n\t\tconst height = Math.floor( texture.image.height * levelScale );\n\n\t\ttextures.setTexture2D( texture, 0 );\n\n\t\t_gl.copyTexSubImage2D( 3553, level, 0, 0, position.x, position.y, width, height );\n\n\t\tstate.unbindTexture();\n\n\t};\n\n\tthis.copyTextureToTexture = function ( position, srcTexture, dstTexture, level = 0 ) {\n\n\t\tconst width = srcTexture.image.width;\n\t\tconst height = srcTexture.image.height;\n\t\tconst glFormat = utils.convert( dstTexture.format );\n\t\tconst glType = utils.convert( dstTexture.type );\n\n\t\ttextures.setTexture2D( dstTexture, 0 );\n\n\t\t// As another texture upload may have changed pixelStorei\n\t\t// parameters, make sure they are correct for the dstTexture\n\t\t_gl.pixelStorei( 37440, dstTexture.flipY );\n\t\t_gl.pixelStorei( 37441, dstTexture.premultiplyAlpha );\n\t\t_gl.pixelStorei( 3317, dstTexture.unpackAlignment );\n\n\t\tif ( srcTexture.isDataTexture ) {\n\n\t\t\t_gl.texSubImage2D( 3553, level, position.x, position.y, width, height, glFormat, glType, srcTexture.image.data );\n\n\t\t} else {\n\n\t\t\tif ( srcTexture.isCompressedTexture ) {\n\n\t\t\t\t_gl.compressedTexSubImage2D( 3553, level, position.x, position.y, srcTexture.mipmaps[ 0 ].width, srcTexture.mipmaps[ 0 ].height, glFormat, srcTexture.mipmaps[ 0 ].data );\n\n\t\t\t} else {\n\n\t\t\t\t_gl.texSubImage2D( 3553, level, position.x, position.y, glFormat, glType, srcTexture.image );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// Generate mipmaps only when copying level 0\n\t\tif ( level === 0 && dstTexture.generateMipmaps ) _gl.generateMipmap( 3553 );\n\n\t\tstate.unbindTexture();\n\n\t};\n\n\tthis.copyTextureToTexture3D = function ( sourceBox, position, srcTexture, dstTexture, level = 0 ) {\n\n\t\tif ( _this.isWebGL1Renderer ) {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer.copyTextureToTexture3D: can only be used with WebGL2.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tconst width = sourceBox.max.x - sourceBox.min.x + 1;\n\t\tconst height = sourceBox.max.y - sourceBox.min.y + 1;\n\t\tconst depth = sourceBox.max.z - sourceBox.min.z + 1;\n\t\tconst glFormat = utils.convert( dstTexture.format );\n\t\tconst glType = utils.convert( dstTexture.type );\n\t\tlet glTarget;\n\n\t\tif ( dstTexture.isData3DTexture ) {\n\n\t\t\ttextures.setTexture3D( dstTexture, 0 );\n\t\t\tglTarget = 32879;\n\n\t\t} else if ( dstTexture.isDataArrayTexture ) {\n\n\t\t\ttextures.setTexture2DArray( dstTexture, 0 );\n\t\t\tglTarget = 35866;\n\n\t\t} else {\n\n\t\t\tconsole.warn( 'THREE.WebGLRenderer.copyTextureToTexture3D: only supports THREE.DataTexture3D and THREE.DataTexture2DArray.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\t_gl.pixelStorei( 37440, dstTexture.flipY );\n\t\t_gl.pixelStorei( 37441, dstTexture.premultiplyAlpha );\n\t\t_gl.pixelStorei( 3317, dstTexture.unpackAlignment );\n\n\t\tconst unpackRowLen = _gl.getParameter( 3314 );\n\t\tconst unpackImageHeight = _gl.getParameter( 32878 );\n\t\tconst unpackSkipPixels = _gl.getParameter( 3316 );\n\t\tconst unpackSkipRows = _gl.getParameter( 3315 );\n\t\tconst unpackSkipImages = _gl.getParameter( 32877 );\n\n\t\tconst image = srcTexture.isCompressedTexture ? srcTexture.mipmaps[ 0 ] : srcTexture.image;\n\n\t\t_gl.pixelStorei( 3314, image.width );\n\t\t_gl.pixelStorei( 32878, image.height );\n\t\t_gl.pixelStorei( 3316, sourceBox.min.x );\n\t\t_gl.pixelStorei( 3315, sourceBox.min.y );\n\t\t_gl.pixelStorei( 32877, sourceBox.min.z );\n\n\t\tif ( srcTexture.isDataTexture || srcTexture.isData3DTexture ) {\n\n\t\t\t_gl.texSubImage3D( glTarget, level, position.x, position.y, position.z, width, height, depth, glFormat, glType, image.data );\n\n\t\t} else {\n\n\t\t\tif ( srcTexture.isCompressedTexture ) {\n\n\t\t\t\tconsole.warn( 'THREE.WebGLRenderer.copyTextureToTexture3D: untested support for compressed srcTexture.' );\n\t\t\t\t_gl.compressedTexSubImage3D( glTarget, level, position.x, position.y, position.z, width, height, depth, glFormat, image.data );\n\n\t\t\t} else {\n\n\t\t\t\t_gl.texSubImage3D( glTarget, level, position.x, position.y, position.z, width, height, depth, glFormat, glType, image );\n\n\t\t\t}\n\n\t\t}\n\n\t\t_gl.pixelStorei( 3314, unpackRowLen );\n\t\t_gl.pixelStorei( 32878, unpackImageHeight );\n\t\t_gl.pixelStorei( 3316, unpackSkipPixels );\n\t\t_gl.pixelStorei( 3315, unpackSkipRows );\n\t\t_gl.pixelStorei( 32877, unpackSkipImages );\n\n\t\t// Generate mipmaps only when copying level 0\n\t\tif ( level === 0 && dstTexture.generateMipmaps ) _gl.generateMipmap( glTarget );\n\n\t\tstate.unbindTexture();\n\n\t};\n\n\tthis.initTexture = function ( texture ) {\n\n\t\ttextures.setTexture2D( texture, 0 );\n\n\t\tstate.unbindTexture();\n\n\t};\n\n\tthis.resetState = function () {\n\n\t\t_currentActiveCubeFace = 0;\n\t\t_currentActiveMipmapLevel = 0;\n\t\t_currentRenderTarget = null;\n\n\t\tstate.reset();\n\t\tbindingStates.reset();\n\n\t};\n\n\tif ( typeof __THREE_DEVTOOLS__ !== 'undefined' ) {\n\n\t\t__THREE_DEVTOOLS__.dispatchEvent( new CustomEvent( 'observe', { detail: this } ) );\n\n\t}\n\n}\n\nclass WebGL1Renderer extends WebGLRenderer {}\n\nWebGL1Renderer.prototype.isWebGL1Renderer = true;\n\nclass FogExp2 {\n\n\tconstructor( color, density = 0.00025 ) {\n\n\t\tthis.isFogExp2 = true;\n\n\t\tthis.name = '';\n\n\t\tthis.color = new Color( color );\n\t\tthis.density = density;\n\n\t}\n\n\tclone() {\n\n\t\treturn new FogExp2( this.color, this.density );\n\n\t}\n\n\ttoJSON( /* meta */ ) {\n\n\t\treturn {\n\t\t\ttype: 'FogExp2',\n\t\t\tcolor: this.color.getHex(),\n\t\t\tdensity: this.density\n\t\t};\n\n\t}\n\n}\n\nclass Fog {\n\n\tconstructor( color, near = 1, far = 1000 ) {\n\n\t\tthis.isFog = true;\n\n\t\tthis.name = '';\n\n\t\tthis.color = new Color( color );\n\n\t\tthis.near = near;\n\t\tthis.far = far;\n\n\t}\n\n\tclone() {\n\n\t\treturn new Fog( this.color, this.near, this.far );\n\n\t}\n\n\ttoJSON( /* meta */ ) {\n\n\t\treturn {\n\t\t\ttype: 'Fog',\n\t\t\tcolor: this.color.getHex(),\n\t\t\tnear: this.near,\n\t\t\tfar: this.far\n\t\t};\n\n\t}\n\n}\n\nclass Scene extends Object3D {\n\n\tconstructor() {\n\n\t\tsuper();\n\n\t\tthis.isScene = true;\n\n\t\tthis.type = 'Scene';\n\n\t\tthis.background = null;\n\t\tthis.environment = null;\n\t\tthis.fog = null;\n\n\t\tthis.overrideMaterial = null;\n\n\t\tthis.autoUpdate = true; // checked by the renderer\n\n\t\tif ( typeof __THREE_DEVTOOLS__ !== 'undefined' ) {\n\n\t\t\t__THREE_DEVTOOLS__.dispatchEvent( new CustomEvent( 'observe', { detail: this } ) );\n\n\t\t}\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tif ( source.background !== null ) this.background = source.background.clone();\n\t\tif ( source.environment !== null ) this.environment = source.environment.clone();\n\t\tif ( source.fog !== null ) this.fog = source.fog.clone();\n\n\t\tif ( source.overrideMaterial !== null ) this.overrideMaterial = source.overrideMaterial.clone();\n\n\t\tthis.autoUpdate = source.autoUpdate;\n\t\tthis.matrixAutoUpdate = source.matrixAutoUpdate;\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON( meta ) {\n\n\t\tconst data = super.toJSON( meta );\n\n\t\tif ( this.fog !== null ) data.object.fog = this.fog.toJSON();\n\n\t\treturn data;\n\n\t}\n\n}\n\nclass InterleavedBuffer {\n\n\tconstructor( array, stride ) {\n\n\t\tthis.isInterleavedBuffer = true;\n\n\t\tthis.array = array;\n\t\tthis.stride = stride;\n\t\tthis.count = array !== undefined ? array.length / stride : 0;\n\n\t\tthis.usage = StaticDrawUsage;\n\t\tthis.updateRange = { offset: 0, count: - 1 };\n\n\t\tthis.version = 0;\n\n\t\tthis.uuid = generateUUID();\n\n\t}\n\n\tonUploadCallback() {}\n\n\tset needsUpdate( value ) {\n\n\t\tif ( value === true ) this.version ++;\n\n\t}\n\n\tsetUsage( value ) {\n\n\t\tthis.usage = value;\n\n\t\treturn this;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tthis.array = new source.array.constructor( source.array );\n\t\tthis.count = source.count;\n\t\tthis.stride = source.stride;\n\t\tthis.usage = source.usage;\n\n\t\treturn this;\n\n\t}\n\n\tcopyAt( index1, attribute, index2 ) {\n\n\t\tindex1 *= this.stride;\n\t\tindex2 *= attribute.stride;\n\n\t\tfor ( let i = 0, l = this.stride; i < l; i ++ ) {\n\n\t\t\tthis.array[ index1 + i ] = attribute.array[ index2 + i ];\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tset( value, offset = 0 ) {\n\n\t\tthis.array.set( value, offset );\n\n\t\treturn this;\n\n\t}\n\n\tclone( data ) {\n\n\t\tif ( data.arrayBuffers === undefined ) {\n\n\t\t\tdata.arrayBuffers = {};\n\n\t\t}\n\n\t\tif ( this.array.buffer._uuid === undefined ) {\n\n\t\t\tthis.array.buffer._uuid = generateUUID();\n\n\t\t}\n\n\t\tif ( data.arrayBuffers[ this.array.buffer._uuid ] === undefined ) {\n\n\t\t\tdata.arrayBuffers[ this.array.buffer._uuid ] = this.array.slice( 0 ).buffer;\n\n\t\t}\n\n\t\tconst array = new this.array.constructor( data.arrayBuffers[ this.array.buffer._uuid ] );\n\n\t\tconst ib = new this.constructor( array, this.stride );\n\t\tib.setUsage( this.usage );\n\n\t\treturn ib;\n\n\t}\n\n\tonUpload( callback ) {\n\n\t\tthis.onUploadCallback = callback;\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON( data ) {\n\n\t\tif ( data.arrayBuffers === undefined ) {\n\n\t\t\tdata.arrayBuffers = {};\n\n\t\t}\n\n\t\t// generate UUID for array buffer if necessary\n\n\t\tif ( this.array.buffer._uuid === undefined ) {\n\n\t\t\tthis.array.buffer._uuid = generateUUID();\n\n\t\t}\n\n\t\tif ( data.arrayBuffers[ this.array.buffer._uuid ] === undefined ) {\n\n\t\t\tdata.arrayBuffers[ this.array.buffer._uuid ] = Array.prototype.slice.call( new Uint32Array( this.array.buffer ) );\n\n\t\t}\n\n\t\t//\n\n\t\treturn {\n\t\t\tuuid: this.uuid,\n\t\t\tbuffer: this.array.buffer._uuid,\n\t\t\ttype: this.array.constructor.name,\n\t\t\tstride: this.stride\n\t\t};\n\n\t}\n\n}\n\nconst _vector$6 = /*@__PURE__*/ new Vector3();\n\nclass InterleavedBufferAttribute {\n\n\tconstructor( interleavedBuffer, itemSize, offset, normalized = false ) {\n\n\t\tthis.isInterleavedBufferAttribute = true;\n\n\t\tthis.name = '';\n\n\t\tthis.data = interleavedBuffer;\n\t\tthis.itemSize = itemSize;\n\t\tthis.offset = offset;\n\n\t\tthis.normalized = normalized === true;\n\n\t}\n\n\tget count() {\n\n\t\treturn this.data.count;\n\n\t}\n\n\tget array() {\n\n\t\treturn this.data.array;\n\n\t}\n\n\tset needsUpdate( value ) {\n\n\t\tthis.data.needsUpdate = value;\n\n\t}\n\n\tapplyMatrix4( m ) {\n\n\t\tfor ( let i = 0, l = this.data.count; i < l; i ++ ) {\n\n\t\t\t_vector$6.fromBufferAttribute( this, i );\n\n\t\t\t_vector$6.applyMatrix4( m );\n\n\t\t\tthis.setXYZ( i, _vector$6.x, _vector$6.y, _vector$6.z );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tapplyNormalMatrix( m ) {\n\n\t\tfor ( let i = 0, l = this.count; i < l; i ++ ) {\n\n\t\t\t_vector$6.fromBufferAttribute( this, i );\n\n\t\t\t_vector$6.applyNormalMatrix( m );\n\n\t\t\tthis.setXYZ( i, _vector$6.x, _vector$6.y, _vector$6.z );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\ttransformDirection( m ) {\n\n\t\tfor ( let i = 0, l = this.count; i < l; i ++ ) {\n\n\t\t\t_vector$6.fromBufferAttribute( this, i );\n\n\t\t\t_vector$6.transformDirection( m );\n\n\t\t\tthis.setXYZ( i, _vector$6.x, _vector$6.y, _vector$6.z );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tsetX( index, x ) {\n\n\t\tthis.data.array[ index * this.data.stride + this.offset ] = x;\n\n\t\treturn this;\n\n\t}\n\n\tsetY( index, y ) {\n\n\t\tthis.data.array[ index * this.data.stride + this.offset + 1 ] = y;\n\n\t\treturn this;\n\n\t}\n\n\tsetZ( index, z ) {\n\n\t\tthis.data.array[ index * this.data.stride + this.offset + 2 ] = z;\n\n\t\treturn this;\n\n\t}\n\n\tsetW( index, w ) {\n\n\t\tthis.data.array[ index * this.data.stride + this.offset + 3 ] = w;\n\n\t\treturn this;\n\n\t}\n\n\tgetX( index ) {\n\n\t\treturn this.data.array[ index * this.data.stride + this.offset ];\n\n\t}\n\n\tgetY( index ) {\n\n\t\treturn this.data.array[ index * this.data.stride + this.offset + 1 ];\n\n\t}\n\n\tgetZ( index ) {\n\n\t\treturn this.data.array[ index * this.data.stride + this.offset + 2 ];\n\n\t}\n\n\tgetW( index ) {\n\n\t\treturn this.data.array[ index * this.data.stride + this.offset + 3 ];\n\n\t}\n\n\tsetXY( index, x, y ) {\n\n\t\tindex = index * this.data.stride + this.offset;\n\n\t\tthis.data.array[ index + 0 ] = x;\n\t\tthis.data.array[ index + 1 ] = y;\n\n\t\treturn this;\n\n\t}\n\n\tsetXYZ( index, x, y, z ) {\n\n\t\tindex = index * this.data.stride + this.offset;\n\n\t\tthis.data.array[ index + 0 ] = x;\n\t\tthis.data.array[ index + 1 ] = y;\n\t\tthis.data.array[ index + 2 ] = z;\n\n\t\treturn this;\n\n\t}\n\n\tsetXYZW( index, x, y, z, w ) {\n\n\t\tindex = index * this.data.stride + this.offset;\n\n\t\tthis.data.array[ index + 0 ] = x;\n\t\tthis.data.array[ index + 1 ] = y;\n\t\tthis.data.array[ index + 2 ] = z;\n\t\tthis.data.array[ index + 3 ] = w;\n\n\t\treturn this;\n\n\t}\n\n\tclone( data ) {\n\n\t\tif ( data === undefined ) {\n\n\t\t\tconsole.log( 'THREE.InterleavedBufferAttribute.clone(): Cloning an interlaved buffer attribute will deinterleave buffer data.' );\n\n\t\t\tconst array = [];\n\n\t\t\tfor ( let i = 0; i < this.count; i ++ ) {\n\n\t\t\t\tconst index = i * this.data.stride + this.offset;\n\n\t\t\t\tfor ( let j = 0; j < this.itemSize; j ++ ) {\n\n\t\t\t\t\tarray.push( this.data.array[ index + j ] );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn new BufferAttribute( new this.array.constructor( array ), this.itemSize, this.normalized );\n\n\t\t} else {\n\n\t\t\tif ( data.interleavedBuffers === undefined ) {\n\n\t\t\t\tdata.interleavedBuffers = {};\n\n\t\t\t}\n\n\t\t\tif ( data.interleavedBuffers[ this.data.uuid ] === undefined ) {\n\n\t\t\t\tdata.interleavedBuffers[ this.data.uuid ] = this.data.clone( data );\n\n\t\t\t}\n\n\t\t\treturn new InterleavedBufferAttribute( data.interleavedBuffers[ this.data.uuid ], this.itemSize, this.offset, this.normalized );\n\n\t\t}\n\n\t}\n\n\ttoJSON( data ) {\n\n\t\tif ( data === undefined ) {\n\n\t\t\tconsole.log( 'THREE.InterleavedBufferAttribute.toJSON(): Serializing an interlaved buffer attribute will deinterleave buffer data.' );\n\n\t\t\tconst array = [];\n\n\t\t\tfor ( let i = 0; i < this.count; i ++ ) {\n\n\t\t\t\tconst index = i * this.data.stride + this.offset;\n\n\t\t\t\tfor ( let j = 0; j < this.itemSize; j ++ ) {\n\n\t\t\t\t\tarray.push( this.data.array[ index + j ] );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// deinterleave data and save it as an ordinary buffer attribute for now\n\n\t\t\treturn {\n\t\t\t\titemSize: this.itemSize,\n\t\t\t\ttype: this.array.constructor.name,\n\t\t\t\tarray: array,\n\t\t\t\tnormalized: this.normalized\n\t\t\t};\n\n\t\t} else {\n\n\t\t\t// save as true interlaved attribtue\n\n\t\t\tif ( data.interleavedBuffers === undefined ) {\n\n\t\t\t\tdata.interleavedBuffers = {};\n\n\t\t\t}\n\n\t\t\tif ( data.interleavedBuffers[ this.data.uuid ] === undefined ) {\n\n\t\t\t\tdata.interleavedBuffers[ this.data.uuid ] = this.data.toJSON( data );\n\n\t\t\t}\n\n\t\t\treturn {\n\t\t\t\tisInterleavedBufferAttribute: true,\n\t\t\t\titemSize: this.itemSize,\n\t\t\t\tdata: this.data.uuid,\n\t\t\t\toffset: this.offset,\n\t\t\t\tnormalized: this.normalized\n\t\t\t};\n\n\t\t}\n\n\t}\n\n}\n\nclass SpriteMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isSpriteMaterial = true;\n\n\t\tthis.type = 'SpriteMaterial';\n\n\t\tthis.color = new Color( 0xffffff );\n\n\t\tthis.map = null;\n\n\t\tthis.alphaMap = null;\n\n\t\tthis.rotation = 0;\n\n\t\tthis.sizeAttenuation = true;\n\n\t\tthis.transparent = true;\n\n\t\tthis.fog = true;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.color.copy( source.color );\n\n\t\tthis.map = source.map;\n\n\t\tthis.alphaMap = source.alphaMap;\n\n\t\tthis.rotation = source.rotation;\n\n\t\tthis.sizeAttenuation = source.sizeAttenuation;\n\n\t\tthis.fog = source.fog;\n\n\t\treturn this;\n\n\t}\n\n}\n\nlet _geometry;\n\nconst _intersectPoint = /*@__PURE__*/ new Vector3();\nconst _worldScale = /*@__PURE__*/ new Vector3();\nconst _mvPosition = /*@__PURE__*/ new Vector3();\n\nconst _alignedPosition = /*@__PURE__*/ new Vector2();\nconst _rotatedPosition = /*@__PURE__*/ new Vector2();\nconst _viewWorldMatrix = /*@__PURE__*/ new Matrix4();\n\nconst _vA = /*@__PURE__*/ new Vector3();\nconst _vB = /*@__PURE__*/ new Vector3();\nconst _vC = /*@__PURE__*/ new Vector3();\n\nconst _uvA = /*@__PURE__*/ new Vector2();\nconst _uvB = /*@__PURE__*/ new Vector2();\nconst _uvC = /*@__PURE__*/ new Vector2();\n\nclass Sprite extends Object3D {\n\n\tconstructor( material ) {\n\n\t\tsuper();\n\n\t\tthis.isSprite = true;\n\n\t\tthis.type = 'Sprite';\n\n\t\tif ( _geometry === undefined ) {\n\n\t\t\t_geometry = new BufferGeometry();\n\n\t\t\tconst float32Array = new Float32Array( [\n\t\t\t\t- 0.5, - 0.5, 0, 0, 0,\n\t\t\t\t0.5, - 0.5, 0, 1, 0,\n\t\t\t\t0.5, 0.5, 0, 1, 1,\n\t\t\t\t- 0.5, 0.5, 0, 0, 1\n\t\t\t] );\n\n\t\t\tconst interleavedBuffer = new InterleavedBuffer( float32Array, 5 );\n\n\t\t\t_geometry.setIndex( [ 0, 1, 2,\t0, 2, 3 ] );\n\t\t\t_geometry.setAttribute( 'position', new InterleavedBufferAttribute( interleavedBuffer, 3, 0, false ) );\n\t\t\t_geometry.setAttribute( 'uv', new InterleavedBufferAttribute( interleavedBuffer, 2, 3, false ) );\n\n\t\t}\n\n\t\tthis.geometry = _geometry;\n\t\tthis.material = ( material !== undefined ) ? material : new SpriteMaterial();\n\n\t\tthis.center = new Vector2( 0.5, 0.5 );\n\n\t}\n\n\traycast( raycaster, intersects ) {\n\n\t\tif ( raycaster.camera === null ) {\n\n\t\t\tconsole.error( 'THREE.Sprite: \"Raycaster.camera\" needs to be set in order to raycast against sprites.' );\n\n\t\t}\n\n\t\t_worldScale.setFromMatrixScale( this.matrixWorld );\n\n\t\t_viewWorldMatrix.copy( raycaster.camera.matrixWorld );\n\t\tthis.modelViewMatrix.multiplyMatrices( raycaster.camera.matrixWorldInverse, this.matrixWorld );\n\n\t\t_mvPosition.setFromMatrixPosition( this.modelViewMatrix );\n\n\t\tif ( raycaster.camera.isPerspectiveCamera && this.material.sizeAttenuation === false ) {\n\n\t\t\t_worldScale.multiplyScalar( - _mvPosition.z );\n\n\t\t}\n\n\t\tconst rotation = this.material.rotation;\n\t\tlet sin, cos;\n\n\t\tif ( rotation !== 0 ) {\n\n\t\t\tcos = Math.cos( rotation );\n\t\t\tsin = Math.sin( rotation );\n\n\t\t}\n\n\t\tconst center = this.center;\n\n\t\ttransformVertex( _vA.set( - 0.5, - 0.5, 0 ), _mvPosition, center, _worldScale, sin, cos );\n\t\ttransformVertex( _vB.set( 0.5, - 0.5, 0 ), _mvPosition, center, _worldScale, sin, cos );\n\t\ttransformVertex( _vC.set( 0.5, 0.5, 0 ), _mvPosition, center, _worldScale, sin, cos );\n\n\t\t_uvA.set( 0, 0 );\n\t\t_uvB.set( 1, 0 );\n\t\t_uvC.set( 1, 1 );\n\n\t\t// check first triangle\n\t\tlet intersect = raycaster.ray.intersectTriangle( _vA, _vB, _vC, false, _intersectPoint );\n\n\t\tif ( intersect === null ) {\n\n\t\t\t// check second triangle\n\t\t\ttransformVertex( _vB.set( - 0.5, 0.5, 0 ), _mvPosition, center, _worldScale, sin, cos );\n\t\t\t_uvB.set( 0, 1 );\n\n\t\t\tintersect = raycaster.ray.intersectTriangle( _vA, _vC, _vB, false, _intersectPoint );\n\t\t\tif ( intersect === null ) {\n\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst distance = raycaster.ray.origin.distanceTo( _intersectPoint );\n\n\t\tif ( distance < raycaster.near || distance > raycaster.far ) return;\n\n\t\tintersects.push( {\n\n\t\t\tdistance: distance,\n\t\t\tpoint: _intersectPoint.clone(),\n\t\t\tuv: Triangle.getUV( _intersectPoint, _vA, _vB, _vC, _uvA, _uvB, _uvC, new Vector2() ),\n\t\t\tface: null,\n\t\t\tobject: this\n\n\t\t} );\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tif ( source.center !== undefined ) this.center.copy( source.center );\n\n\t\tthis.material = source.material;\n\n\t\treturn this;\n\n\t}\n\n}\n\nfunction transformVertex( vertexPosition, mvPosition, center, scale, sin, cos ) {\n\n\t// compute position in camera space\n\t_alignedPosition.subVectors( vertexPosition, center ).addScalar( 0.5 ).multiply( scale );\n\n\t// to check if rotation is not zero\n\tif ( sin !== undefined ) {\n\n\t\t_rotatedPosition.x = ( cos * _alignedPosition.x ) - ( sin * _alignedPosition.y );\n\t\t_rotatedPosition.y = ( sin * _alignedPosition.x ) + ( cos * _alignedPosition.y );\n\n\t} else {\n\n\t\t_rotatedPosition.copy( _alignedPosition );\n\n\t}\n\n\n\tvertexPosition.copy( mvPosition );\n\tvertexPosition.x += _rotatedPosition.x;\n\tvertexPosition.y += _rotatedPosition.y;\n\n\t// transform to world space\n\tvertexPosition.applyMatrix4( _viewWorldMatrix );\n\n}\n\nconst _v1$2 = /*@__PURE__*/ new Vector3();\nconst _v2$1 = /*@__PURE__*/ new Vector3();\n\nclass LOD extends Object3D {\n\n\tconstructor() {\n\n\t\tsuper();\n\n\t\tthis._currentLevel = 0;\n\n\t\tthis.type = 'LOD';\n\n\t\tObject.defineProperties( this, {\n\t\t\tlevels: {\n\t\t\t\tenumerable: true,\n\t\t\t\tvalue: []\n\t\t\t},\n\t\t\tisLOD: {\n\t\t\t\tvalue: true,\n\t\t\t}\n\t\t} );\n\n\t\tthis.autoUpdate = true;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source, false );\n\n\t\tconst levels = source.levels;\n\n\t\tfor ( let i = 0, l = levels.length; i < l; i ++ ) {\n\n\t\t\tconst level = levels[ i ];\n\n\t\t\tthis.addLevel( level.object.clone(), level.distance );\n\n\t\t}\n\n\t\tthis.autoUpdate = source.autoUpdate;\n\n\t\treturn this;\n\n\t}\n\n\taddLevel( object, distance = 0 ) {\n\n\t\tdistance = Math.abs( distance );\n\n\t\tconst levels = this.levels;\n\n\t\tlet l;\n\n\t\tfor ( l = 0; l < levels.length; l ++ ) {\n\n\t\t\tif ( distance < levels[ l ].distance ) {\n\n\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t\tlevels.splice( l, 0, { distance: distance, object: object } );\n\n\t\tthis.add( object );\n\n\t\treturn this;\n\n\t}\n\n\tgetCurrentLevel() {\n\n\t\treturn this._currentLevel;\n\n\t}\n\n\tgetObjectForDistance( distance ) {\n\n\t\tconst levels = this.levels;\n\n\t\tif ( levels.length > 0 ) {\n\n\t\t\tlet i, l;\n\n\t\t\tfor ( i = 1, l = levels.length; i < l; i ++ ) {\n\n\t\t\t\tif ( distance < levels[ i ].distance ) {\n\n\t\t\t\t\tbreak;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn levels[ i - 1 ].object;\n\n\t\t}\n\n\t\treturn null;\n\n\t}\n\n\traycast( raycaster, intersects ) {\n\n\t\tconst levels = this.levels;\n\n\t\tif ( levels.length > 0 ) {\n\n\t\t\t_v1$2.setFromMatrixPosition( this.matrixWorld );\n\n\t\t\tconst distance = raycaster.ray.origin.distanceTo( _v1$2 );\n\n\t\t\tthis.getObjectForDistance( distance ).raycast( raycaster, intersects );\n\n\t\t}\n\n\t}\n\n\tupdate( camera ) {\n\n\t\tconst levels = this.levels;\n\n\t\tif ( levels.length > 1 ) {\n\n\t\t\t_v1$2.setFromMatrixPosition( camera.matrixWorld );\n\t\t\t_v2$1.setFromMatrixPosition( this.matrixWorld );\n\n\t\t\tconst distance = _v1$2.distanceTo( _v2$1 ) / camera.zoom;\n\n\t\t\tlevels[ 0 ].object.visible = true;\n\n\t\t\tlet i, l;\n\n\t\t\tfor ( i = 1, l = levels.length; i < l; i ++ ) {\n\n\t\t\t\tif ( distance >= levels[ i ].distance ) {\n\n\t\t\t\t\tlevels[ i - 1 ].object.visible = false;\n\t\t\t\t\tlevels[ i ].object.visible = true;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tbreak;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis._currentLevel = i - 1;\n\n\t\t\tfor ( ; i < l; i ++ ) {\n\n\t\t\t\tlevels[ i ].object.visible = false;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\ttoJSON( meta ) {\n\n\t\tconst data = super.toJSON( meta );\n\n\t\tif ( this.autoUpdate === false ) data.object.autoUpdate = false;\n\n\t\tdata.object.levels = [];\n\n\t\tconst levels = this.levels;\n\n\t\tfor ( let i = 0, l = levels.length; i < l; i ++ ) {\n\n\t\t\tconst level = levels[ i ];\n\n\t\t\tdata.object.levels.push( {\n\t\t\t\tobject: level.object.uuid,\n\t\t\t\tdistance: level.distance\n\t\t\t} );\n\n\t\t}\n\n\t\treturn data;\n\n\t}\n\n}\n\nconst _basePosition = /*@__PURE__*/ new Vector3();\n\nconst _skinIndex = /*@__PURE__*/ new Vector4();\nconst _skinWeight = /*@__PURE__*/ new Vector4();\n\nconst _vector$5 = /*@__PURE__*/ new Vector3();\nconst _matrix = /*@__PURE__*/ new Matrix4();\n\nclass SkinnedMesh extends Mesh {\n\n\tconstructor( geometry, material ) {\n\n\t\tsuper( geometry, material );\n\n\t\tthis.isSkinnedMesh = true;\n\n\t\tthis.type = 'SkinnedMesh';\n\n\t\tthis.bindMode = 'attached';\n\t\tthis.bindMatrix = new Matrix4();\n\t\tthis.bindMatrixInverse = new Matrix4();\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tthis.bindMode = source.bindMode;\n\t\tthis.bindMatrix.copy( source.bindMatrix );\n\t\tthis.bindMatrixInverse.copy( source.bindMatrixInverse );\n\n\t\tthis.skeleton = source.skeleton;\n\n\t\treturn this;\n\n\t}\n\n\tbind( skeleton, bindMatrix ) {\n\n\t\tthis.skeleton = skeleton;\n\n\t\tif ( bindMatrix === undefined ) {\n\n\t\t\tthis.updateMatrixWorld( true );\n\n\t\t\tthis.skeleton.calculateInverses();\n\n\t\t\tbindMatrix = this.matrixWorld;\n\n\t\t}\n\n\t\tthis.bindMatrix.copy( bindMatrix );\n\t\tthis.bindMatrixInverse.copy( bindMatrix ).invert();\n\n\t}\n\n\tpose() {\n\n\t\tthis.skeleton.pose();\n\n\t}\n\n\tnormalizeSkinWeights() {\n\n\t\tconst vector = new Vector4();\n\n\t\tconst skinWeight = this.geometry.attributes.skinWeight;\n\n\t\tfor ( let i = 0, l = skinWeight.count; i < l; i ++ ) {\n\n\t\t\tvector.fromBufferAttribute( skinWeight, i );\n\n\t\t\tconst scale = 1.0 / vector.manhattanLength();\n\n\t\t\tif ( scale !== Infinity ) {\n\n\t\t\t\tvector.multiplyScalar( scale );\n\n\t\t\t} else {\n\n\t\t\t\tvector.set( 1, 0, 0, 0 ); // do something reasonable\n\n\t\t\t}\n\n\t\t\tskinWeight.setXYZW( i, vector.x, vector.y, vector.z, vector.w );\n\n\t\t}\n\n\t}\n\n\tupdateMatrixWorld( force ) {\n\n\t\tsuper.updateMatrixWorld( force );\n\n\t\tif ( this.bindMode === 'attached' ) {\n\n\t\t\tthis.bindMatrixInverse.copy( this.matrixWorld ).invert();\n\n\t\t} else if ( this.bindMode === 'detached' ) {\n\n\t\t\tthis.bindMatrixInverse.copy( this.bindMatrix ).invert();\n\n\t\t} else {\n\n\t\t\tconsole.warn( 'THREE.SkinnedMesh: Unrecognized bindMode: ' + this.bindMode );\n\n\t\t}\n\n\t}\n\n\tboneTransform( index, target ) {\n\n\t\tconst skeleton = this.skeleton;\n\t\tconst geometry = this.geometry;\n\n\t\t_skinIndex.fromBufferAttribute( geometry.attributes.skinIndex, index );\n\t\t_skinWeight.fromBufferAttribute( geometry.attributes.skinWeight, index );\n\n\t\t_basePosition.copy( target ).applyMatrix4( this.bindMatrix );\n\n\t\ttarget.set( 0, 0, 0 );\n\n\t\tfor ( let i = 0; i < 4; i ++ ) {\n\n\t\t\tconst weight = _skinWeight.getComponent( i );\n\n\t\t\tif ( weight !== 0 ) {\n\n\t\t\t\tconst boneIndex = _skinIndex.getComponent( i );\n\n\t\t\t\t_matrix.multiplyMatrices( skeleton.bones[ boneIndex ].matrixWorld, skeleton.boneInverses[ boneIndex ] );\n\n\t\t\t\ttarget.addScaledVector( _vector$5.copy( _basePosition ).applyMatrix4( _matrix ), weight );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn target.applyMatrix4( this.bindMatrixInverse );\n\n\t}\n\n}\n\nclass Bone extends Object3D {\n\n\tconstructor() {\n\n\t\tsuper();\n\n\t\tthis.isBone = true;\n\n\t\tthis.type = 'Bone';\n\n\t}\n\n}\n\nclass DataTexture extends Texture {\n\n\tconstructor( data = null, width = 1, height = 1, format, type, mapping, wrapS, wrapT, magFilter = NearestFilter, minFilter = NearestFilter, anisotropy, encoding ) {\n\n\t\tsuper( null, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding );\n\n\t\tthis.isDataTexture = true;\n\n\t\tthis.image = { data: data, width: width, height: height };\n\n\t\tthis.generateMipmaps = false;\n\t\tthis.flipY = false;\n\t\tthis.unpackAlignment = 1;\n\n\t}\n\n}\n\nconst _offsetMatrix = /*@__PURE__*/ new Matrix4();\nconst _identityMatrix = /*@__PURE__*/ new Matrix4();\n\nclass Skeleton {\n\n\tconstructor( bones = [], boneInverses = [] ) {\n\n\t\tthis.uuid = generateUUID();\n\n\t\tthis.bones = bones.slice( 0 );\n\t\tthis.boneInverses = boneInverses;\n\t\tthis.boneMatrices = null;\n\n\t\tthis.boneTexture = null;\n\t\tthis.boneTextureSize = 0;\n\n\t\tthis.frame = - 1;\n\n\t\tthis.init();\n\n\t}\n\n\tinit() {\n\n\t\tconst bones = this.bones;\n\t\tconst boneInverses = this.boneInverses;\n\n\t\tthis.boneMatrices = new Float32Array( bones.length * 16 );\n\n\t\t// calculate inverse bone matrices if necessary\n\n\t\tif ( boneInverses.length === 0 ) {\n\n\t\t\tthis.calculateInverses();\n\n\t\t} else {\n\n\t\t\t// handle special case\n\n\t\t\tif ( bones.length !== boneInverses.length ) {\n\n\t\t\t\tconsole.warn( 'THREE.Skeleton: Number of inverse bone matrices does not match amount of bones.' );\n\n\t\t\t\tthis.boneInverses = [];\n\n\t\t\t\tfor ( let i = 0, il = this.bones.length; i < il; i ++ ) {\n\n\t\t\t\t\tthis.boneInverses.push( new Matrix4() );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tcalculateInverses() {\n\n\t\tthis.boneInverses.length = 0;\n\n\t\tfor ( let i = 0, il = this.bones.length; i < il; i ++ ) {\n\n\t\t\tconst inverse = new Matrix4();\n\n\t\t\tif ( this.bones[ i ] ) {\n\n\t\t\t\tinverse.copy( this.bones[ i ].matrixWorld ).invert();\n\n\t\t\t}\n\n\t\t\tthis.boneInverses.push( inverse );\n\n\t\t}\n\n\t}\n\n\tpose() {\n\n\t\t// recover the bind-time world matrices\n\n\t\tfor ( let i = 0, il = this.bones.length; i < il; i ++ ) {\n\n\t\t\tconst bone = this.bones[ i ];\n\n\t\t\tif ( bone ) {\n\n\t\t\t\tbone.matrixWorld.copy( this.boneInverses[ i ] ).invert();\n\n\t\t\t}\n\n\t\t}\n\n\t\t// compute the local matrices, positions, rotations and scales\n\n\t\tfor ( let i = 0, il = this.bones.length; i < il; i ++ ) {\n\n\t\t\tconst bone = this.bones[ i ];\n\n\t\t\tif ( bone ) {\n\n\t\t\t\tif ( bone.parent && bone.parent.isBone ) {\n\n\t\t\t\t\tbone.matrix.copy( bone.parent.matrixWorld ).invert();\n\t\t\t\t\tbone.matrix.multiply( bone.matrixWorld );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tbone.matrix.copy( bone.matrixWorld );\n\n\t\t\t\t}\n\n\t\t\t\tbone.matrix.decompose( bone.position, bone.quaternion, bone.scale );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tupdate() {\n\n\t\tconst bones = this.bones;\n\t\tconst boneInverses = this.boneInverses;\n\t\tconst boneMatrices = this.boneMatrices;\n\t\tconst boneTexture = this.boneTexture;\n\n\t\t// flatten bone matrices to array\n\n\t\tfor ( let i = 0, il = bones.length; i < il; i ++ ) {\n\n\t\t\t// compute the offset between the current and the original transform\n\n\t\t\tconst matrix = bones[ i ] ? bones[ i ].matrixWorld : _identityMatrix;\n\n\t\t\t_offsetMatrix.multiplyMatrices( matrix, boneInverses[ i ] );\n\t\t\t_offsetMatrix.toArray( boneMatrices, i * 16 );\n\n\t\t}\n\n\t\tif ( boneTexture !== null ) {\n\n\t\t\tboneTexture.needsUpdate = true;\n\n\t\t}\n\n\t}\n\n\tclone() {\n\n\t\treturn new Skeleton( this.bones, this.boneInverses );\n\n\t}\n\n\tcomputeBoneTexture() {\n\n\t\t// layout (1 matrix = 4 pixels)\n\t\t// RGBA RGBA RGBA RGBA (=> column1, column2, column3, column4)\n\t\t// with 8x8 pixel texture max 16 bones * 4 pixels = (8 * 8)\n\t\t// 16x16 pixel texture max 64 bones * 4 pixels = (16 * 16)\n\t\t// 32x32 pixel texture max 256 bones * 4 pixels = (32 * 32)\n\t\t// 64x64 pixel texture max 1024 bones * 4 pixels = (64 * 64)\n\n\t\tlet size = Math.sqrt( this.bones.length * 4 ); // 4 pixels needed for 1 matrix\n\t\tsize = ceilPowerOfTwo( size );\n\t\tsize = Math.max( size, 4 );\n\n\t\tconst boneMatrices = new Float32Array( size * size * 4 ); // 4 floats per RGBA pixel\n\t\tboneMatrices.set( this.boneMatrices ); // copy current values\n\n\t\tconst boneTexture = new DataTexture( boneMatrices, size, size, RGBAFormat, FloatType );\n\t\tboneTexture.needsUpdate = true;\n\n\t\tthis.boneMatrices = boneMatrices;\n\t\tthis.boneTexture = boneTexture;\n\t\tthis.boneTextureSize = size;\n\n\t\treturn this;\n\n\t}\n\n\tgetBoneByName( name ) {\n\n\t\tfor ( let i = 0, il = this.bones.length; i < il; i ++ ) {\n\n\t\t\tconst bone = this.bones[ i ];\n\n\t\t\tif ( bone.name === name ) {\n\n\t\t\t\treturn bone;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn undefined;\n\n\t}\n\n\tdispose( ) {\n\n\t\tif ( this.boneTexture !== null ) {\n\n\t\t\tthis.boneTexture.dispose();\n\n\t\t\tthis.boneTexture = null;\n\n\t\t}\n\n\t}\n\n\tfromJSON( json, bones ) {\n\n\t\tthis.uuid = json.uuid;\n\n\t\tfor ( let i = 0, l = json.bones.length; i < l; i ++ ) {\n\n\t\t\tconst uuid = json.bones[ i ];\n\t\t\tlet bone = bones[ uuid ];\n\n\t\t\tif ( bone === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.Skeleton: No bone found with UUID:', uuid );\n\t\t\t\tbone = new Bone();\n\n\t\t\t}\n\n\t\t\tthis.bones.push( bone );\n\t\t\tthis.boneInverses.push( new Matrix4().fromArray( json.boneInverses[ i ] ) );\n\n\t\t}\n\n\t\tthis.init();\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Skeleton',\n\t\t\t\tgenerator: 'Skeleton.toJSON'\n\t\t\t},\n\t\t\tbones: [],\n\t\t\tboneInverses: []\n\t\t};\n\n\t\tdata.uuid = this.uuid;\n\n\t\tconst bones = this.bones;\n\t\tconst boneInverses = this.boneInverses;\n\n\t\tfor ( let i = 0, l = bones.length; i < l; i ++ ) {\n\n\t\t\tconst bone = bones[ i ];\n\t\t\tdata.bones.push( bone.uuid );\n\n\t\t\tconst boneInverse = boneInverses[ i ];\n\t\t\tdata.boneInverses.push( boneInverse.toArray() );\n\n\t\t}\n\n\t\treturn data;\n\n\t}\n\n}\n\nclass InstancedBufferAttribute extends BufferAttribute {\n\n\tconstructor( array, itemSize, normalized, meshPerAttribute = 1 ) {\n\n\t\tif ( typeof normalized === 'number' ) {\n\n\t\t\tmeshPerAttribute = normalized;\n\n\t\t\tnormalized = false;\n\n\t\t\tconsole.error( 'THREE.InstancedBufferAttribute: The constructor now expects normalized as the third argument.' );\n\n\t\t}\n\n\t\tsuper( array, itemSize, normalized );\n\n\t\tthis.isInstancedBufferAttribute = true;\n\n\t\tthis.meshPerAttribute = meshPerAttribute;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.meshPerAttribute = source.meshPerAttribute;\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.meshPerAttribute = this.meshPerAttribute;\n\n\t\tdata.isInstancedBufferAttribute = true;\n\n\t\treturn data;\n\n\t}\n\n}\n\nconst _instanceLocalMatrix = /*@__PURE__*/ new Matrix4();\nconst _instanceWorldMatrix = /*@__PURE__*/ new Matrix4();\n\nconst _instanceIntersects = [];\n\nconst _mesh = /*@__PURE__*/ new Mesh();\n\nclass InstancedMesh extends Mesh {\n\n\tconstructor( geometry, material, count ) {\n\n\t\tsuper( geometry, material );\n\n\t\tthis.isInstancedMesh = true;\n\n\t\tthis.instanceMatrix = new InstancedBufferAttribute( new Float32Array( count * 16 ), 16 );\n\t\tthis.instanceColor = null;\n\n\t\tthis.count = count;\n\n\t\tthis.frustumCulled = false;\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tthis.instanceMatrix.copy( source.instanceMatrix );\n\n\t\tif ( source.instanceColor !== null ) this.instanceColor = source.instanceColor.clone();\n\n\t\tthis.count = source.count;\n\n\t\treturn this;\n\n\t}\n\n\tgetColorAt( index, color ) {\n\n\t\tcolor.fromArray( this.instanceColor.array, index * 3 );\n\n\t}\n\n\tgetMatrixAt( index, matrix ) {\n\n\t\tmatrix.fromArray( this.instanceMatrix.array, index * 16 );\n\n\t}\n\n\traycast( raycaster, intersects ) {\n\n\t\tconst matrixWorld = this.matrixWorld;\n\t\tconst raycastTimes = this.count;\n\n\t\t_mesh.geometry = this.geometry;\n\t\t_mesh.material = this.material;\n\n\t\tif ( _mesh.material === undefined ) return;\n\n\t\tfor ( let instanceId = 0; instanceId < raycastTimes; instanceId ++ ) {\n\n\t\t\t// calculate the world matrix for each instance\n\n\t\t\tthis.getMatrixAt( instanceId, _instanceLocalMatrix );\n\n\t\t\t_instanceWorldMatrix.multiplyMatrices( matrixWorld, _instanceLocalMatrix );\n\n\t\t\t// the mesh represents this single instance\n\n\t\t\t_mesh.matrixWorld = _instanceWorldMatrix;\n\n\t\t\t_mesh.raycast( raycaster, _instanceIntersects );\n\n\t\t\t// process the result of raycast\n\n\t\t\tfor ( let i = 0, l = _instanceIntersects.length; i < l; i ++ ) {\n\n\t\t\t\tconst intersect = _instanceIntersects[ i ];\n\t\t\t\tintersect.instanceId = instanceId;\n\t\t\t\tintersect.object = this;\n\t\t\t\tintersects.push( intersect );\n\n\t\t\t}\n\n\t\t\t_instanceIntersects.length = 0;\n\n\t\t}\n\n\t}\n\n\tsetColorAt( index, color ) {\n\n\t\tif ( this.instanceColor === null ) {\n\n\t\t\tthis.instanceColor = new InstancedBufferAttribute( new Float32Array( this.instanceMatrix.count * 3 ), 3 );\n\n\t\t}\n\n\t\tcolor.toArray( this.instanceColor.array, index * 3 );\n\n\t}\n\n\tsetMatrixAt( index, matrix ) {\n\n\t\tmatrix.toArray( this.instanceMatrix.array, index * 16 );\n\n\t}\n\n\tupdateMorphTargets() {\n\n\t}\n\n\tdispose() {\n\n\t\tthis.dispatchEvent( { type: 'dispose' } );\n\n\t}\n\n}\n\nclass LineBasicMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isLineBasicMaterial = true;\n\n\t\tthis.type = 'LineBasicMaterial';\n\n\t\tthis.color = new Color( 0xffffff );\n\n\t\tthis.linewidth = 1;\n\t\tthis.linecap = 'round';\n\t\tthis.linejoin = 'round';\n\n\t\tthis.fog = true;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.color.copy( source.color );\n\n\t\tthis.linewidth = source.linewidth;\n\t\tthis.linecap = source.linecap;\n\t\tthis.linejoin = source.linejoin;\n\n\t\tthis.fog = source.fog;\n\n\t\treturn this;\n\n\t}\n\n}\n\nconst _start$1 = /*@__PURE__*/ new Vector3();\nconst _end$1 = /*@__PURE__*/ new Vector3();\nconst _inverseMatrix$1 = /*@__PURE__*/ new Matrix4();\nconst _ray$1 = /*@__PURE__*/ new Ray();\nconst _sphere$1 = /*@__PURE__*/ new Sphere();\n\nclass Line extends Object3D {\n\n\tconstructor( geometry = new BufferGeometry(), material = new LineBasicMaterial() ) {\n\n\t\tsuper();\n\n\t\tthis.isLine = true;\n\n\t\tthis.type = 'Line';\n\n\t\tthis.geometry = geometry;\n\t\tthis.material = material;\n\n\t\tthis.updateMorphTargets();\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tthis.material = source.material;\n\t\tthis.geometry = source.geometry;\n\n\t\treturn this;\n\n\t}\n\n\tcomputeLineDistances() {\n\n\t\tconst geometry = this.geometry;\n\n\t\t// we assume non-indexed geometry\n\n\t\tif ( geometry.index === null ) {\n\n\t\t\tconst positionAttribute = geometry.attributes.position;\n\t\t\tconst lineDistances = [ 0 ];\n\n\t\t\tfor ( let i = 1, l = positionAttribute.count; i < l; i ++ ) {\n\n\t\t\t\t_start$1.fromBufferAttribute( positionAttribute, i - 1 );\n\t\t\t\t_end$1.fromBufferAttribute( positionAttribute, i );\n\n\t\t\t\tlineDistances[ i ] = lineDistances[ i - 1 ];\n\t\t\t\tlineDistances[ i ] += _start$1.distanceTo( _end$1 );\n\n\t\t\t}\n\n\t\t\tgeometry.setAttribute( 'lineDistance', new Float32BufferAttribute( lineDistances, 1 ) );\n\n\t\t} else {\n\n\t\t\tconsole.warn( 'THREE.Line.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.' );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\traycast( raycaster, intersects ) {\n\n\t\tconst geometry = this.geometry;\n\t\tconst matrixWorld = this.matrixWorld;\n\t\tconst threshold = raycaster.params.Line.threshold;\n\t\tconst drawRange = geometry.drawRange;\n\n\t\t// Checking boundingSphere distance to ray\n\n\t\tif ( geometry.boundingSphere === null ) geometry.computeBoundingSphere();\n\n\t\t_sphere$1.copy( geometry.boundingSphere );\n\t\t_sphere$1.applyMatrix4( matrixWorld );\n\t\t_sphere$1.radius += threshold;\n\n\t\tif ( raycaster.ray.intersectsSphere( _sphere$1 ) === false ) return;\n\n\t\t//\n\n\t\t_inverseMatrix$1.copy( matrixWorld ).invert();\n\t\t_ray$1.copy( raycaster.ray ).applyMatrix4( _inverseMatrix$1 );\n\n\t\tconst localThreshold = threshold / ( ( this.scale.x + this.scale.y + this.scale.z ) / 3 );\n\t\tconst localThresholdSq = localThreshold * localThreshold;\n\n\t\tconst vStart = new Vector3();\n\t\tconst vEnd = new Vector3();\n\t\tconst interSegment = new Vector3();\n\t\tconst interRay = new Vector3();\n\t\tconst step = this.isLineSegments ? 2 : 1;\n\n\t\tconst index = geometry.index;\n\t\tconst attributes = geometry.attributes;\n\t\tconst positionAttribute = attributes.position;\n\n\t\tif ( index !== null ) {\n\n\t\t\tconst start = Math.max( 0, drawRange.start );\n\t\t\tconst end = Math.min( index.count, ( drawRange.start + drawRange.count ) );\n\n\t\t\tfor ( let i = start, l = end - 1; i < l; i += step ) {\n\n\t\t\t\tconst a = index.getX( i );\n\t\t\t\tconst b = index.getX( i + 1 );\n\n\t\t\t\tvStart.fromBufferAttribute( positionAttribute, a );\n\t\t\t\tvEnd.fromBufferAttribute( positionAttribute, b );\n\n\t\t\t\tconst distSq = _ray$1.distanceSqToSegment( vStart, vEnd, interRay, interSegment );\n\n\t\t\t\tif ( distSq > localThresholdSq ) continue;\n\n\t\t\t\tinterRay.applyMatrix4( this.matrixWorld ); //Move back to world space for distance calculation\n\n\t\t\t\tconst distance = raycaster.ray.origin.distanceTo( interRay );\n\n\t\t\t\tif ( distance < raycaster.near || distance > raycaster.far ) continue;\n\n\t\t\t\tintersects.push( {\n\n\t\t\t\t\tdistance: distance,\n\t\t\t\t\t// What do we want? intersection point on the ray or on the segment??\n\t\t\t\t\t// point: raycaster.ray.at( distance ),\n\t\t\t\t\tpoint: interSegment.clone().applyMatrix4( this.matrixWorld ),\n\t\t\t\t\tindex: i,\n\t\t\t\t\tface: null,\n\t\t\t\t\tfaceIndex: null,\n\t\t\t\t\tobject: this\n\n\t\t\t\t} );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tconst start = Math.max( 0, drawRange.start );\n\t\t\tconst end = Math.min( positionAttribute.count, ( drawRange.start + drawRange.count ) );\n\n\t\t\tfor ( let i = start, l = end - 1; i < l; i += step ) {\n\n\t\t\t\tvStart.fromBufferAttribute( positionAttribute, i );\n\t\t\t\tvEnd.fromBufferAttribute( positionAttribute, i + 1 );\n\n\t\t\t\tconst distSq = _ray$1.distanceSqToSegment( vStart, vEnd, interRay, interSegment );\n\n\t\t\t\tif ( distSq > localThresholdSq ) continue;\n\n\t\t\t\tinterRay.applyMatrix4( this.matrixWorld ); //Move back to world space for distance calculation\n\n\t\t\t\tconst distance = raycaster.ray.origin.distanceTo( interRay );\n\n\t\t\t\tif ( distance < raycaster.near || distance > raycaster.far ) continue;\n\n\t\t\t\tintersects.push( {\n\n\t\t\t\t\tdistance: distance,\n\t\t\t\t\t// What do we want? intersection point on the ray or on the segment??\n\t\t\t\t\t// point: raycaster.ray.at( distance ),\n\t\t\t\t\tpoint: interSegment.clone().applyMatrix4( this.matrixWorld ),\n\t\t\t\t\tindex: i,\n\t\t\t\t\tface: null,\n\t\t\t\t\tfaceIndex: null,\n\t\t\t\t\tobject: this\n\n\t\t\t\t} );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tupdateMorphTargets() {\n\n\t\tconst geometry = this.geometry;\n\n\t\tconst morphAttributes = geometry.morphAttributes;\n\t\tconst keys = Object.keys( morphAttributes );\n\n\t\tif ( keys.length > 0 ) {\n\n\t\t\tconst morphAttribute = morphAttributes[ keys[ 0 ] ];\n\n\t\t\tif ( morphAttribute !== undefined ) {\n\n\t\t\t\tthis.morphTargetInfluences = [];\n\t\t\t\tthis.morphTargetDictionary = {};\n\n\t\t\t\tfor ( let m = 0, ml = morphAttribute.length; m < ml; m ++ ) {\n\n\t\t\t\t\tconst name = morphAttribute[ m ].name || String( m );\n\n\t\t\t\t\tthis.morphTargetInfluences.push( 0 );\n\t\t\t\t\tthis.morphTargetDictionary[ name ] = m;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n}\n\nconst _start = /*@__PURE__*/ new Vector3();\nconst _end = /*@__PURE__*/ new Vector3();\n\nclass LineSegments extends Line {\n\n\tconstructor( geometry, material ) {\n\n\t\tsuper( geometry, material );\n\n\t\tthis.isLineSegments = true;\n\n\t\tthis.type = 'LineSegments';\n\n\t}\n\n\tcomputeLineDistances() {\n\n\t\tconst geometry = this.geometry;\n\n\t\t// we assume non-indexed geometry\n\n\t\tif ( geometry.index === null ) {\n\n\t\t\tconst positionAttribute = geometry.attributes.position;\n\t\t\tconst lineDistances = [];\n\n\t\t\tfor ( let i = 0, l = positionAttribute.count; i < l; i += 2 ) {\n\n\t\t\t\t_start.fromBufferAttribute( positionAttribute, i );\n\t\t\t\t_end.fromBufferAttribute( positionAttribute, i + 1 );\n\n\t\t\t\tlineDistances[ i ] = ( i === 0 ) ? 0 : lineDistances[ i - 1 ];\n\t\t\t\tlineDistances[ i + 1 ] = lineDistances[ i ] + _start.distanceTo( _end );\n\n\t\t\t}\n\n\t\t\tgeometry.setAttribute( 'lineDistance', new Float32BufferAttribute( lineDistances, 1 ) );\n\n\t\t} else {\n\n\t\t\tconsole.warn( 'THREE.LineSegments.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.' );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass LineLoop extends Line {\n\n\tconstructor( geometry, material ) {\n\n\t\tsuper( geometry, material );\n\n\t\tthis.isLineLoop = true;\n\n\t\tthis.type = 'LineLoop';\n\n\t}\n\n}\n\nclass PointsMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isPointsMaterial = true;\n\n\t\tthis.type = 'PointsMaterial';\n\n\t\tthis.color = new Color( 0xffffff );\n\n\t\tthis.map = null;\n\n\t\tthis.alphaMap = null;\n\n\t\tthis.size = 1;\n\t\tthis.sizeAttenuation = true;\n\n\t\tthis.fog = true;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.color.copy( source.color );\n\n\t\tthis.map = source.map;\n\n\t\tthis.alphaMap = source.alphaMap;\n\n\t\tthis.size = source.size;\n\t\tthis.sizeAttenuation = source.sizeAttenuation;\n\n\t\tthis.fog = source.fog;\n\n\t\treturn this;\n\n\t}\n\n}\n\nconst _inverseMatrix = /*@__PURE__*/ new Matrix4();\nconst _ray = /*@__PURE__*/ new Ray();\nconst _sphere = /*@__PURE__*/ new Sphere();\nconst _position$2 = /*@__PURE__*/ new Vector3();\n\nclass Points extends Object3D {\n\n\tconstructor( geometry = new BufferGeometry(), material = new PointsMaterial() ) {\n\n\t\tsuper();\n\n\t\tthis.isPoints = true;\n\n\t\tthis.type = 'Points';\n\n\t\tthis.geometry = geometry;\n\t\tthis.material = material;\n\n\t\tthis.updateMorphTargets();\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tthis.material = source.material;\n\t\tthis.geometry = source.geometry;\n\n\t\treturn this;\n\n\t}\n\n\traycast( raycaster, intersects ) {\n\n\t\tconst geometry = this.geometry;\n\t\tconst matrixWorld = this.matrixWorld;\n\t\tconst threshold = raycaster.params.Points.threshold;\n\t\tconst drawRange = geometry.drawRange;\n\n\t\t// Checking boundingSphere distance to ray\n\n\t\tif ( geometry.boundingSphere === null ) geometry.computeBoundingSphere();\n\n\t\t_sphere.copy( geometry.boundingSphere );\n\t\t_sphere.applyMatrix4( matrixWorld );\n\t\t_sphere.radius += threshold;\n\n\t\tif ( raycaster.ray.intersectsSphere( _sphere ) === false ) return;\n\n\t\t//\n\n\t\t_inverseMatrix.copy( matrixWorld ).invert();\n\t\t_ray.copy( raycaster.ray ).applyMatrix4( _inverseMatrix );\n\n\t\tconst localThreshold = threshold / ( ( this.scale.x + this.scale.y + this.scale.z ) / 3 );\n\t\tconst localThresholdSq = localThreshold * localThreshold;\n\n\t\tconst index = geometry.index;\n\t\tconst attributes = geometry.attributes;\n\t\tconst positionAttribute = attributes.position;\n\n\t\tif ( index !== null ) {\n\n\t\t\tconst start = Math.max( 0, drawRange.start );\n\t\t\tconst end = Math.min( index.count, ( drawRange.start + drawRange.count ) );\n\n\t\t\tfor ( let i = start, il = end; i < il; i ++ ) {\n\n\t\t\t\tconst a = index.getX( i );\n\n\t\t\t\t_position$2.fromBufferAttribute( positionAttribute, a );\n\n\t\t\t\ttestPoint( _position$2, a, localThresholdSq, matrixWorld, raycaster, intersects, this );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tconst start = Math.max( 0, drawRange.start );\n\t\t\tconst end = Math.min( positionAttribute.count, ( drawRange.start + drawRange.count ) );\n\n\t\t\tfor ( let i = start, l = end; i < l; i ++ ) {\n\n\t\t\t\t_position$2.fromBufferAttribute( positionAttribute, i );\n\n\t\t\t\ttestPoint( _position$2, i, localThresholdSq, matrixWorld, raycaster, intersects, this );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tupdateMorphTargets() {\n\n\t\tconst geometry = this.geometry;\n\n\t\tconst morphAttributes = geometry.morphAttributes;\n\t\tconst keys = Object.keys( morphAttributes );\n\n\t\tif ( keys.length > 0 ) {\n\n\t\t\tconst morphAttribute = morphAttributes[ keys[ 0 ] ];\n\n\t\t\tif ( morphAttribute !== undefined ) {\n\n\t\t\t\tthis.morphTargetInfluences = [];\n\t\t\t\tthis.morphTargetDictionary = {};\n\n\t\t\t\tfor ( let m = 0, ml = morphAttribute.length; m < ml; m ++ ) {\n\n\t\t\t\t\tconst name = morphAttribute[ m ].name || String( m );\n\n\t\t\t\t\tthis.morphTargetInfluences.push( 0 );\n\t\t\t\t\tthis.morphTargetDictionary[ name ] = m;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n}\n\nfunction testPoint( point, index, localThresholdSq, matrixWorld, raycaster, intersects, object ) {\n\n\tconst rayPointDistanceSq = _ray.distanceSqToPoint( point );\n\n\tif ( rayPointDistanceSq < localThresholdSq ) {\n\n\t\tconst intersectPoint = new Vector3();\n\n\t\t_ray.closestPointToPoint( point, intersectPoint );\n\t\tintersectPoint.applyMatrix4( matrixWorld );\n\n\t\tconst distance = raycaster.ray.origin.distanceTo( intersectPoint );\n\n\t\tif ( distance < raycaster.near || distance > raycaster.far ) return;\n\n\t\tintersects.push( {\n\n\t\t\tdistance: distance,\n\t\t\tdistanceToRay: Math.sqrt( rayPointDistanceSq ),\n\t\t\tpoint: intersectPoint,\n\t\t\tindex: index,\n\t\t\tface: null,\n\t\t\tobject: object\n\n\t\t} );\n\n\t}\n\n}\n\nclass VideoTexture extends Texture {\n\n\tconstructor( video, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy ) {\n\n\t\tsuper( video, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy );\n\n\t\tthis.isVideoTexture = true;\n\n\t\tthis.minFilter = minFilter !== undefined ? minFilter : LinearFilter;\n\t\tthis.magFilter = magFilter !== undefined ? magFilter : LinearFilter;\n\n\t\tthis.generateMipmaps = false;\n\n\t\tconst scope = this;\n\n\t\tfunction updateVideo() {\n\n\t\t\tscope.needsUpdate = true;\n\t\t\tvideo.requestVideoFrameCallback( updateVideo );\n\n\t\t}\n\n\t\tif ( 'requestVideoFrameCallback' in video ) {\n\n\t\t\tvideo.requestVideoFrameCallback( updateVideo );\n\n\t\t}\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor( this.image ).copy( this );\n\n\t}\n\n\tupdate() {\n\n\t\tconst video = this.image;\n\t\tconst hasVideoFrameCallback = 'requestVideoFrameCallback' in video;\n\n\t\tif ( hasVideoFrameCallback === false && video.readyState >= video.HAVE_CURRENT_DATA ) {\n\n\t\t\tthis.needsUpdate = true;\n\n\t\t}\n\n\t}\n\n}\n\nclass FramebufferTexture extends Texture {\n\n\tconstructor( width, height, format ) {\n\n\t\tsuper( { width, height } );\n\n\t\tthis.isFramebufferTexture = true;\n\n\t\tthis.format = format;\n\n\t\tthis.magFilter = NearestFilter;\n\t\tthis.minFilter = NearestFilter;\n\n\t\tthis.generateMipmaps = false;\n\n\t\tthis.needsUpdate = true;\n\n\t}\n\n}\n\nclass CompressedTexture extends Texture {\n\n\tconstructor( mipmaps, width, height, format, type, mapping, wrapS, wrapT, magFilter, minFilter, anisotropy, encoding ) {\n\n\t\tsuper( null, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy, encoding );\n\n\t\tthis.isCompressedTexture = true;\n\n\t\tthis.image = { width: width, height: height };\n\t\tthis.mipmaps = mipmaps;\n\n\t\t// no flipping for cube textures\n\t\t// (also flipping doesn't work for compressed textures )\n\n\t\tthis.flipY = false;\n\n\t\t// can't generate mipmaps for compressed textures\n\t\t// mips must be embedded in DDS files\n\n\t\tthis.generateMipmaps = false;\n\n\t}\n\n}\n\nclass CanvasTexture extends Texture {\n\n\tconstructor( canvas, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy ) {\n\n\t\tsuper( canvas, mapping, wrapS, wrapT, magFilter, minFilter, format, type, anisotropy );\n\n\t\tthis.isCanvasTexture = true;\n\n\t\tthis.needsUpdate = true;\n\n\t}\n\n}\n\n/**\n * Extensible curve object.\n *\n * Some common of curve methods:\n * .getPoint( t, optionalTarget ), .getTangent( t, optionalTarget )\n * .getPointAt( u, optionalTarget ), .getTangentAt( u, optionalTarget )\n * .getPoints(), .getSpacedPoints()\n * .getLength()\n * .updateArcLengths()\n *\n * This following curves inherit from THREE.Curve:\n *\n * -- 2D curves --\n * THREE.ArcCurve\n * THREE.CubicBezierCurve\n * THREE.EllipseCurve\n * THREE.LineCurve\n * THREE.QuadraticBezierCurve\n * THREE.SplineCurve\n *\n * -- 3D curves --\n * THREE.CatmullRomCurve3\n * THREE.CubicBezierCurve3\n * THREE.LineCurve3\n * THREE.QuadraticBezierCurve3\n *\n * A series of curves can be represented as a THREE.CurvePath.\n *\n **/\n\nclass Curve {\n\n\tconstructor() {\n\n\t\tthis.type = 'Curve';\n\n\t\tthis.arcLengthDivisions = 200;\n\n\t}\n\n\t// Virtual base class method to overwrite and implement in subclasses\n\t//\t- t [0 .. 1]\n\n\tgetPoint( /* t, optionalTarget */ ) {\n\n\t\tconsole.warn( 'THREE.Curve: .getPoint() not implemented.' );\n\t\treturn null;\n\n\t}\n\n\t// Get point at relative position in curve according to arc length\n\t// - u [0 .. 1]\n\n\tgetPointAt( u, optionalTarget ) {\n\n\t\tconst t = this.getUtoTmapping( u );\n\t\treturn this.getPoint( t, optionalTarget );\n\n\t}\n\n\t// Get sequence of points using getPoint( t )\n\n\tgetPoints( divisions = 5 ) {\n\n\t\tconst points = [];\n\n\t\tfor ( let d = 0; d <= divisions; d ++ ) {\n\n\t\t\tpoints.push( this.getPoint( d / divisions ) );\n\n\t\t}\n\n\t\treturn points;\n\n\t}\n\n\t// Get sequence of points using getPointAt( u )\n\n\tgetSpacedPoints( divisions = 5 ) {\n\n\t\tconst points = [];\n\n\t\tfor ( let d = 0; d <= divisions; d ++ ) {\n\n\t\t\tpoints.push( this.getPointAt( d / divisions ) );\n\n\t\t}\n\n\t\treturn points;\n\n\t}\n\n\t// Get total curve arc length\n\n\tgetLength() {\n\n\t\tconst lengths = this.getLengths();\n\t\treturn lengths[ lengths.length - 1 ];\n\n\t}\n\n\t// Get list of cumulative segment lengths\n\n\tgetLengths( divisions = this.arcLengthDivisions ) {\n\n\t\tif ( this.cacheArcLengths &&\n\t\t\t( this.cacheArcLengths.length === divisions + 1 ) &&\n\t\t\t! this.needsUpdate ) {\n\n\t\t\treturn this.cacheArcLengths;\n\n\t\t}\n\n\t\tthis.needsUpdate = false;\n\n\t\tconst cache = [];\n\t\tlet current, last = this.getPoint( 0 );\n\t\tlet sum = 0;\n\n\t\tcache.push( 0 );\n\n\t\tfor ( let p = 1; p <= divisions; p ++ ) {\n\n\t\t\tcurrent = this.getPoint( p / divisions );\n\t\t\tsum += current.distanceTo( last );\n\t\t\tcache.push( sum );\n\t\t\tlast = current;\n\n\t\t}\n\n\t\tthis.cacheArcLengths = cache;\n\n\t\treturn cache; // { sums: cache, sum: sum }; Sum is in the last element.\n\n\t}\n\n\tupdateArcLengths() {\n\n\t\tthis.needsUpdate = true;\n\t\tthis.getLengths();\n\n\t}\n\n\t// Given u ( 0 .. 1 ), get a t to find p. This gives you points which are equidistant\n\n\tgetUtoTmapping( u, distance ) {\n\n\t\tconst arcLengths = this.getLengths();\n\n\t\tlet i = 0;\n\t\tconst il = arcLengths.length;\n\n\t\tlet targetArcLength; // The targeted u distance value to get\n\n\t\tif ( distance ) {\n\n\t\t\ttargetArcLength = distance;\n\n\t\t} else {\n\n\t\t\ttargetArcLength = u * arcLengths[ il - 1 ];\n\n\t\t}\n\n\t\t// binary search for the index with largest value smaller than target u distance\n\n\t\tlet low = 0, high = il - 1, comparison;\n\n\t\twhile ( low <= high ) {\n\n\t\t\ti = Math.floor( low + ( high - low ) / 2 ); // less likely to overflow, though probably not issue here, JS doesn't really have integers, all numbers are floats\n\n\t\t\tcomparison = arcLengths[ i ] - targetArcLength;\n\n\t\t\tif ( comparison < 0 ) {\n\n\t\t\t\tlow = i + 1;\n\n\t\t\t} else if ( comparison > 0 ) {\n\n\t\t\t\thigh = i - 1;\n\n\t\t\t} else {\n\n\t\t\t\thigh = i;\n\t\t\t\tbreak;\n\n\t\t\t\t// DONE\n\n\t\t\t}\n\n\t\t}\n\n\t\ti = high;\n\n\t\tif ( arcLengths[ i ] === targetArcLength ) {\n\n\t\t\treturn i / ( il - 1 );\n\n\t\t}\n\n\t\t// we could get finer grain at lengths, or use simple interpolation between two points\n\n\t\tconst lengthBefore = arcLengths[ i ];\n\t\tconst lengthAfter = arcLengths[ i + 1 ];\n\n\t\tconst segmentLength = lengthAfter - lengthBefore;\n\n\t\t// determine where we are between the 'before' and 'after' points\n\n\t\tconst segmentFraction = ( targetArcLength - lengthBefore ) / segmentLength;\n\n\t\t// add that fractional amount to t\n\n\t\tconst t = ( i + segmentFraction ) / ( il - 1 );\n\n\t\treturn t;\n\n\t}\n\n\t// Returns a unit vector tangent at t\n\t// In case any sub curve does not implement its tangent derivation,\n\t// 2 points a small delta apart will be used to find its gradient\n\t// which seems to give a reasonable approximation\n\n\tgetTangent( t, optionalTarget ) {\n\n\t\tconst delta = 0.0001;\n\t\tlet t1 = t - delta;\n\t\tlet t2 = t + delta;\n\n\t\t// Capping in case of danger\n\n\t\tif ( t1 < 0 ) t1 = 0;\n\t\tif ( t2 > 1 ) t2 = 1;\n\n\t\tconst pt1 = this.getPoint( t1 );\n\t\tconst pt2 = this.getPoint( t2 );\n\n\t\tconst tangent = optionalTarget || ( ( pt1.isVector2 ) ? new Vector2() : new Vector3() );\n\n\t\ttangent.copy( pt2 ).sub( pt1 ).normalize();\n\n\t\treturn tangent;\n\n\t}\n\n\tgetTangentAt( u, optionalTarget ) {\n\n\t\tconst t = this.getUtoTmapping( u );\n\t\treturn this.getTangent( t, optionalTarget );\n\n\t}\n\n\tcomputeFrenetFrames( segments, closed ) {\n\n\t\t// see http://www.cs.indiana.edu/pub/techreports/TR425.pdf\n\n\t\tconst normal = new Vector3();\n\n\t\tconst tangents = [];\n\t\tconst normals = [];\n\t\tconst binormals = [];\n\n\t\tconst vec = new Vector3();\n\t\tconst mat = new Matrix4();\n\n\t\t// compute the tangent vectors for each segment on the curve\n\n\t\tfor ( let i = 0; i <= segments; i ++ ) {\n\n\t\t\tconst u = i / segments;\n\n\t\t\ttangents[ i ] = this.getTangentAt( u, new Vector3() );\n\n\t\t}\n\n\t\t// select an initial normal vector perpendicular to the first tangent vector,\n\t\t// and in the direction of the minimum tangent xyz component\n\n\t\tnormals[ 0 ] = new Vector3();\n\t\tbinormals[ 0 ] = new Vector3();\n\t\tlet min = Number.MAX_VALUE;\n\t\tconst tx = Math.abs( tangents[ 0 ].x );\n\t\tconst ty = Math.abs( tangents[ 0 ].y );\n\t\tconst tz = Math.abs( tangents[ 0 ].z );\n\n\t\tif ( tx <= min ) {\n\n\t\t\tmin = tx;\n\t\t\tnormal.set( 1, 0, 0 );\n\n\t\t}\n\n\t\tif ( ty <= min ) {\n\n\t\t\tmin = ty;\n\t\t\tnormal.set( 0, 1, 0 );\n\n\t\t}\n\n\t\tif ( tz <= min ) {\n\n\t\t\tnormal.set( 0, 0, 1 );\n\n\t\t}\n\n\t\tvec.crossVectors( tangents[ 0 ], normal ).normalize();\n\n\t\tnormals[ 0 ].crossVectors( tangents[ 0 ], vec );\n\t\tbinormals[ 0 ].crossVectors( tangents[ 0 ], normals[ 0 ] );\n\n\n\t\t// compute the slowly-varying normal and binormal vectors for each segment on the curve\n\n\t\tfor ( let i = 1; i <= segments; i ++ ) {\n\n\t\t\tnormals[ i ] = normals[ i - 1 ].clone();\n\n\t\t\tbinormals[ i ] = binormals[ i - 1 ].clone();\n\n\t\t\tvec.crossVectors( tangents[ i - 1 ], tangents[ i ] );\n\n\t\t\tif ( vec.length() > Number.EPSILON ) {\n\n\t\t\t\tvec.normalize();\n\n\t\t\t\tconst theta = Math.acos( clamp( tangents[ i - 1 ].dot( tangents[ i ] ), - 1, 1 ) ); // clamp for floating pt errors\n\n\t\t\t\tnormals[ i ].applyMatrix4( mat.makeRotationAxis( vec, theta ) );\n\n\t\t\t}\n\n\t\t\tbinormals[ i ].crossVectors( tangents[ i ], normals[ i ] );\n\n\t\t}\n\n\t\t// if the curve is closed, postprocess the vectors so the first and last normal vectors are the same\n\n\t\tif ( closed === true ) {\n\n\t\t\tlet theta = Math.acos( clamp( normals[ 0 ].dot( normals[ segments ] ), - 1, 1 ) );\n\t\t\ttheta /= segments;\n\n\t\t\tif ( tangents[ 0 ].dot( vec.crossVectors( normals[ 0 ], normals[ segments ] ) ) > 0 ) {\n\n\t\t\t\ttheta = - theta;\n\n\t\t\t}\n\n\t\t\tfor ( let i = 1; i <= segments; i ++ ) {\n\n\t\t\t\t// twist a little...\n\t\t\t\tnormals[ i ].applyMatrix4( mat.makeRotationAxis( tangents[ i ], theta * i ) );\n\t\t\t\tbinormals[ i ].crossVectors( tangents[ i ], normals[ i ] );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn {\n\t\t\ttangents: tangents,\n\t\t\tnormals: normals,\n\t\t\tbinormals: binormals\n\t\t};\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tthis.arcLengthDivisions = source.arcLengthDivisions;\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = {\n\t\t\tmetadata: {\n\t\t\t\tversion: 4.5,\n\t\t\t\ttype: 'Curve',\n\t\t\t\tgenerator: 'Curve.toJSON'\n\t\t\t}\n\t\t};\n\n\t\tdata.arcLengthDivisions = this.arcLengthDivisions;\n\t\tdata.type = this.type;\n\n\t\treturn data;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tthis.arcLengthDivisions = json.arcLengthDivisions;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass EllipseCurve extends Curve {\n\n\tconstructor( aX = 0, aY = 0, xRadius = 1, yRadius = 1, aStartAngle = 0, aEndAngle = Math.PI * 2, aClockwise = false, aRotation = 0 ) {\n\n\t\tsuper();\n\n\t\tthis.isEllipseCurve = true;\n\n\t\tthis.type = 'EllipseCurve';\n\n\t\tthis.aX = aX;\n\t\tthis.aY = aY;\n\n\t\tthis.xRadius = xRadius;\n\t\tthis.yRadius = yRadius;\n\n\t\tthis.aStartAngle = aStartAngle;\n\t\tthis.aEndAngle = aEndAngle;\n\n\t\tthis.aClockwise = aClockwise;\n\n\t\tthis.aRotation = aRotation;\n\n\t}\n\n\tgetPoint( t, optionalTarget ) {\n\n\t\tconst point = optionalTarget || new Vector2();\n\n\t\tconst twoPi = Math.PI * 2;\n\t\tlet deltaAngle = this.aEndAngle - this.aStartAngle;\n\t\tconst samePoints = Math.abs( deltaAngle ) < Number.EPSILON;\n\n\t\t// ensures that deltaAngle is 0 .. 2 PI\n\t\twhile ( deltaAngle < 0 ) deltaAngle += twoPi;\n\t\twhile ( deltaAngle > twoPi ) deltaAngle -= twoPi;\n\n\t\tif ( deltaAngle < Number.EPSILON ) {\n\n\t\t\tif ( samePoints ) {\n\n\t\t\t\tdeltaAngle = 0;\n\n\t\t\t} else {\n\n\t\t\t\tdeltaAngle = twoPi;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( this.aClockwise === true && ! samePoints ) {\n\n\t\t\tif ( deltaAngle === twoPi ) {\n\n\t\t\t\tdeltaAngle = - twoPi;\n\n\t\t\t} else {\n\n\t\t\t\tdeltaAngle = deltaAngle - twoPi;\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst angle = this.aStartAngle + t * deltaAngle;\n\t\tlet x = this.aX + this.xRadius * Math.cos( angle );\n\t\tlet y = this.aY + this.yRadius * Math.sin( angle );\n\n\t\tif ( this.aRotation !== 0 ) {\n\n\t\t\tconst cos = Math.cos( this.aRotation );\n\t\t\tconst sin = Math.sin( this.aRotation );\n\n\t\t\tconst tx = x - this.aX;\n\t\t\tconst ty = y - this.aY;\n\n\t\t\t// Rotate the point about the center of the ellipse.\n\t\t\tx = tx * cos - ty * sin + this.aX;\n\t\t\ty = tx * sin + ty * cos + this.aY;\n\n\t\t}\n\n\t\treturn point.set( x, y );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.aX = source.aX;\n\t\tthis.aY = source.aY;\n\n\t\tthis.xRadius = source.xRadius;\n\t\tthis.yRadius = source.yRadius;\n\n\t\tthis.aStartAngle = source.aStartAngle;\n\t\tthis.aEndAngle = source.aEndAngle;\n\n\t\tthis.aClockwise = source.aClockwise;\n\n\t\tthis.aRotation = source.aRotation;\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.aX = this.aX;\n\t\tdata.aY = this.aY;\n\n\t\tdata.xRadius = this.xRadius;\n\t\tdata.yRadius = this.yRadius;\n\n\t\tdata.aStartAngle = this.aStartAngle;\n\t\tdata.aEndAngle = this.aEndAngle;\n\n\t\tdata.aClockwise = this.aClockwise;\n\n\t\tdata.aRotation = this.aRotation;\n\n\t\treturn data;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tsuper.fromJSON( json );\n\n\t\tthis.aX = json.aX;\n\t\tthis.aY = json.aY;\n\n\t\tthis.xRadius = json.xRadius;\n\t\tthis.yRadius = json.yRadius;\n\n\t\tthis.aStartAngle = json.aStartAngle;\n\t\tthis.aEndAngle = json.aEndAngle;\n\n\t\tthis.aClockwise = json.aClockwise;\n\n\t\tthis.aRotation = json.aRotation;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass ArcCurve extends EllipseCurve {\n\n\tconstructor( aX, aY, aRadius, aStartAngle, aEndAngle, aClockwise ) {\n\n\t\tsuper( aX, aY, aRadius, aRadius, aStartAngle, aEndAngle, aClockwise );\n\n\t\tthis.isArcCurve = true;\n\n\t\tthis.type = 'ArcCurve';\n\n\t}\n\n}\n\n/**\n * Centripetal CatmullRom Curve - which is useful for avoiding\n * cusps and self-intersections in non-uniform catmull rom curves.\n * http://www.cemyuksel.com/research/catmullrom_param/catmullrom.pdf\n *\n * curve.type accepts centripetal(default), chordal and catmullrom\n * curve.tension is used for catmullrom which defaults to 0.5\n */\n\n\n/*\nBased on an optimized c++ solution in\n - http://stackoverflow.com/questions/9489736/catmull-rom-curve-with-no-cusps-and-no-self-intersections/\n - http://ideone.com/NoEbVM\n\nThis CubicPoly class could be used for reusing some variables and calculations,\nbut for three.js curve use, it could be possible inlined and flatten into a single function call\nwhich can be placed in CurveUtils.\n*/\n\nfunction CubicPoly() {\n\n\tlet c0 = 0, c1 = 0, c2 = 0, c3 = 0;\n\n\t/*\n\t * Compute coefficients for a cubic polynomial\n\t * p(s) = c0 + c1*s + c2*s^2 + c3*s^3\n\t * such that\n\t * p(0) = x0, p(1) = x1\n\t * and\n\t * p'(0) = t0, p'(1) = t1.\n\t */\n\tfunction init( x0, x1, t0, t1 ) {\n\n\t\tc0 = x0;\n\t\tc1 = t0;\n\t\tc2 = - 3 * x0 + 3 * x1 - 2 * t0 - t1;\n\t\tc3 = 2 * x0 - 2 * x1 + t0 + t1;\n\n\t}\n\n\treturn {\n\n\t\tinitCatmullRom: function ( x0, x1, x2, x3, tension ) {\n\n\t\t\tinit( x1, x2, tension * ( x2 - x0 ), tension * ( x3 - x1 ) );\n\n\t\t},\n\n\t\tinitNonuniformCatmullRom: function ( x0, x1, x2, x3, dt0, dt1, dt2 ) {\n\n\t\t\t// compute tangents when parameterized in [t1,t2]\n\t\t\tlet t1 = ( x1 - x0 ) / dt0 - ( x2 - x0 ) / ( dt0 + dt1 ) + ( x2 - x1 ) / dt1;\n\t\t\tlet t2 = ( x2 - x1 ) / dt1 - ( x3 - x1 ) / ( dt1 + dt2 ) + ( x3 - x2 ) / dt2;\n\n\t\t\t// rescale tangents for parametrization in [0,1]\n\t\t\tt1 *= dt1;\n\t\t\tt2 *= dt1;\n\n\t\t\tinit( x1, x2, t1, t2 );\n\n\t\t},\n\n\t\tcalc: function ( t ) {\n\n\t\t\tconst t2 = t * t;\n\t\t\tconst t3 = t2 * t;\n\t\t\treturn c0 + c1 * t + c2 * t2 + c3 * t3;\n\n\t\t}\n\n\t};\n\n}\n\n//\n\nconst tmp = new Vector3();\nconst px = new CubicPoly(), py = new CubicPoly(), pz = new CubicPoly();\n\nclass CatmullRomCurve3 extends Curve {\n\n\tconstructor( points = [], closed = false, curveType = 'centripetal', tension = 0.5 ) {\n\n\t\tsuper();\n\n\t\tthis.isCatmullRomCurve3 = true;\n\n\t\tthis.type = 'CatmullRomCurve3';\n\n\t\tthis.points = points;\n\t\tthis.closed = closed;\n\t\tthis.curveType = curveType;\n\t\tthis.tension = tension;\n\n\t}\n\n\tgetPoint( t, optionalTarget = new Vector3() ) {\n\n\t\tconst point = optionalTarget;\n\n\t\tconst points = this.points;\n\t\tconst l = points.length;\n\n\t\tconst p = ( l - ( this.closed ? 0 : 1 ) ) * t;\n\t\tlet intPoint = Math.floor( p );\n\t\tlet weight = p - intPoint;\n\n\t\tif ( this.closed ) {\n\n\t\t\tintPoint += intPoint > 0 ? 0 : ( Math.floor( Math.abs( intPoint ) / l ) + 1 ) * l;\n\n\t\t} else if ( weight === 0 && intPoint === l - 1 ) {\n\n\t\t\tintPoint = l - 2;\n\t\t\tweight = 1;\n\n\t\t}\n\n\t\tlet p0, p3; // 4 points (p1 & p2 defined below)\n\n\t\tif ( this.closed || intPoint > 0 ) {\n\n\t\t\tp0 = points[ ( intPoint - 1 ) % l ];\n\n\t\t} else {\n\n\t\t\t// extrapolate first point\n\t\t\ttmp.subVectors( points[ 0 ], points[ 1 ] ).add( points[ 0 ] );\n\t\t\tp0 = tmp;\n\n\t\t}\n\n\t\tconst p1 = points[ intPoint % l ];\n\t\tconst p2 = points[ ( intPoint + 1 ) % l ];\n\n\t\tif ( this.closed || intPoint + 2 < l ) {\n\n\t\t\tp3 = points[ ( intPoint + 2 ) % l ];\n\n\t\t} else {\n\n\t\t\t// extrapolate last point\n\t\t\ttmp.subVectors( points[ l - 1 ], points[ l - 2 ] ).add( points[ l - 1 ] );\n\t\t\tp3 = tmp;\n\n\t\t}\n\n\t\tif ( this.curveType === 'centripetal' || this.curveType === 'chordal' ) {\n\n\t\t\t// init Centripetal / Chordal Catmull-Rom\n\t\t\tconst pow = this.curveType === 'chordal' ? 0.5 : 0.25;\n\t\t\tlet dt0 = Math.pow( p0.distanceToSquared( p1 ), pow );\n\t\t\tlet dt1 = Math.pow( p1.distanceToSquared( p2 ), pow );\n\t\t\tlet dt2 = Math.pow( p2.distanceToSquared( p3 ), pow );\n\n\t\t\t// safety check for repeated points\n\t\t\tif ( dt1 < 1e-4 ) dt1 = 1.0;\n\t\t\tif ( dt0 < 1e-4 ) dt0 = dt1;\n\t\t\tif ( dt2 < 1e-4 ) dt2 = dt1;\n\n\t\t\tpx.initNonuniformCatmullRom( p0.x, p1.x, p2.x, p3.x, dt0, dt1, dt2 );\n\t\t\tpy.initNonuniformCatmullRom( p0.y, p1.y, p2.y, p3.y, dt0, dt1, dt2 );\n\t\t\tpz.initNonuniformCatmullRom( p0.z, p1.z, p2.z, p3.z, dt0, dt1, dt2 );\n\n\t\t} else if ( this.curveType === 'catmullrom' ) {\n\n\t\t\tpx.initCatmullRom( p0.x, p1.x, p2.x, p3.x, this.tension );\n\t\t\tpy.initCatmullRom( p0.y, p1.y, p2.y, p3.y, this.tension );\n\t\t\tpz.initCatmullRom( p0.z, p1.z, p2.z, p3.z, this.tension );\n\n\t\t}\n\n\t\tpoint.set(\n\t\t\tpx.calc( weight ),\n\t\t\tpy.calc( weight ),\n\t\t\tpz.calc( weight )\n\t\t);\n\n\t\treturn point;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.points = [];\n\n\t\tfor ( let i = 0, l = source.points.length; i < l; i ++ ) {\n\n\t\t\tconst point = source.points[ i ];\n\n\t\t\tthis.points.push( point.clone() );\n\n\t\t}\n\n\t\tthis.closed = source.closed;\n\t\tthis.curveType = source.curveType;\n\t\tthis.tension = source.tension;\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.points = [];\n\n\t\tfor ( let i = 0, l = this.points.length; i < l; i ++ ) {\n\n\t\t\tconst point = this.points[ i ];\n\t\t\tdata.points.push( point.toArray() );\n\n\t\t}\n\n\t\tdata.closed = this.closed;\n\t\tdata.curveType = this.curveType;\n\t\tdata.tension = this.tension;\n\n\t\treturn data;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tsuper.fromJSON( json );\n\n\t\tthis.points = [];\n\n\t\tfor ( let i = 0, l = json.points.length; i < l; i ++ ) {\n\n\t\t\tconst point = json.points[ i ];\n\t\t\tthis.points.push( new Vector3().fromArray( point ) );\n\n\t\t}\n\n\t\tthis.closed = json.closed;\n\t\tthis.curveType = json.curveType;\n\t\tthis.tension = json.tension;\n\n\t\treturn this;\n\n\t}\n\n}\n\n/**\n * Bezier Curves formulas obtained from\n * https://en.wikipedia.org/wiki/B%C3%A9zier_curve\n */\n\nfunction CatmullRom( t, p0, p1, p2, p3 ) {\n\n\tconst v0 = ( p2 - p0 ) * 0.5;\n\tconst v1 = ( p3 - p1 ) * 0.5;\n\tconst t2 = t * t;\n\tconst t3 = t * t2;\n\treturn ( 2 * p1 - 2 * p2 + v0 + v1 ) * t3 + ( - 3 * p1 + 3 * p2 - 2 * v0 - v1 ) * t2 + v0 * t + p1;\n\n}\n\n//\n\nfunction QuadraticBezierP0( t, p ) {\n\n\tconst k = 1 - t;\n\treturn k * k * p;\n\n}\n\nfunction QuadraticBezierP1( t, p ) {\n\n\treturn 2 * ( 1 - t ) * t * p;\n\n}\n\nfunction QuadraticBezierP2( t, p ) {\n\n\treturn t * t * p;\n\n}\n\nfunction QuadraticBezier( t, p0, p1, p2 ) {\n\n\treturn QuadraticBezierP0( t, p0 ) + QuadraticBezierP1( t, p1 ) +\n\t\tQuadraticBezierP2( t, p2 );\n\n}\n\n//\n\nfunction CubicBezierP0( t, p ) {\n\n\tconst k = 1 - t;\n\treturn k * k * k * p;\n\n}\n\nfunction CubicBezierP1( t, p ) {\n\n\tconst k = 1 - t;\n\treturn 3 * k * k * t * p;\n\n}\n\nfunction CubicBezierP2( t, p ) {\n\n\treturn 3 * ( 1 - t ) * t * t * p;\n\n}\n\nfunction CubicBezierP3( t, p ) {\n\n\treturn t * t * t * p;\n\n}\n\nfunction CubicBezier( t, p0, p1, p2, p3 ) {\n\n\treturn CubicBezierP0( t, p0 ) + CubicBezierP1( t, p1 ) + CubicBezierP2( t, p2 ) +\n\t\tCubicBezierP3( t, p3 );\n\n}\n\nclass CubicBezierCurve extends Curve {\n\n\tconstructor( v0 = new Vector2(), v1 = new Vector2(), v2 = new Vector2(), v3 = new Vector2() ) {\n\n\t\tsuper();\n\n\t\tthis.isCubicBezierCurve = true;\n\n\t\tthis.type = 'CubicBezierCurve';\n\n\t\tthis.v0 = v0;\n\t\tthis.v1 = v1;\n\t\tthis.v2 = v2;\n\t\tthis.v3 = v3;\n\n\t}\n\n\tgetPoint( t, optionalTarget = new Vector2() ) {\n\n\t\tconst point = optionalTarget;\n\n\t\tconst v0 = this.v0, v1 = this.v1, v2 = this.v2, v3 = this.v3;\n\n\t\tpoint.set(\n\t\t\tCubicBezier( t, v0.x, v1.x, v2.x, v3.x ),\n\t\t\tCubicBezier( t, v0.y, v1.y, v2.y, v3.y )\n\t\t);\n\n\t\treturn point;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.v0.copy( source.v0 );\n\t\tthis.v1.copy( source.v1 );\n\t\tthis.v2.copy( source.v2 );\n\t\tthis.v3.copy( source.v3 );\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.v0 = this.v0.toArray();\n\t\tdata.v1 = this.v1.toArray();\n\t\tdata.v2 = this.v2.toArray();\n\t\tdata.v3 = this.v3.toArray();\n\n\t\treturn data;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tsuper.fromJSON( json );\n\n\t\tthis.v0.fromArray( json.v0 );\n\t\tthis.v1.fromArray( json.v1 );\n\t\tthis.v2.fromArray( json.v2 );\n\t\tthis.v3.fromArray( json.v3 );\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass CubicBezierCurve3 extends Curve {\n\n\tconstructor( v0 = new Vector3(), v1 = new Vector3(), v2 = new Vector3(), v3 = new Vector3() ) {\n\n\t\tsuper();\n\n\t\tthis.isCubicBezierCurve3 = true;\n\n\t\tthis.type = 'CubicBezierCurve3';\n\n\t\tthis.v0 = v0;\n\t\tthis.v1 = v1;\n\t\tthis.v2 = v2;\n\t\tthis.v3 = v3;\n\n\t}\n\n\tgetPoint( t, optionalTarget = new Vector3() ) {\n\n\t\tconst point = optionalTarget;\n\n\t\tconst v0 = this.v0, v1 = this.v1, v2 = this.v2, v3 = this.v3;\n\n\t\tpoint.set(\n\t\t\tCubicBezier( t, v0.x, v1.x, v2.x, v3.x ),\n\t\t\tCubicBezier( t, v0.y, v1.y, v2.y, v3.y ),\n\t\t\tCubicBezier( t, v0.z, v1.z, v2.z, v3.z )\n\t\t);\n\n\t\treturn point;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.v0.copy( source.v0 );\n\t\tthis.v1.copy( source.v1 );\n\t\tthis.v2.copy( source.v2 );\n\t\tthis.v3.copy( source.v3 );\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.v0 = this.v0.toArray();\n\t\tdata.v1 = this.v1.toArray();\n\t\tdata.v2 = this.v2.toArray();\n\t\tdata.v3 = this.v3.toArray();\n\n\t\treturn data;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tsuper.fromJSON( json );\n\n\t\tthis.v0.fromArray( json.v0 );\n\t\tthis.v1.fromArray( json.v1 );\n\t\tthis.v2.fromArray( json.v2 );\n\t\tthis.v3.fromArray( json.v3 );\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass LineCurve extends Curve {\n\n\tconstructor( v1 = new Vector2(), v2 = new Vector2() ) {\n\n\t\tsuper();\n\n\t\tthis.isLineCurve = true;\n\n\t\tthis.type = 'LineCurve';\n\n\t\tthis.v1 = v1;\n\t\tthis.v2 = v2;\n\n\t}\n\n\tgetPoint( t, optionalTarget = new Vector2() ) {\n\n\t\tconst point = optionalTarget;\n\n\t\tif ( t === 1 ) {\n\n\t\t\tpoint.copy( this.v2 );\n\n\t\t} else {\n\n\t\t\tpoint.copy( this.v2 ).sub( this.v1 );\n\t\t\tpoint.multiplyScalar( t ).add( this.v1 );\n\n\t\t}\n\n\t\treturn point;\n\n\t}\n\n\t// Line curve is linear, so we can overwrite default getPointAt\n\tgetPointAt( u, optionalTarget ) {\n\n\t\treturn this.getPoint( u, optionalTarget );\n\n\t}\n\n\tgetTangent( t, optionalTarget ) {\n\n\t\tconst tangent = optionalTarget || new Vector2();\n\n\t\ttangent.copy( this.v2 ).sub( this.v1 ).normalize();\n\n\t\treturn tangent;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.v1.copy( source.v1 );\n\t\tthis.v2.copy( source.v2 );\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.v1 = this.v1.toArray();\n\t\tdata.v2 = this.v2.toArray();\n\n\t\treturn data;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tsuper.fromJSON( json );\n\n\t\tthis.v1.fromArray( json.v1 );\n\t\tthis.v2.fromArray( json.v2 );\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass LineCurve3 extends Curve {\n\n\tconstructor( v1 = new Vector3(), v2 = new Vector3() ) {\n\n\t\tsuper();\n\n\t\tthis.isLineCurve3 = true;\n\n\t\tthis.type = 'LineCurve3';\n\n\t\tthis.v1 = v1;\n\t\tthis.v2 = v2;\n\n\t}\n\tgetPoint( t, optionalTarget = new Vector3() ) {\n\n\t\tconst point = optionalTarget;\n\n\t\tif ( t === 1 ) {\n\n\t\t\tpoint.copy( this.v2 );\n\n\t\t} else {\n\n\t\t\tpoint.copy( this.v2 ).sub( this.v1 );\n\t\t\tpoint.multiplyScalar( t ).add( this.v1 );\n\n\t\t}\n\n\t\treturn point;\n\n\t}\n\t// Line curve is linear, so we can overwrite default getPointAt\n\tgetPointAt( u, optionalTarget ) {\n\n\t\treturn this.getPoint( u, optionalTarget );\n\n\t}\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.v1.copy( source.v1 );\n\t\tthis.v2.copy( source.v2 );\n\n\t\treturn this;\n\n\t}\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.v1 = this.v1.toArray();\n\t\tdata.v2 = this.v2.toArray();\n\n\t\treturn data;\n\n\t}\n\tfromJSON( json ) {\n\n\t\tsuper.fromJSON( json );\n\n\t\tthis.v1.fromArray( json.v1 );\n\t\tthis.v2.fromArray( json.v2 );\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass QuadraticBezierCurve extends Curve {\n\n\tconstructor( v0 = new Vector2(), v1 = new Vector2(), v2 = new Vector2() ) {\n\n\t\tsuper();\n\n\t\tthis.isQuadraticBezierCurve = true;\n\n\t\tthis.type = 'QuadraticBezierCurve';\n\n\t\tthis.v0 = v0;\n\t\tthis.v1 = v1;\n\t\tthis.v2 = v2;\n\n\t}\n\n\tgetPoint( t, optionalTarget = new Vector2() ) {\n\n\t\tconst point = optionalTarget;\n\n\t\tconst v0 = this.v0, v1 = this.v1, v2 = this.v2;\n\n\t\tpoint.set(\n\t\t\tQuadraticBezier( t, v0.x, v1.x, v2.x ),\n\t\t\tQuadraticBezier( t, v0.y, v1.y, v2.y )\n\t\t);\n\n\t\treturn point;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.v0.copy( source.v0 );\n\t\tthis.v1.copy( source.v1 );\n\t\tthis.v2.copy( source.v2 );\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.v0 = this.v0.toArray();\n\t\tdata.v1 = this.v1.toArray();\n\t\tdata.v2 = this.v2.toArray();\n\n\t\treturn data;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tsuper.fromJSON( json );\n\n\t\tthis.v0.fromArray( json.v0 );\n\t\tthis.v1.fromArray( json.v1 );\n\t\tthis.v2.fromArray( json.v2 );\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass QuadraticBezierCurve3 extends Curve {\n\n\tconstructor( v0 = new Vector3(), v1 = new Vector3(), v2 = new Vector3() ) {\n\n\t\tsuper();\n\n\t\tthis.isQuadraticBezierCurve3 = true;\n\n\t\tthis.type = 'QuadraticBezierCurve3';\n\n\t\tthis.v0 = v0;\n\t\tthis.v1 = v1;\n\t\tthis.v2 = v2;\n\n\t}\n\n\tgetPoint( t, optionalTarget = new Vector3() ) {\n\n\t\tconst point = optionalTarget;\n\n\t\tconst v0 = this.v0, v1 = this.v1, v2 = this.v2;\n\n\t\tpoint.set(\n\t\t\tQuadraticBezier( t, v0.x, v1.x, v2.x ),\n\t\t\tQuadraticBezier( t, v0.y, v1.y, v2.y ),\n\t\t\tQuadraticBezier( t, v0.z, v1.z, v2.z )\n\t\t);\n\n\t\treturn point;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.v0.copy( source.v0 );\n\t\tthis.v1.copy( source.v1 );\n\t\tthis.v2.copy( source.v2 );\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.v0 = this.v0.toArray();\n\t\tdata.v1 = this.v1.toArray();\n\t\tdata.v2 = this.v2.toArray();\n\n\t\treturn data;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tsuper.fromJSON( json );\n\n\t\tthis.v0.fromArray( json.v0 );\n\t\tthis.v1.fromArray( json.v1 );\n\t\tthis.v2.fromArray( json.v2 );\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass SplineCurve extends Curve {\n\n\tconstructor( points = [] ) {\n\n\t\tsuper();\n\n\t\tthis.isSplineCurve = true;\n\n\t\tthis.type = 'SplineCurve';\n\n\t\tthis.points = points;\n\n\t}\n\n\tgetPoint( t, optionalTarget = new Vector2() ) {\n\n\t\tconst point = optionalTarget;\n\n\t\tconst points = this.points;\n\t\tconst p = ( points.length - 1 ) * t;\n\n\t\tconst intPoint = Math.floor( p );\n\t\tconst weight = p - intPoint;\n\n\t\tconst p0 = points[ intPoint === 0 ? intPoint : intPoint - 1 ];\n\t\tconst p1 = points[ intPoint ];\n\t\tconst p2 = points[ intPoint > points.length - 2 ? points.length - 1 : intPoint + 1 ];\n\t\tconst p3 = points[ intPoint > points.length - 3 ? points.length - 1 : intPoint + 2 ];\n\n\t\tpoint.set(\n\t\t\tCatmullRom( weight, p0.x, p1.x, p2.x, p3.x ),\n\t\t\tCatmullRom( weight, p0.y, p1.y, p2.y, p3.y )\n\t\t);\n\n\t\treturn point;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.points = [];\n\n\t\tfor ( let i = 0, l = source.points.length; i < l; i ++ ) {\n\n\t\t\tconst point = source.points[ i ];\n\n\t\t\tthis.points.push( point.clone() );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.points = [];\n\n\t\tfor ( let i = 0, l = this.points.length; i < l; i ++ ) {\n\n\t\t\tconst point = this.points[ i ];\n\t\t\tdata.points.push( point.toArray() );\n\n\t\t}\n\n\t\treturn data;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tsuper.fromJSON( json );\n\n\t\tthis.points = [];\n\n\t\tfor ( let i = 0, l = json.points.length; i < l; i ++ ) {\n\n\t\t\tconst point = json.points[ i ];\n\t\t\tthis.points.push( new Vector2().fromArray( point ) );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n}\n\nvar Curves = /*#__PURE__*/Object.freeze({\n\t__proto__: null,\n\tArcCurve: ArcCurve,\n\tCatmullRomCurve3: CatmullRomCurve3,\n\tCubicBezierCurve: CubicBezierCurve,\n\tCubicBezierCurve3: CubicBezierCurve3,\n\tEllipseCurve: EllipseCurve,\n\tLineCurve: LineCurve,\n\tLineCurve3: LineCurve3,\n\tQuadraticBezierCurve: QuadraticBezierCurve,\n\tQuadraticBezierCurve3: QuadraticBezierCurve3,\n\tSplineCurve: SplineCurve\n});\n\n/**************************************************************\n *\tCurved Path - a curve path is simply a array of connected\n * curves, but retains the api of a curve\n **************************************************************/\n\nclass CurvePath extends Curve {\n\n\tconstructor() {\n\n\t\tsuper();\n\n\t\tthis.type = 'CurvePath';\n\n\t\tthis.curves = [];\n\t\tthis.autoClose = false; // Automatically closes the path\n\n\t}\n\n\tadd( curve ) {\n\n\t\tthis.curves.push( curve );\n\n\t}\n\n\tclosePath() {\n\n\t\t// Add a line curve if start and end of lines are not connected\n\t\tconst startPoint = this.curves[ 0 ].getPoint( 0 );\n\t\tconst endPoint = this.curves[ this.curves.length - 1 ].getPoint( 1 );\n\n\t\tif ( ! startPoint.equals( endPoint ) ) {\n\n\t\t\tthis.curves.push( new LineCurve( endPoint, startPoint ) );\n\n\t\t}\n\n\t}\n\n\t// To get accurate point with reference to\n\t// entire path distance at time t,\n\t// following has to be done:\n\n\t// 1. Length of each sub path have to be known\n\t// 2. Locate and identify type of curve\n\t// 3. Get t for the curve\n\t// 4. Return curve.getPointAt(t')\n\n\tgetPoint( t, optionalTarget ) {\n\n\t\tconst d = t * this.getLength();\n\t\tconst curveLengths = this.getCurveLengths();\n\t\tlet i = 0;\n\n\t\t// To think about boundaries points.\n\n\t\twhile ( i < curveLengths.length ) {\n\n\t\t\tif ( curveLengths[ i ] >= d ) {\n\n\t\t\t\tconst diff = curveLengths[ i ] - d;\n\t\t\t\tconst curve = this.curves[ i ];\n\n\t\t\t\tconst segmentLength = curve.getLength();\n\t\t\t\tconst u = segmentLength === 0 ? 0 : 1 - diff / segmentLength;\n\n\t\t\t\treturn curve.getPointAt( u, optionalTarget );\n\n\t\t\t}\n\n\t\t\ti ++;\n\n\t\t}\n\n\t\treturn null;\n\n\t\t// loop where sum != 0, sum > d , sum+1 1 && ! points[ points.length - 1 ].equals( points[ 0 ] ) ) {\n\n\t\t\tpoints.push( points[ 0 ] );\n\n\t\t}\n\n\t\treturn points;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.curves = [];\n\n\t\tfor ( let i = 0, l = source.curves.length; i < l; i ++ ) {\n\n\t\t\tconst curve = source.curves[ i ];\n\n\t\t\tthis.curves.push( curve.clone() );\n\n\t\t}\n\n\t\tthis.autoClose = source.autoClose;\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.autoClose = this.autoClose;\n\t\tdata.curves = [];\n\n\t\tfor ( let i = 0, l = this.curves.length; i < l; i ++ ) {\n\n\t\t\tconst curve = this.curves[ i ];\n\t\t\tdata.curves.push( curve.toJSON() );\n\n\t\t}\n\n\t\treturn data;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tsuper.fromJSON( json );\n\n\t\tthis.autoClose = json.autoClose;\n\t\tthis.curves = [];\n\n\t\tfor ( let i = 0, l = json.curves.length; i < l; i ++ ) {\n\n\t\t\tconst curve = json.curves[ i ];\n\t\t\tthis.curves.push( new Curves[ curve.type ]().fromJSON( curve ) );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass Path extends CurvePath {\n\n\tconstructor( points ) {\n\n\t\tsuper();\n\t\tthis.type = 'Path';\n\n\t\tthis.currentPoint = new Vector2();\n\n\t\tif ( points ) {\n\n\t\t\tthis.setFromPoints( points );\n\n\t\t}\n\n\t}\n\n\tsetFromPoints( points ) {\n\n\t\tthis.moveTo( points[ 0 ].x, points[ 0 ].y );\n\n\t\tfor ( let i = 1, l = points.length; i < l; i ++ ) {\n\n\t\t\tthis.lineTo( points[ i ].x, points[ i ].y );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tmoveTo( x, y ) {\n\n\t\tthis.currentPoint.set( x, y ); // TODO consider referencing vectors instead of copying?\n\n\t\treturn this;\n\n\t}\n\n\tlineTo( x, y ) {\n\n\t\tconst curve = new LineCurve( this.currentPoint.clone(), new Vector2( x, y ) );\n\t\tthis.curves.push( curve );\n\n\t\tthis.currentPoint.set( x, y );\n\n\t\treturn this;\n\n\t}\n\n\tquadraticCurveTo( aCPx, aCPy, aX, aY ) {\n\n\t\tconst curve = new QuadraticBezierCurve(\n\t\t\tthis.currentPoint.clone(),\n\t\t\tnew Vector2( aCPx, aCPy ),\n\t\t\tnew Vector2( aX, aY )\n\t\t);\n\n\t\tthis.curves.push( curve );\n\n\t\tthis.currentPoint.set( aX, aY );\n\n\t\treturn this;\n\n\t}\n\n\tbezierCurveTo( aCP1x, aCP1y, aCP2x, aCP2y, aX, aY ) {\n\n\t\tconst curve = new CubicBezierCurve(\n\t\t\tthis.currentPoint.clone(),\n\t\t\tnew Vector2( aCP1x, aCP1y ),\n\t\t\tnew Vector2( aCP2x, aCP2y ),\n\t\t\tnew Vector2( aX, aY )\n\t\t);\n\n\t\tthis.curves.push( curve );\n\n\t\tthis.currentPoint.set( aX, aY );\n\n\t\treturn this;\n\n\t}\n\n\tsplineThru( pts /*Array of Vector*/ ) {\n\n\t\tconst npts = [ this.currentPoint.clone() ].concat( pts );\n\n\t\tconst curve = new SplineCurve( npts );\n\t\tthis.curves.push( curve );\n\n\t\tthis.currentPoint.copy( pts[ pts.length - 1 ] );\n\n\t\treturn this;\n\n\t}\n\n\tarc( aX, aY, aRadius, aStartAngle, aEndAngle, aClockwise ) {\n\n\t\tconst x0 = this.currentPoint.x;\n\t\tconst y0 = this.currentPoint.y;\n\n\t\tthis.absarc( aX + x0, aY + y0, aRadius,\n\t\t\taStartAngle, aEndAngle, aClockwise );\n\n\t\treturn this;\n\n\t}\n\n\tabsarc( aX, aY, aRadius, aStartAngle, aEndAngle, aClockwise ) {\n\n\t\tthis.absellipse( aX, aY, aRadius, aRadius, aStartAngle, aEndAngle, aClockwise );\n\n\t\treturn this;\n\n\t}\n\n\tellipse( aX, aY, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation ) {\n\n\t\tconst x0 = this.currentPoint.x;\n\t\tconst y0 = this.currentPoint.y;\n\n\t\tthis.absellipse( aX + x0, aY + y0, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation );\n\n\t\treturn this;\n\n\t}\n\n\tabsellipse( aX, aY, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation ) {\n\n\t\tconst curve = new EllipseCurve( aX, aY, xRadius, yRadius, aStartAngle, aEndAngle, aClockwise, aRotation );\n\n\t\tif ( this.curves.length > 0 ) {\n\n\t\t\t// if a previous curve is present, attempt to join\n\t\t\tconst firstPoint = curve.getPoint( 0 );\n\n\t\t\tif ( ! firstPoint.equals( this.currentPoint ) ) {\n\n\t\t\t\tthis.lineTo( firstPoint.x, firstPoint.y );\n\n\t\t\t}\n\n\t\t}\n\n\t\tthis.curves.push( curve );\n\n\t\tconst lastPoint = curve.getPoint( 1 );\n\t\tthis.currentPoint.copy( lastPoint );\n\n\t\treturn this;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.currentPoint.copy( source.currentPoint );\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.currentPoint = this.currentPoint.toArray();\n\n\t\treturn data;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tsuper.fromJSON( json );\n\n\t\tthis.currentPoint.fromArray( json.currentPoint );\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass LatheGeometry extends BufferGeometry {\n\n\tconstructor( points = [ new Vector2( 0, 0.5 ), new Vector2( 0.5, 0 ), new Vector2( 0, - 0.5 ) ], segments = 12, phiStart = 0, phiLength = Math.PI * 2 ) {\n\n\t\tsuper();\n\n\t\tthis.type = 'LatheGeometry';\n\n\t\tthis.parameters = {\n\t\t\tpoints: points,\n\t\t\tsegments: segments,\n\t\t\tphiStart: phiStart,\n\t\t\tphiLength: phiLength\n\t\t};\n\n\t\tsegments = Math.floor( segments );\n\n\t\t// clamp phiLength so it's in range of [ 0, 2PI ]\n\n\t\tphiLength = clamp( phiLength, 0, Math.PI * 2 );\n\n\t\t// buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst uvs = [];\n\t\tconst initNormals = [];\n\t\tconst normals = [];\n\n\t\t// helper variables\n\n\t\tconst inverseSegments = 1.0 / segments;\n\t\tconst vertex = new Vector3();\n\t\tconst uv = new Vector2();\n\t\tconst normal = new Vector3();\n\t\tconst curNormal = new Vector3();\n\t\tconst prevNormal = new Vector3();\n\t\tlet dx = 0;\n\t\tlet dy = 0;\n\n\t\t// pre-compute normals for initial \"meridian\"\n\n\t\tfor ( let j = 0; j <= ( points.length - 1 ); j ++ ) {\n\n\t\t\tswitch ( j ) {\n\n\t\t\t\tcase 0:\t\t\t\t// special handling for 1st vertex on path\n\n\t\t\t\t\tdx = points[ j + 1 ].x - points[ j ].x;\n\t\t\t\t\tdy = points[ j + 1 ].y - points[ j ].y;\n\n\t\t\t\t\tnormal.x = dy * 1.0;\n\t\t\t\t\tnormal.y = - dx;\n\t\t\t\t\tnormal.z = dy * 0.0;\n\n\t\t\t\t\tprevNormal.copy( normal );\n\n\t\t\t\t\tnormal.normalize();\n\n\t\t\t\t\tinitNormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase ( points.length - 1 ):\t// special handling for last Vertex on path\n\n\t\t\t\t\tinitNormals.push( prevNormal.x, prevNormal.y, prevNormal.z );\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\t\t\t// default handling for all vertices in between\n\n\t\t\t\t\tdx = points[ j + 1 ].x - points[ j ].x;\n\t\t\t\t\tdy = points[ j + 1 ].y - points[ j ].y;\n\n\t\t\t\t\tnormal.x = dy * 1.0;\n\t\t\t\t\tnormal.y = - dx;\n\t\t\t\t\tnormal.z = dy * 0.0;\n\n\t\t\t\t\tcurNormal.copy( normal );\n\n\t\t\t\t\tnormal.x += prevNormal.x;\n\t\t\t\t\tnormal.y += prevNormal.y;\n\t\t\t\t\tnormal.z += prevNormal.z;\n\n\t\t\t\t\tnormal.normalize();\n\n\t\t\t\t\tinitNormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t\t\tprevNormal.copy( curNormal );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// generate vertices, uvs and normals\n\n\t\tfor ( let i = 0; i <= segments; i ++ ) {\n\n\t\t\tconst phi = phiStart + i * inverseSegments * phiLength;\n\n\t\t\tconst sin = Math.sin( phi );\n\t\t\tconst cos = Math.cos( phi );\n\n\t\t\tfor ( let j = 0; j <= ( points.length - 1 ); j ++ ) {\n\n\t\t\t\t// vertex\n\n\t\t\t\tvertex.x = points[ j ].x * sin;\n\t\t\t\tvertex.y = points[ j ].y;\n\t\t\t\tvertex.z = points[ j ].x * cos;\n\n\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t\t// uv\n\n\t\t\t\tuv.x = i / segments;\n\t\t\t\tuv.y = j / ( points.length - 1 );\n\n\t\t\t\tuvs.push( uv.x, uv.y );\n\n\t\t\t\t// normal\n\n\t\t\t\tconst x = initNormals[ 3 * j + 0 ] * sin;\n\t\t\t\tconst y = initNormals[ 3 * j + 1 ];\n\t\t\t\tconst z = initNormals[ 3 * j + 0 ] * cos;\n\n\t\t\t\tnormals.push( x, y, z );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// indices\n\n\t\tfor ( let i = 0; i < segments; i ++ ) {\n\n\t\t\tfor ( let j = 0; j < ( points.length - 1 ); j ++ ) {\n\n\t\t\t\tconst base = j + i * points.length;\n\n\t\t\t\tconst a = base;\n\t\t\t\tconst b = base + points.length;\n\t\t\t\tconst c = base + points.length + 1;\n\t\t\t\tconst d = base + 1;\n\n\t\t\t\t// faces\n\n\t\t\t\tindices.push( a, b, d );\n\t\t\t\tindices.push( c, d, b );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// build geometry\n\n\t\tthis.setIndex( indices );\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\t\tthis.setAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new LatheGeometry( data.points, data.segments, data.phiStart, data.phiLength );\n\n\t}\n\n}\n\nclass CapsuleGeometry extends LatheGeometry {\n\n\tconstructor( radius = 1, length = 1, capSegments = 4, radialSegments = 8 ) {\n\n\t\tconst path = new Path();\n\t\tpath.absarc( 0, - length / 2, radius, Math.PI * 1.5, 0 );\n\t\tpath.absarc( 0, length / 2, radius, 0, Math.PI * 0.5 );\n\n\t\tsuper( path.getPoints( capSegments ), radialSegments );\n\n\t\tthis.type = 'CapsuleGeometry';\n\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\theight: length,\n\t\t\tcapSegments: capSegments,\n\t\t\tradialSegments: radialSegments,\n\t\t};\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new CapsuleGeometry( data.radius, data.length, data.capSegments, data.radialSegments );\n\n\t}\n\n}\n\nclass CircleGeometry extends BufferGeometry {\n\n\tconstructor( radius = 1, segments = 8, thetaStart = 0, thetaLength = Math.PI * 2 ) {\n\n\t\tsuper();\n\n\t\tthis.type = 'CircleGeometry';\n\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\tsegments: segments,\n\t\t\tthetaStart: thetaStart,\n\t\t\tthetaLength: thetaLength\n\t\t};\n\n\t\tsegments = Math.max( 3, segments );\n\n\t\t// buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\n\t\t// helper variables\n\n\t\tconst vertex = new Vector3();\n\t\tconst uv = new Vector2();\n\n\t\t// center point\n\n\t\tvertices.push( 0, 0, 0 );\n\t\tnormals.push( 0, 0, 1 );\n\t\tuvs.push( 0.5, 0.5 );\n\n\t\tfor ( let s = 0, i = 3; s <= segments; s ++, i += 3 ) {\n\n\t\t\tconst segment = thetaStart + s / segments * thetaLength;\n\n\t\t\t// vertex\n\n\t\t\tvertex.x = radius * Math.cos( segment );\n\t\t\tvertex.y = radius * Math.sin( segment );\n\n\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t// normal\n\n\t\t\tnormals.push( 0, 0, 1 );\n\n\t\t\t// uvs\n\n\t\t\tuv.x = ( vertices[ i ] / radius + 1 ) / 2;\n\t\t\tuv.y = ( vertices[ i + 1 ] / radius + 1 ) / 2;\n\n\t\t\tuvs.push( uv.x, uv.y );\n\n\t\t}\n\n\t\t// indices\n\n\t\tfor ( let i = 1; i <= segments; i ++ ) {\n\n\t\t\tindices.push( i, i + 1, 0 );\n\n\t\t}\n\n\t\t// build geometry\n\n\t\tthis.setIndex( indices );\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tthis.setAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new CircleGeometry( data.radius, data.segments, data.thetaStart, data.thetaLength );\n\n\t}\n\n}\n\nclass CylinderGeometry extends BufferGeometry {\n\n\tconstructor( radiusTop = 1, radiusBottom = 1, height = 1, radialSegments = 8, heightSegments = 1, openEnded = false, thetaStart = 0, thetaLength = Math.PI * 2 ) {\n\n\t\tsuper();\n\t\tthis.type = 'CylinderGeometry';\n\n\t\tthis.parameters = {\n\t\t\tradiusTop: radiusTop,\n\t\t\tradiusBottom: radiusBottom,\n\t\t\theight: height,\n\t\t\tradialSegments: radialSegments,\n\t\t\theightSegments: heightSegments,\n\t\t\topenEnded: openEnded,\n\t\t\tthetaStart: thetaStart,\n\t\t\tthetaLength: thetaLength\n\t\t};\n\n\t\tconst scope = this;\n\n\t\tradialSegments = Math.floor( radialSegments );\n\t\theightSegments = Math.floor( heightSegments );\n\n\t\t// buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\n\t\t// helper variables\n\n\t\tlet index = 0;\n\t\tconst indexArray = [];\n\t\tconst halfHeight = height / 2;\n\t\tlet groupStart = 0;\n\n\t\t// generate geometry\n\n\t\tgenerateTorso();\n\n\t\tif ( openEnded === false ) {\n\n\t\t\tif ( radiusTop > 0 ) generateCap( true );\n\t\t\tif ( radiusBottom > 0 ) generateCap( false );\n\n\t\t}\n\n\t\t// build geometry\n\n\t\tthis.setIndex( indices );\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tthis.setAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\t\tfunction generateTorso() {\n\n\t\t\tconst normal = new Vector3();\n\t\t\tconst vertex = new Vector3();\n\n\t\t\tlet groupCount = 0;\n\n\t\t\t// this will be used to calculate the normal\n\t\t\tconst slope = ( radiusBottom - radiusTop ) / height;\n\n\t\t\t// generate vertices, normals and uvs\n\n\t\t\tfor ( let y = 0; y <= heightSegments; y ++ ) {\n\n\t\t\t\tconst indexRow = [];\n\n\t\t\t\tconst v = y / heightSegments;\n\n\t\t\t\t// calculate the radius of the current row\n\n\t\t\t\tconst radius = v * ( radiusBottom - radiusTop ) + radiusTop;\n\n\t\t\t\tfor ( let x = 0; x <= radialSegments; x ++ ) {\n\n\t\t\t\t\tconst u = x / radialSegments;\n\n\t\t\t\t\tconst theta = u * thetaLength + thetaStart;\n\n\t\t\t\t\tconst sinTheta = Math.sin( theta );\n\t\t\t\t\tconst cosTheta = Math.cos( theta );\n\n\t\t\t\t\t// vertex\n\n\t\t\t\t\tvertex.x = radius * sinTheta;\n\t\t\t\t\tvertex.y = - v * height + halfHeight;\n\t\t\t\t\tvertex.z = radius * cosTheta;\n\t\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t\t\t// normal\n\n\t\t\t\t\tnormal.set( sinTheta, slope, cosTheta ).normalize();\n\t\t\t\t\tnormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t\t\t// uv\n\n\t\t\t\t\tuvs.push( u, 1 - v );\n\n\t\t\t\t\t// save index of vertex in respective row\n\n\t\t\t\t\tindexRow.push( index ++ );\n\n\t\t\t\t}\n\n\t\t\t\t// now save vertices of the row in our index array\n\n\t\t\t\tindexArray.push( indexRow );\n\n\t\t\t}\n\n\t\t\t// generate indices\n\n\t\t\tfor ( let x = 0; x < radialSegments; x ++ ) {\n\n\t\t\t\tfor ( let y = 0; y < heightSegments; y ++ ) {\n\n\t\t\t\t\t// we use the index array to access the correct indices\n\n\t\t\t\t\tconst a = indexArray[ y ][ x ];\n\t\t\t\t\tconst b = indexArray[ y + 1 ][ x ];\n\t\t\t\t\tconst c = indexArray[ y + 1 ][ x + 1 ];\n\t\t\t\t\tconst d = indexArray[ y ][ x + 1 ];\n\n\t\t\t\t\t// faces\n\n\t\t\t\t\tindices.push( a, b, d );\n\t\t\t\t\tindices.push( b, c, d );\n\n\t\t\t\t\t// update group counter\n\n\t\t\t\t\tgroupCount += 6;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// add a group to the geometry. this will ensure multi material support\n\n\t\t\tscope.addGroup( groupStart, groupCount, 0 );\n\n\t\t\t// calculate new start value for groups\n\n\t\t\tgroupStart += groupCount;\n\n\t\t}\n\n\t\tfunction generateCap( top ) {\n\n\t\t\t// save the index of the first center vertex\n\t\t\tconst centerIndexStart = index;\n\n\t\t\tconst uv = new Vector2();\n\t\t\tconst vertex = new Vector3();\n\n\t\t\tlet groupCount = 0;\n\n\t\t\tconst radius = ( top === true ) ? radiusTop : radiusBottom;\n\t\t\tconst sign = ( top === true ) ? 1 : - 1;\n\n\t\t\t// first we generate the center vertex data of the cap.\n\t\t\t// because the geometry needs one set of uvs per face,\n\t\t\t// we must generate a center vertex per face/segment\n\n\t\t\tfor ( let x = 1; x <= radialSegments; x ++ ) {\n\n\t\t\t\t// vertex\n\n\t\t\t\tvertices.push( 0, halfHeight * sign, 0 );\n\n\t\t\t\t// normal\n\n\t\t\t\tnormals.push( 0, sign, 0 );\n\n\t\t\t\t// uv\n\n\t\t\t\tuvs.push( 0.5, 0.5 );\n\n\t\t\t\t// increase index\n\n\t\t\t\tindex ++;\n\n\t\t\t}\n\n\t\t\t// save the index of the last center vertex\n\t\t\tconst centerIndexEnd = index;\n\n\t\t\t// now we generate the surrounding vertices, normals and uvs\n\n\t\t\tfor ( let x = 0; x <= radialSegments; x ++ ) {\n\n\t\t\t\tconst u = x / radialSegments;\n\t\t\t\tconst theta = u * thetaLength + thetaStart;\n\n\t\t\t\tconst cosTheta = Math.cos( theta );\n\t\t\t\tconst sinTheta = Math.sin( theta );\n\n\t\t\t\t// vertex\n\n\t\t\t\tvertex.x = radius * sinTheta;\n\t\t\t\tvertex.y = halfHeight * sign;\n\t\t\t\tvertex.z = radius * cosTheta;\n\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t\t// normal\n\n\t\t\t\tnormals.push( 0, sign, 0 );\n\n\t\t\t\t// uv\n\n\t\t\t\tuv.x = ( cosTheta * 0.5 ) + 0.5;\n\t\t\t\tuv.y = ( sinTheta * 0.5 * sign ) + 0.5;\n\t\t\t\tuvs.push( uv.x, uv.y );\n\n\t\t\t\t// increase index\n\n\t\t\t\tindex ++;\n\n\t\t\t}\n\n\t\t\t// generate indices\n\n\t\t\tfor ( let x = 0; x < radialSegments; x ++ ) {\n\n\t\t\t\tconst c = centerIndexStart + x;\n\t\t\t\tconst i = centerIndexEnd + x;\n\n\t\t\t\tif ( top === true ) {\n\n\t\t\t\t\t// face top\n\n\t\t\t\t\tindices.push( i, i + 1, c );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// face bottom\n\n\t\t\t\t\tindices.push( i + 1, i, c );\n\n\t\t\t\t}\n\n\t\t\t\tgroupCount += 3;\n\n\t\t\t}\n\n\t\t\t// add a group to the geometry. this will ensure multi material support\n\n\t\t\tscope.addGroup( groupStart, groupCount, top === true ? 1 : 2 );\n\n\t\t\t// calculate new start value for groups\n\n\t\t\tgroupStart += groupCount;\n\n\t\t}\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new CylinderGeometry( data.radiusTop, data.radiusBottom, data.height, data.radialSegments, data.heightSegments, data.openEnded, data.thetaStart, data.thetaLength );\n\n\t}\n\n}\n\nclass ConeGeometry extends CylinderGeometry {\n\n\tconstructor( radius = 1, height = 1, radialSegments = 8, heightSegments = 1, openEnded = false, thetaStart = 0, thetaLength = Math.PI * 2 ) {\n\n\t\tsuper( 0, radius, height, radialSegments, heightSegments, openEnded, thetaStart, thetaLength );\n\n\t\tthis.type = 'ConeGeometry';\n\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\theight: height,\n\t\t\tradialSegments: radialSegments,\n\t\t\theightSegments: heightSegments,\n\t\t\topenEnded: openEnded,\n\t\t\tthetaStart: thetaStart,\n\t\t\tthetaLength: thetaLength\n\t\t};\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new ConeGeometry( data.radius, data.height, data.radialSegments, data.heightSegments, data.openEnded, data.thetaStart, data.thetaLength );\n\n\t}\n\n}\n\nclass PolyhedronGeometry extends BufferGeometry {\n\n\tconstructor( vertices = [], indices = [], radius = 1, detail = 0 ) {\n\n\t\tsuper();\n\n\t\tthis.type = 'PolyhedronGeometry';\n\n\t\tthis.parameters = {\n\t\t\tvertices: vertices,\n\t\t\tindices: indices,\n\t\t\tradius: radius,\n\t\t\tdetail: detail\n\t\t};\n\n\t\t// default buffer data\n\n\t\tconst vertexBuffer = [];\n\t\tconst uvBuffer = [];\n\n\t\t// the subdivision creates the vertex buffer data\n\n\t\tsubdivide( detail );\n\n\t\t// all vertices should lie on a conceptual sphere with a given radius\n\n\t\tapplyRadius( radius );\n\n\t\t// finally, create the uv data\n\n\t\tgenerateUVs();\n\n\t\t// build non-indexed geometry\n\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertexBuffer, 3 ) );\n\t\tthis.setAttribute( 'normal', new Float32BufferAttribute( vertexBuffer.slice(), 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvBuffer, 2 ) );\n\n\t\tif ( detail === 0 ) {\n\n\t\t\tthis.computeVertexNormals(); // flat normals\n\n\t\t} else {\n\n\t\t\tthis.normalizeNormals(); // smooth normals\n\n\t\t}\n\n\t\t// helper functions\n\n\t\tfunction subdivide( detail ) {\n\n\t\t\tconst a = new Vector3();\n\t\t\tconst b = new Vector3();\n\t\t\tconst c = new Vector3();\n\n\t\t\t// iterate over all faces and apply a subdivison with the given detail value\n\n\t\t\tfor ( let i = 0; i < indices.length; i += 3 ) {\n\n\t\t\t\t// get the vertices of the face\n\n\t\t\t\tgetVertexByIndex( indices[ i + 0 ], a );\n\t\t\t\tgetVertexByIndex( indices[ i + 1 ], b );\n\t\t\t\tgetVertexByIndex( indices[ i + 2 ], c );\n\n\t\t\t\t// perform subdivision\n\n\t\t\t\tsubdivideFace( a, b, c, detail );\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction subdivideFace( a, b, c, detail ) {\n\n\t\t\tconst cols = detail + 1;\n\n\t\t\t// we use this multidimensional array as a data structure for creating the subdivision\n\n\t\t\tconst v = [];\n\n\t\t\t// construct all of the vertices for this subdivision\n\n\t\t\tfor ( let i = 0; i <= cols; i ++ ) {\n\n\t\t\t\tv[ i ] = [];\n\n\t\t\t\tconst aj = a.clone().lerp( c, i / cols );\n\t\t\t\tconst bj = b.clone().lerp( c, i / cols );\n\n\t\t\t\tconst rows = cols - i;\n\n\t\t\t\tfor ( let j = 0; j <= rows; j ++ ) {\n\n\t\t\t\t\tif ( j === 0 && i === cols ) {\n\n\t\t\t\t\t\tv[ i ][ j ] = aj;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tv[ i ][ j ] = aj.clone().lerp( bj, j / rows );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// construct all of the faces\n\n\t\t\tfor ( let i = 0; i < cols; i ++ ) {\n\n\t\t\t\tfor ( let j = 0; j < 2 * ( cols - i ) - 1; j ++ ) {\n\n\t\t\t\t\tconst k = Math.floor( j / 2 );\n\n\t\t\t\t\tif ( j % 2 === 0 ) {\n\n\t\t\t\t\t\tpushVertex( v[ i ][ k + 1 ] );\n\t\t\t\t\t\tpushVertex( v[ i + 1 ][ k ] );\n\t\t\t\t\t\tpushVertex( v[ i ][ k ] );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tpushVertex( v[ i ][ k + 1 ] );\n\t\t\t\t\t\tpushVertex( v[ i + 1 ][ k + 1 ] );\n\t\t\t\t\t\tpushVertex( v[ i + 1 ][ k ] );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction applyRadius( radius ) {\n\n\t\t\tconst vertex = new Vector3();\n\n\t\t\t// iterate over the entire buffer and apply the radius to each vertex\n\n\t\t\tfor ( let i = 0; i < vertexBuffer.length; i += 3 ) {\n\n\t\t\t\tvertex.x = vertexBuffer[ i + 0 ];\n\t\t\t\tvertex.y = vertexBuffer[ i + 1 ];\n\t\t\t\tvertex.z = vertexBuffer[ i + 2 ];\n\n\t\t\t\tvertex.normalize().multiplyScalar( radius );\n\n\t\t\t\tvertexBuffer[ i + 0 ] = vertex.x;\n\t\t\t\tvertexBuffer[ i + 1 ] = vertex.y;\n\t\t\t\tvertexBuffer[ i + 2 ] = vertex.z;\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction generateUVs() {\n\n\t\t\tconst vertex = new Vector3();\n\n\t\t\tfor ( let i = 0; i < vertexBuffer.length; i += 3 ) {\n\n\t\t\t\tvertex.x = vertexBuffer[ i + 0 ];\n\t\t\t\tvertex.y = vertexBuffer[ i + 1 ];\n\t\t\t\tvertex.z = vertexBuffer[ i + 2 ];\n\n\t\t\t\tconst u = azimuth( vertex ) / 2 / Math.PI + 0.5;\n\t\t\t\tconst v = inclination( vertex ) / Math.PI + 0.5;\n\t\t\t\tuvBuffer.push( u, 1 - v );\n\n\t\t\t}\n\n\t\t\tcorrectUVs();\n\n\t\t\tcorrectSeam();\n\n\t\t}\n\n\t\tfunction correctSeam() {\n\n\t\t\t// handle case when face straddles the seam, see #3269\n\n\t\t\tfor ( let i = 0; i < uvBuffer.length; i += 6 ) {\n\n\t\t\t\t// uv data of a single face\n\n\t\t\t\tconst x0 = uvBuffer[ i + 0 ];\n\t\t\t\tconst x1 = uvBuffer[ i + 2 ];\n\t\t\t\tconst x2 = uvBuffer[ i + 4 ];\n\n\t\t\t\tconst max = Math.max( x0, x1, x2 );\n\t\t\t\tconst min = Math.min( x0, x1, x2 );\n\n\t\t\t\t// 0.9 is somewhat arbitrary\n\n\t\t\t\tif ( max > 0.9 && min < 0.1 ) {\n\n\t\t\t\t\tif ( x0 < 0.2 ) uvBuffer[ i + 0 ] += 1;\n\t\t\t\t\tif ( x1 < 0.2 ) uvBuffer[ i + 2 ] += 1;\n\t\t\t\t\tif ( x2 < 0.2 ) uvBuffer[ i + 4 ] += 1;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction pushVertex( vertex ) {\n\n\t\t\tvertexBuffer.push( vertex.x, vertex.y, vertex.z );\n\n\t\t}\n\n\t\tfunction getVertexByIndex( index, vertex ) {\n\n\t\t\tconst stride = index * 3;\n\n\t\t\tvertex.x = vertices[ stride + 0 ];\n\t\t\tvertex.y = vertices[ stride + 1 ];\n\t\t\tvertex.z = vertices[ stride + 2 ];\n\n\t\t}\n\n\t\tfunction correctUVs() {\n\n\t\t\tconst a = new Vector3();\n\t\t\tconst b = new Vector3();\n\t\t\tconst c = new Vector3();\n\n\t\t\tconst centroid = new Vector3();\n\n\t\t\tconst uvA = new Vector2();\n\t\t\tconst uvB = new Vector2();\n\t\t\tconst uvC = new Vector2();\n\n\t\t\tfor ( let i = 0, j = 0; i < vertexBuffer.length; i += 9, j += 6 ) {\n\n\t\t\t\ta.set( vertexBuffer[ i + 0 ], vertexBuffer[ i + 1 ], vertexBuffer[ i + 2 ] );\n\t\t\t\tb.set( vertexBuffer[ i + 3 ], vertexBuffer[ i + 4 ], vertexBuffer[ i + 5 ] );\n\t\t\t\tc.set( vertexBuffer[ i + 6 ], vertexBuffer[ i + 7 ], vertexBuffer[ i + 8 ] );\n\n\t\t\t\tuvA.set( uvBuffer[ j + 0 ], uvBuffer[ j + 1 ] );\n\t\t\t\tuvB.set( uvBuffer[ j + 2 ], uvBuffer[ j + 3 ] );\n\t\t\t\tuvC.set( uvBuffer[ j + 4 ], uvBuffer[ j + 5 ] );\n\n\t\t\t\tcentroid.copy( a ).add( b ).add( c ).divideScalar( 3 );\n\n\t\t\t\tconst azi = azimuth( centroid );\n\n\t\t\t\tcorrectUV( uvA, j + 0, a, azi );\n\t\t\t\tcorrectUV( uvB, j + 2, b, azi );\n\t\t\t\tcorrectUV( uvC, j + 4, c, azi );\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction correctUV( uv, stride, vector, azimuth ) {\n\n\t\t\tif ( ( azimuth < 0 ) && ( uv.x === 1 ) ) {\n\n\t\t\t\tuvBuffer[ stride ] = uv.x - 1;\n\n\t\t\t}\n\n\t\t\tif ( ( vector.x === 0 ) && ( vector.z === 0 ) ) {\n\n\t\t\t\tuvBuffer[ stride ] = azimuth / 2 / Math.PI + 0.5;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// Angle around the Y axis, counter-clockwise when looking from above.\n\n\t\tfunction azimuth( vector ) {\n\n\t\t\treturn Math.atan2( vector.z, - vector.x );\n\n\t\t}\n\n\n\t\t// Angle above the XZ plane.\n\n\t\tfunction inclination( vector ) {\n\n\t\t\treturn Math.atan2( - vector.y, Math.sqrt( ( vector.x * vector.x ) + ( vector.z * vector.z ) ) );\n\n\t\t}\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new PolyhedronGeometry( data.vertices, data.indices, data.radius, data.details );\n\n\t}\n\n}\n\nclass DodecahedronGeometry extends PolyhedronGeometry {\n\n\tconstructor( radius = 1, detail = 0 ) {\n\n\t\tconst t = ( 1 + Math.sqrt( 5 ) ) / 2;\n\t\tconst r = 1 / t;\n\n\t\tconst vertices = [\n\n\t\t\t// (±1, ±1, ±1)\n\t\t\t- 1, - 1, - 1,\t- 1, - 1, 1,\n\t\t\t- 1, 1, - 1, - 1, 1, 1,\n\t\t\t1, - 1, - 1, 1, - 1, 1,\n\t\t\t1, 1, - 1, 1, 1, 1,\n\n\t\t\t// (0, ±1/φ, ±φ)\n\t\t\t0, - r, - t, 0, - r, t,\n\t\t\t0, r, - t, 0, r, t,\n\n\t\t\t// (±1/φ, ±φ, 0)\n\t\t\t- r, - t, 0, - r, t, 0,\n\t\t\tr, - t, 0, r, t, 0,\n\n\t\t\t// (±φ, 0, ±1/φ)\n\t\t\t- t, 0, - r, t, 0, - r,\n\t\t\t- t, 0, r, t, 0, r\n\t\t];\n\n\t\tconst indices = [\n\t\t\t3, 11, 7, \t3, 7, 15, \t3, 15, 13,\n\t\t\t7, 19, 17, \t7, 17, 6, \t7, 6, 15,\n\t\t\t17, 4, 8, \t17, 8, 10, \t17, 10, 6,\n\t\t\t8, 0, 16, \t8, 16, 2, \t8, 2, 10,\n\t\t\t0, 12, 1, \t0, 1, 18, \t0, 18, 16,\n\t\t\t6, 10, 2, \t6, 2, 13, \t6, 13, 15,\n\t\t\t2, 16, 18, \t2, 18, 3, \t2, 3, 13,\n\t\t\t18, 1, 9, \t18, 9, 11, \t18, 11, 3,\n\t\t\t4, 14, 12, \t4, 12, 0, \t4, 0, 8,\n\t\t\t11, 9, 5, \t11, 5, 19, \t11, 19, 7,\n\t\t\t19, 5, 14, \t19, 14, 4, \t19, 4, 17,\n\t\t\t1, 12, 14, \t1, 14, 5, \t1, 5, 9\n\t\t];\n\n\t\tsuper( vertices, indices, radius, detail );\n\n\t\tthis.type = 'DodecahedronGeometry';\n\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\tdetail: detail\n\t\t};\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new DodecahedronGeometry( data.radius, data.detail );\n\n\t}\n\n}\n\nconst _v0 = new Vector3();\nconst _v1$1 = new Vector3();\nconst _normal = new Vector3();\nconst _triangle = new Triangle();\n\nclass EdgesGeometry extends BufferGeometry {\n\n\tconstructor( geometry = null, thresholdAngle = 1 ) {\n\n\t\tsuper();\n\t\tthis.type = 'EdgesGeometry';\n\n\t\tthis.parameters = {\n\t\t\tgeometry: geometry,\n\t\t\tthresholdAngle: thresholdAngle\n\t\t};\n\n\t\tif ( geometry !== null ) {\n\n\t\t\tconst precisionPoints = 4;\n\t\t\tconst precision = Math.pow( 10, precisionPoints );\n\t\t\tconst thresholdDot = Math.cos( DEG2RAD * thresholdAngle );\n\n\t\t\tconst indexAttr = geometry.getIndex();\n\t\t\tconst positionAttr = geometry.getAttribute( 'position' );\n\t\t\tconst indexCount = indexAttr ? indexAttr.count : positionAttr.count;\n\n\t\t\tconst indexArr = [ 0, 0, 0 ];\n\t\t\tconst vertKeys = [ 'a', 'b', 'c' ];\n\t\t\tconst hashes = new Array( 3 );\n\n\t\t\tconst edgeData = {};\n\t\t\tconst vertices = [];\n\t\t\tfor ( let i = 0; i < indexCount; i += 3 ) {\n\n\t\t\t\tif ( indexAttr ) {\n\n\t\t\t\t\tindexArr[ 0 ] = indexAttr.getX( i );\n\t\t\t\t\tindexArr[ 1 ] = indexAttr.getX( i + 1 );\n\t\t\t\t\tindexArr[ 2 ] = indexAttr.getX( i + 2 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tindexArr[ 0 ] = i;\n\t\t\t\t\tindexArr[ 1 ] = i + 1;\n\t\t\t\t\tindexArr[ 2 ] = i + 2;\n\n\t\t\t\t}\n\n\t\t\t\tconst { a, b, c } = _triangle;\n\t\t\t\ta.fromBufferAttribute( positionAttr, indexArr[ 0 ] );\n\t\t\t\tb.fromBufferAttribute( positionAttr, indexArr[ 1 ] );\n\t\t\t\tc.fromBufferAttribute( positionAttr, indexArr[ 2 ] );\n\t\t\t\t_triangle.getNormal( _normal );\n\n\t\t\t\t// create hashes for the edge from the vertices\n\t\t\t\thashes[ 0 ] = `${ Math.round( a.x * precision ) },${ Math.round( a.y * precision ) },${ Math.round( a.z * precision ) }`;\n\t\t\t\thashes[ 1 ] = `${ Math.round( b.x * precision ) },${ Math.round( b.y * precision ) },${ Math.round( b.z * precision ) }`;\n\t\t\t\thashes[ 2 ] = `${ Math.round( c.x * precision ) },${ Math.round( c.y * precision ) },${ Math.round( c.z * precision ) }`;\n\n\t\t\t\t// skip degenerate triangles\n\t\t\t\tif ( hashes[ 0 ] === hashes[ 1 ] || hashes[ 1 ] === hashes[ 2 ] || hashes[ 2 ] === hashes[ 0 ] ) {\n\n\t\t\t\t\tcontinue;\n\n\t\t\t\t}\n\n\t\t\t\t// iterate over every edge\n\t\t\t\tfor ( let j = 0; j < 3; j ++ ) {\n\n\t\t\t\t\t// get the first and next vertex making up the edge\n\t\t\t\t\tconst jNext = ( j + 1 ) % 3;\n\t\t\t\t\tconst vecHash0 = hashes[ j ];\n\t\t\t\t\tconst vecHash1 = hashes[ jNext ];\n\t\t\t\t\tconst v0 = _triangle[ vertKeys[ j ] ];\n\t\t\t\t\tconst v1 = _triangle[ vertKeys[ jNext ] ];\n\n\t\t\t\t\tconst hash = `${ vecHash0 }_${ vecHash1 }`;\n\t\t\t\t\tconst reverseHash = `${ vecHash1 }_${ vecHash0 }`;\n\n\t\t\t\t\tif ( reverseHash in edgeData && edgeData[ reverseHash ] ) {\n\n\t\t\t\t\t\t// if we found a sibling edge add it into the vertex array if\n\t\t\t\t\t\t// it meets the angle threshold and delete the edge from the map.\n\t\t\t\t\t\tif ( _normal.dot( edgeData[ reverseHash ].normal ) <= thresholdDot ) {\n\n\t\t\t\t\t\t\tvertices.push( v0.x, v0.y, v0.z );\n\t\t\t\t\t\t\tvertices.push( v1.x, v1.y, v1.z );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tedgeData[ reverseHash ] = null;\n\n\t\t\t\t\t} else if ( ! ( hash in edgeData ) ) {\n\n\t\t\t\t\t\t// if we've already got an edge here then skip adding a new one\n\t\t\t\t\t\tedgeData[ hash ] = {\n\n\t\t\t\t\t\t\tindex0: indexArr[ j ],\n\t\t\t\t\t\t\tindex1: indexArr[ jNext ],\n\t\t\t\t\t\t\tnormal: _normal.clone(),\n\n\t\t\t\t\t\t};\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// iterate over all remaining, unmatched edges and add them to the vertex array\n\t\t\tfor ( const key in edgeData ) {\n\n\t\t\t\tif ( edgeData[ key ] ) {\n\n\t\t\t\t\tconst { index0, index1 } = edgeData[ key ];\n\t\t\t\t\t_v0.fromBufferAttribute( positionAttr, index0 );\n\t\t\t\t\t_v1$1.fromBufferAttribute( positionAttr, index1 );\n\n\t\t\t\t\tvertices.push( _v0.x, _v0.y, _v0.z );\n\t\t\t\t\tvertices.push( _v1$1.x, _v1$1.y, _v1$1.z );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\n\t\t}\n\n\t}\n\n}\n\nclass Shape extends Path {\n\n\tconstructor( points ) {\n\n\t\tsuper( points );\n\n\t\tthis.uuid = generateUUID();\n\n\t\tthis.type = 'Shape';\n\n\t\tthis.holes = [];\n\n\t}\n\n\tgetPointsHoles( divisions ) {\n\n\t\tconst holesPts = [];\n\n\t\tfor ( let i = 0, l = this.holes.length; i < l; i ++ ) {\n\n\t\t\tholesPts[ i ] = this.holes[ i ].getPoints( divisions );\n\n\t\t}\n\n\t\treturn holesPts;\n\n\t}\n\n\t// get points of shape and holes (keypoints based on segments parameter)\n\n\textractPoints( divisions ) {\n\n\t\treturn {\n\n\t\t\tshape: this.getPoints( divisions ),\n\t\t\tholes: this.getPointsHoles( divisions )\n\n\t\t};\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.holes = [];\n\n\t\tfor ( let i = 0, l = source.holes.length; i < l; i ++ ) {\n\n\t\t\tconst hole = source.holes[ i ];\n\n\t\t\tthis.holes.push( hole.clone() );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.uuid = this.uuid;\n\t\tdata.holes = [];\n\n\t\tfor ( let i = 0, l = this.holes.length; i < l; i ++ ) {\n\n\t\t\tconst hole = this.holes[ i ];\n\t\t\tdata.holes.push( hole.toJSON() );\n\n\t\t}\n\n\t\treturn data;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tsuper.fromJSON( json );\n\n\t\tthis.uuid = json.uuid;\n\t\tthis.holes = [];\n\n\t\tfor ( let i = 0, l = json.holes.length; i < l; i ++ ) {\n\n\t\t\tconst hole = json.holes[ i ];\n\t\t\tthis.holes.push( new Path().fromJSON( hole ) );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n}\n\n/**\n * Port from https://github.com/mapbox/earcut (v2.2.2)\n */\n\nconst Earcut = {\n\n\ttriangulate: function ( data, holeIndices, dim = 2 ) {\n\n\t\tconst hasHoles = holeIndices && holeIndices.length;\n\t\tconst outerLen = hasHoles ? holeIndices[ 0 ] * dim : data.length;\n\t\tlet outerNode = linkedList( data, 0, outerLen, dim, true );\n\t\tconst triangles = [];\n\n\t\tif ( ! outerNode || outerNode.next === outerNode.prev ) return triangles;\n\n\t\tlet minX, minY, maxX, maxY, x, y, invSize;\n\n\t\tif ( hasHoles ) outerNode = eliminateHoles( data, holeIndices, outerNode, dim );\n\n\t\t// if the shape is not too simple, we'll use z-order curve hash later; calculate polygon bbox\n\t\tif ( data.length > 80 * dim ) {\n\n\t\t\tminX = maxX = data[ 0 ];\n\t\t\tminY = maxY = data[ 1 ];\n\n\t\t\tfor ( let i = dim; i < outerLen; i += dim ) {\n\n\t\t\t\tx = data[ i ];\n\t\t\t\ty = data[ i + 1 ];\n\t\t\t\tif ( x < minX ) minX = x;\n\t\t\t\tif ( y < minY ) minY = y;\n\t\t\t\tif ( x > maxX ) maxX = x;\n\t\t\t\tif ( y > maxY ) maxY = y;\n\n\t\t\t}\n\n\t\t\t// minX, minY and invSize are later used to transform coords into integers for z-order calculation\n\t\t\tinvSize = Math.max( maxX - minX, maxY - minY );\n\t\t\tinvSize = invSize !== 0 ? 1 / invSize : 0;\n\n\t\t}\n\n\t\tearcutLinked( outerNode, triangles, dim, minX, minY, invSize );\n\n\t\treturn triangles;\n\n\t}\n\n};\n\n// create a circular doubly linked list from polygon points in the specified winding order\nfunction linkedList( data, start, end, dim, clockwise ) {\n\n\tlet i, last;\n\n\tif ( clockwise === ( signedArea( data, start, end, dim ) > 0 ) ) {\n\n\t\tfor ( i = start; i < end; i += dim ) last = insertNode( i, data[ i ], data[ i + 1 ], last );\n\n\t} else {\n\n\t\tfor ( i = end - dim; i >= start; i -= dim ) last = insertNode( i, data[ i ], data[ i + 1 ], last );\n\n\t}\n\n\tif ( last && equals( last, last.next ) ) {\n\n\t\tremoveNode( last );\n\t\tlast = last.next;\n\n\t}\n\n\treturn last;\n\n}\n\n// eliminate colinear or duplicate points\nfunction filterPoints( start, end ) {\n\n\tif ( ! start ) return start;\n\tif ( ! end ) end = start;\n\n\tlet p = start,\n\t\tagain;\n\tdo {\n\n\t\tagain = false;\n\n\t\tif ( ! p.steiner && ( equals( p, p.next ) || area( p.prev, p, p.next ) === 0 ) ) {\n\n\t\t\tremoveNode( p );\n\t\t\tp = end = p.prev;\n\t\t\tif ( p === p.next ) break;\n\t\t\tagain = true;\n\n\t\t} else {\n\n\t\t\tp = p.next;\n\n\t\t}\n\n\t} while ( again || p !== end );\n\n\treturn end;\n\n}\n\n// main ear slicing loop which triangulates a polygon (given as a linked list)\nfunction earcutLinked( ear, triangles, dim, minX, minY, invSize, pass ) {\n\n\tif ( ! ear ) return;\n\n\t// interlink polygon nodes in z-order\n\tif ( ! pass && invSize ) indexCurve( ear, minX, minY, invSize );\n\n\tlet stop = ear,\n\t\tprev, next;\n\n\t// iterate through ears, slicing them one by one\n\twhile ( ear.prev !== ear.next ) {\n\n\t\tprev = ear.prev;\n\t\tnext = ear.next;\n\n\t\tif ( invSize ? isEarHashed( ear, minX, minY, invSize ) : isEar( ear ) ) {\n\n\t\t\t// cut off the triangle\n\t\t\ttriangles.push( prev.i / dim );\n\t\t\ttriangles.push( ear.i / dim );\n\t\t\ttriangles.push( next.i / dim );\n\n\t\t\tremoveNode( ear );\n\n\t\t\t// skipping the next vertex leads to less sliver triangles\n\t\t\tear = next.next;\n\t\t\tstop = next.next;\n\n\t\t\tcontinue;\n\n\t\t}\n\n\t\tear = next;\n\n\t\t// if we looped through the whole remaining polygon and can't find any more ears\n\t\tif ( ear === stop ) {\n\n\t\t\t// try filtering points and slicing again\n\t\t\tif ( ! pass ) {\n\n\t\t\t\tearcutLinked( filterPoints( ear ), triangles, dim, minX, minY, invSize, 1 );\n\n\t\t\t\t// if this didn't work, try curing all small self-intersections locally\n\n\t\t\t} else if ( pass === 1 ) {\n\n\t\t\t\tear = cureLocalIntersections( filterPoints( ear ), triangles, dim );\n\t\t\t\tearcutLinked( ear, triangles, dim, minX, minY, invSize, 2 );\n\n\t\t\t\t// as a last resort, try splitting the remaining polygon into two\n\n\t\t\t} else if ( pass === 2 ) {\n\n\t\t\t\tsplitEarcut( ear, triangles, dim, minX, minY, invSize );\n\n\t\t\t}\n\n\t\t\tbreak;\n\n\t\t}\n\n\t}\n\n}\n\n// check whether a polygon node forms a valid ear with adjacent nodes\nfunction isEar( ear ) {\n\n\tconst a = ear.prev,\n\t\tb = ear,\n\t\tc = ear.next;\n\n\tif ( area( a, b, c ) >= 0 ) return false; // reflex, can't be an ear\n\n\t// now make sure we don't have other points inside the potential ear\n\tlet p = ear.next.next;\n\n\twhile ( p !== ear.prev ) {\n\n\t\tif ( pointInTriangle( a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y ) &&\n\t\t\tarea( p.prev, p, p.next ) >= 0 ) return false;\n\t\tp = p.next;\n\n\t}\n\n\treturn true;\n\n}\n\nfunction isEarHashed( ear, minX, minY, invSize ) {\n\n\tconst a = ear.prev,\n\t\tb = ear,\n\t\tc = ear.next;\n\n\tif ( area( a, b, c ) >= 0 ) return false; // reflex, can't be an ear\n\n\t// triangle bbox; min & max are calculated like this for speed\n\tconst minTX = a.x < b.x ? ( a.x < c.x ? a.x : c.x ) : ( b.x < c.x ? b.x : c.x ),\n\t\tminTY = a.y < b.y ? ( a.y < c.y ? a.y : c.y ) : ( b.y < c.y ? b.y : c.y ),\n\t\tmaxTX = a.x > b.x ? ( a.x > c.x ? a.x : c.x ) : ( b.x > c.x ? b.x : c.x ),\n\t\tmaxTY = a.y > b.y ? ( a.y > c.y ? a.y : c.y ) : ( b.y > c.y ? b.y : c.y );\n\n\t// z-order range for the current triangle bbox;\n\tconst minZ = zOrder( minTX, minTY, minX, minY, invSize ),\n\t\tmaxZ = zOrder( maxTX, maxTY, minX, minY, invSize );\n\n\tlet p = ear.prevZ,\n\t\tn = ear.nextZ;\n\n\t// look for points inside the triangle in both directions\n\twhile ( p && p.z >= minZ && n && n.z <= maxZ ) {\n\n\t\tif ( p !== ear.prev && p !== ear.next &&\n\t\t\tpointInTriangle( a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y ) &&\n\t\t\tarea( p.prev, p, p.next ) >= 0 ) return false;\n\t\tp = p.prevZ;\n\n\t\tif ( n !== ear.prev && n !== ear.next &&\n\t\t\tpointInTriangle( a.x, a.y, b.x, b.y, c.x, c.y, n.x, n.y ) &&\n\t\t\tarea( n.prev, n, n.next ) >= 0 ) return false;\n\t\tn = n.nextZ;\n\n\t}\n\n\t// look for remaining points in decreasing z-order\n\twhile ( p && p.z >= minZ ) {\n\n\t\tif ( p !== ear.prev && p !== ear.next &&\n\t\t\tpointInTriangle( a.x, a.y, b.x, b.y, c.x, c.y, p.x, p.y ) &&\n\t\t\tarea( p.prev, p, p.next ) >= 0 ) return false;\n\t\tp = p.prevZ;\n\n\t}\n\n\t// look for remaining points in increasing z-order\n\twhile ( n && n.z <= maxZ ) {\n\n\t\tif ( n !== ear.prev && n !== ear.next &&\n\t\t\tpointInTriangle( a.x, a.y, b.x, b.y, c.x, c.y, n.x, n.y ) &&\n\t\t\tarea( n.prev, n, n.next ) >= 0 ) return false;\n\t\tn = n.nextZ;\n\n\t}\n\n\treturn true;\n\n}\n\n// go through all polygon nodes and cure small local self-intersections\nfunction cureLocalIntersections( start, triangles, dim ) {\n\n\tlet p = start;\n\tdo {\n\n\t\tconst a = p.prev,\n\t\t\tb = p.next.next;\n\n\t\tif ( ! equals( a, b ) && intersects( a, p, p.next, b ) && locallyInside( a, b ) && locallyInside( b, a ) ) {\n\n\t\t\ttriangles.push( a.i / dim );\n\t\t\ttriangles.push( p.i / dim );\n\t\t\ttriangles.push( b.i / dim );\n\n\t\t\t// remove two nodes involved\n\t\t\tremoveNode( p );\n\t\t\tremoveNode( p.next );\n\n\t\t\tp = start = b;\n\n\t\t}\n\n\t\tp = p.next;\n\n\t} while ( p !== start );\n\n\treturn filterPoints( p );\n\n}\n\n// try splitting polygon into two and triangulate them independently\nfunction splitEarcut( start, triangles, dim, minX, minY, invSize ) {\n\n\t// look for a valid diagonal that divides the polygon into two\n\tlet a = start;\n\tdo {\n\n\t\tlet b = a.next.next;\n\t\twhile ( b !== a.prev ) {\n\n\t\t\tif ( a.i !== b.i && isValidDiagonal( a, b ) ) {\n\n\t\t\t\t// split the polygon in two by the diagonal\n\t\t\t\tlet c = splitPolygon( a, b );\n\n\t\t\t\t// filter colinear points around the cuts\n\t\t\t\ta = filterPoints( a, a.next );\n\t\t\t\tc = filterPoints( c, c.next );\n\n\t\t\t\t// run earcut on each half\n\t\t\t\tearcutLinked( a, triangles, dim, minX, minY, invSize );\n\t\t\t\tearcutLinked( c, triangles, dim, minX, minY, invSize );\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t\tb = b.next;\n\n\t\t}\n\n\t\ta = a.next;\n\n\t} while ( a !== start );\n\n}\n\n// link every hole into the outer loop, producing a single-ring polygon without holes\nfunction eliminateHoles( data, holeIndices, outerNode, dim ) {\n\n\tconst queue = [];\n\tlet i, len, start, end, list;\n\n\tfor ( i = 0, len = holeIndices.length; i < len; i ++ ) {\n\n\t\tstart = holeIndices[ i ] * dim;\n\t\tend = i < len - 1 ? holeIndices[ i + 1 ] * dim : data.length;\n\t\tlist = linkedList( data, start, end, dim, false );\n\t\tif ( list === list.next ) list.steiner = true;\n\t\tqueue.push( getLeftmost( list ) );\n\n\t}\n\n\tqueue.sort( compareX );\n\n\t// process holes from left to right\n\tfor ( i = 0; i < queue.length; i ++ ) {\n\n\t\teliminateHole( queue[ i ], outerNode );\n\t\touterNode = filterPoints( outerNode, outerNode.next );\n\n\t}\n\n\treturn outerNode;\n\n}\n\nfunction compareX( a, b ) {\n\n\treturn a.x - b.x;\n\n}\n\n// find a bridge between vertices that connects hole with an outer ring and link it\nfunction eliminateHole( hole, outerNode ) {\n\n\touterNode = findHoleBridge( hole, outerNode );\n\tif ( outerNode ) {\n\n\t\tconst b = splitPolygon( outerNode, hole );\n\n\t\t// filter collinear points around the cuts\n\t\tfilterPoints( outerNode, outerNode.next );\n\t\tfilterPoints( b, b.next );\n\n\t}\n\n}\n\n// David Eberly's algorithm for finding a bridge between hole and outer polygon\nfunction findHoleBridge( hole, outerNode ) {\n\n\tlet p = outerNode;\n\tconst hx = hole.x;\n\tconst hy = hole.y;\n\tlet qx = - Infinity, m;\n\n\t// find a segment intersected by a ray from the hole's leftmost point to the left;\n\t// segment's endpoint with lesser x will be potential connection point\n\tdo {\n\n\t\tif ( hy <= p.y && hy >= p.next.y && p.next.y !== p.y ) {\n\n\t\t\tconst x = p.x + ( hy - p.y ) * ( p.next.x - p.x ) / ( p.next.y - p.y );\n\t\t\tif ( x <= hx && x > qx ) {\n\n\t\t\t\tqx = x;\n\t\t\t\tif ( x === hx ) {\n\n\t\t\t\t\tif ( hy === p.y ) return p;\n\t\t\t\t\tif ( hy === p.next.y ) return p.next;\n\n\t\t\t\t}\n\n\t\t\t\tm = p.x < p.next.x ? p : p.next;\n\n\t\t\t}\n\n\t\t}\n\n\t\tp = p.next;\n\n\t} while ( p !== outerNode );\n\n\tif ( ! m ) return null;\n\n\tif ( hx === qx ) return m; // hole touches outer segment; pick leftmost endpoint\n\n\t// look for points inside the triangle of hole point, segment intersection and endpoint;\n\t// if there are no points found, we have a valid connection;\n\t// otherwise choose the point of the minimum angle with the ray as connection point\n\n\tconst stop = m,\n\t\tmx = m.x,\n\t\tmy = m.y;\n\tlet tanMin = Infinity, tan;\n\n\tp = m;\n\n\tdo {\n\n\t\tif ( hx >= p.x && p.x >= mx && hx !== p.x &&\n\t\t\t\tpointInTriangle( hy < my ? hx : qx, hy, mx, my, hy < my ? qx : hx, hy, p.x, p.y ) ) {\n\n\t\t\ttan = Math.abs( hy - p.y ) / ( hx - p.x ); // tangential\n\n\t\t\tif ( locallyInside( p, hole ) && ( tan < tanMin || ( tan === tanMin && ( p.x > m.x || ( p.x === m.x && sectorContainsSector( m, p ) ) ) ) ) ) {\n\n\t\t\t\tm = p;\n\t\t\t\ttanMin = tan;\n\n\t\t\t}\n\n\t\t}\n\n\t\tp = p.next;\n\n\t} while ( p !== stop );\n\n\treturn m;\n\n}\n\n// whether sector in vertex m contains sector in vertex p in the same coordinates\nfunction sectorContainsSector( m, p ) {\n\n\treturn area( m.prev, m, p.prev ) < 0 && area( p.next, m, m.next ) < 0;\n\n}\n\n// interlink polygon nodes in z-order\nfunction indexCurve( start, minX, minY, invSize ) {\n\n\tlet p = start;\n\tdo {\n\n\t\tif ( p.z === null ) p.z = zOrder( p.x, p.y, minX, minY, invSize );\n\t\tp.prevZ = p.prev;\n\t\tp.nextZ = p.next;\n\t\tp = p.next;\n\n\t} while ( p !== start );\n\n\tp.prevZ.nextZ = null;\n\tp.prevZ = null;\n\n\tsortLinked( p );\n\n}\n\n// Simon Tatham's linked list merge sort algorithm\n// http://www.chiark.greenend.org.uk/~sgtatham/algorithms/listsort.html\nfunction sortLinked( list ) {\n\n\tlet i, p, q, e, tail, numMerges, pSize, qSize,\n\t\tinSize = 1;\n\n\tdo {\n\n\t\tp = list;\n\t\tlist = null;\n\t\ttail = null;\n\t\tnumMerges = 0;\n\n\t\twhile ( p ) {\n\n\t\t\tnumMerges ++;\n\t\t\tq = p;\n\t\t\tpSize = 0;\n\t\t\tfor ( i = 0; i < inSize; i ++ ) {\n\n\t\t\t\tpSize ++;\n\t\t\t\tq = q.nextZ;\n\t\t\t\tif ( ! q ) break;\n\n\t\t\t}\n\n\t\t\tqSize = inSize;\n\n\t\t\twhile ( pSize > 0 || ( qSize > 0 && q ) ) {\n\n\t\t\t\tif ( pSize !== 0 && ( qSize === 0 || ! q || p.z <= q.z ) ) {\n\n\t\t\t\t\te = p;\n\t\t\t\t\tp = p.nextZ;\n\t\t\t\t\tpSize --;\n\n\t\t\t\t} else {\n\n\t\t\t\t\te = q;\n\t\t\t\t\tq = q.nextZ;\n\t\t\t\t\tqSize --;\n\n\t\t\t\t}\n\n\t\t\t\tif ( tail ) tail.nextZ = e;\n\t\t\t\telse list = e;\n\n\t\t\t\te.prevZ = tail;\n\t\t\t\ttail = e;\n\n\t\t\t}\n\n\t\t\tp = q;\n\n\t\t}\n\n\t\ttail.nextZ = null;\n\t\tinSize *= 2;\n\n\t} while ( numMerges > 1 );\n\n\treturn list;\n\n}\n\n// z-order of a point given coords and inverse of the longer side of data bbox\nfunction zOrder( x, y, minX, minY, invSize ) {\n\n\t// coords are transformed into non-negative 15-bit integer range\n\tx = 32767 * ( x - minX ) * invSize;\n\ty = 32767 * ( y - minY ) * invSize;\n\n\tx = ( x | ( x << 8 ) ) & 0x00FF00FF;\n\tx = ( x | ( x << 4 ) ) & 0x0F0F0F0F;\n\tx = ( x | ( x << 2 ) ) & 0x33333333;\n\tx = ( x | ( x << 1 ) ) & 0x55555555;\n\n\ty = ( y | ( y << 8 ) ) & 0x00FF00FF;\n\ty = ( y | ( y << 4 ) ) & 0x0F0F0F0F;\n\ty = ( y | ( y << 2 ) ) & 0x33333333;\n\ty = ( y | ( y << 1 ) ) & 0x55555555;\n\n\treturn x | ( y << 1 );\n\n}\n\n// find the leftmost node of a polygon ring\nfunction getLeftmost( start ) {\n\n\tlet p = start,\n\t\tleftmost = start;\n\tdo {\n\n\t\tif ( p.x < leftmost.x || ( p.x === leftmost.x && p.y < leftmost.y ) ) leftmost = p;\n\t\tp = p.next;\n\n\t} while ( p !== start );\n\n\treturn leftmost;\n\n}\n\n// check if a point lies within a convex triangle\nfunction pointInTriangle( ax, ay, bx, by, cx, cy, px, py ) {\n\n\treturn ( cx - px ) * ( ay - py ) - ( ax - px ) * ( cy - py ) >= 0 &&\n\t\t\t( ax - px ) * ( by - py ) - ( bx - px ) * ( ay - py ) >= 0 &&\n\t\t\t( bx - px ) * ( cy - py ) - ( cx - px ) * ( by - py ) >= 0;\n\n}\n\n// check if a diagonal between two polygon nodes is valid (lies in polygon interior)\nfunction isValidDiagonal( a, b ) {\n\n\treturn a.next.i !== b.i && a.prev.i !== b.i && ! intersectsPolygon( a, b ) && // doesn't intersect other edges\n\t\t( locallyInside( a, b ) && locallyInside( b, a ) && middleInside( a, b ) && // locally visible\n\t\t( area( a.prev, a, b.prev ) || area( a, b.prev, b ) ) || // does not create opposite-facing sectors\n\t\tequals( a, b ) && area( a.prev, a, a.next ) > 0 && area( b.prev, b, b.next ) > 0 ); // special zero-length case\n\n}\n\n// signed area of a triangle\nfunction area( p, q, r ) {\n\n\treturn ( q.y - p.y ) * ( r.x - q.x ) - ( q.x - p.x ) * ( r.y - q.y );\n\n}\n\n// check if two points are equal\nfunction equals( p1, p2 ) {\n\n\treturn p1.x === p2.x && p1.y === p2.y;\n\n}\n\n// check if two segments intersect\nfunction intersects( p1, q1, p2, q2 ) {\n\n\tconst o1 = sign( area( p1, q1, p2 ) );\n\tconst o2 = sign( area( p1, q1, q2 ) );\n\tconst o3 = sign( area( p2, q2, p1 ) );\n\tconst o4 = sign( area( p2, q2, q1 ) );\n\n\tif ( o1 !== o2 && o3 !== o4 ) return true; // general case\n\n\tif ( o1 === 0 && onSegment( p1, p2, q1 ) ) return true; // p1, q1 and p2 are collinear and p2 lies on p1q1\n\tif ( o2 === 0 && onSegment( p1, q2, q1 ) ) return true; // p1, q1 and q2 are collinear and q2 lies on p1q1\n\tif ( o3 === 0 && onSegment( p2, p1, q2 ) ) return true; // p2, q2 and p1 are collinear and p1 lies on p2q2\n\tif ( o4 === 0 && onSegment( p2, q1, q2 ) ) return true; // p2, q2 and q1 are collinear and q1 lies on p2q2\n\n\treturn false;\n\n}\n\n// for collinear points p, q, r, check if point q lies on segment pr\nfunction onSegment( p, q, r ) {\n\n\treturn q.x <= Math.max( p.x, r.x ) && q.x >= Math.min( p.x, r.x ) && q.y <= Math.max( p.y, r.y ) && q.y >= Math.min( p.y, r.y );\n\n}\n\nfunction sign( num ) {\n\n\treturn num > 0 ? 1 : num < 0 ? - 1 : 0;\n\n}\n\n// check if a polygon diagonal intersects any polygon segments\nfunction intersectsPolygon( a, b ) {\n\n\tlet p = a;\n\tdo {\n\n\t\tif ( p.i !== a.i && p.next.i !== a.i && p.i !== b.i && p.next.i !== b.i &&\n\t\t\t\tintersects( p, p.next, a, b ) ) return true;\n\t\tp = p.next;\n\n\t} while ( p !== a );\n\n\treturn false;\n\n}\n\n// check if a polygon diagonal is locally inside the polygon\nfunction locallyInside( a, b ) {\n\n\treturn area( a.prev, a, a.next ) < 0 ?\n\t\tarea( a, b, a.next ) >= 0 && area( a, a.prev, b ) >= 0 :\n\t\tarea( a, b, a.prev ) < 0 || area( a, a.next, b ) < 0;\n\n}\n\n// check if the middle point of a polygon diagonal is inside the polygon\nfunction middleInside( a, b ) {\n\n\tlet p = a,\n\t\tinside = false;\n\tconst px = ( a.x + b.x ) / 2,\n\t\tpy = ( a.y + b.y ) / 2;\n\tdo {\n\n\t\tif ( ( ( p.y > py ) !== ( p.next.y > py ) ) && p.next.y !== p.y &&\n\t\t\t\t( px < ( p.next.x - p.x ) * ( py - p.y ) / ( p.next.y - p.y ) + p.x ) )\n\t\t\tinside = ! inside;\n\t\tp = p.next;\n\n\t} while ( p !== a );\n\n\treturn inside;\n\n}\n\n// link two polygon vertices with a bridge; if the vertices belong to the same ring, it splits polygon into two;\n// if one belongs to the outer ring and another to a hole, it merges it into a single ring\nfunction splitPolygon( a, b ) {\n\n\tconst a2 = new Node( a.i, a.x, a.y ),\n\t\tb2 = new Node( b.i, b.x, b.y ),\n\t\tan = a.next,\n\t\tbp = b.prev;\n\n\ta.next = b;\n\tb.prev = a;\n\n\ta2.next = an;\n\tan.prev = a2;\n\n\tb2.next = a2;\n\ta2.prev = b2;\n\n\tbp.next = b2;\n\tb2.prev = bp;\n\n\treturn b2;\n\n}\n\n// create a node and optionally link it with previous one (in a circular doubly linked list)\nfunction insertNode( i, x, y, last ) {\n\n\tconst p = new Node( i, x, y );\n\n\tif ( ! last ) {\n\n\t\tp.prev = p;\n\t\tp.next = p;\n\n\t} else {\n\n\t\tp.next = last.next;\n\t\tp.prev = last;\n\t\tlast.next.prev = p;\n\t\tlast.next = p;\n\n\t}\n\n\treturn p;\n\n}\n\nfunction removeNode( p ) {\n\n\tp.next.prev = p.prev;\n\tp.prev.next = p.next;\n\n\tif ( p.prevZ ) p.prevZ.nextZ = p.nextZ;\n\tif ( p.nextZ ) p.nextZ.prevZ = p.prevZ;\n\n}\n\nfunction Node( i, x, y ) {\n\n\t// vertex index in coordinates array\n\tthis.i = i;\n\n\t// vertex coordinates\n\tthis.x = x;\n\tthis.y = y;\n\n\t// previous and next vertex nodes in a polygon ring\n\tthis.prev = null;\n\tthis.next = null;\n\n\t// z-order curve value\n\tthis.z = null;\n\n\t// previous and next nodes in z-order\n\tthis.prevZ = null;\n\tthis.nextZ = null;\n\n\t// indicates whether this is a steiner point\n\tthis.steiner = false;\n\n}\n\nfunction signedArea( data, start, end, dim ) {\n\n\tlet sum = 0;\n\tfor ( let i = start, j = end - dim; i < end; i += dim ) {\n\n\t\tsum += ( data[ j ] - data[ i ] ) * ( data[ i + 1 ] + data[ j + 1 ] );\n\t\tj = i;\n\n\t}\n\n\treturn sum;\n\n}\n\nclass ShapeUtils {\n\n\t// calculate area of the contour polygon\n\n\tstatic area( contour ) {\n\n\t\tconst n = contour.length;\n\t\tlet a = 0.0;\n\n\t\tfor ( let p = n - 1, q = 0; q < n; p = q ++ ) {\n\n\t\t\ta += contour[ p ].x * contour[ q ].y - contour[ q ].x * contour[ p ].y;\n\n\t\t}\n\n\t\treturn a * 0.5;\n\n\t}\n\n\tstatic isClockWise( pts ) {\n\n\t\treturn ShapeUtils.area( pts ) < 0;\n\n\t}\n\n\tstatic triangulateShape( contour, holes ) {\n\n\t\tconst vertices = []; // flat array of vertices like [ x0,y0, x1,y1, x2,y2, ... ]\n\t\tconst holeIndices = []; // array of hole indices\n\t\tconst faces = []; // final array of vertex indices like [ [ a,b,d ], [ b,c,d ] ]\n\n\t\tremoveDupEndPts( contour );\n\t\taddContour( vertices, contour );\n\n\t\t//\n\n\t\tlet holeIndex = contour.length;\n\n\t\tholes.forEach( removeDupEndPts );\n\n\t\tfor ( let i = 0; i < holes.length; i ++ ) {\n\n\t\t\tholeIndices.push( holeIndex );\n\t\t\tholeIndex += holes[ i ].length;\n\t\t\taddContour( vertices, holes[ i ] );\n\n\t\t}\n\n\t\t//\n\n\t\tconst triangles = Earcut.triangulate( vertices, holeIndices );\n\n\t\t//\n\n\t\tfor ( let i = 0; i < triangles.length; i += 3 ) {\n\n\t\t\tfaces.push( triangles.slice( i, i + 3 ) );\n\n\t\t}\n\n\t\treturn faces;\n\n\t}\n\n}\n\nfunction removeDupEndPts( points ) {\n\n\tconst l = points.length;\n\n\tif ( l > 2 && points[ l - 1 ].equals( points[ 0 ] ) ) {\n\n\t\tpoints.pop();\n\n\t}\n\n}\n\nfunction addContour( vertices, contour ) {\n\n\tfor ( let i = 0; i < contour.length; i ++ ) {\n\n\t\tvertices.push( contour[ i ].x );\n\t\tvertices.push( contour[ i ].y );\n\n\t}\n\n}\n\n/**\n * Creates extruded geometry from a path shape.\n *\n * parameters = {\n *\n * curveSegments: , // number of points on the curves\n * steps: , // number of points for z-side extrusions / used for subdividing segments of extrude spline too\n * depth: , // Depth to extrude the shape\n *\n * bevelEnabled: , // turn on bevel\n * bevelThickness: , // how deep into the original shape bevel goes\n * bevelSize: , // how far from shape outline (including bevelOffset) is bevel\n * bevelOffset: , // how far from shape outline does bevel start\n * bevelSegments: , // number of bevel layers\n *\n * extrudePath: // curve to extrude shape along\n *\n * UVGenerator: // object that provides UV generator functions\n *\n * }\n */\n\nclass ExtrudeGeometry extends BufferGeometry {\n\n\tconstructor( shapes = new Shape( [ new Vector2( 0.5, 0.5 ), new Vector2( - 0.5, 0.5 ), new Vector2( - 0.5, - 0.5 ), new Vector2( 0.5, - 0.5 ) ] ), options = {} ) {\n\n\t\tsuper();\n\n\t\tthis.type = 'ExtrudeGeometry';\n\n\t\tthis.parameters = {\n\t\t\tshapes: shapes,\n\t\t\toptions: options\n\t\t};\n\n\t\tshapes = Array.isArray( shapes ) ? shapes : [ shapes ];\n\n\t\tconst scope = this;\n\n\t\tconst verticesArray = [];\n\t\tconst uvArray = [];\n\n\t\tfor ( let i = 0, l = shapes.length; i < l; i ++ ) {\n\n\t\t\tconst shape = shapes[ i ];\n\t\t\taddShape( shape );\n\n\t\t}\n\n\t\t// build geometry\n\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( verticesArray, 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvArray, 2 ) );\n\n\t\tthis.computeVertexNormals();\n\n\t\t// functions\n\n\t\tfunction addShape( shape ) {\n\n\t\t\tconst placeholder = [];\n\n\t\t\t// options\n\n\t\t\tconst curveSegments = options.curveSegments !== undefined ? options.curveSegments : 12;\n\t\t\tconst steps = options.steps !== undefined ? options.steps : 1;\n\t\t\tlet depth = options.depth !== undefined ? options.depth : 1;\n\n\t\t\tlet bevelEnabled = options.bevelEnabled !== undefined ? options.bevelEnabled : true;\n\t\t\tlet bevelThickness = options.bevelThickness !== undefined ? options.bevelThickness : 0.2;\n\t\t\tlet bevelSize = options.bevelSize !== undefined ? options.bevelSize : bevelThickness - 0.1;\n\t\t\tlet bevelOffset = options.bevelOffset !== undefined ? options.bevelOffset : 0;\n\t\t\tlet bevelSegments = options.bevelSegments !== undefined ? options.bevelSegments : 3;\n\n\t\t\tconst extrudePath = options.extrudePath;\n\n\t\t\tconst uvgen = options.UVGenerator !== undefined ? options.UVGenerator : WorldUVGenerator;\n\n\t\t\t// deprecated options\n\n\t\t\tif ( options.amount !== undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.ExtrudeBufferGeometry: amount has been renamed to depth.' );\n\t\t\t\tdepth = options.amount;\n\n\t\t\t}\n\n\t\t\t//\n\n\t\t\tlet extrudePts, extrudeByPath = false;\n\t\t\tlet splineTube, binormal, normal, position2;\n\n\t\t\tif ( extrudePath ) {\n\n\t\t\t\textrudePts = extrudePath.getSpacedPoints( steps );\n\n\t\t\t\textrudeByPath = true;\n\t\t\t\tbevelEnabled = false; // bevels not supported for path extrusion\n\n\t\t\t\t// SETUP TNB variables\n\n\t\t\t\t// TODO1 - have a .isClosed in spline?\n\n\t\t\t\tsplineTube = extrudePath.computeFrenetFrames( steps, false );\n\n\t\t\t\t// console.log(splineTube, 'splineTube', splineTube.normals.length, 'steps', steps, 'extrudePts', extrudePts.length);\n\n\t\t\t\tbinormal = new Vector3();\n\t\t\t\tnormal = new Vector3();\n\t\t\t\tposition2 = new Vector3();\n\n\t\t\t}\n\n\t\t\t// Safeguards if bevels are not enabled\n\n\t\t\tif ( ! bevelEnabled ) {\n\n\t\t\t\tbevelSegments = 0;\n\t\t\t\tbevelThickness = 0;\n\t\t\t\tbevelSize = 0;\n\t\t\t\tbevelOffset = 0;\n\n\t\t\t}\n\n\t\t\t// Variables initialization\n\n\t\t\tconst shapePoints = shape.extractPoints( curveSegments );\n\n\t\t\tlet vertices = shapePoints.shape;\n\t\t\tconst holes = shapePoints.holes;\n\n\t\t\tconst reverse = ! ShapeUtils.isClockWise( vertices );\n\n\t\t\tif ( reverse ) {\n\n\t\t\t\tvertices = vertices.reverse();\n\n\t\t\t\t// Maybe we should also check if holes are in the opposite direction, just to be safe ...\n\n\t\t\t\tfor ( let h = 0, hl = holes.length; h < hl; h ++ ) {\n\n\t\t\t\t\tconst ahole = holes[ h ];\n\n\t\t\t\t\tif ( ShapeUtils.isClockWise( ahole ) ) {\n\n\t\t\t\t\t\tholes[ h ] = ahole.reverse();\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\n\t\t\tconst faces = ShapeUtils.triangulateShape( vertices, holes );\n\n\t\t\t/* Vertices */\n\n\t\t\tconst contour = vertices; // vertices has all points but contour has only points of circumference\n\n\t\t\tfor ( let h = 0, hl = holes.length; h < hl; h ++ ) {\n\n\t\t\t\tconst ahole = holes[ h ];\n\n\t\t\t\tvertices = vertices.concat( ahole );\n\n\t\t\t}\n\n\n\t\t\tfunction scalePt2( pt, vec, size ) {\n\n\t\t\t\tif ( ! vec ) console.error( 'THREE.ExtrudeGeometry: vec does not exist' );\n\n\t\t\t\treturn vec.clone().multiplyScalar( size ).add( pt );\n\n\t\t\t}\n\n\t\t\tconst vlen = vertices.length, flen = faces.length;\n\n\n\t\t\t// Find directions for point movement\n\n\n\t\t\tfunction getBevelVec( inPt, inPrev, inNext ) {\n\n\t\t\t\t// computes for inPt the corresponding point inPt' on a new contour\n\t\t\t\t// shifted by 1 unit (length of normalized vector) to the left\n\t\t\t\t// if we walk along contour clockwise, this new contour is outside the old one\n\t\t\t\t//\n\t\t\t\t// inPt' is the intersection of the two lines parallel to the two\n\t\t\t\t// adjacent edges of inPt at a distance of 1 unit on the left side.\n\n\t\t\t\tlet v_trans_x, v_trans_y, shrink_by; // resulting translation vector for inPt\n\n\t\t\t\t// good reading for geometry algorithms (here: line-line intersection)\n\t\t\t\t// http://geomalgorithms.com/a05-_intersect-1.html\n\n\t\t\t\tconst v_prev_x = inPt.x - inPrev.x,\n\t\t\t\t\tv_prev_y = inPt.y - inPrev.y;\n\t\t\t\tconst v_next_x = inNext.x - inPt.x,\n\t\t\t\t\tv_next_y = inNext.y - inPt.y;\n\n\t\t\t\tconst v_prev_lensq = ( v_prev_x * v_prev_x + v_prev_y * v_prev_y );\n\n\t\t\t\t// check for collinear edges\n\t\t\t\tconst collinear0 = ( v_prev_x * v_next_y - v_prev_y * v_next_x );\n\n\t\t\t\tif ( Math.abs( collinear0 ) > Number.EPSILON ) {\n\n\t\t\t\t\t// not collinear\n\n\t\t\t\t\t// length of vectors for normalizing\n\n\t\t\t\t\tconst v_prev_len = Math.sqrt( v_prev_lensq );\n\t\t\t\t\tconst v_next_len = Math.sqrt( v_next_x * v_next_x + v_next_y * v_next_y );\n\n\t\t\t\t\t// shift adjacent points by unit vectors to the left\n\n\t\t\t\t\tconst ptPrevShift_x = ( inPrev.x - v_prev_y / v_prev_len );\n\t\t\t\t\tconst ptPrevShift_y = ( inPrev.y + v_prev_x / v_prev_len );\n\n\t\t\t\t\tconst ptNextShift_x = ( inNext.x - v_next_y / v_next_len );\n\t\t\t\t\tconst ptNextShift_y = ( inNext.y + v_next_x / v_next_len );\n\n\t\t\t\t\t// scaling factor for v_prev to intersection point\n\n\t\t\t\t\tconst sf = ( ( ptNextShift_x - ptPrevShift_x ) * v_next_y -\n\t\t\t\t\t\t\t( ptNextShift_y - ptPrevShift_y ) * v_next_x ) /\n\t\t\t\t\t\t( v_prev_x * v_next_y - v_prev_y * v_next_x );\n\n\t\t\t\t\t// vector from inPt to intersection point\n\n\t\t\t\t\tv_trans_x = ( ptPrevShift_x + v_prev_x * sf - inPt.x );\n\t\t\t\t\tv_trans_y = ( ptPrevShift_y + v_prev_y * sf - inPt.y );\n\n\t\t\t\t\t// Don't normalize!, otherwise sharp corners become ugly\n\t\t\t\t\t// but prevent crazy spikes\n\t\t\t\t\tconst v_trans_lensq = ( v_trans_x * v_trans_x + v_trans_y * v_trans_y );\n\t\t\t\t\tif ( v_trans_lensq <= 2 ) {\n\n\t\t\t\t\t\treturn new Vector2( v_trans_x, v_trans_y );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tshrink_by = Math.sqrt( v_trans_lensq / 2 );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// handle special case of collinear edges\n\n\t\t\t\t\tlet direction_eq = false; // assumes: opposite\n\n\t\t\t\t\tif ( v_prev_x > Number.EPSILON ) {\n\n\t\t\t\t\t\tif ( v_next_x > Number.EPSILON ) {\n\n\t\t\t\t\t\t\tdirection_eq = true;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tif ( v_prev_x < - Number.EPSILON ) {\n\n\t\t\t\t\t\t\tif ( v_next_x < - Number.EPSILON ) {\n\n\t\t\t\t\t\t\t\tdirection_eq = true;\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tif ( Math.sign( v_prev_y ) === Math.sign( v_next_y ) ) {\n\n\t\t\t\t\t\t\t\tdirection_eq = true;\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( direction_eq ) {\n\n\t\t\t\t\t\t// console.log(\"Warning: lines are a straight sequence\");\n\t\t\t\t\t\tv_trans_x = - v_prev_y;\n\t\t\t\t\t\tv_trans_y = v_prev_x;\n\t\t\t\t\t\tshrink_by = Math.sqrt( v_prev_lensq );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// console.log(\"Warning: lines are a straight spike\");\n\t\t\t\t\t\tv_trans_x = v_prev_x;\n\t\t\t\t\t\tv_trans_y = v_prev_y;\n\t\t\t\t\t\tshrink_by = Math.sqrt( v_prev_lensq / 2 );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\treturn new Vector2( v_trans_x / shrink_by, v_trans_y / shrink_by );\n\n\t\t\t}\n\n\n\t\t\tconst contourMovements = [];\n\n\t\t\tfor ( let i = 0, il = contour.length, j = il - 1, k = i + 1; i < il; i ++, j ++, k ++ ) {\n\n\t\t\t\tif ( j === il ) j = 0;\n\t\t\t\tif ( k === il ) k = 0;\n\n\t\t\t\t// (j)---(i)---(k)\n\t\t\t\t// console.log('i,j,k', i, j , k)\n\n\t\t\t\tcontourMovements[ i ] = getBevelVec( contour[ i ], contour[ j ], contour[ k ] );\n\n\t\t\t}\n\n\t\t\tconst holesMovements = [];\n\t\t\tlet oneHoleMovements, verticesMovements = contourMovements.concat();\n\n\t\t\tfor ( let h = 0, hl = holes.length; h < hl; h ++ ) {\n\n\t\t\t\tconst ahole = holes[ h ];\n\n\t\t\t\toneHoleMovements = [];\n\n\t\t\t\tfor ( let i = 0, il = ahole.length, j = il - 1, k = i + 1; i < il; i ++, j ++, k ++ ) {\n\n\t\t\t\t\tif ( j === il ) j = 0;\n\t\t\t\t\tif ( k === il ) k = 0;\n\n\t\t\t\t\t// (j)---(i)---(k)\n\t\t\t\t\toneHoleMovements[ i ] = getBevelVec( ahole[ i ], ahole[ j ], ahole[ k ] );\n\n\t\t\t\t}\n\n\t\t\t\tholesMovements.push( oneHoleMovements );\n\t\t\t\tverticesMovements = verticesMovements.concat( oneHoleMovements );\n\n\t\t\t}\n\n\n\t\t\t// Loop bevelSegments, 1 for the front, 1 for the back\n\n\t\t\tfor ( let b = 0; b < bevelSegments; b ++ ) {\n\n\t\t\t\t//for ( b = bevelSegments; b > 0; b -- ) {\n\n\t\t\t\tconst t = b / bevelSegments;\n\t\t\t\tconst z = bevelThickness * Math.cos( t * Math.PI / 2 );\n\t\t\t\tconst bs = bevelSize * Math.sin( t * Math.PI / 2 ) + bevelOffset;\n\n\t\t\t\t// contract shape\n\n\t\t\t\tfor ( let i = 0, il = contour.length; i < il; i ++ ) {\n\n\t\t\t\t\tconst vert = scalePt2( contour[ i ], contourMovements[ i ], bs );\n\n\t\t\t\t\tv( vert.x, vert.y, - z );\n\n\t\t\t\t}\n\n\t\t\t\t// expand holes\n\n\t\t\t\tfor ( let h = 0, hl = holes.length; h < hl; h ++ ) {\n\n\t\t\t\t\tconst ahole = holes[ h ];\n\t\t\t\t\toneHoleMovements = holesMovements[ h ];\n\n\t\t\t\t\tfor ( let i = 0, il = ahole.length; i < il; i ++ ) {\n\n\t\t\t\t\t\tconst vert = scalePt2( ahole[ i ], oneHoleMovements[ i ], bs );\n\n\t\t\t\t\t\tv( vert.x, vert.y, - z );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tconst bs = bevelSize + bevelOffset;\n\n\t\t\t// Back facing vertices\n\n\t\t\tfor ( let i = 0; i < vlen; i ++ ) {\n\n\t\t\t\tconst vert = bevelEnabled ? scalePt2( vertices[ i ], verticesMovements[ i ], bs ) : vertices[ i ];\n\n\t\t\t\tif ( ! extrudeByPath ) {\n\n\t\t\t\t\tv( vert.x, vert.y, 0 );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// v( vert.x, vert.y + extrudePts[ 0 ].y, extrudePts[ 0 ].x );\n\n\t\t\t\t\tnormal.copy( splineTube.normals[ 0 ] ).multiplyScalar( vert.x );\n\t\t\t\t\tbinormal.copy( splineTube.binormals[ 0 ] ).multiplyScalar( vert.y );\n\n\t\t\t\t\tposition2.copy( extrudePts[ 0 ] ).add( normal ).add( binormal );\n\n\t\t\t\t\tv( position2.x, position2.y, position2.z );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// Add stepped vertices...\n\t\t\t// Including front facing vertices\n\n\t\t\tfor ( let s = 1; s <= steps; s ++ ) {\n\n\t\t\t\tfor ( let i = 0; i < vlen; i ++ ) {\n\n\t\t\t\t\tconst vert = bevelEnabled ? scalePt2( vertices[ i ], verticesMovements[ i ], bs ) : vertices[ i ];\n\n\t\t\t\t\tif ( ! extrudeByPath ) {\n\n\t\t\t\t\t\tv( vert.x, vert.y, depth / steps * s );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// v( vert.x, vert.y + extrudePts[ s - 1 ].y, extrudePts[ s - 1 ].x );\n\n\t\t\t\t\t\tnormal.copy( splineTube.normals[ s ] ).multiplyScalar( vert.x );\n\t\t\t\t\t\tbinormal.copy( splineTube.binormals[ s ] ).multiplyScalar( vert.y );\n\n\t\t\t\t\t\tposition2.copy( extrudePts[ s ] ).add( normal ).add( binormal );\n\n\t\t\t\t\t\tv( position2.x, position2.y, position2.z );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\n\t\t\t// Add bevel segments planes\n\n\t\t\t//for ( b = 1; b <= bevelSegments; b ++ ) {\n\t\t\tfor ( let b = bevelSegments - 1; b >= 0; b -- ) {\n\n\t\t\t\tconst t = b / bevelSegments;\n\t\t\t\tconst z = bevelThickness * Math.cos( t * Math.PI / 2 );\n\t\t\t\tconst bs = bevelSize * Math.sin( t * Math.PI / 2 ) + bevelOffset;\n\n\t\t\t\t// contract shape\n\n\t\t\t\tfor ( let i = 0, il = contour.length; i < il; i ++ ) {\n\n\t\t\t\t\tconst vert = scalePt2( contour[ i ], contourMovements[ i ], bs );\n\t\t\t\t\tv( vert.x, vert.y, depth + z );\n\n\t\t\t\t}\n\n\t\t\t\t// expand holes\n\n\t\t\t\tfor ( let h = 0, hl = holes.length; h < hl; h ++ ) {\n\n\t\t\t\t\tconst ahole = holes[ h ];\n\t\t\t\t\toneHoleMovements = holesMovements[ h ];\n\n\t\t\t\t\tfor ( let i = 0, il = ahole.length; i < il; i ++ ) {\n\n\t\t\t\t\t\tconst vert = scalePt2( ahole[ i ], oneHoleMovements[ i ], bs );\n\n\t\t\t\t\t\tif ( ! extrudeByPath ) {\n\n\t\t\t\t\t\t\tv( vert.x, vert.y, depth + z );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tv( vert.x, vert.y + extrudePts[ steps - 1 ].y, extrudePts[ steps - 1 ].x + z );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t/* Faces */\n\n\t\t\t// Top and bottom faces\n\n\t\t\tbuildLidFaces();\n\n\t\t\t// Sides faces\n\n\t\t\tbuildSideFaces();\n\n\n\t\t\t///// Internal functions\n\n\t\t\tfunction buildLidFaces() {\n\n\t\t\t\tconst start = verticesArray.length / 3;\n\n\t\t\t\tif ( bevelEnabled ) {\n\n\t\t\t\t\tlet layer = 0; // steps + 1\n\t\t\t\t\tlet offset = vlen * layer;\n\n\t\t\t\t\t// Bottom faces\n\n\t\t\t\t\tfor ( let i = 0; i < flen; i ++ ) {\n\n\t\t\t\t\t\tconst face = faces[ i ];\n\t\t\t\t\t\tf3( face[ 2 ] + offset, face[ 1 ] + offset, face[ 0 ] + offset );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tlayer = steps + bevelSegments * 2;\n\t\t\t\t\toffset = vlen * layer;\n\n\t\t\t\t\t// Top faces\n\n\t\t\t\t\tfor ( let i = 0; i < flen; i ++ ) {\n\n\t\t\t\t\t\tconst face = faces[ i ];\n\t\t\t\t\t\tf3( face[ 0 ] + offset, face[ 1 ] + offset, face[ 2 ] + offset );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// Bottom faces\n\n\t\t\t\t\tfor ( let i = 0; i < flen; i ++ ) {\n\n\t\t\t\t\t\tconst face = faces[ i ];\n\t\t\t\t\t\tf3( face[ 2 ], face[ 1 ], face[ 0 ] );\n\n\t\t\t\t\t}\n\n\t\t\t\t\t// Top faces\n\n\t\t\t\t\tfor ( let i = 0; i < flen; i ++ ) {\n\n\t\t\t\t\t\tconst face = faces[ i ];\n\t\t\t\t\t\tf3( face[ 0 ] + vlen * steps, face[ 1 ] + vlen * steps, face[ 2 ] + vlen * steps );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tscope.addGroup( start, verticesArray.length / 3 - start, 0 );\n\n\t\t\t}\n\n\t\t\t// Create faces for the z-sides of the shape\n\n\t\t\tfunction buildSideFaces() {\n\n\t\t\t\tconst start = verticesArray.length / 3;\n\t\t\t\tlet layeroffset = 0;\n\t\t\t\tsidewalls( contour, layeroffset );\n\t\t\t\tlayeroffset += contour.length;\n\n\t\t\t\tfor ( let h = 0, hl = holes.length; h < hl; h ++ ) {\n\n\t\t\t\t\tconst ahole = holes[ h ];\n\t\t\t\t\tsidewalls( ahole, layeroffset );\n\n\t\t\t\t\t//, true\n\t\t\t\t\tlayeroffset += ahole.length;\n\n\t\t\t\t}\n\n\n\t\t\t\tscope.addGroup( start, verticesArray.length / 3 - start, 1 );\n\n\n\t\t\t}\n\n\t\t\tfunction sidewalls( contour, layeroffset ) {\n\n\t\t\t\tlet i = contour.length;\n\n\t\t\t\twhile ( -- i >= 0 ) {\n\n\t\t\t\t\tconst j = i;\n\t\t\t\t\tlet k = i - 1;\n\t\t\t\t\tif ( k < 0 ) k = contour.length - 1;\n\n\t\t\t\t\t//console.log('b', i,j, i-1, k,vertices.length);\n\n\t\t\t\t\tfor ( let s = 0, sl = ( steps + bevelSegments * 2 ); s < sl; s ++ ) {\n\n\t\t\t\t\t\tconst slen1 = vlen * s;\n\t\t\t\t\t\tconst slen2 = vlen * ( s + 1 );\n\n\t\t\t\t\t\tconst a = layeroffset + j + slen1,\n\t\t\t\t\t\t\tb = layeroffset + k + slen1,\n\t\t\t\t\t\t\tc = layeroffset + k + slen2,\n\t\t\t\t\t\t\td = layeroffset + j + slen2;\n\n\t\t\t\t\t\tf4( a, b, c, d );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tfunction v( x, y, z ) {\n\n\t\t\t\tplaceholder.push( x );\n\t\t\t\tplaceholder.push( y );\n\t\t\t\tplaceholder.push( z );\n\n\t\t\t}\n\n\n\t\t\tfunction f3( a, b, c ) {\n\n\t\t\t\taddVertex( a );\n\t\t\t\taddVertex( b );\n\t\t\t\taddVertex( c );\n\n\t\t\t\tconst nextIndex = verticesArray.length / 3;\n\t\t\t\tconst uvs = uvgen.generateTopUV( scope, verticesArray, nextIndex - 3, nextIndex - 2, nextIndex - 1 );\n\n\t\t\t\taddUV( uvs[ 0 ] );\n\t\t\t\taddUV( uvs[ 1 ] );\n\t\t\t\taddUV( uvs[ 2 ] );\n\n\t\t\t}\n\n\t\t\tfunction f4( a, b, c, d ) {\n\n\t\t\t\taddVertex( a );\n\t\t\t\taddVertex( b );\n\t\t\t\taddVertex( d );\n\n\t\t\t\taddVertex( b );\n\t\t\t\taddVertex( c );\n\t\t\t\taddVertex( d );\n\n\n\t\t\t\tconst nextIndex = verticesArray.length / 3;\n\t\t\t\tconst uvs = uvgen.generateSideWallUV( scope, verticesArray, nextIndex - 6, nextIndex - 3, nextIndex - 2, nextIndex - 1 );\n\n\t\t\t\taddUV( uvs[ 0 ] );\n\t\t\t\taddUV( uvs[ 1 ] );\n\t\t\t\taddUV( uvs[ 3 ] );\n\n\t\t\t\taddUV( uvs[ 1 ] );\n\t\t\t\taddUV( uvs[ 2 ] );\n\t\t\t\taddUV( uvs[ 3 ] );\n\n\t\t\t}\n\n\t\t\tfunction addVertex( index ) {\n\n\t\t\t\tverticesArray.push( placeholder[ index * 3 + 0 ] );\n\t\t\t\tverticesArray.push( placeholder[ index * 3 + 1 ] );\n\t\t\t\tverticesArray.push( placeholder[ index * 3 + 2 ] );\n\n\t\t\t}\n\n\n\t\t\tfunction addUV( vector2 ) {\n\n\t\t\t\tuvArray.push( vector2.x );\n\t\t\t\tuvArray.push( vector2.y );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tconst shapes = this.parameters.shapes;\n\t\tconst options = this.parameters.options;\n\n\t\treturn toJSON$1( shapes, options, data );\n\n\t}\n\n\tstatic fromJSON( data, shapes ) {\n\n\t\tconst geometryShapes = [];\n\n\t\tfor ( let j = 0, jl = data.shapes.length; j < jl; j ++ ) {\n\n\t\t\tconst shape = shapes[ data.shapes[ j ] ];\n\n\t\t\tgeometryShapes.push( shape );\n\n\t\t}\n\n\t\tconst extrudePath = data.options.extrudePath;\n\n\t\tif ( extrudePath !== undefined ) {\n\n\t\t\tdata.options.extrudePath = new Curves[ extrudePath.type ]().fromJSON( extrudePath );\n\n\t\t}\n\n\t\treturn new ExtrudeGeometry( geometryShapes, data.options );\n\n\t}\n\n}\n\nconst WorldUVGenerator = {\n\n\tgenerateTopUV: function ( geometry, vertices, indexA, indexB, indexC ) {\n\n\t\tconst a_x = vertices[ indexA * 3 ];\n\t\tconst a_y = vertices[ indexA * 3 + 1 ];\n\t\tconst b_x = vertices[ indexB * 3 ];\n\t\tconst b_y = vertices[ indexB * 3 + 1 ];\n\t\tconst c_x = vertices[ indexC * 3 ];\n\t\tconst c_y = vertices[ indexC * 3 + 1 ];\n\n\t\treturn [\n\t\t\tnew Vector2( a_x, a_y ),\n\t\t\tnew Vector2( b_x, b_y ),\n\t\t\tnew Vector2( c_x, c_y )\n\t\t];\n\n\t},\n\n\tgenerateSideWallUV: function ( geometry, vertices, indexA, indexB, indexC, indexD ) {\n\n\t\tconst a_x = vertices[ indexA * 3 ];\n\t\tconst a_y = vertices[ indexA * 3 + 1 ];\n\t\tconst a_z = vertices[ indexA * 3 + 2 ];\n\t\tconst b_x = vertices[ indexB * 3 ];\n\t\tconst b_y = vertices[ indexB * 3 + 1 ];\n\t\tconst b_z = vertices[ indexB * 3 + 2 ];\n\t\tconst c_x = vertices[ indexC * 3 ];\n\t\tconst c_y = vertices[ indexC * 3 + 1 ];\n\t\tconst c_z = vertices[ indexC * 3 + 2 ];\n\t\tconst d_x = vertices[ indexD * 3 ];\n\t\tconst d_y = vertices[ indexD * 3 + 1 ];\n\t\tconst d_z = vertices[ indexD * 3 + 2 ];\n\n\t\tif ( Math.abs( a_y - b_y ) < Math.abs( a_x - b_x ) ) {\n\n\t\t\treturn [\n\t\t\t\tnew Vector2( a_x, 1 - a_z ),\n\t\t\t\tnew Vector2( b_x, 1 - b_z ),\n\t\t\t\tnew Vector2( c_x, 1 - c_z ),\n\t\t\t\tnew Vector2( d_x, 1 - d_z )\n\t\t\t];\n\n\t\t} else {\n\n\t\t\treturn [\n\t\t\t\tnew Vector2( a_y, 1 - a_z ),\n\t\t\t\tnew Vector2( b_y, 1 - b_z ),\n\t\t\t\tnew Vector2( c_y, 1 - c_z ),\n\t\t\t\tnew Vector2( d_y, 1 - d_z )\n\t\t\t];\n\n\t\t}\n\n\t}\n\n};\n\nfunction toJSON$1( shapes, options, data ) {\n\n\tdata.shapes = [];\n\n\tif ( Array.isArray( shapes ) ) {\n\n\t\tfor ( let i = 0, l = shapes.length; i < l; i ++ ) {\n\n\t\t\tconst shape = shapes[ i ];\n\n\t\t\tdata.shapes.push( shape.uuid );\n\n\t\t}\n\n\t} else {\n\n\t\tdata.shapes.push( shapes.uuid );\n\n\t}\n\n\tdata.options = Object.assign( {}, options );\n\n\tif ( options.extrudePath !== undefined ) data.options.extrudePath = options.extrudePath.toJSON();\n\n\treturn data;\n\n}\n\nclass IcosahedronGeometry extends PolyhedronGeometry {\n\n\tconstructor( radius = 1, detail = 0 ) {\n\n\t\tconst t = ( 1 + Math.sqrt( 5 ) ) / 2;\n\n\t\tconst vertices = [\n\t\t\t- 1, t, 0, \t1, t, 0, \t- 1, - t, 0, \t1, - t, 0,\n\t\t\t0, - 1, t, \t0, 1, t,\t0, - 1, - t, \t0, 1, - t,\n\t\t\tt, 0, - 1, \tt, 0, 1, \t- t, 0, - 1, \t- t, 0, 1\n\t\t];\n\n\t\tconst indices = [\n\t\t\t0, 11, 5, \t0, 5, 1, \t0, 1, 7, \t0, 7, 10, \t0, 10, 11,\n\t\t\t1, 5, 9, \t5, 11, 4,\t11, 10, 2,\t10, 7, 6,\t7, 1, 8,\n\t\t\t3, 9, 4, \t3, 4, 2,\t3, 2, 6,\t3, 6, 8,\t3, 8, 9,\n\t\t\t4, 9, 5, \t2, 4, 11,\t6, 2, 10,\t8, 6, 7,\t9, 8, 1\n\t\t];\n\n\t\tsuper( vertices, indices, radius, detail );\n\n\t\tthis.type = 'IcosahedronGeometry';\n\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\tdetail: detail\n\t\t};\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new IcosahedronGeometry( data.radius, data.detail );\n\n\t}\n\n}\n\nclass OctahedronGeometry extends PolyhedronGeometry {\n\n\tconstructor( radius = 1, detail = 0 ) {\n\n\t\tconst vertices = [\n\t\t\t1, 0, 0, \t- 1, 0, 0,\t0, 1, 0,\n\t\t\t0, - 1, 0, \t0, 0, 1,\t0, 0, - 1\n\t\t];\n\n\t\tconst indices = [\n\t\t\t0, 2, 4,\t0, 4, 3,\t0, 3, 5,\n\t\t\t0, 5, 2,\t1, 2, 5,\t1, 5, 3,\n\t\t\t1, 3, 4,\t1, 4, 2\n\t\t];\n\n\t\tsuper( vertices, indices, radius, detail );\n\n\t\tthis.type = 'OctahedronGeometry';\n\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\tdetail: detail\n\t\t};\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new OctahedronGeometry( data.radius, data.detail );\n\n\t}\n\n}\n\nclass RingGeometry extends BufferGeometry {\n\n\tconstructor( innerRadius = 0.5, outerRadius = 1, thetaSegments = 8, phiSegments = 1, thetaStart = 0, thetaLength = Math.PI * 2 ) {\n\n\t\tsuper();\n\n\t\tthis.type = 'RingGeometry';\n\n\t\tthis.parameters = {\n\t\t\tinnerRadius: innerRadius,\n\t\t\touterRadius: outerRadius,\n\t\t\tthetaSegments: thetaSegments,\n\t\t\tphiSegments: phiSegments,\n\t\t\tthetaStart: thetaStart,\n\t\t\tthetaLength: thetaLength\n\t\t};\n\n\t\tthetaSegments = Math.max( 3, thetaSegments );\n\t\tphiSegments = Math.max( 1, phiSegments );\n\n\t\t// buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\n\t\t// some helper variables\n\n\t\tlet radius = innerRadius;\n\t\tconst radiusStep = ( ( outerRadius - innerRadius ) / phiSegments );\n\t\tconst vertex = new Vector3();\n\t\tconst uv = new Vector2();\n\n\t\t// generate vertices, normals and uvs\n\n\t\tfor ( let j = 0; j <= phiSegments; j ++ ) {\n\n\t\t\tfor ( let i = 0; i <= thetaSegments; i ++ ) {\n\n\t\t\t\t// values are generate from the inside of the ring to the outside\n\n\t\t\t\tconst segment = thetaStart + i / thetaSegments * thetaLength;\n\n\t\t\t\t// vertex\n\n\t\t\t\tvertex.x = radius * Math.cos( segment );\n\t\t\t\tvertex.y = radius * Math.sin( segment );\n\n\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t\t// normal\n\n\t\t\t\tnormals.push( 0, 0, 1 );\n\n\t\t\t\t// uv\n\n\t\t\t\tuv.x = ( vertex.x / outerRadius + 1 ) / 2;\n\t\t\t\tuv.y = ( vertex.y / outerRadius + 1 ) / 2;\n\n\t\t\t\tuvs.push( uv.x, uv.y );\n\n\t\t\t}\n\n\t\t\t// increase the radius for next row of vertices\n\n\t\t\tradius += radiusStep;\n\n\t\t}\n\n\t\t// indices\n\n\t\tfor ( let j = 0; j < phiSegments; j ++ ) {\n\n\t\t\tconst thetaSegmentLevel = j * ( thetaSegments + 1 );\n\n\t\t\tfor ( let i = 0; i < thetaSegments; i ++ ) {\n\n\t\t\t\tconst segment = i + thetaSegmentLevel;\n\n\t\t\t\tconst a = segment;\n\t\t\t\tconst b = segment + thetaSegments + 1;\n\t\t\t\tconst c = segment + thetaSegments + 2;\n\t\t\t\tconst d = segment + 1;\n\n\t\t\t\t// faces\n\n\t\t\t\tindices.push( a, b, d );\n\t\t\t\tindices.push( b, c, d );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// build geometry\n\n\t\tthis.setIndex( indices );\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tthis.setAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new RingGeometry( data.innerRadius, data.outerRadius, data.thetaSegments, data.phiSegments, data.thetaStart, data.thetaLength );\n\n\t}\n\n}\n\nclass ShapeGeometry extends BufferGeometry {\n\n\tconstructor( shapes = new Shape( [ new Vector2( 0, 0.5 ), new Vector2( - 0.5, - 0.5 ), new Vector2( 0.5, - 0.5 ) ] ), curveSegments = 12 ) {\n\n\t\tsuper();\n\t\tthis.type = 'ShapeGeometry';\n\n\t\tthis.parameters = {\n\t\t\tshapes: shapes,\n\t\t\tcurveSegments: curveSegments\n\t\t};\n\n\t\t// buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\n\t\t// helper variables\n\n\t\tlet groupStart = 0;\n\t\tlet groupCount = 0;\n\n\t\t// allow single and array values for \"shapes\" parameter\n\n\t\tif ( Array.isArray( shapes ) === false ) {\n\n\t\t\taddShape( shapes );\n\n\t\t} else {\n\n\t\t\tfor ( let i = 0; i < shapes.length; i ++ ) {\n\n\t\t\t\taddShape( shapes[ i ] );\n\n\t\t\t\tthis.addGroup( groupStart, groupCount, i ); // enables MultiMaterial support\n\n\t\t\t\tgroupStart += groupCount;\n\t\t\t\tgroupCount = 0;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// build geometry\n\n\t\tthis.setIndex( indices );\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tthis.setAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\n\t\t// helper functions\n\n\t\tfunction addShape( shape ) {\n\n\t\t\tconst indexOffset = vertices.length / 3;\n\t\t\tconst points = shape.extractPoints( curveSegments );\n\n\t\t\tlet shapeVertices = points.shape;\n\t\t\tconst shapeHoles = points.holes;\n\n\t\t\t// check direction of vertices\n\n\t\t\tif ( ShapeUtils.isClockWise( shapeVertices ) === false ) {\n\n\t\t\t\tshapeVertices = shapeVertices.reverse();\n\n\t\t\t}\n\n\t\t\tfor ( let i = 0, l = shapeHoles.length; i < l; i ++ ) {\n\n\t\t\t\tconst shapeHole = shapeHoles[ i ];\n\n\t\t\t\tif ( ShapeUtils.isClockWise( shapeHole ) === true ) {\n\n\t\t\t\t\tshapeHoles[ i ] = shapeHole.reverse();\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tconst faces = ShapeUtils.triangulateShape( shapeVertices, shapeHoles );\n\n\t\t\t// join vertices of inner and outer paths to a single array\n\n\t\t\tfor ( let i = 0, l = shapeHoles.length; i < l; i ++ ) {\n\n\t\t\t\tconst shapeHole = shapeHoles[ i ];\n\t\t\t\tshapeVertices = shapeVertices.concat( shapeHole );\n\n\t\t\t}\n\n\t\t\t// vertices, normals, uvs\n\n\t\t\tfor ( let i = 0, l = shapeVertices.length; i < l; i ++ ) {\n\n\t\t\t\tconst vertex = shapeVertices[ i ];\n\n\t\t\t\tvertices.push( vertex.x, vertex.y, 0 );\n\t\t\t\tnormals.push( 0, 0, 1 );\n\t\t\t\tuvs.push( vertex.x, vertex.y ); // world uvs\n\n\t\t\t}\n\n\t\t\t// incides\n\n\t\t\tfor ( let i = 0, l = faces.length; i < l; i ++ ) {\n\n\t\t\t\tconst face = faces[ i ];\n\n\t\t\t\tconst a = face[ 0 ] + indexOffset;\n\t\t\t\tconst b = face[ 1 ] + indexOffset;\n\t\t\t\tconst c = face[ 2 ] + indexOffset;\n\n\t\t\t\tindices.push( a, b, c );\n\t\t\t\tgroupCount += 3;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tconst shapes = this.parameters.shapes;\n\n\t\treturn toJSON( shapes, data );\n\n\t}\n\n\tstatic fromJSON( data, shapes ) {\n\n\t\tconst geometryShapes = [];\n\n\t\tfor ( let j = 0, jl = data.shapes.length; j < jl; j ++ ) {\n\n\t\t\tconst shape = shapes[ data.shapes[ j ] ];\n\n\t\t\tgeometryShapes.push( shape );\n\n\t\t}\n\n\t\treturn new ShapeGeometry( geometryShapes, data.curveSegments );\n\n\t}\n\n}\n\nfunction toJSON( shapes, data ) {\n\n\tdata.shapes = [];\n\n\tif ( Array.isArray( shapes ) ) {\n\n\t\tfor ( let i = 0, l = shapes.length; i < l; i ++ ) {\n\n\t\t\tconst shape = shapes[ i ];\n\n\t\t\tdata.shapes.push( shape.uuid );\n\n\t\t}\n\n\t} else {\n\n\t\tdata.shapes.push( shapes.uuid );\n\n\t}\n\n\treturn data;\n\n}\n\nclass SphereGeometry extends BufferGeometry {\n\n\tconstructor( radius = 1, widthSegments = 32, heightSegments = 16, phiStart = 0, phiLength = Math.PI * 2, thetaStart = 0, thetaLength = Math.PI ) {\n\n\t\tsuper();\n\t\tthis.type = 'SphereGeometry';\n\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\twidthSegments: widthSegments,\n\t\t\theightSegments: heightSegments,\n\t\t\tphiStart: phiStart,\n\t\t\tphiLength: phiLength,\n\t\t\tthetaStart: thetaStart,\n\t\t\tthetaLength: thetaLength\n\t\t};\n\n\t\twidthSegments = Math.max( 3, Math.floor( widthSegments ) );\n\t\theightSegments = Math.max( 2, Math.floor( heightSegments ) );\n\n\t\tconst thetaEnd = Math.min( thetaStart + thetaLength, Math.PI );\n\n\t\tlet index = 0;\n\t\tconst grid = [];\n\n\t\tconst vertex = new Vector3();\n\t\tconst normal = new Vector3();\n\n\t\t// buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\n\t\t// generate vertices, normals and uvs\n\n\t\tfor ( let iy = 0; iy <= heightSegments; iy ++ ) {\n\n\t\t\tconst verticesRow = [];\n\n\t\t\tconst v = iy / heightSegments;\n\n\t\t\t// special case for the poles\n\n\t\t\tlet uOffset = 0;\n\n\t\t\tif ( iy == 0 && thetaStart == 0 ) {\n\n\t\t\t\tuOffset = 0.5 / widthSegments;\n\n\t\t\t} else if ( iy == heightSegments && thetaEnd == Math.PI ) {\n\n\t\t\t\tuOffset = - 0.5 / widthSegments;\n\n\t\t\t}\n\n\t\t\tfor ( let ix = 0; ix <= widthSegments; ix ++ ) {\n\n\t\t\t\tconst u = ix / widthSegments;\n\n\t\t\t\t// vertex\n\n\t\t\t\tvertex.x = - radius * Math.cos( phiStart + u * phiLength ) * Math.sin( thetaStart + v * thetaLength );\n\t\t\t\tvertex.y = radius * Math.cos( thetaStart + v * thetaLength );\n\t\t\t\tvertex.z = radius * Math.sin( phiStart + u * phiLength ) * Math.sin( thetaStart + v * thetaLength );\n\n\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t\t// normal\n\n\t\t\t\tnormal.copy( vertex ).normalize();\n\t\t\t\tnormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t\t// uv\n\n\t\t\t\tuvs.push( u + uOffset, 1 - v );\n\n\t\t\t\tverticesRow.push( index ++ );\n\n\t\t\t}\n\n\t\t\tgrid.push( verticesRow );\n\n\t\t}\n\n\t\t// indices\n\n\t\tfor ( let iy = 0; iy < heightSegments; iy ++ ) {\n\n\t\t\tfor ( let ix = 0; ix < widthSegments; ix ++ ) {\n\n\t\t\t\tconst a = grid[ iy ][ ix + 1 ];\n\t\t\t\tconst b = grid[ iy ][ ix ];\n\t\t\t\tconst c = grid[ iy + 1 ][ ix ];\n\t\t\t\tconst d = grid[ iy + 1 ][ ix + 1 ];\n\n\t\t\t\tif ( iy !== 0 || thetaStart > 0 ) indices.push( a, b, d );\n\t\t\t\tif ( iy !== heightSegments - 1 || thetaEnd < Math.PI ) indices.push( b, c, d );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// build geometry\n\n\t\tthis.setIndex( indices );\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tthis.setAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new SphereGeometry( data.radius, data.widthSegments, data.heightSegments, data.phiStart, data.phiLength, data.thetaStart, data.thetaLength );\n\n\t}\n\n}\n\nclass TetrahedronGeometry extends PolyhedronGeometry {\n\n\tconstructor( radius = 1, detail = 0 ) {\n\n\t\tconst vertices = [\n\t\t\t1, 1, 1, \t- 1, - 1, 1, \t- 1, 1, - 1, \t1, - 1, - 1\n\t\t];\n\n\t\tconst indices = [\n\t\t\t2, 1, 0, \t0, 3, 2,\t1, 3, 0,\t2, 3, 1\n\t\t];\n\n\t\tsuper( vertices, indices, radius, detail );\n\n\t\tthis.type = 'TetrahedronGeometry';\n\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\tdetail: detail\n\t\t};\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new TetrahedronGeometry( data.radius, data.detail );\n\n\t}\n\n}\n\nclass TorusGeometry extends BufferGeometry {\n\n\tconstructor( radius = 1, tube = 0.4, radialSegments = 8, tubularSegments = 6, arc = Math.PI * 2 ) {\n\n\t\tsuper();\n\t\tthis.type = 'TorusGeometry';\n\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\ttube: tube,\n\t\t\tradialSegments: radialSegments,\n\t\t\ttubularSegments: tubularSegments,\n\t\t\tarc: arc\n\t\t};\n\n\t\tradialSegments = Math.floor( radialSegments );\n\t\ttubularSegments = Math.floor( tubularSegments );\n\n\t\t// buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\n\t\t// helper variables\n\n\t\tconst center = new Vector3();\n\t\tconst vertex = new Vector3();\n\t\tconst normal = new Vector3();\n\n\t\t// generate vertices, normals and uvs\n\n\t\tfor ( let j = 0; j <= radialSegments; j ++ ) {\n\n\t\t\tfor ( let i = 0; i <= tubularSegments; i ++ ) {\n\n\t\t\t\tconst u = i / tubularSegments * arc;\n\t\t\t\tconst v = j / radialSegments * Math.PI * 2;\n\n\t\t\t\t// vertex\n\n\t\t\t\tvertex.x = ( radius + tube * Math.cos( v ) ) * Math.cos( u );\n\t\t\t\tvertex.y = ( radius + tube * Math.cos( v ) ) * Math.sin( u );\n\t\t\t\tvertex.z = tube * Math.sin( v );\n\n\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t\t// normal\n\n\t\t\t\tcenter.x = radius * Math.cos( u );\n\t\t\t\tcenter.y = radius * Math.sin( u );\n\t\t\t\tnormal.subVectors( vertex, center ).normalize();\n\n\t\t\t\tnormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t\t// uv\n\n\t\t\t\tuvs.push( i / tubularSegments );\n\t\t\t\tuvs.push( j / radialSegments );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// generate indices\n\n\t\tfor ( let j = 1; j <= radialSegments; j ++ ) {\n\n\t\t\tfor ( let i = 1; i <= tubularSegments; i ++ ) {\n\n\t\t\t\t// indices\n\n\t\t\t\tconst a = ( tubularSegments + 1 ) * j + i - 1;\n\t\t\t\tconst b = ( tubularSegments + 1 ) * ( j - 1 ) + i - 1;\n\t\t\t\tconst c = ( tubularSegments + 1 ) * ( j - 1 ) + i;\n\t\t\t\tconst d = ( tubularSegments + 1 ) * j + i;\n\n\t\t\t\t// faces\n\n\t\t\t\tindices.push( a, b, d );\n\t\t\t\tindices.push( b, c, d );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// build geometry\n\n\t\tthis.setIndex( indices );\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tthis.setAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new TorusGeometry( data.radius, data.tube, data.radialSegments, data.tubularSegments, data.arc );\n\n\t}\n\n}\n\nclass TorusKnotGeometry extends BufferGeometry {\n\n\tconstructor( radius = 1, tube = 0.4, tubularSegments = 64, radialSegments = 8, p = 2, q = 3 ) {\n\n\t\tsuper();\n\t\tthis.type = 'TorusKnotGeometry';\n\n\t\tthis.parameters = {\n\t\t\tradius: radius,\n\t\t\ttube: tube,\n\t\t\ttubularSegments: tubularSegments,\n\t\t\tradialSegments: radialSegments,\n\t\t\tp: p,\n\t\t\tq: q\n\t\t};\n\n\t\ttubularSegments = Math.floor( tubularSegments );\n\t\tradialSegments = Math.floor( radialSegments );\n\n\t\t// buffers\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\n\t\t// helper variables\n\n\t\tconst vertex = new Vector3();\n\t\tconst normal = new Vector3();\n\n\t\tconst P1 = new Vector3();\n\t\tconst P2 = new Vector3();\n\n\t\tconst B = new Vector3();\n\t\tconst T = new Vector3();\n\t\tconst N = new Vector3();\n\n\t\t// generate vertices, normals and uvs\n\n\t\tfor ( let i = 0; i <= tubularSegments; ++ i ) {\n\n\t\t\t// the radian \"u\" is used to calculate the position on the torus curve of the current tubular segment\n\n\t\t\tconst u = i / tubularSegments * p * Math.PI * 2;\n\n\t\t\t// now we calculate two points. P1 is our current position on the curve, P2 is a little farther ahead.\n\t\t\t// these points are used to create a special \"coordinate space\", which is necessary to calculate the correct vertex positions\n\n\t\t\tcalculatePositionOnCurve( u, p, q, radius, P1 );\n\t\t\tcalculatePositionOnCurve( u + 0.01, p, q, radius, P2 );\n\n\t\t\t// calculate orthonormal basis\n\n\t\t\tT.subVectors( P2, P1 );\n\t\t\tN.addVectors( P2, P1 );\n\t\t\tB.crossVectors( T, N );\n\t\t\tN.crossVectors( B, T );\n\n\t\t\t// normalize B, N. T can be ignored, we don't use it\n\n\t\t\tB.normalize();\n\t\t\tN.normalize();\n\n\t\t\tfor ( let j = 0; j <= radialSegments; ++ j ) {\n\n\t\t\t\t// now calculate the vertices. they are nothing more than an extrusion of the torus curve.\n\t\t\t\t// because we extrude a shape in the xy-plane, there is no need to calculate a z-value.\n\n\t\t\t\tconst v = j / radialSegments * Math.PI * 2;\n\t\t\t\tconst cx = - tube * Math.cos( v );\n\t\t\t\tconst cy = tube * Math.sin( v );\n\n\t\t\t\t// now calculate the final vertex position.\n\t\t\t\t// first we orient the extrusion with our basis vectors, then we add it to the current position on the curve\n\n\t\t\t\tvertex.x = P1.x + ( cx * N.x + cy * B.x );\n\t\t\t\tvertex.y = P1.y + ( cx * N.y + cy * B.y );\n\t\t\t\tvertex.z = P1.z + ( cx * N.z + cy * B.z );\n\n\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t\t// normal (P1 is always the center/origin of the extrusion, thus we can use it to calculate the normal)\n\n\t\t\t\tnormal.subVectors( vertex, P1 ).normalize();\n\n\t\t\t\tnormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t\t// uv\n\n\t\t\t\tuvs.push( i / tubularSegments );\n\t\t\t\tuvs.push( j / radialSegments );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// generate indices\n\n\t\tfor ( let j = 1; j <= tubularSegments; j ++ ) {\n\n\t\t\tfor ( let i = 1; i <= radialSegments; i ++ ) {\n\n\t\t\t\t// indices\n\n\t\t\t\tconst a = ( radialSegments + 1 ) * ( j - 1 ) + ( i - 1 );\n\t\t\t\tconst b = ( radialSegments + 1 ) * j + ( i - 1 );\n\t\t\t\tconst c = ( radialSegments + 1 ) * j + i;\n\t\t\t\tconst d = ( radialSegments + 1 ) * ( j - 1 ) + i;\n\n\t\t\t\t// faces\n\n\t\t\t\tindices.push( a, b, d );\n\t\t\t\tindices.push( b, c, d );\n\n\t\t\t}\n\n\t\t}\n\n\t\t// build geometry\n\n\t\tthis.setIndex( indices );\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tthis.setAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\t\t// this function calculates the current position on the torus curve\n\n\t\tfunction calculatePositionOnCurve( u, p, q, radius, position ) {\n\n\t\t\tconst cu = Math.cos( u );\n\t\t\tconst su = Math.sin( u );\n\t\t\tconst quOverP = q / p * u;\n\t\t\tconst cs = Math.cos( quOverP );\n\n\t\t\tposition.x = radius * ( 2 + cs ) * 0.5 * cu;\n\t\t\tposition.y = radius * ( 2 + cs ) * su * 0.5;\n\t\t\tposition.z = radius * Math.sin( quOverP ) * 0.5;\n\n\t\t}\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\treturn new TorusKnotGeometry( data.radius, data.tube, data.tubularSegments, data.radialSegments, data.p, data.q );\n\n\t}\n\n}\n\nclass TubeGeometry extends BufferGeometry {\n\n\tconstructor( path = new QuadraticBezierCurve3( new Vector3( - 1, - 1, 0 ), new Vector3( - 1, 1, 0 ), new Vector3( 1, 1, 0 ) ), tubularSegments = 64, radius = 1, radialSegments = 8, closed = false ) {\n\n\t\tsuper();\n\t\tthis.type = 'TubeGeometry';\n\n\t\tthis.parameters = {\n\t\t\tpath: path,\n\t\t\ttubularSegments: tubularSegments,\n\t\t\tradius: radius,\n\t\t\tradialSegments: radialSegments,\n\t\t\tclosed: closed\n\t\t};\n\n\t\tconst frames = path.computeFrenetFrames( tubularSegments, closed );\n\n\t\t// expose internals\n\n\t\tthis.tangents = frames.tangents;\n\t\tthis.normals = frames.normals;\n\t\tthis.binormals = frames.binormals;\n\n\t\t// helper variables\n\n\t\tconst vertex = new Vector3();\n\t\tconst normal = new Vector3();\n\t\tconst uv = new Vector2();\n\t\tlet P = new Vector3();\n\n\t\t// buffer\n\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\t\tconst indices = [];\n\n\t\t// create buffer data\n\n\t\tgenerateBufferData();\n\n\t\t// build geometry\n\n\t\tthis.setIndex( indices );\n\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tthis.setAttribute( 'normal', new Float32BufferAttribute( normals, 3 ) );\n\t\tthis.setAttribute( 'uv', new Float32BufferAttribute( uvs, 2 ) );\n\n\t\t// functions\n\n\t\tfunction generateBufferData() {\n\n\t\t\tfor ( let i = 0; i < tubularSegments; i ++ ) {\n\n\t\t\t\tgenerateSegment( i );\n\n\t\t\t}\n\n\t\t\t// if the geometry is not closed, generate the last row of vertices and normals\n\t\t\t// at the regular position on the given path\n\t\t\t//\n\t\t\t// if the geometry is closed, duplicate the first row of vertices and normals (uvs will differ)\n\n\t\t\tgenerateSegment( ( closed === false ) ? tubularSegments : 0 );\n\n\t\t\t// uvs are generated in a separate function.\n\t\t\t// this makes it easy compute correct values for closed geometries\n\n\t\t\tgenerateUVs();\n\n\t\t\t// finally create faces\n\n\t\t\tgenerateIndices();\n\n\t\t}\n\n\t\tfunction generateSegment( i ) {\n\n\t\t\t// we use getPointAt to sample evenly distributed points from the given path\n\n\t\t\tP = path.getPointAt( i / tubularSegments, P );\n\n\t\t\t// retrieve corresponding normal and binormal\n\n\t\t\tconst N = frames.normals[ i ];\n\t\t\tconst B = frames.binormals[ i ];\n\n\t\t\t// generate normals and vertices for the current segment\n\n\t\t\tfor ( let j = 0; j <= radialSegments; j ++ ) {\n\n\t\t\t\tconst v = j / radialSegments * Math.PI * 2;\n\n\t\t\t\tconst sin = Math.sin( v );\n\t\t\t\tconst cos = - Math.cos( v );\n\n\t\t\t\t// normal\n\n\t\t\t\tnormal.x = ( cos * N.x + sin * B.x );\n\t\t\t\tnormal.y = ( cos * N.y + sin * B.y );\n\t\t\t\tnormal.z = ( cos * N.z + sin * B.z );\n\t\t\t\tnormal.normalize();\n\n\t\t\t\tnormals.push( normal.x, normal.y, normal.z );\n\n\t\t\t\t// vertex\n\n\t\t\t\tvertex.x = P.x + radius * normal.x;\n\t\t\t\tvertex.y = P.y + radius * normal.y;\n\t\t\t\tvertex.z = P.z + radius * normal.z;\n\n\t\t\t\tvertices.push( vertex.x, vertex.y, vertex.z );\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction generateIndices() {\n\n\t\t\tfor ( let j = 1; j <= tubularSegments; j ++ ) {\n\n\t\t\t\tfor ( let i = 1; i <= radialSegments; i ++ ) {\n\n\t\t\t\t\tconst a = ( radialSegments + 1 ) * ( j - 1 ) + ( i - 1 );\n\t\t\t\t\tconst b = ( radialSegments + 1 ) * j + ( i - 1 );\n\t\t\t\t\tconst c = ( radialSegments + 1 ) * j + i;\n\t\t\t\t\tconst d = ( radialSegments + 1 ) * ( j - 1 ) + i;\n\n\t\t\t\t\t// faces\n\n\t\t\t\t\tindices.push( a, b, d );\n\t\t\t\t\tindices.push( b, c, d );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tfunction generateUVs() {\n\n\t\t\tfor ( let i = 0; i <= tubularSegments; i ++ ) {\n\n\t\t\t\tfor ( let j = 0; j <= radialSegments; j ++ ) {\n\n\t\t\t\t\tuv.x = i / tubularSegments;\n\t\t\t\t\tuv.y = j / radialSegments;\n\n\t\t\t\t\tuvs.push( uv.x, uv.y );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON();\n\n\t\tdata.path = this.parameters.path.toJSON();\n\n\t\treturn data;\n\n\t}\n\n\tstatic fromJSON( data ) {\n\n\t\t// This only works for built-in curves (e.g. CatmullRomCurve3).\n\t\t// User defined curves or instances of CurvePath will not be deserialized.\n\t\treturn new TubeGeometry(\n\t\t\tnew Curves[ data.path.type ]().fromJSON( data.path ),\n\t\t\tdata.tubularSegments,\n\t\t\tdata.radius,\n\t\t\tdata.radialSegments,\n\t\t\tdata.closed\n\t\t);\n\n\t}\n\n}\n\nclass WireframeGeometry extends BufferGeometry {\n\n\tconstructor( geometry = null ) {\n\n\t\tsuper();\n\t\tthis.type = 'WireframeGeometry';\n\n\t\tthis.parameters = {\n\t\t\tgeometry: geometry\n\t\t};\n\n\t\tif ( geometry !== null ) {\n\n\t\t\t// buffer\n\n\t\t\tconst vertices = [];\n\t\t\tconst edges = new Set();\n\n\t\t\t// helper variables\n\n\t\t\tconst start = new Vector3();\n\t\t\tconst end = new Vector3();\n\n\t\t\tif ( geometry.index !== null ) {\n\n\t\t\t\t// indexed BufferGeometry\n\n\t\t\t\tconst position = geometry.attributes.position;\n\t\t\t\tconst indices = geometry.index;\n\t\t\t\tlet groups = geometry.groups;\n\n\t\t\t\tif ( groups.length === 0 ) {\n\n\t\t\t\t\tgroups = [ { start: 0, count: indices.count, materialIndex: 0 } ];\n\n\t\t\t\t}\n\n\t\t\t\t// create a data structure that contains all edges without duplicates\n\n\t\t\t\tfor ( let o = 0, ol = groups.length; o < ol; ++ o ) {\n\n\t\t\t\t\tconst group = groups[ o ];\n\n\t\t\t\t\tconst groupStart = group.start;\n\t\t\t\t\tconst groupCount = group.count;\n\n\t\t\t\t\tfor ( let i = groupStart, l = ( groupStart + groupCount ); i < l; i += 3 ) {\n\n\t\t\t\t\t\tfor ( let j = 0; j < 3; j ++ ) {\n\n\t\t\t\t\t\t\tconst index1 = indices.getX( i + j );\n\t\t\t\t\t\t\tconst index2 = indices.getX( i + ( j + 1 ) % 3 );\n\n\t\t\t\t\t\t\tstart.fromBufferAttribute( position, index1 );\n\t\t\t\t\t\t\tend.fromBufferAttribute( position, index2 );\n\n\t\t\t\t\t\t\tif ( isUniqueEdge( start, end, edges ) === true ) {\n\n\t\t\t\t\t\t\t\tvertices.push( start.x, start.y, start.z );\n\t\t\t\t\t\t\t\tvertices.push( end.x, end.y, end.z );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\t// non-indexed BufferGeometry\n\n\t\t\t\tconst position = geometry.attributes.position;\n\n\t\t\t\tfor ( let i = 0, l = ( position.count / 3 ); i < l; i ++ ) {\n\n\t\t\t\t\tfor ( let j = 0; j < 3; j ++ ) {\n\n\t\t\t\t\t\t// three edges per triangle, an edge is represented as (index1, index2)\n\t\t\t\t\t\t// e.g. the first triangle has the following edges: (0,1),(1,2),(2,0)\n\n\t\t\t\t\t\tconst index1 = 3 * i + j;\n\t\t\t\t\t\tconst index2 = 3 * i + ( ( j + 1 ) % 3 );\n\n\t\t\t\t\t\tstart.fromBufferAttribute( position, index1 );\n\t\t\t\t\t\tend.fromBufferAttribute( position, index2 );\n\n\t\t\t\t\t\tif ( isUniqueEdge( start, end, edges ) === true ) {\n\n\t\t\t\t\t\t\tvertices.push( start.x, start.y, start.z );\n\t\t\t\t\t\t\tvertices.push( end.x, end.y, end.z );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// build geometry\n\n\t\t\tthis.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\n\t\t}\n\n\t}\n\n}\n\nfunction isUniqueEdge( start, end, edges ) {\n\n\tconst hash1 = `${start.x},${start.y},${start.z}-${end.x},${end.y},${end.z}`;\n\tconst hash2 = `${end.x},${end.y},${end.z}-${start.x},${start.y},${start.z}`; // coincident edge\n\n\tif ( edges.has( hash1 ) === true || edges.has( hash2 ) === true ) {\n\n\t\treturn false;\n\n\t} else {\n\n\t\tedges.add( hash1 );\n\t\tedges.add( hash2 );\n\t\treturn true;\n\n\t}\n\n}\n\nvar Geometries = /*#__PURE__*/Object.freeze({\n\t__proto__: null,\n\tBoxGeometry: BoxGeometry,\n\tBoxBufferGeometry: BoxGeometry,\n\tCapsuleGeometry: CapsuleGeometry,\n\tCapsuleBufferGeometry: CapsuleGeometry,\n\tCircleGeometry: CircleGeometry,\n\tCircleBufferGeometry: CircleGeometry,\n\tConeGeometry: ConeGeometry,\n\tConeBufferGeometry: ConeGeometry,\n\tCylinderGeometry: CylinderGeometry,\n\tCylinderBufferGeometry: CylinderGeometry,\n\tDodecahedronGeometry: DodecahedronGeometry,\n\tDodecahedronBufferGeometry: DodecahedronGeometry,\n\tEdgesGeometry: EdgesGeometry,\n\tExtrudeGeometry: ExtrudeGeometry,\n\tExtrudeBufferGeometry: ExtrudeGeometry,\n\tIcosahedronGeometry: IcosahedronGeometry,\n\tIcosahedronBufferGeometry: IcosahedronGeometry,\n\tLatheGeometry: LatheGeometry,\n\tLatheBufferGeometry: LatheGeometry,\n\tOctahedronGeometry: OctahedronGeometry,\n\tOctahedronBufferGeometry: OctahedronGeometry,\n\tPlaneGeometry: PlaneGeometry,\n\tPlaneBufferGeometry: PlaneGeometry,\n\tPolyhedronGeometry: PolyhedronGeometry,\n\tPolyhedronBufferGeometry: PolyhedronGeometry,\n\tRingGeometry: RingGeometry,\n\tRingBufferGeometry: RingGeometry,\n\tShapeGeometry: ShapeGeometry,\n\tShapeBufferGeometry: ShapeGeometry,\n\tSphereGeometry: SphereGeometry,\n\tSphereBufferGeometry: SphereGeometry,\n\tTetrahedronGeometry: TetrahedronGeometry,\n\tTetrahedronBufferGeometry: TetrahedronGeometry,\n\tTorusGeometry: TorusGeometry,\n\tTorusBufferGeometry: TorusGeometry,\n\tTorusKnotGeometry: TorusKnotGeometry,\n\tTorusKnotBufferGeometry: TorusKnotGeometry,\n\tTubeGeometry: TubeGeometry,\n\tTubeBufferGeometry: TubeGeometry,\n\tWireframeGeometry: WireframeGeometry\n});\n\nclass ShadowMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isShadowMaterial = true;\n\n\t\tthis.type = 'ShadowMaterial';\n\n\t\tthis.color = new Color( 0x000000 );\n\t\tthis.transparent = true;\n\n\t\tthis.fog = true;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.color.copy( source.color );\n\n\t\tthis.fog = source.fog;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass RawShaderMaterial extends ShaderMaterial {\n\n\tconstructor( parameters ) {\n\n\t\tsuper( parameters );\n\n\t\tthis.isRawShaderMaterial = true;\n\n\t\tthis.type = 'RawShaderMaterial';\n\n\t}\n\n}\n\nclass MeshStandardMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isMeshStandardMaterial = true;\n\n\t\tthis.defines = { 'STANDARD': '' };\n\n\t\tthis.type = 'MeshStandardMaterial';\n\n\t\tthis.color = new Color( 0xffffff ); // diffuse\n\t\tthis.roughness = 1.0;\n\t\tthis.metalness = 0.0;\n\n\t\tthis.map = null;\n\n\t\tthis.lightMap = null;\n\t\tthis.lightMapIntensity = 1.0;\n\n\t\tthis.aoMap = null;\n\t\tthis.aoMapIntensity = 1.0;\n\n\t\tthis.emissive = new Color( 0x000000 );\n\t\tthis.emissiveIntensity = 1.0;\n\t\tthis.emissiveMap = null;\n\n\t\tthis.bumpMap = null;\n\t\tthis.bumpScale = 1;\n\n\t\tthis.normalMap = null;\n\t\tthis.normalMapType = TangentSpaceNormalMap;\n\t\tthis.normalScale = new Vector2( 1, 1 );\n\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\n\t\tthis.roughnessMap = null;\n\n\t\tthis.metalnessMap = null;\n\n\t\tthis.alphaMap = null;\n\n\t\tthis.envMap = null;\n\t\tthis.envMapIntensity = 1.0;\n\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.wireframeLinecap = 'round';\n\t\tthis.wireframeLinejoin = 'round';\n\n\t\tthis.flatShading = false;\n\n\t\tthis.fog = true;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.defines = { 'STANDARD': '' };\n\n\t\tthis.color.copy( source.color );\n\t\tthis.roughness = source.roughness;\n\t\tthis.metalness = source.metalness;\n\n\t\tthis.map = source.map;\n\n\t\tthis.lightMap = source.lightMap;\n\t\tthis.lightMapIntensity = source.lightMapIntensity;\n\n\t\tthis.aoMap = source.aoMap;\n\t\tthis.aoMapIntensity = source.aoMapIntensity;\n\n\t\tthis.emissive.copy( source.emissive );\n\t\tthis.emissiveMap = source.emissiveMap;\n\t\tthis.emissiveIntensity = source.emissiveIntensity;\n\n\t\tthis.bumpMap = source.bumpMap;\n\t\tthis.bumpScale = source.bumpScale;\n\n\t\tthis.normalMap = source.normalMap;\n\t\tthis.normalMapType = source.normalMapType;\n\t\tthis.normalScale.copy( source.normalScale );\n\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\n\t\tthis.roughnessMap = source.roughnessMap;\n\n\t\tthis.metalnessMap = source.metalnessMap;\n\n\t\tthis.alphaMap = source.alphaMap;\n\n\t\tthis.envMap = source.envMap;\n\t\tthis.envMapIntensity = source.envMapIntensity;\n\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\tthis.wireframeLinecap = source.wireframeLinecap;\n\t\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\n\t\tthis.flatShading = source.flatShading;\n\n\t\tthis.fog = source.fog;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass MeshPhysicalMaterial extends MeshStandardMaterial {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isMeshPhysicalMaterial = true;\n\n\t\tthis.defines = {\n\n\t\t\t'STANDARD': '',\n\t\t\t'PHYSICAL': ''\n\n\t\t};\n\n\t\tthis.type = 'MeshPhysicalMaterial';\n\n\t\tthis.clearcoatMap = null;\n\t\tthis.clearcoatRoughness = 0.0;\n\t\tthis.clearcoatRoughnessMap = null;\n\t\tthis.clearcoatNormalScale = new Vector2( 1, 1 );\n\t\tthis.clearcoatNormalMap = null;\n\n\t\tthis.ior = 1.5;\n\n\t\tObject.defineProperty( this, 'reflectivity', {\n\t\t\tget: function () {\n\n\t\t\t\treturn ( clamp( 2.5 * ( this.ior - 1 ) / ( this.ior + 1 ), 0, 1 ) );\n\n\t\t\t},\n\t\t\tset: function ( reflectivity ) {\n\n\t\t\t\tthis.ior = ( 1 + 0.4 * reflectivity ) / ( 1 - 0.4 * reflectivity );\n\n\t\t\t}\n\t\t} );\n\n\t\tthis.iridescenceMap = null;\n\t\tthis.iridescenceIOR = 1.3;\n\t\tthis.iridescenceThicknessRange = [ 100, 400 ];\n\t\tthis.iridescenceThicknessMap = null;\n\n\t\tthis.sheenColor = new Color( 0x000000 );\n\t\tthis.sheenColorMap = null;\n\t\tthis.sheenRoughness = 1.0;\n\t\tthis.sheenRoughnessMap = null;\n\n\t\tthis.transmissionMap = null;\n\n\t\tthis.thickness = 0;\n\t\tthis.thicknessMap = null;\n\t\tthis.attenuationDistance = 0.0;\n\t\tthis.attenuationColor = new Color( 1, 1, 1 );\n\n\t\tthis.specularIntensity = 1.0;\n\t\tthis.specularIntensityMap = null;\n\t\tthis.specularColor = new Color( 1, 1, 1 );\n\t\tthis.specularColorMap = null;\n\n\t\tthis._sheen = 0.0;\n\t\tthis._clearcoat = 0;\n\t\tthis._iridescence = 0;\n\t\tthis._transmission = 0;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tget sheen() {\n\n\t\treturn this._sheen;\n\n\t}\n\n\tset sheen( value ) {\n\n\t\tif ( this._sheen > 0 !== value > 0 ) {\n\n\t\t\tthis.version ++;\n\n\t\t}\n\n\t\tthis._sheen = value;\n\n\t}\n\n\tget clearcoat() {\n\n\t\treturn this._clearcoat;\n\n\t}\n\n\tset clearcoat( value ) {\n\n\t\tif ( this._clearcoat > 0 !== value > 0 ) {\n\n\t\t\tthis.version ++;\n\n\t\t}\n\n\t\tthis._clearcoat = value;\n\n\t}\n\n\tget iridescence() {\n\n\t\treturn this._iridescence;\n\n\t}\n\n\tset iridescence( value ) {\n\n\t\tif ( this._iridescence > 0 !== value > 0 ) {\n\n\t\t\tthis.version ++;\n\n\t\t}\n\n\t\tthis._iridescence = value;\n\n\t}\n\n\tget transmission() {\n\n\t\treturn this._transmission;\n\n\t}\n\n\tset transmission( value ) {\n\n\t\tif ( this._transmission > 0 !== value > 0 ) {\n\n\t\t\tthis.version ++;\n\n\t\t}\n\n\t\tthis._transmission = value;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.defines = {\n\n\t\t\t'STANDARD': '',\n\t\t\t'PHYSICAL': ''\n\n\t\t};\n\n\t\tthis.clearcoat = source.clearcoat;\n\t\tthis.clearcoatMap = source.clearcoatMap;\n\t\tthis.clearcoatRoughness = source.clearcoatRoughness;\n\t\tthis.clearcoatRoughnessMap = source.clearcoatRoughnessMap;\n\t\tthis.clearcoatNormalMap = source.clearcoatNormalMap;\n\t\tthis.clearcoatNormalScale.copy( source.clearcoatNormalScale );\n\n\t\tthis.ior = source.ior;\n\n\t\tthis.iridescence = source.iridescence;\n\t\tthis.iridescenceMap = source.iridescenceMap;\n\t\tthis.iridescenceIOR = source.iridescenceIOR;\n\t\tthis.iridescenceThicknessRange = [ ...source.iridescenceThicknessRange ];\n\t\tthis.iridescenceThicknessMap = source.iridescenceThicknessMap;\n\n\t\tthis.sheen = source.sheen;\n\t\tthis.sheenColor.copy( source.sheenColor );\n\t\tthis.sheenColorMap = source.sheenColorMap;\n\t\tthis.sheenRoughness = source.sheenRoughness;\n\t\tthis.sheenRoughnessMap = source.sheenRoughnessMap;\n\n\t\tthis.transmission = source.transmission;\n\t\tthis.transmissionMap = source.transmissionMap;\n\n\t\tthis.thickness = source.thickness;\n\t\tthis.thicknessMap = source.thicknessMap;\n\t\tthis.attenuationDistance = source.attenuationDistance;\n\t\tthis.attenuationColor.copy( source.attenuationColor );\n\n\t\tthis.specularIntensity = source.specularIntensity;\n\t\tthis.specularIntensityMap = source.specularIntensityMap;\n\t\tthis.specularColor.copy( source.specularColor );\n\t\tthis.specularColorMap = source.specularColorMap;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass MeshPhongMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isMeshPhongMaterial = true;\n\n\t\tthis.type = 'MeshPhongMaterial';\n\n\t\tthis.color = new Color( 0xffffff ); // diffuse\n\t\tthis.specular = new Color( 0x111111 );\n\t\tthis.shininess = 30;\n\n\t\tthis.map = null;\n\n\t\tthis.lightMap = null;\n\t\tthis.lightMapIntensity = 1.0;\n\n\t\tthis.aoMap = null;\n\t\tthis.aoMapIntensity = 1.0;\n\n\t\tthis.emissive = new Color( 0x000000 );\n\t\tthis.emissiveIntensity = 1.0;\n\t\tthis.emissiveMap = null;\n\n\t\tthis.bumpMap = null;\n\t\tthis.bumpScale = 1;\n\n\t\tthis.normalMap = null;\n\t\tthis.normalMapType = TangentSpaceNormalMap;\n\t\tthis.normalScale = new Vector2( 1, 1 );\n\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\n\t\tthis.specularMap = null;\n\n\t\tthis.alphaMap = null;\n\n\t\tthis.envMap = null;\n\t\tthis.combine = MultiplyOperation;\n\t\tthis.reflectivity = 1;\n\t\tthis.refractionRatio = 0.98;\n\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.wireframeLinecap = 'round';\n\t\tthis.wireframeLinejoin = 'round';\n\n\t\tthis.flatShading = false;\n\n\t\tthis.fog = true;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.color.copy( source.color );\n\t\tthis.specular.copy( source.specular );\n\t\tthis.shininess = source.shininess;\n\n\t\tthis.map = source.map;\n\n\t\tthis.lightMap = source.lightMap;\n\t\tthis.lightMapIntensity = source.lightMapIntensity;\n\n\t\tthis.aoMap = source.aoMap;\n\t\tthis.aoMapIntensity = source.aoMapIntensity;\n\n\t\tthis.emissive.copy( source.emissive );\n\t\tthis.emissiveMap = source.emissiveMap;\n\t\tthis.emissiveIntensity = source.emissiveIntensity;\n\n\t\tthis.bumpMap = source.bumpMap;\n\t\tthis.bumpScale = source.bumpScale;\n\n\t\tthis.normalMap = source.normalMap;\n\t\tthis.normalMapType = source.normalMapType;\n\t\tthis.normalScale.copy( source.normalScale );\n\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\n\t\tthis.specularMap = source.specularMap;\n\n\t\tthis.alphaMap = source.alphaMap;\n\n\t\tthis.envMap = source.envMap;\n\t\tthis.combine = source.combine;\n\t\tthis.reflectivity = source.reflectivity;\n\t\tthis.refractionRatio = source.refractionRatio;\n\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\tthis.wireframeLinecap = source.wireframeLinecap;\n\t\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\n\t\tthis.flatShading = source.flatShading;\n\n\t\tthis.fog = source.fog;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass MeshToonMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isMeshToonMaterial = true;\n\n\t\tthis.defines = { 'TOON': '' };\n\n\t\tthis.type = 'MeshToonMaterial';\n\n\t\tthis.color = new Color( 0xffffff );\n\n\t\tthis.map = null;\n\t\tthis.gradientMap = null;\n\n\t\tthis.lightMap = null;\n\t\tthis.lightMapIntensity = 1.0;\n\n\t\tthis.aoMap = null;\n\t\tthis.aoMapIntensity = 1.0;\n\n\t\tthis.emissive = new Color( 0x000000 );\n\t\tthis.emissiveIntensity = 1.0;\n\t\tthis.emissiveMap = null;\n\n\t\tthis.bumpMap = null;\n\t\tthis.bumpScale = 1;\n\n\t\tthis.normalMap = null;\n\t\tthis.normalMapType = TangentSpaceNormalMap;\n\t\tthis.normalScale = new Vector2( 1, 1 );\n\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\n\t\tthis.alphaMap = null;\n\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.wireframeLinecap = 'round';\n\t\tthis.wireframeLinejoin = 'round';\n\n\t\tthis.fog = true;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.color.copy( source.color );\n\n\t\tthis.map = source.map;\n\t\tthis.gradientMap = source.gradientMap;\n\n\t\tthis.lightMap = source.lightMap;\n\t\tthis.lightMapIntensity = source.lightMapIntensity;\n\n\t\tthis.aoMap = source.aoMap;\n\t\tthis.aoMapIntensity = source.aoMapIntensity;\n\n\t\tthis.emissive.copy( source.emissive );\n\t\tthis.emissiveMap = source.emissiveMap;\n\t\tthis.emissiveIntensity = source.emissiveIntensity;\n\n\t\tthis.bumpMap = source.bumpMap;\n\t\tthis.bumpScale = source.bumpScale;\n\n\t\tthis.normalMap = source.normalMap;\n\t\tthis.normalMapType = source.normalMapType;\n\t\tthis.normalScale.copy( source.normalScale );\n\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\n\t\tthis.alphaMap = source.alphaMap;\n\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\tthis.wireframeLinecap = source.wireframeLinecap;\n\t\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\n\t\tthis.fog = source.fog;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass MeshNormalMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isMeshNormalMaterial = true;\n\n\t\tthis.type = 'MeshNormalMaterial';\n\n\t\tthis.bumpMap = null;\n\t\tthis.bumpScale = 1;\n\n\t\tthis.normalMap = null;\n\t\tthis.normalMapType = TangentSpaceNormalMap;\n\t\tthis.normalScale = new Vector2( 1, 1 );\n\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\n\t\tthis.flatShading = false;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.bumpMap = source.bumpMap;\n\t\tthis.bumpScale = source.bumpScale;\n\n\t\tthis.normalMap = source.normalMap;\n\t\tthis.normalMapType = source.normalMapType;\n\t\tthis.normalScale.copy( source.normalScale );\n\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\n\t\tthis.flatShading = source.flatShading;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass MeshLambertMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isMeshLambertMaterial = true;\n\n\t\tthis.type = 'MeshLambertMaterial';\n\n\t\tthis.color = new Color( 0xffffff ); // diffuse\n\n\t\tthis.map = null;\n\n\t\tthis.lightMap = null;\n\t\tthis.lightMapIntensity = 1.0;\n\n\t\tthis.aoMap = null;\n\t\tthis.aoMapIntensity = 1.0;\n\n\t\tthis.emissive = new Color( 0x000000 );\n\t\tthis.emissiveIntensity = 1.0;\n\t\tthis.emissiveMap = null;\n\n\t\tthis.specularMap = null;\n\n\t\tthis.alphaMap = null;\n\n\t\tthis.envMap = null;\n\t\tthis.combine = MultiplyOperation;\n\t\tthis.reflectivity = 1;\n\t\tthis.refractionRatio = 0.98;\n\n\t\tthis.wireframe = false;\n\t\tthis.wireframeLinewidth = 1;\n\t\tthis.wireframeLinecap = 'round';\n\t\tthis.wireframeLinejoin = 'round';\n\n\t\tthis.fog = true;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.color.copy( source.color );\n\n\t\tthis.map = source.map;\n\n\t\tthis.lightMap = source.lightMap;\n\t\tthis.lightMapIntensity = source.lightMapIntensity;\n\n\t\tthis.aoMap = source.aoMap;\n\t\tthis.aoMapIntensity = source.aoMapIntensity;\n\n\t\tthis.emissive.copy( source.emissive );\n\t\tthis.emissiveMap = source.emissiveMap;\n\t\tthis.emissiveIntensity = source.emissiveIntensity;\n\n\t\tthis.specularMap = source.specularMap;\n\n\t\tthis.alphaMap = source.alphaMap;\n\n\t\tthis.envMap = source.envMap;\n\t\tthis.combine = source.combine;\n\t\tthis.reflectivity = source.reflectivity;\n\t\tthis.refractionRatio = source.refractionRatio;\n\n\t\tthis.wireframe = source.wireframe;\n\t\tthis.wireframeLinewidth = source.wireframeLinewidth;\n\t\tthis.wireframeLinecap = source.wireframeLinecap;\n\t\tthis.wireframeLinejoin = source.wireframeLinejoin;\n\n\t\tthis.fog = source.fog;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass MeshMatcapMaterial extends Material {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isMeshMatcapMaterial = true;\n\n\t\tthis.defines = { 'MATCAP': '' };\n\n\t\tthis.type = 'MeshMatcapMaterial';\n\n\t\tthis.color = new Color( 0xffffff ); // diffuse\n\n\t\tthis.matcap = null;\n\n\t\tthis.map = null;\n\n\t\tthis.bumpMap = null;\n\t\tthis.bumpScale = 1;\n\n\t\tthis.normalMap = null;\n\t\tthis.normalMapType = TangentSpaceNormalMap;\n\t\tthis.normalScale = new Vector2( 1, 1 );\n\n\t\tthis.displacementMap = null;\n\t\tthis.displacementScale = 1;\n\t\tthis.displacementBias = 0;\n\n\t\tthis.alphaMap = null;\n\n\t\tthis.flatShading = false;\n\n\t\tthis.fog = true;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.defines = { 'MATCAP': '' };\n\n\t\tthis.color.copy( source.color );\n\n\t\tthis.matcap = source.matcap;\n\n\t\tthis.map = source.map;\n\n\t\tthis.bumpMap = source.bumpMap;\n\t\tthis.bumpScale = source.bumpScale;\n\n\t\tthis.normalMap = source.normalMap;\n\t\tthis.normalMapType = source.normalMapType;\n\t\tthis.normalScale.copy( source.normalScale );\n\n\t\tthis.displacementMap = source.displacementMap;\n\t\tthis.displacementScale = source.displacementScale;\n\t\tthis.displacementBias = source.displacementBias;\n\n\t\tthis.alphaMap = source.alphaMap;\n\n\t\tthis.flatShading = source.flatShading;\n\n\t\tthis.fog = source.fog;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass LineDashedMaterial extends LineBasicMaterial {\n\n\tconstructor( parameters ) {\n\n\t\tsuper();\n\n\t\tthis.isLineDashedMaterial = true;\n\n\t\tthis.type = 'LineDashedMaterial';\n\n\t\tthis.scale = 1;\n\t\tthis.dashSize = 3;\n\t\tthis.gapSize = 1;\n\n\t\tthis.setValues( parameters );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.scale = source.scale;\n\t\tthis.dashSize = source.dashSize;\n\t\tthis.gapSize = source.gapSize;\n\n\t\treturn this;\n\n\t}\n\n}\n\nconst materialLib = {\n\tShadowMaterial,\n\tSpriteMaterial,\n\tRawShaderMaterial,\n\tShaderMaterial,\n\tPointsMaterial,\n\tMeshPhysicalMaterial,\n\tMeshStandardMaterial,\n\tMeshPhongMaterial,\n\tMeshToonMaterial,\n\tMeshNormalMaterial,\n\tMeshLambertMaterial,\n\tMeshDepthMaterial,\n\tMeshDistanceMaterial,\n\tMeshBasicMaterial,\n\tMeshMatcapMaterial,\n\tLineDashedMaterial,\n\tLineBasicMaterial,\n\tMaterial\n};\n\nMaterial.fromType = function ( type ) {\n\n\treturn new materialLib[ type ]();\n\n};\n\nconst AnimationUtils = {\n\n\t// same as Array.prototype.slice, but also works on typed arrays\n\tarraySlice: function ( array, from, to ) {\n\n\t\tif ( AnimationUtils.isTypedArray( array ) ) {\n\n\t\t\t// in ios9 array.subarray(from, undefined) will return empty array\n\t\t\t// but array.subarray(from) or array.subarray(from, len) is correct\n\t\t\treturn new array.constructor( array.subarray( from, to !== undefined ? to : array.length ) );\n\n\t\t}\n\n\t\treturn array.slice( from, to );\n\n\t},\n\n\t// converts an array to a specific type\n\tconvertArray: function ( array, type, forceClone ) {\n\n\t\tif ( ! array || // let 'undefined' and 'null' pass\n\t\t\t! forceClone && array.constructor === type ) return array;\n\n\t\tif ( typeof type.BYTES_PER_ELEMENT === 'number' ) {\n\n\t\t\treturn new type( array ); // create typed array\n\n\t\t}\n\n\t\treturn Array.prototype.slice.call( array ); // create Array\n\n\t},\n\n\tisTypedArray: function ( object ) {\n\n\t\treturn ArrayBuffer.isView( object ) &&\n\t\t\t! ( object instanceof DataView );\n\n\t},\n\n\t// returns an array by which times and values can be sorted\n\tgetKeyframeOrder: function ( times ) {\n\n\t\tfunction compareTime( i, j ) {\n\n\t\t\treturn times[ i ] - times[ j ];\n\n\t\t}\n\n\t\tconst n = times.length;\n\t\tconst result = new Array( n );\n\t\tfor ( let i = 0; i !== n; ++ i ) result[ i ] = i;\n\n\t\tresult.sort( compareTime );\n\n\t\treturn result;\n\n\t},\n\n\t// uses the array previously returned by 'getKeyframeOrder' to sort data\n\tsortedArray: function ( values, stride, order ) {\n\n\t\tconst nValues = values.length;\n\t\tconst result = new values.constructor( nValues );\n\n\t\tfor ( let i = 0, dstOffset = 0; dstOffset !== nValues; ++ i ) {\n\n\t\t\tconst srcOffset = order[ i ] * stride;\n\n\t\t\tfor ( let j = 0; j !== stride; ++ j ) {\n\n\t\t\t\tresult[ dstOffset ++ ] = values[ srcOffset + j ];\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn result;\n\n\t},\n\n\t// function for parsing AOS keyframe formats\n\tflattenJSON: function ( jsonKeys, times, values, valuePropertyName ) {\n\n\t\tlet i = 1, key = jsonKeys[ 0 ];\n\n\t\twhile ( key !== undefined && key[ valuePropertyName ] === undefined ) {\n\n\t\t\tkey = jsonKeys[ i ++ ];\n\n\t\t}\n\n\t\tif ( key === undefined ) return; // no data\n\n\t\tlet value = key[ valuePropertyName ];\n\t\tif ( value === undefined ) return; // no data\n\n\t\tif ( Array.isArray( value ) ) {\n\n\t\t\tdo {\n\n\t\t\t\tvalue = key[ valuePropertyName ];\n\n\t\t\t\tif ( value !== undefined ) {\n\n\t\t\t\t\ttimes.push( key.time );\n\t\t\t\t\tvalues.push.apply( values, value ); // push all elements\n\n\t\t\t\t}\n\n\t\t\t\tkey = jsonKeys[ i ++ ];\n\n\t\t\t} while ( key !== undefined );\n\n\t\t} else if ( value.toArray !== undefined ) {\n\n\t\t\t// ...assume THREE.Math-ish\n\n\t\t\tdo {\n\n\t\t\t\tvalue = key[ valuePropertyName ];\n\n\t\t\t\tif ( value !== undefined ) {\n\n\t\t\t\t\ttimes.push( key.time );\n\t\t\t\t\tvalue.toArray( values, values.length );\n\n\t\t\t\t}\n\n\t\t\t\tkey = jsonKeys[ i ++ ];\n\n\t\t\t} while ( key !== undefined );\n\n\t\t} else {\n\n\t\t\t// otherwise push as-is\n\n\t\t\tdo {\n\n\t\t\t\tvalue = key[ valuePropertyName ];\n\n\t\t\t\tif ( value !== undefined ) {\n\n\t\t\t\t\ttimes.push( key.time );\n\t\t\t\t\tvalues.push( value );\n\n\t\t\t\t}\n\n\t\t\t\tkey = jsonKeys[ i ++ ];\n\n\t\t\t} while ( key !== undefined );\n\n\t\t}\n\n\t},\n\n\tsubclip: function ( sourceClip, name, startFrame, endFrame, fps = 30 ) {\n\n\t\tconst clip = sourceClip.clone();\n\n\t\tclip.name = name;\n\n\t\tconst tracks = [];\n\n\t\tfor ( let i = 0; i < clip.tracks.length; ++ i ) {\n\n\t\t\tconst track = clip.tracks[ i ];\n\t\t\tconst valueSize = track.getValueSize();\n\n\t\t\tconst times = [];\n\t\t\tconst values = [];\n\n\t\t\tfor ( let j = 0; j < track.times.length; ++ j ) {\n\n\t\t\t\tconst frame = track.times[ j ] * fps;\n\n\t\t\t\tif ( frame < startFrame || frame >= endFrame ) continue;\n\n\t\t\t\ttimes.push( track.times[ j ] );\n\n\t\t\t\tfor ( let k = 0; k < valueSize; ++ k ) {\n\n\t\t\t\t\tvalues.push( track.values[ j * valueSize + k ] );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( times.length === 0 ) continue;\n\n\t\t\ttrack.times = AnimationUtils.convertArray( times, track.times.constructor );\n\t\t\ttrack.values = AnimationUtils.convertArray( values, track.values.constructor );\n\n\t\t\ttracks.push( track );\n\n\t\t}\n\n\t\tclip.tracks = tracks;\n\n\t\t// find minimum .times value across all tracks in the trimmed clip\n\n\t\tlet minStartTime = Infinity;\n\n\t\tfor ( let i = 0; i < clip.tracks.length; ++ i ) {\n\n\t\t\tif ( minStartTime > clip.tracks[ i ].times[ 0 ] ) {\n\n\t\t\t\tminStartTime = clip.tracks[ i ].times[ 0 ];\n\n\t\t\t}\n\n\t\t}\n\n\t\t// shift all tracks such that clip begins at t=0\n\n\t\tfor ( let i = 0; i < clip.tracks.length; ++ i ) {\n\n\t\t\tclip.tracks[ i ].shift( - 1 * minStartTime );\n\n\t\t}\n\n\t\tclip.resetDuration();\n\n\t\treturn clip;\n\n\t},\n\n\tmakeClipAdditive: function ( targetClip, referenceFrame = 0, referenceClip = targetClip, fps = 30 ) {\n\n\t\tif ( fps <= 0 ) fps = 30;\n\n\t\tconst numTracks = referenceClip.tracks.length;\n\t\tconst referenceTime = referenceFrame / fps;\n\n\t\t// Make each track's values relative to the values at the reference frame\n\t\tfor ( let i = 0; i < numTracks; ++ i ) {\n\n\t\t\tconst referenceTrack = referenceClip.tracks[ i ];\n\t\t\tconst referenceTrackType = referenceTrack.ValueTypeName;\n\n\t\t\t// Skip this track if it's non-numeric\n\t\t\tif ( referenceTrackType === 'bool' || referenceTrackType === 'string' ) continue;\n\n\t\t\t// Find the track in the target clip whose name and type matches the reference track\n\t\t\tconst targetTrack = targetClip.tracks.find( function ( track ) {\n\n\t\t\t\treturn track.name === referenceTrack.name\n\t\t\t\t\t&& track.ValueTypeName === referenceTrackType;\n\n\t\t\t} );\n\n\t\t\tif ( targetTrack === undefined ) continue;\n\n\t\t\tlet referenceOffset = 0;\n\t\t\tconst referenceValueSize = referenceTrack.getValueSize();\n\n\t\t\tif ( referenceTrack.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline ) {\n\n\t\t\t\treferenceOffset = referenceValueSize / 3;\n\n\t\t\t}\n\n\t\t\tlet targetOffset = 0;\n\t\t\tconst targetValueSize = targetTrack.getValueSize();\n\n\t\t\tif ( targetTrack.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline ) {\n\n\t\t\t\ttargetOffset = targetValueSize / 3;\n\n\t\t\t}\n\n\t\t\tconst lastIndex = referenceTrack.times.length - 1;\n\t\t\tlet referenceValue;\n\n\t\t\t// Find the value to subtract out of the track\n\t\t\tif ( referenceTime <= referenceTrack.times[ 0 ] ) {\n\n\t\t\t\t// Reference frame is earlier than the first keyframe, so just use the first keyframe\n\t\t\t\tconst startIndex = referenceOffset;\n\t\t\t\tconst endIndex = referenceValueSize - referenceOffset;\n\t\t\t\treferenceValue = AnimationUtils.arraySlice( referenceTrack.values, startIndex, endIndex );\n\n\t\t\t} else if ( referenceTime >= referenceTrack.times[ lastIndex ] ) {\n\n\t\t\t\t// Reference frame is after the last keyframe, so just use the last keyframe\n\t\t\t\tconst startIndex = lastIndex * referenceValueSize + referenceOffset;\n\t\t\t\tconst endIndex = startIndex + referenceValueSize - referenceOffset;\n\t\t\t\treferenceValue = AnimationUtils.arraySlice( referenceTrack.values, startIndex, endIndex );\n\n\t\t\t} else {\n\n\t\t\t\t// Interpolate to the reference value\n\t\t\t\tconst interpolant = referenceTrack.createInterpolant();\n\t\t\t\tconst startIndex = referenceOffset;\n\t\t\t\tconst endIndex = referenceValueSize - referenceOffset;\n\t\t\t\tinterpolant.evaluate( referenceTime );\n\t\t\t\treferenceValue = AnimationUtils.arraySlice( interpolant.resultBuffer, startIndex, endIndex );\n\n\t\t\t}\n\n\t\t\t// Conjugate the quaternion\n\t\t\tif ( referenceTrackType === 'quaternion' ) {\n\n\t\t\t\tconst referenceQuat = new Quaternion().fromArray( referenceValue ).normalize().conjugate();\n\t\t\t\treferenceQuat.toArray( referenceValue );\n\n\t\t\t}\n\n\t\t\t// Subtract the reference value from all of the track values\n\n\t\t\tconst numTimes = targetTrack.times.length;\n\t\t\tfor ( let j = 0; j < numTimes; ++ j ) {\n\n\t\t\t\tconst valueStart = j * targetValueSize + targetOffset;\n\n\t\t\t\tif ( referenceTrackType === 'quaternion' ) {\n\n\t\t\t\t\t// Multiply the conjugate for quaternion track types\n\t\t\t\t\tQuaternion.multiplyQuaternionsFlat(\n\t\t\t\t\t\ttargetTrack.values,\n\t\t\t\t\t\tvalueStart,\n\t\t\t\t\t\treferenceValue,\n\t\t\t\t\t\t0,\n\t\t\t\t\t\ttargetTrack.values,\n\t\t\t\t\t\tvalueStart\n\t\t\t\t\t);\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconst valueEnd = targetValueSize - targetOffset * 2;\n\n\t\t\t\t\t// Subtract each value for all other numeric track types\n\t\t\t\t\tfor ( let k = 0; k < valueEnd; ++ k ) {\n\n\t\t\t\t\t\ttargetTrack.values[ valueStart + k ] -= referenceValue[ k ];\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\ttargetClip.blendMode = AdditiveAnimationBlendMode;\n\n\t\treturn targetClip;\n\n\t}\n\n};\n\n/**\n * Abstract base class of interpolants over parametric samples.\n *\n * The parameter domain is one dimensional, typically the time or a path\n * along a curve defined by the data.\n *\n * The sample values can have any dimensionality and derived classes may\n * apply special interpretations to the data.\n *\n * This class provides the interval seek in a Template Method, deferring\n * the actual interpolation to derived classes.\n *\n * Time complexity is O(1) for linear access crossing at most two points\n * and O(log N) for random access, where N is the number of positions.\n *\n * References:\n *\n * \t\thttp://www.oodesign.com/template-method-pattern.html\n *\n */\n\nclass Interpolant {\n\n\tconstructor( parameterPositions, sampleValues, sampleSize, resultBuffer ) {\n\n\t\tthis.parameterPositions = parameterPositions;\n\t\tthis._cachedIndex = 0;\n\n\t\tthis.resultBuffer = resultBuffer !== undefined ?\n\t\t\tresultBuffer : new sampleValues.constructor( sampleSize );\n\t\tthis.sampleValues = sampleValues;\n\t\tthis.valueSize = sampleSize;\n\n\t\tthis.settings = null;\n\t\tthis.DefaultSettings_ = {};\n\n\t}\n\n\tevaluate( t ) {\n\n\t\tconst pp = this.parameterPositions;\n\t\tlet i1 = this._cachedIndex,\n\t\t\tt1 = pp[ i1 ],\n\t\t\tt0 = pp[ i1 - 1 ];\n\n\t\tvalidate_interval: {\n\n\t\t\tseek: {\n\n\t\t\t\tlet right;\n\n\t\t\t\tlinear_scan: {\n\n\t\t\t\t\t//- See http://jsperf.com/comparison-to-undefined/3\n\t\t\t\t\t//- slower code:\n\t\t\t\t\t//-\n\t\t\t\t\t//- \t\t\t\tif ( t >= t1 || t1 === undefined ) {\n\t\t\t\t\tforward_scan: if ( ! ( t < t1 ) ) {\n\n\t\t\t\t\t\tfor ( let giveUpAt = i1 + 2; ; ) {\n\n\t\t\t\t\t\t\tif ( t1 === undefined ) {\n\n\t\t\t\t\t\t\t\tif ( t < t0 ) break forward_scan;\n\n\t\t\t\t\t\t\t\t// after end\n\n\t\t\t\t\t\t\t\ti1 = pp.length;\n\t\t\t\t\t\t\t\tthis._cachedIndex = i1;\n\t\t\t\t\t\t\t\treturn this.copySampleValue_( i1 - 1 );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif ( i1 === giveUpAt ) break; // this loop\n\n\t\t\t\t\t\t\tt0 = t1;\n\t\t\t\t\t\t\tt1 = pp[ ++ i1 ];\n\n\t\t\t\t\t\t\tif ( t < t1 ) {\n\n\t\t\t\t\t\t\t\t// we have arrived at the sought interval\n\t\t\t\t\t\t\t\tbreak seek;\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// prepare binary search on the right side of the index\n\t\t\t\t\t\tright = pp.length;\n\t\t\t\t\t\tbreak linear_scan;\n\n\t\t\t\t\t}\n\n\t\t\t\t\t//- slower code:\n\t\t\t\t\t//-\t\t\t\t\tif ( t < t0 || t0 === undefined ) {\n\t\t\t\t\tif ( ! ( t >= t0 ) ) {\n\n\t\t\t\t\t\t// looping?\n\n\t\t\t\t\t\tconst t1global = pp[ 1 ];\n\n\t\t\t\t\t\tif ( t < t1global ) {\n\n\t\t\t\t\t\t\ti1 = 2; // + 1, using the scan for the details\n\t\t\t\t\t\t\tt0 = t1global;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// linear reverse scan\n\n\t\t\t\t\t\tfor ( let giveUpAt = i1 - 2; ; ) {\n\n\t\t\t\t\t\t\tif ( t0 === undefined ) {\n\n\t\t\t\t\t\t\t\t// before start\n\n\t\t\t\t\t\t\t\tthis._cachedIndex = 0;\n\t\t\t\t\t\t\t\treturn this.copySampleValue_( 0 );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif ( i1 === giveUpAt ) break; // this loop\n\n\t\t\t\t\t\t\tt1 = t0;\n\t\t\t\t\t\t\tt0 = pp[ -- i1 - 1 ];\n\n\t\t\t\t\t\t\tif ( t >= t0 ) {\n\n\t\t\t\t\t\t\t\t// we have arrived at the sought interval\n\t\t\t\t\t\t\t\tbreak seek;\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// prepare binary search on the left side of the index\n\t\t\t\t\t\tright = i1;\n\t\t\t\t\t\ti1 = 0;\n\t\t\t\t\t\tbreak linear_scan;\n\n\t\t\t\t\t}\n\n\t\t\t\t\t// the interval is valid\n\n\t\t\t\t\tbreak validate_interval;\n\n\t\t\t\t} // linear scan\n\n\t\t\t\t// binary search\n\n\t\t\t\twhile ( i1 < right ) {\n\n\t\t\t\t\tconst mid = ( i1 + right ) >>> 1;\n\n\t\t\t\t\tif ( t < pp[ mid ] ) {\n\n\t\t\t\t\t\tright = mid;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\ti1 = mid + 1;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tt1 = pp[ i1 ];\n\t\t\t\tt0 = pp[ i1 - 1 ];\n\n\t\t\t\t// check boundary cases, again\n\n\t\t\t\tif ( t0 === undefined ) {\n\n\t\t\t\t\tthis._cachedIndex = 0;\n\t\t\t\t\treturn this.copySampleValue_( 0 );\n\n\t\t\t\t}\n\n\t\t\t\tif ( t1 === undefined ) {\n\n\t\t\t\t\ti1 = pp.length;\n\t\t\t\t\tthis._cachedIndex = i1;\n\t\t\t\t\treturn this.copySampleValue_( i1 - 1 );\n\n\t\t\t\t}\n\n\t\t\t} // seek\n\n\t\t\tthis._cachedIndex = i1;\n\n\t\t\tthis.intervalChanged_( i1, t0, t1 );\n\n\t\t} // validate_interval\n\n\t\treturn this.interpolate_( i1, t0, t, t1 );\n\n\t}\n\n\tgetSettings_() {\n\n\t\treturn this.settings || this.DefaultSettings_;\n\n\t}\n\n\tcopySampleValue_( index ) {\n\n\t\t// copies a sample value to the result buffer\n\n\t\tconst result = this.resultBuffer,\n\t\t\tvalues = this.sampleValues,\n\t\t\tstride = this.valueSize,\n\t\t\toffset = index * stride;\n\n\t\tfor ( let i = 0; i !== stride; ++ i ) {\n\n\t\t\tresult[ i ] = values[ offset + i ];\n\n\t\t}\n\n\t\treturn result;\n\n\t}\n\n\t// Template methods for derived classes:\n\n\tinterpolate_( /* i1, t0, t, t1 */ ) {\n\n\t\tthrow new Error( 'call to abstract method' );\n\t\t// implementations shall return this.resultBuffer\n\n\t}\n\n\tintervalChanged_( /* i1, t0, t1 */ ) {\n\n\t\t// empty\n\n\t}\n\n}\n\n/**\n * Fast and simple cubic spline interpolant.\n *\n * It was derived from a Hermitian construction setting the first derivative\n * at each sample position to the linear slope between neighboring positions\n * over their parameter interval.\n */\n\nclass CubicInterpolant extends Interpolant {\n\n\tconstructor( parameterPositions, sampleValues, sampleSize, resultBuffer ) {\n\n\t\tsuper( parameterPositions, sampleValues, sampleSize, resultBuffer );\n\n\t\tthis._weightPrev = - 0;\n\t\tthis._offsetPrev = - 0;\n\t\tthis._weightNext = - 0;\n\t\tthis._offsetNext = - 0;\n\n\t\tthis.DefaultSettings_ = {\n\n\t\t\tendingStart: ZeroCurvatureEnding,\n\t\t\tendingEnd: ZeroCurvatureEnding\n\n\t\t};\n\n\t}\n\n\tintervalChanged_( i1, t0, t1 ) {\n\n\t\tconst pp = this.parameterPositions;\n\t\tlet iPrev = i1 - 2,\n\t\t\tiNext = i1 + 1,\n\n\t\t\ttPrev = pp[ iPrev ],\n\t\t\ttNext = pp[ iNext ];\n\n\t\tif ( tPrev === undefined ) {\n\n\t\t\tswitch ( this.getSettings_().endingStart ) {\n\n\t\t\t\tcase ZeroSlopeEnding:\n\n\t\t\t\t\t// f'(t0) = 0\n\t\t\t\t\tiPrev = i1;\n\t\t\t\t\ttPrev = 2 * t0 - t1;\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase WrapAroundEnding:\n\n\t\t\t\t\t// use the other end of the curve\n\t\t\t\t\tiPrev = pp.length - 2;\n\t\t\t\t\ttPrev = t0 + pp[ iPrev ] - pp[ iPrev + 1 ];\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault: // ZeroCurvatureEnding\n\n\t\t\t\t\t// f''(t0) = 0 a.k.a. Natural Spline\n\t\t\t\t\tiPrev = i1;\n\t\t\t\t\ttPrev = t1;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( tNext === undefined ) {\n\n\t\t\tswitch ( this.getSettings_().endingEnd ) {\n\n\t\t\t\tcase ZeroSlopeEnding:\n\n\t\t\t\t\t// f'(tN) = 0\n\t\t\t\t\tiNext = i1;\n\t\t\t\t\ttNext = 2 * t1 - t0;\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase WrapAroundEnding:\n\n\t\t\t\t\t// use the other end of the curve\n\t\t\t\t\tiNext = 1;\n\t\t\t\t\ttNext = t1 + pp[ 1 ] - pp[ 0 ];\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault: // ZeroCurvatureEnding\n\n\t\t\t\t\t// f''(tN) = 0, a.k.a. Natural Spline\n\t\t\t\t\tiNext = i1 - 1;\n\t\t\t\t\ttNext = t0;\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst halfDt = ( t1 - t0 ) * 0.5,\n\t\t\tstride = this.valueSize;\n\n\t\tthis._weightPrev = halfDt / ( t0 - tPrev );\n\t\tthis._weightNext = halfDt / ( tNext - t1 );\n\t\tthis._offsetPrev = iPrev * stride;\n\t\tthis._offsetNext = iNext * stride;\n\n\t}\n\n\tinterpolate_( i1, t0, t, t1 ) {\n\n\t\tconst result = this.resultBuffer,\n\t\t\tvalues = this.sampleValues,\n\t\t\tstride = this.valueSize,\n\n\t\t\to1 = i1 * stride,\t\to0 = o1 - stride,\n\t\t\toP = this._offsetPrev, \toN = this._offsetNext,\n\t\t\twP = this._weightPrev,\twN = this._weightNext,\n\n\t\t\tp = ( t - t0 ) / ( t1 - t0 ),\n\t\t\tpp = p * p,\n\t\t\tppp = pp * p;\n\n\t\t// evaluate polynomials\n\n\t\tconst sP = - wP * ppp + 2 * wP * pp - wP * p;\n\t\tconst s0 = ( 1 + wP ) * ppp + ( - 1.5 - 2 * wP ) * pp + ( - 0.5 + wP ) * p + 1;\n\t\tconst s1 = ( - 1 - wN ) * ppp + ( 1.5 + wN ) * pp + 0.5 * p;\n\t\tconst sN = wN * ppp - wN * pp;\n\n\t\t// combine data linearly\n\n\t\tfor ( let i = 0; i !== stride; ++ i ) {\n\n\t\t\tresult[ i ] =\n\t\t\t\t\tsP * values[ oP + i ] +\n\t\t\t\t\ts0 * values[ o0 + i ] +\n\t\t\t\t\ts1 * values[ o1 + i ] +\n\t\t\t\t\tsN * values[ oN + i ];\n\n\t\t}\n\n\t\treturn result;\n\n\t}\n\n}\n\nclass LinearInterpolant extends Interpolant {\n\n\tconstructor( parameterPositions, sampleValues, sampleSize, resultBuffer ) {\n\n\t\tsuper( parameterPositions, sampleValues, sampleSize, resultBuffer );\n\n\t}\n\n\tinterpolate_( i1, t0, t, t1 ) {\n\n\t\tconst result = this.resultBuffer,\n\t\t\tvalues = this.sampleValues,\n\t\t\tstride = this.valueSize,\n\n\t\t\toffset1 = i1 * stride,\n\t\t\toffset0 = offset1 - stride,\n\n\t\t\tweight1 = ( t - t0 ) / ( t1 - t0 ),\n\t\t\tweight0 = 1 - weight1;\n\n\t\tfor ( let i = 0; i !== stride; ++ i ) {\n\n\t\t\tresult[ i ] =\n\t\t\t\t\tvalues[ offset0 + i ] * weight0 +\n\t\t\t\t\tvalues[ offset1 + i ] * weight1;\n\n\t\t}\n\n\t\treturn result;\n\n\t}\n\n}\n\n/**\n *\n * Interpolant that evaluates to the sample value at the position preceding\n * the parameter.\n */\n\nclass DiscreteInterpolant extends Interpolant {\n\n\tconstructor( parameterPositions, sampleValues, sampleSize, resultBuffer ) {\n\n\t\tsuper( parameterPositions, sampleValues, sampleSize, resultBuffer );\n\n\t}\n\n\tinterpolate_( i1 /*, t0, t, t1 */ ) {\n\n\t\treturn this.copySampleValue_( i1 - 1 );\n\n\t}\n\n}\n\nclass KeyframeTrack {\n\n\tconstructor( name, times, values, interpolation ) {\n\n\t\tif ( name === undefined ) throw new Error( 'THREE.KeyframeTrack: track name is undefined' );\n\t\tif ( times === undefined || times.length === 0 ) throw new Error( 'THREE.KeyframeTrack: no keyframes in track named ' + name );\n\n\t\tthis.name = name;\n\n\t\tthis.times = AnimationUtils.convertArray( times, this.TimeBufferType );\n\t\tthis.values = AnimationUtils.convertArray( values, this.ValueBufferType );\n\n\t\tthis.setInterpolation( interpolation || this.DefaultInterpolation );\n\n\t}\n\n\t// Serialization (in static context, because of constructor invocation\n\t// and automatic invocation of .toJSON):\n\n\tstatic toJSON( track ) {\n\n\t\tconst trackType = track.constructor;\n\n\t\tlet json;\n\n\t\t// derived classes can define a static toJSON method\n\t\tif ( trackType.toJSON !== this.toJSON ) {\n\n\t\t\tjson = trackType.toJSON( track );\n\n\t\t} else {\n\n\t\t\t// by default, we assume the data can be serialized as-is\n\t\t\tjson = {\n\n\t\t\t\t'name': track.name,\n\t\t\t\t'times': AnimationUtils.convertArray( track.times, Array ),\n\t\t\t\t'values': AnimationUtils.convertArray( track.values, Array )\n\n\t\t\t};\n\n\t\t\tconst interpolation = track.getInterpolation();\n\n\t\t\tif ( interpolation !== track.DefaultInterpolation ) {\n\n\t\t\t\tjson.interpolation = interpolation;\n\n\t\t\t}\n\n\t\t}\n\n\t\tjson.type = track.ValueTypeName; // mandatory\n\n\t\treturn json;\n\n\t}\n\n\tInterpolantFactoryMethodDiscrete( result ) {\n\n\t\treturn new DiscreteInterpolant( this.times, this.values, this.getValueSize(), result );\n\n\t}\n\n\tInterpolantFactoryMethodLinear( result ) {\n\n\t\treturn new LinearInterpolant( this.times, this.values, this.getValueSize(), result );\n\n\t}\n\n\tInterpolantFactoryMethodSmooth( result ) {\n\n\t\treturn new CubicInterpolant( this.times, this.values, this.getValueSize(), result );\n\n\t}\n\n\tsetInterpolation( interpolation ) {\n\n\t\tlet factoryMethod;\n\n\t\tswitch ( interpolation ) {\n\n\t\t\tcase InterpolateDiscrete:\n\n\t\t\t\tfactoryMethod = this.InterpolantFactoryMethodDiscrete;\n\n\t\t\t\tbreak;\n\n\t\t\tcase InterpolateLinear:\n\n\t\t\t\tfactoryMethod = this.InterpolantFactoryMethodLinear;\n\n\t\t\t\tbreak;\n\n\t\t\tcase InterpolateSmooth:\n\n\t\t\t\tfactoryMethod = this.InterpolantFactoryMethodSmooth;\n\n\t\t\t\tbreak;\n\n\t\t}\n\n\t\tif ( factoryMethod === undefined ) {\n\n\t\t\tconst message = 'unsupported interpolation for ' +\n\t\t\t\tthis.ValueTypeName + ' keyframe track named ' + this.name;\n\n\t\t\tif ( this.createInterpolant === undefined ) {\n\n\t\t\t\t// fall back to default, unless the default itself is messed up\n\t\t\t\tif ( interpolation !== this.DefaultInterpolation ) {\n\n\t\t\t\t\tthis.setInterpolation( this.DefaultInterpolation );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthrow new Error( message ); // fatal, in this case\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tconsole.warn( 'THREE.KeyframeTrack:', message );\n\t\t\treturn this;\n\n\t\t}\n\n\t\tthis.createInterpolant = factoryMethod;\n\n\t\treturn this;\n\n\t}\n\n\tgetInterpolation() {\n\n\t\tswitch ( this.createInterpolant ) {\n\n\t\t\tcase this.InterpolantFactoryMethodDiscrete:\n\n\t\t\t\treturn InterpolateDiscrete;\n\n\t\t\tcase this.InterpolantFactoryMethodLinear:\n\n\t\t\t\treturn InterpolateLinear;\n\n\t\t\tcase this.InterpolantFactoryMethodSmooth:\n\n\t\t\t\treturn InterpolateSmooth;\n\n\t\t}\n\n\t}\n\n\tgetValueSize() {\n\n\t\treturn this.values.length / this.times.length;\n\n\t}\n\n\t// move all keyframes either forwards or backwards in time\n\tshift( timeOffset ) {\n\n\t\tif ( timeOffset !== 0.0 ) {\n\n\t\t\tconst times = this.times;\n\n\t\t\tfor ( let i = 0, n = times.length; i !== n; ++ i ) {\n\n\t\t\t\ttimes[ i ] += timeOffset;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\t// scale all keyframe times by a factor (useful for frame <-> seconds conversions)\n\tscale( timeScale ) {\n\n\t\tif ( timeScale !== 1.0 ) {\n\n\t\t\tconst times = this.times;\n\n\t\t\tfor ( let i = 0, n = times.length; i !== n; ++ i ) {\n\n\t\t\t\ttimes[ i ] *= timeScale;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\t// removes keyframes before and after animation without changing any values within the range [startTime, endTime].\n\t// IMPORTANT: We do not shift around keys to the start of the track time, because for interpolated keys this will change their values\n\ttrim( startTime, endTime ) {\n\n\t\tconst times = this.times,\n\t\t\tnKeys = times.length;\n\n\t\tlet from = 0,\n\t\t\tto = nKeys - 1;\n\n\t\twhile ( from !== nKeys && times[ from ] < startTime ) {\n\n\t\t\t++ from;\n\n\t\t}\n\n\t\twhile ( to !== - 1 && times[ to ] > endTime ) {\n\n\t\t\t-- to;\n\n\t\t}\n\n\t\t++ to; // inclusive -> exclusive bound\n\n\t\tif ( from !== 0 || to !== nKeys ) {\n\n\t\t\t// empty tracks are forbidden, so keep at least one keyframe\n\t\t\tif ( from >= to ) {\n\n\t\t\t\tto = Math.max( to, 1 );\n\t\t\t\tfrom = to - 1;\n\n\t\t\t}\n\n\t\t\tconst stride = this.getValueSize();\n\t\t\tthis.times = AnimationUtils.arraySlice( times, from, to );\n\t\t\tthis.values = AnimationUtils.arraySlice( this.values, from * stride, to * stride );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\t// ensure we do not get a GarbageInGarbageOut situation, make sure tracks are at least minimally viable\n\tvalidate() {\n\n\t\tlet valid = true;\n\n\t\tconst valueSize = this.getValueSize();\n\t\tif ( valueSize - Math.floor( valueSize ) !== 0 ) {\n\n\t\t\tconsole.error( 'THREE.KeyframeTrack: Invalid value size in track.', this );\n\t\t\tvalid = false;\n\n\t\t}\n\n\t\tconst times = this.times,\n\t\t\tvalues = this.values,\n\n\t\t\tnKeys = times.length;\n\n\t\tif ( nKeys === 0 ) {\n\n\t\t\tconsole.error( 'THREE.KeyframeTrack: Track is empty.', this );\n\t\t\tvalid = false;\n\n\t\t}\n\n\t\tlet prevTime = null;\n\n\t\tfor ( let i = 0; i !== nKeys; i ++ ) {\n\n\t\t\tconst currTime = times[ i ];\n\n\t\t\tif ( typeof currTime === 'number' && isNaN( currTime ) ) {\n\n\t\t\t\tconsole.error( 'THREE.KeyframeTrack: Time is not a valid number.', this, i, currTime );\n\t\t\t\tvalid = false;\n\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t\tif ( prevTime !== null && prevTime > currTime ) {\n\n\t\t\t\tconsole.error( 'THREE.KeyframeTrack: Out of order keys.', this, i, currTime, prevTime );\n\t\t\t\tvalid = false;\n\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t\tprevTime = currTime;\n\n\t\t}\n\n\t\tif ( values !== undefined ) {\n\n\t\t\tif ( AnimationUtils.isTypedArray( values ) ) {\n\n\t\t\t\tfor ( let i = 0, n = values.length; i !== n; ++ i ) {\n\n\t\t\t\t\tconst value = values[ i ];\n\n\t\t\t\t\tif ( isNaN( value ) ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.KeyframeTrack: Value is not a valid number.', this, i, value );\n\t\t\t\t\t\tvalid = false;\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn valid;\n\n\t}\n\n\t// removes equivalent sequential keys as common in morph target sequences\n\t// (0,0,0,0,1,1,1,0,0,0,0,0,0,0) --> (0,0,1,1,0,0)\n\toptimize() {\n\n\t\t// times or values may be shared with other tracks, so overwriting is unsafe\n\t\tconst times = AnimationUtils.arraySlice( this.times ),\n\t\t\tvalues = AnimationUtils.arraySlice( this.values ),\n\t\t\tstride = this.getValueSize(),\n\n\t\t\tsmoothInterpolation = this.getInterpolation() === InterpolateSmooth,\n\n\t\t\tlastIndex = times.length - 1;\n\n\t\tlet writeIndex = 1;\n\n\t\tfor ( let i = 1; i < lastIndex; ++ i ) {\n\n\t\t\tlet keep = false;\n\n\t\t\tconst time = times[ i ];\n\t\t\tconst timeNext = times[ i + 1 ];\n\n\t\t\t// remove adjacent keyframes scheduled at the same time\n\n\t\t\tif ( time !== timeNext && ( i !== 1 || time !== times[ 0 ] ) ) {\n\n\t\t\t\tif ( ! smoothInterpolation ) {\n\n\t\t\t\t\t// remove unnecessary keyframes same as their neighbors\n\n\t\t\t\t\tconst offset = i * stride,\n\t\t\t\t\t\toffsetP = offset - stride,\n\t\t\t\t\t\toffsetN = offset + stride;\n\n\t\t\t\t\tfor ( let j = 0; j !== stride; ++ j ) {\n\n\t\t\t\t\t\tconst value = values[ offset + j ];\n\n\t\t\t\t\t\tif ( value !== values[ offsetP + j ] ||\n\t\t\t\t\t\t\tvalue !== values[ offsetN + j ] ) {\n\n\t\t\t\t\t\t\tkeep = true;\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\tkeep = true;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t// in-place compaction\n\n\t\t\tif ( keep ) {\n\n\t\t\t\tif ( i !== writeIndex ) {\n\n\t\t\t\t\ttimes[ writeIndex ] = times[ i ];\n\n\t\t\t\t\tconst readOffset = i * stride,\n\t\t\t\t\t\twriteOffset = writeIndex * stride;\n\n\t\t\t\t\tfor ( let j = 0; j !== stride; ++ j ) {\n\n\t\t\t\t\t\tvalues[ writeOffset + j ] = values[ readOffset + j ];\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\t++ writeIndex;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// flush last keyframe (compaction looks ahead)\n\n\t\tif ( lastIndex > 0 ) {\n\n\t\t\ttimes[ writeIndex ] = times[ lastIndex ];\n\n\t\t\tfor ( let readOffset = lastIndex * stride, writeOffset = writeIndex * stride, j = 0; j !== stride; ++ j ) {\n\n\t\t\t\tvalues[ writeOffset + j ] = values[ readOffset + j ];\n\n\t\t\t}\n\n\t\t\t++ writeIndex;\n\n\t\t}\n\n\t\tif ( writeIndex !== times.length ) {\n\n\t\t\tthis.times = AnimationUtils.arraySlice( times, 0, writeIndex );\n\t\t\tthis.values = AnimationUtils.arraySlice( values, 0, writeIndex * stride );\n\n\t\t} else {\n\n\t\t\tthis.times = times;\n\t\t\tthis.values = values;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\tconst times = AnimationUtils.arraySlice( this.times, 0 );\n\t\tconst values = AnimationUtils.arraySlice( this.values, 0 );\n\n\t\tconst TypedKeyframeTrack = this.constructor;\n\t\tconst track = new TypedKeyframeTrack( this.name, times, values );\n\n\t\t// Interpolant argument to constructor is not saved, so copy the factory method directly.\n\t\ttrack.createInterpolant = this.createInterpolant;\n\n\t\treturn track;\n\n\t}\n\n}\n\nKeyframeTrack.prototype.TimeBufferType = Float32Array;\nKeyframeTrack.prototype.ValueBufferType = Float32Array;\nKeyframeTrack.prototype.DefaultInterpolation = InterpolateLinear;\n\n/**\n * A Track of Boolean keyframe values.\n */\nclass BooleanKeyframeTrack extends KeyframeTrack {}\n\nBooleanKeyframeTrack.prototype.ValueTypeName = 'bool';\nBooleanKeyframeTrack.prototype.ValueBufferType = Array;\nBooleanKeyframeTrack.prototype.DefaultInterpolation = InterpolateDiscrete;\nBooleanKeyframeTrack.prototype.InterpolantFactoryMethodLinear = undefined;\nBooleanKeyframeTrack.prototype.InterpolantFactoryMethodSmooth = undefined;\n\n/**\n * A Track of keyframe values that represent color.\n */\nclass ColorKeyframeTrack extends KeyframeTrack {}\n\nColorKeyframeTrack.prototype.ValueTypeName = 'color';\n\n/**\n * A Track of numeric keyframe values.\n */\nclass NumberKeyframeTrack extends KeyframeTrack {}\n\nNumberKeyframeTrack.prototype.ValueTypeName = 'number';\n\n/**\n * Spherical linear unit quaternion interpolant.\n */\n\nclass QuaternionLinearInterpolant extends Interpolant {\n\n\tconstructor( parameterPositions, sampleValues, sampleSize, resultBuffer ) {\n\n\t\tsuper( parameterPositions, sampleValues, sampleSize, resultBuffer );\n\n\t}\n\n\tinterpolate_( i1, t0, t, t1 ) {\n\n\t\tconst result = this.resultBuffer,\n\t\t\tvalues = this.sampleValues,\n\t\t\tstride = this.valueSize,\n\n\t\t\talpha = ( t - t0 ) / ( t1 - t0 );\n\n\t\tlet offset = i1 * stride;\n\n\t\tfor ( let end = offset + stride; offset !== end; offset += 4 ) {\n\n\t\t\tQuaternion.slerpFlat( result, 0, values, offset - stride, values, offset, alpha );\n\n\t\t}\n\n\t\treturn result;\n\n\t}\n\n}\n\n/**\n * A Track of quaternion keyframe values.\n */\nclass QuaternionKeyframeTrack extends KeyframeTrack {\n\n\tInterpolantFactoryMethodLinear( result ) {\n\n\t\treturn new QuaternionLinearInterpolant( this.times, this.values, this.getValueSize(), result );\n\n\t}\n\n}\n\nQuaternionKeyframeTrack.prototype.ValueTypeName = 'quaternion';\n// ValueBufferType is inherited\nQuaternionKeyframeTrack.prototype.DefaultInterpolation = InterpolateLinear;\nQuaternionKeyframeTrack.prototype.InterpolantFactoryMethodSmooth = undefined;\n\n/**\n * A Track that interpolates Strings\n */\nclass StringKeyframeTrack extends KeyframeTrack {}\n\nStringKeyframeTrack.prototype.ValueTypeName = 'string';\nStringKeyframeTrack.prototype.ValueBufferType = Array;\nStringKeyframeTrack.prototype.DefaultInterpolation = InterpolateDiscrete;\nStringKeyframeTrack.prototype.InterpolantFactoryMethodLinear = undefined;\nStringKeyframeTrack.prototype.InterpolantFactoryMethodSmooth = undefined;\n\n/**\n * A Track of vectored keyframe values.\n */\nclass VectorKeyframeTrack extends KeyframeTrack {}\n\nVectorKeyframeTrack.prototype.ValueTypeName = 'vector';\n\nclass AnimationClip {\n\n\tconstructor( name, duration = - 1, tracks, blendMode = NormalAnimationBlendMode ) {\n\n\t\tthis.name = name;\n\t\tthis.tracks = tracks;\n\t\tthis.duration = duration;\n\t\tthis.blendMode = blendMode;\n\n\t\tthis.uuid = generateUUID();\n\n\t\t// this means it should figure out its duration by scanning the tracks\n\t\tif ( this.duration < 0 ) {\n\n\t\t\tthis.resetDuration();\n\n\t\t}\n\n\t}\n\n\n\tstatic parse( json ) {\n\n\t\tconst tracks = [],\n\t\t\tjsonTracks = json.tracks,\n\t\t\tframeTime = 1.0 / ( json.fps || 1.0 );\n\n\t\tfor ( let i = 0, n = jsonTracks.length; i !== n; ++ i ) {\n\n\t\t\ttracks.push( parseKeyframeTrack( jsonTracks[ i ] ).scale( frameTime ) );\n\n\t\t}\n\n\t\tconst clip = new this( json.name, json.duration, tracks, json.blendMode );\n\t\tclip.uuid = json.uuid;\n\n\t\treturn clip;\n\n\t}\n\n\tstatic toJSON( clip ) {\n\n\t\tconst tracks = [],\n\t\t\tclipTracks = clip.tracks;\n\n\t\tconst json = {\n\n\t\t\t'name': clip.name,\n\t\t\t'duration': clip.duration,\n\t\t\t'tracks': tracks,\n\t\t\t'uuid': clip.uuid,\n\t\t\t'blendMode': clip.blendMode\n\n\t\t};\n\n\t\tfor ( let i = 0, n = clipTracks.length; i !== n; ++ i ) {\n\n\t\t\ttracks.push( KeyframeTrack.toJSON( clipTracks[ i ] ) );\n\n\t\t}\n\n\t\treturn json;\n\n\t}\n\n\tstatic CreateFromMorphTargetSequence( name, morphTargetSequence, fps, noLoop ) {\n\n\t\tconst numMorphTargets = morphTargetSequence.length;\n\t\tconst tracks = [];\n\n\t\tfor ( let i = 0; i < numMorphTargets; i ++ ) {\n\n\t\t\tlet times = [];\n\t\t\tlet values = [];\n\n\t\t\ttimes.push(\n\t\t\t\t( i + numMorphTargets - 1 ) % numMorphTargets,\n\t\t\t\ti,\n\t\t\t\t( i + 1 ) % numMorphTargets );\n\n\t\t\tvalues.push( 0, 1, 0 );\n\n\t\t\tconst order = AnimationUtils.getKeyframeOrder( times );\n\t\t\ttimes = AnimationUtils.sortedArray( times, 1, order );\n\t\t\tvalues = AnimationUtils.sortedArray( values, 1, order );\n\n\t\t\t// if there is a key at the first frame, duplicate it as the\n\t\t\t// last frame as well for perfect loop.\n\t\t\tif ( ! noLoop && times[ 0 ] === 0 ) {\n\n\t\t\t\ttimes.push( numMorphTargets );\n\t\t\t\tvalues.push( values[ 0 ] );\n\n\t\t\t}\n\n\t\t\ttracks.push(\n\t\t\t\tnew NumberKeyframeTrack(\n\t\t\t\t\t'.morphTargetInfluences[' + morphTargetSequence[ i ].name + ']',\n\t\t\t\t\ttimes, values\n\t\t\t\t).scale( 1.0 / fps ) );\n\n\t\t}\n\n\t\treturn new this( name, - 1, tracks );\n\n\t}\n\n\tstatic findByName( objectOrClipArray, name ) {\n\n\t\tlet clipArray = objectOrClipArray;\n\n\t\tif ( ! Array.isArray( objectOrClipArray ) ) {\n\n\t\t\tconst o = objectOrClipArray;\n\t\t\tclipArray = o.geometry && o.geometry.animations || o.animations;\n\n\t\t}\n\n\t\tfor ( let i = 0; i < clipArray.length; i ++ ) {\n\n\t\t\tif ( clipArray[ i ].name === name ) {\n\n\t\t\t\treturn clipArray[ i ];\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn null;\n\n\t}\n\n\tstatic CreateClipsFromMorphTargetSequences( morphTargets, fps, noLoop ) {\n\n\t\tconst animationToMorphTargets = {};\n\n\t\t// tested with https://regex101.com/ on trick sequences\n\t\t// such flamingo_flyA_003, flamingo_run1_003, crdeath0059\n\t\tconst pattern = /^([\\w-]*?)([\\d]+)$/;\n\n\t\t// sort morph target names into animation groups based\n\t\t// patterns like Walk_001, Walk_002, Run_001, Run_002\n\t\tfor ( let i = 0, il = morphTargets.length; i < il; i ++ ) {\n\n\t\t\tconst morphTarget = morphTargets[ i ];\n\t\t\tconst parts = morphTarget.name.match( pattern );\n\n\t\t\tif ( parts && parts.length > 1 ) {\n\n\t\t\t\tconst name = parts[ 1 ];\n\n\t\t\t\tlet animationMorphTargets = animationToMorphTargets[ name ];\n\n\t\t\t\tif ( ! animationMorphTargets ) {\n\n\t\t\t\t\tanimationToMorphTargets[ name ] = animationMorphTargets = [];\n\n\t\t\t\t}\n\n\t\t\t\tanimationMorphTargets.push( morphTarget );\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst clips = [];\n\n\t\tfor ( const name in animationToMorphTargets ) {\n\n\t\t\tclips.push( this.CreateFromMorphTargetSequence( name, animationToMorphTargets[ name ], fps, noLoop ) );\n\n\t\t}\n\n\t\treturn clips;\n\n\t}\n\n\t// parse the animation.hierarchy format\n\tstatic parseAnimation( animation, bones ) {\n\n\t\tif ( ! animation ) {\n\n\t\t\tconsole.error( 'THREE.AnimationClip: No animation in JSONLoader data.' );\n\t\t\treturn null;\n\n\t\t}\n\n\t\tconst addNonemptyTrack = function ( trackType, trackName, animationKeys, propertyName, destTracks ) {\n\n\t\t\t// only return track if there are actually keys.\n\t\t\tif ( animationKeys.length !== 0 ) {\n\n\t\t\t\tconst times = [];\n\t\t\t\tconst values = [];\n\n\t\t\t\tAnimationUtils.flattenJSON( animationKeys, times, values, propertyName );\n\n\t\t\t\t// empty keys are filtered out, so check again\n\t\t\t\tif ( times.length !== 0 ) {\n\n\t\t\t\t\tdestTracks.push( new trackType( trackName, times, values ) );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t};\n\n\t\tconst tracks = [];\n\n\t\tconst clipName = animation.name || 'default';\n\t\tconst fps = animation.fps || 30;\n\t\tconst blendMode = animation.blendMode;\n\n\t\t// automatic length determination in AnimationClip.\n\t\tlet duration = animation.length || - 1;\n\n\t\tconst hierarchyTracks = animation.hierarchy || [];\n\n\t\tfor ( let h = 0; h < hierarchyTracks.length; h ++ ) {\n\n\t\t\tconst animationKeys = hierarchyTracks[ h ].keys;\n\n\t\t\t// skip empty tracks\n\t\t\tif ( ! animationKeys || animationKeys.length === 0 ) continue;\n\n\t\t\t// process morph targets\n\t\t\tif ( animationKeys[ 0 ].morphTargets ) {\n\n\t\t\t\t// figure out all morph targets used in this track\n\t\t\t\tconst morphTargetNames = {};\n\n\t\t\t\tlet k;\n\n\t\t\t\tfor ( k = 0; k < animationKeys.length; k ++ ) {\n\n\t\t\t\t\tif ( animationKeys[ k ].morphTargets ) {\n\n\t\t\t\t\t\tfor ( let m = 0; m < animationKeys[ k ].morphTargets.length; m ++ ) {\n\n\t\t\t\t\t\t\tmorphTargetNames[ animationKeys[ k ].morphTargets[ m ] ] = - 1;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\t// create a track for each morph target with all zero\n\t\t\t\t// morphTargetInfluences except for the keys in which\n\t\t\t\t// the morphTarget is named.\n\t\t\t\tfor ( const morphTargetName in morphTargetNames ) {\n\n\t\t\t\t\tconst times = [];\n\t\t\t\t\tconst values = [];\n\n\t\t\t\t\tfor ( let m = 0; m !== animationKeys[ k ].morphTargets.length; ++ m ) {\n\n\t\t\t\t\t\tconst animationKey = animationKeys[ k ];\n\n\t\t\t\t\t\ttimes.push( animationKey.time );\n\t\t\t\t\t\tvalues.push( ( animationKey.morphTarget === morphTargetName ) ? 1 : 0 );\n\n\t\t\t\t\t}\n\n\t\t\t\t\ttracks.push( new NumberKeyframeTrack( '.morphTargetInfluence[' + morphTargetName + ']', times, values ) );\n\n\t\t\t\t}\n\n\t\t\t\tduration = morphTargetNames.length * fps;\n\n\t\t\t} else {\n\n\t\t\t\t// ...assume skeletal animation\n\n\t\t\t\tconst boneName = '.bones[' + bones[ h ].name + ']';\n\n\t\t\t\taddNonemptyTrack(\n\t\t\t\t\tVectorKeyframeTrack, boneName + '.position',\n\t\t\t\t\tanimationKeys, 'pos', tracks );\n\n\t\t\t\taddNonemptyTrack(\n\t\t\t\t\tQuaternionKeyframeTrack, boneName + '.quaternion',\n\t\t\t\t\tanimationKeys, 'rot', tracks );\n\n\t\t\t\taddNonemptyTrack(\n\t\t\t\t\tVectorKeyframeTrack, boneName + '.scale',\n\t\t\t\t\tanimationKeys, 'scl', tracks );\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( tracks.length === 0 ) {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\tconst clip = new this( clipName, duration, tracks, blendMode );\n\n\t\treturn clip;\n\n\t}\n\n\tresetDuration() {\n\n\t\tconst tracks = this.tracks;\n\t\tlet duration = 0;\n\n\t\tfor ( let i = 0, n = tracks.length; i !== n; ++ i ) {\n\n\t\t\tconst track = this.tracks[ i ];\n\n\t\t\tduration = Math.max( duration, track.times[ track.times.length - 1 ] );\n\n\t\t}\n\n\t\tthis.duration = duration;\n\n\t\treturn this;\n\n\t}\n\n\ttrim() {\n\n\t\tfor ( let i = 0; i < this.tracks.length; i ++ ) {\n\n\t\t\tthis.tracks[ i ].trim( 0, this.duration );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tvalidate() {\n\n\t\tlet valid = true;\n\n\t\tfor ( let i = 0; i < this.tracks.length; i ++ ) {\n\n\t\t\tvalid = valid && this.tracks[ i ].validate();\n\n\t\t}\n\n\t\treturn valid;\n\n\t}\n\n\toptimize() {\n\n\t\tfor ( let i = 0; i < this.tracks.length; i ++ ) {\n\n\t\t\tthis.tracks[ i ].optimize();\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\tconst tracks = [];\n\n\t\tfor ( let i = 0; i < this.tracks.length; i ++ ) {\n\n\t\t\ttracks.push( this.tracks[ i ].clone() );\n\n\t\t}\n\n\t\treturn new this.constructor( this.name, this.duration, tracks, this.blendMode );\n\n\t}\n\n\ttoJSON() {\n\n\t\treturn this.constructor.toJSON( this );\n\n\t}\n\n}\n\nfunction getTrackTypeForValueTypeName( typeName ) {\n\n\tswitch ( typeName.toLowerCase() ) {\n\n\t\tcase 'scalar':\n\t\tcase 'double':\n\t\tcase 'float':\n\t\tcase 'number':\n\t\tcase 'integer':\n\n\t\t\treturn NumberKeyframeTrack;\n\n\t\tcase 'vector':\n\t\tcase 'vector2':\n\t\tcase 'vector3':\n\t\tcase 'vector4':\n\n\t\t\treturn VectorKeyframeTrack;\n\n\t\tcase 'color':\n\n\t\t\treturn ColorKeyframeTrack;\n\n\t\tcase 'quaternion':\n\n\t\t\treturn QuaternionKeyframeTrack;\n\n\t\tcase 'bool':\n\t\tcase 'boolean':\n\n\t\t\treturn BooleanKeyframeTrack;\n\n\t\tcase 'string':\n\n\t\t\treturn StringKeyframeTrack;\n\n\t}\n\n\tthrow new Error( 'THREE.KeyframeTrack: Unsupported typeName: ' + typeName );\n\n}\n\nfunction parseKeyframeTrack( json ) {\n\n\tif ( json.type === undefined ) {\n\n\t\tthrow new Error( 'THREE.KeyframeTrack: track type undefined, can not parse' );\n\n\t}\n\n\tconst trackType = getTrackTypeForValueTypeName( json.type );\n\n\tif ( json.times === undefined ) {\n\n\t\tconst times = [], values = [];\n\n\t\tAnimationUtils.flattenJSON( json.keys, times, values, 'value' );\n\n\t\tjson.times = times;\n\t\tjson.values = values;\n\n\t}\n\n\t// derived classes can define a static parse method\n\tif ( trackType.parse !== undefined ) {\n\n\t\treturn trackType.parse( json );\n\n\t} else {\n\n\t\t// by default, we assume a constructor compatible with the base\n\t\treturn new trackType( json.name, json.times, json.values, json.interpolation );\n\n\t}\n\n}\n\nconst Cache = {\n\n\tenabled: false,\n\n\tfiles: {},\n\n\tadd: function ( key, file ) {\n\n\t\tif ( this.enabled === false ) return;\n\n\t\t// console.log( 'THREE.Cache', 'Adding key:', key );\n\n\t\tthis.files[ key ] = file;\n\n\t},\n\n\tget: function ( key ) {\n\n\t\tif ( this.enabled === false ) return;\n\n\t\t// console.log( 'THREE.Cache', 'Checking key:', key );\n\n\t\treturn this.files[ key ];\n\n\t},\n\n\tremove: function ( key ) {\n\n\t\tdelete this.files[ key ];\n\n\t},\n\n\tclear: function () {\n\n\t\tthis.files = {};\n\n\t}\n\n};\n\nclass LoadingManager {\n\n\tconstructor( onLoad, onProgress, onError ) {\n\n\t\tconst scope = this;\n\n\t\tlet isLoading = false;\n\t\tlet itemsLoaded = 0;\n\t\tlet itemsTotal = 0;\n\t\tlet urlModifier = undefined;\n\t\tconst handlers = [];\n\n\t\t// Refer to #5689 for the reason why we don't set .onStart\n\t\t// in the constructor\n\n\t\tthis.onStart = undefined;\n\t\tthis.onLoad = onLoad;\n\t\tthis.onProgress = onProgress;\n\t\tthis.onError = onError;\n\n\t\tthis.itemStart = function ( url ) {\n\n\t\t\titemsTotal ++;\n\n\t\t\tif ( isLoading === false ) {\n\n\t\t\t\tif ( scope.onStart !== undefined ) {\n\n\t\t\t\t\tscope.onStart( url, itemsLoaded, itemsTotal );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tisLoading = true;\n\n\t\t};\n\n\t\tthis.itemEnd = function ( url ) {\n\n\t\t\titemsLoaded ++;\n\n\t\t\tif ( scope.onProgress !== undefined ) {\n\n\t\t\t\tscope.onProgress( url, itemsLoaded, itemsTotal );\n\n\t\t\t}\n\n\t\t\tif ( itemsLoaded === itemsTotal ) {\n\n\t\t\t\tisLoading = false;\n\n\t\t\t\tif ( scope.onLoad !== undefined ) {\n\n\t\t\t\t\tscope.onLoad();\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t};\n\n\t\tthis.itemError = function ( url ) {\n\n\t\t\tif ( scope.onError !== undefined ) {\n\n\t\t\t\tscope.onError( url );\n\n\t\t\t}\n\n\t\t};\n\n\t\tthis.resolveURL = function ( url ) {\n\n\t\t\tif ( urlModifier ) {\n\n\t\t\t\treturn urlModifier( url );\n\n\t\t\t}\n\n\t\t\treturn url;\n\n\t\t};\n\n\t\tthis.setURLModifier = function ( transform ) {\n\n\t\t\turlModifier = transform;\n\n\t\t\treturn this;\n\n\t\t};\n\n\t\tthis.addHandler = function ( regex, loader ) {\n\n\t\t\thandlers.push( regex, loader );\n\n\t\t\treturn this;\n\n\t\t};\n\n\t\tthis.removeHandler = function ( regex ) {\n\n\t\t\tconst index = handlers.indexOf( regex );\n\n\t\t\tif ( index !== - 1 ) {\n\n\t\t\t\thandlers.splice( index, 2 );\n\n\t\t\t}\n\n\t\t\treturn this;\n\n\t\t};\n\n\t\tthis.getHandler = function ( file ) {\n\n\t\t\tfor ( let i = 0, l = handlers.length; i < l; i += 2 ) {\n\n\t\t\t\tconst regex = handlers[ i ];\n\t\t\t\tconst loader = handlers[ i + 1 ];\n\n\t\t\t\tif ( regex.global ) regex.lastIndex = 0; // see #17920\n\n\t\t\t\tif ( regex.test( file ) ) {\n\n\t\t\t\t\treturn loader;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn null;\n\n\t\t};\n\n\t}\n\n}\n\nconst DefaultLoadingManager = new LoadingManager();\n\nclass Loader {\n\n\tconstructor( manager ) {\n\n\t\tthis.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;\n\n\t\tthis.crossOrigin = 'anonymous';\n\t\tthis.withCredentials = false;\n\t\tthis.path = '';\n\t\tthis.resourcePath = '';\n\t\tthis.requestHeader = {};\n\n\t}\n\n\tload( /* url, onLoad, onProgress, onError */ ) {}\n\n\tloadAsync( url, onProgress ) {\n\n\t\tconst scope = this;\n\n\t\treturn new Promise( function ( resolve, reject ) {\n\n\t\t\tscope.load( url, resolve, onProgress, reject );\n\n\t\t} );\n\n\t}\n\n\tparse( /* data */ ) {}\n\n\tsetCrossOrigin( crossOrigin ) {\n\n\t\tthis.crossOrigin = crossOrigin;\n\t\treturn this;\n\n\t}\n\n\tsetWithCredentials( value ) {\n\n\t\tthis.withCredentials = value;\n\t\treturn this;\n\n\t}\n\n\tsetPath( path ) {\n\n\t\tthis.path = path;\n\t\treturn this;\n\n\t}\n\n\tsetResourcePath( resourcePath ) {\n\n\t\tthis.resourcePath = resourcePath;\n\t\treturn this;\n\n\t}\n\n\tsetRequestHeader( requestHeader ) {\n\n\t\tthis.requestHeader = requestHeader;\n\t\treturn this;\n\n\t}\n\n}\n\nconst loading = {};\n\nclass FileLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tif ( url === undefined ) url = '';\n\n\t\tif ( this.path !== undefined ) url = this.path + url;\n\n\t\turl = this.manager.resolveURL( url );\n\n\t\tconst cached = Cache.get( url );\n\n\t\tif ( cached !== undefined ) {\n\n\t\t\tthis.manager.itemStart( url );\n\n\t\t\tsetTimeout( () => {\n\n\t\t\t\tif ( onLoad ) onLoad( cached );\n\n\t\t\t\tthis.manager.itemEnd( url );\n\n\t\t\t}, 0 );\n\n\t\t\treturn cached;\n\n\t\t}\n\n\t\t// Check if request is duplicate\n\n\t\tif ( loading[ url ] !== undefined ) {\n\n\t\t\tloading[ url ].push( {\n\n\t\t\t\tonLoad: onLoad,\n\t\t\t\tonProgress: onProgress,\n\t\t\t\tonError: onError\n\n\t\t\t} );\n\n\t\t\treturn;\n\n\t\t}\n\n\t\t// Initialise array for duplicate requests\n\t\tloading[ url ] = [];\n\n\t\tloading[ url ].push( {\n\t\t\tonLoad: onLoad,\n\t\t\tonProgress: onProgress,\n\t\t\tonError: onError,\n\t\t} );\n\n\t\t// create request\n\t\tconst req = new Request( url, {\n\t\t\theaders: new Headers( this.requestHeader ),\n\t\t\tcredentials: this.withCredentials ? 'include' : 'same-origin',\n\t\t\t// An abort controller could be added within a future PR\n\t\t} );\n\n\t\t// record states ( avoid data race )\n\t\tconst mimeType = this.mimeType;\n\t\tconst responseType = this.responseType;\n\n\t\t// start the fetch\n\t\tfetch( req )\n\t\t\t.then( response => {\n\n\t\t\t\tif ( response.status === 200 || response.status === 0 ) {\n\n\t\t\t\t\t// Some browsers return HTTP Status 0 when using non-http protocol\n\t\t\t\t\t// e.g. 'file://' or 'data://'. Handle as success.\n\n\t\t\t\t\tif ( response.status === 0 ) {\n\n\t\t\t\t\t\tconsole.warn( 'THREE.FileLoader: HTTP Status 0 received.' );\n\n\t\t\t\t\t}\n\n\t\t\t\t\t// Workaround: Checking if response.body === undefined for Alipay browser #23548\n\n\t\t\t\t\tif ( typeof ReadableStream === 'undefined' || response.body === undefined || response.body.getReader === undefined ) {\n\n\t\t\t\t\t\treturn response;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tconst callbacks = loading[ url ];\n\t\t\t\t\tconst reader = response.body.getReader();\n\t\t\t\t\tconst contentLength = response.headers.get( 'Content-Length' );\n\t\t\t\t\tconst total = contentLength ? parseInt( contentLength ) : 0;\n\t\t\t\t\tconst lengthComputable = total !== 0;\n\t\t\t\t\tlet loaded = 0;\n\n\t\t\t\t\t// periodically read data into the new stream tracking while download progress\n\t\t\t\t\tconst stream = new ReadableStream( {\n\t\t\t\t\t\tstart( controller ) {\n\n\t\t\t\t\t\t\treadData();\n\n\t\t\t\t\t\t\tfunction readData() {\n\n\t\t\t\t\t\t\t\treader.read().then( ( { done, value } ) => {\n\n\t\t\t\t\t\t\t\t\tif ( done ) {\n\n\t\t\t\t\t\t\t\t\t\tcontroller.close();\n\n\t\t\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\t\t\tloaded += value.byteLength;\n\n\t\t\t\t\t\t\t\t\t\tconst event = new ProgressEvent( 'progress', { lengthComputable, loaded, total } );\n\t\t\t\t\t\t\t\t\t\tfor ( let i = 0, il = callbacks.length; i < il; i ++ ) {\n\n\t\t\t\t\t\t\t\t\t\t\tconst callback = callbacks[ i ];\n\t\t\t\t\t\t\t\t\t\t\tif ( callback.onProgress ) callback.onProgress( event );\n\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tcontroller.enqueue( value );\n\t\t\t\t\t\t\t\t\t\treadData();\n\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t} );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn new Response( stream );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthrow Error( `fetch for \"${response.url}\" responded with ${response.status}: ${response.statusText}` );\n\n\t\t\t\t}\n\n\t\t\t} )\n\t\t\t.then( response => {\n\n\t\t\t\tswitch ( responseType ) {\n\n\t\t\t\t\tcase 'arraybuffer':\n\n\t\t\t\t\t\treturn response.arrayBuffer();\n\n\t\t\t\t\tcase 'blob':\n\n\t\t\t\t\t\treturn response.blob();\n\n\t\t\t\t\tcase 'document':\n\n\t\t\t\t\t\treturn response.text()\n\t\t\t\t\t\t\t.then( text => {\n\n\t\t\t\t\t\t\t\tconst parser = new DOMParser();\n\t\t\t\t\t\t\t\treturn parser.parseFromString( text, mimeType );\n\n\t\t\t\t\t\t\t} );\n\n\t\t\t\t\tcase 'json':\n\n\t\t\t\t\t\treturn response.json();\n\n\t\t\t\t\tdefault:\n\n\t\t\t\t\t\tif ( mimeType === undefined ) {\n\n\t\t\t\t\t\t\treturn response.text();\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t// sniff encoding\n\t\t\t\t\t\t\tconst re = /charset=\"?([^;\"\\s]*)\"?/i;\n\t\t\t\t\t\t\tconst exec = re.exec( mimeType );\n\t\t\t\t\t\t\tconst label = exec && exec[ 1 ] ? exec[ 1 ].toLowerCase() : undefined;\n\t\t\t\t\t\t\tconst decoder = new TextDecoder( label );\n\t\t\t\t\t\t\treturn response.arrayBuffer().then( ab => decoder.decode( ab ) );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t} )\n\t\t\t.then( data => {\n\n\t\t\t\t// Add to cache only on HTTP success, so that we do not cache\n\t\t\t\t// error response bodies as proper responses to requests.\n\t\t\t\tCache.add( url, data );\n\n\t\t\t\tconst callbacks = loading[ url ];\n\t\t\t\tdelete loading[ url ];\n\n\t\t\t\tfor ( let i = 0, il = callbacks.length; i < il; i ++ ) {\n\n\t\t\t\t\tconst callback = callbacks[ i ];\n\t\t\t\t\tif ( callback.onLoad ) callback.onLoad( data );\n\n\t\t\t\t}\n\n\t\t\t} )\n\t\t\t.catch( err => {\n\n\t\t\t\t// Abort errors and other errors are handled the same\n\n\t\t\t\tconst callbacks = loading[ url ];\n\n\t\t\t\tif ( callbacks === undefined ) {\n\n\t\t\t\t\t// When onLoad was called and url was deleted in `loading`\n\t\t\t\t\tthis.manager.itemError( url );\n\t\t\t\t\tthrow err;\n\n\t\t\t\t}\n\n\t\t\t\tdelete loading[ url ];\n\n\t\t\t\tfor ( let i = 0, il = callbacks.length; i < il; i ++ ) {\n\n\t\t\t\t\tconst callback = callbacks[ i ];\n\t\t\t\t\tif ( callback.onError ) callback.onError( err );\n\n\t\t\t\t}\n\n\t\t\t\tthis.manager.itemError( url );\n\n\t\t\t} )\n\t\t\t.finally( () => {\n\n\t\t\t\tthis.manager.itemEnd( url );\n\n\t\t\t} );\n\n\t\tthis.manager.itemStart( url );\n\n\t}\n\n\tsetResponseType( value ) {\n\n\t\tthis.responseType = value;\n\t\treturn this;\n\n\t}\n\n\tsetMimeType( value ) {\n\n\t\tthis.mimeType = value;\n\t\treturn this;\n\n\t}\n\n}\n\nclass AnimationLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tconst scope = this;\n\n\t\tconst loader = new FileLoader( this.manager );\n\t\tloader.setPath( this.path );\n\t\tloader.setRequestHeader( this.requestHeader );\n\t\tloader.setWithCredentials( this.withCredentials );\n\t\tloader.load( url, function ( text ) {\n\n\t\t\ttry {\n\n\t\t\t\tonLoad( scope.parse( JSON.parse( text ) ) );\n\n\t\t\t} catch ( e ) {\n\n\t\t\t\tif ( onError ) {\n\n\t\t\t\t\tonError( e );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.error( e );\n\n\t\t\t\t}\n\n\t\t\t\tscope.manager.itemError( url );\n\n\t\t\t}\n\n\t\t}, onProgress, onError );\n\n\t}\n\n\tparse( json ) {\n\n\t\tconst animations = [];\n\n\t\tfor ( let i = 0; i < json.length; i ++ ) {\n\n\t\t\tconst clip = AnimationClip.parse( json[ i ] );\n\n\t\t\tanimations.push( clip );\n\n\t\t}\n\n\t\treturn animations;\n\n\t}\n\n}\n\n/**\n * Abstract Base class to block based textures loader (dds, pvr, ...)\n *\n * Sub classes have to implement the parse() method which will be used in load().\n */\n\nclass CompressedTextureLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tconst scope = this;\n\n\t\tconst images = [];\n\n\t\tconst texture = new CompressedTexture();\n\n\t\tconst loader = new FileLoader( this.manager );\n\t\tloader.setPath( this.path );\n\t\tloader.setResponseType( 'arraybuffer' );\n\t\tloader.setRequestHeader( this.requestHeader );\n\t\tloader.setWithCredentials( scope.withCredentials );\n\n\t\tlet loaded = 0;\n\n\t\tfunction loadTexture( i ) {\n\n\t\t\tloader.load( url[ i ], function ( buffer ) {\n\n\t\t\t\tconst texDatas = scope.parse( buffer, true );\n\n\t\t\t\timages[ i ] = {\n\t\t\t\t\twidth: texDatas.width,\n\t\t\t\t\theight: texDatas.height,\n\t\t\t\t\tformat: texDatas.format,\n\t\t\t\t\tmipmaps: texDatas.mipmaps\n\t\t\t\t};\n\n\t\t\t\tloaded += 1;\n\n\t\t\t\tif ( loaded === 6 ) {\n\n\t\t\t\t\tif ( texDatas.mipmapCount === 1 ) texture.minFilter = LinearFilter;\n\n\t\t\t\t\ttexture.image = images;\n\t\t\t\t\ttexture.format = texDatas.format;\n\t\t\t\t\ttexture.needsUpdate = true;\n\n\t\t\t\t\tif ( onLoad ) onLoad( texture );\n\n\t\t\t\t}\n\n\t\t\t}, onProgress, onError );\n\n\t\t}\n\n\t\tif ( Array.isArray( url ) ) {\n\n\t\t\tfor ( let i = 0, il = url.length; i < il; ++ i ) {\n\n\t\t\t\tloadTexture( i );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t// compressed cubemap texture stored in a single DDS file\n\n\t\t\tloader.load( url, function ( buffer ) {\n\n\t\t\t\tconst texDatas = scope.parse( buffer, true );\n\n\t\t\t\tif ( texDatas.isCubemap ) {\n\n\t\t\t\t\tconst faces = texDatas.mipmaps.length / texDatas.mipmapCount;\n\n\t\t\t\t\tfor ( let f = 0; f < faces; f ++ ) {\n\n\t\t\t\t\t\timages[ f ] = { mipmaps: [] };\n\n\t\t\t\t\t\tfor ( let i = 0; i < texDatas.mipmapCount; i ++ ) {\n\n\t\t\t\t\t\t\timages[ f ].mipmaps.push( texDatas.mipmaps[ f * texDatas.mipmapCount + i ] );\n\t\t\t\t\t\t\timages[ f ].format = texDatas.format;\n\t\t\t\t\t\t\timages[ f ].width = texDatas.width;\n\t\t\t\t\t\t\timages[ f ].height = texDatas.height;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\ttexture.image = images;\n\n\t\t\t\t} else {\n\n\t\t\t\t\ttexture.image.width = texDatas.width;\n\t\t\t\t\ttexture.image.height = texDatas.height;\n\t\t\t\t\ttexture.mipmaps = texDatas.mipmaps;\n\n\t\t\t\t}\n\n\t\t\t\tif ( texDatas.mipmapCount === 1 ) {\n\n\t\t\t\t\ttexture.minFilter = LinearFilter;\n\n\t\t\t\t}\n\n\t\t\t\ttexture.format = texDatas.format;\n\t\t\t\ttexture.needsUpdate = true;\n\n\t\t\t\tif ( onLoad ) onLoad( texture );\n\n\t\t\t}, onProgress, onError );\n\n\t\t}\n\n\t\treturn texture;\n\n\t}\n\n}\n\nclass ImageLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tif ( this.path !== undefined ) url = this.path + url;\n\n\t\turl = this.manager.resolveURL( url );\n\n\t\tconst scope = this;\n\n\t\tconst cached = Cache.get( url );\n\n\t\tif ( cached !== undefined ) {\n\n\t\t\tscope.manager.itemStart( url );\n\n\t\t\tsetTimeout( function () {\n\n\t\t\t\tif ( onLoad ) onLoad( cached );\n\n\t\t\t\tscope.manager.itemEnd( url );\n\n\t\t\t}, 0 );\n\n\t\t\treturn cached;\n\n\t\t}\n\n\t\tconst image = createElementNS( 'img' );\n\n\t\tfunction onImageLoad() {\n\n\t\t\tremoveEventListeners();\n\n\t\t\tCache.add( url, this );\n\n\t\t\tif ( onLoad ) onLoad( this );\n\n\t\t\tscope.manager.itemEnd( url );\n\n\t\t}\n\n\t\tfunction onImageError( event ) {\n\n\t\t\tremoveEventListeners();\n\n\t\t\tif ( onError ) onError( event );\n\n\t\t\tscope.manager.itemError( url );\n\t\t\tscope.manager.itemEnd( url );\n\n\t\t}\n\n\t\tfunction removeEventListeners() {\n\n\t\t\timage.removeEventListener( 'load', onImageLoad, false );\n\t\t\timage.removeEventListener( 'error', onImageError, false );\n\n\t\t}\n\n\t\timage.addEventListener( 'load', onImageLoad, false );\n\t\timage.addEventListener( 'error', onImageError, false );\n\n\t\tif ( url.slice( 0, 5 ) !== 'data:' ) {\n\n\t\t\tif ( this.crossOrigin !== undefined ) image.crossOrigin = this.crossOrigin;\n\n\t\t}\n\n\t\tscope.manager.itemStart( url );\n\n\t\timage.src = url;\n\n\t\treturn image;\n\n\t}\n\n}\n\nclass CubeTextureLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t}\n\n\tload( urls, onLoad, onProgress, onError ) {\n\n\t\tconst texture = new CubeTexture();\n\n\t\tconst loader = new ImageLoader( this.manager );\n\t\tloader.setCrossOrigin( this.crossOrigin );\n\t\tloader.setPath( this.path );\n\n\t\tlet loaded = 0;\n\n\t\tfunction loadTexture( i ) {\n\n\t\t\tloader.load( urls[ i ], function ( image ) {\n\n\t\t\t\ttexture.images[ i ] = image;\n\n\t\t\t\tloaded ++;\n\n\t\t\t\tif ( loaded === 6 ) {\n\n\t\t\t\t\ttexture.needsUpdate = true;\n\n\t\t\t\t\tif ( onLoad ) onLoad( texture );\n\n\t\t\t\t}\n\n\t\t\t}, undefined, onError );\n\n\t\t}\n\n\t\tfor ( let i = 0; i < urls.length; ++ i ) {\n\n\t\t\tloadTexture( i );\n\n\t\t}\n\n\t\treturn texture;\n\n\t}\n\n}\n\n/**\n * Abstract Base class to load generic binary textures formats (rgbe, hdr, ...)\n *\n * Sub classes have to implement the parse() method which will be used in load().\n */\n\nclass DataTextureLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tconst scope = this;\n\n\t\tconst texture = new DataTexture();\n\n\t\tconst loader = new FileLoader( this.manager );\n\t\tloader.setResponseType( 'arraybuffer' );\n\t\tloader.setRequestHeader( this.requestHeader );\n\t\tloader.setPath( this.path );\n\t\tloader.setWithCredentials( scope.withCredentials );\n\t\tloader.load( url, function ( buffer ) {\n\n\t\t\tconst texData = scope.parse( buffer );\n\n\t\t\tif ( ! texData ) return;\n\n\t\t\tif ( texData.image !== undefined ) {\n\n\t\t\t\ttexture.image = texData.image;\n\n\t\t\t} else if ( texData.data !== undefined ) {\n\n\t\t\t\ttexture.image.width = texData.width;\n\t\t\t\ttexture.image.height = texData.height;\n\t\t\t\ttexture.image.data = texData.data;\n\n\t\t\t}\n\n\t\t\ttexture.wrapS = texData.wrapS !== undefined ? texData.wrapS : ClampToEdgeWrapping;\n\t\t\ttexture.wrapT = texData.wrapT !== undefined ? texData.wrapT : ClampToEdgeWrapping;\n\n\t\t\ttexture.magFilter = texData.magFilter !== undefined ? texData.magFilter : LinearFilter;\n\t\t\ttexture.minFilter = texData.minFilter !== undefined ? texData.minFilter : LinearFilter;\n\n\t\t\ttexture.anisotropy = texData.anisotropy !== undefined ? texData.anisotropy : 1;\n\n\t\t\tif ( texData.encoding !== undefined ) {\n\n\t\t\t\ttexture.encoding = texData.encoding;\n\n\t\t\t}\n\n\t\t\tif ( texData.flipY !== undefined ) {\n\n\t\t\t\ttexture.flipY = texData.flipY;\n\n\t\t\t}\n\n\t\t\tif ( texData.format !== undefined ) {\n\n\t\t\t\ttexture.format = texData.format;\n\n\t\t\t}\n\n\t\t\tif ( texData.type !== undefined ) {\n\n\t\t\t\ttexture.type = texData.type;\n\n\t\t\t}\n\n\t\t\tif ( texData.mipmaps !== undefined ) {\n\n\t\t\t\ttexture.mipmaps = texData.mipmaps;\n\t\t\t\ttexture.minFilter = LinearMipmapLinearFilter; // presumably...\n\n\t\t\t}\n\n\t\t\tif ( texData.mipmapCount === 1 ) {\n\n\t\t\t\ttexture.minFilter = LinearFilter;\n\n\t\t\t}\n\n\t\t\tif ( texData.generateMipmaps !== undefined ) {\n\n\t\t\t\ttexture.generateMipmaps = texData.generateMipmaps;\n\n\t\t\t}\n\n\t\t\ttexture.needsUpdate = true;\n\n\t\t\tif ( onLoad ) onLoad( texture, texData );\n\n\t\t}, onProgress, onError );\n\n\n\t\treturn texture;\n\n\t}\n\n}\n\nclass TextureLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tconst texture = new Texture();\n\n\t\tconst loader = new ImageLoader( this.manager );\n\t\tloader.setCrossOrigin( this.crossOrigin );\n\t\tloader.setPath( this.path );\n\n\t\tloader.load( url, function ( image ) {\n\n\t\t\ttexture.image = image;\n\t\t\ttexture.needsUpdate = true;\n\n\t\t\tif ( onLoad !== undefined ) {\n\n\t\t\t\tonLoad( texture );\n\n\t\t\t}\n\n\t\t}, onProgress, onError );\n\n\t\treturn texture;\n\n\t}\n\n}\n\nclass Light extends Object3D {\n\n\tconstructor( color, intensity = 1 ) {\n\n\t\tsuper();\n\n\t\tthis.isLight = true;\n\n\t\tthis.type = 'Light';\n\n\t\tthis.color = new Color( color );\n\t\tthis.intensity = intensity;\n\n\t}\n\n\tdispose() {\n\n\t\t// Empty here in base class; some subclasses override.\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tthis.color.copy( source.color );\n\t\tthis.intensity = source.intensity;\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON( meta ) {\n\n\t\tconst data = super.toJSON( meta );\n\n\t\tdata.object.color = this.color.getHex();\n\t\tdata.object.intensity = this.intensity;\n\n\t\tif ( this.groundColor !== undefined ) data.object.groundColor = this.groundColor.getHex();\n\n\t\tif ( this.distance !== undefined ) data.object.distance = this.distance;\n\t\tif ( this.angle !== undefined ) data.object.angle = this.angle;\n\t\tif ( this.decay !== undefined ) data.object.decay = this.decay;\n\t\tif ( this.penumbra !== undefined ) data.object.penumbra = this.penumbra;\n\n\t\tif ( this.shadow !== undefined ) data.object.shadow = this.shadow.toJSON();\n\n\t\treturn data;\n\n\t}\n\n}\n\nclass HemisphereLight extends Light {\n\n\tconstructor( skyColor, groundColor, intensity ) {\n\n\t\tsuper( skyColor, intensity );\n\n\t\tthis.isHemisphereLight = true;\n\n\t\tthis.type = 'HemisphereLight';\n\n\t\tthis.position.copy( Object3D.DefaultUp );\n\t\tthis.updateMatrix();\n\n\t\tthis.groundColor = new Color( groundColor );\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tthis.groundColor.copy( source.groundColor );\n\n\t\treturn this;\n\n\t}\n\n}\n\nconst _projScreenMatrix$1 = /*@__PURE__*/ new Matrix4();\nconst _lightPositionWorld$1 = /*@__PURE__*/ new Vector3();\nconst _lookTarget$1 = /*@__PURE__*/ new Vector3();\n\nclass LightShadow {\n\n\tconstructor( camera ) {\n\n\t\tthis.camera = camera;\n\n\t\tthis.bias = 0;\n\t\tthis.normalBias = 0;\n\t\tthis.radius = 1;\n\t\tthis.blurSamples = 8;\n\n\t\tthis.mapSize = new Vector2( 512, 512 );\n\n\t\tthis.map = null;\n\t\tthis.mapPass = null;\n\t\tthis.matrix = new Matrix4();\n\n\t\tthis.autoUpdate = true;\n\t\tthis.needsUpdate = false;\n\n\t\tthis._frustum = new Frustum();\n\t\tthis._frameExtents = new Vector2( 1, 1 );\n\n\t\tthis._viewportCount = 1;\n\n\t\tthis._viewports = [\n\n\t\t\tnew Vector4( 0, 0, 1, 1 )\n\n\t\t];\n\n\t}\n\n\tgetViewportCount() {\n\n\t\treturn this._viewportCount;\n\n\t}\n\n\tgetFrustum() {\n\n\t\treturn this._frustum;\n\n\t}\n\n\tupdateMatrices( light ) {\n\n\t\tconst shadowCamera = this.camera;\n\t\tconst shadowMatrix = this.matrix;\n\n\t\t_lightPositionWorld$1.setFromMatrixPosition( light.matrixWorld );\n\t\tshadowCamera.position.copy( _lightPositionWorld$1 );\n\n\t\t_lookTarget$1.setFromMatrixPosition( light.target.matrixWorld );\n\t\tshadowCamera.lookAt( _lookTarget$1 );\n\t\tshadowCamera.updateMatrixWorld();\n\n\t\t_projScreenMatrix$1.multiplyMatrices( shadowCamera.projectionMatrix, shadowCamera.matrixWorldInverse );\n\t\tthis._frustum.setFromProjectionMatrix( _projScreenMatrix$1 );\n\n\t\tshadowMatrix.set(\n\t\t\t0.5, 0.0, 0.0, 0.5,\n\t\t\t0.0, 0.5, 0.0, 0.5,\n\t\t\t0.0, 0.0, 0.5, 0.5,\n\t\t\t0.0, 0.0, 0.0, 1.0\n\t\t);\n\n\t\tshadowMatrix.multiply( shadowCamera.projectionMatrix );\n\t\tshadowMatrix.multiply( shadowCamera.matrixWorldInverse );\n\n\t}\n\n\tgetViewport( viewportIndex ) {\n\n\t\treturn this._viewports[ viewportIndex ];\n\n\t}\n\n\tgetFrameExtents() {\n\n\t\treturn this._frameExtents;\n\n\t}\n\n\tdispose() {\n\n\t\tif ( this.map ) {\n\n\t\t\tthis.map.dispose();\n\n\t\t}\n\n\t\tif ( this.mapPass ) {\n\n\t\t\tthis.mapPass.dispose();\n\n\t\t}\n\n\t}\n\n\tcopy( source ) {\n\n\t\tthis.camera = source.camera.clone();\n\n\t\tthis.bias = source.bias;\n\t\tthis.radius = source.radius;\n\n\t\tthis.mapSize.copy( source.mapSize );\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst object = {};\n\n\t\tif ( this.bias !== 0 ) object.bias = this.bias;\n\t\tif ( this.normalBias !== 0 ) object.normalBias = this.normalBias;\n\t\tif ( this.radius !== 1 ) object.radius = this.radius;\n\t\tif ( this.mapSize.x !== 512 || this.mapSize.y !== 512 ) object.mapSize = this.mapSize.toArray();\n\n\t\tobject.camera = this.camera.toJSON( false ).object;\n\t\tdelete object.camera.matrix;\n\n\t\treturn object;\n\n\t}\n\n}\n\nclass SpotLightShadow extends LightShadow {\n\n\tconstructor() {\n\n\t\tsuper( new PerspectiveCamera( 50, 1, 0.5, 500 ) );\n\n\t\tthis.isSpotLightShadow = true;\n\n\t\tthis.focus = 1;\n\n\t}\n\n\tupdateMatrices( light ) {\n\n\t\tconst camera = this.camera;\n\n\t\tconst fov = RAD2DEG * 2 * light.angle * this.focus;\n\t\tconst aspect = this.mapSize.width / this.mapSize.height;\n\t\tconst far = light.distance || camera.far;\n\n\t\tif ( fov !== camera.fov || aspect !== camera.aspect || far !== camera.far ) {\n\n\t\t\tcamera.fov = fov;\n\t\t\tcamera.aspect = aspect;\n\t\t\tcamera.far = far;\n\t\t\tcamera.updateProjectionMatrix();\n\n\t\t}\n\n\t\tsuper.updateMatrices( light );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.focus = source.focus;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass SpotLight extends Light {\n\n\tconstructor( color, intensity, distance = 0, angle = Math.PI / 3, penumbra = 0, decay = 1 ) {\n\n\t\tsuper( color, intensity );\n\n\t\tthis.isSpotLight = true;\n\n\t\tthis.type = 'SpotLight';\n\n\t\tthis.position.copy( Object3D.DefaultUp );\n\t\tthis.updateMatrix();\n\n\t\tthis.target = new Object3D();\n\n\t\tthis.distance = distance;\n\t\tthis.angle = angle;\n\t\tthis.penumbra = penumbra;\n\t\tthis.decay = decay; // for physically correct lights, should be 2.\n\n\t\tthis.shadow = new SpotLightShadow();\n\n\t}\n\n\tget power() {\n\n\t\t// compute the light's luminous power (in lumens) from its intensity (in candela)\n\t\t// by convention for a spotlight, luminous power (lm) = π * luminous intensity (cd)\n\t\treturn this.intensity * Math.PI;\n\n\t}\n\n\tset power( power ) {\n\n\t\t// set the light's intensity (in candela) from the desired luminous power (in lumens)\n\t\tthis.intensity = power / Math.PI;\n\n\t}\n\n\tdispose() {\n\n\t\tthis.shadow.dispose();\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tthis.distance = source.distance;\n\t\tthis.angle = source.angle;\n\t\tthis.penumbra = source.penumbra;\n\t\tthis.decay = source.decay;\n\n\t\tthis.target = source.target.clone();\n\n\t\tthis.shadow = source.shadow.clone();\n\n\t\treturn this;\n\n\t}\n\n}\n\nconst _projScreenMatrix = /*@__PURE__*/ new Matrix4();\nconst _lightPositionWorld = /*@__PURE__*/ new Vector3();\nconst _lookTarget = /*@__PURE__*/ new Vector3();\n\nclass PointLightShadow extends LightShadow {\n\n\tconstructor() {\n\n\t\tsuper( new PerspectiveCamera( 90, 1, 0.5, 500 ) );\n\n\t\tthis.isPointLightShadow = true;\n\n\t\tthis._frameExtents = new Vector2( 4, 2 );\n\n\t\tthis._viewportCount = 6;\n\n\t\tthis._viewports = [\n\t\t\t// These viewports map a cube-map onto a 2D texture with the\n\t\t\t// following orientation:\n\t\t\t//\n\t\t\t// xzXZ\n\t\t\t// y Y\n\t\t\t//\n\t\t\t// X - Positive x direction\n\t\t\t// x - Negative x direction\n\t\t\t// Y - Positive y direction\n\t\t\t// y - Negative y direction\n\t\t\t// Z - Positive z direction\n\t\t\t// z - Negative z direction\n\n\t\t\t// positive X\n\t\t\tnew Vector4( 2, 1, 1, 1 ),\n\t\t\t// negative X\n\t\t\tnew Vector4( 0, 1, 1, 1 ),\n\t\t\t// positive Z\n\t\t\tnew Vector4( 3, 1, 1, 1 ),\n\t\t\t// negative Z\n\t\t\tnew Vector4( 1, 1, 1, 1 ),\n\t\t\t// positive Y\n\t\t\tnew Vector4( 3, 0, 1, 1 ),\n\t\t\t// negative Y\n\t\t\tnew Vector4( 1, 0, 1, 1 )\n\t\t];\n\n\t\tthis._cubeDirections = [\n\t\t\tnew Vector3( 1, 0, 0 ), new Vector3( - 1, 0, 0 ), new Vector3( 0, 0, 1 ),\n\t\t\tnew Vector3( 0, 0, - 1 ), new Vector3( 0, 1, 0 ), new Vector3( 0, - 1, 0 )\n\t\t];\n\n\t\tthis._cubeUps = [\n\t\t\tnew Vector3( 0, 1, 0 ), new Vector3( 0, 1, 0 ), new Vector3( 0, 1, 0 ),\n\t\t\tnew Vector3( 0, 1, 0 ), new Vector3( 0, 0, 1 ),\tnew Vector3( 0, 0, - 1 )\n\t\t];\n\n\t}\n\n\tupdateMatrices( light, viewportIndex = 0 ) {\n\n\t\tconst camera = this.camera;\n\t\tconst shadowMatrix = this.matrix;\n\n\t\tconst far = light.distance || camera.far;\n\n\t\tif ( far !== camera.far ) {\n\n\t\t\tcamera.far = far;\n\t\t\tcamera.updateProjectionMatrix();\n\n\t\t}\n\n\t\t_lightPositionWorld.setFromMatrixPosition( light.matrixWorld );\n\t\tcamera.position.copy( _lightPositionWorld );\n\n\t\t_lookTarget.copy( camera.position );\n\t\t_lookTarget.add( this._cubeDirections[ viewportIndex ] );\n\t\tcamera.up.copy( this._cubeUps[ viewportIndex ] );\n\t\tcamera.lookAt( _lookTarget );\n\t\tcamera.updateMatrixWorld();\n\n\t\tshadowMatrix.makeTranslation( - _lightPositionWorld.x, - _lightPositionWorld.y, - _lightPositionWorld.z );\n\n\t\t_projScreenMatrix.multiplyMatrices( camera.projectionMatrix, camera.matrixWorldInverse );\n\t\tthis._frustum.setFromProjectionMatrix( _projScreenMatrix );\n\n\t}\n\n}\n\nclass PointLight extends Light {\n\n\tconstructor( color, intensity, distance = 0, decay = 1 ) {\n\n\t\tsuper( color, intensity );\n\n\t\tthis.isPointLight = true;\n\n\t\tthis.type = 'PointLight';\n\n\t\tthis.distance = distance;\n\t\tthis.decay = decay; // for physically correct lights, should be 2.\n\n\t\tthis.shadow = new PointLightShadow();\n\n\t}\n\n\tget power() {\n\n\t\t// compute the light's luminous power (in lumens) from its intensity (in candela)\n\t\t// for an isotropic light source, luminous power (lm) = 4 π luminous intensity (cd)\n\t\treturn this.intensity * 4 * Math.PI;\n\n\t}\n\n\tset power( power ) {\n\n\t\t// set the light's intensity (in candela) from the desired luminous power (in lumens)\n\t\tthis.intensity = power / ( 4 * Math.PI );\n\n\t}\n\n\tdispose() {\n\n\t\tthis.shadow.dispose();\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tthis.distance = source.distance;\n\t\tthis.decay = source.decay;\n\n\t\tthis.shadow = source.shadow.clone();\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass DirectionalLightShadow extends LightShadow {\n\n\tconstructor() {\n\n\t\tsuper( new OrthographicCamera( - 5, 5, 5, - 5, 0.5, 500 ) );\n\n\t\tthis.isDirectionalLightShadow = true;\n\n\t}\n\n}\n\nclass DirectionalLight extends Light {\n\n\tconstructor( color, intensity ) {\n\n\t\tsuper( color, intensity );\n\n\t\tthis.isDirectionalLight = true;\n\n\t\tthis.type = 'DirectionalLight';\n\n\t\tthis.position.copy( Object3D.DefaultUp );\n\t\tthis.updateMatrix();\n\n\t\tthis.target = new Object3D();\n\n\t\tthis.shadow = new DirectionalLightShadow();\n\n\t}\n\n\tdispose() {\n\n\t\tthis.shadow.dispose();\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.target = source.target.clone();\n\t\tthis.shadow = source.shadow.clone();\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass AmbientLight extends Light {\n\n\tconstructor( color, intensity ) {\n\n\t\tsuper( color, intensity );\n\n\t\tthis.isAmbientLight = true;\n\n\t\tthis.type = 'AmbientLight';\n\n\t}\n\n}\n\nclass RectAreaLight extends Light {\n\n\tconstructor( color, intensity, width = 10, height = 10 ) {\n\n\t\tsuper( color, intensity );\n\n\t\tthis.isRectAreaLight = true;\n\n\t\tthis.type = 'RectAreaLight';\n\n\t\tthis.width = width;\n\t\tthis.height = height;\n\n\t}\n\n\tget power() {\n\n\t\t// compute the light's luminous power (in lumens) from its intensity (in nits)\n\t\treturn this.intensity * this.width * this.height * Math.PI;\n\n\t}\n\n\tset power( power ) {\n\n\t\t// set the light's intensity (in nits) from the desired luminous power (in lumens)\n\t\tthis.intensity = power / ( this.width * this.height * Math.PI );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.width = source.width;\n\t\tthis.height = source.height;\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON( meta ) {\n\n\t\tconst data = super.toJSON( meta );\n\n\t\tdata.object.width = this.width;\n\t\tdata.object.height = this.height;\n\n\t\treturn data;\n\n\t}\n\n}\n\n/**\n * Primary reference:\n * https://graphics.stanford.edu/papers/envmap/envmap.pdf\n *\n * Secondary reference:\n * https://www.ppsloan.org/publications/StupidSH36.pdf\n */\n\n// 3-band SH defined by 9 coefficients\n\nclass SphericalHarmonics3 {\n\n\tconstructor() {\n\n\t\tthis.isSphericalHarmonics3 = true;\n\n\t\tthis.coefficients = [];\n\n\t\tfor ( let i = 0; i < 9; i ++ ) {\n\n\t\t\tthis.coefficients.push( new Vector3() );\n\n\t\t}\n\n\t}\n\n\tset( coefficients ) {\n\n\t\tfor ( let i = 0; i < 9; i ++ ) {\n\n\t\t\tthis.coefficients[ i ].copy( coefficients[ i ] );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tzero() {\n\n\t\tfor ( let i = 0; i < 9; i ++ ) {\n\n\t\t\tthis.coefficients[ i ].set( 0, 0, 0 );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\t// get the radiance in the direction of the normal\n\t// target is a Vector3\n\tgetAt( normal, target ) {\n\n\t\t// normal is assumed to be unit length\n\n\t\tconst x = normal.x, y = normal.y, z = normal.z;\n\n\t\tconst coeff = this.coefficients;\n\n\t\t// band 0\n\t\ttarget.copy( coeff[ 0 ] ).multiplyScalar( 0.282095 );\n\n\t\t// band 1\n\t\ttarget.addScaledVector( coeff[ 1 ], 0.488603 * y );\n\t\ttarget.addScaledVector( coeff[ 2 ], 0.488603 * z );\n\t\ttarget.addScaledVector( coeff[ 3 ], 0.488603 * x );\n\n\t\t// band 2\n\t\ttarget.addScaledVector( coeff[ 4 ], 1.092548 * ( x * y ) );\n\t\ttarget.addScaledVector( coeff[ 5 ], 1.092548 * ( y * z ) );\n\t\ttarget.addScaledVector( coeff[ 6 ], 0.315392 * ( 3.0 * z * z - 1.0 ) );\n\t\ttarget.addScaledVector( coeff[ 7 ], 1.092548 * ( x * z ) );\n\t\ttarget.addScaledVector( coeff[ 8 ], 0.546274 * ( x * x - y * y ) );\n\n\t\treturn target;\n\n\t}\n\n\t// get the irradiance (radiance convolved with cosine lobe) in the direction of the normal\n\t// target is a Vector3\n\t// https://graphics.stanford.edu/papers/envmap/envmap.pdf\n\tgetIrradianceAt( normal, target ) {\n\n\t\t// normal is assumed to be unit length\n\n\t\tconst x = normal.x, y = normal.y, z = normal.z;\n\n\t\tconst coeff = this.coefficients;\n\n\t\t// band 0\n\t\ttarget.copy( coeff[ 0 ] ).multiplyScalar( 0.886227 ); // π * 0.282095\n\n\t\t// band 1\n\t\ttarget.addScaledVector( coeff[ 1 ], 2.0 * 0.511664 * y ); // ( 2 * π / 3 ) * 0.488603\n\t\ttarget.addScaledVector( coeff[ 2 ], 2.0 * 0.511664 * z );\n\t\ttarget.addScaledVector( coeff[ 3 ], 2.0 * 0.511664 * x );\n\n\t\t// band 2\n\t\ttarget.addScaledVector( coeff[ 4 ], 2.0 * 0.429043 * x * y ); // ( π / 4 ) * 1.092548\n\t\ttarget.addScaledVector( coeff[ 5 ], 2.0 * 0.429043 * y * z );\n\t\ttarget.addScaledVector( coeff[ 6 ], 0.743125 * z * z - 0.247708 ); // ( π / 4 ) * 0.315392 * 3\n\t\ttarget.addScaledVector( coeff[ 7 ], 2.0 * 0.429043 * x * z );\n\t\ttarget.addScaledVector( coeff[ 8 ], 0.429043 * ( x * x - y * y ) ); // ( π / 4 ) * 0.546274\n\n\t\treturn target;\n\n\t}\n\n\tadd( sh ) {\n\n\t\tfor ( let i = 0; i < 9; i ++ ) {\n\n\t\t\tthis.coefficients[ i ].add( sh.coefficients[ i ] );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\taddScaledSH( sh, s ) {\n\n\t\tfor ( let i = 0; i < 9; i ++ ) {\n\n\t\t\tthis.coefficients[ i ].addScaledVector( sh.coefficients[ i ], s );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tscale( s ) {\n\n\t\tfor ( let i = 0; i < 9; i ++ ) {\n\n\t\t\tthis.coefficients[ i ].multiplyScalar( s );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tlerp( sh, alpha ) {\n\n\t\tfor ( let i = 0; i < 9; i ++ ) {\n\n\t\t\tthis.coefficients[ i ].lerp( sh.coefficients[ i ], alpha );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tequals( sh ) {\n\n\t\tfor ( let i = 0; i < 9; i ++ ) {\n\n\t\t\tif ( ! this.coefficients[ i ].equals( sh.coefficients[ i ] ) ) {\n\n\t\t\t\treturn false;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn true;\n\n\t}\n\n\tcopy( sh ) {\n\n\t\treturn this.set( sh.coefficients );\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n\tfromArray( array, offset = 0 ) {\n\n\t\tconst coefficients = this.coefficients;\n\n\t\tfor ( let i = 0; i < 9; i ++ ) {\n\n\t\t\tcoefficients[ i ].fromArray( array, offset + ( i * 3 ) );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\ttoArray( array = [], offset = 0 ) {\n\n\t\tconst coefficients = this.coefficients;\n\n\t\tfor ( let i = 0; i < 9; i ++ ) {\n\n\t\t\tcoefficients[ i ].toArray( array, offset + ( i * 3 ) );\n\n\t\t}\n\n\t\treturn array;\n\n\t}\n\n\t// evaluate the basis functions\n\t// shBasis is an Array[ 9 ]\n\tstatic getBasisAt( normal, shBasis ) {\n\n\t\t// normal is assumed to be unit length\n\n\t\tconst x = normal.x, y = normal.y, z = normal.z;\n\n\t\t// band 0\n\t\tshBasis[ 0 ] = 0.282095;\n\n\t\t// band 1\n\t\tshBasis[ 1 ] = 0.488603 * y;\n\t\tshBasis[ 2 ] = 0.488603 * z;\n\t\tshBasis[ 3 ] = 0.488603 * x;\n\n\t\t// band 2\n\t\tshBasis[ 4 ] = 1.092548 * x * y;\n\t\tshBasis[ 5 ] = 1.092548 * y * z;\n\t\tshBasis[ 6 ] = 0.315392 * ( 3 * z * z - 1 );\n\t\tshBasis[ 7 ] = 1.092548 * x * z;\n\t\tshBasis[ 8 ] = 0.546274 * ( x * x - y * y );\n\n\t}\n\n}\n\nclass LightProbe extends Light {\n\n\tconstructor( sh = new SphericalHarmonics3(), intensity = 1 ) {\n\n\t\tsuper( undefined, intensity );\n\n\t\tthis.isLightProbe = true;\n\n\t\tthis.sh = sh;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.sh.copy( source.sh );\n\n\t\treturn this;\n\n\t}\n\n\tfromJSON( json ) {\n\n\t\tthis.intensity = json.intensity; // TODO: Move this bit to Light.fromJSON();\n\t\tthis.sh.fromArray( json.sh );\n\n\t\treturn this;\n\n\t}\n\n\ttoJSON( meta ) {\n\n\t\tconst data = super.toJSON( meta );\n\n\t\tdata.object.sh = this.sh.toArray();\n\n\t\treturn data;\n\n\t}\n\n}\n\nclass MaterialLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\t\tthis.textures = {};\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tconst scope = this;\n\n\t\tconst loader = new FileLoader( scope.manager );\n\t\tloader.setPath( scope.path );\n\t\tloader.setRequestHeader( scope.requestHeader );\n\t\tloader.setWithCredentials( scope.withCredentials );\n\t\tloader.load( url, function ( text ) {\n\n\t\t\ttry {\n\n\t\t\t\tonLoad( scope.parse( JSON.parse( text ) ) );\n\n\t\t\t} catch ( e ) {\n\n\t\t\t\tif ( onError ) {\n\n\t\t\t\t\tonError( e );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.error( e );\n\n\t\t\t\t}\n\n\t\t\t\tscope.manager.itemError( url );\n\n\t\t\t}\n\n\t\t}, onProgress, onError );\n\n\t}\n\n\tparse( json ) {\n\n\t\tconst textures = this.textures;\n\n\t\tfunction getTexture( name ) {\n\n\t\t\tif ( textures[ name ] === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.MaterialLoader: Undefined texture', name );\n\n\t\t\t}\n\n\t\t\treturn textures[ name ];\n\n\t\t}\n\n\t\tconst material = Material.fromType( json.type );\n\n\t\tif ( json.uuid !== undefined ) material.uuid = json.uuid;\n\t\tif ( json.name !== undefined ) material.name = json.name;\n\t\tif ( json.color !== undefined && material.color !== undefined ) material.color.setHex( json.color );\n\t\tif ( json.roughness !== undefined ) material.roughness = json.roughness;\n\t\tif ( json.metalness !== undefined ) material.metalness = json.metalness;\n\t\tif ( json.sheen !== undefined ) material.sheen = json.sheen;\n\t\tif ( json.sheenColor !== undefined ) material.sheenColor = new Color().setHex( json.sheenColor );\n\t\tif ( json.sheenRoughness !== undefined ) material.sheenRoughness = json.sheenRoughness;\n\t\tif ( json.emissive !== undefined && material.emissive !== undefined ) material.emissive.setHex( json.emissive );\n\t\tif ( json.specular !== undefined && material.specular !== undefined ) material.specular.setHex( json.specular );\n\t\tif ( json.specularIntensity !== undefined ) material.specularIntensity = json.specularIntensity;\n\t\tif ( json.specularColor !== undefined && material.specularColor !== undefined ) material.specularColor.setHex( json.specularColor );\n\t\tif ( json.shininess !== undefined ) material.shininess = json.shininess;\n\t\tif ( json.clearcoat !== undefined ) material.clearcoat = json.clearcoat;\n\t\tif ( json.clearcoatRoughness !== undefined ) material.clearcoatRoughness = json.clearcoatRoughness;\n\t\tif ( json.iridescence !== undefined ) material.iridescence = json.iridescence;\n\t\tif ( json.iridescenceIOR !== undefined ) material.iridescenceIOR = json.iridescenceIOR;\n\t\tif ( json.iridescenceThicknessRange !== undefined ) material.iridescenceThicknessRange = json.iridescenceThicknessRange;\n\t\tif ( json.transmission !== undefined ) material.transmission = json.transmission;\n\t\tif ( json.thickness !== undefined ) material.thickness = json.thickness;\n\t\tif ( json.attenuationDistance !== undefined ) material.attenuationDistance = json.attenuationDistance;\n\t\tif ( json.attenuationColor !== undefined && material.attenuationColor !== undefined ) material.attenuationColor.setHex( json.attenuationColor );\n\t\tif ( json.fog !== undefined ) material.fog = json.fog;\n\t\tif ( json.flatShading !== undefined ) material.flatShading = json.flatShading;\n\t\tif ( json.blending !== undefined ) material.blending = json.blending;\n\t\tif ( json.combine !== undefined ) material.combine = json.combine;\n\t\tif ( json.side !== undefined ) material.side = json.side;\n\t\tif ( json.shadowSide !== undefined ) material.shadowSide = json.shadowSide;\n\t\tif ( json.opacity !== undefined ) material.opacity = json.opacity;\n\t\tif ( json.transparent !== undefined ) material.transparent = json.transparent;\n\t\tif ( json.alphaTest !== undefined ) material.alphaTest = json.alphaTest;\n\t\tif ( json.depthTest !== undefined ) material.depthTest = json.depthTest;\n\t\tif ( json.depthWrite !== undefined ) material.depthWrite = json.depthWrite;\n\t\tif ( json.colorWrite !== undefined ) material.colorWrite = json.colorWrite;\n\n\t\tif ( json.stencilWrite !== undefined ) material.stencilWrite = json.stencilWrite;\n\t\tif ( json.stencilWriteMask !== undefined ) material.stencilWriteMask = json.stencilWriteMask;\n\t\tif ( json.stencilFunc !== undefined ) material.stencilFunc = json.stencilFunc;\n\t\tif ( json.stencilRef !== undefined ) material.stencilRef = json.stencilRef;\n\t\tif ( json.stencilFuncMask !== undefined ) material.stencilFuncMask = json.stencilFuncMask;\n\t\tif ( json.stencilFail !== undefined ) material.stencilFail = json.stencilFail;\n\t\tif ( json.stencilZFail !== undefined ) material.stencilZFail = json.stencilZFail;\n\t\tif ( json.stencilZPass !== undefined ) material.stencilZPass = json.stencilZPass;\n\n\t\tif ( json.wireframe !== undefined ) material.wireframe = json.wireframe;\n\t\tif ( json.wireframeLinewidth !== undefined ) material.wireframeLinewidth = json.wireframeLinewidth;\n\t\tif ( json.wireframeLinecap !== undefined ) material.wireframeLinecap = json.wireframeLinecap;\n\t\tif ( json.wireframeLinejoin !== undefined ) material.wireframeLinejoin = json.wireframeLinejoin;\n\n\t\tif ( json.rotation !== undefined ) material.rotation = json.rotation;\n\n\t\tif ( json.linewidth !== 1 ) material.linewidth = json.linewidth;\n\t\tif ( json.dashSize !== undefined ) material.dashSize = json.dashSize;\n\t\tif ( json.gapSize !== undefined ) material.gapSize = json.gapSize;\n\t\tif ( json.scale !== undefined ) material.scale = json.scale;\n\n\t\tif ( json.polygonOffset !== undefined ) material.polygonOffset = json.polygonOffset;\n\t\tif ( json.polygonOffsetFactor !== undefined ) material.polygonOffsetFactor = json.polygonOffsetFactor;\n\t\tif ( json.polygonOffsetUnits !== undefined ) material.polygonOffsetUnits = json.polygonOffsetUnits;\n\n\t\tif ( json.dithering !== undefined ) material.dithering = json.dithering;\n\n\t\tif ( json.alphaToCoverage !== undefined ) material.alphaToCoverage = json.alphaToCoverage;\n\t\tif ( json.premultipliedAlpha !== undefined ) material.premultipliedAlpha = json.premultipliedAlpha;\n\n\t\tif ( json.visible !== undefined ) material.visible = json.visible;\n\n\t\tif ( json.toneMapped !== undefined ) material.toneMapped = json.toneMapped;\n\n\t\tif ( json.userData !== undefined ) material.userData = json.userData;\n\n\t\tif ( json.vertexColors !== undefined ) {\n\n\t\t\tif ( typeof json.vertexColors === 'number' ) {\n\n\t\t\t\tmaterial.vertexColors = ( json.vertexColors > 0 ) ? true : false;\n\n\t\t\t} else {\n\n\t\t\t\tmaterial.vertexColors = json.vertexColors;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// Shader Material\n\n\t\tif ( json.uniforms !== undefined ) {\n\n\t\t\tfor ( const name in json.uniforms ) {\n\n\t\t\t\tconst uniform = json.uniforms[ name ];\n\n\t\t\t\tmaterial.uniforms[ name ] = {};\n\n\t\t\t\tswitch ( uniform.type ) {\n\n\t\t\t\t\tcase 't':\n\t\t\t\t\t\tmaterial.uniforms[ name ].value = getTexture( uniform.value );\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'c':\n\t\t\t\t\t\tmaterial.uniforms[ name ].value = new Color().setHex( uniform.value );\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'v2':\n\t\t\t\t\t\tmaterial.uniforms[ name ].value = new Vector2().fromArray( uniform.value );\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'v3':\n\t\t\t\t\t\tmaterial.uniforms[ name ].value = new Vector3().fromArray( uniform.value );\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'v4':\n\t\t\t\t\t\tmaterial.uniforms[ name ].value = new Vector4().fromArray( uniform.value );\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'm3':\n\t\t\t\t\t\tmaterial.uniforms[ name ].value = new Matrix3().fromArray( uniform.value );\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'm4':\n\t\t\t\t\t\tmaterial.uniforms[ name ].value = new Matrix4().fromArray( uniform.value );\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tmaterial.uniforms[ name ].value = uniform.value;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( json.defines !== undefined ) material.defines = json.defines;\n\t\tif ( json.vertexShader !== undefined ) material.vertexShader = json.vertexShader;\n\t\tif ( json.fragmentShader !== undefined ) material.fragmentShader = json.fragmentShader;\n\n\t\tif ( json.extensions !== undefined ) {\n\n\t\t\tfor ( const key in json.extensions ) {\n\n\t\t\t\tmaterial.extensions[ key ] = json.extensions[ key ];\n\n\t\t\t}\n\n\t\t}\n\n\t\t// Deprecated\n\n\t\tif ( json.shading !== undefined ) material.flatShading = json.shading === 1; // THREE.FlatShading\n\n\t\t// for PointsMaterial\n\n\t\tif ( json.size !== undefined ) material.size = json.size;\n\t\tif ( json.sizeAttenuation !== undefined ) material.sizeAttenuation = json.sizeAttenuation;\n\n\t\t// maps\n\n\t\tif ( json.map !== undefined ) material.map = getTexture( json.map );\n\t\tif ( json.matcap !== undefined ) material.matcap = getTexture( json.matcap );\n\n\t\tif ( json.alphaMap !== undefined ) material.alphaMap = getTexture( json.alphaMap );\n\n\t\tif ( json.bumpMap !== undefined ) material.bumpMap = getTexture( json.bumpMap );\n\t\tif ( json.bumpScale !== undefined ) material.bumpScale = json.bumpScale;\n\n\t\tif ( json.normalMap !== undefined ) material.normalMap = getTexture( json.normalMap );\n\t\tif ( json.normalMapType !== undefined ) material.normalMapType = json.normalMapType;\n\t\tif ( json.normalScale !== undefined ) {\n\n\t\t\tlet normalScale = json.normalScale;\n\n\t\t\tif ( Array.isArray( normalScale ) === false ) {\n\n\t\t\t\t// Blender exporter used to export a scalar. See #7459\n\n\t\t\t\tnormalScale = [ normalScale, normalScale ];\n\n\t\t\t}\n\n\t\t\tmaterial.normalScale = new Vector2().fromArray( normalScale );\n\n\t\t}\n\n\t\tif ( json.displacementMap !== undefined ) material.displacementMap = getTexture( json.displacementMap );\n\t\tif ( json.displacementScale !== undefined ) material.displacementScale = json.displacementScale;\n\t\tif ( json.displacementBias !== undefined ) material.displacementBias = json.displacementBias;\n\n\t\tif ( json.roughnessMap !== undefined ) material.roughnessMap = getTexture( json.roughnessMap );\n\t\tif ( json.metalnessMap !== undefined ) material.metalnessMap = getTexture( json.metalnessMap );\n\n\t\tif ( json.emissiveMap !== undefined ) material.emissiveMap = getTexture( json.emissiveMap );\n\t\tif ( json.emissiveIntensity !== undefined ) material.emissiveIntensity = json.emissiveIntensity;\n\n\t\tif ( json.specularMap !== undefined ) material.specularMap = getTexture( json.specularMap );\n\t\tif ( json.specularIntensityMap !== undefined ) material.specularIntensityMap = getTexture( json.specularIntensityMap );\n\t\tif ( json.specularColorMap !== undefined ) material.specularColorMap = getTexture( json.specularColorMap );\n\n\t\tif ( json.envMap !== undefined ) material.envMap = getTexture( json.envMap );\n\t\tif ( json.envMapIntensity !== undefined ) material.envMapIntensity = json.envMapIntensity;\n\n\t\tif ( json.reflectivity !== undefined ) material.reflectivity = json.reflectivity;\n\t\tif ( json.refractionRatio !== undefined ) material.refractionRatio = json.refractionRatio;\n\n\t\tif ( json.lightMap !== undefined ) material.lightMap = getTexture( json.lightMap );\n\t\tif ( json.lightMapIntensity !== undefined ) material.lightMapIntensity = json.lightMapIntensity;\n\n\t\tif ( json.aoMap !== undefined ) material.aoMap = getTexture( json.aoMap );\n\t\tif ( json.aoMapIntensity !== undefined ) material.aoMapIntensity = json.aoMapIntensity;\n\n\t\tif ( json.gradientMap !== undefined ) material.gradientMap = getTexture( json.gradientMap );\n\n\t\tif ( json.clearcoatMap !== undefined ) material.clearcoatMap = getTexture( json.clearcoatMap );\n\t\tif ( json.clearcoatRoughnessMap !== undefined ) material.clearcoatRoughnessMap = getTexture( json.clearcoatRoughnessMap );\n\t\tif ( json.clearcoatNormalMap !== undefined ) material.clearcoatNormalMap = getTexture( json.clearcoatNormalMap );\n\t\tif ( json.clearcoatNormalScale !== undefined ) material.clearcoatNormalScale = new Vector2().fromArray( json.clearcoatNormalScale );\n\n\t\tif ( json.iridescenceMap !== undefined ) material.iridescenceMap = getTexture( json.iridescenceMap );\n\t\tif ( json.iridescenceThicknessMap !== undefined ) material.iridescenceThicknessMap = getTexture( json.iridescenceThicknessMap );\n\n\t\tif ( json.transmissionMap !== undefined ) material.transmissionMap = getTexture( json.transmissionMap );\n\t\tif ( json.thicknessMap !== undefined ) material.thicknessMap = getTexture( json.thicknessMap );\n\n\t\tif ( json.sheenColorMap !== undefined ) material.sheenColorMap = getTexture( json.sheenColorMap );\n\t\tif ( json.sheenRoughnessMap !== undefined ) material.sheenRoughnessMap = getTexture( json.sheenRoughnessMap );\n\n\t\treturn material;\n\n\t}\n\n\tsetTextures( value ) {\n\n\t\tthis.textures = value;\n\t\treturn this;\n\n\t}\n\n}\n\nclass LoaderUtils {\n\n\tstatic decodeText( array ) {\n\n\t\tif ( typeof TextDecoder !== 'undefined' ) {\n\n\t\t\treturn new TextDecoder().decode( array );\n\n\t\t}\n\n\t\t// Avoid the String.fromCharCode.apply(null, array) shortcut, which\n\t\t// throws a \"maximum call stack size exceeded\" error for large arrays.\n\n\t\tlet s = '';\n\n\t\tfor ( let i = 0, il = array.length; i < il; i ++ ) {\n\n\t\t\t// Implicitly assumes little-endian.\n\t\t\ts += String.fromCharCode( array[ i ] );\n\n\t\t}\n\n\t\ttry {\n\n\t\t\t// merges multi-byte utf-8 characters.\n\n\t\t\treturn decodeURIComponent( escape( s ) );\n\n\t\t} catch ( e ) { // see #16358\n\n\t\t\treturn s;\n\n\t\t}\n\n\t}\n\n\tstatic extractUrlBase( url ) {\n\n\t\tconst index = url.lastIndexOf( '/' );\n\n\t\tif ( index === - 1 ) return './';\n\n\t\treturn url.slice( 0, index + 1 );\n\n\t}\n\n\tstatic resolveURL( url, path ) {\n\n\t\t// Invalid URL\n\t\tif ( typeof url !== 'string' || url === '' ) return '';\n\n\t\t// Host Relative URL\n\t\tif ( /^https?:\\/\\//i.test( path ) && /^\\//.test( url ) ) {\n\n\t\t\tpath = path.replace( /(^https?:\\/\\/[^\\/]+).*/i, '$1' );\n\n\t\t}\n\n\t\t// Absolute URL http://,https://,//\n\t\tif ( /^(https?:)?\\/\\//i.test( url ) ) return url;\n\n\t\t// Data URI\n\t\tif ( /^data:.*,.*$/i.test( url ) ) return url;\n\n\t\t// Blob URL\n\t\tif ( /^blob:.*$/i.test( url ) ) return url;\n\n\t\t// Relative URL\n\t\treturn path + url;\n\n\t}\n\n}\n\nclass InstancedBufferGeometry extends BufferGeometry {\n\n\tconstructor() {\n\n\t\tsuper();\n\n\t\tthis.isInstancedBufferGeometry = true;\n\n\t\tthis.type = 'InstancedBufferGeometry';\n\t\tthis.instanceCount = Infinity;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.instanceCount = source.instanceCount;\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n\ttoJSON() {\n\n\t\tconst data = super.toJSON( this );\n\n\t\tdata.instanceCount = this.instanceCount;\n\n\t\tdata.isInstancedBufferGeometry = true;\n\n\t\treturn data;\n\n\t}\n\n}\n\nclass BufferGeometryLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tconst scope = this;\n\n\t\tconst loader = new FileLoader( scope.manager );\n\t\tloader.setPath( scope.path );\n\t\tloader.setRequestHeader( scope.requestHeader );\n\t\tloader.setWithCredentials( scope.withCredentials );\n\t\tloader.load( url, function ( text ) {\n\n\t\t\ttry {\n\n\t\t\t\tonLoad( scope.parse( JSON.parse( text ) ) );\n\n\t\t\t} catch ( e ) {\n\n\t\t\t\tif ( onError ) {\n\n\t\t\t\t\tonError( e );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.error( e );\n\n\t\t\t\t}\n\n\t\t\t\tscope.manager.itemError( url );\n\n\t\t\t}\n\n\t\t}, onProgress, onError );\n\n\t}\n\n\tparse( json ) {\n\n\t\tconst interleavedBufferMap = {};\n\t\tconst arrayBufferMap = {};\n\n\t\tfunction getInterleavedBuffer( json, uuid ) {\n\n\t\t\tif ( interleavedBufferMap[ uuid ] !== undefined ) return interleavedBufferMap[ uuid ];\n\n\t\t\tconst interleavedBuffers = json.interleavedBuffers;\n\t\t\tconst interleavedBuffer = interleavedBuffers[ uuid ];\n\n\t\t\tconst buffer = getArrayBuffer( json, interleavedBuffer.buffer );\n\n\t\t\tconst array = getTypedArray( interleavedBuffer.type, buffer );\n\t\t\tconst ib = new InterleavedBuffer( array, interleavedBuffer.stride );\n\t\t\tib.uuid = interleavedBuffer.uuid;\n\n\t\t\tinterleavedBufferMap[ uuid ] = ib;\n\n\t\t\treturn ib;\n\n\t\t}\n\n\t\tfunction getArrayBuffer( json, uuid ) {\n\n\t\t\tif ( arrayBufferMap[ uuid ] !== undefined ) return arrayBufferMap[ uuid ];\n\n\t\t\tconst arrayBuffers = json.arrayBuffers;\n\t\t\tconst arrayBuffer = arrayBuffers[ uuid ];\n\n\t\t\tconst ab = new Uint32Array( arrayBuffer ).buffer;\n\n\t\t\tarrayBufferMap[ uuid ] = ab;\n\n\t\t\treturn ab;\n\n\t\t}\n\n\t\tconst geometry = json.isInstancedBufferGeometry ? new InstancedBufferGeometry() : new BufferGeometry();\n\n\t\tconst index = json.data.index;\n\n\t\tif ( index !== undefined ) {\n\n\t\t\tconst typedArray = getTypedArray( index.type, index.array );\n\t\t\tgeometry.setIndex( new BufferAttribute( typedArray, 1 ) );\n\n\t\t}\n\n\t\tconst attributes = json.data.attributes;\n\n\t\tfor ( const key in attributes ) {\n\n\t\t\tconst attribute = attributes[ key ];\n\t\t\tlet bufferAttribute;\n\n\t\t\tif ( attribute.isInterleavedBufferAttribute ) {\n\n\t\t\t\tconst interleavedBuffer = getInterleavedBuffer( json.data, attribute.data );\n\t\t\t\tbufferAttribute = new InterleavedBufferAttribute( interleavedBuffer, attribute.itemSize, attribute.offset, attribute.normalized );\n\n\t\t\t} else {\n\n\t\t\t\tconst typedArray = getTypedArray( attribute.type, attribute.array );\n\t\t\t\tconst bufferAttributeConstr = attribute.isInstancedBufferAttribute ? InstancedBufferAttribute : BufferAttribute;\n\t\t\t\tbufferAttribute = new bufferAttributeConstr( typedArray, attribute.itemSize, attribute.normalized );\n\n\t\t\t}\n\n\t\t\tif ( attribute.name !== undefined ) bufferAttribute.name = attribute.name;\n\t\t\tif ( attribute.usage !== undefined ) bufferAttribute.setUsage( attribute.usage );\n\n\t\t\tif ( attribute.updateRange !== undefined ) {\n\n\t\t\t\tbufferAttribute.updateRange.offset = attribute.updateRange.offset;\n\t\t\t\tbufferAttribute.updateRange.count = attribute.updateRange.count;\n\n\t\t\t}\n\n\t\t\tgeometry.setAttribute( key, bufferAttribute );\n\n\t\t}\n\n\t\tconst morphAttributes = json.data.morphAttributes;\n\n\t\tif ( morphAttributes ) {\n\n\t\t\tfor ( const key in morphAttributes ) {\n\n\t\t\t\tconst attributeArray = morphAttributes[ key ];\n\n\t\t\t\tconst array = [];\n\n\t\t\t\tfor ( let i = 0, il = attributeArray.length; i < il; i ++ ) {\n\n\t\t\t\t\tconst attribute = attributeArray[ i ];\n\t\t\t\t\tlet bufferAttribute;\n\n\t\t\t\t\tif ( attribute.isInterleavedBufferAttribute ) {\n\n\t\t\t\t\t\tconst interleavedBuffer = getInterleavedBuffer( json.data, attribute.data );\n\t\t\t\t\t\tbufferAttribute = new InterleavedBufferAttribute( interleavedBuffer, attribute.itemSize, attribute.offset, attribute.normalized );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tconst typedArray = getTypedArray( attribute.type, attribute.array );\n\t\t\t\t\t\tbufferAttribute = new BufferAttribute( typedArray, attribute.itemSize, attribute.normalized );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( attribute.name !== undefined ) bufferAttribute.name = attribute.name;\n\t\t\t\t\tarray.push( bufferAttribute );\n\n\t\t\t\t}\n\n\t\t\t\tgeometry.morphAttributes[ key ] = array;\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst morphTargetsRelative = json.data.morphTargetsRelative;\n\n\t\tif ( morphTargetsRelative ) {\n\n\t\t\tgeometry.morphTargetsRelative = true;\n\n\t\t}\n\n\t\tconst groups = json.data.groups || json.data.drawcalls || json.data.offsets;\n\n\t\tif ( groups !== undefined ) {\n\n\t\t\tfor ( let i = 0, n = groups.length; i !== n; ++ i ) {\n\n\t\t\t\tconst group = groups[ i ];\n\n\t\t\t\tgeometry.addGroup( group.start, group.count, group.materialIndex );\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst boundingSphere = json.data.boundingSphere;\n\n\t\tif ( boundingSphere !== undefined ) {\n\n\t\t\tconst center = new Vector3();\n\n\t\t\tif ( boundingSphere.center !== undefined ) {\n\n\t\t\t\tcenter.fromArray( boundingSphere.center );\n\n\t\t\t}\n\n\t\t\tgeometry.boundingSphere = new Sphere( center, boundingSphere.radius );\n\n\t\t}\n\n\t\tif ( json.name ) geometry.name = json.name;\n\t\tif ( json.userData ) geometry.userData = json.userData;\n\n\t\treturn geometry;\n\n\t}\n\n}\n\nclass ObjectLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tconst scope = this;\n\n\t\tconst path = ( this.path === '' ) ? LoaderUtils.extractUrlBase( url ) : this.path;\n\t\tthis.resourcePath = this.resourcePath || path;\n\n\t\tconst loader = new FileLoader( this.manager );\n\t\tloader.setPath( this.path );\n\t\tloader.setRequestHeader( this.requestHeader );\n\t\tloader.setWithCredentials( this.withCredentials );\n\t\tloader.load( url, function ( text ) {\n\n\t\t\tlet json = null;\n\n\t\t\ttry {\n\n\t\t\t\tjson = JSON.parse( text );\n\n\t\t\t} catch ( error ) {\n\n\t\t\t\tif ( onError !== undefined ) onError( error );\n\n\t\t\t\tconsole.error( 'THREE:ObjectLoader: Can\\'t parse ' + url + '.', error.message );\n\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t\tconst metadata = json.metadata;\n\n\t\t\tif ( metadata === undefined || metadata.type === undefined || metadata.type.toLowerCase() === 'geometry' ) {\n\n\t\t\t\tconsole.error( 'THREE.ObjectLoader: Can\\'t load ' + url );\n\t\t\t\treturn;\n\n\t\t\t}\n\n\t\t\tscope.parse( json, onLoad );\n\n\t\t}, onProgress, onError );\n\n\t}\n\n\tasync loadAsync( url, onProgress ) {\n\n\t\tconst scope = this;\n\n\t\tconst path = ( this.path === '' ) ? LoaderUtils.extractUrlBase( url ) : this.path;\n\t\tthis.resourcePath = this.resourcePath || path;\n\n\t\tconst loader = new FileLoader( this.manager );\n\t\tloader.setPath( this.path );\n\t\tloader.setRequestHeader( this.requestHeader );\n\t\tloader.setWithCredentials( this.withCredentials );\n\n\t\tconst text = await loader.loadAsync( url, onProgress );\n\n\t\tconst json = JSON.parse( text );\n\n\t\tconst metadata = json.metadata;\n\n\t\tif ( metadata === undefined || metadata.type === undefined || metadata.type.toLowerCase() === 'geometry' ) {\n\n\t\t\tthrow new Error( 'THREE.ObjectLoader: Can\\'t load ' + url );\n\n\t\t}\n\n\t\treturn await scope.parseAsync( json );\n\n\t}\n\n\tparse( json, onLoad ) {\n\n\t\tconst animations = this.parseAnimations( json.animations );\n\t\tconst shapes = this.parseShapes( json.shapes );\n\t\tconst geometries = this.parseGeometries( json.geometries, shapes );\n\n\t\tconst images = this.parseImages( json.images, function () {\n\n\t\t\tif ( onLoad !== undefined ) onLoad( object );\n\n\t\t} );\n\n\t\tconst textures = this.parseTextures( json.textures, images );\n\t\tconst materials = this.parseMaterials( json.materials, textures );\n\n\t\tconst object = this.parseObject( json.object, geometries, materials, textures, animations );\n\t\tconst skeletons = this.parseSkeletons( json.skeletons, object );\n\n\t\tthis.bindSkeletons( object, skeletons );\n\n\t\t//\n\n\t\tif ( onLoad !== undefined ) {\n\n\t\t\tlet hasImages = false;\n\n\t\t\tfor ( const uuid in images ) {\n\n\t\t\t\tif ( images[ uuid ].data instanceof HTMLImageElement ) {\n\n\t\t\t\t\thasImages = true;\n\t\t\t\t\tbreak;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( hasImages === false ) onLoad( object );\n\n\t\t}\n\n\t\treturn object;\n\n\t}\n\n\tasync parseAsync( json ) {\n\n\t\tconst animations = this.parseAnimations( json.animations );\n\t\tconst shapes = this.parseShapes( json.shapes );\n\t\tconst geometries = this.parseGeometries( json.geometries, shapes );\n\n\t\tconst images = await this.parseImagesAsync( json.images );\n\n\t\tconst textures = this.parseTextures( json.textures, images );\n\t\tconst materials = this.parseMaterials( json.materials, textures );\n\n\t\tconst object = this.parseObject( json.object, geometries, materials, textures, animations );\n\t\tconst skeletons = this.parseSkeletons( json.skeletons, object );\n\n\t\tthis.bindSkeletons( object, skeletons );\n\n\t\treturn object;\n\n\t}\n\n\tparseShapes( json ) {\n\n\t\tconst shapes = {};\n\n\t\tif ( json !== undefined ) {\n\n\t\t\tfor ( let i = 0, l = json.length; i < l; i ++ ) {\n\n\t\t\t\tconst shape = new Shape().fromJSON( json[ i ] );\n\n\t\t\t\tshapes[ shape.uuid ] = shape;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn shapes;\n\n\t}\n\n\tparseSkeletons( json, object ) {\n\n\t\tconst skeletons = {};\n\t\tconst bones = {};\n\n\t\t// generate bone lookup table\n\n\t\tobject.traverse( function ( child ) {\n\n\t\t\tif ( child.isBone ) bones[ child.uuid ] = child;\n\n\t\t} );\n\n\t\t// create skeletons\n\n\t\tif ( json !== undefined ) {\n\n\t\t\tfor ( let i = 0, l = json.length; i < l; i ++ ) {\n\n\t\t\t\tconst skeleton = new Skeleton().fromJSON( json[ i ], bones );\n\n\t\t\t\tskeletons[ skeleton.uuid ] = skeleton;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn skeletons;\n\n\t}\n\n\tparseGeometries( json, shapes ) {\n\n\t\tconst geometries = {};\n\n\t\tif ( json !== undefined ) {\n\n\t\t\tconst bufferGeometryLoader = new BufferGeometryLoader();\n\n\t\t\tfor ( let i = 0, l = json.length; i < l; i ++ ) {\n\n\t\t\t\tlet geometry;\n\t\t\t\tconst data = json[ i ];\n\n\t\t\t\tswitch ( data.type ) {\n\n\t\t\t\t\tcase 'BufferGeometry':\n\t\t\t\t\tcase 'InstancedBufferGeometry':\n\n\t\t\t\t\t\tgeometry = bufferGeometryLoader.parse( data );\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'Geometry':\n\n\t\t\t\t\t\tconsole.error( 'THREE.ObjectLoader: The legacy Geometry type is no longer supported.' );\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault:\n\n\t\t\t\t\t\tif ( data.type in Geometries ) {\n\n\t\t\t\t\t\t\tgeometry = Geometries[ data.type ].fromJSON( data, shapes );\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\tconsole.warn( `THREE.ObjectLoader: Unsupported geometry type \"${ data.type }\"` );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tgeometry.uuid = data.uuid;\n\n\t\t\t\tif ( data.name !== undefined ) geometry.name = data.name;\n\t\t\t\tif ( geometry.isBufferGeometry === true && data.userData !== undefined ) geometry.userData = data.userData;\n\n\t\t\t\tgeometries[ data.uuid ] = geometry;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn geometries;\n\n\t}\n\n\tparseMaterials( json, textures ) {\n\n\t\tconst cache = {}; // MultiMaterial\n\t\tconst materials = {};\n\n\t\tif ( json !== undefined ) {\n\n\t\t\tconst loader = new MaterialLoader();\n\t\t\tloader.setTextures( textures );\n\n\t\t\tfor ( let i = 0, l = json.length; i < l; i ++ ) {\n\n\t\t\t\tconst data = json[ i ];\n\n\t\t\t\tif ( data.type === 'MultiMaterial' ) {\n\n\t\t\t\t\t// Deprecated\n\n\t\t\t\t\tconst array = [];\n\n\t\t\t\t\tfor ( let j = 0; j < data.materials.length; j ++ ) {\n\n\t\t\t\t\t\tconst material = data.materials[ j ];\n\n\t\t\t\t\t\tif ( cache[ material.uuid ] === undefined ) {\n\n\t\t\t\t\t\t\tcache[ material.uuid ] = loader.parse( material );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tarray.push( cache[ material.uuid ] );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tmaterials[ data.uuid ] = array;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tif ( cache[ data.uuid ] === undefined ) {\n\n\t\t\t\t\t\tcache[ data.uuid ] = loader.parse( data );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tmaterials[ data.uuid ] = cache[ data.uuid ];\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn materials;\n\n\t}\n\n\tparseAnimations( json ) {\n\n\t\tconst animations = {};\n\n\t\tif ( json !== undefined ) {\n\n\t\t\tfor ( let i = 0; i < json.length; i ++ ) {\n\n\t\t\t\tconst data = json[ i ];\n\n\t\t\t\tconst clip = AnimationClip.parse( data );\n\n\t\t\t\tanimations[ clip.uuid ] = clip;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn animations;\n\n\t}\n\n\tparseImages( json, onLoad ) {\n\n\t\tconst scope = this;\n\t\tconst images = {};\n\n\t\tlet loader;\n\n\t\tfunction loadImage( url ) {\n\n\t\t\tscope.manager.itemStart( url );\n\n\t\t\treturn loader.load( url, function () {\n\n\t\t\t\tscope.manager.itemEnd( url );\n\n\t\t\t}, undefined, function () {\n\n\t\t\t\tscope.manager.itemError( url );\n\t\t\t\tscope.manager.itemEnd( url );\n\n\t\t\t} );\n\n\t\t}\n\n\t\tfunction deserializeImage( image ) {\n\n\t\t\tif ( typeof image === 'string' ) {\n\n\t\t\t\tconst url = image;\n\n\t\t\t\tconst path = /^(\\/\\/)|([a-z]+:(\\/\\/)?)/i.test( url ) ? url : scope.resourcePath + url;\n\n\t\t\t\treturn loadImage( path );\n\n\t\t\t} else {\n\n\t\t\t\tif ( image.data ) {\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\tdata: getTypedArray( image.type, image.data ),\n\t\t\t\t\t\twidth: image.width,\n\t\t\t\t\t\theight: image.height\n\t\t\t\t\t};\n\n\t\t\t\t} else {\n\n\t\t\t\t\treturn null;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( json !== undefined && json.length > 0 ) {\n\n\t\t\tconst manager = new LoadingManager( onLoad );\n\n\t\t\tloader = new ImageLoader( manager );\n\t\t\tloader.setCrossOrigin( this.crossOrigin );\n\n\t\t\tfor ( let i = 0, il = json.length; i < il; i ++ ) {\n\n\t\t\t\tconst image = json[ i ];\n\t\t\t\tconst url = image.url;\n\n\t\t\t\tif ( Array.isArray( url ) ) {\n\n\t\t\t\t\t// load array of images e.g CubeTexture\n\n\t\t\t\t\tconst imageArray = [];\n\n\t\t\t\t\tfor ( let j = 0, jl = url.length; j < jl; j ++ ) {\n\n\t\t\t\t\t\tconst currentUrl = url[ j ];\n\n\t\t\t\t\t\tconst deserializedImage = deserializeImage( currentUrl );\n\n\t\t\t\t\t\tif ( deserializedImage !== null ) {\n\n\t\t\t\t\t\t\tif ( deserializedImage instanceof HTMLImageElement ) {\n\n\t\t\t\t\t\t\t\timageArray.push( deserializedImage );\n\n\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\t// special case: handle array of data textures for cube textures\n\n\t\t\t\t\t\t\t\timageArray.push( new DataTexture( deserializedImage.data, deserializedImage.width, deserializedImage.height ) );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\timages[ image.uuid ] = new Source( imageArray );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// load single image\n\n\t\t\t\t\tconst deserializedImage = deserializeImage( image.url );\n\t\t\t\t\timages[ image.uuid ] = new Source( deserializedImage );\n\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn images;\n\n\t}\n\n\tasync parseImagesAsync( json ) {\n\n\t\tconst scope = this;\n\t\tconst images = {};\n\n\t\tlet loader;\n\n\t\tasync function deserializeImage( image ) {\n\n\t\t\tif ( typeof image === 'string' ) {\n\n\t\t\t\tconst url = image;\n\n\t\t\t\tconst path = /^(\\/\\/)|([a-z]+:(\\/\\/)?)/i.test( url ) ? url : scope.resourcePath + url;\n\n\t\t\t\treturn await loader.loadAsync( path );\n\n\t\t\t} else {\n\n\t\t\t\tif ( image.data ) {\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\tdata: getTypedArray( image.type, image.data ),\n\t\t\t\t\t\twidth: image.width,\n\t\t\t\t\t\theight: image.height\n\t\t\t\t\t};\n\n\t\t\t\t} else {\n\n\t\t\t\t\treturn null;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( json !== undefined && json.length > 0 ) {\n\n\t\t\tloader = new ImageLoader( this.manager );\n\t\t\tloader.setCrossOrigin( this.crossOrigin );\n\n\t\t\tfor ( let i = 0, il = json.length; i < il; i ++ ) {\n\n\t\t\t\tconst image = json[ i ];\n\t\t\t\tconst url = image.url;\n\n\t\t\t\tif ( Array.isArray( url ) ) {\n\n\t\t\t\t\t// load array of images e.g CubeTexture\n\n\t\t\t\t\tconst imageArray = [];\n\n\t\t\t\t\tfor ( let j = 0, jl = url.length; j < jl; j ++ ) {\n\n\t\t\t\t\t\tconst currentUrl = url[ j ];\n\n\t\t\t\t\t\tconst deserializedImage = await deserializeImage( currentUrl );\n\n\t\t\t\t\t\tif ( deserializedImage !== null ) {\n\n\t\t\t\t\t\t\tif ( deserializedImage instanceof HTMLImageElement ) {\n\n\t\t\t\t\t\t\t\timageArray.push( deserializedImage );\n\n\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\t// special case: handle array of data textures for cube textures\n\n\t\t\t\t\t\t\t\timageArray.push( new DataTexture( deserializedImage.data, deserializedImage.width, deserializedImage.height ) );\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\timages[ image.uuid ] = new Source( imageArray );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// load single image\n\n\t\t\t\t\tconst deserializedImage = await deserializeImage( image.url );\n\t\t\t\t\timages[ image.uuid ] = new Source( deserializedImage );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn images;\n\n\t}\n\n\tparseTextures( json, images ) {\n\n\t\tfunction parseConstant( value, type ) {\n\n\t\t\tif ( typeof value === 'number' ) return value;\n\n\t\t\tconsole.warn( 'THREE.ObjectLoader.parseTexture: Constant should be in numeric form.', value );\n\n\t\t\treturn type[ value ];\n\n\t\t}\n\n\t\tconst textures = {};\n\n\t\tif ( json !== undefined ) {\n\n\t\t\tfor ( let i = 0, l = json.length; i < l; i ++ ) {\n\n\t\t\t\tconst data = json[ i ];\n\n\t\t\t\tif ( data.image === undefined ) {\n\n\t\t\t\t\tconsole.warn( 'THREE.ObjectLoader: No \"image\" specified for', data.uuid );\n\n\t\t\t\t}\n\n\t\t\t\tif ( images[ data.image ] === undefined ) {\n\n\t\t\t\t\tconsole.warn( 'THREE.ObjectLoader: Undefined image', data.image );\n\n\t\t\t\t}\n\n\t\t\t\tconst source = images[ data.image ];\n\t\t\t\tconst image = source.data;\n\n\t\t\t\tlet texture;\n\n\t\t\t\tif ( Array.isArray( image ) ) {\n\n\t\t\t\t\ttexture = new CubeTexture();\n\n\t\t\t\t\tif ( image.length === 6 ) texture.needsUpdate = true;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tif ( image && image.data ) {\n\n\t\t\t\t\t\ttexture = new DataTexture();\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\ttexture = new Texture();\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( image ) texture.needsUpdate = true; // textures can have undefined image data\n\n\t\t\t\t}\n\n\t\t\t\ttexture.source = source;\n\n\t\t\t\ttexture.uuid = data.uuid;\n\n\t\t\t\tif ( data.name !== undefined ) texture.name = data.name;\n\n\t\t\t\tif ( data.mapping !== undefined ) texture.mapping = parseConstant( data.mapping, TEXTURE_MAPPING );\n\n\t\t\t\tif ( data.offset !== undefined ) texture.offset.fromArray( data.offset );\n\t\t\t\tif ( data.repeat !== undefined ) texture.repeat.fromArray( data.repeat );\n\t\t\t\tif ( data.center !== undefined ) texture.center.fromArray( data.center );\n\t\t\t\tif ( data.rotation !== undefined ) texture.rotation = data.rotation;\n\n\t\t\t\tif ( data.wrap !== undefined ) {\n\n\t\t\t\t\ttexture.wrapS = parseConstant( data.wrap[ 0 ], TEXTURE_WRAPPING );\n\t\t\t\t\ttexture.wrapT = parseConstant( data.wrap[ 1 ], TEXTURE_WRAPPING );\n\n\t\t\t\t}\n\n\t\t\t\tif ( data.format !== undefined ) texture.format = data.format;\n\t\t\t\tif ( data.type !== undefined ) texture.type = data.type;\n\t\t\t\tif ( data.encoding !== undefined ) texture.encoding = data.encoding;\n\n\t\t\t\tif ( data.minFilter !== undefined ) texture.minFilter = parseConstant( data.minFilter, TEXTURE_FILTER );\n\t\t\t\tif ( data.magFilter !== undefined ) texture.magFilter = parseConstant( data.magFilter, TEXTURE_FILTER );\n\t\t\t\tif ( data.anisotropy !== undefined ) texture.anisotropy = data.anisotropy;\n\n\t\t\t\tif ( data.flipY !== undefined ) texture.flipY = data.flipY;\n\n\t\t\t\tif ( data.premultiplyAlpha !== undefined ) texture.premultiplyAlpha = data.premultiplyAlpha;\n\t\t\t\tif ( data.unpackAlignment !== undefined ) texture.unpackAlignment = data.unpackAlignment;\n\n\t\t\t\tif ( data.userData !== undefined ) texture.userData = data.userData;\n\n\t\t\t\ttextures[ data.uuid ] = texture;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn textures;\n\n\t}\n\n\tparseObject( data, geometries, materials, textures, animations ) {\n\n\t\tlet object;\n\n\t\tfunction getGeometry( name ) {\n\n\t\t\tif ( geometries[ name ] === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.ObjectLoader: Undefined geometry', name );\n\n\t\t\t}\n\n\t\t\treturn geometries[ name ];\n\n\t\t}\n\n\t\tfunction getMaterial( name ) {\n\n\t\t\tif ( name === undefined ) return undefined;\n\n\t\t\tif ( Array.isArray( name ) ) {\n\n\t\t\t\tconst array = [];\n\n\t\t\t\tfor ( let i = 0, l = name.length; i < l; i ++ ) {\n\n\t\t\t\t\tconst uuid = name[ i ];\n\n\t\t\t\t\tif ( materials[ uuid ] === undefined ) {\n\n\t\t\t\t\t\tconsole.warn( 'THREE.ObjectLoader: Undefined material', uuid );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tarray.push( materials[ uuid ] );\n\n\t\t\t\t}\n\n\t\t\t\treturn array;\n\n\t\t\t}\n\n\t\t\tif ( materials[ name ] === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.ObjectLoader: Undefined material', name );\n\n\t\t\t}\n\n\t\t\treturn materials[ name ];\n\n\t\t}\n\n\t\tfunction getTexture( uuid ) {\n\n\t\t\tif ( textures[ uuid ] === undefined ) {\n\n\t\t\t\tconsole.warn( 'THREE.ObjectLoader: Undefined texture', uuid );\n\n\t\t\t}\n\n\t\t\treturn textures[ uuid ];\n\n\t\t}\n\n\t\tlet geometry, material;\n\n\t\tswitch ( data.type ) {\n\n\t\t\tcase 'Scene':\n\n\t\t\t\tobject = new Scene();\n\n\t\t\t\tif ( data.background !== undefined ) {\n\n\t\t\t\t\tif ( Number.isInteger( data.background ) ) {\n\n\t\t\t\t\t\tobject.background = new Color( data.background );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tobject.background = getTexture( data.background );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tif ( data.environment !== undefined ) {\n\n\t\t\t\t\tobject.environment = getTexture( data.environment );\n\n\t\t\t\t}\n\n\t\t\t\tif ( data.fog !== undefined ) {\n\n\t\t\t\t\tif ( data.fog.type === 'Fog' ) {\n\n\t\t\t\t\t\tobject.fog = new Fog( data.fog.color, data.fog.near, data.fog.far );\n\n\t\t\t\t\t} else if ( data.fog.type === 'FogExp2' ) {\n\n\t\t\t\t\t\tobject.fog = new FogExp2( data.fog.color, data.fog.density );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'PerspectiveCamera':\n\n\t\t\t\tobject = new PerspectiveCamera( data.fov, data.aspect, data.near, data.far );\n\n\t\t\t\tif ( data.focus !== undefined ) object.focus = data.focus;\n\t\t\t\tif ( data.zoom !== undefined ) object.zoom = data.zoom;\n\t\t\t\tif ( data.filmGauge !== undefined ) object.filmGauge = data.filmGauge;\n\t\t\t\tif ( data.filmOffset !== undefined ) object.filmOffset = data.filmOffset;\n\t\t\t\tif ( data.view !== undefined ) object.view = Object.assign( {}, data.view );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'OrthographicCamera':\n\n\t\t\t\tobject = new OrthographicCamera( data.left, data.right, data.top, data.bottom, data.near, data.far );\n\n\t\t\t\tif ( data.zoom !== undefined ) object.zoom = data.zoom;\n\t\t\t\tif ( data.view !== undefined ) object.view = Object.assign( {}, data.view );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'AmbientLight':\n\n\t\t\t\tobject = new AmbientLight( data.color, data.intensity );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'DirectionalLight':\n\n\t\t\t\tobject = new DirectionalLight( data.color, data.intensity );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'PointLight':\n\n\t\t\t\tobject = new PointLight( data.color, data.intensity, data.distance, data.decay );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'RectAreaLight':\n\n\t\t\t\tobject = new RectAreaLight( data.color, data.intensity, data.width, data.height );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'SpotLight':\n\n\t\t\t\tobject = new SpotLight( data.color, data.intensity, data.distance, data.angle, data.penumbra, data.decay );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'HemisphereLight':\n\n\t\t\t\tobject = new HemisphereLight( data.color, data.groundColor, data.intensity );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'LightProbe':\n\n\t\t\t\tobject = new LightProbe().fromJSON( data );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'SkinnedMesh':\n\n\t\t\t\tgeometry = getGeometry( data.geometry );\n\t\t\t \tmaterial = getMaterial( data.material );\n\n\t\t\t\tobject = new SkinnedMesh( geometry, material );\n\n\t\t\t\tif ( data.bindMode !== undefined ) object.bindMode = data.bindMode;\n\t\t\t\tif ( data.bindMatrix !== undefined ) object.bindMatrix.fromArray( data.bindMatrix );\n\t\t\t\tif ( data.skeleton !== undefined ) object.skeleton = data.skeleton;\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'Mesh':\n\n\t\t\t\tgeometry = getGeometry( data.geometry );\n\t\t\t\tmaterial = getMaterial( data.material );\n\n\t\t\t\tobject = new Mesh( geometry, material );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'InstancedMesh':\n\n\t\t\t\tgeometry = getGeometry( data.geometry );\n\t\t\t\tmaterial = getMaterial( data.material );\n\t\t\t\tconst count = data.count;\n\t\t\t\tconst instanceMatrix = data.instanceMatrix;\n\t\t\t\tconst instanceColor = data.instanceColor;\n\n\t\t\t\tobject = new InstancedMesh( geometry, material, count );\n\t\t\t\tobject.instanceMatrix = new InstancedBufferAttribute( new Float32Array( instanceMatrix.array ), 16 );\n\t\t\t\tif ( instanceColor !== undefined ) object.instanceColor = new InstancedBufferAttribute( new Float32Array( instanceColor.array ), instanceColor.itemSize );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'LOD':\n\n\t\t\t\tobject = new LOD();\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'Line':\n\n\t\t\t\tobject = new Line( getGeometry( data.geometry ), getMaterial( data.material ) );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'LineLoop':\n\n\t\t\t\tobject = new LineLoop( getGeometry( data.geometry ), getMaterial( data.material ) );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'LineSegments':\n\n\t\t\t\tobject = new LineSegments( getGeometry( data.geometry ), getMaterial( data.material ) );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'PointCloud':\n\t\t\tcase 'Points':\n\n\t\t\t\tobject = new Points( getGeometry( data.geometry ), getMaterial( data.material ) );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'Sprite':\n\n\t\t\t\tobject = new Sprite( getMaterial( data.material ) );\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'Group':\n\n\t\t\t\tobject = new Group();\n\n\t\t\t\tbreak;\n\n\t\t\tcase 'Bone':\n\n\t\t\t\tobject = new Bone();\n\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\n\t\t\t\tobject = new Object3D();\n\n\t\t}\n\n\t\tobject.uuid = data.uuid;\n\n\t\tif ( data.name !== undefined ) object.name = data.name;\n\n\t\tif ( data.matrix !== undefined ) {\n\n\t\t\tobject.matrix.fromArray( data.matrix );\n\n\t\t\tif ( data.matrixAutoUpdate !== undefined ) object.matrixAutoUpdate = data.matrixAutoUpdate;\n\t\t\tif ( object.matrixAutoUpdate ) object.matrix.decompose( object.position, object.quaternion, object.scale );\n\n\t\t} else {\n\n\t\t\tif ( data.position !== undefined ) object.position.fromArray( data.position );\n\t\t\tif ( data.rotation !== undefined ) object.rotation.fromArray( data.rotation );\n\t\t\tif ( data.quaternion !== undefined ) object.quaternion.fromArray( data.quaternion );\n\t\t\tif ( data.scale !== undefined ) object.scale.fromArray( data.scale );\n\n\t\t}\n\n\t\tif ( data.castShadow !== undefined ) object.castShadow = data.castShadow;\n\t\tif ( data.receiveShadow !== undefined ) object.receiveShadow = data.receiveShadow;\n\n\t\tif ( data.shadow ) {\n\n\t\t\tif ( data.shadow.bias !== undefined ) object.shadow.bias = data.shadow.bias;\n\t\t\tif ( data.shadow.normalBias !== undefined ) object.shadow.normalBias = data.shadow.normalBias;\n\t\t\tif ( data.shadow.radius !== undefined ) object.shadow.radius = data.shadow.radius;\n\t\t\tif ( data.shadow.mapSize !== undefined ) object.shadow.mapSize.fromArray( data.shadow.mapSize );\n\t\t\tif ( data.shadow.camera !== undefined ) object.shadow.camera = this.parseObject( data.shadow.camera );\n\n\t\t}\n\n\t\tif ( data.visible !== undefined ) object.visible = data.visible;\n\t\tif ( data.frustumCulled !== undefined ) object.frustumCulled = data.frustumCulled;\n\t\tif ( data.renderOrder !== undefined ) object.renderOrder = data.renderOrder;\n\t\tif ( data.userData !== undefined ) object.userData = data.userData;\n\t\tif ( data.layers !== undefined ) object.layers.mask = data.layers;\n\n\t\tif ( data.children !== undefined ) {\n\n\t\t\tconst children = data.children;\n\n\t\t\tfor ( let i = 0; i < children.length; i ++ ) {\n\n\t\t\t\tobject.add( this.parseObject( children[ i ], geometries, materials, textures, animations ) );\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( data.animations !== undefined ) {\n\n\t\t\tconst objectAnimations = data.animations;\n\n\t\t\tfor ( let i = 0; i < objectAnimations.length; i ++ ) {\n\n\t\t\t\tconst uuid = objectAnimations[ i ];\n\n\t\t\t\tobject.animations.push( animations[ uuid ] );\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( data.type === 'LOD' ) {\n\n\t\t\tif ( data.autoUpdate !== undefined ) object.autoUpdate = data.autoUpdate;\n\n\t\t\tconst levels = data.levels;\n\n\t\t\tfor ( let l = 0; l < levels.length; l ++ ) {\n\n\t\t\t\tconst level = levels[ l ];\n\t\t\t\tconst child = object.getObjectByProperty( 'uuid', level.object );\n\n\t\t\t\tif ( child !== undefined ) {\n\n\t\t\t\t\tobject.addLevel( child, level.distance );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn object;\n\n\t}\n\n\tbindSkeletons( object, skeletons ) {\n\n\t\tif ( Object.keys( skeletons ).length === 0 ) return;\n\n\t\tobject.traverse( function ( child ) {\n\n\t\t\tif ( child.isSkinnedMesh === true && child.skeleton !== undefined ) {\n\n\t\t\t\tconst skeleton = skeletons[ child.skeleton ];\n\n\t\t\t\tif ( skeleton === undefined ) {\n\n\t\t\t\t\tconsole.warn( 'THREE.ObjectLoader: No skeleton found with UUID:', child.skeleton );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tchild.bind( skeleton, child.bindMatrix );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} );\n\n\t}\n\n\t/* DEPRECATED */\n\n\tsetTexturePath( value ) {\n\n\t\tconsole.warn( 'THREE.ObjectLoader: .setTexturePath() has been renamed to .setResourcePath().' );\n\t\treturn this.setResourcePath( value );\n\n\t}\n\n}\n\nconst TEXTURE_MAPPING = {\n\tUVMapping: UVMapping,\n\tCubeReflectionMapping: CubeReflectionMapping,\n\tCubeRefractionMapping: CubeRefractionMapping,\n\tEquirectangularReflectionMapping: EquirectangularReflectionMapping,\n\tEquirectangularRefractionMapping: EquirectangularRefractionMapping,\n\tCubeUVReflectionMapping: CubeUVReflectionMapping\n};\n\nconst TEXTURE_WRAPPING = {\n\tRepeatWrapping: RepeatWrapping,\n\tClampToEdgeWrapping: ClampToEdgeWrapping,\n\tMirroredRepeatWrapping: MirroredRepeatWrapping\n};\n\nconst TEXTURE_FILTER = {\n\tNearestFilter: NearestFilter,\n\tNearestMipmapNearestFilter: NearestMipmapNearestFilter,\n\tNearestMipmapLinearFilter: NearestMipmapLinearFilter,\n\tLinearFilter: LinearFilter,\n\tLinearMipmapNearestFilter: LinearMipmapNearestFilter,\n\tLinearMipmapLinearFilter: LinearMipmapLinearFilter\n};\n\nclass ImageBitmapLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t\tthis.isImageBitmapLoader = true;\n\n\t\tif ( typeof createImageBitmap === 'undefined' ) {\n\n\t\t\tconsole.warn( 'THREE.ImageBitmapLoader: createImageBitmap() not supported.' );\n\n\t\t}\n\n\t\tif ( typeof fetch === 'undefined' ) {\n\n\t\t\tconsole.warn( 'THREE.ImageBitmapLoader: fetch() not supported.' );\n\n\t\t}\n\n\t\tthis.options = { premultiplyAlpha: 'none' };\n\n\t}\n\n\tsetOptions( options ) {\n\n\t\tthis.options = options;\n\n\t\treturn this;\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tif ( url === undefined ) url = '';\n\n\t\tif ( this.path !== undefined ) url = this.path + url;\n\n\t\turl = this.manager.resolveURL( url );\n\n\t\tconst scope = this;\n\n\t\tconst cached = Cache.get( url );\n\n\t\tif ( cached !== undefined ) {\n\n\t\t\tscope.manager.itemStart( url );\n\n\t\t\tsetTimeout( function () {\n\n\t\t\t\tif ( onLoad ) onLoad( cached );\n\n\t\t\t\tscope.manager.itemEnd( url );\n\n\t\t\t}, 0 );\n\n\t\t\treturn cached;\n\n\t\t}\n\n\t\tconst fetchOptions = {};\n\t\tfetchOptions.credentials = ( this.crossOrigin === 'anonymous' ) ? 'same-origin' : 'include';\n\t\tfetchOptions.headers = this.requestHeader;\n\n\t\tfetch( url, fetchOptions ).then( function ( res ) {\n\n\t\t\treturn res.blob();\n\n\t\t} ).then( function ( blob ) {\n\n\t\t\treturn createImageBitmap( blob, Object.assign( scope.options, { colorSpaceConversion: 'none' } ) );\n\n\t\t} ).then( function ( imageBitmap ) {\n\n\t\t\tCache.add( url, imageBitmap );\n\n\t\t\tif ( onLoad ) onLoad( imageBitmap );\n\n\t\t\tscope.manager.itemEnd( url );\n\n\t\t} ).catch( function ( e ) {\n\n\t\t\tif ( onError ) onError( e );\n\n\t\t\tscope.manager.itemError( url );\n\t\t\tscope.manager.itemEnd( url );\n\n\t\t} );\n\n\t\tscope.manager.itemStart( url );\n\n\t}\n\n}\n\nlet _context;\n\nconst AudioContext = {\n\n\tgetContext: function () {\n\n\t\tif ( _context === undefined ) {\n\n\t\t\t_context = new ( window.AudioContext || window.webkitAudioContext )();\n\n\t\t}\n\n\t\treturn _context;\n\n\t},\n\n\tsetContext: function ( value ) {\n\n\t\t_context = value;\n\n\t}\n\n};\n\nclass AudioLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tconst scope = this;\n\n\t\tconst loader = new FileLoader( this.manager );\n\t\tloader.setResponseType( 'arraybuffer' );\n\t\tloader.setPath( this.path );\n\t\tloader.setRequestHeader( this.requestHeader );\n\t\tloader.setWithCredentials( this.withCredentials );\n\t\tloader.load( url, function ( buffer ) {\n\n\t\t\ttry {\n\n\t\t\t\t// Create a copy of the buffer. The `decodeAudioData` method\n\t\t\t\t// detaches the buffer when complete, preventing reuse.\n\t\t\t\tconst bufferCopy = buffer.slice( 0 );\n\n\t\t\t\tconst context = AudioContext.getContext();\n\t\t\t\tcontext.decodeAudioData( bufferCopy, function ( audioBuffer ) {\n\n\t\t\t\t\tonLoad( audioBuffer );\n\n\t\t\t\t} );\n\n\t\t\t} catch ( e ) {\n\n\t\t\t\tif ( onError ) {\n\n\t\t\t\t\tonError( e );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.error( e );\n\n\t\t\t\t}\n\n\t\t\t\tscope.manager.itemError( url );\n\n\t\t\t}\n\n\t\t}, onProgress, onError );\n\n\t}\n\n}\n\nclass HemisphereLightProbe extends LightProbe {\n\n\tconstructor( skyColor, groundColor, intensity = 1 ) {\n\n\t\tsuper( undefined, intensity );\n\n\t\tthis.isHemisphereLightProbe = true;\n\n\t\tconst color1 = new Color().set( skyColor );\n\t\tconst color2 = new Color().set( groundColor );\n\n\t\tconst sky = new Vector3( color1.r, color1.g, color1.b );\n\t\tconst ground = new Vector3( color2.r, color2.g, color2.b );\n\n\t\t// without extra factor of PI in the shader, should = 1 / Math.sqrt( Math.PI );\n\t\tconst c0 = Math.sqrt( Math.PI );\n\t\tconst c1 = c0 * Math.sqrt( 0.75 );\n\n\t\tthis.sh.coefficients[ 0 ].copy( sky ).add( ground ).multiplyScalar( c0 );\n\t\tthis.sh.coefficients[ 1 ].copy( sky ).sub( ground ).multiplyScalar( c1 );\n\n\t}\n\n}\n\nclass AmbientLightProbe extends LightProbe {\n\n\tconstructor( color, intensity = 1 ) {\n\n\t\tsuper( undefined, intensity );\n\n\t\tthis.isAmbientLightProbe = true;\n\n\t\tconst color1 = new Color().set( color );\n\n\t\t// without extra factor of PI in the shader, would be 2 / Math.sqrt( Math.PI );\n\t\tthis.sh.coefficients[ 0 ].set( color1.r, color1.g, color1.b ).multiplyScalar( 2 * Math.sqrt( Math.PI ) );\n\n\t}\n\n}\n\nconst _eyeRight = /*@__PURE__*/ new Matrix4();\nconst _eyeLeft = /*@__PURE__*/ new Matrix4();\nconst _projectionMatrix = /*@__PURE__*/ new Matrix4();\n\nclass StereoCamera {\n\n\tconstructor() {\n\n\t\tthis.type = 'StereoCamera';\n\n\t\tthis.aspect = 1;\n\n\t\tthis.eyeSep = 0.064;\n\n\t\tthis.cameraL = new PerspectiveCamera();\n\t\tthis.cameraL.layers.enable( 1 );\n\t\tthis.cameraL.matrixAutoUpdate = false;\n\n\t\tthis.cameraR = new PerspectiveCamera();\n\t\tthis.cameraR.layers.enable( 2 );\n\t\tthis.cameraR.matrixAutoUpdate = false;\n\n\t\tthis._cache = {\n\t\t\tfocus: null,\n\t\t\tfov: null,\n\t\t\taspect: null,\n\t\t\tnear: null,\n\t\t\tfar: null,\n\t\t\tzoom: null,\n\t\t\teyeSep: null\n\t\t};\n\n\t}\n\n\tupdate( camera ) {\n\n\t\tconst cache = this._cache;\n\n\t\tconst needsUpdate = cache.focus !== camera.focus || cache.fov !== camera.fov ||\n\t\t\tcache.aspect !== camera.aspect * this.aspect || cache.near !== camera.near ||\n\t\t\tcache.far !== camera.far || cache.zoom !== camera.zoom || cache.eyeSep !== this.eyeSep;\n\n\t\tif ( needsUpdate ) {\n\n\t\t\tcache.focus = camera.focus;\n\t\t\tcache.fov = camera.fov;\n\t\t\tcache.aspect = camera.aspect * this.aspect;\n\t\t\tcache.near = camera.near;\n\t\t\tcache.far = camera.far;\n\t\t\tcache.zoom = camera.zoom;\n\t\t\tcache.eyeSep = this.eyeSep;\n\n\t\t\t// Off-axis stereoscopic effect based on\n\t\t\t// http://paulbourke.net/stereographics/stereorender/\n\n\t\t\t_projectionMatrix.copy( camera.projectionMatrix );\n\t\t\tconst eyeSepHalf = cache.eyeSep / 2;\n\t\t\tconst eyeSepOnProjection = eyeSepHalf * cache.near / cache.focus;\n\t\t\tconst ymax = ( cache.near * Math.tan( DEG2RAD * cache.fov * 0.5 ) ) / cache.zoom;\n\t\t\tlet xmin, xmax;\n\n\t\t\t// translate xOffset\n\n\t\t\t_eyeLeft.elements[ 12 ] = - eyeSepHalf;\n\t\t\t_eyeRight.elements[ 12 ] = eyeSepHalf;\n\n\t\t\t// for left eye\n\n\t\t\txmin = - ymax * cache.aspect + eyeSepOnProjection;\n\t\t\txmax = ymax * cache.aspect + eyeSepOnProjection;\n\n\t\t\t_projectionMatrix.elements[ 0 ] = 2 * cache.near / ( xmax - xmin );\n\t\t\t_projectionMatrix.elements[ 8 ] = ( xmax + xmin ) / ( xmax - xmin );\n\n\t\t\tthis.cameraL.projectionMatrix.copy( _projectionMatrix );\n\n\t\t\t// for right eye\n\n\t\t\txmin = - ymax * cache.aspect - eyeSepOnProjection;\n\t\t\txmax = ymax * cache.aspect - eyeSepOnProjection;\n\n\t\t\t_projectionMatrix.elements[ 0 ] = 2 * cache.near / ( xmax - xmin );\n\t\t\t_projectionMatrix.elements[ 8 ] = ( xmax + xmin ) / ( xmax - xmin );\n\n\t\t\tthis.cameraR.projectionMatrix.copy( _projectionMatrix );\n\n\t\t}\n\n\t\tthis.cameraL.matrixWorld.copy( camera.matrixWorld ).multiply( _eyeLeft );\n\t\tthis.cameraR.matrixWorld.copy( camera.matrixWorld ).multiply( _eyeRight );\n\n\t}\n\n}\n\nclass Clock {\n\n\tconstructor( autoStart = true ) {\n\n\t\tthis.autoStart = autoStart;\n\n\t\tthis.startTime = 0;\n\t\tthis.oldTime = 0;\n\t\tthis.elapsedTime = 0;\n\n\t\tthis.running = false;\n\n\t}\n\n\tstart() {\n\n\t\tthis.startTime = now();\n\n\t\tthis.oldTime = this.startTime;\n\t\tthis.elapsedTime = 0;\n\t\tthis.running = true;\n\n\t}\n\n\tstop() {\n\n\t\tthis.getElapsedTime();\n\t\tthis.running = false;\n\t\tthis.autoStart = false;\n\n\t}\n\n\tgetElapsedTime() {\n\n\t\tthis.getDelta();\n\t\treturn this.elapsedTime;\n\n\t}\n\n\tgetDelta() {\n\n\t\tlet diff = 0;\n\n\t\tif ( this.autoStart && ! this.running ) {\n\n\t\t\tthis.start();\n\t\t\treturn 0;\n\n\t\t}\n\n\t\tif ( this.running ) {\n\n\t\t\tconst newTime = now();\n\n\t\t\tdiff = ( newTime - this.oldTime ) / 1000;\n\t\t\tthis.oldTime = newTime;\n\n\t\t\tthis.elapsedTime += diff;\n\n\t\t}\n\n\t\treturn diff;\n\n\t}\n\n}\n\nfunction now() {\n\n\treturn ( typeof performance === 'undefined' ? Date : performance ).now(); // see #10732\n\n}\n\nconst _position$1 = /*@__PURE__*/ new Vector3();\nconst _quaternion$1 = /*@__PURE__*/ new Quaternion();\nconst _scale$1 = /*@__PURE__*/ new Vector3();\nconst _orientation$1 = /*@__PURE__*/ new Vector3();\n\nclass AudioListener extends Object3D {\n\n\tconstructor() {\n\n\t\tsuper();\n\n\t\tthis.type = 'AudioListener';\n\n\t\tthis.context = AudioContext.getContext();\n\n\t\tthis.gain = this.context.createGain();\n\t\tthis.gain.connect( this.context.destination );\n\n\t\tthis.filter = null;\n\n\t\tthis.timeDelta = 0;\n\n\t\t// private\n\n\t\tthis._clock = new Clock();\n\n\t}\n\n\tgetInput() {\n\n\t\treturn this.gain;\n\n\t}\n\n\tremoveFilter() {\n\n\t\tif ( this.filter !== null ) {\n\n\t\t\tthis.gain.disconnect( this.filter );\n\t\t\tthis.filter.disconnect( this.context.destination );\n\t\t\tthis.gain.connect( this.context.destination );\n\t\t\tthis.filter = null;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tgetFilter() {\n\n\t\treturn this.filter;\n\n\t}\n\n\tsetFilter( value ) {\n\n\t\tif ( this.filter !== null ) {\n\n\t\t\tthis.gain.disconnect( this.filter );\n\t\t\tthis.filter.disconnect( this.context.destination );\n\n\t\t} else {\n\n\t\t\tthis.gain.disconnect( this.context.destination );\n\n\t\t}\n\n\t\tthis.filter = value;\n\t\tthis.gain.connect( this.filter );\n\t\tthis.filter.connect( this.context.destination );\n\n\t\treturn this;\n\n\t}\n\n\tgetMasterVolume() {\n\n\t\treturn this.gain.gain.value;\n\n\t}\n\n\tsetMasterVolume( value ) {\n\n\t\tthis.gain.gain.setTargetAtTime( value, this.context.currentTime, 0.01 );\n\n\t\treturn this;\n\n\t}\n\n\tupdateMatrixWorld( force ) {\n\n\t\tsuper.updateMatrixWorld( force );\n\n\t\tconst listener = this.context.listener;\n\t\tconst up = this.up;\n\n\t\tthis.timeDelta = this._clock.getDelta();\n\n\t\tthis.matrixWorld.decompose( _position$1, _quaternion$1, _scale$1 );\n\n\t\t_orientation$1.set( 0, 0, - 1 ).applyQuaternion( _quaternion$1 );\n\n\t\tif ( listener.positionX ) {\n\n\t\t\t// code path for Chrome (see #14393)\n\n\t\t\tconst endTime = this.context.currentTime + this.timeDelta;\n\n\t\t\tlistener.positionX.linearRampToValueAtTime( _position$1.x, endTime );\n\t\t\tlistener.positionY.linearRampToValueAtTime( _position$1.y, endTime );\n\t\t\tlistener.positionZ.linearRampToValueAtTime( _position$1.z, endTime );\n\t\t\tlistener.forwardX.linearRampToValueAtTime( _orientation$1.x, endTime );\n\t\t\tlistener.forwardY.linearRampToValueAtTime( _orientation$1.y, endTime );\n\t\t\tlistener.forwardZ.linearRampToValueAtTime( _orientation$1.z, endTime );\n\t\t\tlistener.upX.linearRampToValueAtTime( up.x, endTime );\n\t\t\tlistener.upY.linearRampToValueAtTime( up.y, endTime );\n\t\t\tlistener.upZ.linearRampToValueAtTime( up.z, endTime );\n\n\t\t} else {\n\n\t\t\tlistener.setPosition( _position$1.x, _position$1.y, _position$1.z );\n\t\t\tlistener.setOrientation( _orientation$1.x, _orientation$1.y, _orientation$1.z, up.x, up.y, up.z );\n\n\t\t}\n\n\t}\n\n}\n\nclass Audio extends Object3D {\n\n\tconstructor( listener ) {\n\n\t\tsuper();\n\n\t\tthis.type = 'Audio';\n\n\t\tthis.listener = listener;\n\t\tthis.context = listener.context;\n\n\t\tthis.gain = this.context.createGain();\n\t\tthis.gain.connect( listener.getInput() );\n\n\t\tthis.autoplay = false;\n\n\t\tthis.buffer = null;\n\t\tthis.detune = 0;\n\t\tthis.loop = false;\n\t\tthis.loopStart = 0;\n\t\tthis.loopEnd = 0;\n\t\tthis.offset = 0;\n\t\tthis.duration = undefined;\n\t\tthis.playbackRate = 1;\n\t\tthis.isPlaying = false;\n\t\tthis.hasPlaybackControl = true;\n\t\tthis.source = null;\n\t\tthis.sourceType = 'empty';\n\n\t\tthis._startedAt = 0;\n\t\tthis._progress = 0;\n\t\tthis._connected = false;\n\n\t\tthis.filters = [];\n\n\t}\n\n\tgetOutput() {\n\n\t\treturn this.gain;\n\n\t}\n\n\tsetNodeSource( audioNode ) {\n\n\t\tthis.hasPlaybackControl = false;\n\t\tthis.sourceType = 'audioNode';\n\t\tthis.source = audioNode;\n\t\tthis.connect();\n\n\t\treturn this;\n\n\t}\n\n\tsetMediaElementSource( mediaElement ) {\n\n\t\tthis.hasPlaybackControl = false;\n\t\tthis.sourceType = 'mediaNode';\n\t\tthis.source = this.context.createMediaElementSource( mediaElement );\n\t\tthis.connect();\n\n\t\treturn this;\n\n\t}\n\n\tsetMediaStreamSource( mediaStream ) {\n\n\t\tthis.hasPlaybackControl = false;\n\t\tthis.sourceType = 'mediaStreamNode';\n\t\tthis.source = this.context.createMediaStreamSource( mediaStream );\n\t\tthis.connect();\n\n\t\treturn this;\n\n\t}\n\n\tsetBuffer( audioBuffer ) {\n\n\t\tthis.buffer = audioBuffer;\n\t\tthis.sourceType = 'buffer';\n\n\t\tif ( this.autoplay ) this.play();\n\n\t\treturn this;\n\n\t}\n\n\tplay( delay = 0 ) {\n\n\t\tif ( this.isPlaying === true ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: Audio is already playing.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( this.hasPlaybackControl === false ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: this Audio has no playback control.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tthis._startedAt = this.context.currentTime + delay;\n\n\t\tconst source = this.context.createBufferSource();\n\t\tsource.buffer = this.buffer;\n\t\tsource.loop = this.loop;\n\t\tsource.loopStart = this.loopStart;\n\t\tsource.loopEnd = this.loopEnd;\n\t\tsource.onended = this.onEnded.bind( this );\n\t\tsource.start( this._startedAt, this._progress + this.offset, this.duration );\n\n\t\tthis.isPlaying = true;\n\n\t\tthis.source = source;\n\n\t\tthis.setDetune( this.detune );\n\t\tthis.setPlaybackRate( this.playbackRate );\n\n\t\treturn this.connect();\n\n\t}\n\n\tpause() {\n\n\t\tif ( this.hasPlaybackControl === false ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: this Audio has no playback control.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( this.isPlaying === true ) {\n\n\t\t\t// update current progress\n\n\t\t\tthis._progress += Math.max( this.context.currentTime - this._startedAt, 0 ) * this.playbackRate;\n\n\t\t\tif ( this.loop === true ) {\n\n\t\t\t\t// ensure _progress does not exceed duration with looped audios\n\n\t\t\t\tthis._progress = this._progress % ( this.duration || this.buffer.duration );\n\n\t\t\t}\n\n\t\t\tthis.source.stop();\n\t\t\tthis.source.onended = null;\n\n\t\t\tthis.isPlaying = false;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tstop() {\n\n\t\tif ( this.hasPlaybackControl === false ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: this Audio has no playback control.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tthis._progress = 0;\n\n\t\tthis.source.stop();\n\t\tthis.source.onended = null;\n\t\tthis.isPlaying = false;\n\n\t\treturn this;\n\n\t}\n\n\tconnect() {\n\n\t\tif ( this.filters.length > 0 ) {\n\n\t\t\tthis.source.connect( this.filters[ 0 ] );\n\n\t\t\tfor ( let i = 1, l = this.filters.length; i < l; i ++ ) {\n\n\t\t\t\tthis.filters[ i - 1 ].connect( this.filters[ i ] );\n\n\t\t\t}\n\n\t\t\tthis.filters[ this.filters.length - 1 ].connect( this.getOutput() );\n\n\t\t} else {\n\n\t\t\tthis.source.connect( this.getOutput() );\n\n\t\t}\n\n\t\tthis._connected = true;\n\n\t\treturn this;\n\n\t}\n\n\tdisconnect() {\n\n\t\tif ( this.filters.length > 0 ) {\n\n\t\t\tthis.source.disconnect( this.filters[ 0 ] );\n\n\t\t\tfor ( let i = 1, l = this.filters.length; i < l; i ++ ) {\n\n\t\t\t\tthis.filters[ i - 1 ].disconnect( this.filters[ i ] );\n\n\t\t\t}\n\n\t\t\tthis.filters[ this.filters.length - 1 ].disconnect( this.getOutput() );\n\n\t\t} else {\n\n\t\t\tthis.source.disconnect( this.getOutput() );\n\n\t\t}\n\n\t\tthis._connected = false;\n\n\t\treturn this;\n\n\t}\n\n\tgetFilters() {\n\n\t\treturn this.filters;\n\n\t}\n\n\tsetFilters( value ) {\n\n\t\tif ( ! value ) value = [];\n\n\t\tif ( this._connected === true ) {\n\n\t\t\tthis.disconnect();\n\t\t\tthis.filters = value.slice();\n\t\t\tthis.connect();\n\n\t\t} else {\n\n\t\t\tthis.filters = value.slice();\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tsetDetune( value ) {\n\n\t\tthis.detune = value;\n\n\t\tif ( this.source.detune === undefined ) return; // only set detune when available\n\n\t\tif ( this.isPlaying === true ) {\n\n\t\t\tthis.source.detune.setTargetAtTime( this.detune, this.context.currentTime, 0.01 );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tgetDetune() {\n\n\t\treturn this.detune;\n\n\t}\n\n\tgetFilter() {\n\n\t\treturn this.getFilters()[ 0 ];\n\n\t}\n\n\tsetFilter( filter ) {\n\n\t\treturn this.setFilters( filter ? [ filter ] : [] );\n\n\t}\n\n\tsetPlaybackRate( value ) {\n\n\t\tif ( this.hasPlaybackControl === false ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: this Audio has no playback control.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tthis.playbackRate = value;\n\n\t\tif ( this.isPlaying === true ) {\n\n\t\t\tthis.source.playbackRate.setTargetAtTime( this.playbackRate, this.context.currentTime, 0.01 );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tgetPlaybackRate() {\n\n\t\treturn this.playbackRate;\n\n\t}\n\n\tonEnded() {\n\n\t\tthis.isPlaying = false;\n\n\t}\n\n\tgetLoop() {\n\n\t\tif ( this.hasPlaybackControl === false ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: this Audio has no playback control.' );\n\t\t\treturn false;\n\n\t\t}\n\n\t\treturn this.loop;\n\n\t}\n\n\tsetLoop( value ) {\n\n\t\tif ( this.hasPlaybackControl === false ) {\n\n\t\t\tconsole.warn( 'THREE.Audio: this Audio has no playback control.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tthis.loop = value;\n\n\t\tif ( this.isPlaying === true ) {\n\n\t\t\tthis.source.loop = this.loop;\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tsetLoopStart( value ) {\n\n\t\tthis.loopStart = value;\n\n\t\treturn this;\n\n\t}\n\n\tsetLoopEnd( value ) {\n\n\t\tthis.loopEnd = value;\n\n\t\treturn this;\n\n\t}\n\n\tgetVolume() {\n\n\t\treturn this.gain.gain.value;\n\n\t}\n\n\tsetVolume( value ) {\n\n\t\tthis.gain.gain.setTargetAtTime( value, this.context.currentTime, 0.01 );\n\n\t\treturn this;\n\n\t}\n\n}\n\nconst _position = /*@__PURE__*/ new Vector3();\nconst _quaternion = /*@__PURE__*/ new Quaternion();\nconst _scale = /*@__PURE__*/ new Vector3();\nconst _orientation = /*@__PURE__*/ new Vector3();\n\nclass PositionalAudio extends Audio {\n\n\tconstructor( listener ) {\n\n\t\tsuper( listener );\n\n\t\tthis.panner = this.context.createPanner();\n\t\tthis.panner.panningModel = 'HRTF';\n\t\tthis.panner.connect( this.gain );\n\n\t}\n\n\tdisconnect() {\n\n\t\tsuper.disconnect();\n\n\t\tthis.panner.disconnect( this.gain );\n\n\t}\n\n\tgetOutput() {\n\n\t\treturn this.panner;\n\n\t}\n\n\tgetRefDistance() {\n\n\t\treturn this.panner.refDistance;\n\n\t}\n\n\tsetRefDistance( value ) {\n\n\t\tthis.panner.refDistance = value;\n\n\t\treturn this;\n\n\t}\n\n\tgetRolloffFactor() {\n\n\t\treturn this.panner.rolloffFactor;\n\n\t}\n\n\tsetRolloffFactor( value ) {\n\n\t\tthis.panner.rolloffFactor = value;\n\n\t\treturn this;\n\n\t}\n\n\tgetDistanceModel() {\n\n\t\treturn this.panner.distanceModel;\n\n\t}\n\n\tsetDistanceModel( value ) {\n\n\t\tthis.panner.distanceModel = value;\n\n\t\treturn this;\n\n\t}\n\n\tgetMaxDistance() {\n\n\t\treturn this.panner.maxDistance;\n\n\t}\n\n\tsetMaxDistance( value ) {\n\n\t\tthis.panner.maxDistance = value;\n\n\t\treturn this;\n\n\t}\n\n\tsetDirectionalCone( coneInnerAngle, coneOuterAngle, coneOuterGain ) {\n\n\t\tthis.panner.coneInnerAngle = coneInnerAngle;\n\t\tthis.panner.coneOuterAngle = coneOuterAngle;\n\t\tthis.panner.coneOuterGain = coneOuterGain;\n\n\t\treturn this;\n\n\t}\n\n\tupdateMatrixWorld( force ) {\n\n\t\tsuper.updateMatrixWorld( force );\n\n\t\tif ( this.hasPlaybackControl === true && this.isPlaying === false ) return;\n\n\t\tthis.matrixWorld.decompose( _position, _quaternion, _scale );\n\n\t\t_orientation.set( 0, 0, 1 ).applyQuaternion( _quaternion );\n\n\t\tconst panner = this.panner;\n\n\t\tif ( panner.positionX ) {\n\n\t\t\t// code path for Chrome and Firefox (see #14393)\n\n\t\t\tconst endTime = this.context.currentTime + this.listener.timeDelta;\n\n\t\t\tpanner.positionX.linearRampToValueAtTime( _position.x, endTime );\n\t\t\tpanner.positionY.linearRampToValueAtTime( _position.y, endTime );\n\t\t\tpanner.positionZ.linearRampToValueAtTime( _position.z, endTime );\n\t\t\tpanner.orientationX.linearRampToValueAtTime( _orientation.x, endTime );\n\t\t\tpanner.orientationY.linearRampToValueAtTime( _orientation.y, endTime );\n\t\t\tpanner.orientationZ.linearRampToValueAtTime( _orientation.z, endTime );\n\n\t\t} else {\n\n\t\t\tpanner.setPosition( _position.x, _position.y, _position.z );\n\t\t\tpanner.setOrientation( _orientation.x, _orientation.y, _orientation.z );\n\n\t\t}\n\n\t}\n\n}\n\nclass AudioAnalyser {\n\n\tconstructor( audio, fftSize = 2048 ) {\n\n\t\tthis.analyser = audio.context.createAnalyser();\n\t\tthis.analyser.fftSize = fftSize;\n\n\t\tthis.data = new Uint8Array( this.analyser.frequencyBinCount );\n\n\t\taudio.getOutput().connect( this.analyser );\n\n\t}\n\n\n\tgetFrequencyData() {\n\n\t\tthis.analyser.getByteFrequencyData( this.data );\n\n\t\treturn this.data;\n\n\t}\n\n\tgetAverageFrequency() {\n\n\t\tlet value = 0;\n\t\tconst data = this.getFrequencyData();\n\n\t\tfor ( let i = 0; i < data.length; i ++ ) {\n\n\t\t\tvalue += data[ i ];\n\n\t\t}\n\n\t\treturn value / data.length;\n\n\t}\n\n}\n\nclass PropertyMixer {\n\n\tconstructor( binding, typeName, valueSize ) {\n\n\t\tthis.binding = binding;\n\t\tthis.valueSize = valueSize;\n\n\t\tlet mixFunction,\n\t\t\tmixFunctionAdditive,\n\t\t\tsetIdentity;\n\n\t\t// buffer layout: [ incoming | accu0 | accu1 | orig | addAccu | (optional work) ]\n\t\t//\n\t\t// interpolators can use .buffer as their .result\n\t\t// the data then goes to 'incoming'\n\t\t//\n\t\t// 'accu0' and 'accu1' are used frame-interleaved for\n\t\t// the cumulative result and are compared to detect\n\t\t// changes\n\t\t//\n\t\t// 'orig' stores the original state of the property\n\t\t//\n\t\t// 'add' is used for additive cumulative results\n\t\t//\n\t\t// 'work' is optional and is only present for quaternion types. It is used\n\t\t// to store intermediate quaternion multiplication results\n\n\t\tswitch ( typeName ) {\n\n\t\t\tcase 'quaternion':\n\t\t\t\tmixFunction = this._slerp;\n\t\t\t\tmixFunctionAdditive = this._slerpAdditive;\n\t\t\t\tsetIdentity = this._setAdditiveIdentityQuaternion;\n\n\t\t\t\tthis.buffer = new Float64Array( valueSize * 6 );\n\t\t\t\tthis._workIndex = 5;\n\t\t\t\tbreak;\n\n\t\t\tcase 'string':\n\t\t\tcase 'bool':\n\t\t\t\tmixFunction = this._select;\n\n\t\t\t\t// Use the regular mix function and for additive on these types,\n\t\t\t\t// additive is not relevant for non-numeric types\n\t\t\t\tmixFunctionAdditive = this._select;\n\n\t\t\t\tsetIdentity = this._setAdditiveIdentityOther;\n\n\t\t\t\tthis.buffer = new Array( valueSize * 5 );\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tmixFunction = this._lerp;\n\t\t\t\tmixFunctionAdditive = this._lerpAdditive;\n\t\t\t\tsetIdentity = this._setAdditiveIdentityNumeric;\n\n\t\t\t\tthis.buffer = new Float64Array( valueSize * 5 );\n\n\t\t}\n\n\t\tthis._mixBufferRegion = mixFunction;\n\t\tthis._mixBufferRegionAdditive = mixFunctionAdditive;\n\t\tthis._setIdentity = setIdentity;\n\t\tthis._origIndex = 3;\n\t\tthis._addIndex = 4;\n\n\t\tthis.cumulativeWeight = 0;\n\t\tthis.cumulativeWeightAdditive = 0;\n\n\t\tthis.useCount = 0;\n\t\tthis.referenceCount = 0;\n\n\t}\n\n\t// accumulate data in the 'incoming' region into 'accu'\n\taccumulate( accuIndex, weight ) {\n\n\t\t// note: happily accumulating nothing when weight = 0, the caller knows\n\t\t// the weight and shouldn't have made the call in the first place\n\n\t\tconst buffer = this.buffer,\n\t\t\tstride = this.valueSize,\n\t\t\toffset = accuIndex * stride + stride;\n\n\t\tlet currentWeight = this.cumulativeWeight;\n\n\t\tif ( currentWeight === 0 ) {\n\n\t\t\t// accuN := incoming * weight\n\n\t\t\tfor ( let i = 0; i !== stride; ++ i ) {\n\n\t\t\t\tbuffer[ offset + i ] = buffer[ i ];\n\n\t\t\t}\n\n\t\t\tcurrentWeight = weight;\n\n\t\t} else {\n\n\t\t\t// accuN := accuN + incoming * weight\n\n\t\t\tcurrentWeight += weight;\n\t\t\tconst mix = weight / currentWeight;\n\t\t\tthis._mixBufferRegion( buffer, offset, 0, mix, stride );\n\n\t\t}\n\n\t\tthis.cumulativeWeight = currentWeight;\n\n\t}\n\n\t// accumulate data in the 'incoming' region into 'add'\n\taccumulateAdditive( weight ) {\n\n\t\tconst buffer = this.buffer,\n\t\t\tstride = this.valueSize,\n\t\t\toffset = stride * this._addIndex;\n\n\t\tif ( this.cumulativeWeightAdditive === 0 ) {\n\n\t\t\t// add = identity\n\n\t\t\tthis._setIdentity();\n\n\t\t}\n\n\t\t// add := add + incoming * weight\n\n\t\tthis._mixBufferRegionAdditive( buffer, offset, 0, weight, stride );\n\t\tthis.cumulativeWeightAdditive += weight;\n\n\t}\n\n\t// apply the state of 'accu' to the binding when accus differ\n\tapply( accuIndex ) {\n\n\t\tconst stride = this.valueSize,\n\t\t\tbuffer = this.buffer,\n\t\t\toffset = accuIndex * stride + stride,\n\n\t\t\tweight = this.cumulativeWeight,\n\t\t\tweightAdditive = this.cumulativeWeightAdditive,\n\n\t\t\tbinding = this.binding;\n\n\t\tthis.cumulativeWeight = 0;\n\t\tthis.cumulativeWeightAdditive = 0;\n\n\t\tif ( weight < 1 ) {\n\n\t\t\t// accuN := accuN + original * ( 1 - cumulativeWeight )\n\n\t\t\tconst originalValueOffset = stride * this._origIndex;\n\n\t\t\tthis._mixBufferRegion(\n\t\t\t\tbuffer, offset, originalValueOffset, 1 - weight, stride );\n\n\t\t}\n\n\t\tif ( weightAdditive > 0 ) {\n\n\t\t\t// accuN := accuN + additive accuN\n\n\t\t\tthis._mixBufferRegionAdditive( buffer, offset, this._addIndex * stride, 1, stride );\n\n\t\t}\n\n\t\tfor ( let i = stride, e = stride + stride; i !== e; ++ i ) {\n\n\t\t\tif ( buffer[ i ] !== buffer[ i + stride ] ) {\n\n\t\t\t\t// value has changed -> update scene graph\n\n\t\t\t\tbinding.setValue( buffer, offset );\n\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\t// remember the state of the bound property and copy it to both accus\n\tsaveOriginalState() {\n\n\t\tconst binding = this.binding;\n\n\t\tconst buffer = this.buffer,\n\t\t\tstride = this.valueSize,\n\n\t\t\toriginalValueOffset = stride * this._origIndex;\n\n\t\tbinding.getValue( buffer, originalValueOffset );\n\n\t\t// accu[0..1] := orig -- initially detect changes against the original\n\t\tfor ( let i = stride, e = originalValueOffset; i !== e; ++ i ) {\n\n\t\t\tbuffer[ i ] = buffer[ originalValueOffset + ( i % stride ) ];\n\n\t\t}\n\n\t\t// Add to identity for additive\n\t\tthis._setIdentity();\n\n\t\tthis.cumulativeWeight = 0;\n\t\tthis.cumulativeWeightAdditive = 0;\n\n\t}\n\n\t// apply the state previously taken via 'saveOriginalState' to the binding\n\trestoreOriginalState() {\n\n\t\tconst originalValueOffset = this.valueSize * 3;\n\t\tthis.binding.setValue( this.buffer, originalValueOffset );\n\n\t}\n\n\t_setAdditiveIdentityNumeric() {\n\n\t\tconst startIndex = this._addIndex * this.valueSize;\n\t\tconst endIndex = startIndex + this.valueSize;\n\n\t\tfor ( let i = startIndex; i < endIndex; i ++ ) {\n\n\t\t\tthis.buffer[ i ] = 0;\n\n\t\t}\n\n\t}\n\n\t_setAdditiveIdentityQuaternion() {\n\n\t\tthis._setAdditiveIdentityNumeric();\n\t\tthis.buffer[ this._addIndex * this.valueSize + 3 ] = 1;\n\n\t}\n\n\t_setAdditiveIdentityOther() {\n\n\t\tconst startIndex = this._origIndex * this.valueSize;\n\t\tconst targetIndex = this._addIndex * this.valueSize;\n\n\t\tfor ( let i = 0; i < this.valueSize; i ++ ) {\n\n\t\t\tthis.buffer[ targetIndex + i ] = this.buffer[ startIndex + i ];\n\n\t\t}\n\n\t}\n\n\n\t// mix functions\n\n\t_select( buffer, dstOffset, srcOffset, t, stride ) {\n\n\t\tif ( t >= 0.5 ) {\n\n\t\t\tfor ( let i = 0; i !== stride; ++ i ) {\n\n\t\t\t\tbuffer[ dstOffset + i ] = buffer[ srcOffset + i ];\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\t_slerp( buffer, dstOffset, srcOffset, t ) {\n\n\t\tQuaternion.slerpFlat( buffer, dstOffset, buffer, dstOffset, buffer, srcOffset, t );\n\n\t}\n\n\t_slerpAdditive( buffer, dstOffset, srcOffset, t, stride ) {\n\n\t\tconst workOffset = this._workIndex * stride;\n\n\t\t// Store result in intermediate buffer offset\n\t\tQuaternion.multiplyQuaternionsFlat( buffer, workOffset, buffer, dstOffset, buffer, srcOffset );\n\n\t\t// Slerp to the intermediate result\n\t\tQuaternion.slerpFlat( buffer, dstOffset, buffer, dstOffset, buffer, workOffset, t );\n\n\t}\n\n\t_lerp( buffer, dstOffset, srcOffset, t, stride ) {\n\n\t\tconst s = 1 - t;\n\n\t\tfor ( let i = 0; i !== stride; ++ i ) {\n\n\t\t\tconst j = dstOffset + i;\n\n\t\t\tbuffer[ j ] = buffer[ j ] * s + buffer[ srcOffset + i ] * t;\n\n\t\t}\n\n\t}\n\n\t_lerpAdditive( buffer, dstOffset, srcOffset, t, stride ) {\n\n\t\tfor ( let i = 0; i !== stride; ++ i ) {\n\n\t\t\tconst j = dstOffset + i;\n\n\t\t\tbuffer[ j ] = buffer[ j ] + buffer[ srcOffset + i ] * t;\n\n\t\t}\n\n\t}\n\n}\n\n// Characters [].:/ are reserved for track binding syntax.\nconst _RESERVED_CHARS_RE = '\\\\[\\\\]\\\\.:\\\\/';\nconst _reservedRe = new RegExp( '[' + _RESERVED_CHARS_RE + ']', 'g' );\n\n// Attempts to allow node names from any language. ES5's `\\w` regexp matches\n// only latin characters, and the unicode \\p{L} is not yet supported. So\n// instead, we exclude reserved characters and match everything else.\nconst _wordChar = '[^' + _RESERVED_CHARS_RE + ']';\nconst _wordCharOrDot = '[^' + _RESERVED_CHARS_RE.replace( '\\\\.', '' ) + ']';\n\n// Parent directories, delimited by '/' or ':'. Currently unused, but must\n// be matched to parse the rest of the track name.\nconst _directoryRe = /((?:WC+[\\/:])*)/.source.replace( 'WC', _wordChar );\n\n// Target node. May contain word characters (a-zA-Z0-9_) and '.' or '-'.\nconst _nodeRe = /(WCOD+)?/.source.replace( 'WCOD', _wordCharOrDot );\n\n// Object on target node, and accessor. May not contain reserved\n// characters. Accessor may contain any character except closing bracket.\nconst _objectRe = /(?:\\.(WC+)(?:\\[(.+)\\])?)?/.source.replace( 'WC', _wordChar );\n\n// Property and accessor. May not contain reserved characters. Accessor may\n// contain any non-bracket characters.\nconst _propertyRe = /\\.(WC+)(?:\\[(.+)\\])?/.source.replace( 'WC', _wordChar );\n\nconst _trackRe = new RegExp( ''\n\t+ '^'\n\t+ _directoryRe\n\t+ _nodeRe\n\t+ _objectRe\n\t+ _propertyRe\n\t+ '$'\n);\n\nconst _supportedObjectNames = [ 'material', 'materials', 'bones' ];\n\nclass Composite {\n\n\tconstructor( targetGroup, path, optionalParsedPath ) {\n\n\t\tconst parsedPath = optionalParsedPath || PropertyBinding.parseTrackName( path );\n\n\t\tthis._targetGroup = targetGroup;\n\t\tthis._bindings = targetGroup.subscribe_( path, parsedPath );\n\n\t}\n\n\tgetValue( array, offset ) {\n\n\t\tthis.bind(); // bind all binding\n\n\t\tconst firstValidIndex = this._targetGroup.nCachedObjects_,\n\t\t\tbinding = this._bindings[ firstValidIndex ];\n\n\t\t// and only call .getValue on the first\n\t\tif ( binding !== undefined ) binding.getValue( array, offset );\n\n\t}\n\n\tsetValue( array, offset ) {\n\n\t\tconst bindings = this._bindings;\n\n\t\tfor ( let i = this._targetGroup.nCachedObjects_, n = bindings.length; i !== n; ++ i ) {\n\n\t\t\tbindings[ i ].setValue( array, offset );\n\n\t\t}\n\n\t}\n\n\tbind() {\n\n\t\tconst bindings = this._bindings;\n\n\t\tfor ( let i = this._targetGroup.nCachedObjects_, n = bindings.length; i !== n; ++ i ) {\n\n\t\t\tbindings[ i ].bind();\n\n\t\t}\n\n\t}\n\n\tunbind() {\n\n\t\tconst bindings = this._bindings;\n\n\t\tfor ( let i = this._targetGroup.nCachedObjects_, n = bindings.length; i !== n; ++ i ) {\n\n\t\t\tbindings[ i ].unbind();\n\n\t\t}\n\n\t}\n\n}\n\n// Note: This class uses a State pattern on a per-method basis:\n// 'bind' sets 'this.getValue' / 'setValue' and shadows the\n// prototype version of these methods with one that represents\n// the bound state. When the property is not found, the methods\n// become no-ops.\nclass PropertyBinding {\n\n\tconstructor( rootNode, path, parsedPath ) {\n\n\t\tthis.path = path;\n\t\tthis.parsedPath = parsedPath || PropertyBinding.parseTrackName( path );\n\n\t\tthis.node = PropertyBinding.findNode( rootNode, this.parsedPath.nodeName ) || rootNode;\n\n\t\tthis.rootNode = rootNode;\n\n\t\t// initial state of these methods that calls 'bind'\n\t\tthis.getValue = this._getValue_unbound;\n\t\tthis.setValue = this._setValue_unbound;\n\n\t}\n\n\n\tstatic create( root, path, parsedPath ) {\n\n\t\tif ( ! ( root && root.isAnimationObjectGroup ) ) {\n\n\t\t\treturn new PropertyBinding( root, path, parsedPath );\n\n\t\t} else {\n\n\t\t\treturn new PropertyBinding.Composite( root, path, parsedPath );\n\n\t\t}\n\n\t}\n\n\t/**\n\t * Replaces spaces with underscores and removes unsupported characters from\n\t * node names, to ensure compatibility with parseTrackName().\n\t *\n\t * @param {string} name Node name to be sanitized.\n\t * @return {string}\n\t */\n\tstatic sanitizeNodeName( name ) {\n\n\t\treturn name.replace( /\\s/g, '_' ).replace( _reservedRe, '' );\n\n\t}\n\n\tstatic parseTrackName( trackName ) {\n\n\t\tconst matches = _trackRe.exec( trackName );\n\n\t\tif ( matches === null ) {\n\n\t\t\tthrow new Error( 'PropertyBinding: Cannot parse trackName: ' + trackName );\n\n\t\t}\n\n\t\tconst results = {\n\t\t\t// directoryName: matches[ 1 ], // (tschw) currently unused\n\t\t\tnodeName: matches[ 2 ],\n\t\t\tobjectName: matches[ 3 ],\n\t\t\tobjectIndex: matches[ 4 ],\n\t\t\tpropertyName: matches[ 5 ], // required\n\t\t\tpropertyIndex: matches[ 6 ]\n\t\t};\n\n\t\tconst lastDot = results.nodeName && results.nodeName.lastIndexOf( '.' );\n\n\t\tif ( lastDot !== undefined && lastDot !== - 1 ) {\n\n\t\t\tconst objectName = results.nodeName.substring( lastDot + 1 );\n\n\t\t\t// Object names must be checked against an allowlist. Otherwise, there\n\t\t\t// is no way to parse 'foo.bar.baz': 'baz' must be a property, but\n\t\t\t// 'bar' could be the objectName, or part of a nodeName (which can\n\t\t\t// include '.' characters).\n\t\t\tif ( _supportedObjectNames.indexOf( objectName ) !== - 1 ) {\n\n\t\t\t\tresults.nodeName = results.nodeName.substring( 0, lastDot );\n\t\t\t\tresults.objectName = objectName;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( results.propertyName === null || results.propertyName.length === 0 ) {\n\n\t\t\tthrow new Error( 'PropertyBinding: can not parse propertyName from trackName: ' + trackName );\n\n\t\t}\n\n\t\treturn results;\n\n\t}\n\n\tstatic findNode( root, nodeName ) {\n\n\t\tif ( nodeName === undefined || nodeName === '' || nodeName === '.' || nodeName === - 1 || nodeName === root.name || nodeName === root.uuid ) {\n\n\t\t\treturn root;\n\n\t\t}\n\n\t\t// search into skeleton bones.\n\t\tif ( root.skeleton ) {\n\n\t\t\tconst bone = root.skeleton.getBoneByName( nodeName );\n\n\t\t\tif ( bone !== undefined ) {\n\n\t\t\t\treturn bone;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// search into node subtree.\n\t\tif ( root.children ) {\n\n\t\t\tconst searchNodeSubtree = function ( children ) {\n\n\t\t\t\tfor ( let i = 0; i < children.length; i ++ ) {\n\n\t\t\t\t\tconst childNode = children[ i ];\n\n\t\t\t\t\tif ( childNode.name === nodeName || childNode.uuid === nodeName ) {\n\n\t\t\t\t\t\treturn childNode;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tconst result = searchNodeSubtree( childNode.children );\n\n\t\t\t\t\tif ( result ) return result;\n\n\t\t\t\t}\n\n\t\t\t\treturn null;\n\n\t\t\t};\n\n\t\t\tconst subTreeNode = searchNodeSubtree( root.children );\n\n\t\t\tif ( subTreeNode ) {\n\n\t\t\t\treturn subTreeNode;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn null;\n\n\t}\n\n\t// these are used to \"bind\" a nonexistent property\n\t_getValue_unavailable() {}\n\t_setValue_unavailable() {}\n\n\t// Getters\n\n\t_getValue_direct( buffer, offset ) {\n\n\t\tbuffer[ offset ] = this.targetObject[ this.propertyName ];\n\n\t}\n\n\t_getValue_array( buffer, offset ) {\n\n\t\tconst source = this.resolvedProperty;\n\n\t\tfor ( let i = 0, n = source.length; i !== n; ++ i ) {\n\n\t\t\tbuffer[ offset ++ ] = source[ i ];\n\n\t\t}\n\n\t}\n\n\t_getValue_arrayElement( buffer, offset ) {\n\n\t\tbuffer[ offset ] = this.resolvedProperty[ this.propertyIndex ];\n\n\t}\n\n\t_getValue_toArray( buffer, offset ) {\n\n\t\tthis.resolvedProperty.toArray( buffer, offset );\n\n\t}\n\n\t// Direct\n\n\t_setValue_direct( buffer, offset ) {\n\n\t\tthis.targetObject[ this.propertyName ] = buffer[ offset ];\n\n\t}\n\n\t_setValue_direct_setNeedsUpdate( buffer, offset ) {\n\n\t\tthis.targetObject[ this.propertyName ] = buffer[ offset ];\n\t\tthis.targetObject.needsUpdate = true;\n\n\t}\n\n\t_setValue_direct_setMatrixWorldNeedsUpdate( buffer, offset ) {\n\n\t\tthis.targetObject[ this.propertyName ] = buffer[ offset ];\n\t\tthis.targetObject.matrixWorldNeedsUpdate = true;\n\n\t}\n\n\t// EntireArray\n\n\t_setValue_array( buffer, offset ) {\n\n\t\tconst dest = this.resolvedProperty;\n\n\t\tfor ( let i = 0, n = dest.length; i !== n; ++ i ) {\n\n\t\t\tdest[ i ] = buffer[ offset ++ ];\n\n\t\t}\n\n\t}\n\n\t_setValue_array_setNeedsUpdate( buffer, offset ) {\n\n\t\tconst dest = this.resolvedProperty;\n\n\t\tfor ( let i = 0, n = dest.length; i !== n; ++ i ) {\n\n\t\t\tdest[ i ] = buffer[ offset ++ ];\n\n\t\t}\n\n\t\tthis.targetObject.needsUpdate = true;\n\n\t}\n\n\t_setValue_array_setMatrixWorldNeedsUpdate( buffer, offset ) {\n\n\t\tconst dest = this.resolvedProperty;\n\n\t\tfor ( let i = 0, n = dest.length; i !== n; ++ i ) {\n\n\t\t\tdest[ i ] = buffer[ offset ++ ];\n\n\t\t}\n\n\t\tthis.targetObject.matrixWorldNeedsUpdate = true;\n\n\t}\n\n\t// ArrayElement\n\n\t_setValue_arrayElement( buffer, offset ) {\n\n\t\tthis.resolvedProperty[ this.propertyIndex ] = buffer[ offset ];\n\n\t}\n\n\t_setValue_arrayElement_setNeedsUpdate( buffer, offset ) {\n\n\t\tthis.resolvedProperty[ this.propertyIndex ] = buffer[ offset ];\n\t\tthis.targetObject.needsUpdate = true;\n\n\t}\n\n\t_setValue_arrayElement_setMatrixWorldNeedsUpdate( buffer, offset ) {\n\n\t\tthis.resolvedProperty[ this.propertyIndex ] = buffer[ offset ];\n\t\tthis.targetObject.matrixWorldNeedsUpdate = true;\n\n\t}\n\n\t// HasToFromArray\n\n\t_setValue_fromArray( buffer, offset ) {\n\n\t\tthis.resolvedProperty.fromArray( buffer, offset );\n\n\t}\n\n\t_setValue_fromArray_setNeedsUpdate( buffer, offset ) {\n\n\t\tthis.resolvedProperty.fromArray( buffer, offset );\n\t\tthis.targetObject.needsUpdate = true;\n\n\t}\n\n\t_setValue_fromArray_setMatrixWorldNeedsUpdate( buffer, offset ) {\n\n\t\tthis.resolvedProperty.fromArray( buffer, offset );\n\t\tthis.targetObject.matrixWorldNeedsUpdate = true;\n\n\t}\n\n\t_getValue_unbound( targetArray, offset ) {\n\n\t\tthis.bind();\n\t\tthis.getValue( targetArray, offset );\n\n\t}\n\n\t_setValue_unbound( sourceArray, offset ) {\n\n\t\tthis.bind();\n\t\tthis.setValue( sourceArray, offset );\n\n\t}\n\n\t// create getter / setter pair for a property in the scene graph\n\tbind() {\n\n\t\tlet targetObject = this.node;\n\t\tconst parsedPath = this.parsedPath;\n\n\t\tconst objectName = parsedPath.objectName;\n\t\tconst propertyName = parsedPath.propertyName;\n\t\tlet propertyIndex = parsedPath.propertyIndex;\n\n\t\tif ( ! targetObject ) {\n\n\t\t\ttargetObject = PropertyBinding.findNode( this.rootNode, parsedPath.nodeName ) || this.rootNode;\n\n\t\t\tthis.node = targetObject;\n\n\t\t}\n\n\t\t// set fail state so we can just 'return' on error\n\t\tthis.getValue = this._getValue_unavailable;\n\t\tthis.setValue = this._setValue_unavailable;\n\n\t\t// ensure there is a value node\n\t\tif ( ! targetObject ) {\n\n\t\t\tconsole.error( 'THREE.PropertyBinding: Trying to update node for track: ' + this.path + ' but it wasn\\'t found.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( objectName ) {\n\n\t\t\tlet objectIndex = parsedPath.objectIndex;\n\n\t\t\t// special cases were we need to reach deeper into the hierarchy to get the face materials....\n\t\t\tswitch ( objectName ) {\n\n\t\t\t\tcase 'materials':\n\n\t\t\t\t\tif ( ! targetObject.material ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to material as node does not have a material.', this );\n\t\t\t\t\t\treturn;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( ! targetObject.material.materials ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to material.materials as node.material does not have a materials array.', this );\n\t\t\t\t\t\treturn;\n\n\t\t\t\t\t}\n\n\t\t\t\t\ttargetObject = targetObject.material.materials;\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'bones':\n\n\t\t\t\t\tif ( ! targetObject.skeleton ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to bones as node does not have a skeleton.', this );\n\t\t\t\t\t\treturn;\n\n\t\t\t\t\t}\n\n\t\t\t\t\t// potential future optimization: skip this if propertyIndex is already an integer\n\t\t\t\t\t// and convert the integer string to a true integer.\n\n\t\t\t\t\ttargetObject = targetObject.skeleton.bones;\n\n\t\t\t\t\t// support resolving morphTarget names into indices.\n\t\t\t\t\tfor ( let i = 0; i < targetObject.length; i ++ ) {\n\n\t\t\t\t\t\tif ( targetObject[ i ].name === objectIndex ) {\n\n\t\t\t\t\t\t\tobjectIndex = i;\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\n\n\t\t\t\t\tif ( targetObject[ objectName ] === undefined ) {\n\n\t\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to objectName of node undefined.', this );\n\t\t\t\t\t\treturn;\n\n\t\t\t\t\t}\n\n\t\t\t\t\ttargetObject = targetObject[ objectName ];\n\n\t\t\t}\n\n\n\t\t\tif ( objectIndex !== undefined ) {\n\n\t\t\t\tif ( targetObject[ objectIndex ] === undefined ) {\n\n\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Trying to bind to objectIndex of objectName, but is undefined.', this, targetObject );\n\t\t\t\t\treturn;\n\n\t\t\t\t}\n\n\t\t\t\ttargetObject = targetObject[ objectIndex ];\n\n\t\t\t}\n\n\t\t}\n\n\t\t// resolve property\n\t\tconst nodeProperty = targetObject[ propertyName ];\n\n\t\tif ( nodeProperty === undefined ) {\n\n\t\t\tconst nodeName = parsedPath.nodeName;\n\n\t\t\tconsole.error( 'THREE.PropertyBinding: Trying to update property for track: ' + nodeName +\n\t\t\t\t'.' + propertyName + ' but it wasn\\'t found.', targetObject );\n\t\t\treturn;\n\n\t\t}\n\n\t\t// determine versioning scheme\n\t\tlet versioning = this.Versioning.None;\n\n\t\tthis.targetObject = targetObject;\n\n\t\tif ( targetObject.needsUpdate !== undefined ) { // material\n\n\t\t\tversioning = this.Versioning.NeedsUpdate;\n\n\t\t} else if ( targetObject.matrixWorldNeedsUpdate !== undefined ) { // node transform\n\n\t\t\tversioning = this.Versioning.MatrixWorldNeedsUpdate;\n\n\t\t}\n\n\t\t// determine how the property gets bound\n\t\tlet bindingType = this.BindingType.Direct;\n\n\t\tif ( propertyIndex !== undefined ) {\n\n\t\t\t// access a sub element of the property array (only primitives are supported right now)\n\n\t\t\tif ( propertyName === 'morphTargetInfluences' ) {\n\n\t\t\t\t// potential optimization, skip this if propertyIndex is already an integer, and convert the integer string to a true integer.\n\n\t\t\t\t// support resolving morphTarget names into indices.\n\t\t\t\tif ( ! targetObject.geometry ) {\n\n\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.', this );\n\t\t\t\t\treturn;\n\n\t\t\t\t}\n\n\t\t\t\tif ( ! targetObject.geometry.morphAttributes ) {\n\n\t\t\t\t\tconsole.error( 'THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphAttributes.', this );\n\t\t\t\t\treturn;\n\n\t\t\t\t}\n\n\t\t\t\tif ( targetObject.morphTargetDictionary[ propertyIndex ] !== undefined ) {\n\n\t\t\t\t\tpropertyIndex = targetObject.morphTargetDictionary[ propertyIndex ];\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tbindingType = this.BindingType.ArrayElement;\n\n\t\t\tthis.resolvedProperty = nodeProperty;\n\t\t\tthis.propertyIndex = propertyIndex;\n\n\t\t} else if ( nodeProperty.fromArray !== undefined && nodeProperty.toArray !== undefined ) {\n\n\t\t\t// must use copy for Object3D.Euler/Quaternion\n\n\t\t\tbindingType = this.BindingType.HasFromToArray;\n\n\t\t\tthis.resolvedProperty = nodeProperty;\n\n\t\t} else if ( Array.isArray( nodeProperty ) ) {\n\n\t\t\tbindingType = this.BindingType.EntireArray;\n\n\t\t\tthis.resolvedProperty = nodeProperty;\n\n\t\t} else {\n\n\t\t\tthis.propertyName = propertyName;\n\n\t\t}\n\n\t\t// select getter / setter\n\t\tthis.getValue = this.GetterByBindingType[ bindingType ];\n\t\tthis.setValue = this.SetterByBindingTypeAndVersioning[ bindingType ][ versioning ];\n\n\t}\n\n\tunbind() {\n\n\t\tthis.node = null;\n\n\t\t// back to the prototype version of getValue / setValue\n\t\t// note: avoiding to mutate the shape of 'this' via 'delete'\n\t\tthis.getValue = this._getValue_unbound;\n\t\tthis.setValue = this._setValue_unbound;\n\n\t}\n\n}\n\nPropertyBinding.Composite = Composite;\n\nPropertyBinding.prototype.BindingType = {\n\tDirect: 0,\n\tEntireArray: 1,\n\tArrayElement: 2,\n\tHasFromToArray: 3\n};\n\nPropertyBinding.prototype.Versioning = {\n\tNone: 0,\n\tNeedsUpdate: 1,\n\tMatrixWorldNeedsUpdate: 2\n};\n\nPropertyBinding.prototype.GetterByBindingType = [\n\n\tPropertyBinding.prototype._getValue_direct,\n\tPropertyBinding.prototype._getValue_array,\n\tPropertyBinding.prototype._getValue_arrayElement,\n\tPropertyBinding.prototype._getValue_toArray,\n\n];\n\nPropertyBinding.prototype.SetterByBindingTypeAndVersioning = [\n\n\t[\n\t\t// Direct\n\t\tPropertyBinding.prototype._setValue_direct,\n\t\tPropertyBinding.prototype._setValue_direct_setNeedsUpdate,\n\t\tPropertyBinding.prototype._setValue_direct_setMatrixWorldNeedsUpdate,\n\n\t], [\n\n\t\t// EntireArray\n\n\t\tPropertyBinding.prototype._setValue_array,\n\t\tPropertyBinding.prototype._setValue_array_setNeedsUpdate,\n\t\tPropertyBinding.prototype._setValue_array_setMatrixWorldNeedsUpdate,\n\n\t], [\n\n\t\t// ArrayElement\n\t\tPropertyBinding.prototype._setValue_arrayElement,\n\t\tPropertyBinding.prototype._setValue_arrayElement_setNeedsUpdate,\n\t\tPropertyBinding.prototype._setValue_arrayElement_setMatrixWorldNeedsUpdate,\n\n\t], [\n\n\t\t// HasToFromArray\n\t\tPropertyBinding.prototype._setValue_fromArray,\n\t\tPropertyBinding.prototype._setValue_fromArray_setNeedsUpdate,\n\t\tPropertyBinding.prototype._setValue_fromArray_setMatrixWorldNeedsUpdate,\n\n\t]\n\n];\n\n/**\n *\n * A group of objects that receives a shared animation state.\n *\n * Usage:\n *\n * - Add objects you would otherwise pass as 'root' to the\n * constructor or the .clipAction method of AnimationMixer.\n *\n * - Instead pass this object as 'root'.\n *\n * - You can also add and remove objects later when the mixer\n * is running.\n *\n * Note:\n *\n * Objects of this class appear as one object to the mixer,\n * so cache control of the individual objects must be done\n * on the group.\n *\n * Limitation:\n *\n * - The animated properties must be compatible among the\n * all objects in the group.\n *\n * - A single property can either be controlled through a\n * target group or directly, but not both.\n */\n\nclass AnimationObjectGroup {\n\n\tconstructor() {\n\n\t\tthis.isAnimationObjectGroup = true;\n\n\t\tthis.uuid = generateUUID();\n\n\t\t// cached objects followed by the active ones\n\t\tthis._objects = Array.prototype.slice.call( arguments );\n\n\t\tthis.nCachedObjects_ = 0; // threshold\n\t\t// note: read by PropertyBinding.Composite\n\n\t\tconst indices = {};\n\t\tthis._indicesByUUID = indices; // for bookkeeping\n\n\t\tfor ( let i = 0, n = arguments.length; i !== n; ++ i ) {\n\n\t\t\tindices[ arguments[ i ].uuid ] = i;\n\n\t\t}\n\n\t\tthis._paths = []; // inside: string\n\t\tthis._parsedPaths = []; // inside: { we don't care, here }\n\t\tthis._bindings = []; // inside: Array< PropertyBinding >\n\t\tthis._bindingsIndicesByPath = {}; // inside: indices in these arrays\n\n\t\tconst scope = this;\n\n\t\tthis.stats = {\n\n\t\t\tobjects: {\n\t\t\t\tget total() {\n\n\t\t\t\t\treturn scope._objects.length;\n\n\t\t\t\t},\n\t\t\t\tget inUse() {\n\n\t\t\t\t\treturn this.total - scope.nCachedObjects_;\n\n\t\t\t\t}\n\t\t\t},\n\t\t\tget bindingsPerObject() {\n\n\t\t\t\treturn scope._bindings.length;\n\n\t\t\t}\n\n\t\t};\n\n\t}\n\n\tadd() {\n\n\t\tconst objects = this._objects,\n\t\t\tindicesByUUID = this._indicesByUUID,\n\t\t\tpaths = this._paths,\n\t\t\tparsedPaths = this._parsedPaths,\n\t\t\tbindings = this._bindings,\n\t\t\tnBindings = bindings.length;\n\n\t\tlet knownObject = undefined,\n\t\t\tnObjects = objects.length,\n\t\t\tnCachedObjects = this.nCachedObjects_;\n\n\t\tfor ( let i = 0, n = arguments.length; i !== n; ++ i ) {\n\n\t\t\tconst object = arguments[ i ],\n\t\t\t\tuuid = object.uuid;\n\t\t\tlet index = indicesByUUID[ uuid ];\n\n\t\t\tif ( index === undefined ) {\n\n\t\t\t\t// unknown object -> add it to the ACTIVE region\n\n\t\t\t\tindex = nObjects ++;\n\t\t\t\tindicesByUUID[ uuid ] = index;\n\t\t\t\tobjects.push( object );\n\n\t\t\t\t// accounting is done, now do the same for all bindings\n\n\t\t\t\tfor ( let j = 0, m = nBindings; j !== m; ++ j ) {\n\n\t\t\t\t\tbindings[ j ].push( new PropertyBinding( object, paths[ j ], parsedPaths[ j ] ) );\n\n\t\t\t\t}\n\n\t\t\t} else if ( index < nCachedObjects ) {\n\n\t\t\t\tknownObject = objects[ index ];\n\n\t\t\t\t// move existing object to the ACTIVE region\n\n\t\t\t\tconst firstActiveIndex = -- nCachedObjects,\n\t\t\t\t\tlastCachedObject = objects[ firstActiveIndex ];\n\n\t\t\t\tindicesByUUID[ lastCachedObject.uuid ] = index;\n\t\t\t\tobjects[ index ] = lastCachedObject;\n\n\t\t\t\tindicesByUUID[ uuid ] = firstActiveIndex;\n\t\t\t\tobjects[ firstActiveIndex ] = object;\n\n\t\t\t\t// accounting is done, now do the same for all bindings\n\n\t\t\t\tfor ( let j = 0, m = nBindings; j !== m; ++ j ) {\n\n\t\t\t\t\tconst bindingsForPath = bindings[ j ],\n\t\t\t\t\t\tlastCached = bindingsForPath[ firstActiveIndex ];\n\n\t\t\t\t\tlet binding = bindingsForPath[ index ];\n\n\t\t\t\t\tbindingsForPath[ index ] = lastCached;\n\n\t\t\t\t\tif ( binding === undefined ) {\n\n\t\t\t\t\t\t// since we do not bother to create new bindings\n\t\t\t\t\t\t// for objects that are cached, the binding may\n\t\t\t\t\t\t// or may not exist\n\n\t\t\t\t\t\tbinding = new PropertyBinding( object, paths[ j ], parsedPaths[ j ] );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tbindingsForPath[ firstActiveIndex ] = binding;\n\n\t\t\t\t}\n\n\t\t\t} else if ( objects[ index ] !== knownObject ) {\n\n\t\t\t\tconsole.error( 'THREE.AnimationObjectGroup: Different objects with the same UUID ' +\n\t\t\t\t\t'detected. Clean the caches or recreate your infrastructure when reloading scenes.' );\n\n\t\t\t} // else the object is already where we want it to be\n\n\t\t} // for arguments\n\n\t\tthis.nCachedObjects_ = nCachedObjects;\n\n\t}\n\n\tremove() {\n\n\t\tconst objects = this._objects,\n\t\t\tindicesByUUID = this._indicesByUUID,\n\t\t\tbindings = this._bindings,\n\t\t\tnBindings = bindings.length;\n\n\t\tlet nCachedObjects = this.nCachedObjects_;\n\n\t\tfor ( let i = 0, n = arguments.length; i !== n; ++ i ) {\n\n\t\t\tconst object = arguments[ i ],\n\t\t\t\tuuid = object.uuid,\n\t\t\t\tindex = indicesByUUID[ uuid ];\n\n\t\t\tif ( index !== undefined && index >= nCachedObjects ) {\n\n\t\t\t\t// move existing object into the CACHED region\n\n\t\t\t\tconst lastCachedIndex = nCachedObjects ++,\n\t\t\t\t\tfirstActiveObject = objects[ lastCachedIndex ];\n\n\t\t\t\tindicesByUUID[ firstActiveObject.uuid ] = index;\n\t\t\t\tobjects[ index ] = firstActiveObject;\n\n\t\t\t\tindicesByUUID[ uuid ] = lastCachedIndex;\n\t\t\t\tobjects[ lastCachedIndex ] = object;\n\n\t\t\t\t// accounting is done, now do the same for all bindings\n\n\t\t\t\tfor ( let j = 0, m = nBindings; j !== m; ++ j ) {\n\n\t\t\t\t\tconst bindingsForPath = bindings[ j ],\n\t\t\t\t\t\tfirstActive = bindingsForPath[ lastCachedIndex ],\n\t\t\t\t\t\tbinding = bindingsForPath[ index ];\n\n\t\t\t\t\tbindingsForPath[ index ] = firstActive;\n\t\t\t\t\tbindingsForPath[ lastCachedIndex ] = binding;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} // for arguments\n\n\t\tthis.nCachedObjects_ = nCachedObjects;\n\n\t}\n\n\t// remove & forget\n\tuncache() {\n\n\t\tconst objects = this._objects,\n\t\t\tindicesByUUID = this._indicesByUUID,\n\t\t\tbindings = this._bindings,\n\t\t\tnBindings = bindings.length;\n\n\t\tlet nCachedObjects = this.nCachedObjects_,\n\t\t\tnObjects = objects.length;\n\n\t\tfor ( let i = 0, n = arguments.length; i !== n; ++ i ) {\n\n\t\t\tconst object = arguments[ i ],\n\t\t\t\tuuid = object.uuid,\n\t\t\t\tindex = indicesByUUID[ uuid ];\n\n\t\t\tif ( index !== undefined ) {\n\n\t\t\t\tdelete indicesByUUID[ uuid ];\n\n\t\t\t\tif ( index < nCachedObjects ) {\n\n\t\t\t\t\t// object is cached, shrink the CACHED region\n\n\t\t\t\t\tconst firstActiveIndex = -- nCachedObjects,\n\t\t\t\t\t\tlastCachedObject = objects[ firstActiveIndex ],\n\t\t\t\t\t\tlastIndex = -- nObjects,\n\t\t\t\t\t\tlastObject = objects[ lastIndex ];\n\n\t\t\t\t\t// last cached object takes this object's place\n\t\t\t\t\tindicesByUUID[ lastCachedObject.uuid ] = index;\n\t\t\t\t\tobjects[ index ] = lastCachedObject;\n\n\t\t\t\t\t// last object goes to the activated slot and pop\n\t\t\t\t\tindicesByUUID[ lastObject.uuid ] = firstActiveIndex;\n\t\t\t\t\tobjects[ firstActiveIndex ] = lastObject;\n\t\t\t\t\tobjects.pop();\n\n\t\t\t\t\t// accounting is done, now do the same for all bindings\n\n\t\t\t\t\tfor ( let j = 0, m = nBindings; j !== m; ++ j ) {\n\n\t\t\t\t\t\tconst bindingsForPath = bindings[ j ],\n\t\t\t\t\t\t\tlastCached = bindingsForPath[ firstActiveIndex ],\n\t\t\t\t\t\t\tlast = bindingsForPath[ lastIndex ];\n\n\t\t\t\t\t\tbindingsForPath[ index ] = lastCached;\n\t\t\t\t\t\tbindingsForPath[ firstActiveIndex ] = last;\n\t\t\t\t\t\tbindingsForPath.pop();\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// object is active, just swap with the last and pop\n\n\t\t\t\t\tconst lastIndex = -- nObjects,\n\t\t\t\t\t\tlastObject = objects[ lastIndex ];\n\n\t\t\t\t\tif ( lastIndex > 0 ) {\n\n\t\t\t\t\t\tindicesByUUID[ lastObject.uuid ] = index;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tobjects[ index ] = lastObject;\n\t\t\t\t\tobjects.pop();\n\n\t\t\t\t\t// accounting is done, now do the same for all bindings\n\n\t\t\t\t\tfor ( let j = 0, m = nBindings; j !== m; ++ j ) {\n\n\t\t\t\t\t\tconst bindingsForPath = bindings[ j ];\n\n\t\t\t\t\t\tbindingsForPath[ index ] = bindingsForPath[ lastIndex ];\n\t\t\t\t\t\tbindingsForPath.pop();\n\n\t\t\t\t\t}\n\n\t\t\t\t} // cached or active\n\n\t\t\t} // if object is known\n\n\t\t} // for arguments\n\n\t\tthis.nCachedObjects_ = nCachedObjects;\n\n\t}\n\n\t// Internal interface used by befriended PropertyBinding.Composite:\n\n\tsubscribe_( path, parsedPath ) {\n\n\t\t// returns an array of bindings for the given path that is changed\n\t\t// according to the contained objects in the group\n\n\t\tconst indicesByPath = this._bindingsIndicesByPath;\n\t\tlet index = indicesByPath[ path ];\n\t\tconst bindings = this._bindings;\n\n\t\tif ( index !== undefined ) return bindings[ index ];\n\n\t\tconst paths = this._paths,\n\t\t\tparsedPaths = this._parsedPaths,\n\t\t\tobjects = this._objects,\n\t\t\tnObjects = objects.length,\n\t\t\tnCachedObjects = this.nCachedObjects_,\n\t\t\tbindingsForPath = new Array( nObjects );\n\n\t\tindex = bindings.length;\n\n\t\tindicesByPath[ path ] = index;\n\n\t\tpaths.push( path );\n\t\tparsedPaths.push( parsedPath );\n\t\tbindings.push( bindingsForPath );\n\n\t\tfor ( let i = nCachedObjects, n = objects.length; i !== n; ++ i ) {\n\n\t\t\tconst object = objects[ i ];\n\t\t\tbindingsForPath[ i ] = new PropertyBinding( object, path, parsedPath );\n\n\t\t}\n\n\t\treturn bindingsForPath;\n\n\t}\n\n\tunsubscribe_( path ) {\n\n\t\t// tells the group to forget about a property path and no longer\n\t\t// update the array previously obtained with 'subscribe_'\n\n\t\tconst indicesByPath = this._bindingsIndicesByPath,\n\t\t\tindex = indicesByPath[ path ];\n\n\t\tif ( index !== undefined ) {\n\n\t\t\tconst paths = this._paths,\n\t\t\t\tparsedPaths = this._parsedPaths,\n\t\t\t\tbindings = this._bindings,\n\t\t\t\tlastBindingsIndex = bindings.length - 1,\n\t\t\t\tlastBindings = bindings[ lastBindingsIndex ],\n\t\t\t\tlastBindingsPath = path[ lastBindingsIndex ];\n\n\t\t\tindicesByPath[ lastBindingsPath ] = index;\n\n\t\t\tbindings[ index ] = lastBindings;\n\t\t\tbindings.pop();\n\n\t\t\tparsedPaths[ index ] = parsedPaths[ lastBindingsIndex ];\n\t\t\tparsedPaths.pop();\n\n\t\t\tpaths[ index ] = paths[ lastBindingsIndex ];\n\t\t\tpaths.pop();\n\n\t\t}\n\n\t}\n\n}\n\nclass AnimationAction {\n\n\tconstructor( mixer, clip, localRoot = null, blendMode = clip.blendMode ) {\n\n\t\tthis._mixer = mixer;\n\t\tthis._clip = clip;\n\t\tthis._localRoot = localRoot;\n\t\tthis.blendMode = blendMode;\n\n\t\tconst tracks = clip.tracks,\n\t\t\tnTracks = tracks.length,\n\t\t\tinterpolants = new Array( nTracks );\n\n\t\tconst interpolantSettings = {\n\t\t\tendingStart: ZeroCurvatureEnding,\n\t\t\tendingEnd: ZeroCurvatureEnding\n\t\t};\n\n\t\tfor ( let i = 0; i !== nTracks; ++ i ) {\n\n\t\t\tconst interpolant = tracks[ i ].createInterpolant( null );\n\t\t\tinterpolants[ i ] = interpolant;\n\t\t\tinterpolant.settings = interpolantSettings;\n\n\t\t}\n\n\t\tthis._interpolantSettings = interpolantSettings;\n\n\t\tthis._interpolants = interpolants; // bound by the mixer\n\n\t\t// inside: PropertyMixer (managed by the mixer)\n\t\tthis._propertyBindings = new Array( nTracks );\n\n\t\tthis._cacheIndex = null; // for the memory manager\n\t\tthis._byClipCacheIndex = null; // for the memory manager\n\n\t\tthis._timeScaleInterpolant = null;\n\t\tthis._weightInterpolant = null;\n\n\t\tthis.loop = LoopRepeat;\n\t\tthis._loopCount = - 1;\n\n\t\t// global mixer time when the action is to be started\n\t\t// it's set back to 'null' upon start of the action\n\t\tthis._startTime = null;\n\n\t\t// scaled local time of the action\n\t\t// gets clamped or wrapped to 0..clip.duration according to loop\n\t\tthis.time = 0;\n\n\t\tthis.timeScale = 1;\n\t\tthis._effectiveTimeScale = 1;\n\n\t\tthis.weight = 1;\n\t\tthis._effectiveWeight = 1;\n\n\t\tthis.repetitions = Infinity; // no. of repetitions when looping\n\n\t\tthis.paused = false; // true -> zero effective time scale\n\t\tthis.enabled = true; // false -> zero effective weight\n\n\t\tthis.clampWhenFinished = false;// keep feeding the last frame?\n\n\t\tthis.zeroSlopeAtStart = true;// for smooth interpolation w/o separate\n\t\tthis.zeroSlopeAtEnd = true;// clips for start, loop and end\n\n\t}\n\n\t// State & Scheduling\n\n\tplay() {\n\n\t\tthis._mixer._activateAction( this );\n\n\t\treturn this;\n\n\t}\n\n\tstop() {\n\n\t\tthis._mixer._deactivateAction( this );\n\n\t\treturn this.reset();\n\n\t}\n\n\treset() {\n\n\t\tthis.paused = false;\n\t\tthis.enabled = true;\n\n\t\tthis.time = 0; // restart clip\n\t\tthis._loopCount = - 1;// forget previous loops\n\t\tthis._startTime = null;// forget scheduling\n\n\t\treturn this.stopFading().stopWarping();\n\n\t}\n\n\tisRunning() {\n\n\t\treturn this.enabled && ! this.paused && this.timeScale !== 0 &&\n\t\t\tthis._startTime === null && this._mixer._isActiveAction( this );\n\n\t}\n\n\t// return true when play has been called\n\tisScheduled() {\n\n\t\treturn this._mixer._isActiveAction( this );\n\n\t}\n\n\tstartAt( time ) {\n\n\t\tthis._startTime = time;\n\n\t\treturn this;\n\n\t}\n\n\tsetLoop( mode, repetitions ) {\n\n\t\tthis.loop = mode;\n\t\tthis.repetitions = repetitions;\n\n\t\treturn this;\n\n\t}\n\n\t// Weight\n\n\t// set the weight stopping any scheduled fading\n\t// although .enabled = false yields an effective weight of zero, this\n\t// method does *not* change .enabled, because it would be confusing\n\tsetEffectiveWeight( weight ) {\n\n\t\tthis.weight = weight;\n\n\t\t// note: same logic as when updated at runtime\n\t\tthis._effectiveWeight = this.enabled ? weight : 0;\n\n\t\treturn this.stopFading();\n\n\t}\n\n\t// return the weight considering fading and .enabled\n\tgetEffectiveWeight() {\n\n\t\treturn this._effectiveWeight;\n\n\t}\n\n\tfadeIn( duration ) {\n\n\t\treturn this._scheduleFading( duration, 0, 1 );\n\n\t}\n\n\tfadeOut( duration ) {\n\n\t\treturn this._scheduleFading( duration, 1, 0 );\n\n\t}\n\n\tcrossFadeFrom( fadeOutAction, duration, warp ) {\n\n\t\tfadeOutAction.fadeOut( duration );\n\t\tthis.fadeIn( duration );\n\n\t\tif ( warp ) {\n\n\t\t\tconst fadeInDuration = this._clip.duration,\n\t\t\t\tfadeOutDuration = fadeOutAction._clip.duration,\n\n\t\t\t\tstartEndRatio = fadeOutDuration / fadeInDuration,\n\t\t\t\tendStartRatio = fadeInDuration / fadeOutDuration;\n\n\t\t\tfadeOutAction.warp( 1.0, startEndRatio, duration );\n\t\t\tthis.warp( endStartRatio, 1.0, duration );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tcrossFadeTo( fadeInAction, duration, warp ) {\n\n\t\treturn fadeInAction.crossFadeFrom( this, duration, warp );\n\n\t}\n\n\tstopFading() {\n\n\t\tconst weightInterpolant = this._weightInterpolant;\n\n\t\tif ( weightInterpolant !== null ) {\n\n\t\t\tthis._weightInterpolant = null;\n\t\t\tthis._mixer._takeBackControlInterpolant( weightInterpolant );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\t// Time Scale Control\n\n\t// set the time scale stopping any scheduled warping\n\t// although .paused = true yields an effective time scale of zero, this\n\t// method does *not* change .paused, because it would be confusing\n\tsetEffectiveTimeScale( timeScale ) {\n\n\t\tthis.timeScale = timeScale;\n\t\tthis._effectiveTimeScale = this.paused ? 0 : timeScale;\n\n\t\treturn this.stopWarping();\n\n\t}\n\n\t// return the time scale considering warping and .paused\n\tgetEffectiveTimeScale() {\n\n\t\treturn this._effectiveTimeScale;\n\n\t}\n\n\tsetDuration( duration ) {\n\n\t\tthis.timeScale = this._clip.duration / duration;\n\n\t\treturn this.stopWarping();\n\n\t}\n\n\tsyncWith( action ) {\n\n\t\tthis.time = action.time;\n\t\tthis.timeScale = action.timeScale;\n\n\t\treturn this.stopWarping();\n\n\t}\n\n\thalt( duration ) {\n\n\t\treturn this.warp( this._effectiveTimeScale, 0, duration );\n\n\t}\n\n\twarp( startTimeScale, endTimeScale, duration ) {\n\n\t\tconst mixer = this._mixer,\n\t\t\tnow = mixer.time,\n\t\t\ttimeScale = this.timeScale;\n\n\t\tlet interpolant = this._timeScaleInterpolant;\n\n\t\tif ( interpolant === null ) {\n\n\t\t\tinterpolant = mixer._lendControlInterpolant();\n\t\t\tthis._timeScaleInterpolant = interpolant;\n\n\t\t}\n\n\t\tconst times = interpolant.parameterPositions,\n\t\t\tvalues = interpolant.sampleValues;\n\n\t\ttimes[ 0 ] = now;\n\t\ttimes[ 1 ] = now + duration;\n\n\t\tvalues[ 0 ] = startTimeScale / timeScale;\n\t\tvalues[ 1 ] = endTimeScale / timeScale;\n\n\t\treturn this;\n\n\t}\n\n\tstopWarping() {\n\n\t\tconst timeScaleInterpolant = this._timeScaleInterpolant;\n\n\t\tif ( timeScaleInterpolant !== null ) {\n\n\t\t\tthis._timeScaleInterpolant = null;\n\t\t\tthis._mixer._takeBackControlInterpolant( timeScaleInterpolant );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\t// Object Accessors\n\n\tgetMixer() {\n\n\t\treturn this._mixer;\n\n\t}\n\n\tgetClip() {\n\n\t\treturn this._clip;\n\n\t}\n\n\tgetRoot() {\n\n\t\treturn this._localRoot || this._mixer._root;\n\n\t}\n\n\t// Interna\n\n\t_update( time, deltaTime, timeDirection, accuIndex ) {\n\n\t\t// called by the mixer\n\n\t\tif ( ! this.enabled ) {\n\n\t\t\t// call ._updateWeight() to update ._effectiveWeight\n\n\t\t\tthis._updateWeight( time );\n\t\t\treturn;\n\n\t\t}\n\n\t\tconst startTime = this._startTime;\n\n\t\tif ( startTime !== null ) {\n\n\t\t\t// check for scheduled start of action\n\n\t\t\tconst timeRunning = ( time - startTime ) * timeDirection;\n\t\t\tif ( timeRunning < 0 || timeDirection === 0 ) {\n\n\t\t\t\treturn; // yet to come / don't decide when delta = 0\n\n\t\t\t}\n\n\t\t\t// start\n\n\t\t\tthis._startTime = null; // unschedule\n\t\t\tdeltaTime = timeDirection * timeRunning;\n\n\t\t}\n\n\t\t// apply time scale and advance time\n\n\t\tdeltaTime *= this._updateTimeScale( time );\n\t\tconst clipTime = this._updateTime( deltaTime );\n\n\t\t// note: _updateTime may disable the action resulting in\n\t\t// an effective weight of 0\n\n\t\tconst weight = this._updateWeight( time );\n\n\t\tif ( weight > 0 ) {\n\n\t\t\tconst interpolants = this._interpolants;\n\t\t\tconst propertyMixers = this._propertyBindings;\n\n\t\t\tswitch ( this.blendMode ) {\n\n\t\t\t\tcase AdditiveAnimationBlendMode:\n\n\t\t\t\t\tfor ( let j = 0, m = interpolants.length; j !== m; ++ j ) {\n\n\t\t\t\t\t\tinterpolants[ j ].evaluate( clipTime );\n\t\t\t\t\t\tpropertyMixers[ j ].accumulateAdditive( weight );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase NormalAnimationBlendMode:\n\t\t\t\tdefault:\n\n\t\t\t\t\tfor ( let j = 0, m = interpolants.length; j !== m; ++ j ) {\n\n\t\t\t\t\t\tinterpolants[ j ].evaluate( clipTime );\n\t\t\t\t\t\tpropertyMixers[ j ].accumulate( accuIndex, weight );\n\n\t\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\t_updateWeight( time ) {\n\n\t\tlet weight = 0;\n\n\t\tif ( this.enabled ) {\n\n\t\t\tweight = this.weight;\n\t\t\tconst interpolant = this._weightInterpolant;\n\n\t\t\tif ( interpolant !== null ) {\n\n\t\t\t\tconst interpolantValue = interpolant.evaluate( time )[ 0 ];\n\n\t\t\t\tweight *= interpolantValue;\n\n\t\t\t\tif ( time > interpolant.parameterPositions[ 1 ] ) {\n\n\t\t\t\t\tthis.stopFading();\n\n\t\t\t\t\tif ( interpolantValue === 0 ) {\n\n\t\t\t\t\t\t// faded out, disable\n\t\t\t\t\t\tthis.enabled = false;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tthis._effectiveWeight = weight;\n\t\treturn weight;\n\n\t}\n\n\t_updateTimeScale( time ) {\n\n\t\tlet timeScale = 0;\n\n\t\tif ( ! this.paused ) {\n\n\t\t\ttimeScale = this.timeScale;\n\n\t\t\tconst interpolant = this._timeScaleInterpolant;\n\n\t\t\tif ( interpolant !== null ) {\n\n\t\t\t\tconst interpolantValue = interpolant.evaluate( time )[ 0 ];\n\n\t\t\t\ttimeScale *= interpolantValue;\n\n\t\t\t\tif ( time > interpolant.parameterPositions[ 1 ] ) {\n\n\t\t\t\t\tthis.stopWarping();\n\n\t\t\t\t\tif ( timeScale === 0 ) {\n\n\t\t\t\t\t\t// motion has halted, pause\n\t\t\t\t\t\tthis.paused = true;\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// warp done - apply final time scale\n\t\t\t\t\t\tthis.timeScale = timeScale;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tthis._effectiveTimeScale = timeScale;\n\t\treturn timeScale;\n\n\t}\n\n\t_updateTime( deltaTime ) {\n\n\t\tconst duration = this._clip.duration;\n\t\tconst loop = this.loop;\n\n\t\tlet time = this.time + deltaTime;\n\t\tlet loopCount = this._loopCount;\n\n\t\tconst pingPong = ( loop === LoopPingPong );\n\n\t\tif ( deltaTime === 0 ) {\n\n\t\t\tif ( loopCount === - 1 ) return time;\n\n\t\t\treturn ( pingPong && ( loopCount & 1 ) === 1 ) ? duration - time : time;\n\n\t\t}\n\n\t\tif ( loop === LoopOnce ) {\n\n\t\t\tif ( loopCount === - 1 ) {\n\n\t\t\t\t// just started\n\n\t\t\t\tthis._loopCount = 0;\n\t\t\t\tthis._setEndings( true, true, false );\n\n\t\t\t}\n\n\t\t\thandle_stop: {\n\n\t\t\t\tif ( time >= duration ) {\n\n\t\t\t\t\ttime = duration;\n\n\t\t\t\t} else if ( time < 0 ) {\n\n\t\t\t\t\ttime = 0;\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthis.time = time;\n\n\t\t\t\t\tbreak handle_stop;\n\n\t\t\t\t}\n\n\t\t\t\tif ( this.clampWhenFinished ) this.paused = true;\n\t\t\t\telse this.enabled = false;\n\n\t\t\t\tthis.time = time;\n\n\t\t\t\tthis._mixer.dispatchEvent( {\n\t\t\t\t\ttype: 'finished', action: this,\n\t\t\t\t\tdirection: deltaTime < 0 ? - 1 : 1\n\t\t\t\t} );\n\n\t\t\t}\n\n\t\t} else { // repetitive Repeat or PingPong\n\n\t\t\tif ( loopCount === - 1 ) {\n\n\t\t\t\t// just started\n\n\t\t\t\tif ( deltaTime >= 0 ) {\n\n\t\t\t\t\tloopCount = 0;\n\n\t\t\t\t\tthis._setEndings( true, this.repetitions === 0, pingPong );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// when looping in reverse direction, the initial\n\t\t\t\t\t// transition through zero counts as a repetition,\n\t\t\t\t\t// so leave loopCount at -1\n\n\t\t\t\t\tthis._setEndings( this.repetitions === 0, true, pingPong );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( time >= duration || time < 0 ) {\n\n\t\t\t\t// wrap around\n\n\t\t\t\tconst loopDelta = Math.floor( time / duration ); // signed\n\t\t\t\ttime -= duration * loopDelta;\n\n\t\t\t\tloopCount += Math.abs( loopDelta );\n\n\t\t\t\tconst pending = this.repetitions - loopCount;\n\n\t\t\t\tif ( pending <= 0 ) {\n\n\t\t\t\t\t// have to stop (switch state, clamp time, fire event)\n\n\t\t\t\t\tif ( this.clampWhenFinished ) this.paused = true;\n\t\t\t\t\telse this.enabled = false;\n\n\t\t\t\t\ttime = deltaTime > 0 ? duration : 0;\n\n\t\t\t\t\tthis.time = time;\n\n\t\t\t\t\tthis._mixer.dispatchEvent( {\n\t\t\t\t\t\ttype: 'finished', action: this,\n\t\t\t\t\t\tdirection: deltaTime > 0 ? 1 : - 1\n\t\t\t\t\t} );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// keep running\n\n\t\t\t\t\tif ( pending === 1 ) {\n\n\t\t\t\t\t\t// entering the last round\n\n\t\t\t\t\t\tconst atStart = deltaTime < 0;\n\t\t\t\t\t\tthis._setEndings( atStart, ! atStart, pingPong );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tthis._setEndings( false, false, pingPong );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tthis._loopCount = loopCount;\n\n\t\t\t\t\tthis.time = time;\n\n\t\t\t\t\tthis._mixer.dispatchEvent( {\n\t\t\t\t\t\ttype: 'loop', action: this, loopDelta: loopDelta\n\t\t\t\t\t} );\n\n\t\t\t\t}\n\n\t\t\t} else {\n\n\t\t\t\tthis.time = time;\n\n\t\t\t}\n\n\t\t\tif ( pingPong && ( loopCount & 1 ) === 1 ) {\n\n\t\t\t\t// invert time for the \"pong round\"\n\n\t\t\t\treturn duration - time;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn time;\n\n\t}\n\n\t_setEndings( atStart, atEnd, pingPong ) {\n\n\t\tconst settings = this._interpolantSettings;\n\n\t\tif ( pingPong ) {\n\n\t\t\tsettings.endingStart = ZeroSlopeEnding;\n\t\t\tsettings.endingEnd = ZeroSlopeEnding;\n\n\t\t} else {\n\n\t\t\t// assuming for LoopOnce atStart == atEnd == true\n\n\t\t\tif ( atStart ) {\n\n\t\t\t\tsettings.endingStart = this.zeroSlopeAtStart ? ZeroSlopeEnding : ZeroCurvatureEnding;\n\n\t\t\t} else {\n\n\t\t\t\tsettings.endingStart = WrapAroundEnding;\n\n\t\t\t}\n\n\t\t\tif ( atEnd ) {\n\n\t\t\t\tsettings.endingEnd = this.zeroSlopeAtEnd ? ZeroSlopeEnding : ZeroCurvatureEnding;\n\n\t\t\t} else {\n\n\t\t\t\tsettings.endingEnd \t = WrapAroundEnding;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\t_scheduleFading( duration, weightNow, weightThen ) {\n\n\t\tconst mixer = this._mixer, now = mixer.time;\n\t\tlet interpolant = this._weightInterpolant;\n\n\t\tif ( interpolant === null ) {\n\n\t\t\tinterpolant = mixer._lendControlInterpolant();\n\t\t\tthis._weightInterpolant = interpolant;\n\n\t\t}\n\n\t\tconst times = interpolant.parameterPositions,\n\t\t\tvalues = interpolant.sampleValues;\n\n\t\ttimes[ 0 ] = now;\n\t\tvalues[ 0 ] = weightNow;\n\t\ttimes[ 1 ] = now + duration;\n\t\tvalues[ 1 ] = weightThen;\n\n\t\treturn this;\n\n\t}\n\n}\n\nconst _controlInterpolantsResultBuffer = /*@__PURE__*/ new Float32Array( 1 );\n\n\nclass AnimationMixer extends EventDispatcher {\n\n\tconstructor( root ) {\n\n\t\tsuper();\n\n\t\tthis._root = root;\n\t\tthis._initMemoryManager();\n\t\tthis._accuIndex = 0;\n\t\tthis.time = 0;\n\t\tthis.timeScale = 1.0;\n\n\t}\n\n\t_bindAction( action, prototypeAction ) {\n\n\t\tconst root = action._localRoot || this._root,\n\t\t\ttracks = action._clip.tracks,\n\t\t\tnTracks = tracks.length,\n\t\t\tbindings = action._propertyBindings,\n\t\t\tinterpolants = action._interpolants,\n\t\t\trootUuid = root.uuid,\n\t\t\tbindingsByRoot = this._bindingsByRootAndName;\n\n\t\tlet bindingsByName = bindingsByRoot[ rootUuid ];\n\n\t\tif ( bindingsByName === undefined ) {\n\n\t\t\tbindingsByName = {};\n\t\t\tbindingsByRoot[ rootUuid ] = bindingsByName;\n\n\t\t}\n\n\t\tfor ( let i = 0; i !== nTracks; ++ i ) {\n\n\t\t\tconst track = tracks[ i ],\n\t\t\t\ttrackName = track.name;\n\n\t\t\tlet binding = bindingsByName[ trackName ];\n\n\t\t\tif ( binding !== undefined ) {\n\n\t\t\t\t++ binding.referenceCount;\n\t\t\t\tbindings[ i ] = binding;\n\n\t\t\t} else {\n\n\t\t\t\tbinding = bindings[ i ];\n\n\t\t\t\tif ( binding !== undefined ) {\n\n\t\t\t\t\t// existing binding, make sure the cache knows\n\n\t\t\t\t\tif ( binding._cacheIndex === null ) {\n\n\t\t\t\t\t\t++ binding.referenceCount;\n\t\t\t\t\t\tthis._addInactiveBinding( binding, rootUuid, trackName );\n\n\t\t\t\t\t}\n\n\t\t\t\t\tcontinue;\n\n\t\t\t\t}\n\n\t\t\t\tconst path = prototypeAction && prototypeAction.\n\t\t\t\t\t_propertyBindings[ i ].binding.parsedPath;\n\n\t\t\t\tbinding = new PropertyMixer(\n\t\t\t\t\tPropertyBinding.create( root, trackName, path ),\n\t\t\t\t\ttrack.ValueTypeName, track.getValueSize() );\n\n\t\t\t\t++ binding.referenceCount;\n\t\t\t\tthis._addInactiveBinding( binding, rootUuid, trackName );\n\n\t\t\t\tbindings[ i ] = binding;\n\n\t\t\t}\n\n\t\t\tinterpolants[ i ].resultBuffer = binding.buffer;\n\n\t\t}\n\n\t}\n\n\t_activateAction( action ) {\n\n\t\tif ( ! this._isActiveAction( action ) ) {\n\n\t\t\tif ( action._cacheIndex === null ) {\n\n\t\t\t\t// this action has been forgotten by the cache, but the user\n\t\t\t\t// appears to be still using it -> rebind\n\n\t\t\t\tconst rootUuid = ( action._localRoot || this._root ).uuid,\n\t\t\t\t\tclipUuid = action._clip.uuid,\n\t\t\t\t\tactionsForClip = this._actionsByClip[ clipUuid ];\n\n\t\t\t\tthis._bindAction( action,\n\t\t\t\t\tactionsForClip && actionsForClip.knownActions[ 0 ] );\n\n\t\t\t\tthis._addInactiveAction( action, clipUuid, rootUuid );\n\n\t\t\t}\n\n\t\t\tconst bindings = action._propertyBindings;\n\n\t\t\t// increment reference counts / sort out state\n\t\t\tfor ( let i = 0, n = bindings.length; i !== n; ++ i ) {\n\n\t\t\t\tconst binding = bindings[ i ];\n\n\t\t\t\tif ( binding.useCount ++ === 0 ) {\n\n\t\t\t\t\tthis._lendBinding( binding );\n\t\t\t\t\tbinding.saveOriginalState();\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis._lendAction( action );\n\n\t\t}\n\n\t}\n\n\t_deactivateAction( action ) {\n\n\t\tif ( this._isActiveAction( action ) ) {\n\n\t\t\tconst bindings = action._propertyBindings;\n\n\t\t\t// decrement reference counts / sort out state\n\t\t\tfor ( let i = 0, n = bindings.length; i !== n; ++ i ) {\n\n\t\t\t\tconst binding = bindings[ i ];\n\n\t\t\t\tif ( -- binding.useCount === 0 ) {\n\n\t\t\t\t\tbinding.restoreOriginalState();\n\t\t\t\t\tthis._takeBackBinding( binding );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tthis._takeBackAction( action );\n\n\t\t}\n\n\t}\n\n\t// Memory manager\n\n\t_initMemoryManager() {\n\n\t\tthis._actions = []; // 'nActiveActions' followed by inactive ones\n\t\tthis._nActiveActions = 0;\n\n\t\tthis._actionsByClip = {};\n\t\t// inside:\n\t\t// {\n\t\t// \tknownActions: Array< AnimationAction > - used as prototypes\n\t\t// \tactionByRoot: AnimationAction - lookup\n\t\t// }\n\n\n\t\tthis._bindings = []; // 'nActiveBindings' followed by inactive ones\n\t\tthis._nActiveBindings = 0;\n\n\t\tthis._bindingsByRootAndName = {}; // inside: Map< name, PropertyMixer >\n\n\n\t\tthis._controlInterpolants = []; // same game as above\n\t\tthis._nActiveControlInterpolants = 0;\n\n\t\tconst scope = this;\n\n\t\tthis.stats = {\n\n\t\t\tactions: {\n\t\t\t\tget total() {\n\n\t\t\t\t\treturn scope._actions.length;\n\n\t\t\t\t},\n\t\t\t\tget inUse() {\n\n\t\t\t\t\treturn scope._nActiveActions;\n\n\t\t\t\t}\n\t\t\t},\n\t\t\tbindings: {\n\t\t\t\tget total() {\n\n\t\t\t\t\treturn scope._bindings.length;\n\n\t\t\t\t},\n\t\t\t\tget inUse() {\n\n\t\t\t\t\treturn scope._nActiveBindings;\n\n\t\t\t\t}\n\t\t\t},\n\t\t\tcontrolInterpolants: {\n\t\t\t\tget total() {\n\n\t\t\t\t\treturn scope._controlInterpolants.length;\n\n\t\t\t\t},\n\t\t\t\tget inUse() {\n\n\t\t\t\t\treturn scope._nActiveControlInterpolants;\n\n\t\t\t\t}\n\t\t\t}\n\n\t\t};\n\n\t}\n\n\t// Memory management for AnimationAction objects\n\n\t_isActiveAction( action ) {\n\n\t\tconst index = action._cacheIndex;\n\t\treturn index !== null && index < this._nActiveActions;\n\n\t}\n\n\t_addInactiveAction( action, clipUuid, rootUuid ) {\n\n\t\tconst actions = this._actions,\n\t\t\tactionsByClip = this._actionsByClip;\n\n\t\tlet actionsForClip = actionsByClip[ clipUuid ];\n\n\t\tif ( actionsForClip === undefined ) {\n\n\t\t\tactionsForClip = {\n\n\t\t\t\tknownActions: [ action ],\n\t\t\t\tactionByRoot: {}\n\n\t\t\t};\n\n\t\t\taction._byClipCacheIndex = 0;\n\n\t\t\tactionsByClip[ clipUuid ] = actionsForClip;\n\n\t\t} else {\n\n\t\t\tconst knownActions = actionsForClip.knownActions;\n\n\t\t\taction._byClipCacheIndex = knownActions.length;\n\t\t\tknownActions.push( action );\n\n\t\t}\n\n\t\taction._cacheIndex = actions.length;\n\t\tactions.push( action );\n\n\t\tactionsForClip.actionByRoot[ rootUuid ] = action;\n\n\t}\n\n\t_removeInactiveAction( action ) {\n\n\t\tconst actions = this._actions,\n\t\t\tlastInactiveAction = actions[ actions.length - 1 ],\n\t\t\tcacheIndex = action._cacheIndex;\n\n\t\tlastInactiveAction._cacheIndex = cacheIndex;\n\t\tactions[ cacheIndex ] = lastInactiveAction;\n\t\tactions.pop();\n\n\t\taction._cacheIndex = null;\n\n\n\t\tconst clipUuid = action._clip.uuid,\n\t\t\tactionsByClip = this._actionsByClip,\n\t\t\tactionsForClip = actionsByClip[ clipUuid ],\n\t\t\tknownActionsForClip = actionsForClip.knownActions,\n\n\t\t\tlastKnownAction =\n\t\t\t\tknownActionsForClip[ knownActionsForClip.length - 1 ],\n\n\t\t\tbyClipCacheIndex = action._byClipCacheIndex;\n\n\t\tlastKnownAction._byClipCacheIndex = byClipCacheIndex;\n\t\tknownActionsForClip[ byClipCacheIndex ] = lastKnownAction;\n\t\tknownActionsForClip.pop();\n\n\t\taction._byClipCacheIndex = null;\n\n\n\t\tconst actionByRoot = actionsForClip.actionByRoot,\n\t\t\trootUuid = ( action._localRoot || this._root ).uuid;\n\n\t\tdelete actionByRoot[ rootUuid ];\n\n\t\tif ( knownActionsForClip.length === 0 ) {\n\n\t\t\tdelete actionsByClip[ clipUuid ];\n\n\t\t}\n\n\t\tthis._removeInactiveBindingsForAction( action );\n\n\t}\n\n\t_removeInactiveBindingsForAction( action ) {\n\n\t\tconst bindings = action._propertyBindings;\n\n\t\tfor ( let i = 0, n = bindings.length; i !== n; ++ i ) {\n\n\t\t\tconst binding = bindings[ i ];\n\n\t\t\tif ( -- binding.referenceCount === 0 ) {\n\n\t\t\t\tthis._removeInactiveBinding( binding );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\t_lendAction( action ) {\n\n\t\t// [ active actions | inactive actions ]\n\t\t// [ active actions >| inactive actions ]\n\t\t// s a\n\t\t// <-swap->\n\t\t// a s\n\n\t\tconst actions = this._actions,\n\t\t\tprevIndex = action._cacheIndex,\n\n\t\t\tlastActiveIndex = this._nActiveActions ++,\n\n\t\t\tfirstInactiveAction = actions[ lastActiveIndex ];\n\n\t\taction._cacheIndex = lastActiveIndex;\n\t\tactions[ lastActiveIndex ] = action;\n\n\t\tfirstInactiveAction._cacheIndex = prevIndex;\n\t\tactions[ prevIndex ] = firstInactiveAction;\n\n\t}\n\n\t_takeBackAction( action ) {\n\n\t\t// [ active actions | inactive actions ]\n\t\t// [ active actions |< inactive actions ]\n\t\t// a s\n\t\t// <-swap->\n\t\t// s a\n\n\t\tconst actions = this._actions,\n\t\t\tprevIndex = action._cacheIndex,\n\n\t\t\tfirstInactiveIndex = -- this._nActiveActions,\n\n\t\t\tlastActiveAction = actions[ firstInactiveIndex ];\n\n\t\taction._cacheIndex = firstInactiveIndex;\n\t\tactions[ firstInactiveIndex ] = action;\n\n\t\tlastActiveAction._cacheIndex = prevIndex;\n\t\tactions[ prevIndex ] = lastActiveAction;\n\n\t}\n\n\t// Memory management for PropertyMixer objects\n\n\t_addInactiveBinding( binding, rootUuid, trackName ) {\n\n\t\tconst bindingsByRoot = this._bindingsByRootAndName,\n\t\t\tbindings = this._bindings;\n\n\t\tlet bindingByName = bindingsByRoot[ rootUuid ];\n\n\t\tif ( bindingByName === undefined ) {\n\n\t\t\tbindingByName = {};\n\t\t\tbindingsByRoot[ rootUuid ] = bindingByName;\n\n\t\t}\n\n\t\tbindingByName[ trackName ] = binding;\n\n\t\tbinding._cacheIndex = bindings.length;\n\t\tbindings.push( binding );\n\n\t}\n\n\t_removeInactiveBinding( binding ) {\n\n\t\tconst bindings = this._bindings,\n\t\t\tpropBinding = binding.binding,\n\t\t\trootUuid = propBinding.rootNode.uuid,\n\t\t\ttrackName = propBinding.path,\n\t\t\tbindingsByRoot = this._bindingsByRootAndName,\n\t\t\tbindingByName = bindingsByRoot[ rootUuid ],\n\n\t\t\tlastInactiveBinding = bindings[ bindings.length - 1 ],\n\t\t\tcacheIndex = binding._cacheIndex;\n\n\t\tlastInactiveBinding._cacheIndex = cacheIndex;\n\t\tbindings[ cacheIndex ] = lastInactiveBinding;\n\t\tbindings.pop();\n\n\t\tdelete bindingByName[ trackName ];\n\n\t\tif ( Object.keys( bindingByName ).length === 0 ) {\n\n\t\t\tdelete bindingsByRoot[ rootUuid ];\n\n\t\t}\n\n\t}\n\n\t_lendBinding( binding ) {\n\n\t\tconst bindings = this._bindings,\n\t\t\tprevIndex = binding._cacheIndex,\n\n\t\t\tlastActiveIndex = this._nActiveBindings ++,\n\n\t\t\tfirstInactiveBinding = bindings[ lastActiveIndex ];\n\n\t\tbinding._cacheIndex = lastActiveIndex;\n\t\tbindings[ lastActiveIndex ] = binding;\n\n\t\tfirstInactiveBinding._cacheIndex = prevIndex;\n\t\tbindings[ prevIndex ] = firstInactiveBinding;\n\n\t}\n\n\t_takeBackBinding( binding ) {\n\n\t\tconst bindings = this._bindings,\n\t\t\tprevIndex = binding._cacheIndex,\n\n\t\t\tfirstInactiveIndex = -- this._nActiveBindings,\n\n\t\t\tlastActiveBinding = bindings[ firstInactiveIndex ];\n\n\t\tbinding._cacheIndex = firstInactiveIndex;\n\t\tbindings[ firstInactiveIndex ] = binding;\n\n\t\tlastActiveBinding._cacheIndex = prevIndex;\n\t\tbindings[ prevIndex ] = lastActiveBinding;\n\n\t}\n\n\n\t// Memory management of Interpolants for weight and time scale\n\n\t_lendControlInterpolant() {\n\n\t\tconst interpolants = this._controlInterpolants,\n\t\t\tlastActiveIndex = this._nActiveControlInterpolants ++;\n\n\t\tlet interpolant = interpolants[ lastActiveIndex ];\n\n\t\tif ( interpolant === undefined ) {\n\n\t\t\tinterpolant = new LinearInterpolant(\n\t\t\t\tnew Float32Array( 2 ), new Float32Array( 2 ),\n\t\t\t\t1, _controlInterpolantsResultBuffer );\n\n\t\t\tinterpolant.__cacheIndex = lastActiveIndex;\n\t\t\tinterpolants[ lastActiveIndex ] = interpolant;\n\n\t\t}\n\n\t\treturn interpolant;\n\n\t}\n\n\t_takeBackControlInterpolant( interpolant ) {\n\n\t\tconst interpolants = this._controlInterpolants,\n\t\t\tprevIndex = interpolant.__cacheIndex,\n\n\t\t\tfirstInactiveIndex = -- this._nActiveControlInterpolants,\n\n\t\t\tlastActiveInterpolant = interpolants[ firstInactiveIndex ];\n\n\t\tinterpolant.__cacheIndex = firstInactiveIndex;\n\t\tinterpolants[ firstInactiveIndex ] = interpolant;\n\n\t\tlastActiveInterpolant.__cacheIndex = prevIndex;\n\t\tinterpolants[ prevIndex ] = lastActiveInterpolant;\n\n\t}\n\n\t// return an action for a clip optionally using a custom root target\n\t// object (this method allocates a lot of dynamic memory in case a\n\t// previously unknown clip/root combination is specified)\n\tclipAction( clip, optionalRoot, blendMode ) {\n\n\t\tconst root = optionalRoot || this._root,\n\t\t\trootUuid = root.uuid;\n\n\t\tlet clipObject = typeof clip === 'string' ? AnimationClip.findByName( root, clip ) : clip;\n\n\t\tconst clipUuid = clipObject !== null ? clipObject.uuid : clip;\n\n\t\tconst actionsForClip = this._actionsByClip[ clipUuid ];\n\t\tlet prototypeAction = null;\n\n\t\tif ( blendMode === undefined ) {\n\n\t\t\tif ( clipObject !== null ) {\n\n\t\t\t\tblendMode = clipObject.blendMode;\n\n\t\t\t} else {\n\n\t\t\t\tblendMode = NormalAnimationBlendMode;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( actionsForClip !== undefined ) {\n\n\t\t\tconst existingAction = actionsForClip.actionByRoot[ rootUuid ];\n\n\t\t\tif ( existingAction !== undefined && existingAction.blendMode === blendMode ) {\n\n\t\t\t\treturn existingAction;\n\n\t\t\t}\n\n\t\t\t// we know the clip, so we don't have to parse all\n\t\t\t// the bindings again but can just copy\n\t\t\tprototypeAction = actionsForClip.knownActions[ 0 ];\n\n\t\t\t// also, take the clip from the prototype action\n\t\t\tif ( clipObject === null )\n\t\t\t\tclipObject = prototypeAction._clip;\n\n\t\t}\n\n\t\t// clip must be known when specified via string\n\t\tif ( clipObject === null ) return null;\n\n\t\t// allocate all resources required to run it\n\t\tconst newAction = new AnimationAction( this, clipObject, optionalRoot, blendMode );\n\n\t\tthis._bindAction( newAction, prototypeAction );\n\n\t\t// and make the action known to the memory manager\n\t\tthis._addInactiveAction( newAction, clipUuid, rootUuid );\n\n\t\treturn newAction;\n\n\t}\n\n\t// get an existing action\n\texistingAction( clip, optionalRoot ) {\n\n\t\tconst root = optionalRoot || this._root,\n\t\t\trootUuid = root.uuid,\n\n\t\t\tclipObject = typeof clip === 'string' ?\n\t\t\t\tAnimationClip.findByName( root, clip ) : clip,\n\n\t\t\tclipUuid = clipObject ? clipObject.uuid : clip,\n\n\t\t\tactionsForClip = this._actionsByClip[ clipUuid ];\n\n\t\tif ( actionsForClip !== undefined ) {\n\n\t\t\treturn actionsForClip.actionByRoot[ rootUuid ] || null;\n\n\t\t}\n\n\t\treturn null;\n\n\t}\n\n\t// deactivates all previously scheduled actions\n\tstopAllAction() {\n\n\t\tconst actions = this._actions,\n\t\t\tnActions = this._nActiveActions;\n\n\t\tfor ( let i = nActions - 1; i >= 0; -- i ) {\n\n\t\t\tactions[ i ].stop();\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\t// advance the time and update apply the animation\n\tupdate( deltaTime ) {\n\n\t\tdeltaTime *= this.timeScale;\n\n\t\tconst actions = this._actions,\n\t\t\tnActions = this._nActiveActions,\n\n\t\t\ttime = this.time += deltaTime,\n\t\t\ttimeDirection = Math.sign( deltaTime ),\n\n\t\t\taccuIndex = this._accuIndex ^= 1;\n\n\t\t// run active actions\n\n\t\tfor ( let i = 0; i !== nActions; ++ i ) {\n\n\t\t\tconst action = actions[ i ];\n\n\t\t\taction._update( time, deltaTime, timeDirection, accuIndex );\n\n\t\t}\n\n\t\t// update scene graph\n\n\t\tconst bindings = this._bindings,\n\t\t\tnBindings = this._nActiveBindings;\n\n\t\tfor ( let i = 0; i !== nBindings; ++ i ) {\n\n\t\t\tbindings[ i ].apply( accuIndex );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\t// Allows you to seek to a specific time in an animation.\n\tsetTime( timeInSeconds ) {\n\n\t\tthis.time = 0; // Zero out time attribute for AnimationMixer object;\n\t\tfor ( let i = 0; i < this._actions.length; i ++ ) {\n\n\t\t\tthis._actions[ i ].time = 0; // Zero out time attribute for all associated AnimationAction objects.\n\n\t\t}\n\n\t\treturn this.update( timeInSeconds ); // Update used to set exact time. Returns \"this\" AnimationMixer object.\n\n\t}\n\n\t// return this mixer's root target object\n\tgetRoot() {\n\n\t\treturn this._root;\n\n\t}\n\n\t// free all resources specific to a particular clip\n\tuncacheClip( clip ) {\n\n\t\tconst actions = this._actions,\n\t\t\tclipUuid = clip.uuid,\n\t\t\tactionsByClip = this._actionsByClip,\n\t\t\tactionsForClip = actionsByClip[ clipUuid ];\n\n\t\tif ( actionsForClip !== undefined ) {\n\n\t\t\t// note: just calling _removeInactiveAction would mess up the\n\t\t\t// iteration state and also require updating the state we can\n\t\t\t// just throw away\n\n\t\t\tconst actionsToRemove = actionsForClip.knownActions;\n\n\t\t\tfor ( let i = 0, n = actionsToRemove.length; i !== n; ++ i ) {\n\n\t\t\t\tconst action = actionsToRemove[ i ];\n\n\t\t\t\tthis._deactivateAction( action );\n\n\t\t\t\tconst cacheIndex = action._cacheIndex,\n\t\t\t\t\tlastInactiveAction = actions[ actions.length - 1 ];\n\n\t\t\t\taction._cacheIndex = null;\n\t\t\t\taction._byClipCacheIndex = null;\n\n\t\t\t\tlastInactiveAction._cacheIndex = cacheIndex;\n\t\t\t\tactions[ cacheIndex ] = lastInactiveAction;\n\t\t\t\tactions.pop();\n\n\t\t\t\tthis._removeInactiveBindingsForAction( action );\n\n\t\t\t}\n\n\t\t\tdelete actionsByClip[ clipUuid ];\n\n\t\t}\n\n\t}\n\n\t// free all resources specific to a particular root target object\n\tuncacheRoot( root ) {\n\n\t\tconst rootUuid = root.uuid,\n\t\t\tactionsByClip = this._actionsByClip;\n\n\t\tfor ( const clipUuid in actionsByClip ) {\n\n\t\t\tconst actionByRoot = actionsByClip[ clipUuid ].actionByRoot,\n\t\t\t\taction = actionByRoot[ rootUuid ];\n\n\t\t\tif ( action !== undefined ) {\n\n\t\t\t\tthis._deactivateAction( action );\n\t\t\t\tthis._removeInactiveAction( action );\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst bindingsByRoot = this._bindingsByRootAndName,\n\t\t\tbindingByName = bindingsByRoot[ rootUuid ];\n\n\t\tif ( bindingByName !== undefined ) {\n\n\t\t\tfor ( const trackName in bindingByName ) {\n\n\t\t\t\tconst binding = bindingByName[ trackName ];\n\t\t\t\tbinding.restoreOriginalState();\n\t\t\t\tthis._removeInactiveBinding( binding );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\t// remove a targeted clip from the cache\n\tuncacheAction( clip, optionalRoot ) {\n\n\t\tconst action = this.existingAction( clip, optionalRoot );\n\n\t\tif ( action !== null ) {\n\n\t\t\tthis._deactivateAction( action );\n\t\t\tthis._removeInactiveAction( action );\n\n\t\t}\n\n\t}\n\n}\n\nclass Uniform {\n\n\tconstructor( value ) {\n\n\t\tif ( typeof value === 'string' ) {\n\n\t\t\tconsole.warn( 'THREE.Uniform: Type parameter is no longer needed.' );\n\t\t\tvalue = arguments[ 1 ];\n\n\t\t}\n\n\t\tthis.value = value;\n\n\t}\n\n\tclone() {\n\n\t\treturn new Uniform( this.value.clone === undefined ? this.value : this.value.clone() );\n\n\t}\n\n}\n\nclass InstancedInterleavedBuffer extends InterleavedBuffer {\n\n\tconstructor( array, stride, meshPerAttribute = 1 ) {\n\n\t\tsuper( array, stride );\n\n\t\tthis.isInstancedInterleavedBuffer = true;\n\n\t\tthis.meshPerAttribute = meshPerAttribute;\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.meshPerAttribute = source.meshPerAttribute;\n\n\t\treturn this;\n\n\t}\n\n\tclone( data ) {\n\n\t\tconst ib = super.clone( data );\n\n\t\tib.meshPerAttribute = this.meshPerAttribute;\n\n\t\treturn ib;\n\n\t}\n\n\ttoJSON( data ) {\n\n\t\tconst json = super.toJSON( data );\n\n\t\tjson.isInstancedInterleavedBuffer = true;\n\t\tjson.meshPerAttribute = this.meshPerAttribute;\n\n\t\treturn json;\n\n\t}\n\n}\n\nclass GLBufferAttribute {\n\n\tconstructor( buffer, type, itemSize, elementSize, count ) {\n\n\t\tthis.isGLBufferAttribute = true;\n\n\t\tthis.buffer = buffer;\n\t\tthis.type = type;\n\t\tthis.itemSize = itemSize;\n\t\tthis.elementSize = elementSize;\n\t\tthis.count = count;\n\n\t\tthis.version = 0;\n\n\t}\n\n\tset needsUpdate( value ) {\n\n\t\tif ( value === true ) this.version ++;\n\n\t}\n\n\tsetBuffer( buffer ) {\n\n\t\tthis.buffer = buffer;\n\n\t\treturn this;\n\n\t}\n\n\tsetType( type, elementSize ) {\n\n\t\tthis.type = type;\n\t\tthis.elementSize = elementSize;\n\n\t\treturn this;\n\n\t}\n\n\tsetItemSize( itemSize ) {\n\n\t\tthis.itemSize = itemSize;\n\n\t\treturn this;\n\n\t}\n\n\tsetCount( count ) {\n\n\t\tthis.count = count;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass Raycaster {\n\n\tconstructor( origin, direction, near = 0, far = Infinity ) {\n\n\t\tthis.ray = new Ray( origin, direction );\n\t\t// direction is assumed to be normalized (for accurate distance calculations)\n\n\t\tthis.near = near;\n\t\tthis.far = far;\n\t\tthis.camera = null;\n\t\tthis.layers = new Layers();\n\n\t\tthis.params = {\n\t\t\tMesh: {},\n\t\t\tLine: { threshold: 1 },\n\t\t\tLOD: {},\n\t\t\tPoints: { threshold: 1 },\n\t\t\tSprite: {}\n\t\t};\n\n\t}\n\n\tset( origin, direction ) {\n\n\t\t// direction is assumed to be normalized (for accurate distance calculations)\n\n\t\tthis.ray.set( origin, direction );\n\n\t}\n\n\tsetFromCamera( coords, camera ) {\n\n\t\tif ( camera.isPerspectiveCamera ) {\n\n\t\t\tthis.ray.origin.setFromMatrixPosition( camera.matrixWorld );\n\t\t\tthis.ray.direction.set( coords.x, coords.y, 0.5 ).unproject( camera ).sub( this.ray.origin ).normalize();\n\t\t\tthis.camera = camera;\n\n\t\t} else if ( camera.isOrthographicCamera ) {\n\n\t\t\tthis.ray.origin.set( coords.x, coords.y, ( camera.near + camera.far ) / ( camera.near - camera.far ) ).unproject( camera ); // set origin in plane of camera\n\t\t\tthis.ray.direction.set( 0, 0, - 1 ).transformDirection( camera.matrixWorld );\n\t\t\tthis.camera = camera;\n\n\t\t} else {\n\n\t\t\tconsole.error( 'THREE.Raycaster: Unsupported camera type: ' + camera.type );\n\n\t\t}\n\n\t}\n\n\tintersectObject( object, recursive = true, intersects = [] ) {\n\n\t\tintersectObject( object, this, intersects, recursive );\n\n\t\tintersects.sort( ascSort );\n\n\t\treturn intersects;\n\n\t}\n\n\tintersectObjects( objects, recursive = true, intersects = [] ) {\n\n\t\tfor ( let i = 0, l = objects.length; i < l; i ++ ) {\n\n\t\t\tintersectObject( objects[ i ], this, intersects, recursive );\n\n\t\t}\n\n\t\tintersects.sort( ascSort );\n\n\t\treturn intersects;\n\n\t}\n\n}\n\nfunction ascSort( a, b ) {\n\n\treturn a.distance - b.distance;\n\n}\n\nfunction intersectObject( object, raycaster, intersects, recursive ) {\n\n\tif ( object.layers.test( raycaster.layers ) ) {\n\n\t\tobject.raycast( raycaster, intersects );\n\n\t}\n\n\tif ( recursive === true ) {\n\n\t\tconst children = object.children;\n\n\t\tfor ( let i = 0, l = children.length; i < l; i ++ ) {\n\n\t\t\tintersectObject( children[ i ], raycaster, intersects, true );\n\n\t\t}\n\n\t}\n\n}\n\n/**\n * Ref: https://en.wikipedia.org/wiki/Spherical_coordinate_system\n *\n * The polar angle (phi) is measured from the positive y-axis. The positive y-axis is up.\n * The azimuthal angle (theta) is measured from the positive z-axis.\n */\n\nclass Spherical {\n\n\tconstructor( radius = 1, phi = 0, theta = 0 ) {\n\n\t\tthis.radius = radius;\n\t\tthis.phi = phi; // polar angle\n\t\tthis.theta = theta; // azimuthal angle\n\n\t\treturn this;\n\n\t}\n\n\tset( radius, phi, theta ) {\n\n\t\tthis.radius = radius;\n\t\tthis.phi = phi;\n\t\tthis.theta = theta;\n\n\t\treturn this;\n\n\t}\n\n\tcopy( other ) {\n\n\t\tthis.radius = other.radius;\n\t\tthis.phi = other.phi;\n\t\tthis.theta = other.theta;\n\n\t\treturn this;\n\n\t}\n\n\t// restrict phi to be between EPS and PI-EPS\n\tmakeSafe() {\n\n\t\tconst EPS = 0.000001;\n\t\tthis.phi = Math.max( EPS, Math.min( Math.PI - EPS, this.phi ) );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromVector3( v ) {\n\n\t\treturn this.setFromCartesianCoords( v.x, v.y, v.z );\n\n\t}\n\n\tsetFromCartesianCoords( x, y, z ) {\n\n\t\tthis.radius = Math.sqrt( x * x + y * y + z * z );\n\n\t\tif ( this.radius === 0 ) {\n\n\t\t\tthis.theta = 0;\n\t\t\tthis.phi = 0;\n\n\t\t} else {\n\n\t\t\tthis.theta = Math.atan2( x, z );\n\t\t\tthis.phi = Math.acos( clamp( y / this.radius, - 1, 1 ) );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n}\n\n/**\n * Ref: https://en.wikipedia.org/wiki/Cylindrical_coordinate_system\n */\n\nclass Cylindrical {\n\n\tconstructor( radius = 1, theta = 0, y = 0 ) {\n\n\t\tthis.radius = radius; // distance from the origin to a point in the x-z plane\n\t\tthis.theta = theta; // counterclockwise angle in the x-z plane measured in radians from the positive z-axis\n\t\tthis.y = y; // height above the x-z plane\n\n\t\treturn this;\n\n\t}\n\n\tset( radius, theta, y ) {\n\n\t\tthis.radius = radius;\n\t\tthis.theta = theta;\n\t\tthis.y = y;\n\n\t\treturn this;\n\n\t}\n\n\tcopy( other ) {\n\n\t\tthis.radius = other.radius;\n\t\tthis.theta = other.theta;\n\t\tthis.y = other.y;\n\n\t\treturn this;\n\n\t}\n\n\tsetFromVector3( v ) {\n\n\t\treturn this.setFromCartesianCoords( v.x, v.y, v.z );\n\n\t}\n\n\tsetFromCartesianCoords( x, y, z ) {\n\n\t\tthis.radius = Math.sqrt( x * x + z * z );\n\t\tthis.theta = Math.atan2( x, z );\n\t\tthis.y = y;\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n}\n\nconst _vector$4 = /*@__PURE__*/ new Vector2();\n\nclass Box2 {\n\n\tconstructor( min = new Vector2( + Infinity, + Infinity ), max = new Vector2( - Infinity, - Infinity ) ) {\n\n\t\tthis.isBox2 = true;\n\n\t\tthis.min = min;\n\t\tthis.max = max;\n\n\t}\n\n\tset( min, max ) {\n\n\t\tthis.min.copy( min );\n\t\tthis.max.copy( max );\n\n\t\treturn this;\n\n\t}\n\n\tsetFromPoints( points ) {\n\n\t\tthis.makeEmpty();\n\n\t\tfor ( let i = 0, il = points.length; i < il; i ++ ) {\n\n\t\t\tthis.expandByPoint( points[ i ] );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tsetFromCenterAndSize( center, size ) {\n\n\t\tconst halfSize = _vector$4.copy( size ).multiplyScalar( 0.5 );\n\t\tthis.min.copy( center ).sub( halfSize );\n\t\tthis.max.copy( center ).add( halfSize );\n\n\t\treturn this;\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n\tcopy( box ) {\n\n\t\tthis.min.copy( box.min );\n\t\tthis.max.copy( box.max );\n\n\t\treturn this;\n\n\t}\n\n\tmakeEmpty() {\n\n\t\tthis.min.x = this.min.y = + Infinity;\n\t\tthis.max.x = this.max.y = - Infinity;\n\n\t\treturn this;\n\n\t}\n\n\tisEmpty() {\n\n\t\t// this is a more robust check for empty than ( volume <= 0 ) because volume can get positive with two negative axes\n\n\t\treturn ( this.max.x < this.min.x ) || ( this.max.y < this.min.y );\n\n\t}\n\n\tgetCenter( target ) {\n\n\t\treturn this.isEmpty() ? target.set( 0, 0 ) : target.addVectors( this.min, this.max ).multiplyScalar( 0.5 );\n\n\t}\n\n\tgetSize( target ) {\n\n\t\treturn this.isEmpty() ? target.set( 0, 0 ) : target.subVectors( this.max, this.min );\n\n\t}\n\n\texpandByPoint( point ) {\n\n\t\tthis.min.min( point );\n\t\tthis.max.max( point );\n\n\t\treturn this;\n\n\t}\n\n\texpandByVector( vector ) {\n\n\t\tthis.min.sub( vector );\n\t\tthis.max.add( vector );\n\n\t\treturn this;\n\n\t}\n\n\texpandByScalar( scalar ) {\n\n\t\tthis.min.addScalar( - scalar );\n\t\tthis.max.addScalar( scalar );\n\n\t\treturn this;\n\n\t}\n\n\tcontainsPoint( point ) {\n\n\t\treturn point.x < this.min.x || point.x > this.max.x ||\n\t\t\tpoint.y < this.min.y || point.y > this.max.y ? false : true;\n\n\t}\n\n\tcontainsBox( box ) {\n\n\t\treturn this.min.x <= box.min.x && box.max.x <= this.max.x &&\n\t\t\tthis.min.y <= box.min.y && box.max.y <= this.max.y;\n\n\t}\n\n\tgetParameter( point, target ) {\n\n\t\t// This can potentially have a divide by zero if the box\n\t\t// has a size dimension of 0.\n\n\t\treturn target.set(\n\t\t\t( point.x - this.min.x ) / ( this.max.x - this.min.x ),\n\t\t\t( point.y - this.min.y ) / ( this.max.y - this.min.y )\n\t\t);\n\n\t}\n\n\tintersectsBox( box ) {\n\n\t\t// using 4 splitting planes to rule out intersections\n\n\t\treturn box.max.x < this.min.x || box.min.x > this.max.x ||\n\t\t\tbox.max.y < this.min.y || box.min.y > this.max.y ? false : true;\n\n\t}\n\n\tclampPoint( point, target ) {\n\n\t\treturn target.copy( point ).clamp( this.min, this.max );\n\n\t}\n\n\tdistanceToPoint( point ) {\n\n\t\tconst clampedPoint = _vector$4.copy( point ).clamp( this.min, this.max );\n\t\treturn clampedPoint.sub( point ).length();\n\n\t}\n\n\tintersect( box ) {\n\n\t\tthis.min.max( box.min );\n\t\tthis.max.min( box.max );\n\n\t\treturn this;\n\n\t}\n\n\tunion( box ) {\n\n\t\tthis.min.min( box.min );\n\t\tthis.max.max( box.max );\n\n\t\treturn this;\n\n\t}\n\n\ttranslate( offset ) {\n\n\t\tthis.min.add( offset );\n\t\tthis.max.add( offset );\n\n\t\treturn this;\n\n\t}\n\n\tequals( box ) {\n\n\t\treturn box.min.equals( this.min ) && box.max.equals( this.max );\n\n\t}\n\n}\n\nconst _startP = /*@__PURE__*/ new Vector3();\nconst _startEnd = /*@__PURE__*/ new Vector3();\n\nclass Line3 {\n\n\tconstructor( start = new Vector3(), end = new Vector3() ) {\n\n\t\tthis.start = start;\n\t\tthis.end = end;\n\n\t}\n\n\tset( start, end ) {\n\n\t\tthis.start.copy( start );\n\t\tthis.end.copy( end );\n\n\t\treturn this;\n\n\t}\n\n\tcopy( line ) {\n\n\t\tthis.start.copy( line.start );\n\t\tthis.end.copy( line.end );\n\n\t\treturn this;\n\n\t}\n\n\tgetCenter( target ) {\n\n\t\treturn target.addVectors( this.start, this.end ).multiplyScalar( 0.5 );\n\n\t}\n\n\tdelta( target ) {\n\n\t\treturn target.subVectors( this.end, this.start );\n\n\t}\n\n\tdistanceSq() {\n\n\t\treturn this.start.distanceToSquared( this.end );\n\n\t}\n\n\tdistance() {\n\n\t\treturn this.start.distanceTo( this.end );\n\n\t}\n\n\tat( t, target ) {\n\n\t\treturn this.delta( target ).multiplyScalar( t ).add( this.start );\n\n\t}\n\n\tclosestPointToPointParameter( point, clampToLine ) {\n\n\t\t_startP.subVectors( point, this.start );\n\t\t_startEnd.subVectors( this.end, this.start );\n\n\t\tconst startEnd2 = _startEnd.dot( _startEnd );\n\t\tconst startEnd_startP = _startEnd.dot( _startP );\n\n\t\tlet t = startEnd_startP / startEnd2;\n\n\t\tif ( clampToLine ) {\n\n\t\t\tt = clamp( t, 0, 1 );\n\n\t\t}\n\n\t\treturn t;\n\n\t}\n\n\tclosestPointToPoint( point, clampToLine, target ) {\n\n\t\tconst t = this.closestPointToPointParameter( point, clampToLine );\n\n\t\treturn this.delta( target ).multiplyScalar( t ).add( this.start );\n\n\t}\n\n\tapplyMatrix4( matrix ) {\n\n\t\tthis.start.applyMatrix4( matrix );\n\t\tthis.end.applyMatrix4( matrix );\n\n\t\treturn this;\n\n\t}\n\n\tequals( line ) {\n\n\t\treturn line.start.equals( this.start ) && line.end.equals( this.end );\n\n\t}\n\n\tclone() {\n\n\t\treturn new this.constructor().copy( this );\n\n\t}\n\n}\n\nconst _vector$3 = /*@__PURE__*/ new Vector3();\n\nclass SpotLightHelper extends Object3D {\n\n\tconstructor( light, color ) {\n\n\t\tsuper();\n\t\tthis.light = light;\n\t\tthis.light.updateMatrixWorld();\n\n\t\tthis.matrix = light.matrixWorld;\n\t\tthis.matrixAutoUpdate = false;\n\n\t\tthis.color = color;\n\n\t\tconst geometry = new BufferGeometry();\n\n\t\tconst positions = [\n\t\t\t0, 0, 0, \t0, 0, 1,\n\t\t\t0, 0, 0, \t1, 0, 1,\n\t\t\t0, 0, 0,\t- 1, 0, 1,\n\t\t\t0, 0, 0, \t0, 1, 1,\n\t\t\t0, 0, 0, \t0, - 1, 1\n\t\t];\n\n\t\tfor ( let i = 0, j = 1, l = 32; i < l; i ++, j ++ ) {\n\n\t\t\tconst p1 = ( i / l ) * Math.PI * 2;\n\t\t\tconst p2 = ( j / l ) * Math.PI * 2;\n\n\t\t\tpositions.push(\n\t\t\t\tMath.cos( p1 ), Math.sin( p1 ), 1,\n\t\t\t\tMath.cos( p2 ), Math.sin( p2 ), 1\n\t\t\t);\n\n\t\t}\n\n\t\tgeometry.setAttribute( 'position', new Float32BufferAttribute( positions, 3 ) );\n\n\t\tconst material = new LineBasicMaterial( { fog: false, toneMapped: false } );\n\n\t\tthis.cone = new LineSegments( geometry, material );\n\t\tthis.add( this.cone );\n\n\t\tthis.update();\n\n\t}\n\n\tdispose() {\n\n\t\tthis.cone.geometry.dispose();\n\t\tthis.cone.material.dispose();\n\n\t}\n\n\tupdate() {\n\n\t\tthis.light.updateMatrixWorld();\n\n\t\tconst coneLength = this.light.distance ? this.light.distance : 1000;\n\t\tconst coneWidth = coneLength * Math.tan( this.light.angle );\n\n\t\tthis.cone.scale.set( coneWidth, coneWidth, coneLength );\n\n\t\t_vector$3.setFromMatrixPosition( this.light.target.matrixWorld );\n\n\t\tthis.cone.lookAt( _vector$3 );\n\n\t\tif ( this.color !== undefined ) {\n\n\t\t\tthis.cone.material.color.set( this.color );\n\n\t\t} else {\n\n\t\t\tthis.cone.material.color.copy( this.light.color );\n\n\t\t}\n\n\t}\n\n}\n\nconst _vector$2 = /*@__PURE__*/ new Vector3();\nconst _boneMatrix = /*@__PURE__*/ new Matrix4();\nconst _matrixWorldInv = /*@__PURE__*/ new Matrix4();\n\n\nclass SkeletonHelper extends LineSegments {\n\n\tconstructor( object ) {\n\n\t\tconst bones = getBoneList( object );\n\n\t\tconst geometry = new BufferGeometry();\n\n\t\tconst vertices = [];\n\t\tconst colors = [];\n\n\t\tconst color1 = new Color( 0, 0, 1 );\n\t\tconst color2 = new Color( 0, 1, 0 );\n\n\t\tfor ( let i = 0; i < bones.length; i ++ ) {\n\n\t\t\tconst bone = bones[ i ];\n\n\t\t\tif ( bone.parent && bone.parent.isBone ) {\n\n\t\t\t\tvertices.push( 0, 0, 0 );\n\t\t\t\tvertices.push( 0, 0, 0 );\n\t\t\t\tcolors.push( color1.r, color1.g, color1.b );\n\t\t\t\tcolors.push( color2.r, color2.g, color2.b );\n\n\t\t\t}\n\n\t\t}\n\n\t\tgeometry.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tgeometry.setAttribute( 'color', new Float32BufferAttribute( colors, 3 ) );\n\n\t\tconst material = new LineBasicMaterial( { vertexColors: true, depthTest: false, depthWrite: false, toneMapped: false, transparent: true } );\n\n\t\tsuper( geometry, material );\n\n\t\tthis.isSkeletonHelper = true;\n\n\t\tthis.type = 'SkeletonHelper';\n\n\t\tthis.root = object;\n\t\tthis.bones = bones;\n\n\t\tthis.matrix = object.matrixWorld;\n\t\tthis.matrixAutoUpdate = false;\n\n\t}\n\n\tupdateMatrixWorld( force ) {\n\n\t\tconst bones = this.bones;\n\n\t\tconst geometry = this.geometry;\n\t\tconst position = geometry.getAttribute( 'position' );\n\n\t\t_matrixWorldInv.copy( this.root.matrixWorld ).invert();\n\n\t\tfor ( let i = 0, j = 0; i < bones.length; i ++ ) {\n\n\t\t\tconst bone = bones[ i ];\n\n\t\t\tif ( bone.parent && bone.parent.isBone ) {\n\n\t\t\t\t_boneMatrix.multiplyMatrices( _matrixWorldInv, bone.matrixWorld );\n\t\t\t\t_vector$2.setFromMatrixPosition( _boneMatrix );\n\t\t\t\tposition.setXYZ( j, _vector$2.x, _vector$2.y, _vector$2.z );\n\n\t\t\t\t_boneMatrix.multiplyMatrices( _matrixWorldInv, bone.parent.matrixWorld );\n\t\t\t\t_vector$2.setFromMatrixPosition( _boneMatrix );\n\t\t\t\tposition.setXYZ( j + 1, _vector$2.x, _vector$2.y, _vector$2.z );\n\n\t\t\t\tj += 2;\n\n\t\t\t}\n\n\t\t}\n\n\t\tgeometry.getAttribute( 'position' ).needsUpdate = true;\n\n\t\tsuper.updateMatrixWorld( force );\n\n\t}\n\n}\n\n\nfunction getBoneList( object ) {\n\n\tconst boneList = [];\n\n\tif ( object.isBone === true ) {\n\n\t\tboneList.push( object );\n\n\t}\n\n\tfor ( let i = 0; i < object.children.length; i ++ ) {\n\n\t\tboneList.push.apply( boneList, getBoneList( object.children[ i ] ) );\n\n\t}\n\n\treturn boneList;\n\n}\n\nclass PointLightHelper extends Mesh {\n\n\tconstructor( light, sphereSize, color ) {\n\n\t\tconst geometry = new SphereGeometry( sphereSize, 4, 2 );\n\t\tconst material = new MeshBasicMaterial( { wireframe: true, fog: false, toneMapped: false } );\n\n\t\tsuper( geometry, material );\n\n\t\tthis.light = light;\n\t\tthis.light.updateMatrixWorld();\n\n\t\tthis.color = color;\n\n\t\tthis.type = 'PointLightHelper';\n\n\t\tthis.matrix = this.light.matrixWorld;\n\t\tthis.matrixAutoUpdate = false;\n\n\t\tthis.update();\n\n\n\t\t/*\n\t// TODO: delete this comment?\n\tconst distanceGeometry = new THREE.IcosahedronGeometry( 1, 2 );\n\tconst distanceMaterial = new THREE.MeshBasicMaterial( { color: hexColor, fog: false, wireframe: true, opacity: 0.1, transparent: true } );\n\n\tthis.lightSphere = new THREE.Mesh( bulbGeometry, bulbMaterial );\n\tthis.lightDistance = new THREE.Mesh( distanceGeometry, distanceMaterial );\n\n\tconst d = light.distance;\n\n\tif ( d === 0.0 ) {\n\n\t\tthis.lightDistance.visible = false;\n\n\t} else {\n\n\t\tthis.lightDistance.scale.set( d, d, d );\n\n\t}\n\n\tthis.add( this.lightDistance );\n\t*/\n\n\t}\n\n\tdispose() {\n\n\t\tthis.geometry.dispose();\n\t\tthis.material.dispose();\n\n\t}\n\n\tupdate() {\n\n\t\tif ( this.color !== undefined ) {\n\n\t\t\tthis.material.color.set( this.color );\n\n\t\t} else {\n\n\t\t\tthis.material.color.copy( this.light.color );\n\n\t\t}\n\n\t\t/*\n\t\tconst d = this.light.distance;\n\n\t\tif ( d === 0.0 ) {\n\n\t\t\tthis.lightDistance.visible = false;\n\n\t\t} else {\n\n\t\t\tthis.lightDistance.visible = true;\n\t\t\tthis.lightDistance.scale.set( d, d, d );\n\n\t\t}\n\t\t*/\n\n\t}\n\n}\n\nconst _vector$1 = /*@__PURE__*/ new Vector3();\nconst _color1 = /*@__PURE__*/ new Color();\nconst _color2 = /*@__PURE__*/ new Color();\n\nclass HemisphereLightHelper extends Object3D {\n\n\tconstructor( light, size, color ) {\n\n\t\tsuper();\n\t\tthis.light = light;\n\t\tthis.light.updateMatrixWorld();\n\n\t\tthis.matrix = light.matrixWorld;\n\t\tthis.matrixAutoUpdate = false;\n\n\t\tthis.color = color;\n\n\t\tconst geometry = new OctahedronGeometry( size );\n\t\tgeometry.rotateY( Math.PI * 0.5 );\n\n\t\tthis.material = new MeshBasicMaterial( { wireframe: true, fog: false, toneMapped: false } );\n\t\tif ( this.color === undefined ) this.material.vertexColors = true;\n\n\t\tconst position = geometry.getAttribute( 'position' );\n\t\tconst colors = new Float32Array( position.count * 3 );\n\n\t\tgeometry.setAttribute( 'color', new BufferAttribute( colors, 3 ) );\n\n\t\tthis.add( new Mesh( geometry, this.material ) );\n\n\t\tthis.update();\n\n\t}\n\n\tdispose() {\n\n\t\tthis.children[ 0 ].geometry.dispose();\n\t\tthis.children[ 0 ].material.dispose();\n\n\t}\n\n\tupdate() {\n\n\t\tconst mesh = this.children[ 0 ];\n\n\t\tif ( this.color !== undefined ) {\n\n\t\t\tthis.material.color.set( this.color );\n\n\t\t} else {\n\n\t\t\tconst colors = mesh.geometry.getAttribute( 'color' );\n\n\t\t\t_color1.copy( this.light.color );\n\t\t\t_color2.copy( this.light.groundColor );\n\n\t\t\tfor ( let i = 0, l = colors.count; i < l; i ++ ) {\n\n\t\t\t\tconst color = ( i < ( l / 2 ) ) ? _color1 : _color2;\n\n\t\t\t\tcolors.setXYZ( i, color.r, color.g, color.b );\n\n\t\t\t}\n\n\t\t\tcolors.needsUpdate = true;\n\n\t\t}\n\n\t\tmesh.lookAt( _vector$1.setFromMatrixPosition( this.light.matrixWorld ).negate() );\n\n\t}\n\n}\n\nclass GridHelper extends LineSegments {\n\n\tconstructor( size = 10, divisions = 10, color1 = 0x444444, color2 = 0x888888 ) {\n\n\t\tcolor1 = new Color( color1 );\n\t\tcolor2 = new Color( color2 );\n\n\t\tconst center = divisions / 2;\n\t\tconst step = size / divisions;\n\t\tconst halfSize = size / 2;\n\n\t\tconst vertices = [], colors = [];\n\n\t\tfor ( let i = 0, j = 0, k = - halfSize; i <= divisions; i ++, k += step ) {\n\n\t\t\tvertices.push( - halfSize, 0, k, halfSize, 0, k );\n\t\t\tvertices.push( k, 0, - halfSize, k, 0, halfSize );\n\n\t\t\tconst color = i === center ? color1 : color2;\n\n\t\t\tcolor.toArray( colors, j ); j += 3;\n\t\t\tcolor.toArray( colors, j ); j += 3;\n\t\t\tcolor.toArray( colors, j ); j += 3;\n\t\t\tcolor.toArray( colors, j ); j += 3;\n\n\t\t}\n\n\t\tconst geometry = new BufferGeometry();\n\t\tgeometry.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tgeometry.setAttribute( 'color', new Float32BufferAttribute( colors, 3 ) );\n\n\t\tconst material = new LineBasicMaterial( { vertexColors: true, toneMapped: false } );\n\n\t\tsuper( geometry, material );\n\n\t\tthis.type = 'GridHelper';\n\n\t}\n\n}\n\nclass PolarGridHelper extends LineSegments {\n\n\tconstructor( radius = 10, radials = 16, circles = 8, divisions = 64, color1 = 0x444444, color2 = 0x888888 ) {\n\n\t\tcolor1 = new Color( color1 );\n\t\tcolor2 = new Color( color2 );\n\n\t\tconst vertices = [];\n\t\tconst colors = [];\n\n\t\t// create the radials\n\n\t\tfor ( let i = 0; i <= radials; i ++ ) {\n\n\t\t\tconst v = ( i / radials ) * ( Math.PI * 2 );\n\n\t\t\tconst x = Math.sin( v ) * radius;\n\t\t\tconst z = Math.cos( v ) * radius;\n\n\t\t\tvertices.push( 0, 0, 0 );\n\t\t\tvertices.push( x, 0, z );\n\n\t\t\tconst color = ( i & 1 ) ? color1 : color2;\n\n\t\t\tcolors.push( color.r, color.g, color.b );\n\t\t\tcolors.push( color.r, color.g, color.b );\n\n\t\t}\n\n\t\t// create the circles\n\n\t\tfor ( let i = 0; i <= circles; i ++ ) {\n\n\t\t\tconst color = ( i & 1 ) ? color1 : color2;\n\n\t\t\tconst r = radius - ( radius / circles * i );\n\n\t\t\tfor ( let j = 0; j < divisions; j ++ ) {\n\n\t\t\t\t// first vertex\n\n\t\t\t\tlet v = ( j / divisions ) * ( Math.PI * 2 );\n\n\t\t\t\tlet x = Math.sin( v ) * r;\n\t\t\t\tlet z = Math.cos( v ) * r;\n\n\t\t\t\tvertices.push( x, 0, z );\n\t\t\t\tcolors.push( color.r, color.g, color.b );\n\n\t\t\t\t// second vertex\n\n\t\t\t\tv = ( ( j + 1 ) / divisions ) * ( Math.PI * 2 );\n\n\t\t\t\tx = Math.sin( v ) * r;\n\t\t\t\tz = Math.cos( v ) * r;\n\n\t\t\t\tvertices.push( x, 0, z );\n\t\t\t\tcolors.push( color.r, color.g, color.b );\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst geometry = new BufferGeometry();\n\t\tgeometry.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tgeometry.setAttribute( 'color', new Float32BufferAttribute( colors, 3 ) );\n\n\t\tconst material = new LineBasicMaterial( { vertexColors: true, toneMapped: false } );\n\n\t\tsuper( geometry, material );\n\n\t\tthis.type = 'PolarGridHelper';\n\n\t}\n\n}\n\nconst _v1 = /*@__PURE__*/ new Vector3();\nconst _v2 = /*@__PURE__*/ new Vector3();\nconst _v3 = /*@__PURE__*/ new Vector3();\n\nclass DirectionalLightHelper extends Object3D {\n\n\tconstructor( light, size, color ) {\n\n\t\tsuper();\n\t\tthis.light = light;\n\t\tthis.light.updateMatrixWorld();\n\n\t\tthis.matrix = light.matrixWorld;\n\t\tthis.matrixAutoUpdate = false;\n\n\t\tthis.color = color;\n\n\t\tif ( size === undefined ) size = 1;\n\n\t\tlet geometry = new BufferGeometry();\n\t\tgeometry.setAttribute( 'position', new Float32BufferAttribute( [\n\t\t\t- size, size, 0,\n\t\t\tsize, size, 0,\n\t\t\tsize, - size, 0,\n\t\t\t- size, - size, 0,\n\t\t\t- size, size, 0\n\t\t], 3 ) );\n\n\t\tconst material = new LineBasicMaterial( { fog: false, toneMapped: false } );\n\n\t\tthis.lightPlane = new Line( geometry, material );\n\t\tthis.add( this.lightPlane );\n\n\t\tgeometry = new BufferGeometry();\n\t\tgeometry.setAttribute( 'position', new Float32BufferAttribute( [ 0, 0, 0, 0, 0, 1 ], 3 ) );\n\n\t\tthis.targetLine = new Line( geometry, material );\n\t\tthis.add( this.targetLine );\n\n\t\tthis.update();\n\n\t}\n\n\tdispose() {\n\n\t\tthis.lightPlane.geometry.dispose();\n\t\tthis.lightPlane.material.dispose();\n\t\tthis.targetLine.geometry.dispose();\n\t\tthis.targetLine.material.dispose();\n\n\t}\n\n\tupdate() {\n\n\t\t_v1.setFromMatrixPosition( this.light.matrixWorld );\n\t\t_v2.setFromMatrixPosition( this.light.target.matrixWorld );\n\t\t_v3.subVectors( _v2, _v1 );\n\n\t\tthis.lightPlane.lookAt( _v2 );\n\n\t\tif ( this.color !== undefined ) {\n\n\t\t\tthis.lightPlane.material.color.set( this.color );\n\t\t\tthis.targetLine.material.color.set( this.color );\n\n\t\t} else {\n\n\t\t\tthis.lightPlane.material.color.copy( this.light.color );\n\t\t\tthis.targetLine.material.color.copy( this.light.color );\n\n\t\t}\n\n\t\tthis.targetLine.lookAt( _v2 );\n\t\tthis.targetLine.scale.z = _v3.length();\n\n\t}\n\n}\n\nconst _vector = /*@__PURE__*/ new Vector3();\nconst _camera = /*@__PURE__*/ new Camera();\n\n/**\n *\t- shows frustum, line of sight and up of the camera\n *\t- suitable for fast updates\n * \t- based on frustum visualization in lightgl.js shadowmap example\n *\t\thttps://github.com/evanw/lightgl.js/blob/master/tests/shadowmap.html\n */\n\nclass CameraHelper extends LineSegments {\n\n\tconstructor( camera ) {\n\n\t\tconst geometry = new BufferGeometry();\n\t\tconst material = new LineBasicMaterial( { color: 0xffffff, vertexColors: true, toneMapped: false } );\n\n\t\tconst vertices = [];\n\t\tconst colors = [];\n\n\t\tconst pointMap = {};\n\n\t\t// colors\n\n\t\tconst colorFrustum = new Color( 0xffaa00 );\n\t\tconst colorCone = new Color( 0xff0000 );\n\t\tconst colorUp = new Color( 0x00aaff );\n\t\tconst colorTarget = new Color( 0xffffff );\n\t\tconst colorCross = new Color( 0x333333 );\n\n\t\t// near\n\n\t\taddLine( 'n1', 'n2', colorFrustum );\n\t\taddLine( 'n2', 'n4', colorFrustum );\n\t\taddLine( 'n4', 'n3', colorFrustum );\n\t\taddLine( 'n3', 'n1', colorFrustum );\n\n\t\t// far\n\n\t\taddLine( 'f1', 'f2', colorFrustum );\n\t\taddLine( 'f2', 'f4', colorFrustum );\n\t\taddLine( 'f4', 'f3', colorFrustum );\n\t\taddLine( 'f3', 'f1', colorFrustum );\n\n\t\t// sides\n\n\t\taddLine( 'n1', 'f1', colorFrustum );\n\t\taddLine( 'n2', 'f2', colorFrustum );\n\t\taddLine( 'n3', 'f3', colorFrustum );\n\t\taddLine( 'n4', 'f4', colorFrustum );\n\n\t\t// cone\n\n\t\taddLine( 'p', 'n1', colorCone );\n\t\taddLine( 'p', 'n2', colorCone );\n\t\taddLine( 'p', 'n3', colorCone );\n\t\taddLine( 'p', 'n4', colorCone );\n\n\t\t// up\n\n\t\taddLine( 'u1', 'u2', colorUp );\n\t\taddLine( 'u2', 'u3', colorUp );\n\t\taddLine( 'u3', 'u1', colorUp );\n\n\t\t// target\n\n\t\taddLine( 'c', 't', colorTarget );\n\t\taddLine( 'p', 'c', colorCross );\n\n\t\t// cross\n\n\t\taddLine( 'cn1', 'cn2', colorCross );\n\t\taddLine( 'cn3', 'cn4', colorCross );\n\n\t\taddLine( 'cf1', 'cf2', colorCross );\n\t\taddLine( 'cf3', 'cf4', colorCross );\n\n\t\tfunction addLine( a, b, color ) {\n\n\t\t\taddPoint( a, color );\n\t\t\taddPoint( b, color );\n\n\t\t}\n\n\t\tfunction addPoint( id, color ) {\n\n\t\t\tvertices.push( 0, 0, 0 );\n\t\t\tcolors.push( color.r, color.g, color.b );\n\n\t\t\tif ( pointMap[ id ] === undefined ) {\n\n\t\t\t\tpointMap[ id ] = [];\n\n\t\t\t}\n\n\t\t\tpointMap[ id ].push( ( vertices.length / 3 ) - 1 );\n\n\t\t}\n\n\t\tgeometry.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tgeometry.setAttribute( 'color', new Float32BufferAttribute( colors, 3 ) );\n\n\t\tsuper( geometry, material );\n\n\t\tthis.type = 'CameraHelper';\n\n\t\tthis.camera = camera;\n\t\tif ( this.camera.updateProjectionMatrix ) this.camera.updateProjectionMatrix();\n\n\t\tthis.matrix = camera.matrixWorld;\n\t\tthis.matrixAutoUpdate = false;\n\n\t\tthis.pointMap = pointMap;\n\n\t\tthis.update();\n\n\t}\n\n\tupdate() {\n\n\t\tconst geometry = this.geometry;\n\t\tconst pointMap = this.pointMap;\n\n\t\tconst w = 1, h = 1;\n\n\t\t// we need just camera projection matrix inverse\n\t\t// world matrix must be identity\n\n\t\t_camera.projectionMatrixInverse.copy( this.camera.projectionMatrixInverse );\n\n\t\t// center / target\n\n\t\tsetPoint( 'c', pointMap, geometry, _camera, 0, 0, - 1 );\n\t\tsetPoint( 't', pointMap, geometry, _camera, 0, 0, 1 );\n\n\t\t// near\n\n\t\tsetPoint( 'n1', pointMap, geometry, _camera, - w, - h, - 1 );\n\t\tsetPoint( 'n2', pointMap, geometry, _camera, w, - h, - 1 );\n\t\tsetPoint( 'n3', pointMap, geometry, _camera, - w, h, - 1 );\n\t\tsetPoint( 'n4', pointMap, geometry, _camera, w, h, - 1 );\n\n\t\t// far\n\n\t\tsetPoint( 'f1', pointMap, geometry, _camera, - w, - h, 1 );\n\t\tsetPoint( 'f2', pointMap, geometry, _camera, w, - h, 1 );\n\t\tsetPoint( 'f3', pointMap, geometry, _camera, - w, h, 1 );\n\t\tsetPoint( 'f4', pointMap, geometry, _camera, w, h, 1 );\n\n\t\t// up\n\n\t\tsetPoint( 'u1', pointMap, geometry, _camera, w * 0.7, h * 1.1, - 1 );\n\t\tsetPoint( 'u2', pointMap, geometry, _camera, - w * 0.7, h * 1.1, - 1 );\n\t\tsetPoint( 'u3', pointMap, geometry, _camera, 0, h * 2, - 1 );\n\n\t\t// cross\n\n\t\tsetPoint( 'cf1', pointMap, geometry, _camera, - w, 0, 1 );\n\t\tsetPoint( 'cf2', pointMap, geometry, _camera, w, 0, 1 );\n\t\tsetPoint( 'cf3', pointMap, geometry, _camera, 0, - h, 1 );\n\t\tsetPoint( 'cf4', pointMap, geometry, _camera, 0, h, 1 );\n\n\t\tsetPoint( 'cn1', pointMap, geometry, _camera, - w, 0, - 1 );\n\t\tsetPoint( 'cn2', pointMap, geometry, _camera, w, 0, - 1 );\n\t\tsetPoint( 'cn3', pointMap, geometry, _camera, 0, - h, - 1 );\n\t\tsetPoint( 'cn4', pointMap, geometry, _camera, 0, h, - 1 );\n\n\t\tgeometry.getAttribute( 'position' ).needsUpdate = true;\n\n\t}\n\n\tdispose() {\n\n\t\tthis.geometry.dispose();\n\t\tthis.material.dispose();\n\n\t}\n\n}\n\n\nfunction setPoint( point, pointMap, geometry, camera, x, y, z ) {\n\n\t_vector.set( x, y, z ).unproject( camera );\n\n\tconst points = pointMap[ point ];\n\n\tif ( points !== undefined ) {\n\n\t\tconst position = geometry.getAttribute( 'position' );\n\n\t\tfor ( let i = 0, l = points.length; i < l; i ++ ) {\n\n\t\t\tposition.setXYZ( points[ i ], _vector.x, _vector.y, _vector.z );\n\n\t\t}\n\n\t}\n\n}\n\nconst _box = /*@__PURE__*/ new Box3();\n\nclass BoxHelper extends LineSegments {\n\n\tconstructor( object, color = 0xffff00 ) {\n\n\t\tconst indices = new Uint16Array( [ 0, 1, 1, 2, 2, 3, 3, 0, 4, 5, 5, 6, 6, 7, 7, 4, 0, 4, 1, 5, 2, 6, 3, 7 ] );\n\t\tconst positions = new Float32Array( 8 * 3 );\n\n\t\tconst geometry = new BufferGeometry();\n\t\tgeometry.setIndex( new BufferAttribute( indices, 1 ) );\n\t\tgeometry.setAttribute( 'position', new BufferAttribute( positions, 3 ) );\n\n\t\tsuper( geometry, new LineBasicMaterial( { color: color, toneMapped: false } ) );\n\n\t\tthis.object = object;\n\t\tthis.type = 'BoxHelper';\n\n\t\tthis.matrixAutoUpdate = false;\n\n\t\tthis.update();\n\n\t}\n\n\tupdate( object ) {\n\n\t\tif ( object !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.BoxHelper: .update() has no longer arguments.' );\n\n\t\t}\n\n\t\tif ( this.object !== undefined ) {\n\n\t\t\t_box.setFromObject( this.object );\n\n\t\t}\n\n\t\tif ( _box.isEmpty() ) return;\n\n\t\tconst min = _box.min;\n\t\tconst max = _box.max;\n\n\t\t/*\n\t\t\t5____4\n\t\t1/___0/|\n\t\t| 6__|_7\n\t\t2/___3/\n\n\t\t0: max.x, max.y, max.z\n\t\t1: min.x, max.y, max.z\n\t\t2: min.x, min.y, max.z\n\t\t3: max.x, min.y, max.z\n\t\t4: max.x, max.y, min.z\n\t\t5: min.x, max.y, min.z\n\t\t6: min.x, min.y, min.z\n\t\t7: max.x, min.y, min.z\n\t\t*/\n\n\t\tconst position = this.geometry.attributes.position;\n\t\tconst array = position.array;\n\n\t\tarray[ 0 ] = max.x; array[ 1 ] = max.y; array[ 2 ] = max.z;\n\t\tarray[ 3 ] = min.x; array[ 4 ] = max.y; array[ 5 ] = max.z;\n\t\tarray[ 6 ] = min.x; array[ 7 ] = min.y; array[ 8 ] = max.z;\n\t\tarray[ 9 ] = max.x; array[ 10 ] = min.y; array[ 11 ] = max.z;\n\t\tarray[ 12 ] = max.x; array[ 13 ] = max.y; array[ 14 ] = min.z;\n\t\tarray[ 15 ] = min.x; array[ 16 ] = max.y; array[ 17 ] = min.z;\n\t\tarray[ 18 ] = min.x; array[ 19 ] = min.y; array[ 20 ] = min.z;\n\t\tarray[ 21 ] = max.x; array[ 22 ] = min.y; array[ 23 ] = min.z;\n\n\t\tposition.needsUpdate = true;\n\n\t\tthis.geometry.computeBoundingSphere();\n\n\n\t}\n\n\tsetFromObject( object ) {\n\n\t\tthis.object = object;\n\t\tthis.update();\n\n\t\treturn this;\n\n\t}\n\n\tcopy( source, recursive ) {\n\n\t\tsuper.copy( source, recursive );\n\n\t\tthis.object = source.object;\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass Box3Helper extends LineSegments {\n\n\tconstructor( box, color = 0xffff00 ) {\n\n\t\tconst indices = new Uint16Array( [ 0, 1, 1, 2, 2, 3, 3, 0, 4, 5, 5, 6, 6, 7, 7, 4, 0, 4, 1, 5, 2, 6, 3, 7 ] );\n\n\t\tconst positions = [ 1, 1, 1, - 1, 1, 1, - 1, - 1, 1, 1, - 1, 1, 1, 1, - 1, - 1, 1, - 1, - 1, - 1, - 1, 1, - 1, - 1 ];\n\n\t\tconst geometry = new BufferGeometry();\n\n\t\tgeometry.setIndex( new BufferAttribute( indices, 1 ) );\n\n\t\tgeometry.setAttribute( 'position', new Float32BufferAttribute( positions, 3 ) );\n\n\t\tsuper( geometry, new LineBasicMaterial( { color: color, toneMapped: false } ) );\n\n\t\tthis.box = box;\n\n\t\tthis.type = 'Box3Helper';\n\n\t\tthis.geometry.computeBoundingSphere();\n\n\t}\n\n\tupdateMatrixWorld( force ) {\n\n\t\tconst box = this.box;\n\n\t\tif ( box.isEmpty() ) return;\n\n\t\tbox.getCenter( this.position );\n\n\t\tbox.getSize( this.scale );\n\n\t\tthis.scale.multiplyScalar( 0.5 );\n\n\t\tsuper.updateMatrixWorld( force );\n\n\t}\n\n}\n\nclass PlaneHelper extends Line {\n\n\tconstructor( plane, size = 1, hex = 0xffff00 ) {\n\n\t\tconst color = hex;\n\n\t\tconst positions = [ 1, - 1, 1, - 1, 1, 1, - 1, - 1, 1, 1, 1, 1, - 1, 1, 1, - 1, - 1, 1, 1, - 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0 ];\n\n\t\tconst geometry = new BufferGeometry();\n\t\tgeometry.setAttribute( 'position', new Float32BufferAttribute( positions, 3 ) );\n\t\tgeometry.computeBoundingSphere();\n\n\t\tsuper( geometry, new LineBasicMaterial( { color: color, toneMapped: false } ) );\n\n\t\tthis.type = 'PlaneHelper';\n\n\t\tthis.plane = plane;\n\n\t\tthis.size = size;\n\n\t\tconst positions2 = [ 1, 1, 1, - 1, 1, 1, - 1, - 1, 1, 1, 1, 1, - 1, - 1, 1, 1, - 1, 1 ];\n\n\t\tconst geometry2 = new BufferGeometry();\n\t\tgeometry2.setAttribute( 'position', new Float32BufferAttribute( positions2, 3 ) );\n\t\tgeometry2.computeBoundingSphere();\n\n\t\tthis.add( new Mesh( geometry2, new MeshBasicMaterial( { color: color, opacity: 0.2, transparent: true, depthWrite: false, toneMapped: false } ) ) );\n\n\t}\n\n\tupdateMatrixWorld( force ) {\n\n\t\tlet scale = - this.plane.constant;\n\n\t\tif ( Math.abs( scale ) < 1e-8 ) scale = 1e-8; // sign does not matter\n\n\t\tthis.scale.set( 0.5 * this.size, 0.5 * this.size, scale );\n\n\t\tthis.children[ 0 ].material.side = ( scale < 0 ) ? BackSide : FrontSide; // renderer flips side when determinant < 0; flipping not wanted here\n\n\t\tthis.lookAt( this.plane.normal );\n\n\t\tsuper.updateMatrixWorld( force );\n\n\t}\n\n}\n\nconst _axis = /*@__PURE__*/ new Vector3();\nlet _lineGeometry, _coneGeometry;\n\nclass ArrowHelper extends Object3D {\n\n\t// dir is assumed to be normalized\n\n\tconstructor( dir = new Vector3( 0, 0, 1 ), origin = new Vector3( 0, 0, 0 ), length = 1, color = 0xffff00, headLength = length * 0.2, headWidth = headLength * 0.2 ) {\n\n\t\tsuper();\n\n\t\tthis.type = 'ArrowHelper';\n\n\t\tif ( _lineGeometry === undefined ) {\n\n\t\t\t_lineGeometry = new BufferGeometry();\n\t\t\t_lineGeometry.setAttribute( 'position', new Float32BufferAttribute( [ 0, 0, 0, 0, 1, 0 ], 3 ) );\n\n\t\t\t_coneGeometry = new CylinderGeometry( 0, 0.5, 1, 5, 1 );\n\t\t\t_coneGeometry.translate( 0, - 0.5, 0 );\n\n\t\t}\n\n\t\tthis.position.copy( origin );\n\n\t\tthis.line = new Line( _lineGeometry, new LineBasicMaterial( { color: color, toneMapped: false } ) );\n\t\tthis.line.matrixAutoUpdate = false;\n\t\tthis.add( this.line );\n\n\t\tthis.cone = new Mesh( _coneGeometry, new MeshBasicMaterial( { color: color, toneMapped: false } ) );\n\t\tthis.cone.matrixAutoUpdate = false;\n\t\tthis.add( this.cone );\n\n\t\tthis.setDirection( dir );\n\t\tthis.setLength( length, headLength, headWidth );\n\n\t}\n\n\tsetDirection( dir ) {\n\n\t\t// dir is assumed to be normalized\n\n\t\tif ( dir.y > 0.99999 ) {\n\n\t\t\tthis.quaternion.set( 0, 0, 0, 1 );\n\n\t\t} else if ( dir.y < - 0.99999 ) {\n\n\t\t\tthis.quaternion.set( 1, 0, 0, 0 );\n\n\t\t} else {\n\n\t\t\t_axis.set( dir.z, 0, - dir.x ).normalize();\n\n\t\t\tconst radians = Math.acos( dir.y );\n\n\t\t\tthis.quaternion.setFromAxisAngle( _axis, radians );\n\n\t\t}\n\n\t}\n\n\tsetLength( length, headLength = length * 0.2, headWidth = headLength * 0.2 ) {\n\n\t\tthis.line.scale.set( 1, Math.max( 0.0001, length - headLength ), 1 ); // see #17458\n\t\tthis.line.updateMatrix();\n\n\t\tthis.cone.scale.set( headWidth, headLength, headWidth );\n\t\tthis.cone.position.y = length;\n\t\tthis.cone.updateMatrix();\n\n\t}\n\n\tsetColor( color ) {\n\n\t\tthis.line.material.color.set( color );\n\t\tthis.cone.material.color.set( color );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source, false );\n\n\t\tthis.line.copy( source.line );\n\t\tthis.cone.copy( source.cone );\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass AxesHelper extends LineSegments {\n\n\tconstructor( size = 1 ) {\n\n\t\tconst vertices = [\n\t\t\t0, 0, 0,\tsize, 0, 0,\n\t\t\t0, 0, 0,\t0, size, 0,\n\t\t\t0, 0, 0,\t0, 0, size\n\t\t];\n\n\t\tconst colors = [\n\t\t\t1, 0, 0,\t1, 0.6, 0,\n\t\t\t0, 1, 0,\t0.6, 1, 0,\n\t\t\t0, 0, 1,\t0, 0.6, 1\n\t\t];\n\n\t\tconst geometry = new BufferGeometry();\n\t\tgeometry.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );\n\t\tgeometry.setAttribute( 'color', new Float32BufferAttribute( colors, 3 ) );\n\n\t\tconst material = new LineBasicMaterial( { vertexColors: true, toneMapped: false } );\n\n\t\tsuper( geometry, material );\n\n\t\tthis.type = 'AxesHelper';\n\n\t}\n\n\tsetColors( xAxisColor, yAxisColor, zAxisColor ) {\n\n\t\tconst color = new Color();\n\t\tconst array = this.geometry.attributes.color.array;\n\n\t\tcolor.set( xAxisColor );\n\t\tcolor.toArray( array, 0 );\n\t\tcolor.toArray( array, 3 );\n\n\t\tcolor.set( yAxisColor );\n\t\tcolor.toArray( array, 6 );\n\t\tcolor.toArray( array, 9 );\n\n\t\tcolor.set( zAxisColor );\n\t\tcolor.toArray( array, 12 );\n\t\tcolor.toArray( array, 15 );\n\n\t\tthis.geometry.attributes.color.needsUpdate = true;\n\n\t\treturn this;\n\n\t}\n\n\tdispose() {\n\n\t\tthis.geometry.dispose();\n\t\tthis.material.dispose();\n\n\t}\n\n}\n\nclass ShapePath {\n\n\tconstructor() {\n\n\t\tthis.type = 'ShapePath';\n\n\t\tthis.color = new Color();\n\n\t\tthis.subPaths = [];\n\t\tthis.currentPath = null;\n\n\t}\n\n\tmoveTo( x, y ) {\n\n\t\tthis.currentPath = new Path();\n\t\tthis.subPaths.push( this.currentPath );\n\t\tthis.currentPath.moveTo( x, y );\n\n\t\treturn this;\n\n\t}\n\n\tlineTo( x, y ) {\n\n\t\tthis.currentPath.lineTo( x, y );\n\n\t\treturn this;\n\n\t}\n\n\tquadraticCurveTo( aCPx, aCPy, aX, aY ) {\n\n\t\tthis.currentPath.quadraticCurveTo( aCPx, aCPy, aX, aY );\n\n\t\treturn this;\n\n\t}\n\n\tbezierCurveTo( aCP1x, aCP1y, aCP2x, aCP2y, aX, aY ) {\n\n\t\tthis.currentPath.bezierCurveTo( aCP1x, aCP1y, aCP2x, aCP2y, aX, aY );\n\n\t\treturn this;\n\n\t}\n\n\tsplineThru( pts ) {\n\n\t\tthis.currentPath.splineThru( pts );\n\n\t\treturn this;\n\n\t}\n\n\ttoShapes( isCCW, noHoles ) {\n\n\t\tfunction toShapesNoHoles( inSubpaths ) {\n\n\t\t\tconst shapes = [];\n\n\t\t\tfor ( let i = 0, l = inSubpaths.length; i < l; i ++ ) {\n\n\t\t\t\tconst tmpPath = inSubpaths[ i ];\n\n\t\t\t\tconst tmpShape = new Shape();\n\t\t\t\ttmpShape.curves = tmpPath.curves;\n\n\t\t\t\tshapes.push( tmpShape );\n\n\t\t\t}\n\n\t\t\treturn shapes;\n\n\t\t}\n\n\t\tfunction isPointInsidePolygon( inPt, inPolygon ) {\n\n\t\t\tconst polyLen = inPolygon.length;\n\n\t\t\t// inPt on polygon contour => immediate success or\n\t\t\t// toggling of inside/outside at every single! intersection point of an edge\n\t\t\t// with the horizontal line through inPt, left of inPt\n\t\t\t// not counting lowerY endpoints of edges and whole edges on that line\n\t\t\tlet inside = false;\n\t\t\tfor ( let p = polyLen - 1, q = 0; q < polyLen; p = q ++ ) {\n\n\t\t\t\tlet edgeLowPt = inPolygon[ p ];\n\t\t\t\tlet edgeHighPt = inPolygon[ q ];\n\n\t\t\t\tlet edgeDx = edgeHighPt.x - edgeLowPt.x;\n\t\t\t\tlet edgeDy = edgeHighPt.y - edgeLowPt.y;\n\n\t\t\t\tif ( Math.abs( edgeDy ) > Number.EPSILON ) {\n\n\t\t\t\t\t// not parallel\n\t\t\t\t\tif ( edgeDy < 0 ) {\n\n\t\t\t\t\t\tedgeLowPt = inPolygon[ q ]; edgeDx = - edgeDx;\n\t\t\t\t\t\tedgeHighPt = inPolygon[ p ]; edgeDy = - edgeDy;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( ( inPt.y < edgeLowPt.y ) || ( inPt.y > edgeHighPt.y ) ) \t\tcontinue;\n\n\t\t\t\t\tif ( inPt.y === edgeLowPt.y ) {\n\n\t\t\t\t\t\tif ( inPt.x === edgeLowPt.x )\t\treturn\ttrue;\t\t// inPt is on contour ?\n\t\t\t\t\t\t// continue;\t\t\t\t// no intersection or edgeLowPt => doesn't count !!!\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tconst perpEdge = edgeDy * ( inPt.x - edgeLowPt.x ) - edgeDx * ( inPt.y - edgeLowPt.y );\n\t\t\t\t\t\tif ( perpEdge === 0 )\t\t\t\treturn\ttrue;\t\t// inPt is on contour ?\n\t\t\t\t\t\tif ( perpEdge < 0 ) \t\t\t\tcontinue;\n\t\t\t\t\t\tinside = ! inside;\t\t// true intersection left of inPt\n\n\t\t\t\t\t}\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// parallel or collinear\n\t\t\t\t\tif ( inPt.y !== edgeLowPt.y ) \t\tcontinue;\t\t\t// parallel\n\t\t\t\t\t// edge lies on the same horizontal line as inPt\n\t\t\t\t\tif ( ( ( edgeHighPt.x <= inPt.x ) && ( inPt.x <= edgeLowPt.x ) ) ||\n\t\t\t\t\t\t ( ( edgeLowPt.x <= inPt.x ) && ( inPt.x <= edgeHighPt.x ) ) )\t\treturn\ttrue;\t// inPt: Point on contour !\n\t\t\t\t\t// continue;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn\tinside;\n\n\t\t}\n\n\t\tconst isClockWise = ShapeUtils.isClockWise;\n\n\t\tconst subPaths = this.subPaths;\n\t\tif ( subPaths.length === 0 ) return [];\n\n\t\tif ( noHoles === true )\treturn\ttoShapesNoHoles( subPaths );\n\n\n\t\tlet solid, tmpPath, tmpShape;\n\t\tconst shapes = [];\n\n\t\tif ( subPaths.length === 1 ) {\n\n\t\t\ttmpPath = subPaths[ 0 ];\n\t\t\ttmpShape = new Shape();\n\t\t\ttmpShape.curves = tmpPath.curves;\n\t\t\tshapes.push( tmpShape );\n\t\t\treturn shapes;\n\n\t\t}\n\n\t\tlet holesFirst = ! isClockWise( subPaths[ 0 ].getPoints() );\n\t\tholesFirst = isCCW ? ! holesFirst : holesFirst;\n\n\t\t// console.log(\"Holes first\", holesFirst);\n\n\t\tconst betterShapeHoles = [];\n\t\tconst newShapes = [];\n\t\tlet newShapeHoles = [];\n\t\tlet mainIdx = 0;\n\t\tlet tmpPoints;\n\n\t\tnewShapes[ mainIdx ] = undefined;\n\t\tnewShapeHoles[ mainIdx ] = [];\n\n\t\tfor ( let i = 0, l = subPaths.length; i < l; i ++ ) {\n\n\t\t\ttmpPath = subPaths[ i ];\n\t\t\ttmpPoints = tmpPath.getPoints();\n\t\t\tsolid = isClockWise( tmpPoints );\n\t\t\tsolid = isCCW ? ! solid : solid;\n\n\t\t\tif ( solid ) {\n\n\t\t\t\tif ( ( ! holesFirst ) && ( newShapes[ mainIdx ] ) )\tmainIdx ++;\n\n\t\t\t\tnewShapes[ mainIdx ] = { s: new Shape(), p: tmpPoints };\n\t\t\t\tnewShapes[ mainIdx ].s.curves = tmpPath.curves;\n\n\t\t\t\tif ( holesFirst )\tmainIdx ++;\n\t\t\t\tnewShapeHoles[ mainIdx ] = [];\n\n\t\t\t\t//console.log('cw', i);\n\n\t\t\t} else {\n\n\t\t\t\tnewShapeHoles[ mainIdx ].push( { h: tmpPath, p: tmpPoints[ 0 ] } );\n\n\t\t\t\t//console.log('ccw', i);\n\n\t\t\t}\n\n\t\t}\n\n\t\t// only Holes? -> probably all Shapes with wrong orientation\n\t\tif ( ! newShapes[ 0 ] )\treturn\ttoShapesNoHoles( subPaths );\n\n\n\t\tif ( newShapes.length > 1 ) {\n\n\t\t\tlet ambiguous = false;\n\t\t\tlet toChange = 0;\n\n\t\t\tfor ( let sIdx = 0, sLen = newShapes.length; sIdx < sLen; sIdx ++ ) {\n\n\t\t\t\tbetterShapeHoles[ sIdx ] = [];\n\n\t\t\t}\n\n\t\t\tfor ( let sIdx = 0, sLen = newShapes.length; sIdx < sLen; sIdx ++ ) {\n\n\t\t\t\tconst sho = newShapeHoles[ sIdx ];\n\n\t\t\t\tfor ( let hIdx = 0; hIdx < sho.length; hIdx ++ ) {\n\n\t\t\t\t\tconst ho = sho[ hIdx ];\n\t\t\t\t\tlet hole_unassigned = true;\n\n\t\t\t\t\tfor ( let s2Idx = 0; s2Idx < newShapes.length; s2Idx ++ ) {\n\n\t\t\t\t\t\tif ( isPointInsidePolygon( ho.p, newShapes[ s2Idx ].p ) ) {\n\n\t\t\t\t\t\t\tif ( sIdx !== s2Idx )\ttoChange ++;\n\n\t\t\t\t\t\t\tif ( hole_unassigned ) {\n\n\t\t\t\t\t\t\t\thole_unassigned = false;\n\t\t\t\t\t\t\t\tbetterShapeHoles[ s2Idx ].push( ho );\n\n\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\tambiguous = true;\n\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( hole_unassigned ) {\n\n\t\t\t\t\t\tbetterShapeHoles[ sIdx ].push( ho );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( toChange > 0 && ambiguous === false ) {\n\n\t\t\t\tnewShapeHoles = betterShapeHoles;\n\n\t\t\t}\n\n\t\t}\n\n\t\tlet tmpHoles;\n\n\t\tfor ( let i = 0, il = newShapes.length; i < il; i ++ ) {\n\n\t\t\ttmpShape = newShapes[ i ].s;\n\t\t\tshapes.push( tmpShape );\n\t\t\ttmpHoles = newShapeHoles[ i ];\n\n\t\t\tfor ( let j = 0, jl = tmpHoles.length; j < jl; j ++ ) {\n\n\t\t\t\ttmpShape.holes.push( tmpHoles[ j ].h );\n\n\t\t\t}\n\n\t\t}\n\n\t\t//console.log(\"shape\", shapes);\n\n\t\treturn shapes;\n\n\t}\n\n}\n\n// Fast Half Float Conversions, http://www.fox-toolkit.org/ftp/fasthalffloatconversion.pdf\n\nclass DataUtils {\n\n\t// float32 to float16\n\n\tstatic toHalfFloat( val ) {\n\n\t\tif ( Math.abs( val ) > 65504 ) console.warn( 'THREE.DataUtils.toHalfFloat(): Value out of range.' );\n\n\t\tval = clamp( val, - 65504, 65504 );\n\n\t\t_floatView[ 0 ] = val;\n\t\tconst f = _uint32View[ 0 ];\n\t\tconst e = ( f >> 23 ) & 0x1ff;\n\t\treturn _baseTable[ e ] + ( ( f & 0x007fffff ) >> _shiftTable[ e ] );\n\n\t}\n\n\t// float16 to float32\n\n\tstatic fromHalfFloat( val ) {\n\n\t\tconst m = val >> 10;\n\t\t_uint32View[ 0 ] = _mantissaTable[ _offsetTable[ m ] + ( val & 0x3ff ) ] + _exponentTable[ m ];\n\t\treturn _floatView[ 0 ];\n\n\t}\n\n}\n\n// float32 to float16 helpers\n\nconst _buffer = new ArrayBuffer( 4 );\nconst _floatView = new Float32Array( _buffer );\nconst _uint32View = new Uint32Array( _buffer );\n\nconst _baseTable = new Uint32Array( 512 );\nconst _shiftTable = new Uint32Array( 512 );\n\nfor ( let i = 0; i < 256; ++ i ) {\n\n\tconst e = i - 127;\n\n\t// very small number (0, -0)\n\n\tif ( e < - 27 ) {\n\n\t\t_baseTable[ i ] = 0x0000;\n\t\t_baseTable[ i | 0x100 ] = 0x8000;\n\t\t_shiftTable[ i ] = 24;\n\t\t_shiftTable[ i | 0x100 ] = 24;\n\n\t\t// small number (denorm)\n\n\t} else if ( e < - 14 ) {\n\n\t\t_baseTable[ i ] = 0x0400 >> ( - e - 14 );\n\t\t_baseTable[ i | 0x100 ] = ( 0x0400 >> ( - e - 14 ) ) | 0x8000;\n\t\t_shiftTable[ i ] = - e - 1;\n\t\t_shiftTable[ i | 0x100 ] = - e - 1;\n\n\t\t// normal number\n\n\t} else if ( e <= 15 ) {\n\n\t\t_baseTable[ i ] = ( e + 15 ) << 10;\n\t\t_baseTable[ i | 0x100 ] = ( ( e + 15 ) << 10 ) | 0x8000;\n\t\t_shiftTable[ i ] = 13;\n\t\t_shiftTable[ i | 0x100 ] = 13;\n\n\t\t// large number (Infinity, -Infinity)\n\n\t} else if ( e < 128 ) {\n\n\t\t_baseTable[ i ] = 0x7c00;\n\t\t_baseTable[ i | 0x100 ] = 0xfc00;\n\t\t_shiftTable[ i ] = 24;\n\t\t_shiftTable[ i | 0x100 ] = 24;\n\n\t\t// stay (NaN, Infinity, -Infinity)\n\n\t} else {\n\n\t\t_baseTable[ i ] = 0x7c00;\n\t\t_baseTable[ i | 0x100 ] = 0xfc00;\n\t\t_shiftTable[ i ] = 13;\n\t\t_shiftTable[ i | 0x100 ] = 13;\n\n\t}\n\n}\n\n// float16 to float32 helpers\n\nconst _mantissaTable = new Uint32Array( 2048 );\nconst _exponentTable = new Uint32Array( 64 );\nconst _offsetTable = new Uint32Array( 64 );\n\nfor ( let i = 1; i < 1024; ++ i ) {\n\n\tlet m = i << 13; // zero pad mantissa bits\n\tlet e = 0; // zero exponent\n\n\t// normalized\n\twhile ( ( m & 0x00800000 ) === 0 ) {\n\n\t\tm <<= 1;\n\t\te -= 0x00800000; // decrement exponent\n\n\t}\n\n\tm &= ~ 0x00800000; // clear leading 1 bit\n\te += 0x38800000; // adjust bias\n\n\t_mantissaTable[ i ] = m | e;\n\n}\n\nfor ( let i = 1024; i < 2048; ++ i ) {\n\n\t_mantissaTable[ i ] = 0x38000000 + ( ( i - 1024 ) << 13 );\n\n}\n\nfor ( let i = 1; i < 31; ++ i ) {\n\n\t_exponentTable[ i ] = i << 23;\n\n}\n\n_exponentTable[ 31 ] = 0x47800000;\n_exponentTable[ 32 ] = 0x80000000;\nfor ( let i = 33; i < 63; ++ i ) {\n\n\t_exponentTable[ i ] = 0x80000000 + ( ( i - 32 ) << 23 );\n\n}\n\n_exponentTable[ 63 ] = 0xc7800000;\n\nfor ( let i = 1; i < 64; ++ i ) {\n\n\tif ( i !== 32 ) {\n\n\t\t_offsetTable[ i ] = 1024;\n\n\t}\n\n}\n\n// r133, c5bb5434555a3c3ddd784944a0a124f996fc721b\n\nclass ParametricGeometry extends BufferGeometry {\n\n\tconstructor() {\n\n\t\tconsole.error( 'THREE.ParametricGeometry has been moved to /examples/jsm/geometries/ParametricGeometry.js' );\n\t\tsuper();\n\n\t}\n\n}\n\n// r133, eb58ff153119090d3bbb24474ea0ffc40c70dc92\n\nclass TextGeometry extends BufferGeometry {\n\n\tconstructor() {\n\n\t\tconsole.error( 'THREE.TextGeometry has been moved to /examples/jsm/geometries/TextGeometry.js' );\n\t\tsuper();\n\n\t}\n\n}\n\n// r133, eb58ff153119090d3bbb24474ea0ffc40c70dc92\n\nfunction FontLoader() {\n\n\tconsole.error( 'THREE.FontLoader has been moved to /examples/jsm/loaders/FontLoader.js' );\n\n}\n\n// r133, eb58ff153119090d3bbb24474ea0ffc40c70dc92\n\nfunction Font() {\n\n\tconsole.error( 'THREE.Font has been moved to /examples/jsm/loaders/FontLoader.js' );\n\n}\n\n// r134, d65e0af06644fe5a84a6fc0e372f4318f95a04c0\n\nfunction ImmediateRenderObject() {\n\n\tconsole.error( 'THREE.ImmediateRenderObject has been removed.' );\n\n}\n\n// r138, 48b05d3500acc084df50be9b4c90781ad9b8cb17\n\nclass WebGLMultisampleRenderTarget extends WebGLRenderTarget {\n\n\tconstructor( width, height, options ) {\n\n\t\tconsole.error( 'THREE.WebGLMultisampleRenderTarget has been removed. Use a normal render target and set the \"samples\" property to greater 0 to enable multisampling.' );\n\t\tsuper( width, height, options );\n\t\tthis.samples = 4;\n\n\t}\n\n}\n\n// r138, f9cd9cab03b7b64244e304900a3a2eeaa3a588ce\n\nclass DataTexture2DArray extends DataArrayTexture {\n\n\tconstructor( data, width, height, depth ) {\n\n\t\tconsole.warn( 'THREE.DataTexture2DArray has been renamed to DataArrayTexture.' );\n\t\tsuper( data, width, height, depth );\n\n\t}\n\n}\n\n// r138, f9cd9cab03b7b64244e304900a3a2eeaa3a588ce\n\nclass DataTexture3D extends Data3DTexture {\n\n\tconstructor( data, width, height, depth ) {\n\n\t\tconsole.warn( 'THREE.DataTexture3D has been renamed to Data3DTexture.' );\n\t\tsuper( data, width, height, depth );\n\n\t}\n\n}\n\nif ( typeof __THREE_DEVTOOLS__ !== 'undefined' ) {\n\n\t__THREE_DEVTOOLS__.dispatchEvent( new CustomEvent( 'register', { detail: {\n\t\trevision: REVISION,\n\t} } ) );\n\n}\n\nif ( typeof window !== 'undefined' ) {\n\n\tif ( window.__THREE__ ) {\n\n\t\tconsole.warn( 'WARNING: Multiple instances of Three.js being imported.' );\n\n\t} else {\n\n\t\twindow.__THREE__ = REVISION;\n\n\t}\n\n}\n\nexport { ACESFilmicToneMapping, AddEquation, AddOperation, AdditiveAnimationBlendMode, AdditiveBlending, AlphaFormat, AlwaysDepth, AlwaysStencilFunc, AmbientLight, AmbientLightProbe, AnimationClip, AnimationLoader, AnimationMixer, AnimationObjectGroup, AnimationUtils, ArcCurve, ArrayCamera, ArrowHelper, Audio, AudioAnalyser, AudioContext, AudioListener, AudioLoader, AxesHelper, BackSide, BasicDepthPacking, BasicShadowMap, Bone, BooleanKeyframeTrack, Box2, Box3, Box3Helper, BoxGeometry as BoxBufferGeometry, BoxGeometry, BoxHelper, BufferAttribute, BufferGeometry, BufferGeometryLoader, ByteType, Cache, Camera, CameraHelper, CanvasTexture, CapsuleGeometry as CapsuleBufferGeometry, CapsuleGeometry, CatmullRomCurve3, CineonToneMapping, CircleGeometry as CircleBufferGeometry, CircleGeometry, ClampToEdgeWrapping, Clock, Color, ColorKeyframeTrack, ColorManagement, CompressedTexture, CompressedTextureLoader, ConeGeometry as ConeBufferGeometry, ConeGeometry, CubeCamera, CubeReflectionMapping, CubeRefractionMapping, CubeTexture, CubeTextureLoader, CubeUVReflectionMapping, CubicBezierCurve, CubicBezierCurve3, CubicInterpolant, CullFaceBack, CullFaceFront, CullFaceFrontBack, CullFaceNone, Curve, CurvePath, CustomBlending, CustomToneMapping, CylinderGeometry as CylinderBufferGeometry, CylinderGeometry, Cylindrical, Data3DTexture, DataArrayTexture, DataTexture, DataTexture2DArray, DataTexture3D, DataTextureLoader, DataUtils, DecrementStencilOp, DecrementWrapStencilOp, DefaultLoadingManager, DepthFormat, DepthStencilFormat, DepthTexture, DirectionalLight, DirectionalLightHelper, DiscreteInterpolant, DodecahedronGeometry as DodecahedronBufferGeometry, DodecahedronGeometry, DoubleSide, DstAlphaFactor, DstColorFactor, DynamicCopyUsage, DynamicDrawUsage, DynamicReadUsage, EdgesGeometry, EllipseCurve, EqualDepth, EqualStencilFunc, EquirectangularReflectionMapping, EquirectangularRefractionMapping, Euler, EventDispatcher, ExtrudeGeometry as ExtrudeBufferGeometry, ExtrudeGeometry, FileLoader, FlatShading, Float16BufferAttribute, Float32BufferAttribute, Float64BufferAttribute, FloatType, Fog, FogExp2, Font, FontLoader, FramebufferTexture, FrontSide, Frustum, GLBufferAttribute, GLSL1, GLSL3, GreaterDepth, GreaterEqualDepth, GreaterEqualStencilFunc, GreaterStencilFunc, GridHelper, Group, HalfFloatType, HemisphereLight, HemisphereLightHelper, HemisphereLightProbe, IcosahedronGeometry as IcosahedronBufferGeometry, IcosahedronGeometry, ImageBitmapLoader, ImageLoader, ImageUtils, ImmediateRenderObject, IncrementStencilOp, IncrementWrapStencilOp, InstancedBufferAttribute, InstancedBufferGeometry, InstancedInterleavedBuffer, InstancedMesh, Int16BufferAttribute, Int32BufferAttribute, Int8BufferAttribute, IntType, InterleavedBuffer, InterleavedBufferAttribute, Interpolant, InterpolateDiscrete, InterpolateLinear, InterpolateSmooth, InvertStencilOp, KeepStencilOp, KeyframeTrack, LOD, LatheGeometry as LatheBufferGeometry, LatheGeometry, Layers, LessDepth, LessEqualDepth, LessEqualStencilFunc, LessStencilFunc, Light, LightProbe, Line, Line3, LineBasicMaterial, LineCurve, LineCurve3, LineDashedMaterial, LineLoop, LineSegments, LinearEncoding, LinearFilter, LinearInterpolant, LinearMipMapLinearFilter, LinearMipMapNearestFilter, LinearMipmapLinearFilter, LinearMipmapNearestFilter, LinearSRGBColorSpace, LinearToneMapping, Loader, LoaderUtils, LoadingManager, LoopOnce, LoopPingPong, LoopRepeat, LuminanceAlphaFormat, LuminanceFormat, MOUSE, Material, MaterialLoader, MathUtils, Matrix3, Matrix4, MaxEquation, Mesh, MeshBasicMaterial, MeshDepthMaterial, MeshDistanceMaterial, MeshLambertMaterial, MeshMatcapMaterial, MeshNormalMaterial, MeshPhongMaterial, MeshPhysicalMaterial, MeshStandardMaterial, MeshToonMaterial, MinEquation, MirroredRepeatWrapping, MixOperation, MultiplyBlending, MultiplyOperation, NearestFilter, NearestMipMapLinearFilter, NearestMipMapNearestFilter, NearestMipmapLinearFilter, NearestMipmapNearestFilter, NeverDepth, NeverStencilFunc, NoBlending, NoColorSpace, NoToneMapping, NormalAnimationBlendMode, NormalBlending, NotEqualDepth, NotEqualStencilFunc, NumberKeyframeTrack, Object3D, ObjectLoader, ObjectSpaceNormalMap, OctahedronGeometry as OctahedronBufferGeometry, OctahedronGeometry, OneFactor, OneMinusDstAlphaFactor, OneMinusDstColorFactor, OneMinusSrcAlphaFactor, OneMinusSrcColorFactor, OrthographicCamera, PCFShadowMap, PCFSoftShadowMap, PMREMGenerator, ParametricGeometry, Path, PerspectiveCamera, Plane, PlaneGeometry as PlaneBufferGeometry, PlaneGeometry, PlaneHelper, PointLight, PointLightHelper, Points, PointsMaterial, PolarGridHelper, PolyhedronGeometry as PolyhedronBufferGeometry, PolyhedronGeometry, PositionalAudio, PropertyBinding, PropertyMixer, QuadraticBezierCurve, QuadraticBezierCurve3, Quaternion, QuaternionKeyframeTrack, QuaternionLinearInterpolant, REVISION, RGBADepthPacking, RGBAFormat, RGBAIntegerFormat, RGBA_ASTC_10x10_Format, RGBA_ASTC_10x5_Format, RGBA_ASTC_10x6_Format, RGBA_ASTC_10x8_Format, RGBA_ASTC_12x10_Format, RGBA_ASTC_12x12_Format, RGBA_ASTC_4x4_Format, RGBA_ASTC_5x4_Format, RGBA_ASTC_5x5_Format, RGBA_ASTC_6x5_Format, RGBA_ASTC_6x6_Format, RGBA_ASTC_8x5_Format, RGBA_ASTC_8x6_Format, RGBA_ASTC_8x8_Format, RGBA_BPTC_Format, RGBA_ETC2_EAC_Format, RGBA_PVRTC_2BPPV1_Format, RGBA_PVRTC_4BPPV1_Format, RGBA_S3TC_DXT1_Format, RGBA_S3TC_DXT3_Format, RGBA_S3TC_DXT5_Format, RGBFormat, RGB_ETC1_Format, RGB_ETC2_Format, RGB_PVRTC_2BPPV1_Format, RGB_PVRTC_4BPPV1_Format, RGB_S3TC_DXT1_Format, RGFormat, RGIntegerFormat, RawShaderMaterial, Ray, Raycaster, RectAreaLight, RedFormat, RedIntegerFormat, ReinhardToneMapping, RepeatWrapping, ReplaceStencilOp, ReverseSubtractEquation, RingGeometry as RingBufferGeometry, RingGeometry, SRGBColorSpace, Scene, ShaderChunk, ShaderLib, ShaderMaterial, ShadowMaterial, Shape, ShapeGeometry as ShapeBufferGeometry, ShapeGeometry, ShapePath, ShapeUtils, ShortType, Skeleton, SkeletonHelper, SkinnedMesh, SmoothShading, Source, Sphere, SphereGeometry as SphereBufferGeometry, SphereGeometry, Spherical, SphericalHarmonics3, SplineCurve, SpotLight, SpotLightHelper, Sprite, SpriteMaterial, SrcAlphaFactor, SrcAlphaSaturateFactor, SrcColorFactor, StaticCopyUsage, StaticDrawUsage, StaticReadUsage, StereoCamera, StreamCopyUsage, StreamDrawUsage, StreamReadUsage, StringKeyframeTrack, SubtractEquation, SubtractiveBlending, TOUCH, TangentSpaceNormalMap, TetrahedronGeometry as TetrahedronBufferGeometry, TetrahedronGeometry, TextGeometry, Texture, TextureLoader, TorusGeometry as TorusBufferGeometry, TorusGeometry, TorusKnotGeometry as TorusKnotBufferGeometry, TorusKnotGeometry, Triangle, TriangleFanDrawMode, TriangleStripDrawMode, TrianglesDrawMode, TubeGeometry as TubeBufferGeometry, TubeGeometry, UVMapping, Uint16BufferAttribute, Uint32BufferAttribute, Uint8BufferAttribute, Uint8ClampedBufferAttribute, Uniform, UniformsLib, UniformsUtils, UnsignedByteType, UnsignedInt248Type, UnsignedIntType, UnsignedShort4444Type, UnsignedShort5551Type, UnsignedShortType, VSMShadowMap, Vector2, Vector3, Vector4, VectorKeyframeTrack, VideoTexture, WebGL1Renderer, WebGL3DRenderTarget, WebGLArrayRenderTarget, WebGLCubeRenderTarget, WebGLMultipleRenderTargets, WebGLMultisampleRenderTarget, WebGLRenderTarget, WebGLRenderer, WebGLUtils, WireframeGeometry, WrapAroundEnding, ZeroCurvatureEnding, ZeroFactor, ZeroSlopeEnding, ZeroStencilOp, _SRGBAFormat, sRGBEncoding };\n","import {\n\tFileLoader,\n\tLoader,\n\tShapePath\n} from 'three';\n\nclass FontLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tconst scope = this;\n\n\t\tconst loader = new FileLoader( this.manager );\n\t\tloader.setPath( this.path );\n\t\tloader.setRequestHeader( this.requestHeader );\n\t\tloader.setWithCredentials( scope.withCredentials );\n\t\tloader.load( url, function ( text ) {\n\n\t\t\tlet json;\n\n\t\t\ttry {\n\n\t\t\t\tjson = JSON.parse( text );\n\n\t\t\t} catch ( e ) {\n\n\t\t\t\tconsole.warn( 'THREE.FontLoader: typeface.js support is being deprecated. Use typeface.json instead.' );\n\t\t\t\tjson = JSON.parse( text.substring( 65, text.length - 2 ) );\n\n\t\t\t}\n\n\t\t\tconst font = scope.parse( json );\n\n\t\t\tif ( onLoad ) onLoad( font );\n\n\t\t}, onProgress, onError );\n\n\t}\n\n\tparse( json ) {\n\n\t\treturn new Font( json );\n\n\t}\n\n}\n\n//\n\nclass Font {\n\n\tconstructor( data ) {\n\n\t\tthis.isFont = true;\n\n\t\tthis.type = 'Font';\n\n\t\tthis.data = data;\n\n\t}\n\n\tgenerateShapes( text, size = 100 ) {\n\n\t\tconst shapes = [];\n\t\tconst paths = createPaths( text, size, this.data );\n\n\t\tfor ( let p = 0, pl = paths.length; p < pl; p ++ ) {\n\n\t\t\tArray.prototype.push.apply( shapes, paths[ p ].toShapes() );\n\n\t\t}\n\n\t\treturn shapes;\n\n\t}\n\n}\n\nfunction createPaths( text, size, data ) {\n\n\tconst chars = Array.from( text );\n\tconst scale = size / data.resolution;\n\tconst line_height = ( data.boundingBox.yMax - data.boundingBox.yMin + data.underlineThickness ) * scale;\n\n\tconst paths = [];\n\n\tlet offsetX = 0, offsetY = 0;\n\n\tfor ( let i = 0; i < chars.length; i ++ ) {\n\n\t\tconst char = chars[ i ];\n\n\t\tif ( char === '\\n' ) {\n\n\t\t\toffsetX = 0;\n\t\t\toffsetY -= line_height;\n\n\t\t} else {\n\n\t\t\tconst ret = createPath( char, scale, offsetX, offsetY, data );\n\t\t\toffsetX += ret.offsetX;\n\t\t\tpaths.push( ret.path );\n\n\t\t}\n\n\t}\n\n\treturn paths;\n\n}\n\nfunction createPath( char, scale, offsetX, offsetY, data ) {\n\n\tconst glyph = data.glyphs[ char ] || data.glyphs[ '?' ];\n\n\tif ( ! glyph ) {\n\n\t\tconsole.error( 'THREE.Font: character \"' + char + '\" does not exists in font family ' + data.familyName + '.' );\n\n\t\treturn;\n\n\t}\n\n\tconst path = new ShapePath();\n\n\tlet x, y, cpx, cpy, cpx1, cpy1, cpx2, cpy2;\n\n\tif ( glyph.o ) {\n\n\t\tconst outline = glyph._cachedOutline || ( glyph._cachedOutline = glyph.o.split( ' ' ) );\n\n\t\tfor ( let i = 0, l = outline.length; i < l; ) {\n\n\t\t\tconst action = outline[ i ++ ];\n\n\t\t\tswitch ( action ) {\n\n\t\t\t\tcase 'm': // moveTo\n\n\t\t\t\t\tx = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\ty = outline[ i ++ ] * scale + offsetY;\n\n\t\t\t\t\tpath.moveTo( x, y );\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'l': // lineTo\n\n\t\t\t\t\tx = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\ty = outline[ i ++ ] * scale + offsetY;\n\n\t\t\t\t\tpath.lineTo( x, y );\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'q': // quadraticCurveTo\n\n\t\t\t\t\tcpx = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\tcpy = outline[ i ++ ] * scale + offsetY;\n\t\t\t\t\tcpx1 = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\tcpy1 = outline[ i ++ ] * scale + offsetY;\n\n\t\t\t\t\tpath.quadraticCurveTo( cpx1, cpy1, cpx, cpy );\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'b': // bezierCurveTo\n\n\t\t\t\t\tcpx = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\tcpy = outline[ i ++ ] * scale + offsetY;\n\t\t\t\t\tcpx1 = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\tcpy1 = outline[ i ++ ] * scale + offsetY;\n\t\t\t\t\tcpx2 = outline[ i ++ ] * scale + offsetX;\n\t\t\t\t\tcpy2 = outline[ i ++ ] * scale + offsetY;\n\n\t\t\t\t\tpath.bezierCurveTo( cpx1, cpy1, cpx2, cpy2, cpx, cpy );\n\n\t\t\t\t\tbreak;\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\treturn { offsetX: glyph.ha * scale, path: path };\n\n}\n\nexport { FontLoader, Font };\n","import {\n\tAnimationClip,\n\tBone,\n\tBox3,\n\tBufferAttribute,\n\tBufferGeometry,\n\tClampToEdgeWrapping,\n\tColor,\n\tDirectionalLight,\n\tDoubleSide,\n\tFileLoader,\n\tFrontSide,\n\tGroup,\n\tImageBitmapLoader,\n\tInterleavedBuffer,\n\tInterleavedBufferAttribute,\n\tInterpolant,\n\tInterpolateDiscrete,\n\tInterpolateLinear,\n\tLine,\n\tLineBasicMaterial,\n\tLineLoop,\n\tLineSegments,\n\tLinearFilter,\n\tLinearMipmapLinearFilter,\n\tLinearMipmapNearestFilter,\n\tLoader,\n\tLoaderUtils,\n\tMaterial,\n\tMathUtils,\n\tMatrix4,\n\tMesh,\n\tMeshBasicMaterial,\n\tMeshPhysicalMaterial,\n\tMeshStandardMaterial,\n\tMirroredRepeatWrapping,\n\tNearestFilter,\n\tNearestMipmapLinearFilter,\n\tNearestMipmapNearestFilter,\n\tNumberKeyframeTrack,\n\tObject3D,\n\tOrthographicCamera,\n\tPerspectiveCamera,\n\tPointLight,\n\tPoints,\n\tPointsMaterial,\n\tPropertyBinding,\n\tQuaternion,\n\tQuaternionKeyframeTrack,\n\tRepeatWrapping,\n\tSkeleton,\n\tSkinnedMesh,\n\tSphere,\n\tSpotLight,\n\tTangentSpaceNormalMap,\n\tTexture,\n\tTextureLoader,\n\tTriangleFanDrawMode,\n\tTriangleStripDrawMode,\n\tVector2,\n\tVector3,\n\tVectorKeyframeTrack,\n\tsRGBEncoding\n} from 'three';\n\nclass GLTFLoader extends Loader {\n\n\tconstructor( manager ) {\n\n\t\tsuper( manager );\n\n\t\tthis.dracoLoader = null;\n\t\tthis.ktx2Loader = null;\n\t\tthis.meshoptDecoder = null;\n\n\t\tthis.pluginCallbacks = [];\n\n\t\tthis.register( function ( parser ) {\n\n\t\t\treturn new GLTFMaterialsClearcoatExtension( parser );\n\n\t\t} );\n\n\t\tthis.register( function ( parser ) {\n\n\t\t\treturn new GLTFTextureBasisUExtension( parser );\n\n\t\t} );\n\n\t\tthis.register( function ( parser ) {\n\n\t\t\treturn new GLTFTextureWebPExtension( parser );\n\n\t\t} );\n\n\t\tthis.register( function ( parser ) {\n\n\t\t\treturn new GLTFMaterialsSheenExtension( parser );\n\n\t\t} );\n\n\t\tthis.register( function ( parser ) {\n\n\t\t\treturn new GLTFMaterialsTransmissionExtension( parser );\n\n\t\t} );\n\n\t\tthis.register( function ( parser ) {\n\n\t\t\treturn new GLTFMaterialsVolumeExtension( parser );\n\n\t\t} );\n\n\t\tthis.register( function ( parser ) {\n\n\t\t\treturn new GLTFMaterialsIorExtension( parser );\n\n\t\t} );\n\n\t\tthis.register( function ( parser ) {\n\n\t\t\treturn new GLTFMaterialsEmissiveStrengthExtension( parser );\n\n\t\t} );\n\n\t\tthis.register( function ( parser ) {\n\n\t\t\treturn new GLTFMaterialsSpecularExtension( parser );\n\n\t\t} );\n\n\t\tthis.register( function ( parser ) {\n\n\t\t\treturn new GLTFMaterialsIridescenceExtension( parser );\n\n\t\t} );\n\n\t\tthis.register( function ( parser ) {\n\n\t\t\treturn new GLTFLightsExtension( parser );\n\n\t\t} );\n\n\t\tthis.register( function ( parser ) {\n\n\t\t\treturn new GLTFMeshoptCompression( parser );\n\n\t\t} );\n\n\t}\n\n\tload( url, onLoad, onProgress, onError ) {\n\n\t\tconst scope = this;\n\n\t\tlet resourcePath;\n\n\t\tif ( this.resourcePath !== '' ) {\n\n\t\t\tresourcePath = this.resourcePath;\n\n\t\t} else if ( this.path !== '' ) {\n\n\t\t\tresourcePath = this.path;\n\n\t\t} else {\n\n\t\t\tresourcePath = LoaderUtils.extractUrlBase( url );\n\n\t\t}\n\n\t\t// Tells the LoadingManager to track an extra item, which resolves after\n\t\t// the model is fully loaded. This means the count of items loaded will\n\t\t// be incorrect, but ensures manager.onLoad() does not fire early.\n\t\tthis.manager.itemStart( url );\n\n\t\tconst _onError = function ( e ) {\n\n\t\t\tif ( onError ) {\n\n\t\t\t\tonError( e );\n\n\t\t\t} else {\n\n\t\t\t\tconsole.error( e );\n\n\t\t\t}\n\n\t\t\tscope.manager.itemError( url );\n\t\t\tscope.manager.itemEnd( url );\n\n\t\t};\n\n\t\tconst loader = new FileLoader( this.manager );\n\n\t\tloader.setPath( this.path );\n\t\tloader.setResponseType( 'arraybuffer' );\n\t\tloader.setRequestHeader( this.requestHeader );\n\t\tloader.setWithCredentials( this.withCredentials );\n\n\t\tloader.load( url, function ( data ) {\n\n\t\t\ttry {\n\n\t\t\t\tscope.parse( data, resourcePath, function ( gltf ) {\n\n\t\t\t\t\tonLoad( gltf );\n\n\t\t\t\t\tscope.manager.itemEnd( url );\n\n\t\t\t\t}, _onError );\n\n\t\t\t} catch ( e ) {\n\n\t\t\t\t_onError( e );\n\n\t\t\t}\n\n\t\t}, onProgress, _onError );\n\n\t}\n\n\tsetDRACOLoader( dracoLoader ) {\n\n\t\tthis.dracoLoader = dracoLoader;\n\t\treturn this;\n\n\t}\n\n\tsetDDSLoader() {\n\n\t\tthrow new Error(\n\n\t\t\t'THREE.GLTFLoader: \"MSFT_texture_dds\" no longer supported. Please update to \"KHR_texture_basisu\".'\n\n\t\t);\n\n\t}\n\n\tsetKTX2Loader( ktx2Loader ) {\n\n\t\tthis.ktx2Loader = ktx2Loader;\n\t\treturn this;\n\n\t}\n\n\tsetMeshoptDecoder( meshoptDecoder ) {\n\n\t\tthis.meshoptDecoder = meshoptDecoder;\n\t\treturn this;\n\n\t}\n\n\tregister( callback ) {\n\n\t\tif ( this.pluginCallbacks.indexOf( callback ) === - 1 ) {\n\n\t\t\tthis.pluginCallbacks.push( callback );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tunregister( callback ) {\n\n\t\tif ( this.pluginCallbacks.indexOf( callback ) !== - 1 ) {\n\n\t\t\tthis.pluginCallbacks.splice( this.pluginCallbacks.indexOf( callback ), 1 );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tparse( data, path, onLoad, onError ) {\n\n\t\tlet content;\n\t\tconst extensions = {};\n\t\tconst plugins = {};\n\n\t\tif ( typeof data === 'string' ) {\n\n\t\t\tcontent = data;\n\n\t\t} else {\n\n\t\t\tconst magic = LoaderUtils.decodeText( new Uint8Array( data, 0, 4 ) );\n\n\t\t\tif ( magic === BINARY_EXTENSION_HEADER_MAGIC ) {\n\n\t\t\t\ttry {\n\n\t\t\t\t\textensions[ EXTENSIONS.KHR_BINARY_GLTF ] = new GLTFBinaryExtension( data );\n\n\t\t\t\t} catch ( error ) {\n\n\t\t\t\t\tif ( onError ) onError( error );\n\t\t\t\t\treturn;\n\n\t\t\t\t}\n\n\t\t\t\tcontent = extensions[ EXTENSIONS.KHR_BINARY_GLTF ].content;\n\n\t\t\t} else {\n\n\t\t\t\tcontent = LoaderUtils.decodeText( new Uint8Array( data ) );\n\n\t\t\t}\n\n\t\t}\n\n\t\tconst json = JSON.parse( content );\n\n\t\tif ( json.asset === undefined || json.asset.version[ 0 ] < 2 ) {\n\n\t\t\tif ( onError ) onError( new Error( 'THREE.GLTFLoader: Unsupported asset. glTF versions >=2.0 are supported.' ) );\n\t\t\treturn;\n\n\t\t}\n\n\t\tconst parser = new GLTFParser( json, {\n\n\t\t\tpath: path || this.resourcePath || '',\n\t\t\tcrossOrigin: this.crossOrigin,\n\t\t\trequestHeader: this.requestHeader,\n\t\t\tmanager: this.manager,\n\t\t\tktx2Loader: this.ktx2Loader,\n\t\t\tmeshoptDecoder: this.meshoptDecoder\n\n\t\t} );\n\n\t\tparser.fileLoader.setRequestHeader( this.requestHeader );\n\n\t\tfor ( let i = 0; i < this.pluginCallbacks.length; i ++ ) {\n\n\t\t\tconst plugin = this.pluginCallbacks[ i ]( parser );\n\t\t\tplugins[ plugin.name ] = plugin;\n\n\t\t\t// Workaround to avoid determining as unknown extension\n\t\t\t// in addUnknownExtensionsToUserData().\n\t\t\t// Remove this workaround if we move all the existing\n\t\t\t// extension handlers to plugin system\n\t\t\textensions[ plugin.name ] = true;\n\n\t\t}\n\n\t\tif ( json.extensionsUsed ) {\n\n\t\t\tfor ( let i = 0; i < json.extensionsUsed.length; ++ i ) {\n\n\t\t\t\tconst extensionName = json.extensionsUsed[ i ];\n\t\t\t\tconst extensionsRequired = json.extensionsRequired || [];\n\n\t\t\t\tswitch ( extensionName ) {\n\n\t\t\t\t\tcase EXTENSIONS.KHR_MATERIALS_UNLIT:\n\t\t\t\t\t\textensions[ extensionName ] = new GLTFMaterialsUnlitExtension();\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase EXTENSIONS.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS:\n\t\t\t\t\t\textensions[ extensionName ] = new GLTFMaterialsPbrSpecularGlossinessExtension();\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase EXTENSIONS.KHR_DRACO_MESH_COMPRESSION:\n\t\t\t\t\t\textensions[ extensionName ] = new GLTFDracoMeshCompressionExtension( json, this.dracoLoader );\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase EXTENSIONS.KHR_TEXTURE_TRANSFORM:\n\t\t\t\t\t\textensions[ extensionName ] = new GLTFTextureTransformExtension();\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase EXTENSIONS.KHR_MESH_QUANTIZATION:\n\t\t\t\t\t\textensions[ extensionName ] = new GLTFMeshQuantizationExtension();\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault:\n\n\t\t\t\t\t\tif ( extensionsRequired.indexOf( extensionName ) >= 0 && plugins[ extensionName ] === undefined ) {\n\n\t\t\t\t\t\t\tconsole.warn( 'THREE.GLTFLoader: Unknown extension \"' + extensionName + '\".' );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tparser.setExtensions( extensions );\n\t\tparser.setPlugins( plugins );\n\t\tparser.parse( onLoad, onError );\n\n\t}\n\n\tparseAsync( data, path ) {\n\n\t\tconst scope = this;\n\n\t\treturn new Promise( function ( resolve, reject ) {\n\n\t\t\tscope.parse( data, path, resolve, reject );\n\n\t\t} );\n\n\t}\n\n}\n\n/* GLTFREGISTRY */\n\nfunction GLTFRegistry() {\n\n\tlet objects = {};\n\n\treturn\t{\n\n\t\tget: function ( key ) {\n\n\t\t\treturn objects[ key ];\n\n\t\t},\n\n\t\tadd: function ( key, object ) {\n\n\t\t\tobjects[ key ] = object;\n\n\t\t},\n\n\t\tremove: function ( key ) {\n\n\t\t\tdelete objects[ key ];\n\n\t\t},\n\n\t\tremoveAll: function () {\n\n\t\t\tobjects = {};\n\n\t\t}\n\n\t};\n\n}\n\n/*********************************/\n/********** EXTENSIONS ***********/\n/*********************************/\n\nconst EXTENSIONS = {\n\tKHR_BINARY_GLTF: 'KHR_binary_glTF',\n\tKHR_DRACO_MESH_COMPRESSION: 'KHR_draco_mesh_compression',\n\tKHR_LIGHTS_PUNCTUAL: 'KHR_lights_punctual',\n\tKHR_MATERIALS_CLEARCOAT: 'KHR_materials_clearcoat',\n\tKHR_MATERIALS_IOR: 'KHR_materials_ior',\n\tKHR_MATERIALS_PBR_SPECULAR_GLOSSINESS: 'KHR_materials_pbrSpecularGlossiness',\n\tKHR_MATERIALS_SHEEN: 'KHR_materials_sheen',\n\tKHR_MATERIALS_SPECULAR: 'KHR_materials_specular',\n\tKHR_MATERIALS_TRANSMISSION: 'KHR_materials_transmission',\n\tKHR_MATERIALS_IRIDESCENCE: 'KHR_materials_iridescence',\n\tKHR_MATERIALS_UNLIT: 'KHR_materials_unlit',\n\tKHR_MATERIALS_VOLUME: 'KHR_materials_volume',\n\tKHR_TEXTURE_BASISU: 'KHR_texture_basisu',\n\tKHR_TEXTURE_TRANSFORM: 'KHR_texture_transform',\n\tKHR_MESH_QUANTIZATION: 'KHR_mesh_quantization',\n\tKHR_MATERIALS_EMISSIVE_STRENGTH: 'KHR_materials_emissive_strength',\n\tEXT_TEXTURE_WEBP: 'EXT_texture_webp',\n\tEXT_MESHOPT_COMPRESSION: 'EXT_meshopt_compression'\n};\n\n/**\n * Punctual Lights Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_lights_punctual\n */\nclass GLTFLightsExtension {\n\n\tconstructor( parser ) {\n\n\t\tthis.parser = parser;\n\t\tthis.name = EXTENSIONS.KHR_LIGHTS_PUNCTUAL;\n\n\t\t// Object3D instance caches\n\t\tthis.cache = { refs: {}, uses: {} };\n\n\t}\n\n\t_markDefs() {\n\n\t\tconst parser = this.parser;\n\t\tconst nodeDefs = this.parser.json.nodes || [];\n\n\t\tfor ( let nodeIndex = 0, nodeLength = nodeDefs.length; nodeIndex < nodeLength; nodeIndex ++ ) {\n\n\t\t\tconst nodeDef = nodeDefs[ nodeIndex ];\n\n\t\t\tif ( nodeDef.extensions\n\t\t\t\t\t&& nodeDef.extensions[ this.name ]\n\t\t\t\t\t&& nodeDef.extensions[ this.name ].light !== undefined ) {\n\n\t\t\t\tparser._addNodeRef( this.cache, nodeDef.extensions[ this.name ].light );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\t_loadLight( lightIndex ) {\n\n\t\tconst parser = this.parser;\n\t\tconst cacheKey = 'light:' + lightIndex;\n\t\tlet dependency = parser.cache.get( cacheKey );\n\n\t\tif ( dependency ) return dependency;\n\n\t\tconst json = parser.json;\n\t\tconst extensions = ( json.extensions && json.extensions[ this.name ] ) || {};\n\t\tconst lightDefs = extensions.lights || [];\n\t\tconst lightDef = lightDefs[ lightIndex ];\n\t\tlet lightNode;\n\n\t\tconst color = new Color( 0xffffff );\n\n\t\tif ( lightDef.color !== undefined ) color.fromArray( lightDef.color );\n\n\t\tconst range = lightDef.range !== undefined ? lightDef.range : 0;\n\n\t\tswitch ( lightDef.type ) {\n\n\t\t\tcase 'directional':\n\t\t\t\tlightNode = new DirectionalLight( color );\n\t\t\t\tlightNode.target.position.set( 0, 0, - 1 );\n\t\t\t\tlightNode.add( lightNode.target );\n\t\t\t\tbreak;\n\n\t\t\tcase 'point':\n\t\t\t\tlightNode = new PointLight( color );\n\t\t\t\tlightNode.distance = range;\n\t\t\t\tbreak;\n\n\t\t\tcase 'spot':\n\t\t\t\tlightNode = new SpotLight( color );\n\t\t\t\tlightNode.distance = range;\n\t\t\t\t// Handle spotlight properties.\n\t\t\t\tlightDef.spot = lightDef.spot || {};\n\t\t\t\tlightDef.spot.innerConeAngle = lightDef.spot.innerConeAngle !== undefined ? lightDef.spot.innerConeAngle : 0;\n\t\t\t\tlightDef.spot.outerConeAngle = lightDef.spot.outerConeAngle !== undefined ? lightDef.spot.outerConeAngle : Math.PI / 4.0;\n\t\t\t\tlightNode.angle = lightDef.spot.outerConeAngle;\n\t\t\t\tlightNode.penumbra = 1.0 - lightDef.spot.innerConeAngle / lightDef.spot.outerConeAngle;\n\t\t\t\tlightNode.target.position.set( 0, 0, - 1 );\n\t\t\t\tlightNode.add( lightNode.target );\n\t\t\t\tbreak;\n\n\t\t\tdefault:\n\t\t\t\tthrow new Error( 'THREE.GLTFLoader: Unexpected light type: ' + lightDef.type );\n\n\t\t}\n\n\t\t// Some lights (e.g. spot) default to a position other than the origin. Reset the position\n\t\t// here, because node-level parsing will only override position if explicitly specified.\n\t\tlightNode.position.set( 0, 0, 0 );\n\n\t\tlightNode.decay = 2;\n\n\t\tif ( lightDef.intensity !== undefined ) lightNode.intensity = lightDef.intensity;\n\n\t\tlightNode.name = parser.createUniqueName( lightDef.name || ( 'light_' + lightIndex ) );\n\n\t\tdependency = Promise.resolve( lightNode );\n\n\t\tparser.cache.add( cacheKey, dependency );\n\n\t\treturn dependency;\n\n\t}\n\n\tcreateNodeAttachment( nodeIndex ) {\n\n\t\tconst self = this;\n\t\tconst parser = this.parser;\n\t\tconst json = parser.json;\n\t\tconst nodeDef = json.nodes[ nodeIndex ];\n\t\tconst lightDef = ( nodeDef.extensions && nodeDef.extensions[ this.name ] ) || {};\n\t\tconst lightIndex = lightDef.light;\n\n\t\tif ( lightIndex === undefined ) return null;\n\n\t\treturn this._loadLight( lightIndex ).then( function ( light ) {\n\n\t\t\treturn parser._getNodeRef( self.cache, lightIndex, light );\n\n\t\t} );\n\n\t}\n\n}\n\n/**\n * Unlit Materials Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_unlit\n */\nclass GLTFMaterialsUnlitExtension {\n\n\tconstructor() {\n\n\t\tthis.name = EXTENSIONS.KHR_MATERIALS_UNLIT;\n\n\t}\n\n\tgetMaterialType() {\n\n\t\treturn MeshBasicMaterial;\n\n\t}\n\n\textendParams( materialParams, materialDef, parser ) {\n\n\t\tconst pending = [];\n\n\t\tmaterialParams.color = new Color( 1.0, 1.0, 1.0 );\n\t\tmaterialParams.opacity = 1.0;\n\n\t\tconst metallicRoughness = materialDef.pbrMetallicRoughness;\n\n\t\tif ( metallicRoughness ) {\n\n\t\t\tif ( Array.isArray( metallicRoughness.baseColorFactor ) ) {\n\n\t\t\t\tconst array = metallicRoughness.baseColorFactor;\n\n\t\t\t\tmaterialParams.color.fromArray( array );\n\t\t\t\tmaterialParams.opacity = array[ 3 ];\n\n\t\t\t}\n\n\t\t\tif ( metallicRoughness.baseColorTexture !== undefined ) {\n\n\t\t\t\tpending.push( parser.assignTexture( materialParams, 'map', metallicRoughness.baseColorTexture, sRGBEncoding ) );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn Promise.all( pending );\n\n\t}\n\n}\n\n/**\n * Materials Emissive Strength Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/blob/5768b3ce0ef32bc39cdf1bef10b948586635ead3/extensions/2.0/Khronos/KHR_materials_emissive_strength/README.md\n */\nclass GLTFMaterialsEmissiveStrengthExtension {\n\n\tconstructor( parser ) {\n\n\t\tthis.parser = parser;\n\t\tthis.name = EXTENSIONS.KHR_MATERIALS_EMISSIVE_STRENGTH;\n\n\t}\n\n\textendMaterialParams( materialIndex, materialParams ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) {\n\n\t\t\treturn Promise.resolve();\n\n\t\t}\n\n\t\tconst emissiveStrength = materialDef.extensions[ this.name ].emissiveStrength;\n\n\t\tif ( emissiveStrength !== undefined ) {\n\n\t\t\tmaterialParams.emissiveIntensity = emissiveStrength;\n\n\t\t}\n\n\t\treturn Promise.resolve();\n\n\t}\n\n}\n\n/**\n * Clearcoat Materials Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_clearcoat\n */\nclass GLTFMaterialsClearcoatExtension {\n\n\tconstructor( parser ) {\n\n\t\tthis.parser = parser;\n\t\tthis.name = EXTENSIONS.KHR_MATERIALS_CLEARCOAT;\n\n\t}\n\n\tgetMaterialType( materialIndex ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) return null;\n\n\t\treturn MeshPhysicalMaterial;\n\n\t}\n\n\textendMaterialParams( materialIndex, materialParams ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) {\n\n\t\t\treturn Promise.resolve();\n\n\t\t}\n\n\t\tconst pending = [];\n\n\t\tconst extension = materialDef.extensions[ this.name ];\n\n\t\tif ( extension.clearcoatFactor !== undefined ) {\n\n\t\t\tmaterialParams.clearcoat = extension.clearcoatFactor;\n\n\t\t}\n\n\t\tif ( extension.clearcoatTexture !== undefined ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'clearcoatMap', extension.clearcoatTexture ) );\n\n\t\t}\n\n\t\tif ( extension.clearcoatRoughnessFactor !== undefined ) {\n\n\t\t\tmaterialParams.clearcoatRoughness = extension.clearcoatRoughnessFactor;\n\n\t\t}\n\n\t\tif ( extension.clearcoatRoughnessTexture !== undefined ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'clearcoatRoughnessMap', extension.clearcoatRoughnessTexture ) );\n\n\t\t}\n\n\t\tif ( extension.clearcoatNormalTexture !== undefined ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'clearcoatNormalMap', extension.clearcoatNormalTexture ) );\n\n\t\t\tif ( extension.clearcoatNormalTexture.scale !== undefined ) {\n\n\t\t\t\tconst scale = extension.clearcoatNormalTexture.scale;\n\n\t\t\t\tmaterialParams.clearcoatNormalScale = new Vector2( scale, scale );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn Promise.all( pending );\n\n\t}\n\n}\n\n/**\n * Iridescence Materials Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_iridescence\n */\nclass GLTFMaterialsIridescenceExtension {\n\n\tconstructor( parser ) {\n\n\t\tthis.parser = parser;\n\t\tthis.name = EXTENSIONS.KHR_MATERIALS_IRIDESCENCE;\n\n\t}\n\n\tgetMaterialType( materialIndex ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) return null;\n\n\t\treturn MeshPhysicalMaterial;\n\n\t}\n\n\textendMaterialParams( materialIndex, materialParams ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) {\n\n\t\t\treturn Promise.resolve();\n\n\t\t}\n\n\t\tconst pending = [];\n\n\t\tconst extension = materialDef.extensions[ this.name ];\n\n\t\tif ( extension.iridescenceFactor !== undefined ) {\n\n\t\t\tmaterialParams.iridescence = extension.iridescenceFactor;\n\n\t\t}\n\n\t\tif ( extension.iridescenceTexture !== undefined ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'iridescenceMap', extension.iridescenceTexture ) );\n\n\t\t}\n\n\t\tif ( extension.iridescenceIor !== undefined ) {\n\n\t\t\tmaterialParams.iridescenceIOR = extension.iridescenceIor;\n\n\t\t}\n\n\t\tif ( materialParams.iridescenceThicknessRange === undefined ) {\n\n\t\t\tmaterialParams.iridescenceThicknessRange = [ 100, 400 ];\n\n\t\t}\n\n\t\tif ( extension.iridescenceThicknessMinimum !== undefined ) {\n\n\t\t\tmaterialParams.iridescenceThicknessRange[ 0 ] = extension.iridescenceThicknessMinimum;\n\n\t\t}\n\n\t\tif ( extension.iridescenceThicknessMaximum !== undefined ) {\n\n\t\t\tmaterialParams.iridescenceThicknessRange[ 1 ] = extension.iridescenceThicknessMaximum;\n\n\t\t}\n\n\t\tif ( extension.iridescenceThicknessTexture !== undefined ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'iridescenceThicknessMap', extension.iridescenceThicknessTexture ) );\n\n\t\t}\n\n\t\treturn Promise.all( pending );\n\n\t}\n\n}\n\n/**\n * Sheen Materials Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Khronos/KHR_materials_sheen\n */\nclass GLTFMaterialsSheenExtension {\n\n\tconstructor( parser ) {\n\n\t\tthis.parser = parser;\n\t\tthis.name = EXTENSIONS.KHR_MATERIALS_SHEEN;\n\n\t}\n\n\tgetMaterialType( materialIndex ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) return null;\n\n\t\treturn MeshPhysicalMaterial;\n\n\t}\n\n\textendMaterialParams( materialIndex, materialParams ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) {\n\n\t\t\treturn Promise.resolve();\n\n\t\t}\n\n\t\tconst pending = [];\n\n\t\tmaterialParams.sheenColor = new Color( 0, 0, 0 );\n\t\tmaterialParams.sheenRoughness = 0;\n\t\tmaterialParams.sheen = 1;\n\n\t\tconst extension = materialDef.extensions[ this.name ];\n\n\t\tif ( extension.sheenColorFactor !== undefined ) {\n\n\t\t\tmaterialParams.sheenColor.fromArray( extension.sheenColorFactor );\n\n\t\t}\n\n\t\tif ( extension.sheenRoughnessFactor !== undefined ) {\n\n\t\t\tmaterialParams.sheenRoughness = extension.sheenRoughnessFactor;\n\n\t\t}\n\n\t\tif ( extension.sheenColorTexture !== undefined ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'sheenColorMap', extension.sheenColorTexture, sRGBEncoding ) );\n\n\t\t}\n\n\t\tif ( extension.sheenRoughnessTexture !== undefined ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'sheenRoughnessMap', extension.sheenRoughnessTexture ) );\n\n\t\t}\n\n\t\treturn Promise.all( pending );\n\n\t}\n\n}\n\n/**\n * Transmission Materials Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_transmission\n * Draft: https://github.com/KhronosGroup/glTF/pull/1698\n */\nclass GLTFMaterialsTransmissionExtension {\n\n\tconstructor( parser ) {\n\n\t\tthis.parser = parser;\n\t\tthis.name = EXTENSIONS.KHR_MATERIALS_TRANSMISSION;\n\n\t}\n\n\tgetMaterialType( materialIndex ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) return null;\n\n\t\treturn MeshPhysicalMaterial;\n\n\t}\n\n\textendMaterialParams( materialIndex, materialParams ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) {\n\n\t\t\treturn Promise.resolve();\n\n\t\t}\n\n\t\tconst pending = [];\n\n\t\tconst extension = materialDef.extensions[ this.name ];\n\n\t\tif ( extension.transmissionFactor !== undefined ) {\n\n\t\t\tmaterialParams.transmission = extension.transmissionFactor;\n\n\t\t}\n\n\t\tif ( extension.transmissionTexture !== undefined ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'transmissionMap', extension.transmissionTexture ) );\n\n\t\t}\n\n\t\treturn Promise.all( pending );\n\n\t}\n\n}\n\n/**\n * Materials Volume Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_volume\n */\nclass GLTFMaterialsVolumeExtension {\n\n\tconstructor( parser ) {\n\n\t\tthis.parser = parser;\n\t\tthis.name = EXTENSIONS.KHR_MATERIALS_VOLUME;\n\n\t}\n\n\tgetMaterialType( materialIndex ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) return null;\n\n\t\treturn MeshPhysicalMaterial;\n\n\t}\n\n\textendMaterialParams( materialIndex, materialParams ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) {\n\n\t\t\treturn Promise.resolve();\n\n\t\t}\n\n\t\tconst pending = [];\n\n\t\tconst extension = materialDef.extensions[ this.name ];\n\n\t\tmaterialParams.thickness = extension.thicknessFactor !== undefined ? extension.thicknessFactor : 0;\n\n\t\tif ( extension.thicknessTexture !== undefined ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'thicknessMap', extension.thicknessTexture ) );\n\n\t\t}\n\n\t\tmaterialParams.attenuationDistance = extension.attenuationDistance || 0;\n\n\t\tconst colorArray = extension.attenuationColor || [ 1, 1, 1 ];\n\t\tmaterialParams.attenuationColor = new Color( colorArray[ 0 ], colorArray[ 1 ], colorArray[ 2 ] );\n\n\t\treturn Promise.all( pending );\n\n\t}\n\n}\n\n/**\n * Materials ior Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_ior\n */\nclass GLTFMaterialsIorExtension {\n\n\tconstructor( parser ) {\n\n\t\tthis.parser = parser;\n\t\tthis.name = EXTENSIONS.KHR_MATERIALS_IOR;\n\n\t}\n\n\tgetMaterialType( materialIndex ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) return null;\n\n\t\treturn MeshPhysicalMaterial;\n\n\t}\n\n\textendMaterialParams( materialIndex, materialParams ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) {\n\n\t\t\treturn Promise.resolve();\n\n\t\t}\n\n\t\tconst extension = materialDef.extensions[ this.name ];\n\n\t\tmaterialParams.ior = extension.ior !== undefined ? extension.ior : 1.5;\n\n\t\treturn Promise.resolve();\n\n\t}\n\n}\n\n/**\n * Materials specular Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_specular\n */\nclass GLTFMaterialsSpecularExtension {\n\n\tconstructor( parser ) {\n\n\t\tthis.parser = parser;\n\t\tthis.name = EXTENSIONS.KHR_MATERIALS_SPECULAR;\n\n\t}\n\n\tgetMaterialType( materialIndex ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) return null;\n\n\t\treturn MeshPhysicalMaterial;\n\n\t}\n\n\textendMaterialParams( materialIndex, materialParams ) {\n\n\t\tconst parser = this.parser;\n\t\tconst materialDef = parser.json.materials[ materialIndex ];\n\n\t\tif ( ! materialDef.extensions || ! materialDef.extensions[ this.name ] ) {\n\n\t\t\treturn Promise.resolve();\n\n\t\t}\n\n\t\tconst pending = [];\n\n\t\tconst extension = materialDef.extensions[ this.name ];\n\n\t\tmaterialParams.specularIntensity = extension.specularFactor !== undefined ? extension.specularFactor : 1.0;\n\n\t\tif ( extension.specularTexture !== undefined ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'specularIntensityMap', extension.specularTexture ) );\n\n\t\t}\n\n\t\tconst colorArray = extension.specularColorFactor || [ 1, 1, 1 ];\n\t\tmaterialParams.specularColor = new Color( colorArray[ 0 ], colorArray[ 1 ], colorArray[ 2 ] );\n\n\t\tif ( extension.specularColorTexture !== undefined ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'specularColorMap', extension.specularColorTexture, sRGBEncoding ) );\n\n\t\t}\n\n\t\treturn Promise.all( pending );\n\n\t}\n\n}\n\n/**\n * BasisU Texture Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_texture_basisu\n */\nclass GLTFTextureBasisUExtension {\n\n\tconstructor( parser ) {\n\n\t\tthis.parser = parser;\n\t\tthis.name = EXTENSIONS.KHR_TEXTURE_BASISU;\n\n\t}\n\n\tloadTexture( textureIndex ) {\n\n\t\tconst parser = this.parser;\n\t\tconst json = parser.json;\n\n\t\tconst textureDef = json.textures[ textureIndex ];\n\n\t\tif ( ! textureDef.extensions || ! textureDef.extensions[ this.name ] ) {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\tconst extension = textureDef.extensions[ this.name ];\n\t\tconst loader = parser.options.ktx2Loader;\n\n\t\tif ( ! loader ) {\n\n\t\t\tif ( json.extensionsRequired && json.extensionsRequired.indexOf( this.name ) >= 0 ) {\n\n\t\t\t\tthrow new Error( 'THREE.GLTFLoader: setKTX2Loader must be called before loading KTX2 textures' );\n\n\t\t\t} else {\n\n\t\t\t\t// Assumes that the extension is optional and that a fallback texture is present\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn parser.loadTextureImage( textureIndex, extension.source, loader );\n\n\t}\n\n}\n\n/**\n * WebP Texture Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Vendor/EXT_texture_webp\n */\nclass GLTFTextureWebPExtension {\n\n\tconstructor( parser ) {\n\n\t\tthis.parser = parser;\n\t\tthis.name = EXTENSIONS.EXT_TEXTURE_WEBP;\n\t\tthis.isSupported = null;\n\n\t}\n\n\tloadTexture( textureIndex ) {\n\n\t\tconst name = this.name;\n\t\tconst parser = this.parser;\n\t\tconst json = parser.json;\n\n\t\tconst textureDef = json.textures[ textureIndex ];\n\n\t\tif ( ! textureDef.extensions || ! textureDef.extensions[ name ] ) {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t\tconst extension = textureDef.extensions[ name ];\n\t\tconst source = json.images[ extension.source ];\n\n\t\tlet loader = parser.textureLoader;\n\t\tif ( source.uri ) {\n\n\t\t\tconst handler = parser.options.manager.getHandler( source.uri );\n\t\t\tif ( handler !== null ) loader = handler;\n\n\t\t}\n\n\t\treturn this.detectSupport().then( function ( isSupported ) {\n\n\t\t\tif ( isSupported ) return parser.loadTextureImage( textureIndex, extension.source, loader );\n\n\t\t\tif ( json.extensionsRequired && json.extensionsRequired.indexOf( name ) >= 0 ) {\n\n\t\t\t\tthrow new Error( 'THREE.GLTFLoader: WebP required by asset but unsupported.' );\n\n\t\t\t}\n\n\t\t\t// Fall back to PNG or JPEG.\n\t\t\treturn parser.loadTexture( textureIndex );\n\n\t\t} );\n\n\t}\n\n\tdetectSupport() {\n\n\t\tif ( ! this.isSupported ) {\n\n\t\t\tthis.isSupported = new Promise( function ( resolve ) {\n\n\t\t\t\tconst image = new Image();\n\n\t\t\t\t// Lossy test image. Support for lossy images doesn't guarantee support for all\n\t\t\t\t// WebP images, unfortunately.\n\t\t\t\timage.src = 'data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA';\n\n\t\t\t\timage.onload = image.onerror = function () {\n\n\t\t\t\t\tresolve( image.height === 1 );\n\n\t\t\t\t};\n\n\t\t\t} );\n\n\t\t}\n\n\t\treturn this.isSupported;\n\n\t}\n\n}\n\n/**\n * meshopt BufferView Compression Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Vendor/EXT_meshopt_compression\n */\nclass GLTFMeshoptCompression {\n\n\tconstructor( parser ) {\n\n\t\tthis.name = EXTENSIONS.EXT_MESHOPT_COMPRESSION;\n\t\tthis.parser = parser;\n\n\t}\n\n\tloadBufferView( index ) {\n\n\t\tconst json = this.parser.json;\n\t\tconst bufferView = json.bufferViews[ index ];\n\n\t\tif ( bufferView.extensions && bufferView.extensions[ this.name ] ) {\n\n\t\t\tconst extensionDef = bufferView.extensions[ this.name ];\n\n\t\t\tconst buffer = this.parser.getDependency( 'buffer', extensionDef.buffer );\n\t\t\tconst decoder = this.parser.options.meshoptDecoder;\n\n\t\t\tif ( ! decoder || ! decoder.supported ) {\n\n\t\t\t\tif ( json.extensionsRequired && json.extensionsRequired.indexOf( this.name ) >= 0 ) {\n\n\t\t\t\t\tthrow new Error( 'THREE.GLTFLoader: setMeshoptDecoder must be called before loading compressed files' );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// Assumes that the extension is optional and that fallback buffer data is present\n\t\t\t\t\treturn null;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn Promise.all( [ buffer, decoder.ready ] ).then( function ( res ) {\n\n\t\t\t\tconst byteOffset = extensionDef.byteOffset || 0;\n\t\t\t\tconst byteLength = extensionDef.byteLength || 0;\n\n\t\t\t\tconst count = extensionDef.count;\n\t\t\t\tconst stride = extensionDef.byteStride;\n\n\t\t\t\tconst result = new ArrayBuffer( count * stride );\n\t\t\t\tconst source = new Uint8Array( res[ 0 ], byteOffset, byteLength );\n\n\t\t\t\tdecoder.decodeGltfBuffer( new Uint8Array( result ), count, stride, source, extensionDef.mode, extensionDef.filter );\n\t\t\t\treturn result;\n\n\t\t\t} );\n\n\t\t} else {\n\n\t\t\treturn null;\n\n\t\t}\n\n\t}\n\n}\n\n/* BINARY EXTENSION */\nconst BINARY_EXTENSION_HEADER_MAGIC = 'glTF';\nconst BINARY_EXTENSION_HEADER_LENGTH = 12;\nconst BINARY_EXTENSION_CHUNK_TYPES = { JSON: 0x4E4F534A, BIN: 0x004E4942 };\n\nclass GLTFBinaryExtension {\n\n\tconstructor( data ) {\n\n\t\tthis.name = EXTENSIONS.KHR_BINARY_GLTF;\n\t\tthis.content = null;\n\t\tthis.body = null;\n\n\t\tconst headerView = new DataView( data, 0, BINARY_EXTENSION_HEADER_LENGTH );\n\n\t\tthis.header = {\n\t\t\tmagic: LoaderUtils.decodeText( new Uint8Array( data.slice( 0, 4 ) ) ),\n\t\t\tversion: headerView.getUint32( 4, true ),\n\t\t\tlength: headerView.getUint32( 8, true )\n\t\t};\n\n\t\tif ( this.header.magic !== BINARY_EXTENSION_HEADER_MAGIC ) {\n\n\t\t\tthrow new Error( 'THREE.GLTFLoader: Unsupported glTF-Binary header.' );\n\n\t\t} else if ( this.header.version < 2.0 ) {\n\n\t\t\tthrow new Error( 'THREE.GLTFLoader: Legacy binary file detected.' );\n\n\t\t}\n\n\t\tconst chunkContentsLength = this.header.length - BINARY_EXTENSION_HEADER_LENGTH;\n\t\tconst chunkView = new DataView( data, BINARY_EXTENSION_HEADER_LENGTH );\n\t\tlet chunkIndex = 0;\n\n\t\twhile ( chunkIndex < chunkContentsLength ) {\n\n\t\t\tconst chunkLength = chunkView.getUint32( chunkIndex, true );\n\t\t\tchunkIndex += 4;\n\n\t\t\tconst chunkType = chunkView.getUint32( chunkIndex, true );\n\t\t\tchunkIndex += 4;\n\n\t\t\tif ( chunkType === BINARY_EXTENSION_CHUNK_TYPES.JSON ) {\n\n\t\t\t\tconst contentArray = new Uint8Array( data, BINARY_EXTENSION_HEADER_LENGTH + chunkIndex, chunkLength );\n\t\t\t\tthis.content = LoaderUtils.decodeText( contentArray );\n\n\t\t\t} else if ( chunkType === BINARY_EXTENSION_CHUNK_TYPES.BIN ) {\n\n\t\t\t\tconst byteOffset = BINARY_EXTENSION_HEADER_LENGTH + chunkIndex;\n\t\t\t\tthis.body = data.slice( byteOffset, byteOffset + chunkLength );\n\n\t\t\t}\n\n\t\t\t// Clients must ignore chunks with unknown types.\n\n\t\t\tchunkIndex += chunkLength;\n\n\t\t}\n\n\t\tif ( this.content === null ) {\n\n\t\t\tthrow new Error( 'THREE.GLTFLoader: JSON content not found.' );\n\n\t\t}\n\n\t}\n\n}\n\n/**\n * DRACO Mesh Compression Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_draco_mesh_compression\n */\nclass GLTFDracoMeshCompressionExtension {\n\n\tconstructor( json, dracoLoader ) {\n\n\t\tif ( ! dracoLoader ) {\n\n\t\t\tthrow new Error( 'THREE.GLTFLoader: No DRACOLoader instance provided.' );\n\n\t\t}\n\n\t\tthis.name = EXTENSIONS.KHR_DRACO_MESH_COMPRESSION;\n\t\tthis.json = json;\n\t\tthis.dracoLoader = dracoLoader;\n\t\tthis.dracoLoader.preload();\n\n\t}\n\n\tdecodePrimitive( primitive, parser ) {\n\n\t\tconst json = this.json;\n\t\tconst dracoLoader = this.dracoLoader;\n\t\tconst bufferViewIndex = primitive.extensions[ this.name ].bufferView;\n\t\tconst gltfAttributeMap = primitive.extensions[ this.name ].attributes;\n\t\tconst threeAttributeMap = {};\n\t\tconst attributeNormalizedMap = {};\n\t\tconst attributeTypeMap = {};\n\n\t\tfor ( const attributeName in gltfAttributeMap ) {\n\n\t\t\tconst threeAttributeName = ATTRIBUTES[ attributeName ] || attributeName.toLowerCase();\n\n\t\t\tthreeAttributeMap[ threeAttributeName ] = gltfAttributeMap[ attributeName ];\n\n\t\t}\n\n\t\tfor ( const attributeName in primitive.attributes ) {\n\n\t\t\tconst threeAttributeName = ATTRIBUTES[ attributeName ] || attributeName.toLowerCase();\n\n\t\t\tif ( gltfAttributeMap[ attributeName ] !== undefined ) {\n\n\t\t\t\tconst accessorDef = json.accessors[ primitive.attributes[ attributeName ] ];\n\t\t\t\tconst componentType = WEBGL_COMPONENT_TYPES[ accessorDef.componentType ];\n\n\t\t\t\tattributeTypeMap[ threeAttributeName ] = componentType;\n\t\t\t\tattributeNormalizedMap[ threeAttributeName ] = accessorDef.normalized === true;\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn parser.getDependency( 'bufferView', bufferViewIndex ).then( function ( bufferView ) {\n\n\t\t\treturn new Promise( function ( resolve ) {\n\n\t\t\t\tdracoLoader.decodeDracoFile( bufferView, function ( geometry ) {\n\n\t\t\t\t\tfor ( const attributeName in geometry.attributes ) {\n\n\t\t\t\t\t\tconst attribute = geometry.attributes[ attributeName ];\n\t\t\t\t\t\tconst normalized = attributeNormalizedMap[ attributeName ];\n\n\t\t\t\t\t\tif ( normalized !== undefined ) attribute.normalized = normalized;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tresolve( geometry );\n\n\t\t\t\t}, threeAttributeMap, attributeTypeMap );\n\n\t\t\t} );\n\n\t\t} );\n\n\t}\n\n}\n\n/**\n * Texture Transform Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_texture_transform\n */\nclass GLTFTextureTransformExtension {\n\n\tconstructor() {\n\n\t\tthis.name = EXTENSIONS.KHR_TEXTURE_TRANSFORM;\n\n\t}\n\n\textendTexture( texture, transform ) {\n\n\t\tif ( transform.texCoord !== undefined ) {\n\n\t\t\tconsole.warn( 'THREE.GLTFLoader: Custom UV sets in \"' + this.name + '\" extension not yet supported.' );\n\n\t\t}\n\n\t\tif ( transform.offset === undefined && transform.rotation === undefined && transform.scale === undefined ) {\n\n\t\t\t// See https://github.com/mrdoob/three.js/issues/21819.\n\t\t\treturn texture;\n\n\t\t}\n\n\t\ttexture = texture.clone();\n\n\t\tif ( transform.offset !== undefined ) {\n\n\t\t\ttexture.offset.fromArray( transform.offset );\n\n\t\t}\n\n\t\tif ( transform.rotation !== undefined ) {\n\n\t\t\ttexture.rotation = transform.rotation;\n\n\t\t}\n\n\t\tif ( transform.scale !== undefined ) {\n\n\t\t\ttexture.repeat.fromArray( transform.scale );\n\n\t\t}\n\n\t\ttexture.needsUpdate = true;\n\n\t\treturn texture;\n\n\t}\n\n}\n\n/**\n * Specular-Glossiness Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Archived/KHR_materials_pbrSpecularGlossiness\n */\n\n/**\n * A sub class of StandardMaterial with some of the functionality\n * changed via the `onBeforeCompile` callback\n * @pailhead\n */\nclass GLTFMeshStandardSGMaterial extends MeshStandardMaterial {\n\n\tconstructor( params ) {\n\n\t\tsuper();\n\n\t\tthis.isGLTFSpecularGlossinessMaterial = true;\n\n\t\t//various chunks that need replacing\n\t\tconst specularMapParsFragmentChunk = [\n\t\t\t'#ifdef USE_SPECULARMAP',\n\t\t\t'\tuniform sampler2D specularMap;',\n\t\t\t'#endif'\n\t\t].join( '\\n' );\n\n\t\tconst glossinessMapParsFragmentChunk = [\n\t\t\t'#ifdef USE_GLOSSINESSMAP',\n\t\t\t'\tuniform sampler2D glossinessMap;',\n\t\t\t'#endif'\n\t\t].join( '\\n' );\n\n\t\tconst specularMapFragmentChunk = [\n\t\t\t'vec3 specularFactor = specular;',\n\t\t\t'#ifdef USE_SPECULARMAP',\n\t\t\t'\tvec4 texelSpecular = texture2D( specularMap, vUv );',\n\t\t\t'\t// reads channel RGB, compatible with a glTF Specular-Glossiness (RGBA) texture',\n\t\t\t'\tspecularFactor *= texelSpecular.rgb;',\n\t\t\t'#endif'\n\t\t].join( '\\n' );\n\n\t\tconst glossinessMapFragmentChunk = [\n\t\t\t'float glossinessFactor = glossiness;',\n\t\t\t'#ifdef USE_GLOSSINESSMAP',\n\t\t\t'\tvec4 texelGlossiness = texture2D( glossinessMap, vUv );',\n\t\t\t'\t// reads channel A, compatible with a glTF Specular-Glossiness (RGBA) texture',\n\t\t\t'\tglossinessFactor *= texelGlossiness.a;',\n\t\t\t'#endif'\n\t\t].join( '\\n' );\n\n\t\tconst lightPhysicalFragmentChunk = [\n\t\t\t'PhysicalMaterial material;',\n\t\t\t'material.diffuseColor = diffuseColor.rgb * ( 1. - max( specularFactor.r, max( specularFactor.g, specularFactor.b ) ) );',\n\t\t\t'vec3 dxy = max( abs( dFdx( geometryNormal ) ), abs( dFdy( geometryNormal ) ) );',\n\t\t\t'float geometryRoughness = max( max( dxy.x, dxy.y ), dxy.z );',\n\t\t\t'material.roughness = max( 1.0 - glossinessFactor, 0.0525 ); // 0.0525 corresponds to the base mip of a 256 cubemap.',\n\t\t\t'material.roughness += geometryRoughness;',\n\t\t\t'material.roughness = min( material.roughness, 1.0 );',\n\t\t\t'material.specularColor = specularFactor;',\n\t\t].join( '\\n' );\n\n\t\tconst uniforms = {\n\t\t\tspecular: { value: new Color().setHex( 0xffffff ) },\n\t\t\tglossiness: { value: 1 },\n\t\t\tspecularMap: { value: null },\n\t\t\tglossinessMap: { value: null }\n\t\t};\n\n\t\tthis._extraUniforms = uniforms;\n\n\t\tthis.onBeforeCompile = function ( shader ) {\n\n\t\t\tfor ( const uniformName in uniforms ) {\n\n\t\t\t\tshader.uniforms[ uniformName ] = uniforms[ uniformName ];\n\n\t\t\t}\n\n\t\t\tshader.fragmentShader = shader.fragmentShader\n\t\t\t\t.replace( 'uniform float roughness;', 'uniform vec3 specular;' )\n\t\t\t\t.replace( 'uniform float metalness;', 'uniform float glossiness;' )\n\t\t\t\t.replace( '#include ', specularMapParsFragmentChunk )\n\t\t\t\t.replace( '#include ', glossinessMapParsFragmentChunk )\n\t\t\t\t.replace( '#include ', specularMapFragmentChunk )\n\t\t\t\t.replace( '#include ', glossinessMapFragmentChunk )\n\t\t\t\t.replace( '#include ', lightPhysicalFragmentChunk );\n\n\t\t};\n\n\t\tObject.defineProperties( this, {\n\n\t\t\tspecular: {\n\t\t\t\tget: function () {\n\n\t\t\t\t\treturn uniforms.specular.value;\n\n\t\t\t\t},\n\t\t\t\tset: function ( v ) {\n\n\t\t\t\t\tuniforms.specular.value = v;\n\n\t\t\t\t}\n\t\t\t},\n\n\t\t\tspecularMap: {\n\t\t\t\tget: function () {\n\n\t\t\t\t\treturn uniforms.specularMap.value;\n\n\t\t\t\t},\n\t\t\t\tset: function ( v ) {\n\n\t\t\t\t\tuniforms.specularMap.value = v;\n\n\t\t\t\t\tif ( v ) {\n\n\t\t\t\t\t\tthis.defines.USE_SPECULARMAP = ''; // USE_UV is set by the renderer for specular maps\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tdelete this.defines.USE_SPECULARMAP;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\t\t\t},\n\n\t\t\tglossiness: {\n\t\t\t\tget: function () {\n\n\t\t\t\t\treturn uniforms.glossiness.value;\n\n\t\t\t\t},\n\t\t\t\tset: function ( v ) {\n\n\t\t\t\t\tuniforms.glossiness.value = v;\n\n\t\t\t\t}\n\t\t\t},\n\n\t\t\tglossinessMap: {\n\t\t\t\tget: function () {\n\n\t\t\t\t\treturn uniforms.glossinessMap.value;\n\n\t\t\t\t},\n\t\t\t\tset: function ( v ) {\n\n\t\t\t\t\tuniforms.glossinessMap.value = v;\n\n\t\t\t\t\tif ( v ) {\n\n\t\t\t\t\t\tthis.defines.USE_GLOSSINESSMAP = '';\n\t\t\t\t\t\tthis.defines.USE_UV = '';\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tdelete this.defines.USE_GLOSSINESSMAP;\n\t\t\t\t\t\tdelete this.defines.USE_UV;\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\t\t\t}\n\n\t\t} );\n\n\t\tdelete this.metalness;\n\t\tdelete this.roughness;\n\t\tdelete this.metalnessMap;\n\t\tdelete this.roughnessMap;\n\n\t\tthis.setValues( params );\n\n\t}\n\n\tcopy( source ) {\n\n\t\tsuper.copy( source );\n\n\t\tthis.specularMap = source.specularMap;\n\t\tthis.specular.copy( source.specular );\n\t\tthis.glossinessMap = source.glossinessMap;\n\t\tthis.glossiness = source.glossiness;\n\t\tdelete this.metalness;\n\t\tdelete this.roughness;\n\t\tdelete this.metalnessMap;\n\t\tdelete this.roughnessMap;\n\t\treturn this;\n\n\t}\n\n}\n\n\nclass GLTFMaterialsPbrSpecularGlossinessExtension {\n\n\tconstructor() {\n\n\t\tthis.name = EXTENSIONS.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS;\n\n\t\tthis.specularGlossinessParams = [\n\t\t\t'color',\n\t\t\t'map',\n\t\t\t'lightMap',\n\t\t\t'lightMapIntensity',\n\t\t\t'aoMap',\n\t\t\t'aoMapIntensity',\n\t\t\t'emissive',\n\t\t\t'emissiveIntensity',\n\t\t\t'emissiveMap',\n\t\t\t'bumpMap',\n\t\t\t'bumpScale',\n\t\t\t'normalMap',\n\t\t\t'normalMapType',\n\t\t\t'displacementMap',\n\t\t\t'displacementScale',\n\t\t\t'displacementBias',\n\t\t\t'specularMap',\n\t\t\t'specular',\n\t\t\t'glossinessMap',\n\t\t\t'glossiness',\n\t\t\t'alphaMap',\n\t\t\t'envMap',\n\t\t\t'envMapIntensity'\n\t\t];\n\n\t}\n\n\tgetMaterialType() {\n\n\t\treturn GLTFMeshStandardSGMaterial;\n\n\t}\n\n\textendParams( materialParams, materialDef, parser ) {\n\n\t\tconst pbrSpecularGlossiness = materialDef.extensions[ this.name ];\n\n\t\tmaterialParams.color = new Color( 1.0, 1.0, 1.0 );\n\t\tmaterialParams.opacity = 1.0;\n\n\t\tconst pending = [];\n\n\t\tif ( Array.isArray( pbrSpecularGlossiness.diffuseFactor ) ) {\n\n\t\t\tconst array = pbrSpecularGlossiness.diffuseFactor;\n\n\t\t\tmaterialParams.color.fromArray( array );\n\t\t\tmaterialParams.opacity = array[ 3 ];\n\n\t\t}\n\n\t\tif ( pbrSpecularGlossiness.diffuseTexture !== undefined ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'map', pbrSpecularGlossiness.diffuseTexture, sRGBEncoding ) );\n\n\t\t}\n\n\t\tmaterialParams.emissive = new Color( 0.0, 0.0, 0.0 );\n\t\tmaterialParams.glossiness = pbrSpecularGlossiness.glossinessFactor !== undefined ? pbrSpecularGlossiness.glossinessFactor : 1.0;\n\t\tmaterialParams.specular = new Color( 1.0, 1.0, 1.0 );\n\n\t\tif ( Array.isArray( pbrSpecularGlossiness.specularFactor ) ) {\n\n\t\t\tmaterialParams.specular.fromArray( pbrSpecularGlossiness.specularFactor );\n\n\t\t}\n\n\t\tif ( pbrSpecularGlossiness.specularGlossinessTexture !== undefined ) {\n\n\t\t\tconst specGlossMapDef = pbrSpecularGlossiness.specularGlossinessTexture;\n\t\t\tpending.push( parser.assignTexture( materialParams, 'glossinessMap', specGlossMapDef ) );\n\t\t\tpending.push( parser.assignTexture( materialParams, 'specularMap', specGlossMapDef, sRGBEncoding ) );\n\n\t\t}\n\n\t\treturn Promise.all( pending );\n\n\t}\n\n\tcreateMaterial( materialParams ) {\n\n\t\tconst material = new GLTFMeshStandardSGMaterial( materialParams );\n\t\tmaterial.fog = true;\n\n\t\tmaterial.color = materialParams.color;\n\n\t\tmaterial.map = materialParams.map === undefined ? null : materialParams.map;\n\n\t\tmaterial.lightMap = null;\n\t\tmaterial.lightMapIntensity = 1.0;\n\n\t\tmaterial.aoMap = materialParams.aoMap === undefined ? null : materialParams.aoMap;\n\t\tmaterial.aoMapIntensity = 1.0;\n\n\t\tmaterial.emissive = materialParams.emissive;\n\t\tmaterial.emissiveIntensity = materialParams.emissiveIntensity === undefined ? 1.0 : materialParams.emissiveIntensity;\n\t\tmaterial.emissiveMap = materialParams.emissiveMap === undefined ? null : materialParams.emissiveMap;\n\n\t\tmaterial.bumpMap = materialParams.bumpMap === undefined ? null : materialParams.bumpMap;\n\t\tmaterial.bumpScale = 1;\n\n\t\tmaterial.normalMap = materialParams.normalMap === undefined ? null : materialParams.normalMap;\n\t\tmaterial.normalMapType = TangentSpaceNormalMap;\n\n\t\tif ( materialParams.normalScale ) material.normalScale = materialParams.normalScale;\n\n\t\tmaterial.displacementMap = null;\n\t\tmaterial.displacementScale = 1;\n\t\tmaterial.displacementBias = 0;\n\n\t\tmaterial.specularMap = materialParams.specularMap === undefined ? null : materialParams.specularMap;\n\t\tmaterial.specular = materialParams.specular;\n\n\t\tmaterial.glossinessMap = materialParams.glossinessMap === undefined ? null : materialParams.glossinessMap;\n\t\tmaterial.glossiness = materialParams.glossiness;\n\n\t\tmaterial.alphaMap = null;\n\n\t\tmaterial.envMap = materialParams.envMap === undefined ? null : materialParams.envMap;\n\t\tmaterial.envMapIntensity = 1.0;\n\n\t\treturn material;\n\n\t}\n\n}\n\n/**\n * Mesh Quantization Extension\n *\n * Specification: https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_mesh_quantization\n */\nclass GLTFMeshQuantizationExtension {\n\n\tconstructor() {\n\n\t\tthis.name = EXTENSIONS.KHR_MESH_QUANTIZATION;\n\n\t}\n\n}\n\n/*********************************/\n/********** INTERPOLATION ********/\n/*********************************/\n\n// Spline Interpolation\n// Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#appendix-c-spline-interpolation\nclass GLTFCubicSplineInterpolant extends Interpolant {\n\n\tconstructor( parameterPositions, sampleValues, sampleSize, resultBuffer ) {\n\n\t\tsuper( parameterPositions, sampleValues, sampleSize, resultBuffer );\n\n\t}\n\n\tcopySampleValue_( index ) {\n\n\t\t// Copies a sample value to the result buffer. See description of glTF\n\t\t// CUBICSPLINE values layout in interpolate_() function below.\n\n\t\tconst result = this.resultBuffer,\n\t\t\tvalues = this.sampleValues,\n\t\t\tvalueSize = this.valueSize,\n\t\t\toffset = index * valueSize * 3 + valueSize;\n\n\t\tfor ( let i = 0; i !== valueSize; i ++ ) {\n\n\t\t\tresult[ i ] = values[ offset + i ];\n\n\t\t}\n\n\t\treturn result;\n\n\t}\n\n}\n\nGLTFCubicSplineInterpolant.prototype.interpolate_ = function ( i1, t0, t, t1 ) {\n\n\tconst result = this.resultBuffer;\n\tconst values = this.sampleValues;\n\tconst stride = this.valueSize;\n\n\tconst stride2 = stride * 2;\n\tconst stride3 = stride * 3;\n\n\tconst td = t1 - t0;\n\n\tconst p = ( t - t0 ) / td;\n\tconst pp = p * p;\n\tconst ppp = pp * p;\n\n\tconst offset1 = i1 * stride3;\n\tconst offset0 = offset1 - stride3;\n\n\tconst s2 = - 2 * ppp + 3 * pp;\n\tconst s3 = ppp - pp;\n\tconst s0 = 1 - s2;\n\tconst s1 = s3 - pp + p;\n\n\t// Layout of keyframe output values for CUBICSPLINE animations:\n\t// [ inTangent_1, splineVertex_1, outTangent_1, inTangent_2, splineVertex_2, ... ]\n\tfor ( let i = 0; i !== stride; i ++ ) {\n\n\t\tconst p0 = values[ offset0 + i + stride ]; // splineVertex_k\n\t\tconst m0 = values[ offset0 + i + stride2 ] * td; // outTangent_k * (t_k+1 - t_k)\n\t\tconst p1 = values[ offset1 + i + stride ]; // splineVertex_k+1\n\t\tconst m1 = values[ offset1 + i ] * td; // inTangent_k+1 * (t_k+1 - t_k)\n\n\t\tresult[ i ] = s0 * p0 + s1 * m0 + s2 * p1 + s3 * m1;\n\n\t}\n\n\treturn result;\n\n};\n\nconst _q = new Quaternion();\n\nclass GLTFCubicSplineQuaternionInterpolant extends GLTFCubicSplineInterpolant {\n\n\tinterpolate_( i1, t0, t, t1 ) {\n\n\t\tconst result = super.interpolate_( i1, t0, t, t1 );\n\n\t\t_q.fromArray( result ).normalize().toArray( result );\n\n\t\treturn result;\n\n\t}\n\n}\n\n\n/*********************************/\n/********** INTERNALS ************/\n/*********************************/\n\n/* CONSTANTS */\n\nconst WEBGL_CONSTANTS = {\n\tFLOAT: 5126,\n\t//FLOAT_MAT2: 35674,\n\tFLOAT_MAT3: 35675,\n\tFLOAT_MAT4: 35676,\n\tFLOAT_VEC2: 35664,\n\tFLOAT_VEC3: 35665,\n\tFLOAT_VEC4: 35666,\n\tLINEAR: 9729,\n\tREPEAT: 10497,\n\tSAMPLER_2D: 35678,\n\tPOINTS: 0,\n\tLINES: 1,\n\tLINE_LOOP: 2,\n\tLINE_STRIP: 3,\n\tTRIANGLES: 4,\n\tTRIANGLE_STRIP: 5,\n\tTRIANGLE_FAN: 6,\n\tUNSIGNED_BYTE: 5121,\n\tUNSIGNED_SHORT: 5123\n};\n\nconst WEBGL_COMPONENT_TYPES = {\n\t5120: Int8Array,\n\t5121: Uint8Array,\n\t5122: Int16Array,\n\t5123: Uint16Array,\n\t5125: Uint32Array,\n\t5126: Float32Array\n};\n\nconst WEBGL_FILTERS = {\n\t9728: NearestFilter,\n\t9729: LinearFilter,\n\t9984: NearestMipmapNearestFilter,\n\t9985: LinearMipmapNearestFilter,\n\t9986: NearestMipmapLinearFilter,\n\t9987: LinearMipmapLinearFilter\n};\n\nconst WEBGL_WRAPPINGS = {\n\t33071: ClampToEdgeWrapping,\n\t33648: MirroredRepeatWrapping,\n\t10497: RepeatWrapping\n};\n\nconst WEBGL_TYPE_SIZES = {\n\t'SCALAR': 1,\n\t'VEC2': 2,\n\t'VEC3': 3,\n\t'VEC4': 4,\n\t'MAT2': 4,\n\t'MAT3': 9,\n\t'MAT4': 16\n};\n\nconst ATTRIBUTES = {\n\tPOSITION: 'position',\n\tNORMAL: 'normal',\n\tTANGENT: 'tangent',\n\tTEXCOORD_0: 'uv',\n\tTEXCOORD_1: 'uv2',\n\tCOLOR_0: 'color',\n\tWEIGHTS_0: 'skinWeight',\n\tJOINTS_0: 'skinIndex',\n};\n\nconst PATH_PROPERTIES = {\n\tscale: 'scale',\n\ttranslation: 'position',\n\trotation: 'quaternion',\n\tweights: 'morphTargetInfluences'\n};\n\nconst INTERPOLATION = {\n\tCUBICSPLINE: undefined, // We use a custom interpolant (GLTFCubicSplineInterpolation) for CUBICSPLINE tracks. Each\n\t\t // keyframe track will be initialized with a default interpolation type, then modified.\n\tLINEAR: InterpolateLinear,\n\tSTEP: InterpolateDiscrete\n};\n\nconst ALPHA_MODES = {\n\tOPAQUE: 'OPAQUE',\n\tMASK: 'MASK',\n\tBLEND: 'BLEND'\n};\n\n/**\n * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#default-material\n */\nfunction createDefaultMaterial( cache ) {\n\n\tif ( cache[ 'DefaultMaterial' ] === undefined ) {\n\n\t\tcache[ 'DefaultMaterial' ] = new MeshStandardMaterial( {\n\t\t\tcolor: 0xFFFFFF,\n\t\t\temissive: 0x000000,\n\t\t\tmetalness: 1,\n\t\t\troughness: 1,\n\t\t\ttransparent: false,\n\t\t\tdepthTest: true,\n\t\t\tside: FrontSide\n\t\t} );\n\n\t}\n\n\treturn cache[ 'DefaultMaterial' ];\n\n}\n\nfunction addUnknownExtensionsToUserData( knownExtensions, object, objectDef ) {\n\n\t// Add unknown glTF extensions to an object's userData.\n\n\tfor ( const name in objectDef.extensions ) {\n\n\t\tif ( knownExtensions[ name ] === undefined ) {\n\n\t\t\tobject.userData.gltfExtensions = object.userData.gltfExtensions || {};\n\t\t\tobject.userData.gltfExtensions[ name ] = objectDef.extensions[ name ];\n\n\t\t}\n\n\t}\n\n}\n\n/**\n * @param {Object3D|Material|BufferGeometry} object\n * @param {GLTF.definition} gltfDef\n */\nfunction assignExtrasToUserData( object, gltfDef ) {\n\n\tif ( gltfDef.extras !== undefined ) {\n\n\t\tif ( typeof gltfDef.extras === 'object' ) {\n\n\t\t\tObject.assign( object.userData, gltfDef.extras );\n\n\t\t} else {\n\n\t\t\tconsole.warn( 'THREE.GLTFLoader: Ignoring primitive type .extras, ' + gltfDef.extras );\n\n\t\t}\n\n\t}\n\n}\n\n/**\n * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#morph-targets\n *\n * @param {BufferGeometry} geometry\n * @param {Array} targets\n * @param {GLTFParser} parser\n * @return {Promise}\n */\nfunction addMorphTargets( geometry, targets, parser ) {\n\n\tlet hasMorphPosition = false;\n\tlet hasMorphNormal = false;\n\tlet hasMorphColor = false;\n\n\tfor ( let i = 0, il = targets.length; i < il; i ++ ) {\n\n\t\tconst target = targets[ i ];\n\n\t\tif ( target.POSITION !== undefined ) hasMorphPosition = true;\n\t\tif ( target.NORMAL !== undefined ) hasMorphNormal = true;\n\t\tif ( target.COLOR_0 !== undefined ) hasMorphColor = true;\n\n\t\tif ( hasMorphPosition && hasMorphNormal && hasMorphColor ) break;\n\n\t}\n\n\tif ( ! hasMorphPosition && ! hasMorphNormal && ! hasMorphColor ) return Promise.resolve( geometry );\n\n\tconst pendingPositionAccessors = [];\n\tconst pendingNormalAccessors = [];\n\tconst pendingColorAccessors = [];\n\n\tfor ( let i = 0, il = targets.length; i < il; i ++ ) {\n\n\t\tconst target = targets[ i ];\n\n\t\tif ( hasMorphPosition ) {\n\n\t\t\tconst pendingAccessor = target.POSITION !== undefined\n\t\t\t\t? parser.getDependency( 'accessor', target.POSITION )\n\t\t\t\t: geometry.attributes.position;\n\n\t\t\tpendingPositionAccessors.push( pendingAccessor );\n\n\t\t}\n\n\t\tif ( hasMorphNormal ) {\n\n\t\t\tconst pendingAccessor = target.NORMAL !== undefined\n\t\t\t\t? parser.getDependency( 'accessor', target.NORMAL )\n\t\t\t\t: geometry.attributes.normal;\n\n\t\t\tpendingNormalAccessors.push( pendingAccessor );\n\n\t\t}\n\n\t\tif ( hasMorphColor ) {\n\n\t\t\tconst pendingAccessor = target.COLOR_0 !== undefined\n\t\t\t\t? parser.getDependency( 'accessor', target.COLOR_0 )\n\t\t\t\t: geometry.attributes.color;\n\n\t\t\tpendingColorAccessors.push( pendingAccessor );\n\n\t\t}\n\n\t}\n\n\treturn Promise.all( [\n\t\tPromise.all( pendingPositionAccessors ),\n\t\tPromise.all( pendingNormalAccessors ),\n\t\tPromise.all( pendingColorAccessors )\n\t] ).then( function ( accessors ) {\n\n\t\tconst morphPositions = accessors[ 0 ];\n\t\tconst morphNormals = accessors[ 1 ];\n\t\tconst morphColors = accessors[ 2 ];\n\n\t\tif ( hasMorphPosition ) geometry.morphAttributes.position = morphPositions;\n\t\tif ( hasMorphNormal ) geometry.morphAttributes.normal = morphNormals;\n\t\tif ( hasMorphColor ) geometry.morphAttributes.color = morphColors;\n\t\tgeometry.morphTargetsRelative = true;\n\n\t\treturn geometry;\n\n\t} );\n\n}\n\n/**\n * @param {Mesh} mesh\n * @param {GLTF.Mesh} meshDef\n */\nfunction updateMorphTargets( mesh, meshDef ) {\n\n\tmesh.updateMorphTargets();\n\n\tif ( meshDef.weights !== undefined ) {\n\n\t\tfor ( let i = 0, il = meshDef.weights.length; i < il; i ++ ) {\n\n\t\t\tmesh.morphTargetInfluences[ i ] = meshDef.weights[ i ];\n\n\t\t}\n\n\t}\n\n\t// .extras has user-defined data, so check that .extras.targetNames is an array.\n\tif ( meshDef.extras && Array.isArray( meshDef.extras.targetNames ) ) {\n\n\t\tconst targetNames = meshDef.extras.targetNames;\n\n\t\tif ( mesh.morphTargetInfluences.length === targetNames.length ) {\n\n\t\t\tmesh.morphTargetDictionary = {};\n\n\t\t\tfor ( let i = 0, il = targetNames.length; i < il; i ++ ) {\n\n\t\t\t\tmesh.morphTargetDictionary[ targetNames[ i ] ] = i;\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tconsole.warn( 'THREE.GLTFLoader: Invalid extras.targetNames length. Ignoring names.' );\n\n\t\t}\n\n\t}\n\n}\n\nfunction createPrimitiveKey( primitiveDef ) {\n\n\tconst dracoExtension = primitiveDef.extensions && primitiveDef.extensions[ EXTENSIONS.KHR_DRACO_MESH_COMPRESSION ];\n\tlet geometryKey;\n\n\tif ( dracoExtension ) {\n\n\t\tgeometryKey = 'draco:' + dracoExtension.bufferView\n\t\t\t\t+ ':' + dracoExtension.indices\n\t\t\t\t+ ':' + createAttributesKey( dracoExtension.attributes );\n\n\t} else {\n\n\t\tgeometryKey = primitiveDef.indices + ':' + createAttributesKey( primitiveDef.attributes ) + ':' + primitiveDef.mode;\n\n\t}\n\n\treturn geometryKey;\n\n}\n\nfunction createAttributesKey( attributes ) {\n\n\tlet attributesKey = '';\n\n\tconst keys = Object.keys( attributes ).sort();\n\n\tfor ( let i = 0, il = keys.length; i < il; i ++ ) {\n\n\t\tattributesKey += keys[ i ] + ':' + attributes[ keys[ i ] ] + ';';\n\n\t}\n\n\treturn attributesKey;\n\n}\n\nfunction getNormalizedComponentScale( constructor ) {\n\n\t// Reference:\n\t// https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_mesh_quantization#encoding-quantized-data\n\n\tswitch ( constructor ) {\n\n\t\tcase Int8Array:\n\t\t\treturn 1 / 127;\n\n\t\tcase Uint8Array:\n\t\t\treturn 1 / 255;\n\n\t\tcase Int16Array:\n\t\t\treturn 1 / 32767;\n\n\t\tcase Uint16Array:\n\t\t\treturn 1 / 65535;\n\n\t\tdefault:\n\t\t\tthrow new Error( 'THREE.GLTFLoader: Unsupported normalized accessor component type.' );\n\n\t}\n\n}\n\nfunction getImageURIMimeType( uri ) {\n\n\tif ( uri.search( /\\.jpe?g($|\\?)/i ) > 0 || uri.search( /^data\\:image\\/jpeg/ ) === 0 ) return 'image/jpeg';\n\tif ( uri.search( /\\.webp($|\\?)/i ) > 0 || uri.search( /^data\\:image\\/webp/ ) === 0 ) return 'image/webp';\n\n\treturn 'image/png';\n\n}\n\n/* GLTF PARSER */\n\nclass GLTFParser {\n\n\tconstructor( json = {}, options = {} ) {\n\n\t\tthis.json = json;\n\t\tthis.extensions = {};\n\t\tthis.plugins = {};\n\t\tthis.options = options;\n\n\t\t// loader object cache\n\t\tthis.cache = new GLTFRegistry();\n\n\t\t// associations between Three.js objects and glTF elements\n\t\tthis.associations = new Map();\n\n\t\t// BufferGeometry caching\n\t\tthis.primitiveCache = {};\n\n\t\t// Object3D instance caches\n\t\tthis.meshCache = { refs: {}, uses: {} };\n\t\tthis.cameraCache = { refs: {}, uses: {} };\n\t\tthis.lightCache = { refs: {}, uses: {} };\n\n\t\tthis.sourceCache = {};\n\t\tthis.textureCache = {};\n\n\t\t// Track node names, to ensure no duplicates\n\t\tthis.nodeNamesUsed = {};\n\n\t\t// Use an ImageBitmapLoader if imageBitmaps are supported. Moves much of the\n\t\t// expensive work of uploading a texture to the GPU off the main thread.\n\n\t\tconst isSafari = /^((?!chrome|android).)*safari/i.test( navigator.userAgent ) === true;\n\t\tconst isFirefox = navigator.userAgent.indexOf( 'Firefox' ) > - 1;\n\t\tconst firefoxVersion = isFirefox ? navigator.userAgent.match( /Firefox\\/([0-9]+)\\./ )[ 1 ] : - 1;\n\n\t\tif ( typeof createImageBitmap === 'undefined' || isSafari || ( isFirefox && firefoxVersion < 98 ) ) {\n\n\t\t\tthis.textureLoader = new TextureLoader( this.options.manager );\n\n\t\t} else {\n\n\t\t\tthis.textureLoader = new ImageBitmapLoader( this.options.manager );\n\n\t\t}\n\n\t\tthis.textureLoader.setCrossOrigin( this.options.crossOrigin );\n\t\tthis.textureLoader.setRequestHeader( this.options.requestHeader );\n\n\t\tthis.fileLoader = new FileLoader( this.options.manager );\n\t\tthis.fileLoader.setResponseType( 'arraybuffer' );\n\n\t\tif ( this.options.crossOrigin === 'use-credentials' ) {\n\n\t\t\tthis.fileLoader.setWithCredentials( true );\n\n\t\t}\n\n\t}\n\n\tsetExtensions( extensions ) {\n\n\t\tthis.extensions = extensions;\n\n\t}\n\n\tsetPlugins( plugins ) {\n\n\t\tthis.plugins = plugins;\n\n\t}\n\n\tparse( onLoad, onError ) {\n\n\t\tconst parser = this;\n\t\tconst json = this.json;\n\t\tconst extensions = this.extensions;\n\n\t\t// Clear the loader cache\n\t\tthis.cache.removeAll();\n\n\t\t// Mark the special nodes/meshes in json for efficient parse\n\t\tthis._invokeAll( function ( ext ) {\n\n\t\t\treturn ext._markDefs && ext._markDefs();\n\n\t\t} );\n\n\t\tPromise.all( this._invokeAll( function ( ext ) {\n\n\t\t\treturn ext.beforeRoot && ext.beforeRoot();\n\n\t\t} ) ).then( function () {\n\n\t\t\treturn Promise.all( [\n\n\t\t\t\tparser.getDependencies( 'scene' ),\n\t\t\t\tparser.getDependencies( 'animation' ),\n\t\t\t\tparser.getDependencies( 'camera' ),\n\n\t\t\t] );\n\n\t\t} ).then( function ( dependencies ) {\n\n\t\t\tconst result = {\n\t\t\t\tscene: dependencies[ 0 ][ json.scene || 0 ],\n\t\t\t\tscenes: dependencies[ 0 ],\n\t\t\t\tanimations: dependencies[ 1 ],\n\t\t\t\tcameras: dependencies[ 2 ],\n\t\t\t\tasset: json.asset,\n\t\t\t\tparser: parser,\n\t\t\t\tuserData: {}\n\t\t\t};\n\n\t\t\taddUnknownExtensionsToUserData( extensions, result, json );\n\n\t\t\tassignExtrasToUserData( result, json );\n\n\t\t\tPromise.all( parser._invokeAll( function ( ext ) {\n\n\t\t\t\treturn ext.afterRoot && ext.afterRoot( result );\n\n\t\t\t} ) ).then( function () {\n\n\t\t\t\tonLoad( result );\n\n\t\t\t} );\n\n\t\t} ).catch( onError );\n\n\t}\n\n\t/**\n\t * Marks the special nodes/meshes in json for efficient parse.\n\t */\n\t_markDefs() {\n\n\t\tconst nodeDefs = this.json.nodes || [];\n\t\tconst skinDefs = this.json.skins || [];\n\t\tconst meshDefs = this.json.meshes || [];\n\n\t\t// Nothing in the node definition indicates whether it is a Bone or an\n\t\t// Object3D. Use the skins' joint references to mark bones.\n\t\tfor ( let skinIndex = 0, skinLength = skinDefs.length; skinIndex < skinLength; skinIndex ++ ) {\n\n\t\t\tconst joints = skinDefs[ skinIndex ].joints;\n\n\t\t\tfor ( let i = 0, il = joints.length; i < il; i ++ ) {\n\n\t\t\t\tnodeDefs[ joints[ i ] ].isBone = true;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// Iterate over all nodes, marking references to shared resources,\n\t\t// as well as skeleton joints.\n\t\tfor ( let nodeIndex = 0, nodeLength = nodeDefs.length; nodeIndex < nodeLength; nodeIndex ++ ) {\n\n\t\t\tconst nodeDef = nodeDefs[ nodeIndex ];\n\n\t\t\tif ( nodeDef.mesh !== undefined ) {\n\n\t\t\t\tthis._addNodeRef( this.meshCache, nodeDef.mesh );\n\n\t\t\t\t// Nothing in the mesh definition indicates whether it is\n\t\t\t\t// a SkinnedMesh or Mesh. Use the node's mesh reference\n\t\t\t\t// to mark SkinnedMesh if node has skin.\n\t\t\t\tif ( nodeDef.skin !== undefined ) {\n\n\t\t\t\t\tmeshDefs[ nodeDef.mesh ].isSkinnedMesh = true;\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( nodeDef.camera !== undefined ) {\n\n\t\t\t\tthis._addNodeRef( this.cameraCache, nodeDef.camera );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\t/**\n\t * Counts references to shared node / Object3D resources. These resources\n\t * can be reused, or \"instantiated\", at multiple nodes in the scene\n\t * hierarchy. Mesh, Camera, and Light instances are instantiated and must\n\t * be marked. Non-scenegraph resources (like Materials, Geometries, and\n\t * Textures) can be reused directly and are not marked here.\n\t *\n\t * Example: CesiumMilkTruck sample model reuses \"Wheel\" meshes.\n\t */\n\t_addNodeRef( cache, index ) {\n\n\t\tif ( index === undefined ) return;\n\n\t\tif ( cache.refs[ index ] === undefined ) {\n\n\t\t\tcache.refs[ index ] = cache.uses[ index ] = 0;\n\n\t\t}\n\n\t\tcache.refs[ index ] ++;\n\n\t}\n\n\t/** Returns a reference to a shared resource, cloning it if necessary. */\n\t_getNodeRef( cache, index, object ) {\n\n\t\tif ( cache.refs[ index ] <= 1 ) return object;\n\n\t\tconst ref = object.clone();\n\n\t\t// Propagates mappings to the cloned object, prevents mappings on the\n\t\t// original object from being lost.\n\t\tconst updateMappings = ( original, clone ) => {\n\n\t\t\tconst mappings = this.associations.get( original );\n\t\t\tif ( mappings != null ) {\n\n\t\t\t\tthis.associations.set( clone, mappings );\n\n\t\t\t}\n\n\t\t\tfor ( const [ i, child ] of original.children.entries() ) {\n\n\t\t\t\tupdateMappings( child, clone.children[ i ] );\n\n\t\t\t}\n\n\t\t};\n\n\t\tupdateMappings( object, ref );\n\n\t\tref.name += '_instance_' + ( cache.uses[ index ] ++ );\n\n\t\treturn ref;\n\n\t}\n\n\t_invokeOne( func ) {\n\n\t\tconst extensions = Object.values( this.plugins );\n\t\textensions.push( this );\n\n\t\tfor ( let i = 0; i < extensions.length; i ++ ) {\n\n\t\t\tconst result = func( extensions[ i ] );\n\n\t\t\tif ( result ) return result;\n\n\t\t}\n\n\t\treturn null;\n\n\t}\n\n\t_invokeAll( func ) {\n\n\t\tconst extensions = Object.values( this.plugins );\n\t\textensions.unshift( this );\n\n\t\tconst pending = [];\n\n\t\tfor ( let i = 0; i < extensions.length; i ++ ) {\n\n\t\t\tconst result = func( extensions[ i ] );\n\n\t\t\tif ( result ) pending.push( result );\n\n\t\t}\n\n\t\treturn pending;\n\n\t}\n\n\t/**\n\t * Requests the specified dependency asynchronously, with caching.\n\t * @param {string} type\n\t * @param {number} index\n\t * @return {Promise}\n\t */\n\tgetDependency( type, index ) {\n\n\t\tconst cacheKey = type + ':' + index;\n\t\tlet dependency = this.cache.get( cacheKey );\n\n\t\tif ( ! dependency ) {\n\n\t\t\tswitch ( type ) {\n\n\t\t\t\tcase 'scene':\n\t\t\t\t\tdependency = this.loadScene( index );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'node':\n\t\t\t\t\tdependency = this.loadNode( index );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'mesh':\n\t\t\t\t\tdependency = this._invokeOne( function ( ext ) {\n\n\t\t\t\t\t\treturn ext.loadMesh && ext.loadMesh( index );\n\n\t\t\t\t\t} );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'accessor':\n\t\t\t\t\tdependency = this.loadAccessor( index );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'bufferView':\n\t\t\t\t\tdependency = this._invokeOne( function ( ext ) {\n\n\t\t\t\t\t\treturn ext.loadBufferView && ext.loadBufferView( index );\n\n\t\t\t\t\t} );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'buffer':\n\t\t\t\t\tdependency = this.loadBuffer( index );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'material':\n\t\t\t\t\tdependency = this._invokeOne( function ( ext ) {\n\n\t\t\t\t\t\treturn ext.loadMaterial && ext.loadMaterial( index );\n\n\t\t\t\t\t} );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'texture':\n\t\t\t\t\tdependency = this._invokeOne( function ( ext ) {\n\n\t\t\t\t\t\treturn ext.loadTexture && ext.loadTexture( index );\n\n\t\t\t\t\t} );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'skin':\n\t\t\t\t\tdependency = this.loadSkin( index );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'animation':\n\t\t\t\t\tdependency = this._invokeOne( function ( ext ) {\n\n\t\t\t\t\t\treturn ext.loadAnimation && ext.loadAnimation( index );\n\n\t\t\t\t\t} );\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'camera':\n\t\t\t\t\tdependency = this.loadCamera( index );\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\n\t\t\t\t\tthrow new Error( 'Unknown type: ' + type );\n\n\t\t\t}\n\n\t\t\tthis.cache.add( cacheKey, dependency );\n\n\t\t}\n\n\t\treturn dependency;\n\n\t}\n\n\t/**\n\t * Requests all dependencies of the specified type asynchronously, with caching.\n\t * @param {string} type\n\t * @return {Promise>}\n\t */\n\tgetDependencies( type ) {\n\n\t\tlet dependencies = this.cache.get( type );\n\n\t\tif ( ! dependencies ) {\n\n\t\t\tconst parser = this;\n\t\t\tconst defs = this.json[ type + ( type === 'mesh' ? 'es' : 's' ) ] || [];\n\n\t\t\tdependencies = Promise.all( defs.map( function ( def, index ) {\n\n\t\t\t\treturn parser.getDependency( type, index );\n\n\t\t\t} ) );\n\n\t\t\tthis.cache.add( type, dependencies );\n\n\t\t}\n\n\t\treturn dependencies;\n\n\t}\n\n\t/**\n\t * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#buffers-and-buffer-views\n\t * @param {number} bufferIndex\n\t * @return {Promise}\n\t */\n\tloadBuffer( bufferIndex ) {\n\n\t\tconst bufferDef = this.json.buffers[ bufferIndex ];\n\t\tconst loader = this.fileLoader;\n\n\t\tif ( bufferDef.type && bufferDef.type !== 'arraybuffer' ) {\n\n\t\t\tthrow new Error( 'THREE.GLTFLoader: ' + bufferDef.type + ' buffer type is not supported.' );\n\n\t\t}\n\n\t\t// If present, GLB container is required to be the first buffer.\n\t\tif ( bufferDef.uri === undefined && bufferIndex === 0 ) {\n\n\t\t\treturn Promise.resolve( this.extensions[ EXTENSIONS.KHR_BINARY_GLTF ].body );\n\n\t\t}\n\n\t\tconst options = this.options;\n\n\t\treturn new Promise( function ( resolve, reject ) {\n\n\t\t\tloader.load( LoaderUtils.resolveURL( bufferDef.uri, options.path ), resolve, undefined, function () {\n\n\t\t\t\treject( new Error( 'THREE.GLTFLoader: Failed to load buffer \"' + bufferDef.uri + '\".' ) );\n\n\t\t\t} );\n\n\t\t} );\n\n\t}\n\n\t/**\n\t * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#buffers-and-buffer-views\n\t * @param {number} bufferViewIndex\n\t * @return {Promise}\n\t */\n\tloadBufferView( bufferViewIndex ) {\n\n\t\tconst bufferViewDef = this.json.bufferViews[ bufferViewIndex ];\n\n\t\treturn this.getDependency( 'buffer', bufferViewDef.buffer ).then( function ( buffer ) {\n\n\t\t\tconst byteLength = bufferViewDef.byteLength || 0;\n\t\t\tconst byteOffset = bufferViewDef.byteOffset || 0;\n\t\t\treturn buffer.slice( byteOffset, byteOffset + byteLength );\n\n\t\t} );\n\n\t}\n\n\t/**\n\t * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#accessors\n\t * @param {number} accessorIndex\n\t * @return {Promise}\n\t */\n\tloadAccessor( accessorIndex ) {\n\n\t\tconst parser = this;\n\t\tconst json = this.json;\n\n\t\tconst accessorDef = this.json.accessors[ accessorIndex ];\n\n\t\tif ( accessorDef.bufferView === undefined && accessorDef.sparse === undefined ) {\n\n\t\t\t// Ignore empty accessors, which may be used to declare runtime\n\t\t\t// information about attributes coming from another source (e.g. Draco\n\t\t\t// compression extension).\n\t\t\treturn Promise.resolve( null );\n\n\t\t}\n\n\t\tconst pendingBufferViews = [];\n\n\t\tif ( accessorDef.bufferView !== undefined ) {\n\n\t\t\tpendingBufferViews.push( this.getDependency( 'bufferView', accessorDef.bufferView ) );\n\n\t\t} else {\n\n\t\t\tpendingBufferViews.push( null );\n\n\t\t}\n\n\t\tif ( accessorDef.sparse !== undefined ) {\n\n\t\t\tpendingBufferViews.push( this.getDependency( 'bufferView', accessorDef.sparse.indices.bufferView ) );\n\t\t\tpendingBufferViews.push( this.getDependency( 'bufferView', accessorDef.sparse.values.bufferView ) );\n\n\t\t}\n\n\t\treturn Promise.all( pendingBufferViews ).then( function ( bufferViews ) {\n\n\t\t\tconst bufferView = bufferViews[ 0 ];\n\n\t\t\tconst itemSize = WEBGL_TYPE_SIZES[ accessorDef.type ];\n\t\t\tconst TypedArray = WEBGL_COMPONENT_TYPES[ accessorDef.componentType ];\n\n\t\t\t// For VEC3: itemSize is 3, elementBytes is 4, itemBytes is 12.\n\t\t\tconst elementBytes = TypedArray.BYTES_PER_ELEMENT;\n\t\t\tconst itemBytes = elementBytes * itemSize;\n\t\t\tconst byteOffset = accessorDef.byteOffset || 0;\n\t\t\tconst byteStride = accessorDef.bufferView !== undefined ? json.bufferViews[ accessorDef.bufferView ].byteStride : undefined;\n\t\t\tconst normalized = accessorDef.normalized === true;\n\t\t\tlet array, bufferAttribute;\n\n\t\t\t// The buffer is not interleaved if the stride is the item size in bytes.\n\t\t\tif ( byteStride && byteStride !== itemBytes ) {\n\n\t\t\t\t// Each \"slice\" of the buffer, as defined by 'count' elements of 'byteStride' bytes, gets its own InterleavedBuffer\n\t\t\t\t// This makes sure that IBA.count reflects accessor.count properly\n\t\t\t\tconst ibSlice = Math.floor( byteOffset / byteStride );\n\t\t\t\tconst ibCacheKey = 'InterleavedBuffer:' + accessorDef.bufferView + ':' + accessorDef.componentType + ':' + ibSlice + ':' + accessorDef.count;\n\t\t\t\tlet ib = parser.cache.get( ibCacheKey );\n\n\t\t\t\tif ( ! ib ) {\n\n\t\t\t\t\tarray = new TypedArray( bufferView, ibSlice * byteStride, accessorDef.count * byteStride / elementBytes );\n\n\t\t\t\t\t// Integer parameters to IB/IBA are in array elements, not bytes.\n\t\t\t\t\tib = new InterleavedBuffer( array, byteStride / elementBytes );\n\n\t\t\t\t\tparser.cache.add( ibCacheKey, ib );\n\n\t\t\t\t}\n\n\t\t\t\tbufferAttribute = new InterleavedBufferAttribute( ib, itemSize, ( byteOffset % byteStride ) / elementBytes, normalized );\n\n\t\t\t} else {\n\n\t\t\t\tif ( bufferView === null ) {\n\n\t\t\t\t\tarray = new TypedArray( accessorDef.count * itemSize );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tarray = new TypedArray( bufferView, byteOffset, accessorDef.count * itemSize );\n\n\t\t\t\t}\n\n\t\t\t\tbufferAttribute = new BufferAttribute( array, itemSize, normalized );\n\n\t\t\t}\n\n\t\t\t// https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#sparse-accessors\n\t\t\tif ( accessorDef.sparse !== undefined ) {\n\n\t\t\t\tconst itemSizeIndices = WEBGL_TYPE_SIZES.SCALAR;\n\t\t\t\tconst TypedArrayIndices = WEBGL_COMPONENT_TYPES[ accessorDef.sparse.indices.componentType ];\n\n\t\t\t\tconst byteOffsetIndices = accessorDef.sparse.indices.byteOffset || 0;\n\t\t\t\tconst byteOffsetValues = accessorDef.sparse.values.byteOffset || 0;\n\n\t\t\t\tconst sparseIndices = new TypedArrayIndices( bufferViews[ 1 ], byteOffsetIndices, accessorDef.sparse.count * itemSizeIndices );\n\t\t\t\tconst sparseValues = new TypedArray( bufferViews[ 2 ], byteOffsetValues, accessorDef.sparse.count * itemSize );\n\n\t\t\t\tif ( bufferView !== null ) {\n\n\t\t\t\t\t// Avoid modifying the original ArrayBuffer, if the bufferView wasn't initialized with zeroes.\n\t\t\t\t\tbufferAttribute = new BufferAttribute( bufferAttribute.array.slice(), bufferAttribute.itemSize, bufferAttribute.normalized );\n\n\t\t\t\t}\n\n\t\t\t\tfor ( let i = 0, il = sparseIndices.length; i < il; i ++ ) {\n\n\t\t\t\t\tconst index = sparseIndices[ i ];\n\n\t\t\t\t\tbufferAttribute.setX( index, sparseValues[ i * itemSize ] );\n\t\t\t\t\tif ( itemSize >= 2 ) bufferAttribute.setY( index, sparseValues[ i * itemSize + 1 ] );\n\t\t\t\t\tif ( itemSize >= 3 ) bufferAttribute.setZ( index, sparseValues[ i * itemSize + 2 ] );\n\t\t\t\t\tif ( itemSize >= 4 ) bufferAttribute.setW( index, sparseValues[ i * itemSize + 3 ] );\n\t\t\t\t\tif ( itemSize >= 5 ) throw new Error( 'THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute.' );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn bufferAttribute;\n\n\t\t} );\n\n\t}\n\n\t/**\n\t * Specification: https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#textures\n\t * @param {number} textureIndex\n\t * @return {Promise}\n\t */\n\tloadTexture( textureIndex ) {\n\n\t\tconst json = this.json;\n\t\tconst options = this.options;\n\t\tconst textureDef = json.textures[ textureIndex ];\n\t\tconst sourceIndex = textureDef.source;\n\t\tconst sourceDef = json.images[ sourceIndex ];\n\n\t\tlet loader = this.textureLoader;\n\n\t\tif ( sourceDef.uri ) {\n\n\t\t\tconst handler = options.manager.getHandler( sourceDef.uri );\n\t\t\tif ( handler !== null ) loader = handler;\n\n\t\t}\n\n\t\treturn this.loadTextureImage( textureIndex, sourceIndex, loader );\n\n\t}\n\n\tloadTextureImage( textureIndex, sourceIndex, loader ) {\n\n\t\tconst parser = this;\n\t\tconst json = this.json;\n\n\t\tconst textureDef = json.textures[ textureIndex ];\n\t\tconst sourceDef = json.images[ sourceIndex ];\n\n\t\tconst cacheKey = ( sourceDef.uri || sourceDef.bufferView ) + ':' + textureDef.sampler;\n\n\t\tif ( this.textureCache[ cacheKey ] ) {\n\n\t\t\t// See https://github.com/mrdoob/three.js/issues/21559.\n\t\t\treturn this.textureCache[ cacheKey ];\n\n\t\t}\n\n\t\tconst promise = this.loadImageSource( sourceIndex, loader ).then( function ( texture ) {\n\n\t\t\ttexture.flipY = false;\n\n\t\t\tif ( textureDef.name ) texture.name = textureDef.name;\n\n\t\t\tconst samplers = json.samplers || {};\n\t\t\tconst sampler = samplers[ textureDef.sampler ] || {};\n\n\t\t\ttexture.magFilter = WEBGL_FILTERS[ sampler.magFilter ] || LinearFilter;\n\t\t\ttexture.minFilter = WEBGL_FILTERS[ sampler.minFilter ] || LinearMipmapLinearFilter;\n\t\t\ttexture.wrapS = WEBGL_WRAPPINGS[ sampler.wrapS ] || RepeatWrapping;\n\t\t\ttexture.wrapT = WEBGL_WRAPPINGS[ sampler.wrapT ] || RepeatWrapping;\n\n\t\t\tparser.associations.set( texture, { textures: textureIndex } );\n\n\t\t\treturn texture;\n\n\t\t} ).catch( function () {\n\n\t\t\treturn null;\n\n\t\t} );\n\n\t\tthis.textureCache[ cacheKey ] = promise;\n\n\t\treturn promise;\n\n\t}\n\n\tloadImageSource( sourceIndex, loader ) {\n\n\t\tconst parser = this;\n\t\tconst json = this.json;\n\t\tconst options = this.options;\n\n\t\tif ( this.sourceCache[ sourceIndex ] !== undefined ) {\n\n\t\t\treturn this.sourceCache[ sourceIndex ].then( ( texture ) => texture.clone() );\n\n\t\t}\n\n\t\tconst sourceDef = json.images[ sourceIndex ];\n\n\t\tconst URL = self.URL || self.webkitURL;\n\n\t\tlet sourceURI = sourceDef.uri || '';\n\t\tlet isObjectURL = false;\n\n\t\tif ( sourceDef.bufferView !== undefined ) {\n\n\t\t\t// Load binary image data from bufferView, if provided.\n\n\t\t\tsourceURI = parser.getDependency( 'bufferView', sourceDef.bufferView ).then( function ( bufferView ) {\n\n\t\t\t\tisObjectURL = true;\n\t\t\t\tconst blob = new Blob( [ bufferView ], { type: sourceDef.mimeType } );\n\t\t\t\tsourceURI = URL.createObjectURL( blob );\n\t\t\t\treturn sourceURI;\n\n\t\t\t} );\n\n\t\t} else if ( sourceDef.uri === undefined ) {\n\n\t\t\tthrow new Error( 'THREE.GLTFLoader: Image ' + sourceIndex + ' is missing URI and bufferView' );\n\n\t\t}\n\n\t\tconst promise = Promise.resolve( sourceURI ).then( function ( sourceURI ) {\n\n\t\t\treturn new Promise( function ( resolve, reject ) {\n\n\t\t\t\tlet onLoad = resolve;\n\n\t\t\t\tif ( loader.isImageBitmapLoader === true ) {\n\n\t\t\t\t\tonLoad = function ( imageBitmap ) {\n\n\t\t\t\t\t\tconst texture = new Texture( imageBitmap );\n\t\t\t\t\t\ttexture.needsUpdate = true;\n\n\t\t\t\t\t\tresolve( texture );\n\n\t\t\t\t\t};\n\n\t\t\t\t}\n\n\t\t\t\tloader.load( LoaderUtils.resolveURL( sourceURI, options.path ), onLoad, undefined, reject );\n\n\t\t\t} );\n\n\t\t} ).then( function ( texture ) {\n\n\t\t\t// Clean up resources and configure Texture.\n\n\t\t\tif ( isObjectURL === true ) {\n\n\t\t\t\tURL.revokeObjectURL( sourceURI );\n\n\t\t\t}\n\n\t\t\ttexture.userData.mimeType = sourceDef.mimeType || getImageURIMimeType( sourceDef.uri );\n\n\t\t\treturn texture;\n\n\t\t} ).catch( function ( error ) {\n\n\t\t\tconsole.error( 'THREE.GLTFLoader: Couldn\\'t load texture', sourceURI );\n\t\t\tthrow error;\n\n\t\t} );\n\n\t\tthis.sourceCache[ sourceIndex ] = promise;\n\t\treturn promise;\n\n\t}\n\n\t/**\n\t * Asynchronously assigns a texture to the given material parameters.\n\t * @param {Object} materialParams\n\t * @param {string} mapName\n\t * @param {Object} mapDef\n\t * @return {Promise}\n\t */\n\tassignTexture( materialParams, mapName, mapDef, encoding ) {\n\n\t\tconst parser = this;\n\n\t\treturn this.getDependency( 'texture', mapDef.index ).then( function ( texture ) {\n\n\t\t\t// Materials sample aoMap from UV set 1 and other maps from UV set 0 - this can't be configured\n\t\t\t// However, we will copy UV set 0 to UV set 1 on demand for aoMap\n\t\t\tif ( mapDef.texCoord !== undefined && mapDef.texCoord != 0 && ! ( mapName === 'aoMap' && mapDef.texCoord == 1 ) ) {\n\n\t\t\t\tconsole.warn( 'THREE.GLTFLoader: Custom UV set ' + mapDef.texCoord + ' for texture ' + mapName + ' not yet supported.' );\n\n\t\t\t}\n\n\t\t\tif ( parser.extensions[ EXTENSIONS.KHR_TEXTURE_TRANSFORM ] ) {\n\n\t\t\t\tconst transform = mapDef.extensions !== undefined ? mapDef.extensions[ EXTENSIONS.KHR_TEXTURE_TRANSFORM ] : undefined;\n\n\t\t\t\tif ( transform ) {\n\n\t\t\t\t\tconst gltfReference = parser.associations.get( texture );\n\t\t\t\t\ttexture = parser.extensions[ EXTENSIONS.KHR_TEXTURE_TRANSFORM ].extendTexture( texture, transform );\n\t\t\t\t\tparser.associations.set( texture, gltfReference );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( encoding !== undefined ) {\n\n\t\t\t\ttexture.encoding = encoding;\n\n\t\t\t}\n\n\t\t\tmaterialParams[ mapName ] = texture;\n\n\t\t\treturn texture;\n\n\t\t} );\n\n\t}\n\n\t/**\n\t * Assigns final material to a Mesh, Line, or Points instance. The instance\n\t * already has a material (generated from the glTF material options alone)\n\t * but reuse of the same glTF material may require multiple threejs materials\n\t * to accommodate different primitive types, defines, etc. New materials will\n\t * be created if necessary, and reused from a cache.\n\t * @param {Object3D} mesh Mesh, Line, or Points instance.\n\t */\n\tassignFinalMaterial( mesh ) {\n\n\t\tconst geometry = mesh.geometry;\n\t\tlet material = mesh.material;\n\n\t\tconst useDerivativeTangents = geometry.attributes.tangent === undefined;\n\t\tconst useVertexColors = geometry.attributes.color !== undefined;\n\t\tconst useFlatShading = geometry.attributes.normal === undefined;\n\n\t\tif ( mesh.isPoints ) {\n\n\t\t\tconst cacheKey = 'PointsMaterial:' + material.uuid;\n\n\t\t\tlet pointsMaterial = this.cache.get( cacheKey );\n\n\t\t\tif ( ! pointsMaterial ) {\n\n\t\t\t\tpointsMaterial = new PointsMaterial();\n\t\t\t\tMaterial.prototype.copy.call( pointsMaterial, material );\n\t\t\t\tpointsMaterial.color.copy( material.color );\n\t\t\t\tpointsMaterial.map = material.map;\n\t\t\t\tpointsMaterial.sizeAttenuation = false; // glTF spec says points should be 1px\n\n\t\t\t\tthis.cache.add( cacheKey, pointsMaterial );\n\n\t\t\t}\n\n\t\t\tmaterial = pointsMaterial;\n\n\t\t} else if ( mesh.isLine ) {\n\n\t\t\tconst cacheKey = 'LineBasicMaterial:' + material.uuid;\n\n\t\t\tlet lineMaterial = this.cache.get( cacheKey );\n\n\t\t\tif ( ! lineMaterial ) {\n\n\t\t\t\tlineMaterial = new LineBasicMaterial();\n\t\t\t\tMaterial.prototype.copy.call( lineMaterial, material );\n\t\t\t\tlineMaterial.color.copy( material.color );\n\n\t\t\t\tthis.cache.add( cacheKey, lineMaterial );\n\n\t\t\t}\n\n\t\t\tmaterial = lineMaterial;\n\n\t\t}\n\n\t\t// Clone the material if it will be modified\n\t\tif ( useDerivativeTangents || useVertexColors || useFlatShading ) {\n\n\t\t\tlet cacheKey = 'ClonedMaterial:' + material.uuid + ':';\n\n\t\t\tif ( material.isGLTFSpecularGlossinessMaterial ) cacheKey += 'specular-glossiness:';\n\t\t\tif ( useDerivativeTangents ) cacheKey += 'derivative-tangents:';\n\t\t\tif ( useVertexColors ) cacheKey += 'vertex-colors:';\n\t\t\tif ( useFlatShading ) cacheKey += 'flat-shading:';\n\n\t\t\tlet cachedMaterial = this.cache.get( cacheKey );\n\n\t\t\tif ( ! cachedMaterial ) {\n\n\t\t\t\tcachedMaterial = material.clone();\n\n\t\t\t\tif ( useVertexColors ) cachedMaterial.vertexColors = true;\n\t\t\t\tif ( useFlatShading ) cachedMaterial.flatShading = true;\n\n\t\t\t\tif ( useDerivativeTangents ) {\n\n\t\t\t\t\t// https://github.com/mrdoob/three.js/issues/11438#issuecomment-507003995\n\t\t\t\t\tif ( cachedMaterial.normalScale ) cachedMaterial.normalScale.y *= - 1;\n\t\t\t\t\tif ( cachedMaterial.clearcoatNormalScale ) cachedMaterial.clearcoatNormalScale.y *= - 1;\n\n\t\t\t\t}\n\n\t\t\t\tthis.cache.add( cacheKey, cachedMaterial );\n\n\t\t\t\tthis.associations.set( cachedMaterial, this.associations.get( material ) );\n\n\t\t\t}\n\n\t\t\tmaterial = cachedMaterial;\n\n\t\t}\n\n\t\t// workarounds for mesh and geometry\n\n\t\tif ( material.aoMap && geometry.attributes.uv2 === undefined && geometry.attributes.uv !== undefined ) {\n\n\t\t\tgeometry.setAttribute( 'uv2', geometry.attributes.uv );\n\n\t\t}\n\n\t\tmesh.material = material;\n\n\t}\n\n\tgetMaterialType( /* materialIndex */ ) {\n\n\t\treturn MeshStandardMaterial;\n\n\t}\n\n\t/**\n\t * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#materials\n\t * @param {number} materialIndex\n\t * @return {Promise}\n\t */\n\tloadMaterial( materialIndex ) {\n\n\t\tconst parser = this;\n\t\tconst json = this.json;\n\t\tconst extensions = this.extensions;\n\t\tconst materialDef = json.materials[ materialIndex ];\n\n\t\tlet materialType;\n\t\tconst materialParams = {};\n\t\tconst materialExtensions = materialDef.extensions || {};\n\n\t\tconst pending = [];\n\n\t\tif ( materialExtensions[ EXTENSIONS.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS ] ) {\n\n\t\t\tconst sgExtension = extensions[ EXTENSIONS.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS ];\n\t\t\tmaterialType = sgExtension.getMaterialType();\n\t\t\tpending.push( sgExtension.extendParams( materialParams, materialDef, parser ) );\n\n\t\t} else if ( materialExtensions[ EXTENSIONS.KHR_MATERIALS_UNLIT ] ) {\n\n\t\t\tconst kmuExtension = extensions[ EXTENSIONS.KHR_MATERIALS_UNLIT ];\n\t\t\tmaterialType = kmuExtension.getMaterialType();\n\t\t\tpending.push( kmuExtension.extendParams( materialParams, materialDef, parser ) );\n\n\t\t} else {\n\n\t\t\t// Specification:\n\t\t\t// https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#metallic-roughness-material\n\n\t\t\tconst metallicRoughness = materialDef.pbrMetallicRoughness || {};\n\n\t\t\tmaterialParams.color = new Color( 1.0, 1.0, 1.0 );\n\t\t\tmaterialParams.opacity = 1.0;\n\n\t\t\tif ( Array.isArray( metallicRoughness.baseColorFactor ) ) {\n\n\t\t\t\tconst array = metallicRoughness.baseColorFactor;\n\n\t\t\t\tmaterialParams.color.fromArray( array );\n\t\t\t\tmaterialParams.opacity = array[ 3 ];\n\n\t\t\t}\n\n\t\t\tif ( metallicRoughness.baseColorTexture !== undefined ) {\n\n\t\t\t\tpending.push( parser.assignTexture( materialParams, 'map', metallicRoughness.baseColorTexture, sRGBEncoding ) );\n\n\t\t\t}\n\n\t\t\tmaterialParams.metalness = metallicRoughness.metallicFactor !== undefined ? metallicRoughness.metallicFactor : 1.0;\n\t\t\tmaterialParams.roughness = metallicRoughness.roughnessFactor !== undefined ? metallicRoughness.roughnessFactor : 1.0;\n\n\t\t\tif ( metallicRoughness.metallicRoughnessTexture !== undefined ) {\n\n\t\t\t\tpending.push( parser.assignTexture( materialParams, 'metalnessMap', metallicRoughness.metallicRoughnessTexture ) );\n\t\t\t\tpending.push( parser.assignTexture( materialParams, 'roughnessMap', metallicRoughness.metallicRoughnessTexture ) );\n\n\t\t\t}\n\n\t\t\tmaterialType = this._invokeOne( function ( ext ) {\n\n\t\t\t\treturn ext.getMaterialType && ext.getMaterialType( materialIndex );\n\n\t\t\t} );\n\n\t\t\tpending.push( Promise.all( this._invokeAll( function ( ext ) {\n\n\t\t\t\treturn ext.extendMaterialParams && ext.extendMaterialParams( materialIndex, materialParams );\n\n\t\t\t} ) ) );\n\n\t\t}\n\n\t\tif ( materialDef.doubleSided === true ) {\n\n\t\t\tmaterialParams.side = DoubleSide;\n\n\t\t}\n\n\t\tconst alphaMode = materialDef.alphaMode || ALPHA_MODES.OPAQUE;\n\n\t\tif ( alphaMode === ALPHA_MODES.BLEND ) {\n\n\t\t\tmaterialParams.transparent = true;\n\n\t\t\t// See: https://github.com/mrdoob/three.js/issues/17706\n\t\t\tmaterialParams.depthWrite = false;\n\n\t\t} else {\n\n\t\t\tmaterialParams.transparent = false;\n\n\t\t\tif ( alphaMode === ALPHA_MODES.MASK ) {\n\n\t\t\t\tmaterialParams.alphaTest = materialDef.alphaCutoff !== undefined ? materialDef.alphaCutoff : 0.5;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( materialDef.normalTexture !== undefined && materialType !== MeshBasicMaterial ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'normalMap', materialDef.normalTexture ) );\n\n\t\t\tmaterialParams.normalScale = new Vector2( 1, 1 );\n\n\t\t\tif ( materialDef.normalTexture.scale !== undefined ) {\n\n\t\t\t\tconst scale = materialDef.normalTexture.scale;\n\n\t\t\t\tmaterialParams.normalScale.set( scale, scale );\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( materialDef.occlusionTexture !== undefined && materialType !== MeshBasicMaterial ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'aoMap', materialDef.occlusionTexture ) );\n\n\t\t\tif ( materialDef.occlusionTexture.strength !== undefined ) {\n\n\t\t\t\tmaterialParams.aoMapIntensity = materialDef.occlusionTexture.strength;\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( materialDef.emissiveFactor !== undefined && materialType !== MeshBasicMaterial ) {\n\n\t\t\tmaterialParams.emissive = new Color().fromArray( materialDef.emissiveFactor );\n\n\t\t}\n\n\t\tif ( materialDef.emissiveTexture !== undefined && materialType !== MeshBasicMaterial ) {\n\n\t\t\tpending.push( parser.assignTexture( materialParams, 'emissiveMap', materialDef.emissiveTexture, sRGBEncoding ) );\n\n\t\t}\n\n\t\treturn Promise.all( pending ).then( function () {\n\n\t\t\tlet material;\n\n\t\t\tif ( materialType === GLTFMeshStandardSGMaterial ) {\n\n\t\t\t\tmaterial = extensions[ EXTENSIONS.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS ].createMaterial( materialParams );\n\n\t\t\t} else {\n\n\t\t\t\tmaterial = new materialType( materialParams );\n\n\t\t\t}\n\n\t\t\tif ( materialDef.name ) material.name = materialDef.name;\n\n\t\t\tassignExtrasToUserData( material, materialDef );\n\n\t\t\tparser.associations.set( material, { materials: materialIndex } );\n\n\t\t\tif ( materialDef.extensions ) addUnknownExtensionsToUserData( extensions, material, materialDef );\n\n\t\t\treturn material;\n\n\t\t} );\n\n\t}\n\n\t/** When Object3D instances are targeted by animation, they need unique names. */\n\tcreateUniqueName( originalName ) {\n\n\t\tconst sanitizedName = PropertyBinding.sanitizeNodeName( originalName || '' );\n\n\t\tlet name = sanitizedName;\n\n\t\tfor ( let i = 1; this.nodeNamesUsed[ name ]; ++ i ) {\n\n\t\t\tname = sanitizedName + '_' + i;\n\n\t\t}\n\n\t\tthis.nodeNamesUsed[ name ] = true;\n\n\t\treturn name;\n\n\t}\n\n\t/**\n\t * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#geometry\n\t *\n\t * Creates BufferGeometries from primitives.\n\t *\n\t * @param {Array} primitives\n\t * @return {Promise>}\n\t */\n\tloadGeometries( primitives ) {\n\n\t\tconst parser = this;\n\t\tconst extensions = this.extensions;\n\t\tconst cache = this.primitiveCache;\n\n\t\tfunction createDracoPrimitive( primitive ) {\n\n\t\t\treturn extensions[ EXTENSIONS.KHR_DRACO_MESH_COMPRESSION ]\n\t\t\t\t.decodePrimitive( primitive, parser )\n\t\t\t\t.then( function ( geometry ) {\n\n\t\t\t\t\treturn addPrimitiveAttributes( geometry, primitive, parser );\n\n\t\t\t\t} );\n\n\t\t}\n\n\t\tconst pending = [];\n\n\t\tfor ( let i = 0, il = primitives.length; i < il; i ++ ) {\n\n\t\t\tconst primitive = primitives[ i ];\n\t\t\tconst cacheKey = createPrimitiveKey( primitive );\n\n\t\t\t// See if we've already created this geometry\n\t\t\tconst cached = cache[ cacheKey ];\n\n\t\t\tif ( cached ) {\n\n\t\t\t\t// Use the cached geometry if it exists\n\t\t\t\tpending.push( cached.promise );\n\n\t\t\t} else {\n\n\t\t\t\tlet geometryPromise;\n\n\t\t\t\tif ( primitive.extensions && primitive.extensions[ EXTENSIONS.KHR_DRACO_MESH_COMPRESSION ] ) {\n\n\t\t\t\t\t// Use DRACO geometry if available\n\t\t\t\t\tgeometryPromise = createDracoPrimitive( primitive );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t// Otherwise create a new geometry\n\t\t\t\t\tgeometryPromise = addPrimitiveAttributes( new BufferGeometry(), primitive, parser );\n\n\t\t\t\t}\n\n\t\t\t\t// Cache this geometry\n\t\t\t\tcache[ cacheKey ] = { primitive: primitive, promise: geometryPromise };\n\n\t\t\t\tpending.push( geometryPromise );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn Promise.all( pending );\n\n\t}\n\n\t/**\n\t * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#meshes\n\t * @param {number} meshIndex\n\t * @return {Promise}\n\t */\n\tloadMesh( meshIndex ) {\n\n\t\tconst parser = this;\n\t\tconst json = this.json;\n\t\tconst extensions = this.extensions;\n\n\t\tconst meshDef = json.meshes[ meshIndex ];\n\t\tconst primitives = meshDef.primitives;\n\n\t\tconst pending = [];\n\n\t\tfor ( let i = 0, il = primitives.length; i < il; i ++ ) {\n\n\t\t\tconst material = primitives[ i ].material === undefined\n\t\t\t\t? createDefaultMaterial( this.cache )\n\t\t\t\t: this.getDependency( 'material', primitives[ i ].material );\n\n\t\t\tpending.push( material );\n\n\t\t}\n\n\t\tpending.push( parser.loadGeometries( primitives ) );\n\n\t\treturn Promise.all( pending ).then( function ( results ) {\n\n\t\t\tconst materials = results.slice( 0, results.length - 1 );\n\t\t\tconst geometries = results[ results.length - 1 ];\n\n\t\t\tconst meshes = [];\n\n\t\t\tfor ( let i = 0, il = geometries.length; i < il; i ++ ) {\n\n\t\t\t\tconst geometry = geometries[ i ];\n\t\t\t\tconst primitive = primitives[ i ];\n\n\t\t\t\t// 1. create Mesh\n\n\t\t\t\tlet mesh;\n\n\t\t\t\tconst material = materials[ i ];\n\n\t\t\t\tif ( primitive.mode === WEBGL_CONSTANTS.TRIANGLES ||\n\t\t\t\t\t\tprimitive.mode === WEBGL_CONSTANTS.TRIANGLE_STRIP ||\n\t\t\t\t\t\tprimitive.mode === WEBGL_CONSTANTS.TRIANGLE_FAN ||\n\t\t\t\t\t\tprimitive.mode === undefined ) {\n\n\t\t\t\t\t// .isSkinnedMesh isn't in glTF spec. See ._markDefs()\n\t\t\t\t\tmesh = meshDef.isSkinnedMesh === true\n\t\t\t\t\t\t? new SkinnedMesh( geometry, material )\n\t\t\t\t\t\t: new Mesh( geometry, material );\n\n\t\t\t\t\tif ( mesh.isSkinnedMesh === true && ! mesh.geometry.attributes.skinWeight.normalized ) {\n\n\t\t\t\t\t\t// we normalize floating point skin weight array to fix malformed assets (see #15319)\n\t\t\t\t\t\t// it's important to skip this for non-float32 data since normalizeSkinWeights assumes non-normalized inputs\n\t\t\t\t\t\tmesh.normalizeSkinWeights();\n\n\t\t\t\t\t}\n\n\t\t\t\t\tif ( primitive.mode === WEBGL_CONSTANTS.TRIANGLE_STRIP ) {\n\n\t\t\t\t\t\tmesh.geometry = toTrianglesDrawMode( mesh.geometry, TriangleStripDrawMode );\n\n\t\t\t\t\t} else if ( primitive.mode === WEBGL_CONSTANTS.TRIANGLE_FAN ) {\n\n\t\t\t\t\t\tmesh.geometry = toTrianglesDrawMode( mesh.geometry, TriangleFanDrawMode );\n\n\t\t\t\t\t}\n\n\t\t\t\t} else if ( primitive.mode === WEBGL_CONSTANTS.LINES ) {\n\n\t\t\t\t\tmesh = new LineSegments( geometry, material );\n\n\t\t\t\t} else if ( primitive.mode === WEBGL_CONSTANTS.LINE_STRIP ) {\n\n\t\t\t\t\tmesh = new Line( geometry, material );\n\n\t\t\t\t} else if ( primitive.mode === WEBGL_CONSTANTS.LINE_LOOP ) {\n\n\t\t\t\t\tmesh = new LineLoop( geometry, material );\n\n\t\t\t\t} else if ( primitive.mode === WEBGL_CONSTANTS.POINTS ) {\n\n\t\t\t\t\tmesh = new Points( geometry, material );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tthrow new Error( 'THREE.GLTFLoader: Primitive mode unsupported: ' + primitive.mode );\n\n\t\t\t\t}\n\n\t\t\t\tif ( Object.keys( mesh.geometry.morphAttributes ).length > 0 ) {\n\n\t\t\t\t\tupdateMorphTargets( mesh, meshDef );\n\n\t\t\t\t}\n\n\t\t\t\tmesh.name = parser.createUniqueName( meshDef.name || ( 'mesh_' + meshIndex ) );\n\n\t\t\t\tassignExtrasToUserData( mesh, meshDef );\n\n\t\t\t\tif ( primitive.extensions ) addUnknownExtensionsToUserData( extensions, mesh, primitive );\n\n\t\t\t\tparser.assignFinalMaterial( mesh );\n\n\t\t\t\tmeshes.push( mesh );\n\n\t\t\t}\n\n\t\t\tfor ( let i = 0, il = meshes.length; i < il; i ++ ) {\n\n\t\t\t\tparser.associations.set( meshes[ i ], {\n\t\t\t\t\tmeshes: meshIndex,\n\t\t\t\t\tprimitives: i\n\t\t\t\t} );\n\n\t\t\t}\n\n\t\t\tif ( meshes.length === 1 ) {\n\n\t\t\t\treturn meshes[ 0 ];\n\n\t\t\t}\n\n\t\t\tconst group = new Group();\n\n\t\t\tparser.associations.set( group, { meshes: meshIndex } );\n\n\t\t\tfor ( let i = 0, il = meshes.length; i < il; i ++ ) {\n\n\t\t\t\tgroup.add( meshes[ i ] );\n\n\t\t\t}\n\n\t\t\treturn group;\n\n\t\t} );\n\n\t}\n\n\t/**\n\t * Specification: https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#cameras\n\t * @param {number} cameraIndex\n\t * @return {Promise}\n\t */\n\tloadCamera( cameraIndex ) {\n\n\t\tlet camera;\n\t\tconst cameraDef = this.json.cameras[ cameraIndex ];\n\t\tconst params = cameraDef[ cameraDef.type ];\n\n\t\tif ( ! params ) {\n\n\t\t\tconsole.warn( 'THREE.GLTFLoader: Missing camera parameters.' );\n\t\t\treturn;\n\n\t\t}\n\n\t\tif ( cameraDef.type === 'perspective' ) {\n\n\t\t\tcamera = new PerspectiveCamera( MathUtils.radToDeg( params.yfov ), params.aspectRatio || 1, params.znear || 1, params.zfar || 2e6 );\n\n\t\t} else if ( cameraDef.type === 'orthographic' ) {\n\n\t\t\tcamera = new OrthographicCamera( - params.xmag, params.xmag, params.ymag, - params.ymag, params.znear, params.zfar );\n\n\t\t}\n\n\t\tif ( cameraDef.name ) camera.name = this.createUniqueName( cameraDef.name );\n\n\t\tassignExtrasToUserData( camera, cameraDef );\n\n\t\treturn Promise.resolve( camera );\n\n\t}\n\n\t/**\n\t * Specification: https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#skins\n\t * @param {number} skinIndex\n\t * @return {Promise}\n\t */\n\tloadSkin( skinIndex ) {\n\n\t\tconst skinDef = this.json.skins[ skinIndex ];\n\n\t\tconst skinEntry = { joints: skinDef.joints };\n\n\t\tif ( skinDef.inverseBindMatrices === undefined ) {\n\n\t\t\treturn Promise.resolve( skinEntry );\n\n\t\t}\n\n\t\treturn this.getDependency( 'accessor', skinDef.inverseBindMatrices ).then( function ( accessor ) {\n\n\t\t\tskinEntry.inverseBindMatrices = accessor;\n\n\t\t\treturn skinEntry;\n\n\t\t} );\n\n\t}\n\n\t/**\n\t * Specification: https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#animations\n\t * @param {number} animationIndex\n\t * @return {Promise}\n\t */\n\tloadAnimation( animationIndex ) {\n\n\t\tconst json = this.json;\n\n\t\tconst animationDef = json.animations[ animationIndex ];\n\n\t\tconst pendingNodes = [];\n\t\tconst pendingInputAccessors = [];\n\t\tconst pendingOutputAccessors = [];\n\t\tconst pendingSamplers = [];\n\t\tconst pendingTargets = [];\n\n\t\tfor ( let i = 0, il = animationDef.channels.length; i < il; i ++ ) {\n\n\t\t\tconst channel = animationDef.channels[ i ];\n\t\t\tconst sampler = animationDef.samplers[ channel.sampler ];\n\t\t\tconst target = channel.target;\n\t\t\tconst name = target.node !== undefined ? target.node : target.id; // NOTE: target.id is deprecated.\n\t\t\tconst input = animationDef.parameters !== undefined ? animationDef.parameters[ sampler.input ] : sampler.input;\n\t\t\tconst output = animationDef.parameters !== undefined ? animationDef.parameters[ sampler.output ] : sampler.output;\n\n\t\t\tpendingNodes.push( this.getDependency( 'node', name ) );\n\t\t\tpendingInputAccessors.push( this.getDependency( 'accessor', input ) );\n\t\t\tpendingOutputAccessors.push( this.getDependency( 'accessor', output ) );\n\t\t\tpendingSamplers.push( sampler );\n\t\t\tpendingTargets.push( target );\n\n\t\t}\n\n\t\treturn Promise.all( [\n\n\t\t\tPromise.all( pendingNodes ),\n\t\t\tPromise.all( pendingInputAccessors ),\n\t\t\tPromise.all( pendingOutputAccessors ),\n\t\t\tPromise.all( pendingSamplers ),\n\t\t\tPromise.all( pendingTargets )\n\n\t\t] ).then( function ( dependencies ) {\n\n\t\t\tconst nodes = dependencies[ 0 ];\n\t\t\tconst inputAccessors = dependencies[ 1 ];\n\t\t\tconst outputAccessors = dependencies[ 2 ];\n\t\t\tconst samplers = dependencies[ 3 ];\n\t\t\tconst targets = dependencies[ 4 ];\n\n\t\t\tconst tracks = [];\n\n\t\t\tfor ( let i = 0, il = nodes.length; i < il; i ++ ) {\n\n\t\t\t\tconst node = nodes[ i ];\n\t\t\t\tconst inputAccessor = inputAccessors[ i ];\n\t\t\t\tconst outputAccessor = outputAccessors[ i ];\n\t\t\t\tconst sampler = samplers[ i ];\n\t\t\t\tconst target = targets[ i ];\n\n\t\t\t\tif ( node === undefined ) continue;\n\n\t\t\t\tnode.updateMatrix();\n\t\t\t\tnode.matrixAutoUpdate = true;\n\n\t\t\t\tlet TypedKeyframeTrack;\n\n\t\t\t\tswitch ( PATH_PROPERTIES[ target.path ] ) {\n\n\t\t\t\t\tcase PATH_PROPERTIES.weights:\n\n\t\t\t\t\t\tTypedKeyframeTrack = NumberKeyframeTrack;\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase PATH_PROPERTIES.rotation:\n\n\t\t\t\t\t\tTypedKeyframeTrack = QuaternionKeyframeTrack;\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase PATH_PROPERTIES.position:\n\t\t\t\t\tcase PATH_PROPERTIES.scale:\n\t\t\t\t\tdefault:\n\n\t\t\t\t\t\tTypedKeyframeTrack = VectorKeyframeTrack;\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t}\n\n\t\t\t\tconst targetName = node.name ? node.name : node.uuid;\n\n\t\t\t\tconst interpolation = sampler.interpolation !== undefined ? INTERPOLATION[ sampler.interpolation ] : InterpolateLinear;\n\n\t\t\t\tconst targetNames = [];\n\n\t\t\t\tif ( PATH_PROPERTIES[ target.path ] === PATH_PROPERTIES.weights ) {\n\n\t\t\t\t\tnode.traverse( function ( object ) {\n\n\t\t\t\t\t\tif ( object.morphTargetInfluences ) {\n\n\t\t\t\t\t\t\ttargetNames.push( object.name ? object.name : object.uuid );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t} );\n\n\t\t\t\t} else {\n\n\t\t\t\t\ttargetNames.push( targetName );\n\n\t\t\t\t}\n\n\t\t\t\tlet outputArray = outputAccessor.array;\n\n\t\t\t\tif ( outputAccessor.normalized ) {\n\n\t\t\t\t\tconst scale = getNormalizedComponentScale( outputArray.constructor );\n\t\t\t\t\tconst scaled = new Float32Array( outputArray.length );\n\n\t\t\t\t\tfor ( let j = 0, jl = outputArray.length; j < jl; j ++ ) {\n\n\t\t\t\t\t\tscaled[ j ] = outputArray[ j ] * scale;\n\n\t\t\t\t\t}\n\n\t\t\t\t\toutputArray = scaled;\n\n\t\t\t\t}\n\n\t\t\t\tfor ( let j = 0, jl = targetNames.length; j < jl; j ++ ) {\n\n\t\t\t\t\tconst track = new TypedKeyframeTrack(\n\t\t\t\t\t\ttargetNames[ j ] + '.' + PATH_PROPERTIES[ target.path ],\n\t\t\t\t\t\tinputAccessor.array,\n\t\t\t\t\t\toutputArray,\n\t\t\t\t\t\tinterpolation\n\t\t\t\t\t);\n\n\t\t\t\t\t// Override interpolation with custom factory method.\n\t\t\t\t\tif ( sampler.interpolation === 'CUBICSPLINE' ) {\n\n\t\t\t\t\t\ttrack.createInterpolant = function InterpolantFactoryMethodGLTFCubicSpline( result ) {\n\n\t\t\t\t\t\t\t// A CUBICSPLINE keyframe in glTF has three output values for each input value,\n\t\t\t\t\t\t\t// representing inTangent, splineVertex, and outTangent. As a result, track.getValueSize()\n\t\t\t\t\t\t\t// must be divided by three to get the interpolant's sampleSize argument.\n\n\t\t\t\t\t\t\tconst interpolantType = ( this instanceof QuaternionKeyframeTrack ) ? GLTFCubicSplineQuaternionInterpolant : GLTFCubicSplineInterpolant;\n\n\t\t\t\t\t\t\treturn new interpolantType( this.times, this.values, this.getValueSize() / 3, result );\n\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\t// Mark as CUBICSPLINE. `track.getInterpolation()` doesn't support custom interpolants.\n\t\t\t\t\t\ttrack.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline = true;\n\n\t\t\t\t\t}\n\n\t\t\t\t\ttracks.push( track );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tconst name = animationDef.name ? animationDef.name : 'animation_' + animationIndex;\n\n\t\t\treturn new AnimationClip( name, undefined, tracks );\n\n\t\t} );\n\n\t}\n\n\tcreateNodeMesh( nodeIndex ) {\n\n\t\tconst json = this.json;\n\t\tconst parser = this;\n\t\tconst nodeDef = json.nodes[ nodeIndex ];\n\n\t\tif ( nodeDef.mesh === undefined ) return null;\n\n\t\treturn parser.getDependency( 'mesh', nodeDef.mesh ).then( function ( mesh ) {\n\n\t\t\tconst node = parser._getNodeRef( parser.meshCache, nodeDef.mesh, mesh );\n\n\t\t\t// if weights are provided on the node, override weights on the mesh.\n\t\t\tif ( nodeDef.weights !== undefined ) {\n\n\t\t\t\tnode.traverse( function ( o ) {\n\n\t\t\t\t\tif ( ! o.isMesh ) return;\n\n\t\t\t\t\tfor ( let i = 0, il = nodeDef.weights.length; i < il; i ++ ) {\n\n\t\t\t\t\t\to.morphTargetInfluences[ i ] = nodeDef.weights[ i ];\n\n\t\t\t\t\t}\n\n\t\t\t\t} );\n\n\t\t\t}\n\n\t\t\treturn node;\n\n\t\t} );\n\n\t}\n\n\t/**\n\t * Specification: https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#nodes-and-hierarchy\n\t * @param {number} nodeIndex\n\t * @return {Promise}\n\t */\n\tloadNode( nodeIndex ) {\n\n\t\tconst json = this.json;\n\t\tconst extensions = this.extensions;\n\t\tconst parser = this;\n\n\t\tconst nodeDef = json.nodes[ nodeIndex ];\n\n\t\t// reserve node's name before its dependencies, so the root has the intended name.\n\t\tconst nodeName = nodeDef.name ? parser.createUniqueName( nodeDef.name ) : '';\n\n\t\treturn ( function () {\n\n\t\t\tconst pending = [];\n\n\t\t\tconst meshPromise = parser._invokeOne( function ( ext ) {\n\n\t\t\t\treturn ext.createNodeMesh && ext.createNodeMesh( nodeIndex );\n\n\t\t\t} );\n\n\t\t\tif ( meshPromise ) {\n\n\t\t\t\tpending.push( meshPromise );\n\n\t\t\t}\n\n\t\t\tif ( nodeDef.camera !== undefined ) {\n\n\t\t\t\tpending.push( parser.getDependency( 'camera', nodeDef.camera ).then( function ( camera ) {\n\n\t\t\t\t\treturn parser._getNodeRef( parser.cameraCache, nodeDef.camera, camera );\n\n\t\t\t\t} ) );\n\n\t\t\t}\n\n\t\t\tparser._invokeAll( function ( ext ) {\n\n\t\t\t\treturn ext.createNodeAttachment && ext.createNodeAttachment( nodeIndex );\n\n\t\t\t} ).forEach( function ( promise ) {\n\n\t\t\t\tpending.push( promise );\n\n\t\t\t} );\n\n\t\t\treturn Promise.all( pending );\n\n\t\t}() ).then( function ( objects ) {\n\n\t\t\tlet node;\n\n\t\t\t// .isBone isn't in glTF spec. See ._markDefs\n\t\t\tif ( nodeDef.isBone === true ) {\n\n\t\t\t\tnode = new Bone();\n\n\t\t\t} else if ( objects.length > 1 ) {\n\n\t\t\t\tnode = new Group();\n\n\t\t\t} else if ( objects.length === 1 ) {\n\n\t\t\t\tnode = objects[ 0 ];\n\n\t\t\t} else {\n\n\t\t\t\tnode = new Object3D();\n\n\t\t\t}\n\n\t\t\tif ( node !== objects[ 0 ] ) {\n\n\t\t\t\tfor ( let i = 0, il = objects.length; i < il; i ++ ) {\n\n\t\t\t\t\tnode.add( objects[ i ] );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( nodeDef.name ) {\n\n\t\t\t\tnode.userData.name = nodeDef.name;\n\t\t\t\tnode.name = nodeName;\n\n\t\t\t}\n\n\t\t\tassignExtrasToUserData( node, nodeDef );\n\n\t\t\tif ( nodeDef.extensions ) addUnknownExtensionsToUserData( extensions, node, nodeDef );\n\n\t\t\tif ( nodeDef.matrix !== undefined ) {\n\n\t\t\t\tconst matrix = new Matrix4();\n\t\t\t\tmatrix.fromArray( nodeDef.matrix );\n\t\t\t\tnode.applyMatrix4( matrix );\n\n\t\t\t} else {\n\n\t\t\t\tif ( nodeDef.translation !== undefined ) {\n\n\t\t\t\t\tnode.position.fromArray( nodeDef.translation );\n\n\t\t\t\t}\n\n\t\t\t\tif ( nodeDef.rotation !== undefined ) {\n\n\t\t\t\t\tnode.quaternion.fromArray( nodeDef.rotation );\n\n\t\t\t\t}\n\n\t\t\t\tif ( nodeDef.scale !== undefined ) {\n\n\t\t\t\t\tnode.scale.fromArray( nodeDef.scale );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\tif ( ! parser.associations.has( node ) ) {\n\n\t\t\t\tparser.associations.set( node, {} );\n\n\t\t\t}\n\n\t\t\tparser.associations.get( node ).nodes = nodeIndex;\n\n\t\t\treturn node;\n\n\t\t} );\n\n\t}\n\n\t/**\n\t * Specification: https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#scenes\n\t * @param {number} sceneIndex\n\t * @return {Promise}\n\t */\n\tloadScene( sceneIndex ) {\n\n\t\tconst json = this.json;\n\t\tconst extensions = this.extensions;\n\t\tconst sceneDef = this.json.scenes[ sceneIndex ];\n\t\tconst parser = this;\n\n\t\t// Loader returns Group, not Scene.\n\t\t// See: https://github.com/mrdoob/three.js/issues/18342#issuecomment-578981172\n\t\tconst scene = new Group();\n\t\tif ( sceneDef.name ) scene.name = parser.createUniqueName( sceneDef.name );\n\n\t\tassignExtrasToUserData( scene, sceneDef );\n\n\t\tif ( sceneDef.extensions ) addUnknownExtensionsToUserData( extensions, scene, sceneDef );\n\n\t\tconst nodeIds = sceneDef.nodes || [];\n\n\t\tconst pending = [];\n\n\t\tfor ( let i = 0, il = nodeIds.length; i < il; i ++ ) {\n\n\t\t\tpending.push( buildNodeHierarchy( nodeIds[ i ], scene, json, parser ) );\n\n\t\t}\n\n\t\treturn Promise.all( pending ).then( function () {\n\n\t\t\t// Removes dangling associations, associations that reference a node that\n\t\t\t// didn't make it into the scene.\n\t\t\tconst reduceAssociations = ( node ) => {\n\n\t\t\t\tconst reducedAssociations = new Map();\n\n\t\t\t\tfor ( const [ key, value ] of parser.associations ) {\n\n\t\t\t\t\tif ( key instanceof Material || key instanceof Texture ) {\n\n\t\t\t\t\t\treducedAssociations.set( key, value );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tnode.traverse( ( node ) => {\n\n\t\t\t\t\tconst mappings = parser.associations.get( node );\n\n\t\t\t\t\tif ( mappings != null ) {\n\n\t\t\t\t\t\treducedAssociations.set( node, mappings );\n\n\t\t\t\t\t}\n\n\t\t\t\t} );\n\n\t\t\t\treturn reducedAssociations;\n\n\t\t\t};\n\n\t\t\tparser.associations = reduceAssociations( scene );\n\n\t\t\treturn scene;\n\n\t\t} );\n\n\t}\n\n}\n\nfunction buildNodeHierarchy( nodeId, parentObject, json, parser ) {\n\n\tconst nodeDef = json.nodes[ nodeId ];\n\n\treturn parser.getDependency( 'node', nodeId ).then( function ( node ) {\n\n\t\tif ( nodeDef.skin === undefined ) return node;\n\n\t\t// build skeleton here as well\n\n\t\tlet skinEntry;\n\n\t\treturn parser.getDependency( 'skin', nodeDef.skin ).then( function ( skin ) {\n\n\t\t\tskinEntry = skin;\n\n\t\t\tconst pendingJoints = [];\n\n\t\t\tfor ( let i = 0, il = skinEntry.joints.length; i < il; i ++ ) {\n\n\t\t\t\tpendingJoints.push( parser.getDependency( 'node', skinEntry.joints[ i ] ) );\n\n\t\t\t}\n\n\t\t\treturn Promise.all( pendingJoints );\n\n\t\t} ).then( function ( jointNodes ) {\n\n\t\t\tnode.traverse( function ( mesh ) {\n\n\t\t\t\tif ( ! mesh.isMesh ) return;\n\n\t\t\t\tconst bones = [];\n\t\t\t\tconst boneInverses = [];\n\n\t\t\t\tfor ( let j = 0, jl = jointNodes.length; j < jl; j ++ ) {\n\n\t\t\t\t\tconst jointNode = jointNodes[ j ];\n\n\t\t\t\t\tif ( jointNode ) {\n\n\t\t\t\t\t\tbones.push( jointNode );\n\n\t\t\t\t\t\tconst mat = new Matrix4();\n\n\t\t\t\t\t\tif ( skinEntry.inverseBindMatrices !== undefined ) {\n\n\t\t\t\t\t\t\tmat.fromArray( skinEntry.inverseBindMatrices.array, j * 16 );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tboneInverses.push( mat );\n\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\tconsole.warn( 'THREE.GLTFLoader: Joint \"%s\" could not be found.', skinEntry.joints[ j ] );\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\tmesh.bind( new Skeleton( bones, boneInverses ), mesh.matrixWorld );\n\n\t\t\t} );\n\n\t\t\treturn node;\n\n\t\t} );\n\n\t} ).then( function ( node ) {\n\n\t\t// build node hierachy\n\n\t\tparentObject.add( node );\n\n\t\tconst pending = [];\n\n\t\tif ( nodeDef.children ) {\n\n\t\t\tconst children = nodeDef.children;\n\n\t\t\tfor ( let i = 0, il = children.length; i < il; i ++ ) {\n\n\t\t\t\tconst child = children[ i ];\n\t\t\t\tpending.push( buildNodeHierarchy( child, node, json, parser ) );\n\n\t\t\t}\n\n\t\t}\n\n\t\treturn Promise.all( pending );\n\n\t} );\n\n}\n\n/**\n * @param {BufferGeometry} geometry\n * @param {GLTF.Primitive} primitiveDef\n * @param {GLTFParser} parser\n */\nfunction computeBounds( geometry, primitiveDef, parser ) {\n\n\tconst attributes = primitiveDef.attributes;\n\n\tconst box = new Box3();\n\n\tif ( attributes.POSITION !== undefined ) {\n\n\t\tconst accessor = parser.json.accessors[ attributes.POSITION ];\n\n\t\tconst min = accessor.min;\n\t\tconst max = accessor.max;\n\n\t\t// glTF requires 'min' and 'max', but VRM (which extends glTF) currently ignores that requirement.\n\n\t\tif ( min !== undefined && max !== undefined ) {\n\n\t\t\tbox.set(\n\t\t\t\tnew Vector3( min[ 0 ], min[ 1 ], min[ 2 ] ),\n\t\t\t\tnew Vector3( max[ 0 ], max[ 1 ], max[ 2 ] )\n\t\t\t);\n\n\t\t\tif ( accessor.normalized ) {\n\n\t\t\t\tconst boxScale = getNormalizedComponentScale( WEBGL_COMPONENT_TYPES[ accessor.componentType ] );\n\t\t\t\tbox.min.multiplyScalar( boxScale );\n\t\t\t\tbox.max.multiplyScalar( boxScale );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tconsole.warn( 'THREE.GLTFLoader: Missing min/max properties for accessor POSITION.' );\n\n\t\t\treturn;\n\n\t\t}\n\n\t} else {\n\n\t\treturn;\n\n\t}\n\n\tconst targets = primitiveDef.targets;\n\n\tif ( targets !== undefined ) {\n\n\t\tconst maxDisplacement = new Vector3();\n\t\tconst vector = new Vector3();\n\n\t\tfor ( let i = 0, il = targets.length; i < il; i ++ ) {\n\n\t\t\tconst target = targets[ i ];\n\n\t\t\tif ( target.POSITION !== undefined ) {\n\n\t\t\t\tconst accessor = parser.json.accessors[ target.POSITION ];\n\t\t\t\tconst min = accessor.min;\n\t\t\t\tconst max = accessor.max;\n\n\t\t\t\t// glTF requires 'min' and 'max', but VRM (which extends glTF) currently ignores that requirement.\n\n\t\t\t\tif ( min !== undefined && max !== undefined ) {\n\n\t\t\t\t\t// we need to get max of absolute components because target weight is [-1,1]\n\t\t\t\t\tvector.setX( Math.max( Math.abs( min[ 0 ] ), Math.abs( max[ 0 ] ) ) );\n\t\t\t\t\tvector.setY( Math.max( Math.abs( min[ 1 ] ), Math.abs( max[ 1 ] ) ) );\n\t\t\t\t\tvector.setZ( Math.max( Math.abs( min[ 2 ] ), Math.abs( max[ 2 ] ) ) );\n\n\n\t\t\t\t\tif ( accessor.normalized ) {\n\n\t\t\t\t\t\tconst boxScale = getNormalizedComponentScale( WEBGL_COMPONENT_TYPES[ accessor.componentType ] );\n\t\t\t\t\t\tvector.multiplyScalar( boxScale );\n\n\t\t\t\t\t}\n\n\t\t\t\t\t// Note: this assumes that the sum of all weights is at most 1. This isn't quite correct - it's more conservative\n\t\t\t\t\t// to assume that each target can have a max weight of 1. However, for some use cases - notably, when morph targets\n\t\t\t\t\t// are used to implement key-frame animations and as such only two are active at a time - this results in very large\n\t\t\t\t\t// boxes. So for now we make a box that's sometimes a touch too small but is hopefully mostly of reasonable size.\n\t\t\t\t\tmaxDisplacement.max( vector );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tconsole.warn( 'THREE.GLTFLoader: Missing min/max properties for accessor POSITION.' );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\t// As per comment above this box isn't conservative, but has a reasonable size for a very large number of morph targets.\n\t\tbox.expandByVector( maxDisplacement );\n\n\t}\n\n\tgeometry.boundingBox = box;\n\n\tconst sphere = new Sphere();\n\n\tbox.getCenter( sphere.center );\n\tsphere.radius = box.min.distanceTo( box.max ) / 2;\n\n\tgeometry.boundingSphere = sphere;\n\n}\n\n/**\n * @param {BufferGeometry} geometry\n * @param {GLTF.Primitive} primitiveDef\n * @param {GLTFParser} parser\n * @return {Promise}\n */\nfunction addPrimitiveAttributes( geometry, primitiveDef, parser ) {\n\n\tconst attributes = primitiveDef.attributes;\n\n\tconst pending = [];\n\n\tfunction assignAttributeAccessor( accessorIndex, attributeName ) {\n\n\t\treturn parser.getDependency( 'accessor', accessorIndex )\n\t\t\t.then( function ( accessor ) {\n\n\t\t\t\tgeometry.setAttribute( attributeName, accessor );\n\n\t\t\t} );\n\n\t}\n\n\tfor ( const gltfAttributeName in attributes ) {\n\n\t\tconst threeAttributeName = ATTRIBUTES[ gltfAttributeName ] || gltfAttributeName.toLowerCase();\n\n\t\t// Skip attributes already provided by e.g. Draco extension.\n\t\tif ( threeAttributeName in geometry.attributes ) continue;\n\n\t\tpending.push( assignAttributeAccessor( attributes[ gltfAttributeName ], threeAttributeName ) );\n\n\t}\n\n\tif ( primitiveDef.indices !== undefined && ! geometry.index ) {\n\n\t\tconst accessor = parser.getDependency( 'accessor', primitiveDef.indices ).then( function ( accessor ) {\n\n\t\t\tgeometry.setIndex( accessor );\n\n\t\t} );\n\n\t\tpending.push( accessor );\n\n\t}\n\n\tassignExtrasToUserData( geometry, primitiveDef );\n\n\tcomputeBounds( geometry, primitiveDef, parser );\n\n\treturn Promise.all( pending ).then( function () {\n\n\t\treturn primitiveDef.targets !== undefined\n\t\t\t? addMorphTargets( geometry, primitiveDef.targets, parser )\n\t\t\t: geometry;\n\n\t} );\n\n}\n\n/**\n * @param {BufferGeometry} geometry\n * @param {Number} drawMode\n * @return {BufferGeometry}\n */\nfunction toTrianglesDrawMode( geometry, drawMode ) {\n\n\tlet index = geometry.getIndex();\n\n\t// generate index if not present\n\n\tif ( index === null ) {\n\n\t\tconst indices = [];\n\n\t\tconst position = geometry.getAttribute( 'position' );\n\n\t\tif ( position !== undefined ) {\n\n\t\t\tfor ( let i = 0; i < position.count; i ++ ) {\n\n\t\t\t\tindices.push( i );\n\n\t\t\t}\n\n\t\t\tgeometry.setIndex( indices );\n\t\t\tindex = geometry.getIndex();\n\n\t\t} else {\n\n\t\t\tconsole.error( 'THREE.GLTFLoader.toTrianglesDrawMode(): Undefined position attribute. Processing not possible.' );\n\t\t\treturn geometry;\n\n\t\t}\n\n\t}\n\n\t//\n\n\tconst numberOfTriangles = index.count - 2;\n\tconst newIndices = [];\n\n\tif ( drawMode === TriangleFanDrawMode ) {\n\n\t\t// gl.TRIANGLE_FAN\n\n\t\tfor ( let i = 1; i <= numberOfTriangles; i ++ ) {\n\n\t\t\tnewIndices.push( index.getX( 0 ) );\n\t\t\tnewIndices.push( index.getX( i ) );\n\t\t\tnewIndices.push( index.getX( i + 1 ) );\n\n\t\t}\n\n\t} else {\n\n\t\t// gl.TRIANGLE_STRIP\n\n\t\tfor ( let i = 0; i < numberOfTriangles; i ++ ) {\n\n\t\t\tif ( i % 2 === 0 ) {\n\n\t\t\t\tnewIndices.push( index.getX( i ) );\n\t\t\t\tnewIndices.push( index.getX( i + 1 ) );\n\t\t\t\tnewIndices.push( index.getX( i + 2 ) );\n\n\n\t\t\t} else {\n\n\t\t\t\tnewIndices.push( index.getX( i + 2 ) );\n\t\t\t\tnewIndices.push( index.getX( i + 1 ) );\n\t\t\t\tnewIndices.push( index.getX( i ) );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tif ( ( newIndices.length / 3 ) !== numberOfTriangles ) {\n\n\t\tconsole.error( 'THREE.GLTFLoader.toTrianglesDrawMode(): Unable to generate correct amount of triangles.' );\n\n\t}\n\n\t// build final geometry\n\n\tconst newGeometry = geometry.clone();\n\tnewGeometry.setIndex( newIndices );\n\n\treturn newGeometry;\n\n}\n\nexport { GLTFLoader };\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\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.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","__webpack_require__.amdD = function () {\n\tthrow new Error('define cannot be used indirect');\n};","__webpack_require__.amdO = {};","// 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__.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};","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(59424);\n"],"names":["root","cosh","Math","x","abs","exp","sinh","parser_exit","SyntaxError","logHypot","a","b","_a","_b","log","LN2","Complex","this","z","undefined","Number","isFinite","cos","sin","length","tokens","match","plus","minus","i","c","isNaN","parseFloat","parse","prototype","t","d","pow","arg","atan2","loh","re","im","r","sqrt","tmp","expm1","PI","xx","cosm1","y","t1","t2","Infinity","atan","acos","asin","res","noIM","oneMinus","onePlus","temp","atanh","asinh","acosh","places","ceil","floor","round","ret","E","NaN","globalScope","Decimal","inexact","quadrant","EXP_LIMIT","MAX_DIGITS","NUMERALS","LN10","DEFAULTS","precision","rounding","modulo","toExpNeg","toExpPos","minE","maxE","crypto","external","decimalError","invalidArgument","precisionLimitExceeded","cryptoUnavailable","tag","mathfloor","mathpow","isBinary","isHex","isOctal","isDecimal","BASE","LN10_PRECISION","PI_PRECISION","P","toStringTag","digitsToString","k","ws","indexOfLastWord","str","w","getZeroString","checkInt32","min","max","Error","checkRoundingDigits","rm","repeating","di","rd","convertBase","baseIn","baseOut","j","arrL","arr","strL","indexOf","charAt","reverse","absoluteValue","constructor","s","finalise","e","clampedTo","clamp","Ctor","gt","cmp","comparedTo","xdL","ydL","xd","yd","xs","ys","cosine","pr","sd","len","isZero","tinyPow","toString","taylorSeries","times","cos2x","toLessThanHalfPi","neg","cubeRoot","cbrt","m","n","rep","t3","t3plusx","toExponential","slice","divide","eq","decimalPlaces","dp","dividedBy","div","dividedToIntegerBy","divToInt","equals","greaterThan","greaterThanOrEqualTo","gte","hyperbolicCosine","one","cosh2_x","d8","hyperbolicSine","sinh2_x","d5","d16","d20","hyperbolicTangent","tanh","inverseCosine","halfPi","isNeg","getPi","inverseHyperbolicCosine","lte","ln","inverseHyperbolicSine","inverseHyperbolicTangent","wpr","xsd","inverseSine","inverseTangent","px","x2","isInteger","isInt","isNegative","isPositive","isPos","lessThan","lt","lessThanOrEqualTo","logarithm","base","isBase10","denominator","inf","num","naturalLogarithm","getLn10","sub","xe","xLTy","push","pop","shift","getBase10Exponent","mod","q","naturalExponential","negated","add","carry","unshift","getPrecision","sine","sin2_x","squareRoot","tangent","tan","mul","rL","toBinary","toStringBinary","toDecimalPlaces","toDP","finiteToString","toFixed","toFraction","maxD","d0","d1","d2","n0","n1","toHexadecimal","toHex","toNearest","toNumber","toOctal","toPower","yn","intPow","toPrecision","toSignificantDigits","toSD","truncated","trunc","valueOf","toJSON","multiplyInteger","compare","aL","bL","subtract","logBase","more","prod","prodL","qd","rem","remL","rem0","xi","xL","yd0","yL","yz","sign","isTruncated","digits","roundUp","xdi","out","isExp","nonFiniteToString","zs","truncate","isOdd","maxOrMin","args","ltgt","guard","sum","c0","numerator","x1","String","parseDecimal","replace","search","substring","charCodeAt","parseOther","divisor","isFloat","p","test","toLowerCase","isHyperbolic","u","pi","config","obj","v","useDefaults","defaults","ps","getRandomValues","randomBytes","hypot","arguments","isDecimalInstance","log2","log10","random","Uint32Array","copy","clone","ROUND_UP","ROUND_DOWN","ROUND_CEIL","ROUND_FLOOR","ROUND_HALF_UP","ROUND_HALF_DOWN","ROUND_HALF_EVEN","ROUND_HALF_CEIL","ROUND_HALF_FLOOR","EUCLID","set","hasOwnProperty","__spreadArray","to","from","pack","ar","l","Array","call","concat","BrowserInfo","name","version","os","type","NodeInfo","process","platform","SearchBotDeviceInfo","bot","BotInfo","ReactNativeInfo","SEARCHBOT_OS_REGEX","userAgentRules","operatingSystemRules","detect","userAgent","parseUserAgent","document","navigator","product","getNodeVersion","matchUserAgent","ua","reduce","matched","browser","regex","uaMatch","exec","browserName","data","matchedRule","versionParts","split","join","count","output","ii","createVersionParts","detectOS","searchBotMatch","Promise","o","next","throw","done","value","then","apply","window","maxTouchPoints","MSStream","isIpad","isMobile","isSafari12","f","h","super","Object","setPrototypeOf","mobileTiers","desktopTiers","override","glContext","failIfMajorPerformanceCaveat","benchmarksURL","g","tier","screenSize","screen","loadBenchmarks","fetch","json","parseInt","renderer","A","device","fps","gpu","S","alpha","antialias","depth","powerPreference","stencil","createElement","getContext","getExtension","getParameter","UNMASKED_RENDERER_WEBGL","createShader","createProgram","shaderSource","compileShader","attachShader","linkProgram","detachShader","deleteShader","useProgram","createBuffer","bindBuffer","bufferData","Float32Array","getAttribLocation","vertexAttribPointer","enableVertexAttribArray","clearColor","clear","viewport","drawArrays","Uint8Array","readPixels","deleteProgram","deleteBuffer","filter","map","all","includes","sort","MAX_VALUE","devicePixelRatio","width","height","find","C","L","M","$","_extends","assign","target","source","key","defaultEscapes","_","formatEscapes","defaultEscapeMapFn","module","exports","_ref","_ref$preserveFormatti","preserveFormatting","_ref$escapeMapFn","escapeMapFn","runningStr","result","escapes","escapeKeys","keys","_loop","specialCharFound","forEach","index","Fraction","newFraction","create","gcd","factorize","factors","p1","p2","B","D","N","eps","thisABS","cont","excludeWhole","whole","dec","cycLen","cycleLen","cycOff","rem1","rem2","modpow","cycleStart","naturalSort","oFxNcL","oFyNcL","sre","dre","hre","ore","insensitive","xN","yN","xD","Date","yD","cLoc","numS","alea","xor128","xorwow","xorshift7","xor4096","tychei","sr","global","define","Alea","seed","me","mash","s0","s1","s2","impl","opts","xg","state","prng","int32","double","quick","XorGen","strseed","X","limit","init","pool","math","nodecrypto","startdenom","significance","overflow","mask","seedrandom","options","callback","shortseed","mixkey","flatten","entropy","tostring","msCrypto","plugins","autoseed","arc4","ARC4","pass","is_math_call","keylen","prop","typ","smear","stringseed","fromCharCode","ex","self","on","ctx","fn","once","listener","off","emit","evtArr","evts","liveEvents","TinyEmitter","BROWSER_INF_KEY","INF_NONE","BrowserInf","_name","_os","_version","notPopulated","reset","_hw_nowarn","gpuTier","getGPUTier","_gpuTier","save","BROWSER","localStorage","setItem","JSON","stringify","load","getItem","gpuAdequate","noHWWarning","browserInf","remove","loadResources","setTimeout","$uk","modal","show","is","ships","querryResources","TABLE_CLASS","SHIP_STATS_SHOWN","Thrust","maxThrust","Turning","maxRps","Mass","mass","Health","health","WEAPON_STATS_SHOWN","muzzle_velocity","rps","round_entity_type","shipSelectionMenuSelection","getCurrentShip","$ship","getLoadoutIconPath","shipType","createShipSelectHeader","resource","ship","getShip","entry","append","class","href","attr","addClass","children","removeClass","src","text","$shipDatapage","idx","content","weapons","weapon","$weaponDatapage","updateCurrentHeaders","createGenericShipHeader","setCurrentShip","DEFAULT_SHIP","CURRENT_SHIP_KEY","Resource","ts","typestring","globalResourceCache","TYPE_MODEL","TYPE_IMAGE","TYPE_SOUND","TYPE_SHADER","TYPE_SCENE","TYPE_MAP","TYPE_OBJECT","TYPE_FONT","TYPE_WEAPON","TYPE_SHIP","loadFunctionMap","loader","GLTFLoader","loadAsync","resource_path","url","requestHeader","scene","TextureLoader","AudioLoader","FileLoader","vertex","vert_url","frag","frag_url","ShaderMaterial","vertexShader","fragmentShader","text_loader","image_loader","vert","uniforms","uni","uniform","img","Uniform","console","error","material","model_loader","mesh","model","FontLoader","font","getterBase","expected_type","maybe_value","cache","ok","statusText","resourceMap","promises","resourceLoader","tp","querry","volitility","iterations","fill","mins","maxs","backTrace","generateNext","absMin","absMax","baseMin","baseMax","absMinRange","angle","matrix","angle1","angle2","windowHasLoaded","UIkit","notOk","undef","_types","isArray","RegExp","anyType","_ignore","_conversions","typed","types","conversions","ignore","findTypeByName","typeName","findInArray","hint","TypeError","findTypeIndex","findTypeName","stringifyParams","params","param","typeNames","getTypeName","restParam","parseParam","trim","notEmpty","notIgnore","matchingConversions","matches","conversion","filterConversions","exactTypes","typeIndex","conversionIndex","convertibleTypes","hasRestParam","last","hasConversions","some","compileTest","test0","test1","tests","compileTests","varIndex","lastTest","testRestParam","getParamAtIndex","signature","getExpectedTypeNames","excludeConversions","isExactType","mergeExpectedParams","signatures","entries","uniq","flatMap","createError","err","expected","matchingSignatures","nextMatchingDefs","actualType","category","actual","lengths","maxLength","expectedLength","getLowestTypeIndex","getLowestConversionIndex","compareParams","param1","param2","compareSignatures","signature1","signature2","compileArgConversion","conversion0","conversion1","convert","splitParams","ignoreConversionTypes","_splitParams","typeGroups","filteredTypes","typeGroup","createTypedFunction","signaturesMap","parsedSignatures","array","parsedParam","isInvalidParam","parseSignature","notNull","parsedSignature","conflictingSignature","hasOverlap","len1","len2","restParam1","restParam2","hasConflictingParams","ok0","ok1","ok2","ok3","ok4","ok5","allOk","test00","test10","test20","test30","test40","test50","test01","test11","test21","test31","test41","test51","fns","fnConvert","compiledConversions","fnPreprocess","offset","compileArgsPreprocessing","fn0","fn1","fn2","fn3","fn4","fn5","len0","len3","len4","len5","iStart","iEnd","generic","onMismatch","arg0","arg1","defineProperty","createSignaturesMap","_onMismatch","start","end","array1","array2","item","getName","extractSignatures","validateUnique","_signature","_fn","throwMismatchError","addType","beforeObjectTest","splice","addConversion","arr2","__esModule","arrayLikeToArray","instance","Constructor","_defineProperties","props","descriptor","enumerable","configurable","writable","protoProps","staticProps","bind","iter","Symbol","iterator","_i","_s","_e","_arr","_n","_d","_typeof","_regeneratorRuntime","Op","hasOwn","$Symbol","iteratorSymbol","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","wrap","innerFn","outerFn","tryLocsList","protoGenerator","Generator","generator","context","Context","_invoke","method","delegate","delegateResult","maybeInvokeDelegate","ContinueSentinel","sent","_sent","dispatchException","abrupt","record","tryCatch","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","getPrototypeOf","NativeIteratorPrototype","values","Gp","defineIteratorMethods","AsyncIterator","PromiseImpl","invoke","resolve","reject","__await","unwrapped","previousPromise","callInvokeWithMethodAndArg","info","resultName","nextLoc","pushTryEntry","locs","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","iterable","iteratorMethod","doneResult","displayName","isGeneratorFunction","genFun","ctor","mark","__proto__","awrap","async","object","skipTempReset","prev","stop","rootRecord","rval","exception","handle","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","thrown","delegateYield","arrayWithHoles","iterableToArrayLimit","unsupportedIterableToArray","nonIterableRest","arrayWithoutHoles","iterableToArray","nonIterableSpread","minLen","runtime","regeneratorRuntime","accidentalStrictMode","globalThis","Function","createVersion","createUppercasePi","createUppercaseE","createTrue","createTau","createSQRT2","createSQRT1_2","createPi","createPhi","createNull","createNaN","createLOG2E","createLOG10E","createLN2","createLN10","createInfinity","createI","createFalse","createE","_factory","_constants","_index","factory","recreateFactory","BigNumber","number","_ref2","_ref3","createBigNumberPi","_ref4","createBigNumberTau","tau","_ref5","createBigNumberE","_ref6","createBigNumberPhi","phi","_ref7","_ref8","_ref9","LOG2E","_ref10","LOG10E","_ref11","SQRT1_2","_ref12","SQRT2","_ref13","I","_ref14","_ref15","dependencies","recreateOnConfigChange","DEFAULT_CONFIG","epsilon","predictable","randomSeed","_interopRequireDefault","factories","configInternal","_extends2","default","_config2","emitter","mixin","isNumber","_is","isComplex","isBigNumber","isFraction","isUnit","isString","isMatrix","isCollection","isDenseMatrix","isSparseMatrix","isRange","isIndex","isBoolean","isResultSet","isHelp","isFunction","isDate","isRegExp","isObject","isNull","isUndefined","isAccessorNode","isArrayNode","isAssignmentNode","isBlockNode","isConditionalNode","isConstantNode","isFunctionAssignmentNode","isFunctionNode","isIndexNode","isNode","isObjectNode","isOperatorNode","isParenthesisNode","isRangeNode","isSymbolNode","isChain","_config","configFactory","expression","transform","mathWithTransform","legacyFactories","legacyInstances","importedFactories","internalImport","_import","importFactory","_len","_key","isFactory","firstProperty","_object","isLegacyFactory","warn","import","meta","deepFlatten","ArgumentsError","_ArgumentsError","DimensionError","_DimensionError","IndexError","_IndexError","nodeInterop","_getRequireWildcardCache","has","get","newObj","hasPropertyDescriptor","getOwnPropertyDescriptor","desc","_interopRequireWildcard","WeakMap","cacheBabelInterop","cacheNodeInterop","NUMBER_OPTIONS","MATRIX_OPTIONS","mapObject","validateOption","deepExtend","curr","changes","wrapper","_wrap","_defineProperty2","isTypedFunction","_importTransform","silent","allowedInExpressions","_deleteTransform","_importFactory","_array","contains","namespace","isTransformFunctionFactory","existingTransform","existing","resolver","stripOptionalNotation","dependency","classes","lazy","factoryAllowedInExpressions","isSupportedType","_typeof2","unsafe","isClass","isTransformFunction","docs","chain","functions","flattenImports","flatValues","flatName","createTyped","_typedFunction","_number","_map","_createTyped2","DenseMatrix","isMap","throwNoBignumber","throwNoComplex","throwNoFraction","throwNoMatrix","freeze","_dependenciesAccessorNodeGenerated","AccessorNodeDependencies","_dependenciesArrayNodeGenerated","ArrayNodeDependencies","_dependenciesAssignmentNodeGenerated","AssignmentNodeDependencies","_dependenciesBigNumberClassGenerated","BigNumberDependencies","_dependenciesBlockNodeGenerated","BlockNodeDependencies","_dependenciesChainClassGenerated","ChainDependencies","_dependenciesComplexClassGenerated","ComplexDependencies","_dependenciesConditionalNodeGenerated","ConditionalNodeDependencies","_dependenciesConstantNodeGenerated","ConstantNodeDependencies","_dependenciesDenseMatrixClassGenerated","DenseMatrixDependencies","_dependenciesUppercaseEGenerated","EDependencies","_dependenciesFibonacciHeapClassGenerated","FibonacciHeapDependencies","_dependenciesFractionClassGenerated","FractionDependencies","_dependenciesFunctionAssignmentNodeGenerated","FunctionAssignmentNodeDependencies","_dependenciesFunctionNodeGenerated","FunctionNodeDependencies","_dependenciesHelpClassGenerated","HelpDependencies","_dependenciesImmutableDenseMatrixClassGenerated","ImmutableDenseMatrixDependencies","_dependenciesIndexClassGenerated","IndexDependencies","_dependenciesIndexNodeGenerated","IndexNodeDependencies","_dependenciesInfinityGenerated","InfinityDependencies","_dependenciesLN10Generated","LN10Dependencies","_dependenciesLN2Generated","LN2Dependencies","_dependenciesLOG10EGenerated","LOG10EDependencies","_dependenciesLOG2EGenerated","LOG2EDependencies","_dependenciesMatrixClassGenerated","MatrixDependencies","_dependenciesNaNGenerated","NaNDependencies","_dependenciesNodeGenerated","NodeDependencies","_dependenciesObjectNodeGenerated","ObjectNodeDependencies","_dependenciesOperatorNodeGenerated","OperatorNodeDependencies","_dependenciesUppercasePiGenerated","PIDependencies","_dependenciesParenthesisNodeGenerated","ParenthesisNodeDependencies","_dependenciesParserClassGenerated","ParserDependencies","_dependenciesRangeClassGenerated","RangeDependencies","_dependenciesRangeNodeGenerated","RangeNodeDependencies","_dependenciesRelationalNodeGenerated","RelationalNodeDependencies","_dependenciesResultSetGenerated","ResultSetDependencies","_dependenciesSQRT1_2Generated","SQRT1_2Dependencies","_dependenciesSQRT2Generated","SQRT2Dependencies","_dependenciesSpaClassGenerated","SpaDependencies","_dependenciesSparseMatrixClassGenerated","SparseMatrixDependencies","_dependenciesSymbolNodeGenerated","SymbolNodeDependencies","_dependenciesUnitClassGenerated","UnitDependencies","_dependenciesAbsGenerated","absDependencies","_dependenciesAcosGenerated","acosDependencies","_dependenciesAcoshGenerated","acoshDependencies","_dependenciesAcotGenerated","acotDependencies","_dependenciesAcothGenerated","acothDependencies","_dependenciesAcscGenerated","acscDependencies","_dependenciesAcschGenerated","acschDependencies","_dependenciesAddGenerated","addDependencies","_dependenciesAddScalarGenerated","addScalarDependencies","_allFactoriesAny","_dependenciesAndGenerated","andDependencies","_dependenciesApplyGenerated","applyDependencies","_dependenciesApplyTransformGenerated","applyTransformDependencies","_dependenciesArgGenerated","argDependencies","_dependenciesAsecGenerated","asecDependencies","_dependenciesAsechGenerated","asechDependencies","_dependenciesAsinGenerated","asinDependencies","_dependenciesAsinhGenerated","asinhDependencies","_dependenciesAtan2Generated","atan2Dependencies","_dependenciesAtanGenerated","atanDependencies","_dependenciesAtanhGenerated","atanhDependencies","_dependenciesAtomicMassGenerated","atomicMassDependencies","_dependenciesAvogadroGenerated","avogadroDependencies","_dependenciesBellNumbersGenerated","bellNumbersDependencies","_dependenciesBignumberGenerated","bignumberDependencies","_dependenciesBinGenerated","binDependencies","_dependenciesBitAndGenerated","bitAndDependencies","_dependenciesBitNotGenerated","bitNotDependencies","_dependenciesBitOrGenerated","bitOrDependencies","_dependenciesBitXorGenerated","bitXorDependencies","_dependenciesBohrMagnetonGenerated","bohrMagnetonDependencies","_dependenciesBohrRadiusGenerated","bohrRadiusDependencies","_dependenciesBoltzmannGenerated","boltzmannDependencies","_dependenciesBooleanGenerated","booleanDependencies","_dependenciesCatalanGenerated","catalanDependencies","_dependenciesCbrtGenerated","cbrtDependencies","_dependenciesCeilGenerated","ceilDependencies","_dependenciesChainGenerated","chainDependencies","_dependenciesClassicalElectronRadiusGenerated","classicalElectronRadiusDependencies","_dependenciesCloneGenerated","cloneDependencies","_dependenciesColumnGenerated","columnDependencies","_dependenciesColumnTransformGenerated","columnTransformDependencies","_dependenciesCombinationsGenerated","combinationsDependencies","_dependenciesCombinationsWithRepGenerated","combinationsWithRepDependencies","_dependenciesCompareGenerated","compareDependencies","_dependenciesCompareNaturalGenerated","compareNaturalDependencies","_dependenciesCompareTextGenerated","compareTextDependencies","_dependenciesCompileGenerated","compileDependencies","_dependenciesComplexGenerated","complexDependencies","_dependenciesCompositionGenerated","compositionDependencies","_dependenciesConcatGenerated","concatDependencies","_dependenciesConcatTransformGenerated","concatTransformDependencies","_dependenciesConductanceQuantumGenerated","conductanceQuantumDependencies","_dependenciesConjGenerated","conjDependencies","_dependenciesCosGenerated","cosDependencies","_dependenciesCoshGenerated","coshDependencies","_dependenciesCotGenerated","cotDependencies","_dependenciesCothGenerated","cothDependencies","_dependenciesCoulombGenerated","coulombDependencies","_dependenciesCountGenerated","countDependencies","_dependenciesCreateUnitGenerated","createUnitDependencies","_dependenciesCrossGenerated","crossDependencies","_dependenciesCscGenerated","cscDependencies","_dependenciesCschGenerated","cschDependencies","_dependenciesCtransposeGenerated","ctransposeDependencies","_dependenciesCubeGenerated","cubeDependencies","_dependenciesCumSumGenerated","cumsumDependencies","_dependenciesCumSumTransformGenerated","cumsumTransformDependencies","_dependenciesDeepEqualGenerated","deepEqualDependencies","_dependenciesDerivativeGenerated","derivativeDependencies","_dependenciesDetGenerated","detDependencies","_dependenciesDeuteronMassGenerated","deuteronMassDependencies","_dependenciesDiagGenerated","diagDependencies","_dependenciesDiffGenerated","diffDependencies","_dependenciesDiffTransformGenerated","diffTransformDependencies","_dependenciesDistanceGenerated","distanceDependencies","_dependenciesDivideGenerated","divideDependencies","_dependenciesDivideScalarGenerated","divideScalarDependencies","_dependenciesDotGenerated","dotDependencies","_dependenciesDotDivideGenerated","dotDivideDependencies","_dependenciesDotMultiplyGenerated","dotMultiplyDependencies","_dependenciesDotPowGenerated","dotPowDependencies","_dependenciesEGenerated","eDependencies","_dependenciesEfimovFactorGenerated","efimovFactorDependencies","_dependenciesEigsGenerated","eigsDependencies","_dependenciesElectricConstantGenerated","electricConstantDependencies","_dependenciesElectronMassGenerated","electronMassDependencies","_dependenciesElementaryChargeGenerated","elementaryChargeDependencies","_dependenciesEqualGenerated","equalDependencies","_dependenciesEqualScalarGenerated","equalScalarDependencies","_dependenciesEqualTextGenerated","equalTextDependencies","_dependenciesErfGenerated","erfDependencies","_dependenciesEvaluateGenerated","evaluateDependencies","_dependenciesExpGenerated","expDependencies","_dependenciesExpm1Generated","expm1Dependencies","_dependenciesExpmGenerated","expmDependencies","_dependenciesFactorialGenerated","factorialDependencies","_dependenciesFalseGenerated","falseDependencies","_dependenciesFaradayGenerated","faradayDependencies","_dependenciesFermiCouplingGenerated","fermiCouplingDependencies","_dependenciesFftGenerated","fftDependencies","_dependenciesFilterGenerated","filterDependencies","_dependenciesFilterTransformGenerated","filterTransformDependencies","_dependenciesFineStructureGenerated","fineStructureDependencies","_dependenciesFirstRadiationGenerated","firstRadiationDependencies","_dependenciesFixGenerated","fixDependencies","_dependenciesFlattenGenerated","flattenDependencies","_dependenciesFloorGenerated","floorDependencies","_dependenciesForEachGenerated","forEachDependencies","_dependenciesForEachTransformGenerated","forEachTransformDependencies","_dependenciesFormatGenerated","formatDependencies","_dependenciesFractionGenerated","fractionDependencies","_dependenciesGammaGenerated","gammaDependencies","_dependenciesGasConstantGenerated","gasConstantDependencies","_dependenciesGcdGenerated","gcdDependencies","_dependenciesGetMatrixDataTypeGenerated","getMatrixDataTypeDependencies","_dependenciesGravitationConstantGenerated","gravitationConstantDependencies","_dependenciesGravityGenerated","gravityDependencies","_dependenciesHartreeEnergyGenerated","hartreeEnergyDependencies","_dependenciesHasNumericValueGenerated","hasNumericValueDependencies","_dependenciesHelpGenerated","helpDependencies","_dependenciesHexGenerated","hexDependencies","_dependenciesHypotGenerated","hypotDependencies","_dependenciesIGenerated","iDependencies","_dependenciesIdentityGenerated","identityDependencies","_dependenciesIfftGenerated","ifftDependencies","_dependenciesImGenerated","imDependencies","_dependenciesIndexGenerated","indexDependencies","_dependenciesIndexTransformGenerated","indexTransformDependencies","_dependenciesIntersectGenerated","intersectDependencies","_dependenciesInvGenerated","invDependencies","_dependenciesInverseConductanceQuantumGenerated","inverseConductanceQuantumDependencies","_dependenciesInvmodGenerated","invmodDependencies","_dependenciesIsIntegerGenerated","isIntegerDependencies","_dependenciesIsNaNGenerated","isNaNDependencies","_dependenciesIsNegativeGenerated","isNegativeDependencies","_dependenciesIsNumericGenerated","isNumericDependencies","_dependenciesIsPositiveGenerated","isPositiveDependencies","_dependenciesIsPrimeGenerated","isPrimeDependencies","_dependenciesIsZeroGenerated","isZeroDependencies","_dependenciesKldivergenceGenerated","kldivergenceDependencies","_dependenciesKlitzingGenerated","klitzingDependencies","_dependenciesKronGenerated","kronDependencies","_dependenciesLargerGenerated","largerDependencies","_dependenciesLargerEqGenerated","largerEqDependencies","_dependenciesLcmGenerated","lcmDependencies","_dependenciesLeafCountGenerated","leafCountDependencies","_dependenciesLeftShiftGenerated","leftShiftDependencies","_dependenciesLgammaGenerated","lgammaDependencies","_dependenciesLog10Generated","log10Dependencies","_dependenciesLog1pGenerated","log1pDependencies","_dependenciesLog2Generated","log2Dependencies","_dependenciesLogGenerated","logDependencies","_dependenciesLoschmidtGenerated","loschmidtDependencies","_dependenciesLsolveAllGenerated","lsolveAllDependencies","_dependenciesLsolveGenerated","lsolveDependencies","_dependenciesLupGenerated","lupDependencies","_dependenciesLusolveGenerated","lusolveDependencies","_dependenciesMadGenerated","madDependencies","_dependenciesMagneticConstantGenerated","magneticConstantDependencies","_dependenciesMagneticFluxQuantumGenerated","magneticFluxQuantumDependencies","_dependenciesMapGenerated","mapDependencies","_dependenciesMapTransformGenerated","mapTransformDependencies","_dependenciesMatrixGenerated","matrixDependencies","_dependenciesMatrixFromColumnsGenerated","matrixFromColumnsDependencies","_dependenciesMatrixFromFunctionGenerated","matrixFromFunctionDependencies","_dependenciesMatrixFromRowsGenerated","matrixFromRowsDependencies","_dependenciesMaxGenerated","maxDependencies","_dependenciesMaxTransformGenerated","maxTransformDependencies","_dependenciesMeanGenerated","meanDependencies","_dependenciesMeanTransformGenerated","meanTransformDependencies","_dependenciesMedianGenerated","medianDependencies","_dependenciesMinGenerated","minDependencies","_dependenciesMinTransformGenerated","minTransformDependencies","_dependenciesModGenerated","modDependencies","_dependenciesModeGenerated","modeDependencies","_dependenciesMolarMassC12Generated","molarMassC12Dependencies","_dependenciesMolarMassGenerated","molarMassDependencies","_dependenciesMolarPlanckConstantGenerated","molarPlanckConstantDependencies","_dependenciesMolarVolumeGenerated","molarVolumeDependencies","_dependenciesMultinomialGenerated","multinomialDependencies","_dependenciesMultiplyGenerated","multiplyDependencies","_dependenciesMultiplyScalarGenerated","multiplyScalarDependencies","_dependenciesNeutronMassGenerated","neutronMassDependencies","_dependenciesNormGenerated","normDependencies","_dependenciesNotGenerated","notDependencies","_dependenciesNthRootGenerated","nthRootDependencies","_dependenciesNthRootsGenerated","nthRootsDependencies","_dependenciesNuclearMagnetonGenerated","nuclearMagnetonDependencies","_dependenciesNullGenerated","nullDependencies","_dependenciesNumberGenerated","numberDependencies","_dependenciesNumericGenerated","numericDependencies","_dependenciesOctGenerated","octDependencies","_dependenciesOnesGenerated","onesDependencies","_dependenciesOrGenerated","orDependencies","_dependenciesParseGenerated","parseDependencies","_dependenciesParserGenerated","parserDependencies","_dependenciesPartitionSelectGenerated","partitionSelectDependencies","_dependenciesPermutationsGenerated","permutationsDependencies","_dependenciesPhiGenerated","phiDependencies","_dependenciesPiGenerated","piDependencies","_dependenciesPickRandomGenerated","pickRandomDependencies","_dependenciesPinvGenerated","pinvDependencies","_dependenciesPlanckChargeGenerated","planckChargeDependencies","_dependenciesPlanckConstantGenerated","planckConstantDependencies","_dependenciesPlanckLengthGenerated","planckLengthDependencies","_dependenciesPlanckMassGenerated","planckMassDependencies","_dependenciesPlanckTemperatureGenerated","planckTemperatureDependencies","_dependenciesPlanckTimeGenerated","planckTimeDependencies","_dependenciesPowGenerated","powDependencies","_dependenciesPrintGenerated","printDependencies","_dependenciesProdGenerated","prodDependencies","_dependenciesProtonMassGenerated","protonMassDependencies","_dependenciesQrGenerated","qrDependencies","_dependenciesQuantileSeqGenerated","quantileSeqDependencies","_dependenciesQuantumOfCirculationGenerated","quantumOfCirculationDependencies","_dependenciesRandomGenerated","randomDependencies","_dependenciesRandomIntGenerated","randomIntDependencies","_dependenciesRangeGenerated","rangeDependencies","_dependenciesRangeTransformGenerated","rangeTransformDependencies","_dependenciesRationalizeGenerated","rationalizeDependencies","_dependenciesReGenerated","reDependencies","_dependenciesReducedPlanckConstantGenerated","reducedPlanckConstantDependencies","_dependenciesReplacerGenerated","replacerDependencies","_dependenciesReshapeGenerated","reshapeDependencies","_dependenciesResizeGenerated","resizeDependencies","_dependenciesResolveGenerated","resolveDependencies","_dependenciesReviverGenerated","reviverDependencies","_dependenciesRightArithShiftGenerated","rightArithShiftDependencies","_dependenciesRightLogShiftGenerated","rightLogShiftDependencies","_dependenciesRotateGenerated","rotateDependencies","_dependenciesRotationMatrixGenerated","rotationMatrixDependencies","_dependenciesRoundGenerated","roundDependencies","_dependenciesRowGenerated","rowDependencies","_dependenciesRowTransformGenerated","rowTransformDependencies","_dependenciesRydbergGenerated","rydbergDependencies","_dependenciesSackurTetrodeGenerated","sackurTetrodeDependencies","_dependenciesSecGenerated","secDependencies","_dependenciesSechGenerated","sechDependencies","_dependenciesSecondRadiationGenerated","secondRadiationDependencies","_dependenciesSetCartesianGenerated","setCartesianDependencies","_dependenciesSetDifferenceGenerated","setDifferenceDependencies","_dependenciesSetDistinctGenerated","setDistinctDependencies","_dependenciesSetIntersectGenerated","setIntersectDependencies","_dependenciesSetIsSubsetGenerated","setIsSubsetDependencies","_dependenciesSetMultiplicityGenerated","setMultiplicityDependencies","_dependenciesSetPowersetGenerated","setPowersetDependencies","_dependenciesSetSizeGenerated","setSizeDependencies","_dependenciesSetSymDifferenceGenerated","setSymDifferenceDependencies","_dependenciesSetUnionGenerated","setUnionDependencies","_dependenciesSignGenerated","signDependencies","_dependenciesSimplifyCoreGenerated","simplifyCoreDependencies","_dependenciesSimplifyGenerated","simplifyDependencies","_dependenciesSinGenerated","sinDependencies","_dependenciesSinhGenerated","sinhDependencies","_dependenciesSizeGenerated","sizeDependencies","_dependenciesSluGenerated","sluDependencies","_dependenciesSmallerGenerated","smallerDependencies","_dependenciesSmallerEqGenerated","smallerEqDependencies","_dependenciesSortGenerated","sortDependencies","_dependenciesSparseGenerated","sparseDependencies","_dependenciesSpeedOfLightGenerated","speedOfLightDependencies","_dependenciesSplitUnitGenerated","splitUnitDependencies","_dependenciesSqrtGenerated","sqrtDependencies","_dependenciesSqrtmGenerated","sqrtmDependencies","_dependenciesSquareGenerated","squareDependencies","_dependenciesSqueezeGenerated","squeezeDependencies","_dependenciesStdGenerated","stdDependencies","_dependenciesStdTransformGenerated","stdTransformDependencies","_dependenciesStefanBoltzmannGenerated","stefanBoltzmannDependencies","_dependenciesStirlingS2Generated","stirlingS2Dependencies","_dependenciesStringGenerated","stringDependencies","_dependenciesSubsetGenerated","subsetDependencies","_dependenciesSubsetTransformGenerated","subsetTransformDependencies","_dependenciesSubtractGenerated","subtractDependencies","_dependenciesSumGenerated","sumDependencies","_dependenciesSumTransformGenerated","sumTransformDependencies","_dependenciesSymbolicEqualGenerated","symbolicEqualDependencies","_dependenciesTanGenerated","tanDependencies","_dependenciesTanhGenerated","tanhDependencies","_dependenciesTauGenerated","tauDependencies","_dependenciesThomsonCrossSectionGenerated","thomsonCrossSectionDependencies","_dependenciesToGenerated","toDependencies","_dependenciesTraceGenerated","traceDependencies","_dependenciesTransposeGenerated","transposeDependencies","_dependenciesTrueGenerated","trueDependencies","_dependenciesTypeOfGenerated","typeOfDependencies","_dependenciesTypedGenerated","typedDependencies","_dependenciesUnaryMinusGenerated","unaryMinusDependencies","_dependenciesUnaryPlusGenerated","unaryPlusDependencies","_dependenciesUnequalGenerated","unequalDependencies","_dependenciesUnitFunctionGenerated","unitDependencies","_dependenciesUsolveAllGenerated","usolveAllDependencies","_dependenciesUsolveGenerated","usolveDependencies","_dependenciesVacuumImpedanceGenerated","vacuumImpedanceDependencies","_dependenciesVarianceGenerated","varianceDependencies","_dependenciesVarianceTransformGenerated","varianceTransformDependencies","_dependenciesVersionGenerated","versionDependencies","_dependenciesWeakMixingAngleGenerated","weakMixingAngleDependencies","_dependenciesWienDisplacementGenerated","wienDisplacementDependencies","_dependenciesXgcdGenerated","xgcdDependencies","_dependenciesXorGenerated","xorDependencies","_dependenciesZerosGenerated","zerosDependencies","_factoriesAny","createAbs","createAccessorNode","createAcos","createAcosh","createAcot","createAcoth","createAcsc","createAcsch","createAdd","createAddScalar","createAnd","createApply","createApplyTransform","createArg","createArrayNode","createAsec","createAsech","createAsin","createAsinh","createAssignmentNode","createAtan","createAtan2","createAtanh","createAtomicMass","createAvogadro","createBellNumbers","createBigNumberClass","createBignumber","createBin","createBitAnd","createBitNot","createBitOr","createBitXor","createBlockNode","createBohrMagneton","createBohrRadius","createBoltzmann","createBoolean","createCatalan","createCbrt","createCeil","createChain","createChainClass","createClassicalElectronRadius","createClone","createColumn","createColumnTransform","createCombinations","createCombinationsWithRep","createCompare","createCompareNatural","createCompareText","createCompile","createComplex","createComplexClass","createComposition","createConcat","createConcatTransform","createConditionalNode","createConductanceQuantum","createConj","createConstantNode","createCos","createCosh","createCot","createCoth","createCoulomb","createCount","createCreateUnit","createCross","createCsc","createCsch","createCtranspose","createCube","createCumSum","createCumSumTransform","createDeepEqual","createDenseMatrixClass","createDerivative","createDet","createDeuteronMass","createDiag","createDiff","createDiffTransform","createDistance","createDivide","createDivideScalar","createDot","createDotDivide","createDotMultiply","createDotPow","createEfimovFactor","createEigs","createElectricConstant","createElectronMass","createElementaryCharge","createEqual","createEqualScalar","createEqualText","createErf","createEvaluate","createExp","createExpm","createExpm1","createFactorial","createFaraday","createFermiCoupling","createFft","createFibonacciHeapClass","createFilter","createFilterTransform","createFineStructure","createFirstRadiation","createFix","createFlatten","createFloor","createForEach","createForEachTransform","createFormat","createFraction","createFractionClass","createFunctionAssignmentNode","createFunctionNode","createGamma","createGasConstant","createGcd","createGetMatrixDataType","createGravitationConstant","createGravity","createHartreeEnergy","createHasNumericValue","createHelp","createHelpClass","createHex","createHypot","createIdentity","createIfft","createIm","createImmutableDenseMatrixClass","createIndex","createIndexClass","createIndexNode","createIndexTransform","createIntersect","createInv","createInverseConductanceQuantum","createInvmod","createIsInteger","createIsNaN","createIsNegative","createIsNumeric","createIsPositive","createIsPrime","createIsZero","createKldivergence","createKlitzing","createKron","createLarger","createLargerEq","createLcm","createLeafCount","createLeftShift","createLgamma","createLog","createLog10","createLog1p","createLog2","createLoschmidt","createLsolve","createLsolveAll","createLup","createLusolve","createMad","createMagneticConstant","createMagneticFluxQuantum","createMap","createMapTransform","createMatrix","createMatrixClass","createMatrixFromColumns","createMatrixFromFunction","createMatrixFromRows","createMax","createMaxTransform","createMean","createMeanTransform","createMedian","createMin","createMinTransform","createMod","createMode","createMolarMass","createMolarMassC12","createMolarPlanckConstant","createMolarVolume","createMultinomial","createMultiply","createMultiplyScalar","createNeutronMass","createNode","createNorm","createNot","createNthRoot","createNthRoots","createNuclearMagneton","createNumber","createNumeric","createObjectNode","createOct","createOnes","createOperatorNode","createOr","createParenthesisNode","createParse","createParser","createParserClass","createPartitionSelect","createPermutations","createPickRandom","createPinv","createPlanckCharge","createPlanckConstant","createPlanckLength","createPlanckMass","createPlanckTemperature","createPlanckTime","createPow","createPrint","createProd","createProtonMass","createQr","createQuantileSeq","createQuantumOfCirculation","createRandom","createRandomInt","createRange","createRangeClass","createRangeNode","createRangeTransform","createRationalize","createRe","createReducedPlanckConstant","createRelationalNode","createReplacer","createReshape","createResize","createResolve","createResultSet","createReviver","createRightArithShift","createRightLogShift","createRotate","createRotationMatrix","createRound","createRow","createRowTransform","createRydberg","createSackurTetrode","createSec","createSech","createSecondRadiation","createSetCartesian","createSetDifference","createSetDistinct","createSetIntersect","createSetIsSubset","createSetMultiplicity","createSetPowerset","createSetSize","createSetSymDifference","createSetUnion","createSign","createSimplify","createSimplifyCore","createSin","createSinh","createSize","createSlu","createSmaller","createSmallerEq","createSort","createSpaClass","createSparse","createSparseMatrixClass","createSpeedOfLight","createSplitUnit","createSqrt","createSqrtm","createSquare","createSqueeze","createStd","createStdTransform","createStefanBoltzmann","createStirlingS2","createString","createSubset","createSubsetTransform","createSubtract","createSum","createSumTransform","createSymbolNode","createSymbolicEqual","createTan","createTanh","createThomsonCrossSection","createTo","createTrace","createTranspose","createTypeOf","createUnaryMinus","createUnaryPlus","createUnequal","createUnitClass","createUnitFunction","createUsolve","createUsolveAll","createVacuumImpedance","createVariance","createVarianceTransform","createWeakMixingAngle","createWienDisplacement","createXgcd","createXor","createZeros","derivative","compile","SymbolNode","RelationalNode","RangeNode","Parser","ParenthesisNode","OperatorNode","ObjectNode","Node","IndexNode","Help","FunctionNode","FunctionAssignmentNode","ConstantNode","ConditionalNode","Chain","BlockNode","AssignmentNode","ArrayNode","AccessorNode","_embeddedDocs","embeddedDocs","symbolicEqual","simplifyCore","simplify","reviver","rationalize","parser","leafCount","help","evaluate","_configReadonly","_pureFunctionsAnyGenerated","ResultSet","subset","size","Unit","numeric","equal","multiply","bignumber","fraction","false","_false","fineStructure","_Infinity","_NaN","null","_null","sackurTetrode","true","_true","efimovFactor","replacer","unaryPlus","weakMixingAngle","acot","acsc","addScalar","asech","bitNot","boolean","combinations","complex","conj","coth","csc","cube","equalScalar","erf","format","getMatrixDataType","hex","lgamma","multiplyScalar","not","oct","pickRandom","print","sec","splitUnit","square","string","typeOf","acsch","asec","bin","combinationsWithRep","csch","isPrime","randomInt","sech","sparse","unaryMinus","acoth","cot","isNumeric","matrixFromFunction","nthRoot","or","reshape","smaller","squeeze","transpose","xgcd","zeros","and","bitAnd","bitXor","compareText","ctranspose","diag","divideScalar","dotDivide","fft","hasNumericValue","ifft","kron","largerEq","leftShift","lsolve","matrixFromColumns","mode","nthRoots","ones","partitionSelect","resize","rightArithShift","smallerEq","unequal","usolve","xor","bitOr","catalan","compareNatural","cumsum","deepEqual","diff","dot","equalText","identity","invmod","larger","lsolveAll","matrixFromRows","qr","range","rightLogShift","setSize","slu","trace","usolveAll","composition","cross","det","distance","dotMultiply","fix","intersect","lcm","log1p","quantileSeq","row","setCartesian","setDistinct","setIsSubset","setPowerset","column","inv","pinv","setDifference","setMultiplicity","sqrtm","vacuumImpedance","wienDisplacement","atomicMass","bohrMagneton","boltzmann","conductanceQuantum","createUnit","deuteronMass","dotPow","electricConstant","elementaryCharge","expm","faraday","firstRadiation","gamma","gravitationConstant","hartreeEnergy","klitzing","loschmidt","magneticConstant","molarMass","molarPlanckConstant","neutronMass","nuclearMagneton","planckCharge","planckLength","planckTemperature","protonMass","reducedPlanckConstant","rydberg","setIntersect","speedOfLight","stefanBoltzmann","thomsonCrossSection","avogadro","bohrRadius","coulomb","electronMass","factorial","gravity","inverseConductanceQuantum","lup","magneticFluxQuantum","molarMassC12","multinomial","permutations","planckMass","quantumOfCirculation","secondRadiation","stirlingS2","unit","bellNumbers","eigs","fermiCoupling","mean","molarVolume","planckConstant","setSymDifference","classicalElectronRadius","lusolve","median","setUnion","variance","kldivergence","norm","planckTime","rotationMatrix","gasConstant","std","mad","rotate","Index","Matrix","Range","SparseMatrix","FibonacciHeap","ImmutableDenseMatrix","Spa","createProxy","_exportNames","_create","_impureFunctionsAnyGenerated","_typeChecks","_dependenciesAnyGenerated","message","stack","isArgumentsError","relation","RangeError","isDimensionError","isIndexError","_string","doc","description","syntax","examples","scope","expr","mayThrow","seealso","mathjs","fromJSON","createEmptyMap","isParser","getAll","toObject","getAllAsMap","delete","InfinityDocs","LN10Docs","LN2Docs","LOG10EDocs","LOG2EDocs","NaNDocs","SQRT12Docs","SQRT2Docs","eDocs","falseDocs","iDocs","nullDocs","phiDocs","piDocs","tauDocs","trueDocs","versionDocs","bignumberDocs","booleanDocs","complexDocs","createUnitDocs","fractionDocs","indexDocs","matrixDocs","numberDocs","sparseDocs","splitUnitDocs","stringDocs","unitDocs","configDocs","importDocs","typedDocs","_LN","_LN2","_LOG10E","_LOG2E","_phi","_pi","_SQRT1_","_SQRT","_tau","_bignumber","_boolean","_complex","_createUnit","_fraction","_matrix","_sparse","_splitUnit","_unit","_typed","_derivative","_leafCount","_lsolve","_lsolveAll","_lup","_lusolve","_qr","_rationalize","_resolve","_simplify","_simplifyCore","_slu","_symbolicEqual","_usolve","_usolveAll","_abs","_add","_cbrt","_ceil","_cube","_divide","_dotDivide","_dotMultiply","_dotPow","_exp","_expm","_expm2","_fix","_floor","_gcd","_hypot","_invmod","_lcm","_log","_log2","_log1p","_log3","_mod","_multiply","_norm","_nthRoot","_nthRoots","_pow","_round","_sign","_sqrt","_sqrtm","_square","_subtract","_unaryMinus","_unaryPlus","_xgcd","_bitAnd","_bitNot","_bitOr","_bitXor","_leftShift","_rightArithShift","_rightLogShift","_bellNumbers","_catalan","_composition","_stirlingS","_arg","_conj","_im","_re","_evaluate","_help","_distance","_intersect","_and","_not","_or","_xor","_column","_concat","_count","_cross","_ctranspose","_det","_diag","_diff","_dot","_eigs","_filter","_flatten","_forEach","_getMatrixDataType","_identity","_inv","_pinv","_kron","_matrixFromColumns","_matrixFromFunction","_matrixFromRows","_ones","_partitionSelect","_range","_reshape","_resize","_rotate","_rotationMatrix","_row","_size","_sort","_squeeze","_subset","_trace","_transpose","_zeros","_fft","_ifft","_combinations","_combinationsWithRep","_factorial","_gamma","_lgamma","_kldivergence","_multinomial","_permutations","_pickRandom","_random","_randomInt","_compare","_compareNatural","_compareText","_deepEqual","_equal","_equalText","_larger","_largerEq","_smaller","_smallerEq","_unequal","_setCartesian","_setDifference","_setDistinct","_setIntersect","_setIsSubset","_setMultiplicity","_setPowerset","_setSize","_setSymDifference","_setUnion","_erf","_mad","_max","_mean","_median","_min","_mode","_prod","_quantileSeq","_std","_cumsum","_sum","_variance","_acos","_acosh","_acot","_acoth","_acsc","_acsch","_asec","_asech","_asin","_asinh","_atan","_atan2","_atanh","_cos","_cosh","_cot","_coth","_csc","_csch","_sec","_sech","_sin","_sinh","_tan","_tanh","_to","_bin","_clone","_format","_hasNumericValue","_hex","_isInteger","_isNaN","_isNegative","_isNumeric","_isPositive","_isPrime","_isZero","_numeric","_oct","_print","_typeOf","derivativeDocs","lsolveDocs","lsolveAllDocs","lupDocs","lusolveDocs","leafCountDocs","resolveDocs","simplifyDocs","simplifyCoreDocs","symbolicEqualDocs","rationalizeDocs","sluDocs","usolveDocs","usolveAllDocs","qrDocs","absDocs","addDocs","cbrtDocs","ceilDocs","cubeDocs","divideDocs","dotDivideDocs","dotMultiplyDocs","dotPowDocs","expDocs","expmDocs","expm1Docs","fixDocs","floorDocs","gcdDocs","hypotDocs","lcmDocs","logDocs","log2Docs","log1pDocs","log10Docs","modDocs","multiplyDocs","normDocs","nthRootDocs","nthRootsDocs","powDocs","roundDocs","signDocs","sqrtDocs","sqrtmDocs","squareDocs","subtractDocs","unaryMinusDocs","unaryPlusDocs","xgcdDocs","invmodDocs","bitAndDocs","bitNotDocs","bitOrDocs","bitXorDocs","leftShiftDocs","rightArithShiftDocs","rightLogShiftDocs","bellNumbersDocs","catalanDocs","compositionDocs","stirlingS2Docs","argDocs","conjDocs","reDocs","imDocs","evaluateDocs","helpDocs","distanceDocs","intersectDocs","andDocs","notDocs","orDocs","xorDocs","concatDocs","countDocs","crossDocs","columnDocs","ctransposeDocs","detDocs","diagDocs","diffDocs","dotDocs","getMatrixDataTypeDocs","identityDocs","filterDocs","flattenDocs","forEachDocs","invDocs","pinvDocs","eigsDocs","kronDocs","matrixFromFunctionDocs","matrixFromRowsDocs","matrixFromColumnsDocs","mapDocs","onesDocs","partitionSelectDocs","rangeDocs","resizeDocs","reshapeDocs","rotateDocs","rotationMatrixDocs","rowDocs","sizeDocs","sortDocs","squeezeDocs","subsetDocs","traceDocs","transposeDocs","zerosDocs","fftDocs","ifftDocs","combinationsDocs","combinationsWithRepDocs","factorialDocs","gammaDocs","kldivergenceDocs","lgammaDocs","multinomialDocs","permutationsDocs","pickRandomDocs","randomDocs","randomIntDocs","compareDocs","compareNaturalDocs","compareTextDocs","deepEqualDocs","equalDocs","equalTextDocs","largerDocs","largerEqDocs","smallerDocs","smallerEqDocs","unequalDocs","setCartesianDocs","setDifferenceDocs","setDistinctDocs","setIntersectDocs","setIsSubsetDocs","setMultiplicityDocs","setPowersetDocs","setSizeDocs","setSymDifferenceDocs","setUnionDocs","erfDocs","cumSumDocs","madDocs","maxDocs","meanDocs","medianDocs","minDocs","modeDocs","prodDocs","quantileSeqDocs","stdDocs","sumDocs","varianceDocs","acosDocs","acoshDocs","acotDocs","acothDocs","acscDocs","acschDocs","asecDocs","asechDocs","asinDocs","asinhDocs","atanDocs","atanhDocs","atan2Docs","cosDocs","coshDocs","cotDocs","cothDocs","cscDocs","cschDocs","secDocs","sechDocs","sinDocs","sinhDocs","tanDocs","tanhDocs","toDocs","cloneDocs","formatDocs","binDocs","octDocs","hexDocs","isNaNDocs","isIntegerDocs","isNegativeDocs","isNumericDocs","hasNumericValueDocs","isPositiveDocs","isPrimeDocs","isZeroDocs","printDocs","typeOfDocs","numericDocs","_collection","deepMap","_customs","any","searchName","getSafeProperty","searchText","keywords","Set","_access","access","accessFactory","isObjectProperty","getObjectProperty","needParenthesis","node","_compile","argNames","evalObject","evalIndex","_ifNode","_toString","toHTML","_toTex","toTex","items","every","evalItems","evalItem","itemsToTex","nested","mixedItems","itemsFormRow","itemSep","itemsTex","_assign","_operators","assignFactory","parenthesis","precedence","getPrecedence","exprPrecedence","evalValue","setSafeProperty","childObject","evalParentObject","parentProp","parent","evalParentIndex","parentIndex","blocks","block","visible","evalBlocks","results","condition","trueExpr","falseExpr","evalCondition","evalTrueExpr","evalFalseExpr","testCondition","conditionPrecedence","truePrecedence","falsePrecedence","_latex","escapeLatex","toLatex","_keywords","childArgNames","evalExpr","childArgs","escape","toSymbol","_toConsumableArray2","_scope","strin","entity","evalArgs","_rawArgs2","validateSafeMethod","rawArgs","createSubScope","evalArg","fnExpr","evalFn","_rawArgs3","_rawArgs","isRaw","resolveFn","onUndefinedFunction","evalArg0","evalArg1","nodeToString","expandTemplate","template","latex","inputPos","property","ReferenceError","customString","handler","nodeToTex","customTex","latexConverter","customToTex","latexFunctions","defaultTemplate","getIdentifier","dimensions","dotNotation","evalDimensions","dimension","_evalDimension","evalDimension","comment","symbol","_validateScope","traverse","_traverse","child","path","_transform","replacement","nodes","cloneDeep","other","deepStrictEqual","_getCustomString","getContent","properties","evalEntries","stringifiedKey","parsedKey","isSafeProperty","op","implicit","isPercentage","calculateNecessaryParentheses","associativity","getAssociativity","operandPrecedence","operandIdentifier","rootIdentifier","latexLeftParens","latexParens","lhsParens","rhsParens","lhsPrecedence","assocWithLhs","isAssociativeWith","_rootIdentifier","lhsIdentifier","rhsIdentifier","rhsPrecedence","assocWithRhs","latexRightParens","argPrecedence","assocWithArg","argAssociativity","isSafeMethod","_evalArg","isUnary","parens","assoc","operand","opIsNamed","lhs","rhs","stringifiedArgs","latexOperators","lhsTex","rhsTex","texifiedArgs","step","startPrecedence","stepPrecedence","endPrecedence","needsEnd","evalStart","evalEnd","evalStep","conditionals","isRelationalNode","compiled","evalLhs","evalRhs","condFn","_this","_this2","paramStrings","paramPrecedence","operatorMap","isValuelessUnit","onUndefinedSymbol","_errorTransform","errorTransform","_node","identifier","nodeA","nodeB","identifierA","identifierB","associativeWith","parseStart","expressions","parseMultiple","extraNodes","elem","DELIMITERS","NAMED_DELIMITERS","in","CONSTANTS","NUMERIC_CONSTANTS","currentString","substr","currentCharacter","prevCharacter","nextCharacter","getToken","tokenType","token","isWhitespace","nestingLevel","c1","c2","c3","isDigitDot","_c","isHexDigit","isDigit","isDecimalMark","createSyntaxError","isAlpha","getTokenSkipNewline","openParams","closeParams","conditionalLevel","parseAssignment","parseBlock","valid","parseLogicalXor","parseLogicalOr","parseConditional","parseLogicalAnd","parseBitwiseOr","parseBitwiseXor","parseBitwiseAnd","parseRelational","parseShift","operators","cond","parseConversion","parseRange","parseAddSubtract","parseMultiplyDivide","rightNode","parseImplicitMultiplication","parseRule2","parsePercentage","tokenStates","parseUnary","CustomNode","parseAccessors","parseDoubleQuotesStringToken","parseSingleQuotesStringToken","rows","cols","parseRow","numberStr","parseEnd","parseParentheses","parseNumber","parseObject","parseMatrix","parseSingleQuotesString","parseDoubleQuotesString","parseSymbol","parseCustomNodes","parseLeftHandOperators","parsePow","col","char","cPrev","cNext","isValidLatinOrGreek","isValidMathSymbol","high","low","_apply","dim","lastIndex","_lastDimToZeroBase","lastDimToZeroBase","_function","_compileInlineExpression","filterTransform","compileInlineExpression","toArray","filterRegExp","maxArgumentCount","forEachTransform","recurse","isSet","mapTransform","orig","argsCount","subScope","_AccessorNode","_addScalar","_applyTransform","_ArrayNode","_AssignmentNode","_physicalConstants","_BigNumber","_BlockNode","_chain","_Chain","_columnTransform","_Complex","_concatTransform","_ConditionalNode","_ConstantNode","_cumsumTransform","_DenseMatrix","_diffTransform","_divideScalar","_equalScalar","_FibonacciHeap","_filterTransform","_forEachTransform","_Fraction","_FunctionAssignmentNode","_FunctionNode","_Help","_ImmutableDenseMatrix","_MatrixIndex","_IndexNode","_indexTransform","_mapTransform","_Matrix","_maxTransform","_meanTransform","_minTransform","_multiplyScalar","_Node","_ObjectNode","_OperatorNode","_ParenthesisNode","_parse","_parser","_Parser","_Range","_RangeNode","_rangeTransform","_RelationalNode","_replacer","_ResultSet","_reviver","_rowTransform","_Spa","_SparseMatrix","_stdTransform","_subsetTransform","_sumTransform","_SymbolNode","_Unit","_varianceTransform","_denseLUP","columns","_values","ptr","_ptr","lvalues","lindex","lptr","lsize","uvalues","uindex","uptr","usize","pvCo","pvOc","spa","k0","k1","vkj","_forEachRow","vik","accumulate","kx","ky","vjj","pabsv","absv","_swapRows","swap","U","_sparseLUP","_data","ldata","udata","vij","pv","_denseQR","_sparseQR","Q","R","_denseQRimpl","Qdata","Rdata","pivot","sgn","conjSgn","alphaSquared","u1","zero","_csSqr","_csLu","csSqr","createCsSqr","csLu","createCsLu","order","threshold","variable","constNodes","constTag","deriv","_derivTex","varName","isConst","funcArgsCheck","funcDerivative","func","negative","chainDerivative","constantTerms","nonConstantTerms","nonConstantNode","newArgs","argOuter","argInner","_arg2","powMinusOne","valueType","countLeaves","_simplifyConstant","simplifyConstant","createSimplifyConstant","detailed","setRules","oldRules","rulesFirst","rulesSucDiv","firstRules","distrDivRules","sucDivRules","firstRulesAgain","finalRules","rulesRationalize","polyRet","extended","rules","variables","exactFractions","oper","recPoly","retFunc","polynomial","nVars","noExactFractions","withExactFractions","sBefore","expandPower","eDistrDiv","redoInic","coefficients","retRationalize","polyToCanonical","indParent","internal","val","does","nEsqTopo","nDirTopo","maxExpo","varname","recurPol","noPai","noFil","fire","cte","valor","_i2","no","first","n2","n3","within","nextWithin","_args","_util","_createUtil","createUtil","hasProperty","isCommutative","isAssociative","mergeContext","unflattenr","unflattenl","createMakeNodeFunction","defaultContext","realContext","positiveContext","debug","consoleDebug","ruleSet","rule","newRule","ruleType","_canonicalizeRule","_buildRules","visited","removeParens","_lastsym","laststr","rulestr","applyRule","newstr","SUPPORTED_CONSTANTS","ruleObject","lr","makeNode","expandsym","expanded","assuming","total","commutative","repeat","imposeContext","associative","addition","mapRule","resNodes","newNode","mergedContext","newContent","newItems","newIndex","newDims","changed","newProps","repl","_ruleMatch","placeholders","mergeMatch","match1","match2","_exactMatch","combineChildMatches","list1","list2","merged","i1","i2","isSplit","splits","right","rightArgs","left","getSplits","splitMatches","_i3","matchSet","childMatches","childMatch","leftMatch","rightMatch","sets","uniqueSets","unique","mergeChildMatches","_noop","_createForOfIteratorHelper","allowArrayLike","it","_arrayLikeToArray","_unsupportedIterableToArray","F","normalCompletion","didErr","_e2","return","allChildren","_ensureNode","foldFraction","_removeFractions","thing","_eval","fnname","_toNumber","_toNode","vn","unaryMinusNode","_exactFraction","fractionsLimit","noBignumber","noFraction","foldOp","ignoreandcontinue","sz","section","consts","vars","remainingDims","_step","second","tryItems","fromItems","_iterator","_foldAccessor","foldItems","foldProps","ownKeys","enumerableOnly","getOwnPropertySymbols","symbols","sym","_objectSpread","getOwnPropertyDescriptors","defineProperties","T","defaultName","trivial","paren","defaultF","nodeOrName","_properties","_properties2","findChildren","primary","secondary","curnode","node0","node1","simpChild","childCount","a0","a1","a00","a00a1","a01","_solveValidation","solveValidation","createSolveValidation","bdata","bj","jValues","jIndices","firstIndex","xj","_k","_sparseForwardSubstitution","_denseForwardSubstitution","mdata","b_","iValues","iIndices","Mii","J","bNew","_j3","_lastIndex2","_J2","_j2","_lastIndex","_J","_j","_csIpvec","_toMatrix","csIpvec","_sparseBackwardSubstitution","_denseBackwardSubstitution","mSize","bSize","datatype","_datatype","bsize","arraySize","_i4","_i5","createCsAmd","_csFkeep","_csFlip","_csTdfs","asize","lemax","dense","cm","at","tindex","tptr","_createTargetMatrix","csFkeep","k2","pj","nvi","pk","eln","pn","cindex","cptr","cnz","W","nv","head","elen","degree","hhead","_wclear","_initializeQuotientGraph","nel","csFlip","_initializeDegreeLists","mindeg","elenk","nvk","dk","pk1","pk2","wnvi","dext","p3","p4","nvj","jlast","csTdfs","createCsCounts","_csLeaf","post","ata","p0","maxfirst","prevleaf","colcount","csLeaf","jleaf","csDfs","top","jnew","_csMarked","csMarked","_csMark","csMark","_csUnflip","csUnflip","csEtree","inext","aindex","aptr","avalues","nz","ancestor","sparent","jprev","_csSpsolve","csSpsolve","createCsSpsolve","tol","lnz","unz","ipiv","xabs","csPermute","adt","cvalues","t0","createSparseMatrix","csPost","csReach","gptr","gsize","bindex","bptr","_csDfs","_csReach","lo","gvalues","gindex","bvalues","_csPermute","_csPost","_csEtree","_csAmd","_csCounts","csAmd","csCounts","cp","leftmost","tail","nque","m2","pa","_vcount","e1","e2","simplified","absNumber","_algorithm","_algorithm2","_algorithm3","_algorithm4","_algorithm5","algorithm01","createAlgorithm01","algorithm04","createAlgorithm04","algorithm10","createAlgorithm10","algorithm13","createAlgorithm13","algorithm14","createAlgorithm14","extend","rest","addNumber","equalBase","fixPrefix","cbrtNumber","_cbrtComplex","third","negate","_result","allRoots","arg3","principal","createCeilNumber","_slicedToArray2","_decimal","_nearlyEqual","nearlyEqual","_split","_split2","exponent","_split3","_split4","algorithm11","createAlgorithm11","algorithm12","createAlgorithm12","ceilNumber","storage","cubeNumber","_normalize","_algorithm6","_algorithm7","algorithm02","createAlgorithm02","algorithm03","createAlgorithm03","algorithm07","createAlgorithm07","algorithm09","createAlgorithm09","expNumber","expm1Number","createFixNumber","fixNumber","bn","createFloorNumber","floorNumber","gcdNumber","largest","_res","_res2","algorithm06","createAlgorithm06","lcmNumber","logNumber","log10Number","_log1pComplex","xRe1p","log2Number","_log2Complex","newX","algorithm05","createAlgorithm05","modNumber","_validateMatrixDimensions","size1","size2","_multiplyMatrixVector","dt","adata","bdt","arows","acolumns","af","mf","createDenseMatrix","brows","ib","vbi","ka0","ka1","ka","ia","ic","_multiplyMatrixMatrix","bcolumns","jb","kb0","kb1","cij","kb","vbij","xsize","ysize","_multiplyVectorVector","alength","_multiplyVectorDenseMatrix","_multiplyVectorMatrix","multiplyNumber","sizeX","POSITIVE_INFINITY","pinf","_vectorNormPlusInfinity","NEGATIVE_INFINITY","ninf","_vectorNormMinusInfinity","_vectorNorm","maxc","cj","_matrixNormOne","maxr","ri","_matrixNormInfinity","fro","_matrixNormFrobenius","tx","squaredX","eigenVals","rho","_matrixNormTwo","_matrixNorm","createNthRootNumber","complexErr","nthRootNumber","_bigNthRoot","density","Big","_calculateExactResult","_nthComplexRoots","aIsNumeric","roots","halfPiFactor","_powArray","_powMatrix","yFrac","yNum","powNumber","NO_INT","roundNumber","signNumber","_isDerived","units","_sqrtNumber","squareNumber","checkEqualDimensions","unaryMinusNumber","unaryPlusNumber","xgcdNumber","lastx","lasty","_bitwise","bitAndNumber","bitAndBigNumber","bitNotNumber","bitNotBigNumber","bitOrNumber","bitOrBigNumber","bitXorNumber","algorithm08","createAlgorithm08","leftShiftNumber","leftShiftBigNumber","rightArithShiftNumber","rightArithShiftBigNumber","rightLogShiftNumber","smallCache","bigCache","big","make","nn","nk","conjugate","_2d","xCoeff","yCoeff","constant","_distancePointLine2D","lineTwoPtY","lineTwoPtX","lineOnePtY","lineOnePtX","pointX","pointY","_3d","_parametricLine","_distancePointLine3D","_containsOnlyNumbers","_euclideanDistance","xCoeffLine","yCoeffLine","pointZ","x0","y0","z0","pointOneX","pointOneY","pointTwoX","pointTwoY","pointOneZ","pointTwoZ","_isNumber","aI","_pairwise","pointA","pointB","_distancePairwise","_objectToArray","den","vectorSize","_AAA","_AAAA","plane","_coerceArr","_4d","y1","z1","y2","z2","x1x","x2x","y1y","y2y","z1z","z2z","_intersectLinePlane","p1a","p1b","p2a","p2b","o1","o2","d20o11","d21o10","d20o21","d21o20","_intersect2d","x3","y3","z3","x4","y4","z4","d1343","_intersect3dHelper","d4321","d1321","d4343","d2121","ta","tb","pax","pay","paz","pbx","pby","pbz","_intersect3d","el","add1","add2","add3","andNumber","notNumber","orNumber","xorNumber","mat","tran","_switch","validateIndex","rowRange","prevDim","asMatrix","matrices","concatDim","highestDimension","xSize","ySize","rowIndices","k_","piv","piv_","i_","kSuper","kSub","ms","diagonal","_createDiagonalMatrix","dm","vector","_getDiagonal","_recursive","element","_ElementDiff","obj1","obj2","obj1IsArray","obj2IsArray","arr1","_ArrayDiff","_validateDim","aIsColumn","bIsColumn","_c2","_c3","xindex","xvalues","yindex","yvalues","xLen","yLen","_complexEigs","_realSymetric","doRealSymetric","createRealSymmetric","doComplexEigs","createComplexEigs","computeValuesAndVectors","prec","_computeValuesAndVect","vectors","_computeValuesAndVect2","isReal","coerceReal","isSymmetric","_type","coerceTypes","hasNumber","hasBig","hasComplex","jordanBase2x2","l1","l2","cplx","na","nb","nc","nd","inflateMatrix","_arr$i","inverseIterate","orthog","largeNum","randomOrthogonalVector","orthogonalComplement","normalize","_step3","_iterator3","findVectors","Rdiag","realzero","realone","radix","radixSq","colNorm","rowNorm","rowDivRadix","rowMulRadix","balance","maxIndex","tmp1","tmp2","tmp3","_k2","reduceToHessenberg","_iterateUntilTriangul","trA","detA","lambdas","Sdiag","Qtotal","Qpartial","lastConvergenceBefore","ll","_step2","_iterator2","_i6","blockDiag","iterateUntilTriangular","Cinv","uniqueValues","multiplicities","failedLambdas","solutions","approxVec","correction","findEigenvectors","psi","e0","Sij","createArray","Vab","getAij","aii","ajj","aij","denom","Sij1","Ei","sorting","diagBig","getAijBig","x1Big","Sij1Big","theta","Ski","Skj","Hij","Aki","Akj","csHij","Aii","Ajj","_k3","_k4","Mij","maxMij","maxIJ","minID","_k5","infNorm","rowSum","infinityNorm","errorEstimate","findParams","Apos","factor","AposToI","alternate","qfac","twoqfac","twoqp1fac","_ndFft","_1dFft","_filterCallback","flat","getArrayDataType","getDataType","_identityVector","defaultValue","minimum","acc","ABig","rBig","Ac","Bc","Ar","Br","newmsg","indexString","_createArray","checkVectorTypeAndReturnLength","colLength","vec","rowLength","hasBigNumbers","_validate","asc","quickSelect","_isZeros","_rankFact2","rref","lead","_rref","_rankFact","Cpinv","Fpinv","_strRange","_out","_rangeEx","includeEnd","_rangeInc","_bigRangeEx","_bigRangeInc","noMatrix","nums","sizes","_resizeString","defaultChar","_validateSize","expectedSize","actualSize","_rotationMatrix2x2","matrixV","_validateVector","_rotationMatrix3x3","storageType","minusOne","cosTheta","sinTheta","_convertToFormat","_mul","normV","vx","vy","vz","oneMinusC","columnRange","compareAsc","compareDesc","_arrayIsVector","_matrixIsVector","_comparator","_tolerance","_denmanBeavers","Y","Z","Yk","isScalar","_getObjectProperty","_getSubstring","_setSubstring","_setObjectProperty","strLen","chars","updated","_denseTrace","transposedRow","transposed","_denseTranspose","_sparseTranspose","combinationsNumber","nMinusk","isPositiveInteger","_product","nMinusOne","gammaNumber","_t","gammaP","gammaPval","gammaG","twoPiSqrt","tpow","expt","bigFactorial","_kldiv","plength","qlength","qnorm","pnorm","coeffs","lgammaNumber","lgammaStirling","copysign","lgammaRecurrence","leftPart","lnSqrt2PI","rz","rzz","rightPart","signflips","sb","shiftprod","nsb","deepForEach","ai","_seededRNG","rng","createRng","possibles","weights","_ref2$elementWise","elementWise","single","totalWeights","pick","randKey","createRandomNumber","_randomMatrix2","_randomMatrix","randomMatrix","_randomIntMatrix","_length","singletonRandom","_seedrandom","now","createCompareNumber","_javascriptNaturalSort","compareBooleans","typeX","typeY","compareMatricesAndArrays","compareComplexNumbers","compareArrays","formatUnits","keysX","keysY","compareObjects","createCompareTextNumber","createEqualNumber","createEqualScalarNumber","complexEquals","createLargerNumber","createLargerEqNumber","createSmallerNumber","createSmallerEqNumber","createUnequalNumber","a2","b1","b2","inb2","identify","generalize","bitarray","MAX_NUM","THRESH","ysq","xnum","xden","erf1","del","erfc2","SQRPI","erfc3","_switch2","_improveErrorMessage","_ncumSumDim","containsCollections","_cumsummap","improveErrorMessage","sums","_cumsumDimensional","initialValue","med","_largest","mid","middle2","middle","_smallest","prob","sorted","_fracPart","validate","_left","_right","_integerPart","_value","integerPart","fracPart","integerPartNumber","probOrN","probArr","dataArr","nPlusOne","intN","_nPlusOne","currProb","normalization","fnName","details","DEFAULT_NORMALIZATION","_var","_varDim","notation","wordSize","original","acoshNumber","acotNumber","acothNumber","acscNumber","acschNumber","asecNumber","xInv","asechNumber","asinhNumber","atanhNumber","hasBase","BASE_UNITS","ANGLE","cotNumber","cothNumber","cscNumber","cschNumber","secNumber","sechNumber","sinhNumber","isNaNNumber","isNegativeNumber","isPositiveNumber","modPow","modulus","accumulator","bases","adn","_x","isZeroNumber","validInputTypes","validOutputTypes","outputType","inputType","_mainAny","divideNumber","log1pNumber","normNumber","decimals","sqrtNumber","subtractNumber","answer","nextdivisor","lastdivisor","nextnumerator","_arithmetic","_logical","_relational","_probability","_trigonometry","_utils","lgammaN","lgammaG","lgammaSeries","twoN","threeN","fourN","fiveN","acosNumber","asinNumber","atan2Number","atanNumber","cosNumber","coshNumber","sinNumber","tanNumber","tanhNumber","isIntegerNumber","wordSizeSuffixMatch","twoPowSize","twoPowSizeSubOne","lcase","createLazyProxy","chainify","excludedNames","toPolar","strRe","strIm","fromPolar","ZERO","_regenerator","preprocess","_get","_getSubmatrix","dims","_set","submatrix","sSize","iSize","outer","unsqueeze","_fit","_setSubmatrix","dataIndex","subIndex","newSize","indexI","sizeArray","currentLength","processSizesWildcard","_callee","_context2","_context","swapRows","vi","oneOverLogPhi","_minimum","_cut","_cascadingCut","isFibonacciHeap","insert","isEmpty","extractMinimum","numberOfChildren","tempRight","numRoots","_linkNodes","_findMinimumNode","_decreaseKey","isImmutableDenseMatrix","skipZeros","ranges","_dimensions","_isScalar","_createImmutableMatrix","strings","hasStart","hasEnd","hasStep","_heap","isSpa","heap","nodei","nodej","_createFromArray","_createFromMatrix","_getsubset","kk","mvalues","mindex","mptr","_setsubset","firstDimensionRange","secondDimensionRange","firstDataIndex","firstSubIndex","secondDataIndex","secondSubIndex","_getValueIndex","bottom","_insert","ins","_toArray","_remove","colIndex","rowIndex","r1","minRow","maxRow","minColumn","maxColumn","_i7","denseMatrix","sparseMatrix","inverse","cf","cdata","xa","xb","wa","wb","wai","wbi","vc","scatter","_scatter","va","vb","csize","_iterate","level","av","bv","cv","input","nonDecimalWithRadixMatch","nonDecimalNumberParts","fractionalPart","parts","makeNumberFromNonDecimalParts","valuelessUnit","UNIT_NONE","prefix","PREFIXES","NONE","power","BASE_DIMENSIONS","skipAutomaticSimplification","skipWhitespace","revert","oldIndex","tentativeNumber","tentativeIndex","parseUnit","unitName","isValidAlpha","firstC","parseCharacter","toFind","powerMultiplierCurrent","expectingUnit","valueStr","powerMultiplierStack","powerMultiplierStackProduct","uStr","oldC","_findUnit","baseDim","UNIT_SYSTEMS","auto","allowNoUnits","_getNumberConverter","unitValue","unitPrefixValue","unitPower","_denormalize","prefixValue","memoize","UNITS","prefixes","endsWith","prefixLen","prefixName","_prefix","hasher","getNumericIfUnitless","inverted","valThis","valOther","nominalOffset","unitOffset","thisUnitValue","thisNominalOffset","thisUnitOffset","otherUnitValue","otherNominalOffset","otherUnitOffset","toNumeric","matchingBase","matchingUnit","proposedUnitList","currentUnitSystem","missingBaseDim","toSI","si","strNum","strDen","nNum","nDen","simp","isImaginary","VAR","VA","_bestPrefix","unitStr","absValue","absUnitValue","bestPrefix","bestDiff","scientific","xNumeric","xRounded","testSum","SHORT","da","G","LONG","deca","hecto","kilo","mega","giga","tera","peta","exa","zetta","yotta","deci","centi","milli","micro","nano","pico","femto","atto","zepto","yocto","SQUARED","CUBIC","BINARY_SHORT_SI","BINARY_SHORT_IEC","Ki","Mi","Gi","Ti","Pi","Zi","Yi","BINARY_LONG_SI","BINARY_LONG_IEC","kibi","mebi","gibi","tebi","pebi","exi","zebi","yobi","BTU","MM","SHORTLONG","BINARY_SHORT","BINARY_LONG","MASS","LENGTH","TIME","CURRENT","TEMPERATURE","LUMINOUS_INTENSITY","AMOUNT_OF_SUBSTANCE","FORCE","SURFACE","VOLUME","ENERGY","POWER","PRESSURE","ELECTRIC_CHARGE","ELECTRIC_CAPACITANCE","ELECTRIC_POTENTIAL","ELECTRIC_RESISTANCE","ELECTRIC_INDUCTANCE","ELECTRIC_CONDUCTANCE","MAGNETIC_FLUX","MAGNETIC_FLUX_DENSITY","FREQUENCY","BIT","meter","inch","foot","yard","mile","link","rod","angstrom","ft","mi","li","ch","mil","sqin","sqft","sqyd","sqmi","sqrd","sqch","sqmil","acre","hectare","m3","litre","cuin","cuft","cuyd","teaspoon","tablespoon","drop","gtt","minim","fluiddram","fluidounce","gill","cc","cup","pint","quart","gallon","beerbarrel","oilbarrel","hogshead","fldr","floz","gi","pt","qt","gal","bbl","obl","gram","ton","tonne","grain","dram","ounce","poundmass","hundredweight","stick","stone","gr","dr","oz","lbm","cwt","minute","hour","day","week","month","year","decade","century","millennium","hertz","reciprocal","Hz","rad","radian","deg","grad","gradian","cycle","arcsec","arcmin","ampere","K","degC","degF","degR","kelvin","celsius","fahrenheit","rankine","mol","mole","cd","candela","newton","dyn","dyne","lbf","poundforce","kip","kilogramforce","joule","erg","Wh","eV","electronvolt","watt","hp","Pa","atm","bar","torr","mmHg","mmH2O","cmH2O","farad","volt","V","ohm","henry","H","siemens","weber","Wb","tesla","bits","bytes","ALIASES","meters","inches","feet","yards","miles","links","rods","chains","angstroms","litres","liter","liters","teaspoons","tablespoons","minims","fluiddrams","fluidounces","gills","cups","pints","quarts","gallons","beerbarrels","oilbarrels","hogsheads","gtts","grams","tons","tonnes","grains","drams","ounces","poundmasses","hundredweights","sticks","lb","lbs","kips","kgf","acres","hectares","sqfeet","sqyard","sqmile","sqmiles","mmhg","mmh2o","cmh2o","seconds","secs","minutes","hours","hr","hrs","days","weeks","months","years","decades","centuries","millennia","radians","degrees","gradians","cycles","arcsecond","arcseconds","arcminute","arcminutes","BTUs","watts","joules","amperes","coulombs","volts","ohms","farads","webers","teslas","electronvolts","moles","bit","byte","calculateAngleValues","cgs","us","_key2","setUnitSystem","getUnitSystem","typeConverters","_name2","_unit2","alias","_key3","_key4","deleteUnit","aliases","lastUnit","_key5","createUnitSingle","assertUnitNameIsValid","definition","baseName","defUnit","toUpperCase","newUnit","anyMatch","_newBaseUnit","newBaseUnit","_i8","aliasName","_alias","_key6","def","createJosephson","unitFactory","numberFactory","regexp","itemType","initial","separator","flatArray","newLength","tmpArray2","tmpArray","sizeIndex","_unsqueeze","dimNext","oldLen","newLen","processedSizes","wildCardIndex","prevPrec","bitwise","xBits","yBits","minBits","maxBits","minSign","xSign","ySign","decCoefficientToBinaryString","shortLen","longLen","expFuncVal","outVal","twoPower","two","negOne","toEngineering","formatBigNumberToBase","lowerExp","upperExp","rounded","big2","BigNumberCtor","suffix","newExp","valueWithoutExp","_reduce","update","getSafeProperties","isPlainObject","hasSafeProperty","safeNativeProperties","safeNativeMethods","toLocaleString","_tinyEmitter","assertDependencies","sortFactories","assertAndCreate","deps","pickShallow","isOptionalDependency","factoriesByName","containsDependency","addFactory","missingDependencies","Map","lru","_lruQueue","lruQueue","hash","hit","newVal","memoizeCompare","isEqual","cached","latexSymbols","latexUnits","_escapeLatex","Alpha","Beta","beta","Gamma","Delta","delta","Epsilon","varepsilon","Zeta","zeta","Eta","eta","Theta","vartheta","Iota","iota","Kappa","kappa","varkappa","Lambda","lambda","Mu","mu","Nu","nu","Xi","Omicron","omicron","varpi","Rho","varrho","Sigma","sigma","varsigma","Tau","Upsilon","upsilon","Phi","varphi","Chi","chi","Psi","Omega","omega","Inf","infinity","oo","lim","queue","id","nuIndex","ObjectWrappingMap","objects","_objects","_Object$keys","mapOrObject","wrappedObject","_classCallCheck2","_createClass2","noIndex","noSubset","DBL_EPSILON","formatNumberToBase","roundDigits","splitNumber","missingZeros","expDiff","decimalIdx","decimalVal","splitValue","pp","EPSILON","canDefineProperty","nestedObject","flattenedObject","_deepFlatten","valueResolver","_uninitialized","isPath","half","parentScope","escaped","_formatter","looksLikeFraction","formatArray","REVISION","AddEquation","UVMapping","CubeReflectionMapping","CubeRefractionMapping","EquirectangularReflectionMapping","EquirectangularRefractionMapping","CubeUVReflectionMapping","RepeatWrapping","ClampToEdgeWrapping","MirroredRepeatWrapping","NearestFilter","NearestMipmapNearestFilter","NearestMipmapLinearFilter","LinearFilter","LinearMipmapNearestFilter","LinearMipmapLinearFilter","UnsignedByteType","UnsignedShortType","UnsignedIntType","FloatType","HalfFloatType","UnsignedInt248Type","RGBAFormat","DepthFormat","DepthStencilFormat","RGB_S3TC_DXT1_Format","RGBA_S3TC_DXT1_Format","RGBA_S3TC_DXT3_Format","RGBA_S3TC_DXT5_Format","RGB_PVRTC_4BPPV1_Format","RGB_PVRTC_2BPPV1_Format","RGBA_PVRTC_4BPPV1_Format","RGBA_PVRTC_2BPPV1_Format","RGB_ETC2_Format","RGBA_ETC2_EAC_Format","RGBA_ASTC_4x4_Format","RGBA_ASTC_5x4_Format","RGBA_ASTC_5x5_Format","RGBA_ASTC_6x5_Format","RGBA_ASTC_6x6_Format","RGBA_ASTC_8x5_Format","RGBA_ASTC_8x6_Format","RGBA_ASTC_8x8_Format","RGBA_ASTC_10x5_Format","RGBA_ASTC_10x6_Format","RGBA_ASTC_10x8_Format","RGBA_ASTC_10x10_Format","RGBA_ASTC_12x10_Format","RGBA_ASTC_12x12_Format","RGBA_BPTC_Format","InterpolateDiscrete","InterpolateLinear","InterpolateSmooth","ZeroCurvatureEnding","ZeroSlopeEnding","WrapAroundEnding","AdditiveAnimationBlendMode","LinearEncoding","sRGBEncoding","SRGBColorSpace","LinearSRGBColorSpace","KeepStencilOp","StaticDrawUsage","GLSL3","_SRGBAFormat","EventDispatcher","addEventListener","_listeners","listeners","hasEventListener","removeEventListener","listenerArray","dispatchEvent","event","_lut","_seed","DEG2RAD","RAD2DEG","generateUUID","d3","euclideanModulo","lerp","isPowerOfTwo","ceilPowerOfTwo","floorPowerOfTwo","MathUtils","mapLinear","inverseLerp","damp","pingpong","smoothstep","smootherstep","randInt","randFloat","randFloatSpread","seededRandom","imul","degToRad","radToDeg","setQuaternionFromProperEuler","c13","s13","c1_3","s1_3","c3_1","s3_1","Uint16Array","Int16Array","Int8Array","denormalize","Vector2","isVector2","setScalar","scalar","setX","setY","setComponent","getComponent","addVectors","addScaledVector","subVectors","subScalar","applyMatrix3","elements","clampScalar","minVal","maxVal","clampLength","roundToZero","lengthSq","manhattanLength","distanceTo","distanceToSquared","dx","dy","manhattanDistanceTo","setLength","lerpVectors","v1","v2","fromArray","fromBufferAttribute","attribute","getX","getY","rotateAround","center","Matrix3","isMatrix3","n11","n12","n13","n21","n22","n23","n31","n32","n33","te","extractBasis","xAxis","yAxis","zAxis","setFromMatrix3Column","setFromMatrix4","multiplyMatrices","premultiply","ae","be","a11","a12","a13","a21","a22","a23","a31","a32","a33","b11","b12","b13","b21","b22","b23","b31","b32","b33","determinant","invert","t11","t12","t13","detInv","getNormalMatrix","matrix4","transposeIntoArray","setUvTransform","ty","sx","sy","rotation","cx","cy","scale","translate","arrayNeedsUint32","TYPED_ARRAYS","Uint8ClampedArray","Int32Array","Float64Array","getTypedArray","buffer","createElementNS","SRGBToLinear","LinearToSRGB","FN","ColorManagement","legacyMode","workingColorSpace","colorSpace","color","sourceColorSpace","targetColorSpace","fromWorkingColorSpace","toWorkingColorSpace","_colorKeywords","_rgb","_hslA","_hslB","hue2rgb","toComponents","Color","isColor","setRGB","setHex","setStyle","setHSL","style","handleAlpha","components","setColorName","copySRGBToLinear","copyLinearToSRGB","convertSRGBToLinear","convertLinearToSRGB","getHex","getHexString","getHSL","hue","saturation","lightness","getRGB","getStyle","offsetHSL","addColors","color1","color2","lerpColors","lerpHSL","getZ","normalized","_canvas","NAMES","ImageUtils","static","image","HTMLCanvasElement","canvas","ImageData","putImageData","drawImage","toDataURL","HTMLImageElement","ImageBitmap","imageData","getImageData","Source","isSource","uuid","needsUpdate","isRootObject","images","isDataTexture","serializeImage","getDataURL","textureId","Texture","DEFAULT_IMAGE","mapping","DEFAULT_MAPPING","wrapS","wrapT","magFilter","minFilter","anisotropy","encoding","isTexture","mipmaps","internalFormat","matrixAutoUpdate","generateMipmaps","premultiplyAlpha","flipY","unpackAlignment","userData","onUpdate","isRenderTargetTexture","needsPMREMUpdate","updateMatrix","textures","metadata","dispose","transformUv","uv","Vector4","isVector4","setZ","setW","applyMatrix4","setAxisAngleFromQuaternion","setAxisAngleFromRotationMatrix","epsilon2","m11","m12","m13","m21","m22","m23","m31","m32","m33","yy","zz","xy","xz","getW","WebGLRenderTarget","isWebGLRenderTarget","scissor","scissorTest","texture","depthBuffer","stencilBuffer","depthTexture","samples","DataArrayTexture","isDataArrayTexture","wrapR","Data3DTexture","isData3DTexture","Quaternion","isQuaternion","_y","_z","_w","qa","qb","qm","slerpQuaternions","dst","dstOffset","src0","srcOffset0","src1","srcOffset1","w0","w1","dir","sqrSin","tDir","_onChangeCallback","quaternion","setFromEuler","euler","isEuler","_order","s3","setFromAxisAngle","axis","halfAngle","setFromRotationMatrix","setFromUnitVectors","vFrom","vTo","angleTo","rotateTowards","slerp","multiplyQuaternions","qax","qay","qaz","qaw","qbx","qby","qbz","qbw","cosHalfTheta","sqrSinHalfTheta","sinHalfTheta","halfTheta","ratioA","ratioB","sqrt1u1","sqrtu1","u2","u3","_onChange","Vector3","isVector3","multiplyVectors","applyEuler","applyQuaternion","_quaternion$4","applyAxisAngle","applyNormalMatrix","qx","qy","qz","qw","ix","iy","iz","iw","project","camera","matrixWorldInverse","projectionMatrix","unproject","projectionMatrixInverse","matrixWorld","transformDirection","crossVectors","ax","ay","az","bx","by","bz","projectOnVector","projectOnPlane","planeNormal","_vector$c","reflect","normal","dz","setFromSpherical","setFromSphericalCoords","radius","sinPhiRadius","setFromCylindrical","setFromCylindricalCoords","setFromMatrixPosition","setFromMatrixScale","setFromMatrixColumn","randomDirection","Box3","isBox3","setFromArray","minX","minY","minZ","maxX","maxY","maxZ","setFromBufferAttribute","setFromPoints","points","makeEmpty","il","expandByPoint","setFromCenterAndSize","halfSize","_vector$b","setFromObject","precise","expandByObject","box","getCenter","getSize","point","expandByVector","expandByScalar","updateWorldMatrix","geometry","attributes","position","boundingBox","computeBoundingBox","_box$3","union","containsPoint","containsBox","intersectsBox","intersectsSphere","sphere","clampPoint","intersectsPlane","intersectsTriangle","triangle","_center","_extents","_v0$2","_v1$7","_v2$3","_f0","_f1","_f2","axes","satForAxes","_triangleNormal","distanceToPoint","getBoundingSphere","_points","_testAxis","v0","extents","_box$2","_v1$6","_toFarthestPoint","_toPoint","Sphere","optionalCenter","maxRadiusSq","radiusSum","deltaLengthSq","getBoundingBox","getMaxScaleOnAxis","missingRadiusHalf","_vector$a","_segCenter","_segDir","_edge1","_edge2","_normal$1","Ray","origin","direction","ray","lookAt","recast","closestPointToPoint","directionDistance","distanceSqToPoint","distanceSqToSegment","optionalPointOnRay","optionalPointOnSegment","segExtent","b0","sqrDist","extDet","invDet","intersectSphere","tca","radius2","thc","distanceToPlane","intersectPlane","distToPoint","intersectBox","tmin","tmax","tymin","tymax","tzmin","tzmax","invdirx","invdiry","invdirz","intersectTriangle","backfaceCulling","DdN","DdQxE2","DdE1xQ","QdN","Matrix4","isMatrix4","n14","n24","n34","n41","n42","n43","n44","copyPosition","setFromMatrix3","makeBasis","extractRotation","scaleX","_v1$5","scaleY","scaleZ","makeRotationFromEuler","bf","ce","de","df","ac","ad","bc","bd","makeRotationFromQuaternion","compose","_zero","_one","eye","up","a14","a24","a34","a41","a42","a43","a44","b14","b24","b34","b41","b42","b43","b44","setPosition","t14","scaleXSq","scaleYSq","scaleZSq","makeTranslation","makeRotationX","makeRotationY","makeRotationZ","makeRotationAxis","makeScale","makeShear","yx","zx","zy","wx","wy","wz","decompose","_m1$2","invSX","invSY","invSZ","makePerspective","near","far","makeOrthographic","_matrix$1","_quaternion$3","Euler","DefaultOrder","setFromQuaternion","setFromVector3","reorder","newOrder","toVector3","RotationOrders","Layers","channel","enable","enableAll","toggle","disable","disableAll","layers","isEnabled","_object3DId","_v1$4","_q1","_m1$1","_target","_position$3","_scale$2","_quaternion$2","_xAxis","_yAxis","_zAxis","_addedEvent","_removedEvent","Object3D","isObject3D","DefaultUp","modelViewMatrix","normalMatrix","DefaultMatrixAutoUpdate","matrixWorldNeedsUpdate","castShadow","receiveShadow","frustumCulled","renderOrder","animations","onBeforeRender","onAfterRender","setRotationFromAxisAngle","setRotationFromEuler","setRotationFromMatrix","setRotationFromQuaternion","rotateOnAxis","rotateOnWorldAxis","rotateX","rotateY","rotateZ","translateOnAxis","translateX","translateY","translateZ","localToWorld","worldToLocal","isCamera","isLight","removeFromParent","attach","getObjectById","getObjectByProperty","getObjectByName","getWorldPosition","getWorldQuaternion","getWorldScale","getWorldDirection","raycast","traverseVisible","traverseAncestors","updateMatrixWorld","force","updateParents","updateChildren","geometries","materials","shapes","skeletons","serialize","library","isInstancedMesh","instanceMatrix","instanceColor","isScene","background","environment","isMesh","isLine","isPoints","parameters","shape","isSkinnedMesh","bindMode","bindMatrix","skeleton","uuids","animation","extractFromCache","recursive","_v0$1","_v1$3","_v2$2","_v3$1","_vab","_vac","_vbc","_vap","_vbp","_vcp","Triangle","targetLengthSq","dot00","dot01","dot02","dot11","dot12","invDenom","getBarycoord","uv1","uv2","uv3","setFromPointsAndIndices","i0","setFromAttributeAndIndices","getArea","getMidpoint","getNormal","getPlane","setFromCoplanarPoints","getUV","isFrontFacing","d4","d6","materialId","Material","isMaterial","blending","side","vertexColors","opacity","transparent","blendSrc","blendDst","blendEquation","blendSrcAlpha","blendDstAlpha","blendEquationAlpha","depthFunc","depthTest","depthWrite","stencilWriteMask","stencilFunc","stencilRef","stencilFuncMask","stencilFail","stencilZFail","stencilZPass","stencilWrite","clippingPlanes","clipIntersection","clipShadows","shadowSide","colorWrite","polygonOffset","polygonOffsetFactor","polygonOffsetUnits","dithering","alphaToCoverage","premultipliedAlpha","toneMapped","_alphaTest","alphaTest","onBuild","onBeforeCompile","customProgramCacheKey","setValues","newValue","flatShading","currentValue","roughness","metalness","sheen","sheenColor","sheenRoughness","emissive","emissiveIntensity","specular","specularIntensity","specularColor","shininess","clearcoat","clearcoatRoughness","clearcoatMap","clearcoatRoughnessMap","clearcoatNormalMap","clearcoatNormalScale","iridescence","iridescenceIOR","iridescenceThicknessRange","iridescenceMap","iridescenceThicknessMap","matcap","alphaMap","lightMap","lightMapIntensity","aoMap","aoMapIntensity","bumpMap","bumpScale","normalMap","normalMapType","normalScale","displacementMap","displacementScale","displacementBias","roughnessMap","metalnessMap","emissiveMap","specularMap","specularIntensityMap","specularColorMap","envMap","combine","envMapIntensity","reflectivity","refractionRatio","gradientMap","transmission","transmissionMap","thickness","thicknessMap","attenuationDistance","attenuationColor","sizeAttenuation","linewidth","dashSize","gapSize","wireframe","wireframeLinewidth","wireframeLinecap","wireframeLinejoin","fog","srcPlanes","dstPlanes","vertexTangents","fromType","MeshBasicMaterial","isMeshBasicMaterial","_vector$9","_vector2$1","BufferAttribute","itemSize","isBufferAttribute","usage","updateRange","onUploadCallback","setUsage","copyAt","index1","index2","copyArray","copyColorsArray","colors","copyVector2sArray","copyVector3sArray","copyVector4sArray","setXY","setXYZ","setXYZW","onUpload","Uint16BufferAttribute","Uint32BufferAttribute","Float32BufferAttribute","_id$1","_m1","_obj","_offset","_box$1","_boxMorphTargets","_vector$8","BufferGeometry","isBufferGeometry","morphAttributes","morphTargetsRelative","groups","boundingSphere","drawRange","getIndex","setIndex","getAttribute","setAttribute","deleteAttribute","hasAttribute","addGroup","materialIndex","clearGroups","setDrawRange","computeBoundingSphere","morphAttributesPosition","isGLBufferAttribute","morphAttribute","jl","computeTangents","indices","positions","normals","uvs","nVertices","tangents","tan1","tan2","vA","vB","vC","uvA","uvB","uvC","sdir","tdir","handleTriangle","group","handleVertex","computeVertexNormals","positionAttribute","normalAttribute","pA","pB","pC","nA","nB","nC","cb","ab","normalizeNormals","merge","attributeArray1","attribute2","attributeArray2","attributeOffset","toNonIndexed","convertBufferAttribute","isInterleavedBufferAttribute","stride","geometry2","newAttribute","morphArray","hasMorphAttributes","attributeArray","_inverseMatrix$2","_ray$2","_sphere$3","_vA$1","_vB$1","_vC$1","_tempA","_tempB","_tempC","_morphA","_morphB","_morphC","_uvA$1","_uvB$1","_uvC$1","_intersectionPoint","_intersectionPointWorld","Mesh","updateMorphTargets","morphTargetInfluences","morphTargetDictionary","ml","raycaster","intersects","intersection","morphPosition","groupMaterial","checkBufferGeometryIntersection","faceIndex","face","morphInfluences","influence","boneTransform","checkIntersection","BoxGeometry","widthSegments","heightSegments","depthSegments","vertices","numberOfVertices","groupStart","buildPlane","udir","vdir","gridX","gridY","segmentWidth","segmentHeight","widthHalf","heightHalf","depthHalf","gridX1","gridY1","vertexCounter","groupCount","cloneUniforms","mergeUniforms","UniformsUtils","isShaderMaterial","defines","lights","clipping","extensions","derivatives","fragDepth","drawBuffers","shaderTextureLOD","defaultAttributeValues","index0AttributeName","uniformsNeedUpdate","glslVersion","Camera","PerspectiveCamera","fov","aspect","isPerspectiveCamera","zoom","focus","view","filmGauge","filmOffset","updateProjectionMatrix","setFocalLength","focalLength","vExtentSlope","getFilmHeight","getFocalLength","getEffectiveFOV","getFilmWidth","setViewOffset","fullWidth","fullHeight","enabled","offsetX","offsetY","clearViewOffset","skew","CubeCamera","renderTarget","isWebGLCubeRenderTarget","cameraPX","cameraNX","cameraPY","cameraNY","cameraPZ","cameraNZ","currentRenderTarget","getRenderTarget","currentToneMapping","toneMapping","currentXrEnabled","xr","setRenderTarget","render","CubeTexture","isCubeTexture","WebGLCubeRenderTarget","fromEquirectangularTexture","shader","tEquirect","currentMinFilter","_vector1","_vector2","_normalMatrix","Plane","isPlane","setComponents","setFromNormalAndCoplanarPoint","inverseNormalLength","distanceToSphere","projectPoint","intersectLine","line","intersectsLine","startSign","endSign","coplanarPoint","optionalNormalMatrix","referencePoint","_sphere$2","_vector$7","Frustum","p5","planes","frustum","setFromProjectionMatrix","me0","me1","me2","me3","me4","me5","me6","me7","me8","me9","me10","me11","me12","me13","me14","me15","intersectsObject","intersectsSprite","sprite","negRadius","WebGLAnimation","isAnimating","animationLoop","requestId","onAnimationFrame","time","frame","requestAnimationFrame","cancelAnimationFrame","setAnimationLoop","setContext","WebGLAttributes","gl","capabilities","isWebGL2","buffers","bufferType","bytesPerElement","elementSize","FLOAT","isFloat16BufferAttribute","HALF_FLOAT","UNSIGNED_SHORT","UNSIGNED_INT","INT","BYTE","UNSIGNED_BYTE","BYTES_PER_ELEMENT","bufferSubData","subarray","updateBuffer","PlaneGeometry","width_half","height_half","segment_width","segment_height","ShaderChunk","alphamap_fragment","alphamap_pars_fragment","alphatest_fragment","alphatest_pars_fragment","aomap_fragment","aomap_pars_fragment","begin_vertex","beginnormal_vertex","bsdfs","iridescence_fragment","bumpmap_pars_fragment","clipping_planes_fragment","clipping_planes_pars_fragment","clipping_planes_pars_vertex","clipping_planes_vertex","color_fragment","color_pars_fragment","color_pars_vertex","color_vertex","common","cube_uv_reflection_fragment","defaultnormal_vertex","displacementmap_pars_vertex","displacementmap_vertex","emissivemap_fragment","emissivemap_pars_fragment","encodings_fragment","encodings_pars_fragment","envmap_fragment","envmap_common_pars_fragment","envmap_pars_fragment","envmap_pars_vertex","envmap_physical_pars_fragment","envmap_vertex","fog_vertex","fog_pars_vertex","fog_fragment","fog_pars_fragment","gradientmap_pars_fragment","lightmap_fragment","lightmap_pars_fragment","lights_lambert_vertex","lights_pars_begin","lights_toon_fragment","lights_toon_pars_fragment","lights_phong_fragment","lights_phong_pars_fragment","lights_physical_fragment","lights_physical_pars_fragment","lights_fragment_begin","lights_fragment_maps","lights_fragment_end","logdepthbuf_fragment","logdepthbuf_pars_fragment","logdepthbuf_pars_vertex","logdepthbuf_vertex","map_fragment","map_pars_fragment","map_particle_fragment","map_particle_pars_fragment","metalnessmap_fragment","metalnessmap_pars_fragment","morphcolor_vertex","morphnormal_vertex","morphtarget_pars_vertex","morphtarget_vertex","normal_fragment_begin","normal_fragment_maps","normal_pars_fragment","normal_pars_vertex","normal_vertex","normalmap_pars_fragment","clearcoat_normal_fragment_begin","clearcoat_normal_fragment_maps","clearcoat_pars_fragment","iridescence_pars_fragment","output_fragment","packing","premultiplied_alpha_fragment","project_vertex","dithering_fragment","dithering_pars_fragment","roughnessmap_fragment","roughnessmap_pars_fragment","shadowmap_pars_fragment","shadowmap_pars_vertex","shadowmap_vertex","shadowmask_pars_fragment","skinbase_vertex","skinning_pars_vertex","skinning_vertex","skinnormal_vertex","specularmap_fragment","specularmap_pars_fragment","tonemapping_fragment","tonemapping_pars_fragment","transmission_fragment","transmission_pars_fragment","uv_pars_fragment","uv_pars_vertex","uv_vertex","uv2_pars_fragment","uv2_pars_vertex","uv2_vertex","worldpos_vertex","background_vert","background_frag","cube_vert","cube_frag","depth_vert","depth_frag","distanceRGBA_vert","distanceRGBA_frag","equirect_vert","equirect_frag","linedashed_vert","linedashed_frag","meshbasic_vert","meshbasic_frag","meshlambert_vert","meshlambert_frag","meshmatcap_vert","meshmatcap_frag","meshnormal_vert","meshnormal_frag","meshphong_vert","meshphong_frag","meshphysical_vert","meshphysical_frag","meshtoon_vert","meshtoon_frag","points_vert","points_frag","shadow_vert","shadow_frag","sprite_vert","sprite_frag","UniformsLib","diffuse","uvTransform","uv2Transform","specularmap","envmap","flipEnvMap","ior","aomap","lightmap","emissivemap","bumpmap","normalmap","displacementmap","roughnessmap","metalnessmap","gradientmap","fogDensity","fogNear","fogFar","fogColor","ambientLightColor","lightProbe","directionalLights","directionalLightShadows","shadowBias","shadowNormalBias","shadowRadius","shadowMapSize","directionalShadowMap","directionalShadowMatrix","spotLights","coneCos","penumbraCos","decay","spotLightShadows","spotShadowMap","spotShadowMatrix","pointLights","pointLightShadows","shadowCameraNear","shadowCameraFar","pointShadowMap","pointShadowMatrix","hemisphereLights","skyColor","groundColor","rectAreaLights","ltc_1","ltc_2","ShaderLib","basic","lambert","phong","standard","toon","dashed","totalSize","t2D","equirect","distanceRGBA","referencePosition","nearDistance","farDistance","shadow","WebGLBackground","cubemaps","planeMesh","boxMesh","clearAlpha","currentBackground","currentBackgroundVersion","currentTonemapping","setClear","getClearColor","setClearColor","getClearAlpha","setClearAlpha","renderList","forceClear","session","getSession","environmentBlendMode","autoClear","autoClearColor","autoClearDepth","autoClearStencil","WebGLBindingStates","maxVertexAttributes","MAX_VERTEX_ATTRIBS","extension","vaoAvailable","bindingStates","defaultState","createBindingState","currentState","forceUpdate","bindVertexArrayObject","vao","bindVertexArray","bindVertexArrayOES","deleteVertexArrayObject","deleteVertexArray","deleteVertexArrayOES","newAttributes","enabledAttributes","attributeDivisors","program","initAttributes","enableAttribute","enableAttributeAndDivisor","meshPerAttribute","disableUnusedAttributes","disableVertexAttribArray","vertexAttribIPointer","resetDefaultState","setup","updateBuffers","programMap","stateMap","createVertexArray","createVertexArrayOES","getBindingState","cachedAttributes","geometryAttributes","attributesNum","programAttributes","getAttributes","location","cachedAttribute","geometryAttribute","saveCache","ELEMENT_ARRAY_BUFFER","isInstancedBufferGeometry","materialDefaultAttributeValues","programAttribute","isInstancedInterleavedBuffer","locationSize","_maxInstanceCount","ARRAY_BUFFER","isInstancedBufferAttribute","vertexAttrib2fv","vertexAttrib3fv","vertexAttrib4fv","vertexAttrib1fv","setupVertexAttributes","geometryId","programId","releaseStatesOfGeometry","releaseStatesOfProgram","WebGLBufferRenderer","setMode","renderInstances","primcount","methodName","WebGLCapabilities","maxAnisotropy","getMaxPrecision","getShaderPrecisionFormat","VERTEX_SHADER","HIGH_FLOAT","FRAGMENT_SHADER","MEDIUM_FLOAT","WebGL2RenderingContext","WebGL2ComputeRenderingContext","maxPrecision","logarithmicDepthBuffer","maxTextures","MAX_TEXTURE_IMAGE_UNITS","maxVertexTextures","MAX_VERTEX_TEXTURE_IMAGE_UNITS","maxTextureSize","MAX_TEXTURE_SIZE","maxCubemapSize","MAX_CUBE_MAP_TEXTURE_SIZE","maxAttributes","maxVertexUniforms","MAX_VERTEX_UNIFORM_VECTORS","maxVaryings","MAX_VARYING_VECTORS","maxFragmentUniforms","MAX_FRAGMENT_UNIFORM_VECTORS","vertexTextures","floatFragmentTextures","getMaxAnisotropy","MAX_TEXTURE_MAX_ANISOTROPY_EXT","floatVertexTextures","maxSamples","MAX_SAMPLES","WebGLClipping","globalState","numGlobalPlanes","localClippingEnabled","renderingShadows","viewNormalMatrix","resetGlobalState","numPlanes","numIntersection","projectPlanes","skipTransform","nPlanes","dstArray","flatSize","viewMatrix","i4","enableLocalClipping","beginShadows","endShadows","setState","useCache","materialProperties","nGlobal","lGlobal","clippingState","WebGLCubeMaps","mapTextureMapping","onTextureDispose","cubemap","physical","iridescenceThicknessMinimum","iridescenceThicknessMaximum","sheenColorMap","sheenRoughnessMap","transmissionSamplerSize","transmissionSamplerMap","OrthographicCamera","isOrthographicCamera","scaleW","scaleH","EXTRA_LOD_SIGMA","_flatCamera","_clearColor","_oldTarget","PHI","INV_PHI","_axisDirections","PMREMGenerator","_renderer","_pingPongRenderTarget","_lodMax","_cubeSize","_lodPlanes","_sizeLods","_sigmas","_blurMaterial","_cubemapMaterial","_equirectMaterial","_compileMaterial","fromScene","cubeUVRenderTarget","_allocateTargets","_sceneToCubeUV","_blur","_applyPMREM","_cleanup","fromEquirectangular","equirectangular","_fromTexture","fromCubemap","compileCubemapShader","_getCubemapMaterial","compileEquirectangularShader","_getEquirectMaterial","_dispose","cubeSize","outputTarget","_setViewport","_textureToCubeUV","_createRenderTarget","sizeLods","lodPlanes","sigmas","lodMax","lod","totalLods","sizeLod","texelSize","cubeFaces","positionSize","uvSize","faceIndexSize","coordinates","_createPlanes","poleAxis","_getBlurShader","tmpMesh","cubeCamera","upSign","forwardSign","originalAutoClear","backgroundMaterial","backgroundBox","useSolidColor","lodIn","lodOut","pingPongRenderTarget","_halfBlur","targetIn","targetOut","sigmaRadians","blurMaterial","blurMesh","blurUniforms","pixels","radiansPerPixel","sigmaPixels","weight","outputSize","WebGLCubeUVMaps","cubeUVmaps","pmremGenerator","cubemapUV","isEquirectMap","isCubeMap","isCubeTextureComplete","WebGLExtensions","WebGLGeometries","wireframeAttributes","onGeometryDispose","memory","updateWireframeAttribute","geometryIndex","geometryPosition","previousAttribute","getWireframeAttribute","currentAttribute","WebGLIndexedBufferRenderer","drawElements","WebGLInfo","calls","triangles","lines","programs","autoReset","instanceCount","TRIANGLES","LINES","LINE_STRIP","LINE_LOOP","POINTS","numericalSort","absNumericalSort","morph","WebGLMorphtargets","influencesList","morphTextures","workInfluences","objectInfluences","morphTargetsCount","hasMorphPosition","hasMorphNormals","hasMorphColors","morphTargets","morphNormals","morphColors","vertexDataCount","vertexDataStride","morphTarget","morphNormal","morphColor","disposeTexture","morphInfluencesSum","morphBaseInfluence","getUniforms","setValue","influences","MAX_SAFE_INTEGER","WebGLObjects","updateMap","onInstancedMeshDispose","instancedMesh","buffergeometry","emptyTexture","emptyArrayTexture","empty3dTexture","emptyCubeTexture","arrayCacheF32","arrayCacheI32","mat4array","mat3array","mat2array","nBlocks","blockSize","firstElem","arraysEqual","allocTexUnits","allocateTextureUnit","setValueV1f","uniform1f","addr","setValueV2f","uniform2f","uniform2fv","setValueV3f","uniform3f","uniform3fv","setValueV4f","uniform4f","uniform4fv","setValueM2","uniformMatrix2fv","setValueM3","uniformMatrix3fv","setValueM4","uniformMatrix4fv","setValueV1i","uniform1i","setValueV2i","uniform2iv","setValueV3i","uniform3iv","setValueV4i","uniform4iv","setValueV1ui","uniform1ui","setValueV2ui","uniform2uiv","setValueV3ui","uniform3uiv","setValueV4ui","uniform4uiv","setValueT1","setTexture2D","setValueT3D1","setTexture3D","setValueT6","setTextureCube","setValueT2DArray1","setTexture2DArray","setValueV1fArray","uniform1fv","setValueV2fArray","setValueV3fArray","setValueV4fArray","setValueM2Array","setValueM3Array","setValueM4Array","setValueV1iArray","uniform1iv","setValueV2iArray","setValueV3iArray","setValueV4iArray","setValueV1uiArray","uniform1uiv","setValueV2uiArray","setValueV3uiArray","setValueV4uiArray","setValueT1Array","setValueT3DArray","setValueT6Array","setValueT2DArrayArray","SingleUniform","activeInfo","getSingularSetter","PureArrayUniform","getPureArraySetter","StructuredUniform","seq","RePathPart","addUniform","container","uniformObject","parseUniform","pathLength","matchEnd","idIsIndex","subscript","WebGLUniforms","getProgramParameter","ACTIVE_UNIFORMS","getActiveUniform","getUniformLocation","setOptional","WebGLShader","programIdCount","getShaderErrors","status","getShaderParameter","COMPILE_STATUS","errors","getShaderInfoLog","errorMatches","errorLine","lines2","handleSource","getShaderSource","getTexelEncodingFunction","functionName","getEncodingComponents","getToneMappingFunction","toneMappingName","filterEmptyLine","replaceLightNums","numDirLights","numSpotLights","numRectAreaLights","numPointLights","numHemiLights","numDirLightShadows","numSpotLightShadows","numPointLightShadows","replaceClippingPlaneNums","numClippingPlanes","numClipIntersection","includePattern","resolveIncludes","includeReplacer","include","deprecatedUnrollLoopPattern","unrollLoopPattern","unrollLoops","loopReplacer","deprecatedLoopReplacer","snippet","generatePrecision","precisionstring","WebGLProgram","cacheKey","shadowMapTypeDefine","shadowMapType","generateShadowMapTypeDefine","envMapTypeDefine","envMapMode","generateEnvMapTypeDefine","envMapModeDefine","generateEnvMapModeDefine","envMapBlendingDefine","generateEnvMapBlendingDefine","envMapCubeUVSize","imageHeight","envMapCubeUVHeight","maxMip","texelHeight","texelWidth","generateCubeUVSize","customExtensions","extensionDerivatives","tangentSpaceNormalMap","shaderID","extensionFragDepth","rendererExtensionFragDepth","extensionDrawBuffers","rendererExtensionDrawBuffers","extensionShaderTextureLOD","rendererExtensionShaderTextureLod","generateExtensions","customDefines","chunks","generateDefines","prefixVertex","prefixFragment","versionString","isRawShaderMaterial","shaderName","instancing","instancingColor","supportsVertexTextures","useFog","fogExp2","objectSpaceNormalMap","vertexAlphas","vertexUvs","uvsVertexOnly","skinning","morphTextureStride","doubleSided","flipSided","shadowMapEnabled","decodeVideoTexture","physicallyCorrectLights","opaque","outputEncoding","useDepthPacking","depthPacking","vertexGlsl","fragmentGlsl","glVertexShader","glFragmentShader","bindAttribLocation","checkShaderErrors","programLog","getProgramInfoLog","vertexLog","fragmentLog","runnable","haveDiagnostics","LINK_STATUS","vertexErrors","fragmentErrors","getError","VALIDATE_STATUS","diagnostics","cachedUniforms","ACTIVE_ATTRIBUTES","getActiveAttrib","FLOAT_MAT2","FLOAT_MAT3","FLOAT_MAT4","fetchAttributeLocations","destroy","usedTimes","_id","WebGLShaderCache","shaderCache","materialCache","vertexShaderStage","_getShaderStage","fragmentShaderStage","materialShaders","_getShaderCacheForMaterial","shaderStage","code","getVertexShaderID","getFragmentShaderID","stage","WebGLShaderStage","WebGLPrograms","cubeuvmaps","_programLayers","_customShaders","shaderIDs","MeshDepthMaterial","MeshDistanceMaterial","MeshNormalMaterial","MeshLambertMaterial","MeshPhongMaterial","MeshToonMaterial","MeshStandardMaterial","MeshPhysicalMaterial","MeshMatcapMaterial","LineBasicMaterial","LineDashedMaterial","PointsMaterial","ShadowMaterial","SpriteMaterial","getParameters","shadows","isMeshStandardMaterial","customVertexShaderID","customFragmentShaderID","useAlphaTest","useClearcoat","useIridescence","isXRRenderTarget","isVideoTexture","isFogExp2","directional","spot","rectArea","hemi","shadowMap","getProgramCacheKey","morphAttributeCount","getProgramCacheKeyParameters","getProgramCacheKeyBooleans","acquireProgram","pl","preexistingProgram","releaseProgram","releaseShaderCache","WebGLProperties","painterSortStable","groupOrder","reversePainterSortStable","WebGLRenderList","renderItems","renderItemsIndex","transmissive","getNextRenderItem","renderItem","customOpaqueSort","customTransparentSort","WebGLRenderLists","lists","renderCallDepth","list","UniformsCache","light","halfWidth","halfHeight","nextVersion","shadowCastingLightsFirst","lightA","lightB","WebGLLights","shadowCache","ShadowUniformsCache","directionalLength","pointLength","spotLength","rectAreaLength","hemiLength","numDirectionalShadows","numPointShadows","numSpotShadows","ambient","probe","directionalShadow","spotShadow","rectAreaLTC1","rectAreaLTC2","pointShadow","vector3","matrix42","scaleFactor","intensity","isAmbientLight","isLightProbe","sh","isDirectionalLight","shadowUniforms","bias","normalBias","mapSize","isSpotLight","penumbra","isRectAreaLight","isPointLight","isHemisphereLight","LTC_FLOAT_1","LTC_FLOAT_2","LTC_HALF_1","LTC_HALF_2","setupView","WebGLRenderState","lightsArray","shadowsArray","setupLights","setupLightsView","pushLight","pushShadow","shadowLight","WebGLRenderStates","renderStates","renderState","isMeshDepthMaterial","isMeshDistanceMaterial","WebGLShadowMap","_capabilities","_frustum","_shadowMapSize","_viewportSize","_viewport","_depthMaterial","_distanceMaterial","_materialCache","_maxTextureSize","shadowMaterialVertical","VSM_SAMPLES","shadow_pass","resolution","shadowMaterialHorizontal","HORIZONTAL_PASS","fullScreenTri","fullScreenMesh","VSMPass","blurSamples","mapPass","renderBufferDirect","getDepthMaterial","customMaterial","customDistanceMaterial","customDepthMaterial","keyA","keyB","materialsForVariant","cachedMaterial","renderObject","shadowCamera","kl","depthMaterial","autoUpdate","activeCubeFace","getActiveCubeFace","activeMipmapLevel","getActiveMipmapLevel","_state","setBlending","setTest","setScissorTest","shadowFrameExtents","getFrameExtents","isPointLightShadow","pars","viewportCount","getViewportCount","vp","getViewport","updateMatrices","getFrustum","WebGLState","colorBuffer","locked","currentColorMask","currentColorClear","setMask","colorMask","setLocked","lock","currentDepthMask","currentDepthFunc","currentDepthClear","DEPTH_TEST","depthMask","setFunc","NEVER","ALWAYS","LESS","LEQUAL","EQUAL","GEQUAL","GREATER","NOTEQUAL","clearDepth","currentStencilMask","currentStencilFunc","currentStencilRef","currentStencilFuncMask","currentStencilFail","currentStencilZFail","currentStencilZPass","currentStencilClear","stencilTest","STENCIL_TEST","stencilMask","setOp","stencilOp","clearStencil","enabledCapabilities","currentBoundFramebuffers","currentDrawbuffers","defaultDrawbuffers","currentProgram","currentBlendingEnabled","currentBlending","currentBlendEquation","currentBlendSrc","currentBlendDst","currentBlendEquationAlpha","currentBlendSrcAlpha","currentBlendDstAlpha","currentPremultipledAlpha","currentFlipSided","currentCullFace","currentLineWidth","currentPolygonOffsetFactor","currentPolygonOffsetUnits","MAX_COMBINED_TEXTURE_IMAGE_UNITS","lineWidthAvailable","glVersion","VERSION","currentTextureSlot","currentBoundTextures","scissorParam","SCISSOR_BOX","viewportParam","VIEWPORT","currentScissor","currentViewport","createTexture","bindTexture","texParameteri","TEXTURE_MIN_FILTER","NEAREST","TEXTURE_MAG_FILTER","texImage2D","RGBA","emptyTextures","TEXTURE_2D","TEXTURE_CUBE_MAP","TEXTURE_CUBE_MAP_POSITIVE_X","setFlipSided","setCullFace","CULL_FACE","equationToGL","FUNC_ADD","FUNC_SUBTRACT","FUNC_REVERSE_SUBTRACT","MIN","MAX","MIN_EXT","MAX_EXT","factorToGL","ONE","SRC_COLOR","SRC_ALPHA","SRC_ALPHA_SATURATE","DST_COLOR","DST_ALPHA","ONE_MINUS_SRC_COLOR","ONE_MINUS_SRC_ALPHA","ONE_MINUS_DST_COLOR","ONE_MINUS_DST_ALPHA","BLEND","blendEquationSeparate","blendFuncSeparate","blendFunc","frontFace","CW","CCW","cullFace","BACK","FRONT","FRONT_AND_BACK","setPolygonOffset","POLYGON_OFFSET_FILL","activeTexture","webglSlot","TEXTURE0","bindFramebuffer","framebuffer","DRAW_FRAMEBUFFER","FRAMEBUFFER","isWebGLMultipleRenderTargets","COLOR_ATTACHMENT0","drawBuffersWEBGL","setMaterial","frontFaceCW","SAMPLE_ALPHA_TO_COVERAGE","setLineWidth","lineWidth","SCISSOR_TEST","webglType","webglTexture","boundTexture","unbindTexture","compressedTexImage2D","texImage3D","texStorage2D","texStorage3D","texSubImage2D","texSubImage3D","compressedTexSubImage2D","KEEP","READ_FRAMEBUFFER","WebGLTextures","_gl","utils","multisampledRTTExt","supportsInvalidateFramebuffer","_videoTextures","_sources","useOffscreenCanvas","OffscreenCanvas","createCanvas","resizeImage","needsPowerOfTwo","needsNewCanvas","maxSize","isPowerOfTwo$1","textureNeedsGenerateMipmaps","supportsMips","generateMipmap","getInternalFormat","internalFormatName","glFormat","glType","RED","R32F","R16F","R8","RG","RG32F","RG16F","RG8","RGBA32F","RGBA16F","SRGB8_ALPHA8","RGBA8","UNSIGNED_SHORT_4_4_4_4","RGBA4","UNSIGNED_SHORT_5_5_5_1","RGB5_A1","getMipLevels","isFramebufferTexture","isCompressedTexture","filterFallback","LINEAR","textureProperties","__webglInit","webglTextures","__cacheKey","deleteTexture","deallocateTexture","onRenderTargetDispose","renderTargetProperties","__webglTexture","deleteFramebuffer","__webglFramebuffer","__webglDepthbuffer","deleteRenderbuffer","__webglMultisampledFramebuffer","__webglColorRenderbuffer","__webglDepthRenderbuffer","attachmentProperties","deallocateRenderTarget","textureUnits","slot","updateVideoTexture","__version","uploadTexture","wrappingToGL","REPEAT","CLAMP_TO_EDGE","MIRRORED_REPEAT","filterToGL","NEAREST_MIPMAP_NEAREST","NEAREST_MIPMAP_LINEAR","LINEAR_MIPMAP_NEAREST","LINEAR_MIPMAP_LINEAR","setTextureParameters","textureType","TEXTURE_WRAP_S","TEXTURE_WRAP_T","TEXTURE_3D","TEXTURE_2D_ARRAY","TEXTURE_WRAP_R","__currentAnisotropy","texParameterf","TEXTURE_MAX_ANISOTROPY_EXT","initTexture","forceUpload","textureCacheKey","getTextureCacheKey","__currentVersion","pixelStorei","UNPACK_FLIP_Y_WEBGL","UNPACK_PREMULTIPLY_ALPHA_WEBGL","UNPACK_ALIGNMENT","UNPACK_COLORSPACE_CONVERSION_WEBGL","textureNeedsPowerOfTwo","verifyColorSpace","mipmap","glInternalFormat","useTexStorage","allocateMemory","levels","isDepthTexture","DEPTH_COMPONENT","DEPTH_COMPONENT32F","DEPTH_COMPONENT24","DEPTH24_STENCIL8","DEPTH_COMPONENT16","DEPTH_STENCIL","setupFrameBufferTexture","attachment","textureTarget","__hasExternalTextures","useMultisampledRTT","framebufferTexture2DMultisampleEXT","getRenderTargetSamples","framebufferTexture2D","setupRenderBufferStorage","renderbuffer","isMultisample","bindRenderbuffer","RENDERBUFFER","renderbufferStorageMultisampleEXT","renderbufferStorageMultisample","renderbufferStorage","framebufferRenderbuffer","DEPTH_ATTACHMENT","DEPTH_STENCIL_ATTACHMENT","setupDepthRenderbuffer","isCube","__autoAllocateDepthBuffer","webglDepthTexture","setupDepthTexture","createRenderbuffer","__useRenderToTexture","sRGBToLinear","textureUnit","resetTextureUnits","isCompressed","cubeImage","mipmapImage","uploadCubeTexture","rebindTextures","colorTexture","setupRenderTarget","isMultipleRenderTargets","createFramebuffer","glTextureType","isWebGL3DRenderTarget","isWebGLArrayRenderTarget","updateRenderTargetMipmap","updateMultisampleRenderTarget","COLOR_BUFFER_BIT","invalidationArray","depthStyle","ignoreDepthValues","__ignoreDepthValues","DEPTH_BUFFER_BIT","STENCIL_BUFFER_BIT","invalidateFramebuffer","blitFramebuffer","WebGLUtils","HALF_FLOAT_OES","ALPHA","LUMINANCE","LUMINANCE_ALPHA","SRGB_ALPHA_EXT","RED_INTEGER","RG_INTEGER","RGBA_INTEGER","COMPRESSED_SRGB_S3TC_DXT1_EXT","COMPRESSED_SRGB_ALPHA_S3TC_DXT1_EXT","COMPRESSED_SRGB_ALPHA_S3TC_DXT3_EXT","COMPRESSED_SRGB_ALPHA_S3TC_DXT5_EXT","COMPRESSED_RGB_S3TC_DXT1_EXT","COMPRESSED_RGBA_S3TC_DXT1_EXT","COMPRESSED_RGBA_S3TC_DXT3_EXT","COMPRESSED_RGBA_S3TC_DXT5_EXT","COMPRESSED_RGB_PVRTC_4BPPV1_IMG","COMPRESSED_RGB_PVRTC_2BPPV1_IMG","COMPRESSED_RGBA_PVRTC_4BPPV1_IMG","COMPRESSED_RGBA_PVRTC_2BPPV1_IMG","COMPRESSED_RGB_ETC1_WEBGL","COMPRESSED_SRGB8_ETC2","COMPRESSED_RGB8_ETC2","COMPRESSED_SRGB8_ALPHA8_ETC2_EAC","COMPRESSED_RGBA8_ETC2_EAC","COMPRESSED_SRGB8_ALPHA8_ASTC_4x4_KHR","COMPRESSED_RGBA_ASTC_4x4_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_5x4_KHR","COMPRESSED_RGBA_ASTC_5x4_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_5x5_KHR","COMPRESSED_RGBA_ASTC_5x5_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_6x5_KHR","COMPRESSED_RGBA_ASTC_6x5_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_6x6_KHR","COMPRESSED_RGBA_ASTC_6x6_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_8x5_KHR","COMPRESSED_RGBA_ASTC_8x5_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_8x6_KHR","COMPRESSED_RGBA_ASTC_8x6_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_8x8_KHR","COMPRESSED_RGBA_ASTC_8x8_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_10x5_KHR","COMPRESSED_RGBA_ASTC_10x5_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_10x6_KHR","COMPRESSED_RGBA_ASTC_10x6_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_10x8_KHR","COMPRESSED_RGBA_ASTC_10x8_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_10x10_KHR","COMPRESSED_RGBA_ASTC_10x10_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_12x10_KHR","COMPRESSED_RGBA_ASTC_12x10_KHR","COMPRESSED_SRGB8_ALPHA8_ASTC_12x12_KHR","COMPRESSED_RGBA_ASTC_12x12_KHR","COMPRESSED_SRGB_ALPHA_BPTC_UNORM_EXT","COMPRESSED_RGBA_BPTC_UNORM_EXT","UNSIGNED_INT_24_8","UNSIGNED_INT_24_8_WEBGL","ArrayCamera","isArrayCamera","cameras","Group","isGroup","_moveEvent","WebXRController","_targetRay","_grip","_hand","getHandSpace","joints","inputState","pinching","getTargetRaySpace","hasLinearVelocity","linearVelocity","hasAngularVelocity","angularVelocity","getGripSpace","disconnect","inputSource","referenceSpace","inputPose","gripPose","handPose","targetRay","grip","hand","visibilityState","getPose","targetRaySpace","inputjoint","jointPose","getJointPose","jointName","joint","jointRadius","indexTip","thumbTip","distanceToPinch","handedness","gripSpace","DepthTexture","WebXRManager","framebufferScaleFactor","referenceSpaceType","customReferenceSpace","pose","glBinding","glProjLayer","glBaseLayer","xrFrame","getContextAttributes","initialRenderTarget","newRenderTarget","controllers","inputSourcesMap","cameraL","cameraR","cameraVR","_currentDepthNear","_currentDepthFar","onSessionEvent","controller","onSessionEnd","onInputSourcesChange","isPresenting","inputSources","removed","added","cameraAutoUpdate","getController","getControllerGrip","getHand","setFramebufferScaleFactor","setReferenceSpaceType","getReferenceSpace","setReferenceSpace","space","getBaseLayer","getBinding","getFrame","setSession","xrCompatible","makeXRCompatible","layerInit","XRWebGLLayer","updateRenderState","baseLayer","framebufferWidth","framebufferHeight","depthFormat","depthType","glDepthFormat","projectionlayerInit","colorFormat","XRWebGLBinding","createProjectionLayer","textureWidth","textureHeight","setFoveation","requestReferenceSpace","cameraLPos","cameraRPos","updateCamera","depthNear","depthFar","ipd","projL","projR","topFov","bottomFov","leftFov","rightFov","zOffset","xOffset","near2","far2","left2","right2","top2","bottom2","setProjectionFromUnion","getCamera","getFoveation","fixedFoveation","foveation","onAnimationFrameCallback","getViewerPose","views","setRenderTargetFramebuffer","cameraVRNeedsUpdate","glSubImage","getViewSubImage","setRenderTargetTextures","depthStencilTexture","WebGLMaterials","refreshUniformsCommon","uvScaleMap","uv2ScaleMap","refreshFogUniforms","isFog","refreshMaterialUniforms","pixelRatio","transmissionRenderTarget","isMeshLambertMaterial","isMeshToonMaterial","refreshUniformsToon","isMeshPhongMaterial","refreshUniformsPhong","refreshUniformsStandard","isMeshPhysicalMaterial","refreshUniformsPhysical","isMeshMatcapMaterial","refreshUniformsMatcap","refreshUniformsDistance","isMeshNormalMaterial","isLineBasicMaterial","refreshUniformsLine","isLineDashedMaterial","refreshUniformsDash","isPointsMaterial","refreshUniformsPoints","isSpriteMaterial","refreshUniformsSprites","isShadowMaterial","WebGLRenderer","isWebGLRenderer","display","createCanvasElement","_depth","_stencil","_antialias","_premultipliedAlpha","_preserveDrawingBuffer","preserveDrawingBuffer","_powerPreference","_failIfMajorPerformanceCaveat","_alpha","currentRenderList","currentRenderState","renderListStack","renderStateStack","domElement","sortObjects","toneMappingExposure","gammaFactor","_isContextLost","_currentActiveCubeFace","_currentActiveMipmapLevel","_currentRenderTarget","_currentMaterialId","_currentCamera","_currentViewport","_currentScissor","_currentScissorTest","_width","_height","_pixelRatio","_opaqueSort","_transparentSort","_scissor","_scissorTest","_clippingEnabled","_localClippingEnabled","_transmissionRenderTarget","_projScreenMatrix","_vector3","_emptyScene","overrideMaterial","getTargetPixelRatio","programCache","renderLists","morphtargets","bufferRenderer","indexedBufferRenderer","contextNames","contextAttributes","contextName","onContextLost","onContextRestore","onContextCreationError","isWebGL1Renderer","initGLContext","preventDefault","infoAutoReset","shadowMapAutoUpdate","shadowMapNeedsUpdate","statusMessage","onMaterialDispose","releaseMaterialProgramReferences","deallocateMaterial","forceContextLoss","loseContext","forceContextRestore","restoreContext","getPixelRatio","setPixelRatio","updateStyle","setViewport","getDrawingBufferSize","setDrawingBufferSize","getCurrentViewport","getScissor","setScissor","getScissorTest","setOpaqueSort","setTransparentSort","onXRSessionStart","onXRSessionEnd","needsProgramChange","needsLights","lightsStateVersion","getProgram","refreshProgram","refreshMaterial","refreshLights","p_uniforms","m_uniforms","uCamPos","cameraPosition","boneTexture","computeBoneTexture","boneTextureSize","upload","uniformsList","setProgram","rangeFactor","dataCount","rangeStart","rangeCount","drawStart","drawEnd","drawCount","isLineSegments","isLineLoop","isSprite","projectObject","isLOD","renderScene","opaqueObjects","transmissiveObjects","transparentObjects","renderObjects","renderTransmissionPass","programCacheKey","updateCommonMaterialProperties","materialNeedsLights","progUniforms","seqWithValue","camera2","defaultFramebuffer","__useDefaultFramebuffer","useDefaultFramebuffer","isRenderTarget3D","layer","framebufferTextureLayer","readRenderTargetPixels","activeCubeFaceIndex","textureFormat","IMPLEMENTATION_COLOR_READ_FORMAT","halfFloatSupportedByExt","IMPLEMENTATION_COLOR_READ_TYPE","copyFramebufferToTexture","levelScale","copyTexSubImage2D","copyTextureToTexture","srcTexture","dstTexture","copyTextureToTexture3D","sourceBox","glTarget","unpackRowLen","UNPACK_ROW_LENGTH","unpackImageHeight","UNPACK_IMAGE_HEIGHT","unpackSkipPixels","UNPACK_SKIP_PIXELS","unpackSkipRows","UNPACK_SKIP_ROWS","unpackSkipImages","UNPACK_SKIP_IMAGES","compressedTexSubImage3D","resetState","__THREE_DEVTOOLS__","CustomEvent","detail","WebGL1Renderer","FogExp2","Fog","Scene","InterleavedBuffer","isInterleavedBuffer","arrayBuffers","_uuid","_vector$6","InterleavedBufferAttribute","interleavedBuffer","interleavedBuffers","_geometry","_intersectPoint","_worldScale","_mvPosition","_alignedPosition","_rotatedPosition","_viewWorldMatrix","_vA","_vB","_vC","_uvA","_uvB","_uvC","Sprite","float32Array","transformVertex","vertexPosition","mvPosition","_v1$2","_v2$1","LOD","_currentLevel","addLevel","getCurrentLevel","getObjectForDistance","_basePosition","_skinIndex","_skinWeight","_vector$5","SkinnedMesh","bindMatrixInverse","calculateInverses","normalizeSkinWeights","skinWeight","skinIndex","boneIndex","bones","boneInverses","Bone","isBone","DataTexture","_offsetMatrix","_identityMatrix","Skeleton","boneMatrices","bone","getBoneByName","boneInverse","InstancedBufferAttribute","_instanceLocalMatrix","_instanceWorldMatrix","_instanceIntersects","_mesh","InstancedMesh","getColorAt","getMatrixAt","raycastTimes","instanceId","setColorAt","setMatrixAt","linecap","linejoin","_start$1","_end$1","_inverseMatrix$1","_ray$1","_sphere$1","Line","computeLineDistances","lineDistances","localThreshold","localThresholdSq","vStart","vEnd","interSegment","interRay","_start","_end","LineSegments","LineLoop","_inverseMatrix","_ray","_sphere","_position$2","Points","testPoint","rayPointDistanceSq","intersectPoint","distanceToRay","CompressedTexture","Curve","arcLengthDivisions","getPoint","getPointAt","optionalTarget","getUtoTmapping","getPoints","divisions","getSpacedPoints","getLength","getLengths","cacheArcLengths","current","updateArcLengths","arcLengths","targetArcLength","comparison","lengthBefore","getTangent","pt1","pt2","getTangentAt","computeFrenetFrames","segments","closed","binormals","tz","EllipseCurve","aX","aY","xRadius","yRadius","aStartAngle","aEndAngle","aClockwise","aRotation","isEllipseCurve","twoPi","deltaAngle","samePoints","ArcCurve","aRadius","isArcCurve","CubicPoly","initCatmullRom","tension","initNonuniformCatmullRom","dt0","dt1","dt2","calc","py","pz","CatmullRomCurve3","curveType","isCatmullRomCurve3","intPoint","CatmullRom","QuadraticBezier","QuadraticBezierP0","QuadraticBezierP1","QuadraticBezierP2","CubicBezier","CubicBezierP0","CubicBezierP1","CubicBezierP2","CubicBezierP3","CubicBezierCurve","v3","isCubicBezierCurve","CubicBezierCurve3","isCubicBezierCurve3","LineCurve","isLineCurve","LineCurve3","isLineCurve3","QuadraticBezierCurve","isQuadraticBezierCurve","QuadraticBezierCurve3","isQuadraticBezierCurve3","SplineCurve","isSplineCurve","Curves","CurvePath","curves","autoClose","curve","closePath","startPoint","endPoint","curveLengths","getCurveLengths","segmentLength","lens","cacheLengths","pts","Path","currentPoint","moveTo","lineTo","quadraticCurveTo","aCPx","aCPy","bezierCurveTo","aCP1x","aCP1y","aCP2x","aCP2y","splineThru","npts","arc","absarc","absellipse","ellipse","firstPoint","lastPoint","LatheGeometry","phiStart","phiLength","initNormals","inverseSegments","curNormal","prevNormal","CapsuleGeometry","capSegments","radialSegments","CircleGeometry","thetaStart","thetaLength","segment","CylinderGeometry","radiusTop","radiusBottom","openEnded","indexArray","generateCap","centerIndexStart","centerIndexEnd","slope","indexRow","generateTorso","ConeGeometry","PolyhedronGeometry","vertexBuffer","uvBuffer","subdivideFace","aj","pushVertex","getVertexByIndex","correctUV","azimuth","subdivide","applyRadius","centroid","azi","correctUVs","correctSeam","generateUVs","DodecahedronGeometry","_v0","_v1$1","_normal","_triangle","EdgesGeometry","thresholdAngle","precisionPoints","thresholdDot","indexAttr","positionAttr","indexCount","indexArr","vertKeys","hashes","edgeData","jNext","vecHash0","vecHash1","reverseHash","index0","Shape","holes","getPointsHoles","holesPts","extractPoints","hole","linkedList","clockwise","signedArea","insertNode","removeNode","filterPoints","again","steiner","area","earcutLinked","ear","invSize","zOrder","prevZ","nextZ","numMerges","pSize","qSize","inSize","sortLinked","indexCurve","isEarHashed","isEar","cureLocalIntersections","splitEarcut","pointInTriangle","minTX","minTY","maxTX","maxTY","locallyInside","isValidDiagonal","splitPolygon","compareX","eliminateHole","outerNode","hx","hy","mx","my","tanMin","sectorContainsSector","findHoleBridge","getLeftmost","intersectsPolygon","inside","middleInside","q1","q2","o3","o4","onSegment","an","bp","ShapeUtils","contour","holeIndices","faces","removeDupEndPts","addContour","holeIndex","hasHoles","outerLen","eliminateHoles","Earcut","ExtrudeGeometry","verticesArray","uvArray","addShape","placeholder","curveSegments","steps","bevelEnabled","bevelThickness","bevelSize","bevelOffset","bevelSegments","extrudePath","uvgen","UVGenerator","WorldUVGenerator","amount","extrudePts","splineTube","binormal","position2","extrudeByPath","shapePoints","isClockWise","hl","ahole","triangulateShape","scalePt2","vlen","flen","getBevelVec","inPt","inPrev","inNext","v_trans_x","v_trans_y","shrink_by","v_prev_x","v_prev_y","v_next_x","v_next_y","v_prev_lensq","collinear0","v_prev_len","v_next_len","ptPrevShift_x","ptPrevShift_y","sf","v_trans_lensq","direction_eq","contourMovements","holesMovements","oneHoleMovements","verticesMovements","bs","sidewalls","layeroffset","sl","slen1","slen2","f4","f3","addVertex","nextIndex","generateTopUV","addUV","generateSideWallUV","vector2","buildLidFaces","buildSideFaces","toJSON$1","geometryShapes","indexA","indexB","indexC","a_x","a_y","b_x","b_y","c_x","c_y","indexD","a_z","b_z","c_z","d_x","d_y","d_z","IcosahedronGeometry","OctahedronGeometry","RingGeometry","innerRadius","outerRadius","thetaSegments","phiSegments","radiusStep","thetaSegmentLevel","ShapeGeometry","indexOffset","shapeVertices","shapeHoles","shapeHole","SphereGeometry","thetaEnd","grid","verticesRow","uOffset","TetrahedronGeometry","TorusGeometry","tube","tubularSegments","TorusKnotGeometry","P1","P2","calculatePositionOnCurve","cu","su","quOverP","cs","TubeGeometry","frames","generateSegment","generateIndices","generateBufferData","WireframeGeometry","edges","ol","isUniqueEdge","hash1","hash2","Geometries","BoxBufferGeometry","CapsuleBufferGeometry","CircleBufferGeometry","ConeBufferGeometry","CylinderBufferGeometry","DodecahedronBufferGeometry","ExtrudeBufferGeometry","IcosahedronBufferGeometry","LatheBufferGeometry","OctahedronBufferGeometry","PlaneBufferGeometry","PolyhedronBufferGeometry","RingBufferGeometry","ShapeBufferGeometry","SphereBufferGeometry","TetrahedronBufferGeometry","TorusBufferGeometry","TorusKnotBufferGeometry","TubeBufferGeometry","RawShaderMaterial","_sheen","_clearcoat","_iridescence","_transmission","materialLib","AnimationUtils","arraySlice","isTypedArray","convertArray","forceClone","ArrayBuffer","isView","DataView","getKeyframeOrder","sortedArray","nValues","srcOffset","flattenJSON","jsonKeys","valuePropertyName","subclip","sourceClip","startFrame","endFrame","clip","tracks","track","valueSize","getValueSize","minStartTime","resetDuration","makeClipAdditive","targetClip","referenceFrame","referenceClip","numTracks","referenceTime","referenceTrack","referenceTrackType","ValueTypeName","targetTrack","referenceOffset","referenceValueSize","createInterpolant","isInterpolantFactoryMethodGLTFCubicSpline","targetOffset","targetValueSize","referenceValue","startIndex","endIndex","interpolant","resultBuffer","numTimes","valueStart","multiplyQuaternionsFlat","valueEnd","blendMode","Interpolant","parameterPositions","sampleValues","sampleSize","_cachedIndex","settings","DefaultSettings_","validate_interval","seek","linear_scan","forward_scan","giveUpAt","copySampleValue_","t1global","intervalChanged_","interpolate_","getSettings_","CubicInterpolant","_weightPrev","_offsetPrev","_weightNext","_offsetNext","endingStart","endingEnd","iPrev","iNext","tPrev","tNext","halfDt","o0","oP","oN","wP","wN","ppp","sP","sN","LinearInterpolant","offset1","offset0","weight1","weight0","DiscreteInterpolant","KeyframeTrack","interpolation","TimeBufferType","ValueBufferType","setInterpolation","DefaultInterpolation","trackType","getInterpolation","InterpolantFactoryMethodDiscrete","InterpolantFactoryMethodLinear","InterpolantFactoryMethodSmooth","factoryMethod","timeOffset","timeScale","startTime","endTime","nKeys","prevTime","currTime","optimize","smoothInterpolation","writeIndex","keep","offsetP","offsetN","readOffset","writeOffset","TypedKeyframeTrack","BooleanKeyframeTrack","ColorKeyframeTrack","NumberKeyframeTrack","QuaternionLinearInterpolant","slerpFlat","QuaternionKeyframeTrack","StringKeyframeTrack","VectorKeyframeTrack","AnimationClip","duration","NormalAnimationBlendMode","jsonTracks","frameTime","parseKeyframeTrack","clipTracks","morphTargetSequence","noLoop","numMorphTargets","objectOrClipArray","clipArray","animationToMorphTargets","pattern","animationMorphTargets","clips","CreateFromMorphTargetSequence","addNonemptyTrack","trackName","animationKeys","propertyName","destTracks","clipName","hierarchyTracks","hierarchy","morphTargetNames","morphTargetName","animationKey","boneName","getTrackTypeForValueTypeName","Cache","files","file","LoadingManager","onLoad","onProgress","onError","urlModifier","isLoading","itemsLoaded","itemsTotal","handlers","onStart","itemStart","itemEnd","itemError","resolveURL","setURLModifier","addHandler","removeHandler","getHandler","DefaultLoadingManager","Loader","manager","crossOrigin","withCredentials","resourcePath","setCrossOrigin","setWithCredentials","setPath","setResourcePath","setRequestHeader","loading","req","Request","headers","Headers","credentials","mimeType","responseType","response","ReadableStream","body","getReader","callbacks","reader","contentLength","lengthComputable","loaded","stream","readData","read","close","byteLength","ProgressEvent","enqueue","Response","arrayBuffer","blob","DOMParser","parseFromString","label","decoder","TextDecoder","decode","catch","finally","setResponseType","setMimeType","ImageLoader","onImageLoad","removeEventListeners","onImageError","Light","HemisphereLight","_projScreenMatrix$1","_lightPositionWorld$1","_lookTarget$1","LightShadow","_frameExtents","_viewportCount","_viewports","shadowMatrix","viewportIndex","SpotLightShadow","isSpotLightShadow","SpotLight","_lightPositionWorld","_lookTarget","PointLightShadow","_cubeDirections","_cubeUps","PointLight","DirectionalLightShadow","isDirectionalLightShadow","DirectionalLight","AmbientLight","RectAreaLight","SphericalHarmonics3","isSphericalHarmonics3","getAt","coeff","getIrradianceAt","addScaledSH","shBasis","LightProbe","MaterialLoader","getTexture","shading","setTextures","LoaderUtils","decodeURIComponent","lastIndexOf","InstancedBufferGeometry","BufferGeometryLoader","interleavedBufferMap","arrayBufferMap","getInterleavedBuffer","getArrayBuffer","typedArray","bufferAttribute","drawcalls","offsets","TEXTURE_MAPPING","TEXTURE_WRAPPING","TEXTURE_FILTER","AudioContext","webkitAudioContext","_eyeRight","_eyeLeft","_projectionMatrix","Clock","autoStart","oldTime","elapsedTime","running","getElapsedTime","getDelta","newTime","performance","_position$1","_quaternion$1","_scale$1","_orientation$1","Audio","gain","createGain","connect","getInput","autoplay","detune","loop","loopStart","loopEnd","playbackRate","isPlaying","hasPlaybackControl","sourceType","_startedAt","_progress","_connected","filters","getOutput","setNodeSource","audioNode","setMediaElementSource","mediaElement","createMediaElementSource","setMediaStreamSource","mediaStream","createMediaStreamSource","setBuffer","audioBuffer","play","delay","currentTime","createBufferSource","onended","onEnded","setDetune","setPlaybackRate","pause","getFilters","setFilters","setTargetAtTime","getDetune","getFilter","setFilter","getPlaybackRate","getLoop","setLoop","setLoopStart","setLoopEnd","getVolume","setVolume","_position","_quaternion","_scale","_orientation","PropertyMixer","binding","mixFunction","mixFunctionAdditive","setIdentity","_slerp","_slerpAdditive","_setAdditiveIdentityQuaternion","_workIndex","_select","_setAdditiveIdentityOther","_lerp","_lerpAdditive","_setAdditiveIdentityNumeric","_mixBufferRegion","_mixBufferRegionAdditive","_setIdentity","_origIndex","_addIndex","cumulativeWeight","cumulativeWeightAdditive","useCount","referenceCount","accuIndex","currentWeight","mix","accumulateAdditive","weightAdditive","originalValueOffset","saveOriginalState","getValue","restoreOriginalState","targetIndex","workOffset","_reservedRe","_wordChar","_wordCharOrDot","_directoryRe","_nodeRe","_objectRe","_propertyRe","_trackRe","_supportedObjectNames","PropertyBinding","rootNode","parsedPath","parseTrackName","findNode","nodeName","_getValue_unbound","_setValue_unbound","isAnimationObjectGroup","Composite","objectName","objectIndex","propertyIndex","lastDot","searchNodeSubtree","childNode","subTreeNode","_getValue_unavailable","_setValue_unavailable","_getValue_direct","targetObject","_getValue_array","resolvedProperty","_getValue_arrayElement","_getValue_toArray","_setValue_direct","_setValue_direct_setNeedsUpdate","_setValue_direct_setMatrixWorldNeedsUpdate","_setValue_array","dest","_setValue_array_setNeedsUpdate","_setValue_array_setMatrixWorldNeedsUpdate","_setValue_arrayElement","_setValue_arrayElement_setNeedsUpdate","_setValue_arrayElement_setMatrixWorldNeedsUpdate","_setValue_fromArray","_setValue_fromArray_setNeedsUpdate","_setValue_fromArray_setMatrixWorldNeedsUpdate","targetArray","sourceArray","nodeProperty","versioning","Versioning","None","NeedsUpdate","MatrixWorldNeedsUpdate","bindingType","BindingType","Direct","ArrayElement","HasFromToArray","EntireArray","GetterByBindingType","SetterByBindingTypeAndVersioning","unbind","targetGroup","optionalParsedPath","_targetGroup","_bindings","subscribe_","firstValidIndex","nCachedObjects_","bindings","AnimationAction","mixer","localRoot","_mixer","_clip","_localRoot","nTracks","interpolants","interpolantSettings","_interpolantSettings","_interpolants","_propertyBindings","_cacheIndex","_byClipCacheIndex","_timeScaleInterpolant","_weightInterpolant","_loopCount","_startTime","_effectiveTimeScale","_effectiveWeight","repetitions","paused","clampWhenFinished","zeroSlopeAtStart","zeroSlopeAtEnd","_activateAction","_deactivateAction","stopFading","stopWarping","isRunning","_isActiveAction","isScheduled","startAt","setEffectiveWeight","getEffectiveWeight","fadeIn","_scheduleFading","fadeOut","crossFadeFrom","fadeOutAction","warp","fadeInDuration","fadeOutDuration","startEndRatio","endStartRatio","crossFadeTo","fadeInAction","weightInterpolant","_takeBackControlInterpolant","setEffectiveTimeScale","getEffectiveTimeScale","setDuration","syncWith","action","halt","startTimeScale","endTimeScale","_lendControlInterpolant","timeScaleInterpolant","getMixer","getClip","getRoot","_root","_update","deltaTime","timeDirection","_updateWeight","timeRunning","_updateTimeScale","clipTime","_updateTime","propertyMixers","interpolantValue","loopCount","pingPong","_setEndings","handle_stop","loopDelta","pending","atStart","atEnd","weightNow","weightThen","_controlInterpolantsResultBuffer","ascSort","intersectObject","_vector$4","_startP","_startEnd","_vector$3","_vector$2","_boneMatrix","_matrixWorldInv","getBoneList","boneList","_vector$1","_color1","_color2","_v1","_v2","_v3","_vector","_camera","setPoint","pointMap","_box","_axis","_lineGeometry","_coneGeometry","_buffer","_floatView","_uint32View","_baseTable","_shiftTable","_mantissaTable","_exponentTable","_offsetTable","revision","__THREE__","ACESFilmicToneMapping","AddOperation","AdditiveBlending","AlphaFormat","AlwaysDepth","AlwaysStencilFunc","AmbientLightProbe","isAmbientLightProbe","AnimationLoader","AnimationMixer","_initMemoryManager","_accuIndex","_bindAction","prototypeAction","rootUuid","bindingsByRoot","_bindingsByRootAndName","bindingsByName","_addInactiveBinding","clipUuid","actionsForClip","_actionsByClip","knownActions","_addInactiveAction","_lendBinding","_lendAction","_takeBackBinding","_takeBackAction","_actions","_nActiveActions","_nActiveBindings","_controlInterpolants","_nActiveControlInterpolants","stats","actions","inUse","controlInterpolants","actionsByClip","actionByRoot","_removeInactiveAction","lastInactiveAction","cacheIndex","knownActionsForClip","lastKnownAction","byClipCacheIndex","_removeInactiveBindingsForAction","_removeInactiveBinding","prevIndex","lastActiveIndex","firstInactiveAction","firstInactiveIndex","lastActiveAction","bindingByName","propBinding","lastInactiveBinding","firstInactiveBinding","lastActiveBinding","__cacheIndex","lastActiveInterpolant","clipAction","optionalRoot","clipObject","findByName","existingAction","newAction","stopAllAction","nActions","nBindings","setTime","timeInSeconds","uncacheClip","actionsToRemove","uncacheRoot","uncacheAction","AnimationObjectGroup","_indicesByUUID","_paths","_parsedPaths","_bindingsIndicesByPath","bindingsPerObject","indicesByUUID","paths","parsedPaths","knownObject","nObjects","nCachedObjects","firstActiveIndex","lastCachedObject","bindingsForPath","lastCached","lastCachedIndex","firstActiveObject","firstActive","uncache","lastObject","indicesByPath","unsubscribe_","lastBindingsIndex","lastBindings","ArrowHelper","headLength","headWidth","cone","setDirection","setColor","AudioAnalyser","audio","fftSize","analyser","createAnalyser","frequencyBinCount","getFrequencyData","getByteFrequencyData","getAverageFrequency","AudioListener","destination","timeDelta","_clock","removeFilter","getMasterVolume","setMasterVolume","positionX","linearRampToValueAtTime","positionY","positionZ","forwardX","forwardY","forwardZ","upX","upY","upZ","setOrientation","bufferCopy","decodeAudioData","AxesHelper","setColors","xAxisColor","yAxisColor","zAxisColor","BackSide","BasicDepthPacking","BasicShadowMap","Box2","isBox2","Box3Helper","BoxHelper","ByteType","CameraHelper","colorFrustum","colorCone","colorUp","colorTarget","colorCross","addLine","addPoint","CanvasTexture","isCanvasTexture","CineonToneMapping","CompressedTextureLoader","loadTexture","texDatas","mipmapCount","isCubemap","CubeTextureLoader","urls","CullFaceBack","CullFaceFront","CullFaceFrontBack","CullFaceNone","CustomBlending","CustomToneMapping","Cylindrical","setFromCartesianCoords","DataTexture2DArray","DataTexture3D","DataTextureLoader","texData","DataUtils","DecrementStencilOp","DecrementWrapStencilOp","DirectionalLightHelper","lightPlane","targetLine","DoubleSide","DstAlphaFactor","DstColorFactor","DynamicCopyUsage","DynamicDrawUsage","DynamicReadUsage","EqualDepth","EqualStencilFunc","FlatShading","Float16BufferAttribute","Float64BufferAttribute","Font","FramebufferTexture","FrontSide","GLBufferAttribute","setType","setItemSize","setCount","GLSL1","GreaterDepth","GreaterEqualDepth","GreaterEqualStencilFunc","GreaterStencilFunc","GridHelper","HemisphereLightHelper","HemisphereLightProbe","isHemisphereLightProbe","sky","ground","ImageBitmapLoader","isImageBitmapLoader","createImageBitmap","setOptions","fetchOptions","colorSpaceConversion","imageBitmap","ImmediateRenderObject","IncrementStencilOp","IncrementWrapStencilOp","InstancedInterleavedBuffer","Int16BufferAttribute","Int32BufferAttribute","Int8BufferAttribute","IntType","InvertStencilOp","LessDepth","LessEqualDepth","LessEqualStencilFunc","LessStencilFunc","Line3","distanceSq","closestPointToPointParameter","clampToLine","startEnd2","LinearMipMapLinearFilter","LinearMipMapNearestFilter","LinearToneMapping","LoopOnce","LoopPingPong","LoopRepeat","LuminanceAlphaFormat","LuminanceFormat","MOUSE","LEFT","MIDDLE","RIGHT","ROTATE","DOLLY","PAN","MaxEquation","MinEquation","MixOperation","MultiplyBlending","MultiplyOperation","NearestMipMapLinearFilter","NearestMipMapNearestFilter","NeverDepth","NeverStencilFunc","NoBlending","NoColorSpace","NoToneMapping","NormalBlending","NotEqualDepth","NotEqualStencilFunc","ObjectLoader","extractUrlBase","parseAsync","parseAnimations","parseShapes","parseGeometries","parseImages","parseTextures","parseMaterials","parseSkeletons","bindSkeletons","hasImages","parseImagesAsync","bufferGeometryLoader","deserializeImage","loadImage","imageArray","deserializedImage","currentUrl","parseConstant","getGeometry","getMaterial","objectAnimations","setTexturePath","ObjectSpaceNormalMap","OneFactor","OneMinusDstAlphaFactor","OneMinusDstColorFactor","OneMinusSrcAlphaFactor","OneMinusSrcColorFactor","PCFShadowMap","PCFSoftShadowMap","ParametricGeometry","PlaneHelper","PointLightHelper","sphereSize","PolarGridHelper","radials","circles","PositionalAudio","panner","createPanner","panningModel","getRefDistance","refDistance","setRefDistance","getRolloffFactor","rolloffFactor","setRolloffFactor","getDistanceModel","distanceModel","setDistanceModel","getMaxDistance","maxDistance","setMaxDistance","setDirectionalCone","coneInnerAngle","coneOuterAngle","coneOuterGain","orientationX","orientationY","orientationZ","RGBADepthPacking","RGBAIntegerFormat","RGBFormat","RGB_ETC1_Format","RGFormat","RGIntegerFormat","Raycaster","setFromCamera","coords","intersectObjects","RedFormat","RedIntegerFormat","ReinhardToneMapping","ReplaceStencilOp","ReverseSubtractEquation","ShapePath","subPaths","currentPath","toShapes","isCCW","noHoles","toShapesNoHoles","inSubpaths","tmpPath","tmpShape","isPointInsidePolygon","inPolygon","polyLen","edgeLowPt","edgeHighPt","edgeDx","edgeDy","perpEdge","solid","holesFirst","betterShapeHoles","newShapes","tmpPoints","tmpHoles","newShapeHoles","mainIdx","ambiguous","toChange","sIdx","sLen","sho","hIdx","ho","hole_unassigned","s2Idx","ShortType","SkeletonHelper","isSkeletonHelper","SmoothShading","Spherical","makeSafe","EPS","SpotLightHelper","coneLength","coneWidth","SrcAlphaFactor","SrcAlphaSaturateFactor","SrcColorFactor","StaticCopyUsage","StaticReadUsage","StereoCamera","eyeSep","_cache","eyeSepHalf","eyeSepOnProjection","ymax","xmin","xmax","StreamCopyUsage","StreamDrawUsage","StreamReadUsage","SubtractEquation","SubtractiveBlending","TOUCH","DOLLY_PAN","DOLLY_ROTATE","TangentSpaceNormalMap","TextGeometry","TriangleFanDrawMode","TriangleStripDrawMode","TrianglesDrawMode","Uint8BufferAttribute","Uint8ClampedBufferAttribute","UnsignedShort4444Type","UnsignedShort5551Type","VSMShadowMap","VideoTexture","video","requestVideoFrameCallback","updateVideo","readyState","HAVE_CURRENT_DATA","WebGL3DRenderTarget","WebGLArrayRenderTarget","WebGLMultipleRenderTargets","WebGLMultisampleRenderTarget","ZeroFactor","ZeroStencilOp","isFont","generateShapes","line_height","yMax","yMin","underlineThickness","createPath","createPaths","glyph","glyphs","familyName","cpx","cpy","cpx1","cpy1","cpx2","cpy2","outline","_cachedOutline","ha","dracoLoader","ktx2Loader","meshoptDecoder","pluginCallbacks","register","GLTFMaterialsClearcoatExtension","GLTFTextureBasisUExtension","GLTFTextureWebPExtension","GLTFMaterialsSheenExtension","GLTFMaterialsTransmissionExtension","GLTFMaterialsVolumeExtension","GLTFMaterialsIorExtension","GLTFMaterialsEmissiveStrengthExtension","GLTFMaterialsSpecularExtension","GLTFMaterialsIridescenceExtension","GLTFLightsExtension","GLTFMeshoptCompression","_onError","gltf","setDRACOLoader","setDDSLoader","setKTX2Loader","setMeshoptDecoder","unregister","BINARY_EXTENSION_HEADER_MAGIC","EXTENSIONS","KHR_BINARY_GLTF","GLTFBinaryExtension","asset","GLTFParser","fileLoader","plugin","extensionsUsed","extensionName","extensionsRequired","KHR_MATERIALS_UNLIT","GLTFMaterialsUnlitExtension","KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS","GLTFMaterialsPbrSpecularGlossinessExtension","KHR_DRACO_MESH_COMPRESSION","GLTFDracoMeshCompressionExtension","KHR_TEXTURE_TRANSFORM","GLTFTextureTransformExtension","KHR_MESH_QUANTIZATION","GLTFMeshQuantizationExtension","setExtensions","setPlugins","GLTFRegistry","removeAll","KHR_LIGHTS_PUNCTUAL","KHR_MATERIALS_CLEARCOAT","KHR_MATERIALS_IOR","KHR_MATERIALS_SHEEN","KHR_MATERIALS_SPECULAR","KHR_MATERIALS_TRANSMISSION","KHR_MATERIALS_IRIDESCENCE","KHR_MATERIALS_VOLUME","KHR_TEXTURE_BASISU","KHR_MATERIALS_EMISSIVE_STRENGTH","EXT_TEXTURE_WEBP","EXT_MESHOPT_COMPRESSION","refs","uses","_markDefs","nodeDefs","nodeIndex","nodeLength","nodeDef","_addNodeRef","_loadLight","lightIndex","lightDef","lightNode","innerConeAngle","outerConeAngle","createUniqueName","createNodeAttachment","_getNodeRef","getMaterialType","extendParams","materialParams","materialDef","metallicRoughness","pbrMetallicRoughness","baseColorFactor","baseColorTexture","assignTexture","extendMaterialParams","emissiveStrength","clearcoatFactor","clearcoatTexture","clearcoatRoughnessFactor","clearcoatRoughnessTexture","clearcoatNormalTexture","iridescenceFactor","iridescenceTexture","iridescenceIor","iridescenceThicknessTexture","sheenColorFactor","sheenRoughnessFactor","sheenColorTexture","sheenRoughnessTexture","transmissionFactor","transmissionTexture","thicknessFactor","thicknessTexture","colorArray","specularFactor","specularTexture","specularColorFactor","specularColorTexture","textureIndex","textureDef","loadTextureImage","isSupported","textureLoader","uri","detectSupport","Image","onload","onerror","loadBufferView","bufferView","bufferViews","extensionDef","getDependency","supported","ready","byteOffset","byteStride","decodeGltfBuffer","headerView","header","magic","getUint32","chunkContentsLength","chunkView","chunkIndex","chunkLength","chunkType","contentArray","preload","decodePrimitive","primitive","bufferViewIndex","gltfAttributeMap","threeAttributeMap","attributeNormalizedMap","attributeTypeMap","attributeName","threeAttributeName","ATTRIBUTES","accessorDef","accessors","componentType","WEBGL_COMPONENT_TYPES","decodeDracoFile","extendTexture","texCoord","GLTFMeshStandardSGMaterial","isGLTFSpecularGlossinessMaterial","specularMapParsFragmentChunk","glossinessMapParsFragmentChunk","specularMapFragmentChunk","glossinessMapFragmentChunk","lightPhysicalFragmentChunk","glossiness","glossinessMap","_extraUniforms","uniformName","USE_SPECULARMAP","USE_GLOSSINESSMAP","USE_UV","specularGlossinessParams","pbrSpecularGlossiness","diffuseFactor","diffuseTexture","glossinessFactor","specularGlossinessTexture","specGlossMapDef","createMaterial","GLTFCubicSplineInterpolant","stride2","stride3","td","m0","m1","_q","GLTFCubicSplineQuaternionInterpolant","WEBGL_FILTERS","WEBGL_WRAPPINGS","WEBGL_TYPE_SIZES","POSITION","NORMAL","TANGENT","TEXCOORD_0","TEXCOORD_1","COLOR_0","WEIGHTS_0","JOINTS_0","PATH_PROPERTIES","translation","INTERPOLATION","CUBICSPLINE","STEP","addUnknownExtensionsToUserData","knownExtensions","objectDef","gltfExtensions","assignExtrasToUserData","gltfDef","extras","meshDef","targetNames","createPrimitiveKey","primitiveDef","dracoExtension","geometryKey","createAttributesKey","attributesKey","getNormalizedComponentScale","associations","primitiveCache","meshCache","cameraCache","lightCache","sourceCache","textureCache","nodeNamesUsed","isSafari","isFirefox","firefoxVersion","_invokeAll","ext","beforeRoot","getDependencies","scenes","afterRoot","skinDefs","skins","meshDefs","meshes","skinLength","skin","ref","updateMappings","mappings","_invokeOne","loadScene","loadNode","loadMesh","loadAccessor","loadBuffer","loadMaterial","loadSkin","loadAnimation","loadCamera","defs","bufferIndex","bufferDef","bufferViewDef","accessorIndex","pendingBufferViews","TypedArray","elementBytes","itemBytes","ibSlice","ibCacheKey","itemSizeIndices","SCALAR","TypedArrayIndices","byteOffsetIndices","byteOffsetValues","sparseIndices","sparseValues","sourceIndex","sourceDef","sampler","promise","loadImageSource","samplers","URL","webkitURL","sourceURI","isObjectURL","Blob","createObjectURL","revokeObjectURL","mapName","mapDef","gltfReference","assignFinalMaterial","useDerivativeTangents","useVertexColors","useFlatShading","pointsMaterial","lineMaterial","materialType","materialExtensions","sgExtension","kmuExtension","metallicFactor","roughnessFactor","metallicRoughnessTexture","alphaMode","alphaCutoff","normalTexture","occlusionTexture","strength","emissiveFactor","emissiveTexture","originalName","sanitizedName","loadGeometries","primitives","createDracoPrimitive","addPrimitiveAttributes","geometryPromise","meshIndex","toTrianglesDrawMode","cameraIndex","cameraDef","yfov","aspectRatio","znear","zfar","xmag","ymag","skinDef","skinEntry","inverseBindMatrices","accessor","animationIndex","animationDef","pendingNodes","pendingInputAccessors","pendingOutputAccessors","pendingSamplers","pendingTargets","channels","inputAccessors","outputAccessors","targets","inputAccessor","outputAccessor","targetName","outputArray","scaled","createNodeMesh","meshPromise","sceneIndex","sceneDef","nodeIds","buildNodeHierarchy","reducedAssociations","reduceAssociations","nodeId","parentObject","pendingJoints","jointNodes","jointNode","assignAttributeAccessor","gltfAttributeName","boxScale","maxDisplacement","computeBounds","hasMorphNormal","hasMorphColor","pendingPositionAccessors","pendingNormalAccessors","pendingColorAccessors","pendingAccessor","morphPositions","addMorphTargets","drawMode","numberOfTriangles","newIndices","newGeometry","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","amdD","amdO","nmd"],"sourceRoot":""}